/* =========================================================
   sports tracker - graphite visual system
   TOPAZ  (dark / default) : graphite + gold brass accent
   SIBIR  (light)          : white, greys, calm slate accent
   Token NAMES kept (HTML + chart JS depend on them); only the
   values + element treatment are re-thought onto graphite.
   Weight semantics: --down = loss = good (green),
                     --up   = gain = bad  (red).
   ASCII-only comments (web-system convention).
   ========================================================= */

:root{
  /* ---- TOPAZ (dark / default) ---- */
  --bg:#0d0d0f; --bg2:#08080a;
  --brass:#e0a24c; --brass-2:#f1c270; --brass-deep:#c8883a;
  --ink:#f4f3f1; --muted:#aeaca8; --faint:#7d7a74;
  --line:rgba(255,255,255,.08); --line-strong:rgba(255,255,255,.15);
  --card:#1a1a1d; --card-bd:rgba(255,255,255,.08);
  --well:rgba(0,0,0,.22);
  --up:#e8675e; --up-soft:rgba(232,103,94,.15);
  --down:#46c47e; --down-soft:rgba(70,196,126,.15);
  --flat:#caa14e;
  --cool:#6f9fd0; --cool-light:#8fb6e0;
  --corridor:rgba(224,162,76,.10);
  /* radius scale: sm=small fields/tips, btn=square buttons, ctl=controls/rows/chips, card=cards/pills */
  --r-sm:8px; --r-btn:11px; --r-ctl:14px; --r-card:20px;
  --serif:'Onest',system-ui,-apple-system,sans-serif;
  --sans:'Onest',system-ui,-apple-system,sans-serif;
  --num:'Onest',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --easing:cubic-bezier(.4,.1,.2,1);
  --mtn:url(../images/mountains-dark.webp);
  --img-filter:grayscale(1) brightness(.9) contrast(1.05);
}

/* ---- SIBIR (light): white canvas, slate-blue accent, red reserved ---- */
[data-theme="light"]{
  --bg:#f3f4f6; --bg2:#eceef0;
  --brass:#5f7ea4; --brass-2:#4c6a90; --brass-deep:#86a0c0;
  --ink:#17191d; --muted:#5e636b; --faint:#9298a1;
  --line:rgba(20,24,30,.10); --line-strong:rgba(20,24,30,.18);
  --card:#ffffff; --card-bd:rgba(20,24,30,.08);
  --well:rgba(20,24,30,.045);
  --up:#c5384a; --up-soft:rgba(197,56,74,.12);
  --down:#56986e; --down-soft:rgba(86,152,110,.16);
  --flat:#b9842a;
  --cool:#3f8f8a; --cool-light:#5fa9a3;
  --corridor:rgba(95,126,164,.12);
  --mtn:url(../images/mountains-light.webp);
  --img-filter:grayscale(.55) brightness(1.03);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{background:var(--bg2);overflow-x:hidden;overflow-y:scroll;scrollbar-gutter:stable;width:100%;max-width:100%;overscroll-behavior-x:none;touch-action:pan-y;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:radial-gradient(125% 85% at 50% -12%, #17171b 0%, var(--bg) 55%);
  min-height:100vh;overflow-x:hidden;width:100%;max-width:100vw;position:relative;overscroll-behavior-x:none;line-height:1.45;
  -webkit-font-smoothing:antialiased;transition:color .3s var(--easing),background .5s var(--easing);
  padding:max(env(safe-area-inset-top),14px) max(env(safe-area-inset-right),16px) max(env(safe-area-inset-bottom),28px) max(env(safe-area-inset-left),16px);
}
[data-theme="light"] body{background:radial-gradient(120% 82% at 50% -8%, #ffffff 0%, #f3f4f6 54%, var(--bg2) 100%)}

/* ----- living background: glows + grey mountains ----- */
.bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.bg .glow{position:absolute;border-radius:50%;filter:blur(70px);opacity:.32;animation:drift 26s ease-in-out infinite}
.bg .g1{width:300px;height:300px;background:radial-gradient(circle,rgba(224,162,76,.16),transparent 70%);top:-70px;left:-60px}
.bg .g2{width:380px;height:380px;background:radial-gradient(circle,rgba(111,159,208,.12),transparent 70%);top:32%;right:-120px;animation-delay:-9s}
.bg .g3{width:300px;height:300px;background:radial-gradient(circle,rgba(111,159,208,.07),transparent 70%);bottom:-40px;left:20%;animation-delay:-16s}
@keyframes drift{0%,100%{transform:translate(0,0)}33%{transform:translate(24px,-22px)}66%{transform:translate(-18px,18px)}}
[data-theme="light"] .bg .glow{filter:blur(72px)}
[data-theme="light"] .bg .g1{background:radial-gradient(circle,rgba(95,126,164,.18),transparent 70%);opacity:.3}
[data-theme="light"] .bg .g2{background:radial-gradient(circle,rgba(63,143,138,.16),transparent 70%);opacity:.28}
[data-theme="light"] .bg .g3{opacity:0}
.bg svg.stars{position:absolute;inset:0;width:100%;height:100%}
.star{fill:#f0c87a;animation:tw 4s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.12}50%{opacity:.6}}
[data-theme="light"] .stars,[data-theme="light"] .star{display:none}
.mtnimg{position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(720px,100%);height:clamp(240px,34vh,400px);z-index:1;pointer-events:none;
  background:var(--mtn) center 18% / cover no-repeat;opacity:.55;filter:var(--img-filter);
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 22%,#000 78%,transparent 100%),linear-gradient(to bottom,#000 0,#000 48%,transparent 92%);
  mask-image:linear-gradient(to right,transparent 0,#000 22%,#000 78%,transparent 100%),linear-gradient(to bottom,#000 0,#000 48%,transparent 92%);
  -webkit-mask-composite:source-in;mask-composite:intersect}
[data-theme="light"] .mtnimg{opacity:.85}
.mtn-bottom{position:absolute;left:0;bottom:0;width:100%;height:30vh;min-height:180px;opacity:.9}
[data-theme="light"] .mtn-bottom{opacity:.5}
[data-theme="light"] .mtn-bottom path:nth-child(1){fill:#d6d9dd}
[data-theme="light"] .mtn-bottom path:nth-child(2){fill:#c6cace}
[data-theme="light"] .mtn-bottom path:nth-child(3){fill:#b4b9bf}

/* ----- frame ----- */
.wrap{position:relative;z-index:5;max-width:440px;margin:0 auto}
header{position:relative;z-index:4;display:flex;justify-content:center;padding:30px 0 0;margin-bottom:-16px;pointer-events:none}
.logo-full{height:auto;width:min(78%,310px);max-width:100%;object-fit:contain;display:block;margin:0 auto;filter:drop-shadow(0 8px 22px rgba(0,0,0,.45));position:relative;z-index:4}
.logo-full.logo-light{display:none}
[data-theme="light"] .logo-full.logo-dark{display:none}
[data-theme="light"] .logo-full.logo-light{display:block}
/* light logo is teal art -> shift to the slate-blue light accent */
[data-theme="light"] .logo-full{filter:hue-rotate(34deg) saturate(.72) brightness(.97) drop-shadow(0 6px 16px rgba(30,40,60,.14))}

/* ----- card: solid graphite elevation (no glass) ----- */
.card{position:relative;overflow:hidden;border:1px solid var(--card-bd);border-radius:var(--r-card);padding:18px;margin-bottom:14px;
  background:var(--card);
  box-shadow:0 14px 38px -24px rgba(0,0,0,.72),inset 0 1px 0 rgba(255,255,255,.05)}
[data-theme="light"] .card{box-shadow:0 18px 42px -26px rgba(30,42,70,.4),inset 0 1px 0 rgba(255,255,255,.8)}
.card>*{position:relative;z-index:2}
.sumcard{padding-top:26px}
.card-h{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:0 0 14px;display:flex;flex-wrap:nowrap;gap:10px;justify-content:space-between;align-items:center}
.ch-ic{display:inline-flex;flex:none;width:1.2em;height:1.2em;vertical-align:-.18em;margin-right:.45em;opacity:.85;color:var(--brass)}
.ch-ic svg{width:100%;height:100%;display:block}

/* ----- summary ----- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat{text-align:center;padding:4px 2px;display:flex;flex-direction:column;align-items:center}
.stat .si{display:block;color:var(--brass);margin:0 auto 7px;opacity:.92}
.stat .si svg{width:22px;height:22px;display:block;margin:0 auto}
.stat .n{font-family:var(--num);font-weight:700;font-size:40px;line-height:1;letter-spacing:-.02em;position:relative;display:inline-block;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.stat .u{font-size:13px;font-weight:500;color:var(--faint);position:absolute;right:-1.9em;bottom:.32em;letter-spacing:0}
.stat .l{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.stat .d{font-family:var(--mono);font-size:11px;margin-top:3px;white-space:nowrap}
.stat .l{white-space:nowrap}
.goalset{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);display:inline-flex;align-items:center;gap:5px;
  background:color-mix(in srgb,var(--brass) 11%,transparent);border:1px solid color-mix(in srgb,var(--brass) 42%,transparent);border-radius:var(--r-card);padding:5px 11px}
.goalset .gs-star{width:13px;height:13px;flex:none;color:var(--brass)}
.goalset .gs-star svg{width:100%;height:100%;display:block}
.goalset input{width:34px;background:transparent;border:none;color:var(--brass-2);font-family:var(--num);font-weight:700;font-size:15px;text-align:center;padding:0;margin:0 1px;font-variant-numeric:tabular-nums}
.goalset input:focus{outline:none;color:var(--ink)}

/* ----- goal bar: centered polar-star with +/- stepper ----- */
.goalbar{display:flex;align-items:center;justify-content:center;gap:10px;max-width:300px;margin:2px auto 0;
  background:var(--well);border:1px solid var(--line);border-radius:var(--r-card);padding:7px 14px}
.goalbar .gs-star{width:14px;height:14px;flex:none;color:var(--brass);opacity:.85}
.goalbar .gs-star svg{width:100%;height:100%;display:block}
.goal-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.goal-btn{width:30px;height:30px;flex:none;border:none;border-radius:var(--r-btn);background:color-mix(in srgb,var(--ink) 7%,transparent);color:var(--muted);font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .08s,color .15s}
.goal-btn:active{transform:scale(.9);background:color-mix(in srgb,var(--ink) 13%,transparent);color:var(--ink)}
@media(hover:hover){.goal-btn:hover{background:color-mix(in srgb,var(--ink) 12%,transparent);color:var(--ink)}}
.goal-val{font-family:var(--num);font-weight:700;font-size:22px;color:var(--ink);min-width:42px;text-align:center;font-variant-numeric:tabular-nums;line-height:1}
.goal-unit{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.06em}
.sum-div{height:1px;margin:16px 0;background:linear-gradient(to right,transparent,var(--line-strong) 25%,var(--line-strong) 75%,transparent)}

/* ----- day record ----- */
.today{position:relative}
.today .saved{margin-left:auto;flex:0 0 auto;white-space:nowrap}
.datebar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:-2px 0 14px}
.today .date{font-family:var(--serif);font-weight:600;font-style:normal;font-size:18px;color:var(--brass);letter-spacing:0;min-width:170px;text-align:center}
.today .date .dnum{color:var(--ink);font-weight:700}
.datenav{display:flex;align-items:center;gap:8px}
.dn{background:none;border:none;color:var(--brass);font-size:22px;line-height:1;cursor:pointer;padding:0 4px;opacity:.7;transition:opacity .15s}
.dn:hover{opacity:1}
.dn:disabled{opacity:.2;cursor:default}
.tojump{background:color-mix(in srgb,var(--brass) 14%,transparent);border:1px solid var(--line-strong);color:var(--brass-2);font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;cursor:pointer;padding:6px 12px;border-radius:var(--r-card);
  opacity:0;pointer-events:none;transform:translateX(6px);transition:opacity .2s,transform .2s,background .15s}
.tojump.shown{opacity:1;pointer-events:auto;transform:none}
.tojump:active{background:color-mix(in srgb,var(--brass) 24%,transparent)}
.saved{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--down);opacity:0;transition:opacity .25s}
.saved.on{opacity:1}

/* ----- stepper (weight / waist) ----- */
.stepper{display:flex;align-items:center;gap:12px;margin-top:14px}
.stepper .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);width:54px;flex:0 0 54px}
.stepper .ctrl{flex:1;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl);padding:6px}
.step-btn{width:42px;height:42px;flex:0 0 42px;border:none;border-radius:var(--r-btn);background:color-mix(in srgb,var(--brass) 14%,transparent);color:var(--brass-2);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .08s}
.step-btn:active{transform:scale(.92);background:color-mix(in srgb,var(--brass) 26%,transparent)}
@media(hover:hover){.step-btn:hover{background:color-mix(in srgb,var(--brass) 22%,transparent);color:var(--brass-2)}}
.step-val{flex:1;text-align:center;font-family:var(--mono);font-weight:500;font-size:25px;color:var(--ink);background:none;border:none;width:100%;padding:0;font-variant-numeric:tabular-nums}
.step-val:focus{outline:none;color:var(--brass-2)}
.step-val.ghost{color:var(--faint)}
.step-unit{font-size:13px;color:var(--faint);margin-left:2px}

/* ----- food / day mood segs ----- */
.food{margin-top:16px}
.food-h{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:9px}
.segs{display:flex;gap:7px}
.seg{flex:1;border:1px solid var(--line);border-radius:var(--r-ctl);padding:11px 4px;background:var(--well);cursor:pointer;font-family:var(--mono);font-size:11.5px;color:var(--muted);transition:transform .08s,background .16s,border-color .16s,color .16s}
@media(hover:hover){.seg:hover{background:color-mix(in srgb,var(--ink) 6%,transparent);color:var(--ink)}}
.seg:active{transform:scale(.96)}
.seg.green.on{background:var(--down-soft);border-color:color-mix(in srgb,var(--down) 55%,transparent);color:var(--down)}
.seg.yellow.on{background:color-mix(in srgb,var(--flat) 16%,transparent);border-color:color-mix(in srgb,var(--flat) 55%,transparent);color:var(--flat)}
.seg.red.on{background:var(--up-soft);border-color:color-mix(in srgb,var(--up) 55%,transparent);color:var(--up)}

/* ----- pool / activity bar ----- */
.poolbar{display:flex;align-items:center;gap:10px;margin-top:16px;height:50px;padding:0 14px;box-sizing:border-box;border:1px solid var(--line);border-radius:var(--r-ctl);background:var(--well);cursor:pointer;transition:background .16s,border-color .16s,transform .08s}
.poolbar .pic{display:inline-flex;color:var(--faint);transition:color .16s}
.poolbar .pic svg{width:20px;height:20px;display:block}
.poolbar .ptx{flex:1;font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--muted);transition:color .16s}
.poolbar .pstate{font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--faint);transition:color .16s}
.poolbar:hover{background:color-mix(in srgb,var(--ink) 5%,transparent)}
.poolbar:active{transform:scale(.99)}
.poolbar.on{background:color-mix(in srgb,var(--cool) 16%,transparent);border-color:color-mix(in srgb,var(--cool) 50%,transparent)}
.poolbar.on .pic,.poolbar.on .ptx,.poolbar.on .pstate{color:var(--cool-light)}
.poolbar .pmeters{display:none;align-items:center;gap:5px;font-family:var(--mono);font-size:11px;color:var(--cool-light)}
.poolbar .pmeters input{width:58px;height:32px;box-sizing:border-box;background:var(--well);border:1px solid color-mix(in srgb,var(--cool) 40%,transparent);border-radius:var(--r-sm);color:var(--cool-light);font-family:var(--mono);font-size:13px;text-align:center;padding:0 6px}
.poolbar .pmeters input:focus{outline:none;border-color:var(--cool-light)}
.poolbar.on .pmeters{display:inline-flex}
.poolbar.on .pstate{display:none}

/* ----- factor chips ----- */
.factors-wrap{margin-top:16px}
.factors-h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:9px}
.factors{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.chip{display:flex;align-items:center;justify-content:flex-start;gap:7px;font-family:var(--mono);font-size:11.5px;letter-spacing:.01em;color:var(--muted);background:var(--well);border:1px solid var(--line);border-radius:var(--r-card);padding:7px 12px;cursor:pointer;transition:transform .08s,background .16s,border-color .16s,color .16s}
@media(hover:hover){.chip:hover:not(.on){background:color-mix(in srgb,var(--ink) 6%,transparent);color:var(--ink)}}
.chip:active{transform:scale(.95)}
.chip.on{background:var(--up-soft);border-color:color-mix(in srgb,var(--up) 45%,transparent);color:var(--up)}
.chip.on.good{background:var(--down-soft);border-color:color-mix(in srgb,var(--down) 45%,transparent);color:var(--down)}
.chip-ic{width:15px;height:15px;flex:none;display:inline-flex}
.chip-ic svg{width:100%;height:100%;display:block}

/* ----- chart (dynamics) ----- */
.ranges{display:flex;gap:6px}
.rng{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--faint);background:none;border:1px solid transparent;border-radius:var(--r-sm);padding:3px 8px;cursor:pointer;transition:.16s var(--easing)}
@media(hover:hover){.rng:hover:not(.on){color:var(--ink)}}
.rng.on{color:var(--brass-2);border-color:var(--line);background:color-mix(in srgb,var(--brass) 10%,transparent)}
.chart{width:100%;height:auto;display:block;overflow:visible}
.chart-wrap{position:relative;touch-action:pan-y}
.cguide{position:absolute;top:10px;bottom:24px;width:1px;background:var(--brass-2);opacity:0;pointer-events:none;transition:opacity .12s}
.ctip{position:absolute;top:0;background:var(--bg2);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:5px 9px;font-family:var(--mono);font-size:11px;color:var(--ink);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s;box-shadow:0 8px 22px -10px rgba(0,0,0,.7)}
.ctip b{color:var(--brass-2);font-weight:500;margin-right:4px}
.ctip span{display:block;color:var(--muted);font-size:9.5px;margin-top:2px;letter-spacing:.02em}
[data-theme="light"] .ctip{background:#fff;box-shadow:0 10px 26px -12px rgba(30,42,70,.45)}
.legend{display:flex;gap:16px;justify-content:center;margin-top:8px;font-family:var(--mono);font-size:10px;color:var(--muted)}
.legend i{display:inline-block;width:14px;height:2px;vertical-align:middle;margin-right:5px}
/* light chart: cool teal palette away from gold-on-white */
[data-theme="light"] .chart,[data-theme="light"] .legend{
  --brass:#3f8f8a; --brass-2:#358581; --brass-deep:#2f7c78;
  --corridor:rgba(63,143,138,.13);
}

/* ----- habits (horizontal bars) ----- */
.habits{display:flex;flex-direction:column;gap:16px;padding-top:2px}
.habit{text-align:left}
.habit .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.03em;color:var(--faint);margin-top:5px}
.habit-top{display:flex;align-items:center;gap:9px}
.habit-ic{display:inline-flex;flex:none;width:20px;height:20px;color:var(--brass);opacity:.92}
.habit-ic svg{width:100%;height:100%;display:block}
.habit-name{flex:1;font-family:var(--serif);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:.01em}
.habit-count{font-family:var(--mono);font-weight:600;font-size:20px;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.habit-count .of{font-size:12px;color:var(--faint);font-weight:400;margin-left:1px}
.hbar{height:8px;border-radius:6px;background:var(--well);overflow:hidden;margin-top:9px}
[data-theme="light"] .hbar{background:rgba(20,24,30,.08)}
.hbar-fill{height:100%;width:0;border-radius:6px;transition:width .9s cubic-bezier(.2,.7,.3,1)}
.habit-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:5px;min-height:25px}
.habit-foot .meta{margin-top:0}
.habit-foot .pill{margin-top:0}
.pill{display:inline-block;font-family:var(--mono);font-size:10px;letter-spacing:.05em;padding:4px 11px;border-radius:var(--r-ctl);margin-top:7px;text-align:center;line-height:1.45;max-width:260px}
.pill.pool-on{background:color-mix(in srgb,var(--cool) 16%,transparent);color:var(--cool-light)}
.pill.rest{background:var(--well);color:var(--muted)}
.pill.pool-push{background:color-mix(in srgb,var(--brass) 18%,transparent);color:var(--brass-2);border:1px solid color-mix(in srgb,var(--brass) 35%,transparent);animation:pushpulse 2.4s ease-in-out infinite}
@keyframes pushpulse{0%,100%{box-shadow:0 0 0 0 rgba(224,162,76,0)}50%{box-shadow:0 0 0 4px rgba(224,162,76,.12)}}
@media (prefers-reduced-motion:reduce){.pill.pool-push{animation:none}}

/* ----- app voice / coach ----- */
.coach{font-family:var(--sans);font-size:13.5px;line-height:1.45;padding:11px 14px;border-radius:var(--r-ctl);margin:0 0 14px;border:1px solid var(--line);background:var(--well)}
.coach-down{border-color:color-mix(in srgb,var(--down) 40%,transparent);background:var(--down-soft);color:var(--down)}
.coach-up{border-color:color-mix(in srgb,var(--up) 40%,transparent);background:var(--up-soft);color:var(--up)}
.coach-flat{border-color:color-mix(in srgb,var(--flat) 40%,transparent);background:color-mix(in srgb,var(--flat) 12%,transparent);color:var(--flat)}
.coach.dinsight{border-color:color-mix(in srgb,var(--cool) 40%,transparent);background:color-mix(in srgb,var(--cool) 12%,transparent);color:var(--cool-light)}
.coach-sum{font-size:12.5px;padding:9px 12px;margin:14px 0 0;background:var(--well);border-color:var(--line);color:var(--muted)}
.coach-sum:empty{display:none}

/* ----- weekly digest ----- */
.d-head{font-size:14px;color:var(--muted);margin-bottom:14px}
[data-theme="light"] .d-head{color:var(--ink)}
.d-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.d-main{flex:1 1 auto}
.d-trend{flex:0 0 auto;font-family:var(--mono);font-size:12.5px;font-weight:600;padding:3px 10px;border-radius:var(--r-card);border:1px solid color-mix(in srgb,currentColor 35%,transparent);white-space:nowrap}
.d-panel{background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl);padding:13px 15px;margin-bottom:10px}
.d-sec-l{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.dmetrics{display:flex;gap:20px;flex-wrap:wrap}
.dm{display:flex;flex-direction:column;gap:4px}
.dm-v{font-family:var(--mono);font-weight:600;font-size:23px;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}
.dm-v .dm-of{font-size:12px;color:var(--faint);font-weight:400;margin-left:1px}
.dm-l{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.d-tags{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.digest b{color:var(--brass-2);font-weight:600}
.digest .em{font-family:var(--serif);font-style:normal;color:var(--muted);font-size:13px}
.dstat{display:flex;align-items:center;flex-wrap:wrap;gap:7px}
.dlabel{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-right:3px}
.badge{font-family:var(--mono);font-size:11px;letter-spacing:.02em;padding:5px 10px;border-radius:var(--r-card);background:color-mix(in srgb,var(--brass) 14%,transparent);color:var(--brass-2);border:1px solid color-mix(in srgb,var(--brass) 30%,transparent)}
.badge.bad{background:var(--up-soft);color:var(--up);border-color:color-mix(in srgb,var(--up) 30%,transparent)}
.badge.good{background:var(--down-soft);color:var(--down);border-color:color-mix(in srgb,var(--down) 35%,transparent)}
.badge-ic{display:inline-flex;flex:none;width:1.1em;height:1.1em;vertical-align:-.15em;margin-right:.3em}
.badge-ic svg{width:100%;height:100%;display:block}

/* ----- footer ----- */
footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px 16px;padding:10px 0 4px;font-family:var(--mono);font-size:10.5px;color:var(--faint);letter-spacing:.06em}
footer .flink,footer .mode{display:inline-flex;align-items:center;height:20px;line-height:1;margin:0;font-size:11px}
.flink{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;line-height:1;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line)}
.flink:active{color:var(--brass-2)}
.fnote{flex-basis:100%;text-align:center;margin-top:6px;color:var(--faint)}
.fnote .ftag{opacity:.8}
.fnote a{color:var(--faint);text-decoration:none;transition:color .3s}
.fnote a:hover{color:var(--brass);text-decoration:underline;text-underline-offset:3px}
.mode{display:inline-flex;align-items:center;gap:5px;line-height:1.4}
.mode .dot{width:6px;height:6px;border-radius:50%;background:var(--down)}
.mode.local .dot{background:var(--flat)}
.mode.memory .dot{background:var(--up)}
.empty{text-align:center;color:var(--muted);font-size:13.5px;padding:8px 4px;line-height:1.5}

/* ----- entrance ----- */
.reveal{animation:rise .65s cubic-bezier(.2,.7,.3,1) both}
@keyframes rise{from{opacity:0;transform:translateY(18px) scale(.99)}to{opacity:1;transform:none}}
.wrap>.reveal:nth-of-type(1){animation-delay:.02s}
.wrap>.reveal:nth-of-type(2){animation-delay:.10s}
.wrap>.reveal:nth-of-type(3){animation-delay:.18s}
.wrap>.reveal:nth-of-type(4){animation-delay:.26s}
.wrap>.reveal:nth-of-type(5){animation-delay:.34s}
.wrap>.reveal:nth-of-type(6){animation-delay:.42s}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}
.hide{display:none!important}

/* ----- day habits input (good / bad) ----- */
.habits-input{margin-top:2px}
.hi-h{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:11px}
.hi-sub{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:13px 0 8px}
.hi-sub::after{content:"";flex:1;height:1px;background:var(--line)}
.hi-sub.good{color:var(--down)}
.hi-sub.bad{color:var(--up)}
.hgrid{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.week-chip{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;color:var(--cool-light);background:color-mix(in srgb,var(--cool) 14%,transparent);border:1px solid color-mix(in srgb,var(--cool) 32%,transparent);border-radius:var(--r-ctl);padding:3px 10px;white-space:nowrap}

/* ----- bottom tab bar (translucent, sanctioned glass) ----- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;justify-content:center;pointer-events:none;
  padding:0 16px calc(env(safe-area-inset-bottom) + 9px)}
.tabbar-inner{pointer-events:auto;display:flex;gap:5px;padding:5px;border:1px solid color-mix(in srgb,var(--ink) 10%,transparent);border-radius:var(--r-card);
  background:color-mix(in srgb,var(--card) 50%,transparent);backdrop-filter:blur(22px) saturate(1.6);-webkit-backdrop-filter:blur(22px) saturate(1.6);
  box-shadow:0 12px 30px -16px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.08)}
.tab{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:92px;padding:5px 16px 4px;border:none;background:none;border-radius:var(--r-ctl);
  color:var(--faint);font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:color .2s var(--easing),background .2s var(--easing)}
.tab svg{width:20px;height:20px;display:block;stroke-width:1.7}
@media(hover:hover){.tab:hover:not(.on){color:var(--ink)}}
.tab.on{color:var(--brass);background:color-mix(in srgb,var(--brass) 12%,transparent)}
.wrap{padding-bottom:calc(env(safe-area-inset-bottom) + 84px)}

/* ----- profile stub (pre-auth) ----- */
.profile-stub{text-align:center;padding:30px 20px}
.profile-stub .ps-ic{width:64px;height:64px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;border-radius:50%;
  background:color-mix(in srgb,var(--brass) 12%,transparent);border:1px solid var(--line-brass,rgba(224,162,76,.4));color:var(--brass)}
.profile-stub .ps-ic svg{width:30px;height:30px}
.profile-stub h2{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink);margin:0 0 8px}
.profile-stub p{font-size:13.5px;color:var(--muted);line-height:1.5;max-width:280px;margin:0 auto}

/* ----- auth gate (login / register) ----- */
.auth-card,.paywall-card,.acct-card{max-width:380px;margin:8px auto 0}
.auth-tabs{display:flex;gap:5px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl);padding:4px;margin-bottom:16px}
.auth-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;border:none;background:none;border-radius:var(--r-btn);padding:11px;font-family:var(--sans);font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;transition:.18s var(--easing)}
.auth-tab .at-ic{display:inline-flex}
.auth-tab .at-ic svg{width:17px;height:17px;display:block}
.auth-tab.on{background:color-mix(in srgb,var(--brass) 13%,transparent);color:var(--brass-2)}
#authForm{display:flex;flex-direction:column;gap:10px}
.auth-in{height:48px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl);color:var(--ink);font-family:var(--sans);font-size:15px;padding:0 14px;transition:border-color .15s}
.auth-in::placeholder{color:var(--faint)}
.auth-in:focus{outline:none;border-color:color-mix(in srgb,var(--brass) 50%,transparent)}
.auth-err{font-family:var(--sans);font-size:12.5px;text-align:center;color:var(--up);background:var(--up-soft);border:1px solid color-mix(in srgb,var(--up) 35%,transparent);border-radius:var(--r-btn);padding:9px 12px}
.auth-submit{height:50px;border:none;border-radius:var(--r-ctl);background:linear-gradient(135deg,var(--brass),var(--brass-2));color:#1a1208;font-family:var(--sans);font-weight:700;font-size:16px;cursor:pointer;margin-top:4px;transition:filter .15s,transform .08s}
[data-theme="light"] .auth-submit{color:#fff}
.auth-submit:active{transform:scale(.99)}
@media(hover:hover){.auth-submit:hover{filter:brightness(1.06)}}
.auth-submit.busy{opacity:.6;pointer-events:none}

/* ----- paywall ----- */
.paywall-card{text-align:center;padding:26px 20px}
.pw-ic{width:56px;height:56px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:color-mix(in srgb,var(--brass) 12%,transparent);border:1px solid color-mix(in srgb,var(--brass) 40%,transparent);color:var(--brass)}
.pw-ic svg{width:28px;height:28px}
.paywall-card h2{font-family:var(--serif);font-weight:600;font-size:21px;color:var(--ink);margin:0 0 8px}
.paywall-card p{font-size:13.5px;color:var(--muted);line-height:1.5;max-width:300px;margin:0 auto 18px}
.pw-plans{display:flex;gap:10px;margin:0 0 18px}
.pw-plan{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 8px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl)}
.pw-plan.on{border-color:color-mix(in srgb,var(--brass) 50%,transparent);background:color-mix(in srgb,var(--brass) 10%,transparent)}
.pw-price{font-family:var(--num);font-weight:700;font-size:24px;color:var(--ink)}
.pw-per{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--faint);text-transform:uppercase}
.pw-badge{position:absolute;top:-9px;font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--bg);background:var(--brass);border-radius:var(--r-sm);padding:2px 7px}
.pw-logout{display:block;margin:14px auto 0}

/* ----- account (logged in) ----- */
.acct-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.acct-ava{width:48px;height:48px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:50%;background:color-mix(in srgb,var(--brass) 14%,transparent);border:1px solid color-mix(in srgb,var(--brass) 40%,transparent);color:var(--brass-2);font-family:var(--num);font-weight:700;font-size:20px;text-transform:uppercase}
.acct-tx{display:flex;flex-direction:column;gap:3px;min-width:0}
.acct-email{font-family:var(--sans);font-size:15px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct-plan{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--brass)}
.acct-logout{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:46px;border:1px solid var(--line);background:var(--well);border-radius:var(--r-ctl);color:var(--muted);font-family:var(--sans);font-size:14px;cursor:pointer;transition:.16s var(--easing)}
.acct-logout svg{width:18px;height:18px}
@media(hover:hover){.acct-logout:hover{color:var(--ink);border-color:var(--line-strong)}}
.acct-logout:active{transform:scale(.99)}

/* ----- auth gate extras (forgot / social / secure) ----- */
.auth-forgot{display:block;margin:8px auto 0;background:none;border:none;color:var(--brass-2);font-family:var(--mono);font-size:11px;letter-spacing:.04em;cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--brass) 40%,transparent)}
.auth-or{display:flex;align-items:center;gap:12px;margin:18px 0 12px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-social{display:flex;gap:10px}
.auth-soc{flex:1;display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl);cursor:pointer;transition:border-color .16s}
@media(hover:hover){.auth-soc:hover{border-color:var(--line-strong)}}
.auth-soc-ic{width:26px;height:26px;flex:none;display:flex;align-items:center;justify-content:center}
.auth-soc-ic svg{width:26px;height:26px;display:block}
.auth-soc-t{flex:1;font-family:var(--sans);font-size:14px;color:var(--ink);text-align:left}
.auth-soon{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);background:var(--well);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px 7px}
.auth-secure{display:flex;gap:11px;align-items:flex-start;margin-top:16px;padding:13px;background:var(--well);border:1px solid var(--line);border-radius:var(--r-ctl)}
.auth-secure-ic{flex:none;color:var(--brass);opacity:.85}
.auth-secure-ic svg{width:24px;height:24px;display:block}
.auth-secure-t{font-family:var(--sans);font-size:12px;line-height:1.45;color:var(--muted)}

/* ----- shared modal (forgot password, profile edits) ----- */
.modal-wrap{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-end;justify-content:center;padding:16px;background:rgba(6,6,9,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.modal-card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--card-bd);border-radius:var(--r-card);padding:20px;box-shadow:0 -10px 50px -16px rgba(0,0,0,.7);animation:mUp .3s cubic-bezier(.2,.7,.3,1) both}
@keyframes mUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.modal-card h3{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink);margin:0 0 6px}
.modal-card .m-sub{font-size:13px;color:var(--muted);line-height:1.45;margin:0 0 16px}
.modal-card .auth-in{width:100%;margin-bottom:10px}
.modal-card .auth-err{margin-bottom:10px}
.m-actions{display:flex;gap:10px;margin-top:6px}
.m-actions button{flex:1;height:46px;border-radius:var(--r-ctl);font-family:var(--sans);font-size:15px;cursor:pointer}
.m-ghost{background:var(--well);color:var(--muted);border:1px solid var(--line)}
.m-primary{border:none;background:linear-gradient(135deg,var(--brass),var(--brass-2));color:#1a1208;font-weight:700}
[data-theme="light"] .m-primary{color:#fff}
@media (min-width:540px){.modal-wrap{align-items:center}}

/* ----- toast ----- */
.toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:calc(env(safe-area-inset-bottom) + 96px);z-index:130;max-width:340px;background:var(--card);border:1px solid var(--line-strong);border-radius:var(--r-ctl);padding:11px 16px;font-family:var(--sans);font-size:13.5px;color:var(--ink);box-shadow:0 14px 38px -16px rgba(0,0,0,.7);opacity:0;pointer-events:none;transition:opacity .25s var(--easing),transform .25s var(--easing)}
.toast.on{opacity:1;transform:translateX(-50%)}

/* ----- profile hub (account, poker-parity) ----- */
.pf-id{text-align:center;padding:28px 0 2px}
.pf-ava{margin:0 auto 12px}
.pf-name{font-family:var(--serif);font-weight:600;font-size:22px;line-height:1.15;color:var(--ink);margin-bottom:1px}
.pf-meta{font-family:var(--mono);font-size:12px;color:var(--muted)}
.pf-badge{display:inline-block;margin-top:11px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:4px 13px;border-radius:var(--r-card);color:var(--cool-light);border:1px solid color-mix(in srgb,var(--cool) 38%,transparent);background:color-mix(in srgb,var(--cool) 12%,transparent)}
.pf-badge.trial{color:var(--brass-2);border-color:color-mix(in srgb,var(--brass) 40%,transparent);background:color-mix(in srgb,var(--brass) 11%,transparent)}
.pf-badge.active,.pf-badge.friend{color:var(--down);border-color:color-mix(in srgb,var(--down) 40%,transparent);background:var(--down-soft)}
.pf-sec-t{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin:18px 6px 9px}
.pf-list{padding:4px 6px}
.pf-row{display:flex;align-items:center;gap:13px;padding:13px 10px;cursor:pointer;border-radius:var(--r-ctl);transition:background .14s}
.pf-row+.pf-row{border-top:1px solid var(--line)}
@media(hover:hover){.pf-row:hover{background:color-mix(in srgb,var(--ink) 4%,transparent)}}
.pf-ic{width:34px;height:34px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:9px;background:var(--well);color:var(--brass)}
.pf-ic svg{width:19px;height:19px}
.pf-ic.logo{background:transparent;padding:0}
.pf-ic.logo svg{width:34px;height:34px}
.pf-row-l{flex:1;min-width:0}
.pf-row-k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:3px;display:flex;align-items:center;gap:6px}
.pf-row-v{font-family:var(--sans);font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-row-act{flex:none;font-family:var(--sans);font-size:13px;color:var(--brass-2);font-weight:500}
.pf-dim{color:var(--faint)}
.pf-nav-arrow{flex:none;color:var(--faint);display:inline-flex}
.pf-nav-arrow svg{width:18px;height:18px}
.pf-verify{font-family:var(--mono);font-size:8px;letter-spacing:.04em;padding:2px 6px;border-radius:var(--r-sm);color:var(--faint);background:var(--well);text-transform:none}
.pf-verify.ok{color:var(--down);background:var(--down-soft)}
#profileHub .acct-logout{margin-top:18px}
/* unified row controls: theme swatch, selected check, toggle (one grammar across all profile sections) */
.pf-ic.th-dark,.pf-ic.th-light{position:relative;color:transparent;box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--ink) 10%,transparent)}
.pf-ic.th-dark{background:linear-gradient(135deg,#2b2b30,#161619 60%,#0b0b0d)}
.pf-ic.th-light{background:linear-gradient(135deg,#fff,#eceef0)}
.pf-ic.th-dark::after,.pf-ic.th-light::after{content:"";position:absolute;right:6px;bottom:6px;width:9px;height:9px;border-radius:50%}
.pf-ic.th-dark::after{background:linear-gradient(135deg,#f7d99b,#e0a24c)}
.pf-ic.th-light::after{background:linear-gradient(135deg,#80a0c6,#5f7ea4)}
.pf-row.sel{background:color-mix(in srgb,var(--brass) 9%,transparent)}
@media(hover:hover){.pf-row.sel:hover{background:color-mix(in srgb,var(--brass) 12%,transparent)}}
.pf-check{flex:none;color:var(--brass-2);display:none}
.pf-row.sel .pf-check{display:inline-flex}
.pf-check svg{width:20px;height:20px}
.pf-toggle{position:relative;width:44px;height:26px;flex:none;border-radius:13px;background:color-mix(in srgb,var(--ink) 12%,transparent);border:1px solid var(--line);transition:background .2s,border-color .2s}
.pf-toggle::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--muted);transition:transform .22s cubic-bezier(.3,.7,.3,1),background .2s}
.pf-row.on{background:color-mix(in srgb,var(--brass) 9%,transparent)}
.pf-row.on .pf-toggle{background:color-mix(in srgb,var(--brass) 40%,transparent);border-color:var(--brass)}
.pf-row.on .pf-toggle::after{transform:translateX(18px);background:var(--brass-2)}
.pf-row.disabled{cursor:default}
.pf-row.disabled .pf-toggle{display:none}
.pf-notif .pf-row{cursor:pointer}
.pf-notif .pf-row-v{white-space:normal;overflow:visible;text-overflow:clip}
@media (min-width:700px){.pf-notif{display:none}}

/* ----- splash / launch screen (always dark graphite, fades into app) ----- */
#splash{position:fixed;inset:0;z-index:200;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:1;transition:opacity .55s ease}
#splash.gone{opacity:0;pointer-events:none}
#splash .sp-mtn{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);width:min(960px,135%);height:clamp(360px,64vh,660px);
  background:var(--mtn) center 32%/cover no-repeat;filter:var(--img-filter);opacity:.55;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 22%,#000 78%,transparent),linear-gradient(to bottom,transparent 0,#000 26%,#000 68%,transparent 100%);
  mask-image:linear-gradient(to right,transparent,#000 22%,#000 78%,transparent),linear-gradient(to bottom,transparent 0,#000 26%,#000 68%,transparent 100%);
  -webkit-mask-composite:source-in;mask-composite:intersect;animation:spMtn 1.2s ease both}
#splash .sp-logo{position:relative;z-index:2;width:min(72%,300px);filter:drop-shadow(0 8px 22px rgba(0,0,0,.5));animation:spLogo 1s cubic-bezier(.2,.7,.3,1) both}
#splash .sp-ridge{position:absolute;left:0;bottom:0;width:100%;height:28vh;min-height:160px;opacity:.9;animation:spRidge 1.1s ease both}
@keyframes spLogo{from{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:none}}
@keyframes spMtn{from{opacity:0}to{opacity:.4}}
@keyframes spRidge{from{opacity:0;transform:translateY(20px)}to{opacity:.9;transform:none}}
#splash .sp-logo.logo-light{display:none}
[data-theme="light"] #splash .sp-logo.logo-dark{display:none}
[data-theme="light"] #splash .sp-logo.logo-light{display:block}
[data-theme="light"] #splash .sp-logo{filter:hue-rotate(34deg) saturate(.72) brightness(.97) drop-shadow(0 8px 22px rgba(30,40,60,.18))}
[data-theme="light"] #splash .sp-ridge{opacity:.5}
[data-theme="light"] #splash .sp-ridge path:nth-child(1){fill:#d6d9dd}
[data-theme="light"] #splash .sp-ridge path:nth-child(2){fill:#c6cace}
[data-theme="light"] #splash .sp-ridge path:nth-child(3){fill:#b4b9bf}
@media(prefers-reduced-motion:reduce){#splash .sp-logo,#splash .sp-mtn,#splash .sp-ridge{animation:none}}

/* ----- mobile ----- */
@media (max-width:480px){
  .mtnimg{height:clamp(340px,52vh,480px);background-position:center 0;background-size:140% auto;opacity:.55;width:100%}
  [data-theme="light"] .mtnimg{opacity:.8}
  .logo-full{width:min(74%,270px);filter:none}
  header{padding-top:18px;margin-bottom:-12px}
  .sumcard{padding-top:24px}
  .tabbar{padding:0 12px env(safe-area-inset-bottom)}
}
