/* ===========================================================
   Reminder Hub — brand stylesheet
   Blue gradient brand: #006EED → #00B3F8 · ink #0F1B2D
   =========================================================== */
:root{
  --brand:#0089F2; --brand-dark:#006EED; --brand-light:#00B3F8;
  --grad:linear-gradient(135deg,#006EED 0%,#00B3F8 100%);
  --grad-soft:linear-gradient(135deg,#EAF4FF 0%,#E6FBFF 100%);
  --ink:#0F1B2D; --muted:#5B6B7B; --muted-2:#8A98A8;
  --line:#E6ECF2; --bg:#FFFFFF; --bg-soft:#F4F9FF; --bg-dark:#0F1B2D;
  --ok:#10B981; --warn:#F59E0B; --danger:#EF4444;
  --radius:14px; --radius-sm:10px; --radius-lg:22px;
  --shadow:0 1px 2px rgba(15,27,45,.06),0 8px 24px rgba(15,27,45,.06);
  --shadow-lg:0 20px 50px rgba(0,110,237,.16);
  --container:1160px;
  --font:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--brand-dark)}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,4.6vw,3.5rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 22px}
.section{padding:54px 0}
.section-soft{background:var(--bg-soft)}
.center{text-align:center}
.eyebrow{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--brand-dark);background:#E7F2FF;
  padding:6px 14px;border-radius:999px;margin-bottom:18px}
.lead{font-size:1.13rem;color:var(--muted);max-width:620px}
.center .lead{margin-left:auto;margin-right:auto}
.text-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:inherit;font-weight:700;font-size:.98rem;cursor:pointer;border:0;
  padding:13px 24px;border-radius:var(--radius-sm);transition:.18s ease;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 8px 20px rgba(0,110,237,.28)}
.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,110,237,.36)}
.btn-outline{background:#fff;color:var(--brand-dark);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--brand);color:var(--brand-dark);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{color:var(--brand-dark)}
.btn-white{background:#fff;color:var(--brand-dark)}
.btn-white:hover{color:var(--brand-dark);transform:translateY(-2px)}
.btn-lg{padding:16px 30px;font-size:1.05rem}
.btn-block{width:100%}
.btn-sm{padding:9px 16px;font-size:.88rem}

/* ---------- Navbar ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);font-weight:600;font-size:.96rem}
.nav-links a:hover{color:var(--brand)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;padding:50px 0 60px;background:
  radial-gradient(900px 500px at 80% -10%,#E7F4FF 0%,transparent 60%),
  radial-gradient(700px 500px at 0% 20%,#EAFBFF 0%,transparent 55%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin-bottom:.35em}
.hero .lead{font-size:1.18rem}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:26px;color:var(--muted);font-size:.9rem}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.tick{color:var(--ok);font-weight:800}

/* dashboard mock card */
.mock{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden}
.mock-top{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);background:#fff}
.dot{width:11px;height:11px;border-radius:50%;background:#E2E8F0}
.mock-body{padding:18px}
.mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.mini{border:1px solid var(--line);border-radius:12px;padding:12px}
.mini b{display:block;font-size:1.5rem;line-height:1.1}
.mini small{color:var(--muted);font-size:.74rem}
.mrow{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--line)}
.mrow:first-of-type{border-top:0}
.chip{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.chip-warn{background:#FEF3C7;color:#92590B}
.chip-danger{background:#FEE2E2;color:#991B1B}
.chip-ok{background:#D1FAE5;color:#065F46}
.mrow .mt{flex:1;min-width:0}
.mrow .mt b{font-size:.9rem;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mrow .mt small{color:var(--muted);font-size:.76rem}

/* ---------- Trust bar ---------- */
.trustbar{padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.trustbar .container{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.trust-pill{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--muted);
  font-size:.92rem;background:var(--bg-soft);padding:9px 16px;border-radius:999px}

/* ---------- Features ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow);transition:.2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#CFE6FF}
.ficon{width:52px;height:52px;border-radius:13px;display:grid;place-items:center;
  background:var(--grad-soft);color:var(--brand);margin-bottom:16px;font-size:1.5rem}
.card h3{margin-bottom:.4em}
.card p{color:var(--muted);margin:0;font-size:.96rem}

/* ---------- Category chips ---------- */
.cats{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:780px;margin:20px auto 0}
.cat{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);
  padding:11px 18px;border-radius:999px;font-weight:600;font-size:.94rem;box-shadow:var(--shadow)}
.cat i{width:9px;height:9px;border-radius:50%}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step .num{width:46px;height:46px;border-radius:13px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:1.2rem;margin-bottom:14px;box-shadow:0 8px 18px rgba(0,110,237,.3)}
.step h3{margin-bottom:.3em}
.step p{color:var(--muted);margin:0}

/* ---------- Pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch}
.plan{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 24px;
  display:flex;flex-direction:column;box-shadow:var(--shadow);transition:.2s;position:relative}
.plan:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.plan.featured{border:2px solid var(--brand);box-shadow:var(--shadow-lg)}
.plan .badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);
  color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:6px 14px;border-radius:999px;text-transform:uppercase}
.plan h3{font-size:1.15rem;margin-bottom:.1em}
.plan .price{font-size:2.2rem;font-weight:800;margin:10px 0 2px;letter-spacing:-.03em}
.plan .price small{font-size:.9rem;font-weight:600;color:var(--muted)}
.plan .pnote{color:var(--muted);font-size:.84rem;min-height:20px;margin-bottom:18px}
.plan ul{list-style:none;margin:0 0 22px;padding:0;flex:1}
.plan li{display:flex;gap:10px;align-items:flex-start;padding:7px 0;font-size:.93rem;color:#33414F}
.plan li .y{color:var(--ok);font-weight:800}
.plan li .n{color:#C7D0DA;font-weight:800}
.plan li.off{color:var(--muted-2)}

/* ---------- CTA band ---------- */
.cta{background:var(--grad);border-radius:var(--radius-lg);padding:36px;color:#fff;text-align:center;
  box-shadow:var(--shadow-lg)}
.cta h2{color:#fff}
.cta p{color:rgba(255,255,255,.92);max-width:560px;margin:0 auto 26px}

/* ---------- Forms ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.input,textarea.input,select.input{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--radius-sm);background:#fff;transition:.15s}
.input:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 4px rgba(0,137,242,.12)}
textarea.input{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.help{font-size:.82rem;color:var(--muted)}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:30px;box-shadow:var(--shadow);max-width:560px;margin:0 auto}

/* ---------- Alerts / flash ---------- */
.flash-wrap{position:fixed;top:84px;right:20px;z-index:100;display:flex;flex-direction:column;gap:10px;max-width:360px}
.alert{padding:13px 16px;border-radius:var(--radius-sm);font-size:.92rem;font-weight:600;box-shadow:var(--shadow);
  display:flex;gap:10px;align-items:flex-start;background:#fff;border-left:4px solid var(--brand)}
.alert-success{border-color:var(--ok)}
.alert-error{border-color:var(--danger)}
.alert-info{border-color:var(--brand)}

/* ---------- Footer ---------- */
.footer{background:var(--bg-dark);color:#AEBBC9;padding:44px 0 20px}
.footer a{color:#AEBBC9}
.footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.footer .brand img{height:40px}
.footer h4{color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin-bottom:10px;font-size:.93rem}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.86rem;color:var(--muted-2)}

/* ---------- Utilities ---------- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.section-head{max-width:680px;margin:0 auto 50px}
.hide{display:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-media{order:-1}
  .grid-3,.steps{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .section{padding:60px 0}
  .nav-links,.nav-cta .btn-ghost{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
    background:#fff;border-bottom:1px solid var(--line);padding:18px 22px;gap:16px}
  .grid-3,.grid-2,.steps,.plans,.form-row,.foot-grid{grid-template-columns:1fr}
  .cta{padding:38px 24px}
  .flash-wrap{left:14px;right:14px;max-width:none}
}

/* ===========================================================
   App shell (authenticated dashboard)
   =========================================================== */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
/* Sidebar palette — follows the light/dark theme like the rest of the page. */
:root{
  --side-bg:#FFFFFF; --side-text:#42526A; --side-muted:#8A98A8; --side-group:#9AA7B5;
  --side-hover:#F1F6FC; --side-hover-text:var(--brand-dark); --side-border:#E8EDF3;
  --side-active:var(--brand-dark); --side-active-strong:var(--ink);
  --side-foot-bg:#F4F9FF; --side-track:#E2EAF2;
  --side-badge-soft-bg:#EAF0F6; --side-badge-soft-text:#5B6B7B;
}
.sidebar{background:var(--side-bg);color:var(--side-text);padding:16px 12px;position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--side-border)}
.sidebar .brand{margin:2px 4px 18px;display:block;padding:0 4px}
.sidebar .brand img{width:100%;height:auto}
.side-group{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--side-group);margin:12px 8px 4px}
.side-link{display:flex;align-items:center;gap:10px;padding:5px 8px;color:var(--side-text);
  font-weight:600;font-size:.85rem;transition:.12s;border-left:2px solid transparent}
.side-link:hover{color:var(--side-hover-text)}
.side-link.active{color:var(--side-active-strong);border-left-color:var(--side-active);font-weight:700}
.side-link .ic{width:19px;display:inline-flex;align-items:center;justify-content:center}
.side-link.active .ic{color:currentColor}
.side-link.scat.active{color:var(--side-active)}
.side-section{margin-bottom:1px}
.side-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:0;cursor:pointer;
  font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--side-group);font-weight:700;
  padding:0 8px;margin:12px 0 4px;font-family:inherit}
.side-group-toggle:hover{color:var(--side-hover-text)}
.side-group-toggle svg{transition:transform .15s;opacity:.55;flex-shrink:0}
.side-section.collapsed .side-group-toggle svg{transform:rotate(-90deg)}
.side-section.collapsed .side-cat-list{display:none}
.side-cat-list{display:flex;flex-direction:column}

.main{display:flex;flex-direction:column;min-width:0;background:var(--bg-soft)}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 28px;
  background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar h1{font-size:1.3rem;margin:0}
.topbar .sub{color:var(--muted);font-size:.86rem}
.topbar-right{display:flex;align-items:center;gap:14px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--grad);color:#fff;display:grid;
  place-items:center;font-weight:700;font-size:.85rem}
.plan-badge{font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:999px;background:#E7F2FF;color:var(--brand-dark)}
.plan-badge.trial{background:#FEF3C7;color:#92590B}
.content{padding:28px;flex:1}
.hamburger{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.stat .lab{color:var(--muted);font-size:.84rem;font-weight:600;display:flex;align-items:center;gap:8px}
.stat .val{font-size:2rem;font-weight:800;letter-spacing:-.02em;margin-top:6px}
.stat.danger .val{color:var(--danger)}.stat.warn .val{color:var(--warn)}.stat.ok .val{color:var(--ok)}

.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.panel-head h3{margin:0;font-size:1.05rem}
.panel-body{padding:6px 0}
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  padding:12px 22px;border-bottom:1px solid var(--line);font-weight:700}
.table td{padding:14px 22px;border-bottom:1px solid var(--line);font-size:.93rem;vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:#FAFCFF}
.t-title{font-weight:700}
.t-sub{color:var(--muted);font-size:.82rem}
.badge-cat{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600}
.badge-cat i{width:9px;height:9px;border-radius:50%}
.pill{font-size:.74rem;font-weight:700;padding:4px 11px;border-radius:999px;white-space:nowrap;display:inline-block}
.pill.warn{background:#FEF3C7;color:#92590B}.pill.danger{background:#FEE2E2;color:#991B1B}
.pill.ok{background:#D1FAE5;color:#065F46}.pill.muted{background:#EEF2F6;color:#5B6B7B}

.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h2{margin:0;font-size:calc(clamp(1.7rem, 3.2vw, 2.5rem) * 0.6)}
.empty{text-align:center;padding:54px 20px;color:var(--muted)}
.empty .big{font-size:2.6rem;margin-bottom:8px}
.toolbar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.toolbar .input,.toolbar select{max-width:240px}
.row-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}
.row-actions form{display:inline-flex;margin:0}
.icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:34px;min-width:34px;
  padding:0 12px;box-sizing:border-box;background:#fff;border:1px solid var(--line);border-radius:8px;cursor:pointer;
  font-size:.82rem;font-weight:600;line-height:1;color:var(--ink);transition:.15s;text-decoration:none;font-family:inherit;vertical-align:middle}
.icon-btn svg{display:block}
.icon-btn:hover{border-color:var(--brand);color:var(--brand-dark)}
.icon-btn.danger:hover{border-color:var(--danger);color:var(--danger)}
.banner{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#FEF3C7;
  border:1px solid #FCE4A6;color:#92590B;border-radius:var(--radius);padding:14px 20px;margin-bottom:22px;font-weight:600}
.banner.danger{background:#FEE2E2;border-color:#FBC4C4;color:#991B1B}

/* Renewals: category rail + records layout */
.rec-layout{display:grid;grid-template-columns:236px 1fr;gap:22px;align-items:start}
.cat-rail{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:12px 10px;position:sticky;top:18px;max-height:calc(100vh - 40px);overflow-y:auto}
.cat-rail-group{font-size:.68rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted-2);
  font-weight:700;margin:14px 10px 6px}
.cat-rail-group:first-child{margin-top:4px}
.cat-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;color:var(--ink);
  font-size:.86rem;font-weight:600;transition:.14s}
.cat-link:hover{background:var(--bg-soft);color:var(--brand-dark)}
.cat-link.active{background:var(--grad);color:#fff;box-shadow:0 6px 16px rgba(0,110,237,.32)}
.cat-link.active .cat-ic{color:#fff !important}
.cat-ic{width:20px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}
.cat-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cat-count{font-size:.72rem;font-weight:700;background:#EEF2F6;color:var(--muted);border-radius:999px;
  padding:1px 8px;min-width:22px;text-align:center}
.cat-link.active .cat-count{background:rgba(255,255,255,.22);color:#fff}

.status-pills{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.spill{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:7px 14px;font-size:.82rem;font-weight:700;color:var(--muted);transition:.14s}
.spill b{font-weight:800;color:var(--ink)}
.spill:hover{border-color:var(--brand)}
.spill.on{border-color:var(--brand);background:var(--bg-soft);color:var(--brand-dark)}
.spill.ok.on{border-color:var(--ok);background:#ECFDF5;color:#065F46}
.spill.warn.on{border-color:var(--warn);background:#FFFBEB;color:#92590B}
.spill.danger.on{border-color:var(--danger);background:#FEF2F2;color:#991B1B}

.cycle-tag{display:inline-block;font-size:.68rem;font-weight:700;border-radius:6px;padding:1px 7px;
  text-transform:uppercase;letter-spacing:.03em;background:#EEF2F6;color:var(--muted)}
.cycle-tag.monthly{background:#EAF4FF;color:var(--brand-dark)}
.cycle-tag.yearly{background:#ECFDF5;color:#0F766E}
.cycle-tag.onetime{background:#F5F3FF;color:#6D28D9}

@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-260px;width:248px;z-index:60;transition:.25s}
  .app.nav-open .sidebar{left:0}
  .hamburger{display:block}
  .stats{grid-template-columns:1fr 1fr}
  .table .hide-sm{display:none}
  .topsearch{display:none}
  .rec-layout{grid-template-columns:1fr}
  .cat-rail{position:static;max-height:none;display:flex;flex-wrap:wrap;gap:6px}
  .cat-rail-group{flex-basis:100%;margin:8px 6px 2px}
  .cat-link{flex:0 0 auto}
}
@media(max-width:560px){ .stats{grid-template-columns:1fr} .content{padding:18px} }

/* ===========================================================
   Sidebar categories · avatars · dropdowns · account · dark
   =========================================================== */
.side-link .side-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-link.scat{padding:6px 8px;font-size:.84rem}
.side-badge{background:var(--grad);color:#fff;font-size:.7rem;font-weight:800;border-radius:999px;padding:1px 7px;line-height:1.5}
.side-badge.soft{background:var(--side-badge-soft-bg);color:var(--side-badge-soft-text)}

.avatar{overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}

/* Topbar buttons + dropdown menus */
.menu-wrap{position:relative}
.topbtn{position:relative;background:none;border:1px solid var(--line);width:40px;height:40px;border-radius:10px;
  display:grid;place-items:center;cursor:pointer;color:var(--ink)}
.topbtn:hover{border-color:var(--brand);color:var(--brand-dark)}
.dot{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;
  background:var(--danger);color:#fff;font-size:.66rem;font-weight:800;display:grid;place-items:center}
.profile-btn{display:flex;align-items:center;gap:6px;background:none;border:0;cursor:pointer;padding:2px;color:var(--muted)}
.chev{display:inline-flex}
.dropdown{position:absolute;right:0;top:calc(100% + 10px);width:330px;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;z-index:60;display:none}
.menu-wrap.open .dropdown{display:block}
.profile-dd{width:262px}
.dd-head{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 10px;border-bottom:1px solid var(--line)}
.dd-link-btn{background:none;border:0;color:var(--brand-dark);font-weight:700;font-size:.8rem;cursor:pointer}
.dd-list{max-height:360px;overflow-y:auto;padding:4px 0}
.dd-item{display:flex;gap:10px;padding:10px;border-radius:10px;color:var(--ink)}
.dd-item:hover{background:var(--bg-soft)}
.dd-item.unread{background:rgba(0,137,242,.07)}
.dd-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:#EAF4FF;color:var(--brand-dark);flex-shrink:0}
.dd-ic.expired{background:#FEE2E2;color:#991B1B}
.dd-body{display:flex;flex-direction:column;gap:1px;min-width:0}
.dd-title{font-weight:700;font-size:.86rem}
.dd-sub{font-size:.8rem;color:var(--muted)}
.dd-time{font-size:.72rem;color:var(--muted-2);margin-top:2px}
.dd-empty{text-align:center;color:var(--muted);padding:26px 10px}
.dd-empty p{margin:8px 0 0}
.dd-foot{display:block;text-align:center;padding:10px;border-top:1px solid var(--line);font-weight:700;font-size:.84rem}
.dd-profile{display:flex;gap:12px;align-items:center;padding:10px}
.dd-profile-meta{display:flex;flex-direction:column;min-width:0}
.dd-profile-meta b{font-size:.92rem}
.dd-profile-meta span{font-size:.78rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dd-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;color:var(--ink);font-weight:600;font-size:.88rem;width:100%}
.dd-row:hover{background:var(--bg-soft);color:var(--brand-dark)}
.dd-row.danger:hover{color:var(--danger)}
.dd-row-btn{background:none;border:0;cursor:pointer;text-align:left;font-family:inherit}
.dd-divider{height:1px;background:var(--line);margin:6px 4px}

/* Company switcher (top of sidebar) */
.co-switch{margin:2px 4px 14px}
.co-btn{display:flex;align-items:center;gap:9px;width:100%;background:var(--side-hover);border:1px solid var(--side-border);
  border-radius:10px;padding:8px 10px;cursor:pointer;color:var(--side-text);font-weight:600;font-size:.9rem;font-family:inherit}
.co-btn:hover{border-color:var(--side-active)}
.co-btn .co-name{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.co-ava{width:24px;height:24px;border-radius:7px;background:var(--grad);color:#fff;display:grid;place-items:center;
  font-size:.66rem;font-weight:800;flex-shrink:0;overflow:hidden}
.co-ava img{width:100%;height:100%;object-fit:cover}
.co-ava.all{background:var(--side-badge-soft-bg);color:var(--side-text)}
.co-dd{left:0;right:auto;width:100%;top:calc(100% + 6px)}
.co-dd-head{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);font-weight:700;padding:6px 10px 4px}
.co-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;color:var(--ink);font-weight:600;font-size:.86rem}
.co-item:hover{background:var(--bg-soft)}
.co-item.active{color:var(--brand-dark)}
.co-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.co-item svg:last-child{color:var(--brand);flex-shrink:0}
.co-item.add{color:var(--brand-dark);font-weight:700}

/* Custom confirmation dialog (replaces native confirm) */
.cbox-overlay{position:fixed;inset:0;background:rgba(15,27,45,.55);backdrop-filter:blur(3px);
  display:grid;place-items:center;z-index:200;padding:20px;animation:cboxFade .15s ease}
.cbox-overlay[hidden]{display:none}
.cbox{background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-lg);max-width:420px;width:100%;padding:28px 26px;text-align:center;animation:cboxPop .16s ease}
.cbox-ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;margin:0 auto 14px;background:#EAF4FF;color:var(--brand-dark)}
.cbox-overlay.danger .cbox-ic{background:#FEE2E2;color:#B91C1C}
.cbox-title{margin:0 0 6px;font-size:1.15rem;letter-spacing:-.01em}
.cbox-msg{margin:0 0 22px;color:var(--muted);font-size:.95rem;line-height:1.55}
.cbox-input{margin:-4px 0 18px;text-align:center;font-weight:600}
.cbox-actions{display:flex;gap:10px;justify-content:center}
.cbox-actions .btn{min-width:118px;justify-content:center}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}
.btn-danger{background:var(--danger);color:#fff;border:0}
.btn-danger:hover{background:#DC2626;color:#fff}
body.cbox-open{overflow:hidden}
@keyframes cboxFade{from{opacity:0}to{opacity:1}}
@keyframes cboxPop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
[data-theme="dark"] .cbox-ic{background:#16314a;color:#7FC4FF}
[data-theme="dark"] .cbox-overlay.danger .cbox-ic{background:#3a1d1d;color:#FCA5A5}

/* Topbar search */
.topsearch{display:flex;align-items:center;gap:8px;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:10px;padding:7px 12px;color:var(--muted);min-width:230px}
.topsearch input{border:0;background:none;outline:none;color:var(--ink);font-family:inherit;font-size:.86rem;width:100%}
.topsearch input::placeholder{color:var(--muted-2)}

/* Account page */
.avatar-edit{display:flex;gap:16px;align-items:center;margin-bottom:18px}
.avatar-edit-controls{display:flex;flex-direction:column;gap:6px}
.lbl{display:block;font-weight:600;font-size:.9rem;margin-bottom:8px}
.theme-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.theme-card{position:relative;border:2px solid var(--line);border-radius:12px;padding:12px;cursor:pointer;display:block}
.theme-card.sel{border-color:var(--brand)}
.theme-card input{position:absolute;opacity:0;pointer-events:none}
.tc-preview{display:flex;gap:6px;height:46px;border-radius:8px;padding:8px;margin-bottom:8px}
.tc-preview.light{background:#F4F9FF;border:1px solid #E6ECF2}
.tc-preview.dark{background:#0E1A2A;border:1px solid #25374B}
.tc-preview span{flex:1;border-radius:5px}
.tc-preview.light span:first-child{background:#fff;flex:0 0 30%}
.tc-preview.light span:last-child{background:#DCEAFE}
.tc-preview.dark span:first-child{background:#13212F;flex:0 0 30%}
.tc-preview.dark span:last-child{background:#1B2C3D}
.tc-name{display:flex;align-items:center;gap:6px;font-weight:700;font-size:.86rem}

/* Notifications page */
.notif-list{display:flex;flex-direction:column}
.notif-row{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);color:var(--ink)}
.notif-row:last-child{border-bottom:0}
.notif-row:hover{background:#FAFCFF}
.notif-row.unread{background:rgba(0,137,242,.05)}
.notif-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#EAF4FF;color:var(--brand-dark);flex-shrink:0}
.notif-ic.expired{background:#FEE2E2;color:#991B1B}
.notif-main{flex:1;display:flex;flex-direction:column;min-width:0}
.notif-title{font-weight:700}
.notif-body{color:var(--muted);font-size:.86rem}
.notif-time{color:var(--muted-2);font-size:.78rem;white-space:nowrap}

/* Font-size preference (scales rem-based text) */
html[data-font="small"]{font-size:15px}
html[data-font="normal"]{font-size:16px}
html[data-font="large"]{font-size:18px}
html[data-font="xlarge"]{font-size:20px}
html[data-font] body{font-size:1rem}

/* ---------------- Dark mode ---------------- */
[data-theme="dark"]{
  --ink:#E7EDF4; --muted:#9DB0C2; --muted-2:#7B8D9F; --line:#25374B;
  --bg:#0E1A2A; --bg-soft:#0B1623;
  --shadow:0 1px 2px rgba(0,0,0,.5),0 10px 26px rgba(0,0,0,.5);
  /* Sidebar (dark) */
  --side-bg:#0F1B2D; --side-text:#C4D0DC; --side-muted:#8A98A8; --side-group:#5A6B7D;
  --side-hover:rgba(255,255,255,.06); --side-hover-text:#FFFFFF; --side-border:#1D2C3E;
  --side-active:#7FC4FF; --side-active-strong:#FFFFFF;
  --side-foot-bg:rgba(255,255,255,.05); --side-track:rgba(255,255,255,.12);
  --side-badge-soft-bg:rgba(255,255,255,.14); --side-badge-soft-text:#FFFFFF;
}
[data-theme="dark"] body{background:var(--bg);color:var(--ink)}
[data-theme="dark"] .panel,
[data-theme="dark"] .topbar,
[data-theme="dark"] .stat,
[data-theme="dark"] .dropdown,
[data-theme="dark"] .theme-card{background:#13212F;border-color:var(--line);color:var(--ink)}
[data-theme="dark"] .input,
[data-theme="dark"] select,
[data-theme="dark"] textarea,
[data-theme="dark"] .icon-btn,
[data-theme="dark"] .topbtn,
[data-theme="dark"] .spill{background:#0E1A28;border-color:var(--line);color:var(--ink)}
[data-theme="dark"] .table th{color:var(--muted);border-color:var(--line)}
[data-theme="dark"] .table td{border-color:var(--line)}
[data-theme="dark"] .table tr:hover td,
[data-theme="dark"] .notif-row:hover,
[data-theme="dark"] .dd-item:hover,
[data-theme="dark"] .dd-row:hover{background:#172636}
[data-theme="dark"] .notif-row{border-color:var(--line)}
[data-theme="dark"] .plan-badge{background:#1B2C3D;color:#7FC4FF}
[data-theme="dark"] .cycle-tag{background:#1B2C3D;color:var(--muted)}
[data-theme="dark"] .badge-cat,[data-theme="dark"] .dd-title,[data-theme="dark"] .notif-title{color:var(--ink)}
[data-theme="dark"] a:not(.btn){color:var(--brand-light)}
[data-theme="dark"] .btn-outline{background:transparent;color:var(--ink);border-color:#34485F}
[data-theme="dark"] .btn-outline:hover{background:rgba(255,255,255,.04);border-color:var(--brand-light);color:#fff}
[data-theme="dark"] .btn-ghost{color:var(--ink)}
[data-theme="dark"] .btn-ghost:hover{color:var(--brand-light)}
[data-theme="dark"] .btn-white{background:#1B2C3D;color:#fff}
[data-theme="dark"] .btn-white:hover{color:#fff}
[data-theme="dark"] .btn-primary{box-shadow:0 6px 18px rgba(0,0,0,.45)}
[data-theme="dark"] .btn-primary:hover{box-shadow:0 10px 24px rgba(0,0,0,.55)}
[data-theme="dark"] .dd-ic{background:#16314a}
[data-theme="dark"] .sidebar .side-link{color:#ffffff}
[data-theme="dark"] .sidebar .side-link:hover{color:var(--side-hover-text)}
[data-theme="dark"] .sidebar .side-link.active{color:var(--brand-light);border-left-color:var(--brand-light)}
