/* ============================================================
   theme.css  ·  Dark Subrosa / Kira shared design system
   Link this on every page:
     <link rel="stylesheet" href="/theme.css">
   Theme is toggled by setting   <html data-theme="light|dark">
   (handled automatically by /theme.js)
   ============================================================ */

/* ---- 1. FONT ---- */
@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:ital,wght@0,300..800;1,300..800&display=swap');

/* ---- 2. TOKENS ---- */
:root{
  --font: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --shadow: 0 1px 2px rgba(17,17,17,.04), 0 8px 24px -12px rgba(17,17,17,.12);
  --shadow-hover: 0 1px 2px rgba(17,17,17,.05), 0 16px 40px -16px rgba(17,17,17,.18);
  --accent:#2E3A48; --accent-soft:rgba(46,58,72,.10); --accent-ink:#fff;  /* Slate */
}

/* LIGHT (default) */
:root, :root[data-theme="light"]{
  --bg:#F6F4F1; --bg-soft:#EFEDE9; --surface:#FFFFFF; --surface-2:#FBFAF8;
  --line:#E7E3DD; --ink:#1B1A18; --ink-soft:#57534D; --muted:#948E85; --pos:#1F8A5B; --pos-soft:rgba(31,138,91,.12);
  --accent:#2E3A48; --accent-soft:rgba(46,58,72,.10); --accent-ink:#fff;
  --danger:#C0453E; --danger-soft:rgba(192,69,62,.12);
  --warn:#B7791F;   --warn-soft:rgba(183,121,31,.14);
  --info:#2F6FB0;   --info-soft:rgba(47,111,176,.12);
}
/* DARK */
:root[data-theme="dark"]{
  --bg:#131417; --bg-soft:#0E0F11; --surface:#1B1D21; --surface-2:#212327;
  --line:#2B2E34; --ink:#F1EFEC; --ink-soft:#B7B4AE; --muted:#7E8189; --pos:#3BBE85; --pos-soft:rgba(59,190,133,.16);
  --accent:#9DB1C7; --accent-soft:rgba(157,177,199,.14); --accent-ink:#131417;
  --danger:#E6736B; --danger-soft:rgba(230,115,107,.16);
  --warn:#D9A441;   --warn-soft:rgba(217,164,65,.16);
  --info:#6FA8DC;   --info-soft:rgba(111,168,220,.16);
  --shadow: 0 1px 2px rgba(0,0,0,.4), 0 12px 32px -16px rgba(0,0,0,.7);
  --shadow-hover: 0 1px 2px rgba(0,0,0,.5), 0 20px 48px -18px rgba(0,0,0,.8);
}

/* ---- 3. BASE ---- */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--font);background:var(--bg);color:var(--ink);min-height:100vh;
  transition:background .35s ease,color .35s ease}
.num{font-feature-settings:"tnum" 1,"cv01" 1;font-variant-numeric:tabular-nums}
.wrap{max-width:1240px;margin:0 auto;padding:30px 26px 70px}
.hidden{display:none!important}

/* ---- 4. SURFACES ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow)}
.eyebrow{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ---- 5. BUTTONS + INPUTS ---- */
.btn{font:inherit;font-size:13.5px;font-weight:600;padding:10px 16px;border-radius:var(--r-sm);cursor:pointer;
  border:1px solid var(--line);background:var(--surface);color:var(--ink);
  display:inline-flex;align-items:center;gap:7px;transition:.18s;text-decoration:none}
.btn:hover{border-color:var(--ink-soft)}
.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{filter:brightness(1.08);border-color:var(--accent)}

input[type=date],input[type=text],input[type=password],input[type=email]{
  font:inherit;font-size:13.5px;color:var(--ink);padding:9px 12px;
  border:1px solid var(--line);border-radius:var(--r-sm);background:var(--surface);transition:.18s}
input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---- 6. THEME TOGGLE (drop onto any page) ---- */
.theme-toggle{width:39px;height:39px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--surface);color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:.18s}
.theme-toggle:hover{border-color:var(--ink-soft)}
.theme-toggle svg{width:18px;height:18px}
.theme-toggle .sun{display:none}
.theme-toggle .moon{display:block}
:root[data-theme="dark"] .theme-toggle .sun{display:block}
:root[data-theme="dark"] .theme-toggle .moon{display:none}

/* ---- 7. TOP BAR ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--accent-soft);font-size:20px}
.brand h1{font-size:20px;font-weight:700;letter-spacing:-.01em}
.brand .sub{font-size:12px;color:var(--muted);font-weight:500;margin-top:1px}
.topbar-actions{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.date-to{font-size:13px;color:var(--muted);font-weight:500}

/* ---- 8. SEGMENTED CONTROL (date ranges) ---- */
.segment{display:inline-flex;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-md);padding:4px;gap:2px}
.segment button{font:inherit;font-size:13px;font-weight:600;color:var(--ink-soft);border:none;background:transparent;
  padding:8px 15px;border-radius:9px;cursor:pointer;transition:.16s}
.segment button:hover{color:var(--ink)}
.segment button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}

/* ---- 9. DESTINATION PILLS (Square / Shopify / …) ---- */
.dest-row{display:flex;gap:9px;flex-wrap:wrap;margin:14px 0 26px}
.dest{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink-soft);
  padding:9px 15px;border-radius:999px;border:1px solid var(--line);background:var(--surface);cursor:pointer;
  transition:.18s;text-decoration:none}
.dest:hover{border-color:var(--ink-soft);color:var(--ink);transform:translateY(-1px)}
.dest .dot{width:7px;height:7px;border-radius:999px;background:var(--muted)}
.dest.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
.dest.on .dot{background:var(--accent-ink)}

/* ---- 9b. TAB BAR (sections as tabs + date filter on the right) ---- */
.tabbar{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);margin-bottom:26px}
.tabs{display:flex;gap:2px;flex-wrap:wrap}
.tab{font-size:14px;font-weight:600;color:var(--ink-soft);text-decoration:none;
  padding:12px 15px;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.16s;white-space:nowrap}
.tab:hover{color:var(--ink)}
.tab.on{color:var(--ink);border-bottom-color:var(--accent)}
.tabbar .segment{margin-bottom:9px}

/* ---- 10. HERO STAT CARD ---- */
.hero{padding:42px 40px;margin-bottom:18px;text-align:center}
.hero .eyebrow{margin-bottom:14px}
.hero .big{font-size:clamp(46px,6.4vw,66px);font-weight:800;letter-spacing:-.03em;line-height:1}
.hero .big.green{color:var(--pos)}
.hero .orders{font-size:13.5px;color:var(--muted);margin-top:10px;font-weight:500}

/* secondary "Gross" line beneath the highlighted Net figure */
.gross-row{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:18px}
.gross-row .gross-label{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.gross-row .gross-val{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.gross-orders{font-size:13px;color:var(--muted);margin-top:6px}

/* footer block (YTD) */
.hero-foot{margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}
.hero-foot .label{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:8px}
.hero-foot .mid{font-size:34px;font-weight:800;letter-spacing:-.02em}
.hero-foot .foot{font-size:12.5px;color:var(--muted);margin-top:9px}

.hero-split{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:34px;border-top:1px solid var(--line)}
.hero-split>div{padding:26px 24px 4px}
.hero-split>div:first-child{border-right:1px solid var(--line)}
.hero-split .label{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:8px}
.hero-split .mid{font-size:34px;font-weight:800;letter-spacing:-.02em}
.hero-split .mid.green{color:var(--pos)}
.hero-split .foot{font-size:12.5px;color:var(--muted);margin-top:9px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.deductions{display:flex;flex-direction:column;align-items:center;gap:7px;margin-top:14px;font-size:12.5px;color:var(--muted)}
.chip{display:inline-flex;align-items:center;gap:6px}
.chip .d{width:7px;height:7px;border-radius:999px;background:var(--muted)}

/* ---- 11. SOURCE CARDS ---- */
.sources{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:18px}
.src{padding:24px 24px 8px;transition:.22s}
.src:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.src .name{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px}
.row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0}
.row .k{font-size:13px;color:var(--ink-soft)}
.row .k small{display:block;font-size:11px;color:var(--muted);margin-top:1px}
.row .v{font-size:15px;font-weight:600}
.row .v.mut{color:var(--muted);font-weight:500}
.row.total{border-top:1px solid var(--line);margin-top:8px;padding-top:13px}
.row.total .k{font-weight:700;color:var(--ink)}
.row.total .v{font-size:18px;font-weight:800;color:var(--pos)}
.row.tax .v{color:var(--ink-soft)}
.row.grand{border-top:1px solid var(--line);margin-top:4px;padding-top:11px}
.row.grand .k{font-weight:700;color:var(--ink)}
.row.grand .v{font-size:16px;font-weight:800;color:var(--ink)}

/* ---- 12. CHART CARD ---- */
.chart-card{padding:26px 26px 28px}
.chart-head{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.chart-head h3{font-size:15px;font-weight:700}
.mini-seg{display:inline-flex;flex-wrap:wrap;gap:2px;background:var(--bg-soft);border:1px solid var(--line);border-radius:11px;padding:3px}
.mini-seg button{font:inherit;font-size:12px;font-weight:600;color:var(--muted);border:none;background:transparent;padding:6px 11px;border-radius:8px;cursor:pointer}
.mini-seg button.on{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.chart-wrapper{position:relative;height:380px}

/* ---- 13. LOGIN ---- */
.login-stage{position:relative;min-height:100vh;display:grid;place-items:center;padding:40px 20px}
.login-theme{position:absolute;top:20px;right:24px}
.login-card{width:100%;max-width:380px;padding:40px 36px;text-align:center}
.login-card .mark{width:54px;height:54px;border-radius:15px;margin:0 auto 20px;display:grid;place-items:center;background:var(--accent-soft);font-size:28px}
.login-card h2{font-size:23px;font-weight:800;letter-spacing:-.01em}
.login-card .tagline{font-size:13.5px;color:var(--muted);margin-top:6px;margin-bottom:30px}
.field{text-align:left;margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-soft);margin-bottom:7px}
.field input{width:100%;font-size:14.5px;padding:12px 14px;background:var(--surface-2)}
.field input:focus{background:var(--surface)}
.login-card .btn-primary{width:100%;justify-content:center;padding:13px;font-size:14.5px;margin-top:4px}
.login-card .forgot{display:inline-block;margin-top:18px;font-size:12.5px;color:var(--muted);text-decoration:none;font-weight:500}
.login-card .forgot:hover{color:var(--accent)}
.banner{font-size:13px;font-weight:500;padding:11px 14px;border-radius:var(--r-sm);margin-bottom:20px;text-align:left}
.banner.err{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent)}
.banner.ok{background:rgba(31,138,91,.10);color:var(--pos);border:1px solid var(--pos)}

/* ---- 14. STATES ---- */
.loading{text-align:center;padding:80px 40px;color:var(--ink-soft)}
.spinner{border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;width:42px;height:42px;
  animation:spin 1s linear infinite;margin:0 auto 18px}
@keyframes spin{to{transform:rotate(360deg)}}
.error-box{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);
  padding:18px;border-radius:var(--r-md);margin:20px 0}

/* ---- 15. ENTRANCE ---- */
.reveal{opacity:0;transform:translateY(10px);animation:rise .5s cubic-bezier(.2,.7,.3,1) forwards}
@keyframes rise{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){.reveal{animation:none;opacity:1;transform:none}}

/* ---- 16. RESPONSIVE ---- */
@media(max-width:560px){
  .hero{padding:32px 22px}
  .hero-split{grid-template-columns:1fr}
  .hero-split>div:first-child{border-right:none;border-bottom:1px solid var(--line)}
  .topbar-actions{width:100%}
  .chart-wrapper{height:300px}
}
