/* ===================================================================
   GigCove — Bandcard Visual System
   =================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,700;9..144,800&family=Space+Grotesk:wght@400;500;600;700;800&display=swap');

/* ---------- Theme tokens ---------- */
:root{
  --bg-0:#070812;
  --bg-1:#0a0e27;
  --ink:rgba(255,255,255,.92);
  --ink-soft:rgba(255,255,255,.78);
  --ink-muted:rgba(255,255,255,.60);

  --c-cyan:#00d4ff;
  --c-pink:#ff3d7f;
  --c-violet:#8b5cff;

  --glass-bg:linear-gradient(135deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.05) 100%);
  --glass-border:rgba(255,255,255,.14);
  --glass-border-top:rgba(255,255,255,.22);
  --glass-blur:blur(22px) saturate(160%);

  --font-main:"Space Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-display:"Fraunces", ui-serif, Georgia, serif;
  --fs-body:16px;
  --fs-label:13px;
  --fs-button:14px;

  --btn-bg:linear-gradient(135deg, rgba(0,212,255,.95), rgba(255,61,127,.76));
  --btn-bg-hover:linear-gradient(135deg, rgba(66,228,255,.98), rgba(255,107,155,.82));
  --btn-color:#070812;
  --btn-radius:999px;
  --btn-shadow:0 12px 32px rgba(0,212,255,.24), 0 12px 36px rgba(255,61,127,.16);

  --x-bg:rgba(255,255,255,.08);
  --x-bg-hover:rgba(255,255,255,.15);
  --x-color:#fff;
  --x-size:28px;
  --x-font-size:16px;
  --x-shadow:none;

  --section-gap:28px;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:var(--fs-body)/1.55 var(--font-main);
  color:var(--ink);
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(255,61,127,.35), transparent 55%),
    radial-gradient(950px 650px at 85% 10%, rgba(0,212,255,.30), transparent 55%),
    radial-gradient(900px 640px at 70% 105%, rgba(139,92,255,.24), transparent 55%),
    linear-gradient(180deg, var(--bg-0), var(--bg-1) 55%, #060714);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
}

/* Background glow effect */
body::before{
  content:'';
  position:fixed;
  inset:0;
  opacity:.08;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  background-size:180px 180px;
  pointer-events:none;
  z-index:0;
}

a{color:var(--ink);text-decoration:none}
a:hover{color:#ffffff;text-decoration:underline;text-underline-offset:2px}

/* ---------- Header (Glass Morphism) ---------- */
.topbar{
  position:sticky;top:0;z-index:100;
  background:rgba(7,8,18,.58);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.10);
  box-shadow:0 8px 26px rgba(0,0,0,.24);
  transition:all 0.3s ease;
}
.topbar__inner{
  max-width:1200px;
  margin:0 auto;
  padding:16px 32px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.topbar__logo{
  display:flex;
  align-items:center;
  gap:12px;
  transition:transform 0.2s ease;
}
.topbar__logo:hover{
  transform:scale(1.02);
}
.brand__logo{
  display:block;
  height:56px;
  width:auto;
  filter:drop-shadow(0 2px 8px rgba(0,0,0,0.2));
}
.topnav{
  display:flex;
  align-items:center;
  gap:8px;
  margin-left:auto;
}
.topbar__link{
  color:#fff!important;
  font-weight:700;
  font-size:15px;
  line-height:1.3;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.05);
  transition:all 0.2s ease;
  position:relative;
}
.topbar__link::after{
  content:'';
  position:absolute;
  bottom:4px;
  left:16px;
  right:16px;
  height:2px;
  background:rgba(255,255,255,0.8);
  transform:scaleX(0);
  transition:transform 0.2s ease;
  border-radius:2px;
}
.topbar__link:hover{
  background:rgba(255,255,255,.12);
  text-decoration:none;
  transform:translateY(-1px);
}
.topbar__link:hover::after{
  transform:scaleX(1);
}
.topbar .user-email{
  color:var(--ink-soft)!important;
  font-weight:500;
  font-size:14px;
  line-height:1.3;
  padding:8px 16px;
  background:rgba(255,255,255,.06);
  border-radius:8px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  backdrop-filter:blur(8px);
}
.user-email::before{
  content:"👤";
  font-size:16px;
  margin:0;
}
.topbar .btn{
  background:var(--btn-bg);
  color:var(--btn-color);
  border:1px solid rgba(0,212,255,.40);
  padding:8px 20px;
  font-weight:700;
  font-size:14px;
  backdrop-filter:blur(8px);
  transition:all 0.2s ease;
  box-shadow:var(--btn-shadow);
}
.topbar .btn:hover{
  background:var(--btn-bg-hover);
  transform:translateY(-1px);
  box-shadow:0 16px 44px rgba(0,212,255,.30), 0 16px 56px rgba(255,61,127,.20);
}
.topbar .btn--muted{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.18);
  color:#ffffff;
  box-shadow:none;
}
.topbar .btn--muted:hover{
  background:rgba(255,255,255,0.15);
  border-color:rgba(255,255,255,0.3);
  box-shadow:0 2px 8px rgba(0,0,0,0.2);
}
@media (max-width:768px){
  .topbar__inner{
    padding:12px 20px;
  }
  .brand__logo{
    height:48px;
  }
  .topnav{
    gap:4px;
  }
  .topbar__link{
    padding:6px 12px;
    font-size:14px;
  }
}

/* ---------- Page frame & gating ---------- */
.frame{max-width:1200px;margin:20px auto 40px;padding:0 20px;overflow:visible;position:relative;z-index:1}

/* Remove legacy separators per your request */
.hairline{display:none!important;height:0}

/* Auth gating (body.auth = logged in) */
#appSection{display:none}
body.auth #appSection{display:block}
#authSection{display:none}
body:not(.auth) #authSection{display:grid}

/* ---------- Top stats (mast) ---------- */
.mast{display:none}
body.auth .mast{display:block}
.topbar + .mast{margin-top:var(--section-gap)}
.mast{margin-bottom:var(--section-gap);padding:6px 20px}
.mast__stats{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;max-width:1200px;margin:0 auto;
}
.stat{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:10px 14px;text-align:center;
  box-shadow:0 12px 32px rgba(0,0,0,.26);
}
.stat__label{font:600 var(--fs-label)/1.4 var(--font-main);color:var(--ink-muted);margin-bottom:4px}
.stat__num{font:800 15px/1.2 var(--font-main);color:#ffffff}
.stat__num--lg{font:900 22px/1.2 var(--font-main)}
.stat--actions .stat__buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
@media (max-width:980px){.mast__stats{grid-template-columns:1fr}}

/* ---------- Grid ---------- */
.grid{display:grid;gap:28px}
.grid--2{grid-template-columns:1fr 1fr}
.col{min-width:0}
@media (max-width:980px){.grid--2{grid-template-columns:1fr}}

/* ---------- Cards (Glass Morphism) ---------- */
.card{
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-top:1px solid var(--glass-border-top);
  border-radius:22px;
  box-shadow:0 22px 60px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.14);
  overflow:hidden;
  position:relative;
}
.card::before{
  content:'';
  position:absolute;
  top:-2px;
  left:10%;
  right:10%;
  height:70px;
  background:radial-gradient(ellipse at top, rgba(255,255,255,0.18) 0%, transparent 70%);
  filter:blur(15px);
  pointer-events:none;
}
.card__hd{padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,0.1);position:relative;z-index:1}
.card__hd h1,
.card__hd h2{
  margin:0;
  font:800 1.45rem/1.2 var(--font-display);
  color:#ffffff;
  letter-spacing:-.02em;
}
.card__sub{margin:8px 0 0;color:var(--ink-soft);font-weight:500;font-size:0.9375rem}
.card__bd{padding:20px 24px 24px;position:relative;z-index:1}
.col .card + .card{margin-top:24px}
.mb-4{margin-bottom:24px}

/* ---------- Buttons ---------- */
.btn,
button,
a.btn,
input[type="button"].btn,
input[type="submit"].btn{
  -webkit-appearance:none;appearance:none;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-main);font-size:var(--fs-button);line-height:1.25;font-weight:700;
  color:var(--btn-color);background:var(--btn-bg);
  padding:8px 18px;border:0;border-radius:var(--btn-radius);
  box-shadow:var(--btn-shadow);
  cursor:pointer;text-decoration:none;
  transition:all .2s ease;
}
.btn:hover{background:var(--btn-bg-hover);transform:translateY(-1px);box-shadow:0 6px 16px rgba(0, 212, 255, 0.4)}
.btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(0, 212, 255, 0.3)}
.btn--muted{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  box-shadow:none;
}
.btn--sm{font-size:13px;padding:4px 10px}

/* Small nudges - only for form buttons, not header */
#saveSetBtn,#addSongForm .btn{position:relative;top:-3px}
#applyGapBtn{position:relative;top:2px}

/* ---------- Forms (Glass Theme) ---------- */
.field{display:grid;gap:8px;position:relative}
.field__label{font:600 var(--fs-label)/1.4 var(--font-main);color:rgba(255,255,255,0.9)}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
textarea,
select{
  width:100%;
  background:rgba(255,255,255,0.08);
  color:#ffffff;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:12px;
  padding:12px 16px;
  outline:none;
  transition:all .2s ease;
  font-size:14px;
  line-height:1.4;
  font-family:var(--font-main);
}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,0.4);font-style:normal}
input:hover,textarea:hover,select:hover{
  border-color:rgba(255,255,255,0.3);
  background:rgba(255,255,255,0.1);
}
input:focus,textarea:focus,select:focus{
  border-color:rgba(0,212,255,.62);
  background:rgba(255,255,255,0.12);
  box-shadow:0 0 0 4px rgba(0,212,255,.12);
}
textarea{min-height:110px;resize:vertical}
select{cursor:pointer}

/* Field with inline clear “✕” */
.field--withClear{position:relative;display:block}
.field--withClear .field__label{display:block;margin:0 0 8px}
.field--withClear input{display:block;width:100%;padding-right:48px;min-width:0}
.field--withClear .field__clear{
  position:absolute;right:12px;top:50%;
  transform:translateY(-50%); /* perfectly centered */
  width:var(--x-size);height:var(--x-size);
  border:1px solid rgba(255,255,255,0.15);border-radius:50%;
  background:var(--x-bg);color:var(--x-color);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  font-size:var(--x-font-size);font-weight:400;line-height:1;cursor:pointer;z-index:2;
  transition:all .2s ease;
}
.field--withClear .field__clear:hover{
  background:var(--x-bg-hover);
  border-color:rgba(255,255,255,0.3);
  transform:translateY(-50%) scale(1.1);
}

/* Inline chips (ALL CAPS, numbers, etc.) */
.inline-chips{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.chip__label{font:600 var(--fs-label)/1.4 var(--font-main);color:rgba(255,255,255,0.7)}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 12px;
  border:1px solid rgba(255,255,255,0.2);
  border-radius:10px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  font-weight:600;
  color:#ffffff;
  transition:all .2s ease;
  cursor:pointer;
}
.chip:hover{
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.3);
}
.chip input[type="checkbox"],.chip input[type="radio"]{
  width:16px;height:16px;
  accent-color:#00d4ff;
  cursor:pointer;
}
.chip span{font-size:14px;color:#ffffff}

/* Chip groups with labels (Position: Left/Center) */
.chip-group{
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 14px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:12px;
  flex-wrap:nowrap;
}
.chip-group .chip__label{
  font-weight:600;
  font-size:13px;
  color:rgba(255,255,255,0.9);
  margin-right:4px;
  white-space:nowrap;
  flex-shrink:0;
}
.chip-group input[type="text"]{
  width:60px;
  padding:4px 8px;
  font-size:13px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.2);
  color:#ffffff;
  border-radius:8px;
  height:26px;
  line-height:1;
  text-align:center;
  font-weight:600;
  box-sizing:border-box;
}
.chip-group input[type="text"]:focus{
  background:rgba(255,255,255,0.12);
  border-color:#00d4ff;
  outline:none;
}

/* Settings layout */
.grid--settings-top{
  display:grid;
  grid-template-columns:1.2fr 1.2fr .7fr .9fr auto;
  gap:12px 14px;align-items:end;
}
.grid--settings-bottom{
  display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center;margin-top:12px;
}

/* Input widths */
#bandName,#venueName,#setName{max-width:30ch}
#eventDate{max-width:19ch}
@media (max-width:1100px){
  #bandName,#venueName,#setName,#eventDate{max-width:100%}
}

/* “Time Between Songs” */
.gap-setting{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:nowrap}
.gap-setting .gap-label{font-weight:600;font-size:13px;color:rgba(255,255,255,0.9);white-space:nowrap}
.gap-setting input[type="text"]{width:92px;flex:0 0 auto;text-align:center;height:36px;line-height:36px;padding:0 10px}

/* Responsive collapse for settings */
@media (max-width:1100px){
  .grid--settings-top{grid-template-columns:1fr 1fr}
  .grid--settings-top .w-260{grid-column:1 / -1}
  .grid--settings-top .actions-wrap{grid-column:1 / -1;justify-content:flex-start;gap:10px}
}
@media (max-width:640px){
  .grid--settings-top{grid-template-columns:1fr}
  .grid--settings-top .w-260,
  .grid--settings-top .actions-wrap,
  .grid--settings-top .field{grid-column:1 / -1}
}

/* Add Song row */
#addSongForm.grid--addsong{
  display:grid;grid-template-columns:minmax(240px,1fr) 120px auto;
  column-gap:12px;row-gap:8px;align-items:end;
}

/* ---------- Lists (library & setlist cards) - Glass ---------- */
.list{display:grid;gap:14px}
.item{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;
  padding:14px 16px;
  background:linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  backdrop-filter:blur(15px);
  -webkit-backdrop-filter:blur(15px);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:12px;
  transition:all .2s cubic-bezier(0.4, 0, 0.2, 1);
}
.item:hover{
  border-color:rgba(255,255,255,0.25);
  box-shadow:0 6px 20px rgba(0,0,0,0.25);
  background:linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.04) 100%);
  transform:translateY(-2px);
}
.item strong{font-weight:700;letter-spacing:.05px;color:#ffffff}
.item .meta{color:rgba(255,255,255,0.65);font-size:13px}
.dragHandle{cursor:grab;user-select:none;color:rgba(255,255,255,0.5);padding:0 6px;font-size:18px}

/* Remove button (X) within list items */
.item .row .rmBtn{
  all:unset;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--x-bg);color:var(--x-color);
  width:var(--x-size);height:var(--x-size);
  border-radius:50%;font-size:var(--x-font-size);font-weight:700;line-height:1;
  cursor:pointer;box-shadow:var(--x-shadow);
  transition:background .2s ease,transform .05s ease;
}
.item .row .rmBtn:hover{background:var(--x-bg-hover)}

/* Gap inputs (song + encore) */
#setList .row input.gap,
#setList .row input.sepTime{width:9ch;text-align:center;font-family:monospace;padding:2px 6px}
#setList .row input.gap::placeholder,
#setList .row input.sepTime::placeholder{font-style:normal;color:rgba(255,255,255,0.4)}

/* ---------- Preview & Print (screen preview only) ---------- */
.preview{background:#fff;border:1px solid #e6e9ee;border-radius:10px;padding:12px}

/* Authoritative preview canvas — locks to 8.5:11 and 550px max width */
@media screen{
  #printSurface{
    aspect-ratio:8.5 / 11;
    width:100%;
    max-width:550px;
    margin:0 auto;
    position:relative;
    display:flex;
    flex-direction:column;
    overflow:hidden; /* keep content inside */
    background:#fff;
  }
}

/* Header & footer black bars (preview + print colors retained) */
#printMeta,
#printFooter{
  background:#000;color:#fff;font-weight:800;text-align:center;
  border-radius:6px;line-height:1.2;
}
#printMeta{padding:6px 10px;margin:0 0 10px}
#printFooter{padding:6px 10px;margin-top:10px;font-size:10pt}

/* Encore line (within list) */
.encore-line{
  text-align:center;background:#eef1f6;color:#0e1420;
  font-weight:900;margin:10px 0;padding:7px 0 8px;border-radius:10px;letter-spacing:.6px;display:block;
}

/* Keep black bars solid on real printers */
@media print{
  #printMeta,#printFooter{
    -webkit-print-color-adjust:exact;print-color-adjust:exact;
  }
}

/* List inside the preview surface — JS controls sizing/fit */
.preview__list,
#printList{
  list-style:none;padding:0;margin:0;
  white-space:nowrap;width:100%;box-sizing:border-box;
  text-align:center; /* Default center, JavaScript can override */
}
.preview__list li,
#printList li{
  white-space:nowrap;word-break:keep-all;margin:0;
}

/* ---------- Auth / Landing visuals ---------- */
#authSection{margin-top:18px}
#authSection .card{margin-bottom:20px}
.auth-hero{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 22px 60px rgba(0,0,0,.34);
  background:linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  backdrop-filter:blur(20px) saturate(160%);
}
.auth-hero__inner{
  display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;padding:28px;
}
.fancy-hero{max-width:720px}
.fancy-hero .hero-eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:6px}
.fancy-hero h1{margin:0 0 10px;color:#ffffff;font-family:var(--font-display);font-size:clamp(1.8rem,2.8vw,2.4rem);line-height:1.1}
.fancy-hero .hero-lead{font-size:16px;color:rgba(255,255,255,0.85);margin:0 0 18px}
.hero-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0 18px}
.kpi{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.16);
  border-radius:12px;
  padding:12px 14px;
  box-shadow:0 12px 24px rgba(0,0,0,.24);
}
.kpi-num{font-weight:800;font-size:17px;color:#ffffff;line-height:1.1}
.kpi-label{font-size:12px;color:var(--ink-muted)}
.checklist{list-style:none;margin:6px 0 14px;padding:0;display:grid;gap:8px}
.checklist li{position:relative;padding-left:28px;font-size:14px;color:rgba(255,255,255,0.9)}
.checklist li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg, rgba(0,212,255,.80), rgba(139,92,255,.72));
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.checklist li::after{
  content:"";position:absolute;left:5px;top:8px;width:8px;height:4px;border:2px solid #fff;border-top:0;border-right:0;transform:rotate(-45deg);
}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px}
.badge{font-size:12px;color:#ffffff;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);padding:6px 10px;border-radius:999px}
.auth-hero__art{height:220px}
.auth-hero__art img{
  display:block;width:92%;height:100%;margin-left:auto;border-radius:14px;box-shadow:0 14px 40px rgba(0,0,0,.18);
  object-fit:cover;object-position:right center;filter:brightness(.9) contrast(1.05) saturate(1.05);
}
#authSection .grid.grid--2{display:grid;grid-template-columns:1fr 1fr;gap:20px;border-top:1px solid rgba(255,255,255,.12);padding-top:20px}
#authSection .card__hd h2{margin:0}
#authSection .card__bd{padding-top:14px}
.form-gap{height:12px}
#authSection .auth-links{margin-top:10px}
#authSection .auth-links .topbar__link{color:rgba(255,255,255,0.9);text-decoration:none;font-weight:600}
#authSection .auth-links .topbar__link:hover{text-decoration:underline}

/* ---------- Auth responsive ---------- */
@media (max-width:980px){
  .auth-hero__inner{grid-template-columns:1fr;gap:18px;padding:22px}
  .auth-hero__art{height:180px}
  #authSection .grid.grid--2{grid-template-columns:1fr;gap:18px}
}
@media (max-width:560px){
  .hero-kpis{grid-template-columns:1fr}
  .auth-hero__copy h1{font-size:24px}
  .auth-hero__art{height:160px}
}

/* ---------- Utility pages ---------- */
body.auth-shell{
  display:grid;
  place-items:center;
  min-height:100vh;
  padding:24px;
}

.utility-card{
  width:min(460px, 100%);
}

.utility-card h2{
  margin:0 0 10px;
  text-align:center;
  font-family:var(--font-display);
  font-size:clamp(1.8rem, 4vw, 2.1rem);
  line-height:1.1;
}

.utility-card p{
  margin:0 0 18px;
  text-align:center;
  color:var(--ink-soft);
  font-size:14px;
}

.utility-card form{
  display:grid;
  gap:12px;
}

.utility-card .msg{
  text-align:center;
  margin-top:14px;
  font-size:14px;
  font-weight:600;
}

.utility-card .error{ color:#ff7b9f; }
.utility-card .success{ color:#53f3bd; }

.utility-card .back-link{
  text-align:center;
  margin-top:18px;
}

.utility-card .back-link a{
  color:var(--ink);
  font-weight:700;
  border-bottom:1px solid rgba(255,255,255,.25);
}

.utility-card .back-link a:hover{
  text-decoration:none;
  border-bottom-color:rgba(255,255,255,.45);
}

.admin-container{
  width:min(680px, 100%);
  margin:20px auto;
}

.admin-container h1{
  margin:0 0 8px;
  text-align:center;
  font-family:var(--font-display);
}

.admin-container > p{
  text-align:center;
  color:var(--ink-soft);
}

.admin-container .back-link{
  margin-top:24px;
  text-align:center;
}

.admin-container .back-link a{
  color:var(--ink);
  font-weight:700;
  border-bottom:1px solid rgba(255,255,255,.25);
}

.warning{
  margin:16px 0;
  padding:16px;
  border-radius:14px;
  border:1px solid rgba(255,209,102,.35);
  background:rgba(255,209,102,.14);
  color:#ffe9b2;
}

.danger-btn{
  width:100%;
  border:none;
  border-radius:999px;
  padding:12px 18px;
  font-size:15px;
  font-weight:800;
  cursor:pointer;
  background:linear-gradient(135deg, #ff5a82, #ff3d7f);
  color:#120713;
  box-shadow:0 12px 30px rgba(255,61,127,.28);
  transition:transform .16s ease, box-shadow .16s ease;
}

.danger-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 36px rgba(255,61,127,.34);
}

#result{
  margin-top:14px;
  padding:14px;
  border-radius:12px;
  display:none;
}

#result.success{
  display:block;
  border:1px solid rgba(83,243,189,.35);
  background:rgba(83,243,189,.12);
  color:#b6ffe7;
}

#result.error{
  display:block;
  border:1px solid rgba(255,123,159,.35);
  background:rgba(255,123,159,.12);
  color:#ffd6e2;
}

.hidden{
  display:none !important;
}

.utility-card input[type="email"],
.utility-card input[type="password"]{
  width: 100%;
  margin:0;
}
