/* ============================================================================
   Kharcha — "Aurora" design system  (next-generation, depth-rich UI)
   Drop-in restyle. Same semantic class names + CSS variables as the app DOM.
   Logic untouched; this file only changes how Kharcha looks & feels.
   ========================================================================== */

:root{
  /* surface & ink */
  --bg: #EEF1F8;
  --bg-2: #E6EAF5;
  --surface: #FFFFFF;
  --surface-2: #F7F8FC;
  --surface-glass: rgba(255,255,255,.72);
  --text: #0E1426;
  --muted: #6B7488;
  --border: #E4E7F0;
  --border-strong: #D4D9E6;

  /* brand — indigo→violet aurora */
  --primary: #5B5BF0;
  --primary-2: #8B5CF6;
  --primary-ink: #ffffff;
  --primary-soft: #ECECFE;
  --primary-grad: linear-gradient(135deg, #6366F1 0%, #7C5CFB 52%, #9D4EF5 100%);
  --accent: #0EAE9C;
  --accent-2: #22D3C5;

  --success: #16A34A;
  --warning: #E08600;
  --danger: #E5484D;
  --danger-soft: #FDECEC;

  /* radii */
  --r-input: 14px;
  --r-card: 22px;
  --r-pill: 999px;

  /* depth — layered, soft, slightly colored ambient */
  --shadow-sm: 0 1px 2px rgba(20,28,54,.05), 0 2px 6px rgba(20,28,54,.06);
  --shadow-md: 0 2px 6px rgba(20,28,54,.06), 0 12px 28px -8px rgba(20,28,54,.16);
  --shadow-lg: 0 8px 20px -6px rgba(20,28,54,.18), 0 30px 60px -18px rgba(20,28,54,.26);
  --shadow-fab: 0 10px 22px -4px rgba(99,102,241,.55), 0 4px 10px rgba(124,92,251,.4);
  --glow-primary: 0 0 0 1px rgba(99,102,241,.18), 0 8px 24px -6px rgba(99,102,241,.45);
  --ring: 0 0 0 4px rgba(99,102,241,.22);
  --hairline: inset 0 1px 0 rgba(255,255,255,.7);

  --maxw: 480px;
  --nav-h: 66px;
  --font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

[data-theme=dark]{
  --bg: #070B16;
  --bg-2: #0B1124;
  --surface: #121A2E;
  --surface-2: #0E1526;
  --surface-glass: rgba(20,28,48,.62);
  --text: #EAEFFA;
  --muted: #94A0B8;
  --border: #243149;
  --border-strong: #2E3D5A;

  --primary: #7B7BFF;
  --primary-2: #A78BFA;
  --primary-ink: #ffffff;
  --primary-soft: #1B2244;
  --primary-grad: linear-gradient(135deg, #6D6CFF 0%, #8B6CFB 52%, #B45CF6 100%);
  --accent: #2DD4BF;
  --accent-2: #5EEAD4;

  --success: #2BD46E;
  --warning: #F7A823;
  --danger: #FF6166;
  --danger-soft: #2C1822;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.5);
  --shadow-md: 0 2px 8px rgba(0,0,0,.5), 0 18px 40px -12px rgba(0,0,0,.7);
  --shadow-lg: 0 12px 28px -8px rgba(0,0,0,.6), 0 40px 80px -24px rgba(0,0,0,.8);
  --shadow-fab: 0 12px 28px -4px rgba(123,123,255,.6), 0 4px 12px rgba(167,139,250,.5);
  --glow-primary: 0 0 0 1px rgba(123,123,255,.3), 0 10px 30px -6px rgba(123,123,255,.5);
  --ring: 0 0 0 4px rgba(123,123,255,.28);
  --hairline: inset 0 1px 0 rgba(255,255,255,.06);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body,#root{height:100%}
body{
  margin:0;
  font-family:var(--font);
  color:var(--text);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overscroll-behavior-y:none;
  background:var(--bg);
}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
a{color:var(--primary);text-decoration:none}
.tnum{font-variant-numeric:tabular-nums}
h1,h2,h3,p{margin:0}

/* ---- App shell: a floating "device" with an aurora mesh behind it ---------- */
.app{
  max-width:var(--maxw);
  margin:0 auto;
  min-height:100%;
  position:relative;
  display:flex;
  flex-direction:column;
  background:
    radial-gradient(120% 60% at 10% -8%, color-mix(in srgb,var(--primary) 16%,transparent) 0%, transparent 60%),
    radial-gradient(120% 55% at 100% 0%, color-mix(in srgb,var(--primary-2) 14%,transparent) 0%, transparent 55%),
    radial-gradient(150% 70% at 50% 120%, color-mix(in srgb,var(--accent) 10%,transparent) 0%, transparent 60%),
    linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);
  box-shadow:var(--shadow-lg);
}
.app:before{
  /* faint top sheen line */
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);
  opacity:.6;pointer-events:none;
}
.screen{
  padding:18px 16px calc(var(--nav-h) + 36px);
  flex:1;
  animation:fade .26s cubic-bezier(.22,.7,.2,1);
}
@keyframes fade{0%{opacity:0;transform:translateY(8px) scale(.995)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}

/* ---- Type scale --------------------------------------------------------- */
.display{font-size:34px;font-weight:800;letter-spacing:-.025em;line-height:1.05}
.h1{font-size:25px;font-weight:800;letter-spacing:-.02em}
.h2{font-size:19px;font-weight:700;letter-spacing:-.01em}
.small{font-size:13px;font-weight:500}
.caption{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.muted{color:var(--muted)}

/* ---- App bar ------------------------------------------------------------ */
.appbar{display:flex;align-items:center;gap:12px;padding:8px 2px 16px}
.appbar .grow{flex:1}
.iconbtn{
  width:42px;height:42px;display:grid;place-items:center;
  border-radius:14px;color:var(--text);
  background:var(--surface-glass);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm),var(--hairline);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:transform .14s ease, background .15s ease, box-shadow .15s ease;
}
.iconbtn:active{transform:scale(.92);background:var(--primary-soft);color:var(--primary)}

/* ---- Cards: layered glass with gradient hairline ------------------------ */
.card{
  position:relative;
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 140%);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-md),var(--hairline);
  transition:transform .2s cubic-bezier(.22,.7,.2,1), box-shadow .2s ease;
}
.card.pad{padding:18px}
.card:active{transform:translateY(1px)}
.stack>*+*{margin-top:13px}
.row{display:flex;align-items:center;gap:12px}
.spacer{flex:1}

/* ---- Buttons: 3D tactile, gradient primary with sheen ------------------- */
.btn{
  position:relative;height:50px;padding:0 20px;border-radius:var(--r-input);
  font-weight:700;letter-spacing:-.01em;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--surface);color:var(--text);
  border:1px solid var(--border-strong);
  box-shadow:var(--shadow-sm),var(--hairline);
  transition:transform .12s cubic-bezier(.3,.7,.2,1), box-shadow .18s ease, background .18s ease, filter .18s ease;
  overflow:hidden;
}
.btn:active{transform:translateY(2px) scale(.99);box-shadow:var(--shadow-sm)}
.btn.primary{
  background:var(--primary-grad);
  background-size:140% 140%;
  color:var(--primary-ink);
  border-color:transparent;
  box-shadow:var(--glow-primary);
}
.btn.primary:after{
  /* glossy top sheen */
  content:"";position:absolute;inset:0 0 50% 0;
  background:linear-gradient(180deg,rgba(255,255,255,.28),transparent);
  pointer-events:none;
}
.btn.primary:active{filter:saturate(1.08) brightness(1.02)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--primary);box-shadow:none}
.btn.ghost:active{background:var(--primary-soft)}
.btn.danger{background:linear-gradient(135deg,#F0565B,#D6363C);color:#fff;border-color:transparent;box-shadow:0 8px 20px -6px rgba(229,72,77,.5)}
.btn.block{width:100%}
.btn:disabled{opacity:.5;box-shadow:none;transform:none}

/* ---- Fields & inputs ---------------------------------------------------- */
.field{display:block;margin-bottom:14px}
.field label,.lbl{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:7px;letter-spacing:.01em}
.input,.select,textarea.input{
  width:100%;height:50px;padding:0 15px;border-radius:var(--r-input);
  background:var(--surface-2);
  border:1px solid var(--border-strong);
  color:var(--text);outline:none;
  box-shadow:inset 0 1px 2px rgba(20,28,54,.05);
  transition:border-color .16s, box-shadow .16s, background .16s;
}
textarea.input{height:auto;padding:13px 15px;resize:vertical;min-height:80px;line-height:1.5}
.input::placeholder,textarea.input::placeholder{color:var(--muted);opacity:.7}
.input:focus,.select:focus,textarea.input:focus{
  border-color:var(--primary);
  background:var(--surface);
  box-shadow:var(--ring);
}
.select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236B7488' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:40px;
}
.input.err{border-color:var(--danger);box-shadow:0 0 0 4px var(--danger-soft)}
.err-text{color:var(--danger);font-size:13px;margin-top:7px;font-weight:600}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}

/* ---- Chips & segmented control ------------------------------------------ */
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  height:38px;padding:0 15px;border-radius:var(--r-pill);
  border:1px solid var(--border-strong);background:var(--surface);
  color:var(--text);font-size:13px;font-weight:600;
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
  box-shadow:var(--shadow-sm);
  transition:transform .12s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.chip:active{transform:scale(.96)}
.chip.active{background:var(--primary-grad);color:var(--primary-ink);border-color:transparent;box-shadow:var(--glow-primary)}
.chip.soft.active{background:var(--primary-soft);color:var(--primary);box-shadow:none}
.seg{
  display:inline-flex;background:var(--surface-2);
  border:1px solid var(--border);border-radius:var(--r-pill);padding:4px;
  box-shadow:inset 0 1px 3px rgba(20,28,54,.07);
}
.seg button{padding:8px 15px;border-radius:var(--r-pill);font-size:13px;font-weight:700;color:var(--muted);transition:color .15s ease}
.seg button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm),var(--hairline)}

/* ---- Toggle: glowing gradient track ------------------------------------- */
.toggle{
  width:48px;height:28px;border-radius:999px;background:var(--border-strong);
  position:relative;transition:background .2s ease, box-shadow .2s ease;flex:none;
  box-shadow:inset 0 1px 3px rgba(20,28,54,.18);
}
.toggle.on{background:var(--primary-grad);box-shadow:var(--glow-primary)}
.toggle:after{
  content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;
  background:#fff;transition:transform .22s cubic-bezier(.4,1.4,.5,1);
  box-shadow:0 2px 5px rgba(0,0,0,.3);
}
.toggle.on:after{transform:translateX(20px)}

/* ---- Floating bottom nav: glass dock ------------------------------------ */
.bottomnav{
  position:fixed;left:50%;transform:translate(-50%);bottom:0;
  width:100%;max-width:var(--maxw);
  height:calc(var(--nav-h) + env(safe-area-inset-bottom,0px));
  padding-bottom:env(safe-area-inset-bottom,0px);
  background:var(--surface-glass);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);backdrop-filter:blur(20px) saturate(1.4);
  border-top:1px solid var(--border);
  box-shadow:0 -8px 30px -10px rgba(20,28,54,.18);
  display:flex;align-items:stretch;justify-content:space-around;z-index:40;
}
.navitem{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--muted);font-size:10.5px;font-weight:700;position:relative;
  transition:color .18s ease;
}
.navitem svg{width:23px;height:23px;transition:transform .2s cubic-bezier(.3,1.3,.4,1)}
.navitem.active{color:var(--primary)}
.navitem.active svg{transform:translateY(-1px) scale(1.06)}
.navitem.active:before{
  content:"";position:absolute;top:9px;width:34px;height:34px;border-radius:12px;
  background:var(--primary-soft);z-index:-1;
}

/* ---- FAB: glowing aurora orb -------------------------------------------- */
.fab-slot{width:74px;position:relative}
.fab{
  position:absolute;top:-24px;left:50%;transform:translate(-50%);
  width:60px;height:60px;border-radius:50%;
  background:var(--primary-grad);color:#fff;
  display:grid;place-items:center;
  box-shadow:var(--shadow-fab);
  border:4px solid var(--bg);
  transition:transform .16s cubic-bezier(.3,1.4,.4,1), box-shadow .2s ease;
}
.fab:before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  background:radial-gradient(closest-side, color-mix(in srgb,var(--primary) 50%,transparent), transparent);
  filter:blur(6px);z-index:-1;opacity:.8;
}
.fab:after{
  content:"";position:absolute;inset:0 0 55% 0;border-radius:50% 50% 0 0;
  background:linear-gradient(180deg,rgba(255,255,255,.4),transparent);pointer-events:none;
}
.fab:active{transform:translate(-50%) scale(.9)}
.fab svg{width:28px;height:28px;position:relative;z-index:1}

/* ---- Expense rows ------------------------------------------------------- */
.exp-row{display:flex;align-items:center;gap:13px;padding:13px 6px;border-radius:14px;transition:background .15s ease}
.exp-row:active{background:var(--surface-2)}
.cat-ico{
  width:44px;height:44px;border-radius:14px;display:grid;place-items:center;
  font-size:20px;flex:none;color:#fff;
  box-shadow:0 4px 10px -2px rgba(20,28,54,.28), var(--hairline);
  position:relative;overflow:hidden;
}
.cat-ico:after{content:"";position:absolute;inset:0 0 55% 0;background:linear-gradient(180deg,rgba(255,255,255,.32),transparent)}
.exp-row .title{font-weight:700;letter-spacing:-.01em}
.exp-row .sub{font-size:12.5px;color:var(--muted)}
.exp-amt{font-weight:800;letter-spacing:-.02em}
.divide{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}
.daygroup-head{display:flex;justify-content:space-between;align-items:baseline;padding:16px 6px 4px}

/* ---- Tags --------------------------------------------------------------- */
.tag{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:7px;letter-spacing:.02em}
.tag.biz{background:var(--primary-soft);color:var(--primary)}
.tag.per{background:var(--surface-2);color:var(--muted);border:1px solid var(--border)}
.tag.bill{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}

/* ---- Scrim + bottom sheet (glass) --------------------------------------- */
.scrim{position:fixed;inset:0;background:rgba(4,7,20,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:50;animation:fade .2s ease}
.sheet{
  position:fixed;left:50%;transform:translate(-50%);bottom:0;
  width:100%;max-width:var(--maxw);
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);
  border-radius:26px 26px 0 0;z-index:51;max-height:94%;
  display:flex;flex-direction:column;
  border:1px solid var(--border);border-bottom:none;
  box-shadow:0 -16px 50px rgba(4,7,20,.4), var(--hairline);
  animation:slideup .32s cubic-bezier(.2,.85,.2,1);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
@keyframes slideup{0%{transform:translate(-50%,100%)}to{transform:translate(-50%)}}
.sheet .grab{width:42px;height:5px;border-radius:5px;background:var(--border-strong);margin:11px auto 4px}
.sheet .sheet-body{overflow-y:auto;padding:6px 18px 14px;-webkit-overflow-scrolling:touch}
.sheet .sheet-foot{padding:12px 18px calc(14px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border);background:var(--surface)}

/* ---- Amount display: large aurora-gradient numerals --------------------- */
.amount-display{text-align:center;padding:10px 0 6px}
.amount-display .num{
  font-size:50px;font-weight:800;letter-spacing:-.03em;
  background:var(--primary-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.amount-display .rupee{font-size:30px;font-weight:800;color:var(--muted);margin-right:4px;-webkit-text-fill-color:var(--muted)}

/* ---- Keypad: tactile 3D keys -------------------------------------------- */
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.key{
  height:56px;border-radius:16px;background:var(--surface);
  border:1px solid var(--border);
  font-size:23px;font-weight:700;display:grid;place-items:center;
  box-shadow:var(--shadow-sm),var(--hairline);
  transition:transform .1s ease, background .12s ease, box-shadow .12s ease;
}
.key:active{transform:translateY(2px) scale(.98);background:var(--primary-soft);color:var(--primary);box-shadow:none}

/* ---- Category grid tiles ------------------------------------------------ */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.cat-cell{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:12px 4px;border-radius:16px;
  border:1px solid var(--border);background:var(--surface);
  box-shadow:var(--shadow-sm);
  transition:transform .14s ease, border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.cat-cell:active{transform:scale(.95)}
.cat-cell .glyph{
  width:40px;height:40px;border-radius:13px;display:grid;place-items:center;font-size:19px;color:#fff;
  box-shadow:0 4px 10px -3px rgba(20,28,54,.3), var(--hairline);position:relative;overflow:hidden;
}
.cat-cell .glyph:after{content:"";position:absolute;inset:0 0 55% 0;background:linear-gradient(180deg,rgba(255,255,255,.3),transparent)}
.cat-cell .nm{font-size:10.5px;font-weight:700;text-align:center;line-height:1.15;color:var(--muted)}
.cat-cell.active{border-color:transparent;background:var(--primary-soft);box-shadow:var(--glow-primary)}
.cat-cell.active .nm{color:var(--primary)}

/* ---- Insights: legend, dots, bars --------------------------------------- */
.legend{display:flex;flex-direction:column;gap:8px}
.legend .li{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:500}
.dot{width:11px;height:11px;border-radius:4px;flex:none;box-shadow:var(--hairline)}
.bar{height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden;border:1px solid var(--border)}
.bar>span{display:block;height:100%;border-radius:999px;background:var(--primary-grad);box-shadow:0 0 8px -1px color-mix(in srgb,var(--primary) 60%,transparent)}
.bar.over>span{background:linear-gradient(135deg,#F0565B,#D6363C);box-shadow:0 0 8px -1px rgba(229,72,77,.5)}

/* ---- Toasts ------------------------------------------------------------- */
.toast-wrap{position:fixed;left:50%;transform:translate(-50%);bottom:calc(var(--nav-h) + 20px);z-index:80;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{
  background:rgba(14,20,38,.92);color:#fff;padding:12px 18px;border-radius:999px;
  font-size:13px;font-weight:700;
  box-shadow:var(--shadow-lg);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08);
  animation:pop .26s cubic-bezier(.2,1.3,.4,1);
}
[data-theme=dark] .toast{background:rgba(234,239,250,.94);color:#0B1020;border-color:rgba(0,0,0,.06)}
@keyframes pop{0%{transform:translateY(10px) scale(.96);opacity:0}to{transform:none;opacity:1}}

/* ---- Status: offline banner & sync pill --------------------------------- */
.offline-banner{background:linear-gradient(135deg,#F7A823,#E08600);color:#fff;text-align:center;font-size:12.5px;font-weight:700;padding:7px}
.sync-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--muted)}
.sync-pill .blip{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 6px color-mix(in srgb,var(--success) 70%,transparent)}
.sync-pill.syncing .blip{background:var(--warning);animation:blink 1s infinite}
.sync-pill.offline .blip{background:var(--muted);box-shadow:none}
@keyframes blink{50%{opacity:.3}}

/* ---- Empty & skeleton --------------------------------------------------- */
.empty{text-align:center;padding:44px 22px;color:var(--muted)}
.empty .ill{font-size:48px;margin-bottom:10px;filter:saturate(.9)}
.skel{background:linear-gradient(90deg,var(--surface-2) 25%,var(--border) 37%,var(--surface-2) 63%);background-size:400% 100%;animation:shimmer 1.4s infinite;border-radius:12px}
@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}

/* ---- Auth: cinematic aurora hero ---------------------------------------- */
.auth-wrap{
  min-height:100%;display:flex;flex-direction:column;justify-content:center;
  padding:30px 22px calc(30px + env(safe-area-inset-bottom,0));
  position:relative;overflow:hidden;
  background:
    radial-gradient(90% 60% at 15% 0%, #7C5CFB 0%, transparent 55%),
    radial-gradient(80% 60% at 100% 10%, #9D4EF5 0%, transparent 50%),
    radial-gradient(120% 80% at 50% 120%, #0EAE9C 0%, transparent 55%),
    linear-gradient(160deg, #4F46E5 0%, #312E81 60%, #1E1B4B 100%);
}
.auth-wrap:before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 40% at 80% 80%, rgba(255,255,255,.12), transparent 60%);
  pointer-events:none;
}
.auth-card{
  position:relative;
  background:var(--surface-glass);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid rgba(255,255,255,.18);
  border-radius:26px;padding:26px 22px;
  box-shadow:0 30px 70px -20px rgba(0,0,0,.55), var(--hairline);
}
[data-theme=dark] .auth-card{background:rgba(18,26,46,.78);border-color:rgba(255,255,255,.08)}
.brand-mark{
  width:60px;height:60px;border-radius:18px;
  background:var(--primary-grad);color:#fff;
  display:grid;place-items:center;font-size:32px;font-weight:800;
  box-shadow:var(--shadow-fab);position:relative;overflow:hidden;
}
.brand-mark:after{content:"";position:absolute;inset:0 0 55% 0;background:linear-gradient(180deg,rgba(255,255,255,.4),transparent)}

/* ---- Password strength meter -------------------------------------------- */
.pw-meter{height:7px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:9px;border:1px solid var(--border)}
.pw-meter>span{display:block;height:100%;transition:width .25s ease, background .25s ease}

/* ---- List rows / settings ----------------------------------------------- */
.list-row{display:flex;align-items:center;gap:13px;padding:15px 6px;border-bottom:1px solid var(--border)}
.list-row:last-child{border-bottom:none}
.list-row .chev{color:var(--muted)}
.center-col{display:flex;flex-direction:column;align-items:center}
.pill-link{font-size:13px;font-weight:700}
.hr-text{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:16px 0;font-weight:600}
.hr-text:before,.hr-text:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}
.notice{background:var(--primary-soft);color:var(--primary);border-radius:14px;padding:11px 13px;font-size:12.5px;font-weight:600;border:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
