/* ============================================================
   Slice Co. — App styles
   Dark night base, lime accent, native-feeling on iOS.
   ============================================================ */

:root{
  /* surfaces — faintly green-tinted so it feels like dusk on a course */
  --night:#06070a;
  --night-2:#10110f;
  --night-3:#15171a;
  --night-4:#1c1f22;
  --night-5:#252a2e;

  /* ink */
  --ink:#ffffff;
  --ink-2:rgba(255,255,255,0.86);
  --ink-3:rgba(255,255,255,0.56);
  --ink-4:rgba(255,255,255,0.32);
  --ink-5:rgba(255,255,255,0.18);

  /* hairlines */
  --rule:rgba(255,255,255,0.06);
  --rule-2:rgba(255,255,255,0.10);

  /* brand colour */
  --lime:#c8f135;
  --lime-2:#d8ff4a;
  --lime-soft:rgba(200,241,53,0.12);
  --lime-deep:#a8d420;

  /* meaningful accents — brighter, more saturated */
  --flag:#ff6b4a;          /* over par, bogeys, hazards, misses */
  --flag-soft:rgba(255,107,74,0.16);
  --sand:#e8c878;          /* warm tan — sand traps, elevation, warmth */
  --sand-soft:rgba(232,200,120,0.14);
  --fairway:#4a8f5c;       /* fairway green */
  --fairway-soft:rgba(74,143,92,0.16);
  --rough:#2a3a2a;         /* rough green */
  --sky:#5eb3e4;           /* wind, water hazards */
  --sky-soft:rgba(94,179,228,0.14);
  --dusk:#f4994b;          /* golden hour — temp, sunny conditions */
  --dusk-soft:rgba(244,153,75,0.14);
  --violet:#a98ce8;        /* afternoon shade — used sparingly */
  --violet-soft:rgba(169,140,232,0.14);

  /* type */
  --font-display:'Bricolage Grotesque','Inter',system-ui,sans-serif;
  /* Hero numerals — heavy Bricolage with tabular-nums, used everywhere a number stands as data */
  --font-num:'Bricolage Grotesque','Inter',system-ui,sans-serif;
  --font-serif:'Newsreader', Georgia, serif;
  --font-sans:'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:'JetBrains Mono', ui-monospace, monospace;

  /* radii */
  --r-card:18px;
  --r-row:14px;
  --r-pill:9999px;

  /* curves — canonical motion tokens (single source of truth) */
  /* HARD RULE: overshoot scales DOWN as element scales UP — buttons/chevrons 0% (via --ease-ios or --ease-fast); cards <=6% (via --ease-spring); never bounce a full pane or a precise number. */
  /* Duration bands: in-place/toggle/press <200ms; control/list-insert 200-300ms; page/tab/sheet 300-500ms; reject anything >500ms. */
  --ease-out:cubic-bezier(.16,1,.3,1);   /* legacy decel — keep for back-compat */
  --ease-ios:cubic-bezier(.22,1,.36,1);   /* DEFAULT decelerate: entrances, tab slides, sheet/detail content, reveals */
  --ease-spring:cubic-bezier(.34,1.56,.64,1);  /* bouncy overshoot — confirm/badge/count-landing/chevron ONLY, small UI */
  --ease-fast:cubic-bezier(.32,.72,0,1);  /* snappy in/out — press/release */
  --dur-fast:180ms; --dur-base:300ms; --dur-slow:380ms; --dur-enter:440ms; --stagger:42ms;
}

/* ============================================================
   DAY THEME — morning on the course
   Soft parchment surfaces, deeper brand accents, Apple-ish layering
   ============================================================ */
[data-theme="day"]{
  /* surfaces — warm parchment */
  --night:#f5f3ec;
  --night-2:#ffffff;
  --night-3:#ffffff;
  --night-4:#f3f0e6;
  --night-5:#e8e4d6;

  /* ink — iOS system label colours */
  --ink:#0a0a0c;
  --ink-2:rgba(0,0,0,0.82);
  --ink-3:rgba(60,60,67,0.62);
  --ink-4:rgba(60,60,67,0.36);
  --ink-5:rgba(60,60,67,0.18);

  /* hairlines */
  --rule:rgba(0,0,0,0.07);
  --rule-2:rgba(0,0,0,0.14);

  /* brand — deeper for AA contrast on light surfaces */
  --lime:#9bb71d;
  --lime-2:#a8c41a;
  --lime-soft:rgba(155,183,29,0.16);
  --lime-deep:#7a9512;

  /* accents — deeper saturations that pop on parchment */
  --flag:#e84c2f;
  --flag-soft:rgba(232,76,47,0.12);
  --sand:#c9a85e;
  --sand-soft:rgba(201,168,94,0.18);
  --fairway:#3a8a4c;
  --fairway-soft:rgba(58,138,76,0.16);
  --sky:#3a8fc8;
  --sky-soft:rgba(58,143,200,0.14);
  --dusk:#dc7a2f;
  --dusk-soft:rgba(220,122,47,0.14);
  --violet:#7a5cc8;
  --violet-soft:rgba(122,92,200,0.12);
}

/* theme cross-fade transitions — subtle, ~iOS appearance switch */
html,body,.device,.card,.stage,.tabbar,.nav,.sheet,.tab-pane,
.bag-hero,.distance,.conditions,.result-card,.hole-map,.hole-strip,
.about-card,.resume-banner,.stat-grid,.stat-row .stat-card,
.club-row,.round-row,.rows .row,.mini-card,.feedback-thanks{
  transition:background-color .35s ease,background-image .35s ease,
    color .35s ease,border-color .35s ease,box-shadow .35s ease}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:#0a0a0a;color:var(--ink);font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
input,textarea,[contenteditable]{font:inherit;color:inherit;background:none;border:0;outline:0;padding:0}
[contenteditable]:focus{outline:0}

/* ---------- presentation stage ---------- */
.stage{min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:flex-start;padding:40px 24px 80px;gap:14px;
  background:
    radial-gradient(700px 420px at 18% -4%, rgba(200,241,53,0.06), transparent 60%),
    radial-gradient(800px 500px at 88% 18%, rgba(94,179,228,0.05), transparent 64%),
    radial-gradient(700px 600px at 50% 110%, rgba(244,153,75,0.04), transparent 70%),
    #08090c}
.stage-cap{display:flex;justify-content:space-between;align-items:baseline;width:390px;
  max-width:100%;color:var(--ink-4);font-family:var(--font-mono);font-size:10px;
  font-weight:600;letter-spacing:0.14em;text-transform:uppercase}

/* the device */
.device{width:390px;max-width:100%;height:844px;background:var(--night);position:relative;
  border-radius:48px;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 40px 100px rgba(0,0,0,0.6), 0 0 0 10px #1a1a1d, 0 0 0 11px #2a2a2e}

/* ---------- iOS status bar ---------- */
.status{height:54px;padding:18px 28px 0;display:flex;justify-content:space-between;
  align-items:center;font-family:-apple-system,'SF Pro Text',var(--font-sans);
  flex:0 0 auto;position:relative;z-index:6}
.status .time{font-weight:600;font-size:15px;letter-spacing:-0.01em}
.status .icons{display:flex;align-items:center;gap:5px;color:var(--ink)}
.status .icons svg{display:block}
.notch{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:120px;height:32px;
  background:#000;border-radius:18px;z-index:5}

/* ---------- nav bar ---------- */
.nav{display:flex;align-items:center;justify-content:space-between;padding:6px 22px 0;
  height:44px;flex:0 0 auto}
.brand{display:inline-flex;align-items:center;gap:8px}
.duck-mark{width:54px;height:26px;flex:0 0 54px;overflow:visible}
.duck-mark .arc{stroke-dasharray:120;stroke-dashoffset:120;animation:drawarc 1.6s var(--ease-out) .3s forwards}
.duck-mark .ball-tip{opacity:0;animation:show 0.25s linear 1.6s forwards}
@keyframes drawarc{to{stroke-dashoffset:0}}
@keyframes show{to{opacity:1}}
.brand-word{display:inline-flex;align-items:baseline;font-size:18px;line-height:1;
  letter-spacing:-0.025em;white-space:nowrap}
.brand-word .bw-slice{font-family:var(--font-display);font-weight:700;
  font-variation-settings:'wdth' 80,'wght' 700;letter-spacing:-0.04em;color:var(--ink)}
.brand-word .bw-slash{color:var(--lime);font-family:var(--font-display);font-weight:500;margin:0 1px}
.brand-word .bw-co{font-family:var(--font-serif);font-style:italic;font-size:0.92em;
  color:var(--ink-2);font-variation-settings:'opsz' 36;font-weight:500}
.brand-word .bw-co::after{content:".";color:var(--lime)}
.nav-right{display:inline-flex;align-items:center;gap:14px}
.beta-tag{font-family:var(--font-mono);font-weight:600;font-size:10px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-3)}
.icon-btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-2);border-radius:var(--r-pill);transition:background .15s,color .15s,transform .12s}
.icon-btn:hover{background:var(--rule)}
.icon-btn:active{transform:scale(0.92)}

/* sun / moon toggle — show the icon for the theme you'd switch TO */
.theme-toggle{position:relative}
.theme-toggle .sun-glyph,
.theme-toggle .moon-glyph{position:absolute;inset:0;margin:auto;
  transition:opacity .35s ease,transform .35s var(--ease-spring)}
.theme-toggle .sun-glyph{opacity:1;transform:rotate(0deg) scale(1)}
.theme-toggle .moon-glyph{opacity:0;transform:rotate(-90deg) scale(0.6)}
[data-theme="day"] .theme-toggle .sun-glyph{opacity:0;transform:rotate(90deg) scale(0.6)}
[data-theme="day"] .theme-toggle .moon-glyph{opacity:1;transform:rotate(0deg) scale(1)}

/* compact theme segmented in Preferences */
.theme-seg button{min-width:46px}

/* ---------- scroll body / tab pane routing ---------- */
.scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;position:relative}
.scroll::-webkit-scrollbar{display:none}

.tab-pane{padding:8px 22px 28px;display:none;animation:paneIn .42s var(--ease-out)}
.tab-pane.is-active{display:block}
@keyframes paneIn{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}

/* large title (shared) */
.large-title{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:12px 0 4px}
.large-title h1{font-family:var(--font-display);font-weight:700;font-size:34px;line-height:1.05;
  letter-spacing:-0.035em;font-variation-settings:'wdth' 92,'wght' 700,'opsz' 96;color:var(--ink)}
.large-title .meta{color:var(--ink-3);font-size:13px;font-weight:500;letter-spacing:-0.005em;
  text-align:right;line-height:1.35}
.large-title .meta strong{color:var(--ink-2);font-weight:600;display:block}

/* section label */
.label{color:var(--ink-3);font-size:12px;font-weight:600;letter-spacing:-0.005em;padding:0 4px 8px}
.label-row{display:flex;justify-content:space-between;align-items:baseline;padding:0 4px 8px}
.label-row .label{padding:0}
.label-row .link{color:var(--lime);font-size:12px;font-weight:600;letter-spacing:-0.005em}

/* card */
.card{background:var(--night-3);border:1px solid var(--rule);border-radius:var(--r-card);overflow:hidden}
.card-pad{padding:16px 18px}

/* spacing */
.s-8{height:8px}.s-10{height:10px}.s-12{height:12px}.s-14{height:14px}.s-16{height:16px}
.s-18{height:18px}.s-20{height:20px}.s-24{height:24px}.s-28{height:28px}.s-32{height:32px}

/* shared rows (Apple list) */
.rows .row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 18px;min-height:54px;transition:background .15s}
.rows .row + .row{border-top:1px solid var(--rule)}
.rows .row:hover{background:var(--night-4)}
.rows .row:active{background:var(--night-5)}
.rows .row .k{font-size:15px;font-weight:500;color:var(--ink);letter-spacing:-0.01em}
.rows .row .v{font-size:15px;font-weight:500;color:var(--ink-2);letter-spacing:-0.01em;
  display:inline-flex;align-items:center;gap:6px}
.rows .row .v .sub{color:var(--ink-4);font-weight:500;font-size:13px;margin-left:4px}
.rows .row .v.editable{font-family:var(--font-serif);font-style:italic;font-size:18px;
  font-weight:400;color:var(--ink);letter-spacing:-0.015em}
.rows .row .v.editable .sub{font-family:var(--font-sans);font-style:normal}
.chev{width:16px;height:16px;color:var(--ink-4);flex:0 0 16px}

/* segmented control */
.seg{display:inline-flex;background:var(--night-4);border-radius:10px;padding:2px}
.seg button{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:-0.005em;
  padding:6px 11px;border-radius:8px;color:var(--ink-3);min-height:28px;transition:all .2s var(--ease-out)}
.seg button[aria-pressed="true"]{background:var(--lime);color:var(--night)}

/* shot-shape segmented: tint the active button to the shape it represents */
[aria-label="Shot shape"].seg button:nth-child(1)[aria-pressed="true"]{background:var(--sky);color:var(--night)}
[aria-label="Shot shape"].seg button:nth-child(2)[aria-pressed="true"]{background:var(--sand);color:var(--night)}
[aria-label="Shot shape"].seg button:nth-child(3)[aria-pressed="true"]{background:var(--lime);color:var(--night)}

/* unit toggle (pill style) */
.unit-toggle{display:inline-flex;background:var(--night-4);border-radius:var(--r-pill);padding:2px}
.unit-toggle button{font-size:11px;font-weight:600;letter-spacing:0.01em;padding:5px 10px;
  border-radius:var(--r-pill);color:var(--ink-3);min-width:32px;transition:all .2s}
.unit-toggle button[aria-pressed="true"]{background:var(--ink);color:var(--night)}

/* primary CTA */
.cta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:52px;
  background:var(--lime);color:var(--night);font-size:16px;font-weight:700;letter-spacing:-0.015em;
  border-radius:16px;transition:background .15s,transform .12s var(--ease-spring),box-shadow .2s}
.cta:hover{background:var(--lime-2);box-shadow:0 8px 24px rgba(200,241,53,0.18)}
.cta:active{transform:scale(0.985)}
.cta .arr{font-weight:500;font-size:17px;transform:translateY(-1px)}

/* ============================================================
   CADDIE TAB
   ============================================================ */
.conditions{display:grid;grid-template-columns:repeat(4,1fr);
  background:linear-gradient(180deg, rgba(94,179,228,0.04), rgba(244,153,75,0.03))}
.conditions .cell{padding:14px 12px;display:flex;flex-direction:column;gap:6px;position:relative;min-height:72px}
.conditions .cell + .cell::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:1px;background:var(--rule)}
.conditions .lbl{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em;
  display:inline-flex;align-items:center;gap:5px}
.conditions .lbl::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:0.7}
.conditions .cell:nth-child(1) .lbl{color:var(--sky)}
.conditions .cell:nth-child(2) .lbl{color:var(--lime)}
.conditions .cell:nth-child(3) .lbl{color:var(--dusk)}
.conditions .cell:nth-child(4) .lbl{color:var(--violet)}
.conditions .num{font-family:var(--font-num);font-weight:700;font-size:24px;line-height:1;
  letter-spacing:-0.025em;color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:3px}
.conditions .unit{font-family:var(--font-sans);font-weight:500;font-size:11px;color:var(--ink-4);
  letter-spacing:-0.005em;margin-left:2px}
.conditions .dirwrap{display:inline-flex;align-items:center;gap:5px}
.conditions .arrow{width:11px;height:11px;color:var(--sky)}

.distance{padding:24px 20px 22px;
  background:
    radial-gradient(220px 140px at 0% 100%, rgba(74,143,92,0.18), transparent 70%),
    radial-gradient(180px 120px at 100% 0%, rgba(200,241,53,0.06), transparent 70%),
    var(--night-3)}
.distance .pin-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.distance .pin-head .ll{font-size:12px;color:var(--ink-3);font-weight:600;letter-spacing:-0.005em}
.pin-input{display:flex;align-items:baseline;gap:8px}
.pin-input .num{font-family:var(--font-num);font-weight:700;font-size:72px;line-height:0.92;
  letter-spacing:-0.045em;color:var(--lime);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;outline:0;
  text-shadow:0 0 32px rgba(200,241,53,0.18);
  transition:color .2s}
.pin-input .num:focus{color:var(--lime-2)}
.pin-input .unit{font-family:var(--font-sans);font-weight:500;font-size:16px;color:var(--ink-3);
  letter-spacing:-0.005em}

.result-card{background:
    radial-gradient(280px 200px at 100% 0%, rgba(200,241,53,0.10), transparent 70%),
    radial-gradient(220px 180px at 0% 100%, rgba(74,143,92,0.14), transparent 70%),
    var(--night-3);
  border:1px solid rgba(200,241,53,0.18);border-radius:var(--r-card);
  padding:22px 20px 8px;position:relative;overflow:hidden;animation:resultIn .6s var(--ease-spring);
  box-shadow:0 12px 40px rgba(200,241,53,0.05), inset 0 1px 0 rgba(255,255,255,0.04)}
@keyframes resultIn{
  0%{opacity:0;transform:translateY(12px) scale(0.985)}
  100%{opacity:1;transform:translateY(0) scale(1)}
}
.result-club{font-family:var(--font-num);font-weight:700;font-size:72px;line-height:0.92;
  letter-spacing:-0.045em;color:var(--ink);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:10px}
.result-club .it{font-family:var(--font-serif);font-style:italic;font-weight:400;font-variation-settings:'opsz' 72;letter-spacing:-0.02em}
.result-club .it{font-style:italic;color:var(--lime)}
.result-meta{margin-top:12px;display:flex;align-items:baseline;justify-content:space-between;gap:14px}
.result-meta .carry{color:var(--ink-2);font-size:15px;font-weight:500;letter-spacing:-0.005em}
.result-meta .carry b{color:var(--ink);font-weight:600}
.formula{margin-top:18px;padding-top:14px;border-top:1px solid var(--rule);padding-bottom:6px}
.formula .frow{display:grid;grid-template-columns:14px 1fr auto;align-items:baseline;gap:10px;
  padding:9px 0;font-size:14px;line-height:1.4;animation:fadeIn .5s var(--ease-out) both}
.formula .frow:nth-child(1){animation-delay:.05s}
.formula .frow:nth-child(2){animation-delay:.12s}
.formula .frow:nth-child(3){animation-delay:.19s}
.formula .frow:nth-child(4){animation-delay:.26s}
.formula .em{color:var(--ink-4);font-weight:400;font-size:0;line-height:0}
.formula .em::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;
  background:currentColor;transform:translateY(-2px)}
.formula .frow:nth-child(1) .em{color:var(--sky)}
.formula .frow:nth-child(2) .em{color:var(--sand)}
.formula .frow:nth-child(3) .em{color:var(--violet)}
.formula .frow:nth-child(4) .em{color:var(--lime)}
.formula .k{color:var(--ink-3);font-weight:500;letter-spacing:-0.005em}
.formula .v{color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums;
  letter-spacing:-0.005em;text-align:right}
.formula .v small{color:var(--ink-4);font-weight:500;font-size:12px;margin-left:6px;letter-spacing:-0.005em}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* feedback */
.feedback .q{font-size:13px;color:var(--ink-3);font-weight:500;letter-spacing:-0.005em;padding:0 4px 10px}
.feedback .row3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.fb{background:var(--night-3);border:1px solid var(--rule);border-radius:14px;padding:14px 8px;
  font-size:13px;font-weight:600;letter-spacing:-0.005em;color:var(--ink-2);min-height:54px;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s,border-color .15s,transform .12s}
.fb:hover{border-color:var(--rule-2);background:var(--night-4);color:var(--ink)}
.fb:active{transform:scale(0.96)}
.fb.is-on{background:var(--lime);border-color:var(--lime);color:var(--night)}

/* ============================================================
   BAG TAB
   ============================================================ */
.bag-hero{padding:14px 18px 18px}
.bag-hero .figures{display:flex;gap:18px;align-items:baseline;margin-bottom:14px}
.bag-hero .fig{display:flex;flex-direction:column;gap:2px}
.bag-hero .fig .v{font-family:var(--font-num);font-size:28px;font-weight:700;
  letter-spacing:-0.03em;line-height:1;color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.bag-hero .fig .k{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}

.ladder{position:relative;height:54px;margin-top:6px}
.ladder .axis{position:absolute;left:0;right:0;top:32px;height:1px;background:var(--rule)}
.ladder .tick{position:absolute;top:32px;width:1px;height:6px;background:var(--ink-5)}
.ladder .tick .lbl{position:absolute;left:50%;top:9px;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.06em;white-space:nowrap}
.ladder .dot{position:absolute;top:28px;width:9px;height:9px;border-radius:50%;
  background:var(--lime);transform:translateX(-50%);transition:transform .2s;
  box-shadow:0 0 0 3px rgba(200,241,53,0.14);
  opacity:0;animation:dotIn .5s var(--ease-spring) forwards}
.ladder .dot[data-cat="woods"]{background:var(--sky);box-shadow:0 0 0 3px rgba(94,179,228,0.16)}
.ladder .dot[data-cat="irons"]{background:var(--lime);box-shadow:0 0 0 3px rgba(200,241,53,0.16)}
.ladder .dot[data-cat="wedges"]{background:var(--sand);box-shadow:0 0 0 3px rgba(232,200,120,0.16)}
.ladder .dot:hover{transform:translateX(-50%) scale(1.4)}
.ladder .dot.is-active{background:var(--ink);box-shadow:0 0 0 3px rgba(255,255,255,0.16), 0 0 20px rgba(200,241,53,0.4)}
.ladder .dot .name{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  font-family:var(--font-mono);font-size:9px;color:var(--ink-3);letter-spacing:0.04em;
  white-space:nowrap;opacity:0;transition:opacity .2s}
.ladder .dot:hover .name,.ladder .dot.is-active .name{opacity:1}
@keyframes dotIn{from{opacity:0;transform:translateX(-50%) scale(0.4)}to{opacity:1;transform:translateX(-50%) scale(1)}}

.bag-group .group-head{display:flex;justify-content:space-between;align-items:baseline;padding:0 4px 10px;
  position:relative}
.bag-group .group-head .name{font-family:var(--font-display);font-weight:600;font-size:13px;
  letter-spacing:-0.005em;color:var(--ink);display:inline-flex;align-items:center;gap:8px}
.bag-group .group-head .name::before{content:"";width:8px;height:8px;border-radius:2px;
  background:var(--lime);box-shadow:0 0 12px currentColor;flex:0 0 8px}
.bag-group .group-head .meta{font-size:11px;color:var(--ink-4);font-weight:500}

/* per-group colouring */
.bag-group[data-cat="woods"] .group-head .name::before{background:var(--sky);color:var(--sky)}
.bag-group[data-cat="woods"] .conf-bar > i{background:var(--sky)}
.bag-group[data-cat="irons"] .group-head .name::before{background:var(--lime);color:var(--lime)}
.bag-group[data-cat="wedges"] .group-head .name::before{background:var(--sand);color:var(--sand)}
.bag-group[data-cat="wedges"] .conf-bar > i{background:var(--sand)}
.bag-group[data-cat="putter"] .group-head .name::before{background:var(--violet);color:var(--violet)}

/* Bag stagger on tab enter — match Home/feed cascade language (replay driven by SLICECO_MOTION.revealPane; fadeUp keyframe lives in app.html) */
.bag-group{opacity:0;animation:fadeUp var(--dur-enter) var(--ease-ios) forwards}
.bag-group:nth-child(2){animation-delay:80ms}
.bag-group:nth-child(3){animation-delay:160ms}
.bag-group:nth-child(4){animation-delay:240ms}
.club-row{opacity:0;animation:fadeUp var(--dur-base) var(--ease-ios) both}
.bag-group .club-row:nth-child(2){animation-delay:var(--stagger)}
.bag-group .club-row:nth-child(3){animation-delay:calc(var(--stagger)*2)}
.bag-group .club-row:nth-child(4){animation-delay:calc(var(--stagger)*3)}
.bag-group .club-row:nth-child(5){animation-delay:calc(var(--stagger)*4)}
.bag-group .club-row:nth-child(6){animation-delay:calc(var(--stagger)*5)}
.bag-group .club-row:nth-child(7){animation-delay:calc(var(--stagger)*6)}
@media(prefers-reduced-motion:reduce){.bag-group,.club-row{animation:none;opacity:1}}

.club-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:14px;
  padding:14px 18px;transition:background .15s}
.club-row + .club-row{border-top:1px solid var(--rule)}
.club-row:hover{background:var(--night-4)}
.club-row:active{background:var(--night-5)}
.club-row .nm{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--ink);
  letter-spacing:-0.01em}
.club-row .nm small{display:block;font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.08em;text-transform:uppercase;margin-top:3px;font-weight:500}
.club-row .stat{display:flex;flex-direction:column;gap:5px}
.club-row .stat .dist{font-family:var(--font-num);font-size:20px;font-weight:700;
  line-height:1;color:var(--ink);letter-spacing:-0.025em;font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.club-row .stat .dist .u{font-family:var(--font-sans);font-size:11px;color:var(--ink-4);
  margin-left:3px;letter-spacing:-0.005em;font-weight:500}
.club-row .conf{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.club-row .conf .pct{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);
  letter-spacing:0.06em;font-weight:600}
.conf-bar{width:48px;height:3px;background:var(--night-5);border-radius:2px;overflow:hidden}
.conf-bar > i{display:block;height:100%;background:var(--lime);border-radius:2px;transform-origin:left;
  animation:barIn .7s var(--ease-out) .15s both}
.conf-bar.warn > i{background:var(--sand)}
.conf-bar.low > i{background:var(--flag)}
@keyframes barIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}

.shape-glyph{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);
  font-size:9px;color:var(--ink-4);letter-spacing:0.06em;text-transform:uppercase;font-weight:600}
.shape-glyph svg{width:12px;height:8px}

.add-club{margin-top:14px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  height:48px;background:var(--night-3);border:1px dashed var(--rule-2);border-radius:14px;
  color:var(--ink-3);font-size:14px;font-weight:600;letter-spacing:-0.005em;
  transition:background .15s,border-color .15s,color .15s}
.add-club:hover{background:var(--night-4);border-color:var(--ink-4);color:var(--ink-2)}

/* ============================================================
   ROUNDS TAB
   ============================================================ */
.handicap-card{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:18px 20px;align-items:center}
.hc-num{font-family:var(--font-num);font-size:64px;font-weight:700;line-height:0.9;
  letter-spacing:-0.045em;color:var(--ink);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums}
.hc-num .it{font-style:normal}
.hc-side{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.hc-side .lbl{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}
.hc-side .trend{display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.04em;
  color:var(--lime);background:var(--lime-soft);padding:5px 9px;border-radius:var(--r-pill)}
.hc-side .trend.down{color:var(--flag);background:var(--flag-soft)}
.hc-side .trend svg{width:10px;height:10px}

.spark{margin-top:14px;padding-top:14px;border-top:1px solid var(--rule);
  padding-left:20px;padding-right:20px;padding-bottom:18px}
.spark .lbl-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.spark .lbl-row .l{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}
.spark .lbl-row .r{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);letter-spacing:0.06em;font-weight:600}
.spark svg{width:100%;height:48px;display:block;overflow:visible}
.spark .spark-line{stroke:var(--lime);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:200;stroke-dashoffset:200;animation:drawline 1.4s var(--ease-out) .2s forwards}
.spark .spark-fill{fill:url(#sparkGrad);opacity:0;animation:fadein .8s ease 1s forwards}
.spark .spark-dot{fill:var(--lime);opacity:0;animation:show .3s ease 1.5s forwards}
@keyframes drawline{to{stroke-dashoffset:0}}
@keyframes fadein{to{opacity:1}}

/* stat row */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.stat-row .stat-card{background:var(--night-3);border:1px solid var(--rule);border-radius:14px;
  padding:14px 12px;display:flex;flex-direction:column;gap:4px;transition:background .15s;
  position:relative;overflow:hidden}
.stat-row .stat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:currentColor;opacity:0.55}
.stat-row .stat-card:nth-child(1){color:var(--lime)}
.stat-row .stat-card:nth-child(2){color:var(--sky)}
.stat-row .stat-card:nth-child(3){color:var(--sand)}
.stat-row .stat-card:hover{background:var(--night-4)}
.stat-row .v{font-family:var(--font-num);font-size:24px;font-weight:700;letter-spacing:-0.03em;
  color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.stat-row .v small{font-family:var(--font-sans);font-size:12px;color:currentColor;margin-left:3px;
  letter-spacing:-0.005em;font-weight:600;text-transform:lowercase}
.stat-row .k{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}

/* round row */
.round-row{display:grid;grid-template-columns:auto 1fr auto;gap:14px;padding:14px 18px;
  align-items:center;transition:background .15s}
.round-row + .round-row{border-top:1px solid var(--rule)}
.round-row:hover{background:var(--night-4)}
.round-row .date{display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:42px;height:42px;background:var(--night-4);border-radius:10px;flex:0 0 42px}
.round-row .date .d{font-family:var(--font-num);font-size:18px;font-weight:700;line-height:1;
  letter-spacing:-0.025em;color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.round-row .date .m{font-family:var(--font-mono);font-size:8px;color:var(--ink-4);
  letter-spacing:0.1em;font-weight:600;margin-top:2px;text-transform:uppercase}
.round-row .info{display:flex;flex-direction:column;gap:3px;min-width:0}
.round-row .info .course{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-0.005em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.round-row .info .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.06em;font-weight:500;text-transform:uppercase}
.round-row .score{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.round-row .score .n{font-family:var(--font-num);font-size:22px;font-weight:700;line-height:1;
  letter-spacing:-0.03em;color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.round-row .score .vs{font-family:var(--font-mono);font-size:10px;letter-spacing:0.06em;
  font-weight:600;padding:2px 6px;border-radius:4px}
.round-row .score .vs.over{color:var(--flag);background:var(--flag-soft)}
.round-row .score .vs.under{color:var(--lime);background:var(--lime-soft)}
.round-row .score .vs.even{color:var(--ink-3);background:var(--rule)}

.start-round{position:sticky;bottom:14px;margin-top:18px}

/* ============================================================
   ACE TAB (chat)
   ============================================================ */
.ace-header{padding:12px 4px 18px;display:flex;align-items:center;gap:14px}
.ace-avatar{width:48px;height:48px;border-radius:50%;background:var(--night-3);border:1px solid var(--rule);
  display:flex;align-items:center;justify-content:center;position:relative}
.ace-avatar svg{width:34px;height:18px}
.ace-avatar .pulse-dot{position:absolute;bottom:1px;right:1px;width:11px;height:11px;
  background:var(--lime);border-radius:50%;border:2px solid var(--night);
  animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(200,241,53,0.55)}70%{box-shadow:0 0 0 8px rgba(200,241,53,0)}100%{box-shadow:0 0 0 0 rgba(200,241,53,0)}}
.ace-header .who{display:flex;flex-direction:column;gap:3px}
.ace-header .who .nm{font-family:var(--font-display);font-weight:700;font-size:22px;
  letter-spacing:-0.025em;color:var(--ink)}
.ace-header .who .sub{font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:-0.005em}

.chat{display:flex;flex-direction:column;gap:14px;padding-bottom:8px}
.msg{max-width:80%;font-size:15px;line-height:1.45;letter-spacing:-0.005em;
  animation:msgIn .4s var(--ease-out) both}
@keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.msg.ace{align-self:flex-start}
.msg.ace .body{font-family:var(--font-serif);font-size:17px;font-weight:400;letter-spacing:-0.01em;
  line-height:1.45;color:var(--ink);padding:10px 14px 12px;border-left:2px solid var(--lime);
  background:linear-gradient(90deg, rgba(200,241,53,0.04), transparent 80%);border-radius:0 12px 12px 0}
.msg.ace .body em{font-style:italic;color:var(--lime)}
.msg.ace .time{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.1em;
  font-weight:600;text-transform:uppercase;margin-top:5px;padding-left:14px}
.msg.you{align-self:flex-end;text-align:right}
.msg.you .body{background:var(--night-3);border:1px solid var(--rule);
  padding:10px 14px;border-radius:16px;color:var(--ink);font-size:14px;font-weight:500;
  letter-spacing:-0.005em;display:inline-block}
.msg.you .time{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.1em;
  font-weight:600;text-transform:uppercase;margin-top:5px;padding-right:14px}

/* typing indicator */
.typing{display:inline-flex;align-items:center;gap:4px;padding:14px 16px;background:var(--night-3);
  border-left:2px solid var(--lime);border-radius:0 12px 12px 0}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--ink-3);
  animation:bounce 1.2s ease-in-out infinite}
.typing span:nth-child(2){animation-delay:.15s}
.typing span:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,80%,100%{transform:scale(0.6);opacity:0.4}40%{transform:scale(1);opacity:1}}

/* chat input row */
.chat-input-area{position:sticky;bottom:0;padding:10px 0 8px;background:linear-gradient(180deg,transparent,var(--night) 22%)}
.quick-row{display:flex;gap:6px;overflow-x:auto;padding:0 4px 10px;scrollbar-width:none}
.quick-row::-webkit-scrollbar{display:none}
.quick{flex:0 0 auto;background:var(--night-3);border:1px solid var(--rule-2);border-radius:var(--r-pill);
  padding:7px 12px;font-size:12px;font-weight:500;color:var(--ink-2);letter-spacing:-0.005em;
  white-space:nowrap;transition:all .15s}
.quick:hover{border-color:var(--lime);color:var(--lime)}
.chat-input{display:flex;align-items:center;gap:8px;background:var(--night-3);border:1px solid var(--rule);
  border-radius:24px;padding:6px 6px 6px 16px}
.chat-input input{flex:1;font-size:15px;font-weight:400;color:var(--ink);height:36px;letter-spacing:-0.005em}
.chat-input input::placeholder{color:var(--ink-4)}
.chat-input .send{width:36px;height:36px;border-radius:50%;background:var(--lime);color:var(--night);
  display:flex;align-items:center;justify-content:center;transition:transform .12s,opacity .15s;flex:0 0 36px}
.chat-input .send:hover{transform:scale(1.05)}
.chat-input .send:active{transform:scale(0.92)}
.chat-input .send.disabled{background:var(--night-5);color:var(--ink-4);pointer-events:none}

/* ============================================================
   YOU TAB
   ============================================================ */
.profile-hero{padding:18px 18px 22px;display:flex;align-items:center;gap:16px}
.avatar-big{width:68px;height:68px;border-radius:50%;background:var(--lime);color:var(--night);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;
  font-size:26px;letter-spacing:-0.02em;flex:0 0 68px}
.profile-hero .who{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.profile-hero .who .nm{font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.025em;color:var(--ink)}
.profile-hero .who .hc{display:inline-flex;align-items:baseline;gap:6px;color:var(--ink-3);font-size:13px;font-weight:500;letter-spacing:-0.005em}
.profile-hero .who .hc b{font-family:var(--font-num);font-size:18px;color:var(--ink);font-weight:700;letter-spacing:-0.025em;font-variation-settings:'wdth' 88,'wght' 700;font-variant-numeric:tabular-nums}

.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);
  border-radius:var(--r-card);border:1px solid var(--rule);overflow:hidden}
.stat-grid .gcell{background:var(--night-3);padding:14px 16px;display:flex;flex-direction:column;gap:4px;
  position:relative;overflow:hidden}
.stat-grid .gcell::after{content:"";position:absolute;left:0;top:14px;bottom:14px;width:2px;
  border-radius:2px;background:currentColor;opacity:0.7}
.stat-grid .gcell{padding-left:20px}
.stat-grid .gcell:nth-child(1){color:var(--lime)}
.stat-grid .gcell:nth-child(2){color:var(--sky)}
.stat-grid .gcell:nth-child(3){color:var(--fairway)}
.stat-grid .gcell:nth-child(4){color:var(--sand)}
.stat-grid .gcell:nth-child(5){color:var(--violet)}
.stat-grid .gcell:nth-child(6){color:var(--dusk)}
.stat-grid .gcell .v{font-family:var(--font-num);font-size:24px;font-weight:700;letter-spacing:-0.03em;line-height:1;
  color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.stat-grid .gcell .k{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}
.stat-grid .gcell .v small{font-size:13px;color:currentColor;margin-left:3px;font-family:var(--font-sans);font-weight:600}

/* settings list inherits .rows pattern */

.about-card{padding:18px 20px;text-align:center;background:var(--night-2);border:1px solid var(--rule);border-radius:var(--r-card)}
.about-card .duck-foot{display:flex;justify-content:center;margin-bottom:10px}
.about-card .duck-foot svg{width:80px;height:38px}
.about-card .credit{font-family:var(--font-serif);font-style:italic;font-size:14px;color:var(--ink-2);
  letter-spacing:-0.005em;line-height:1.5}
.about-card .credit em{color:var(--lime);font-style:italic}
.about-card .v{margin-top:8px;font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.12em;text-transform:uppercase;font-weight:600}

/* ============================================================
   tab bar
   ============================================================ */
.tabbar{flex:0 0 auto;padding:10px 14px 24px;border-top:1px solid var(--rule);
  background:rgba(14,14,16,0.82);backdrop-filter:saturate(140%) blur(20px);
  -webkit-backdrop-filter:saturate(140%) blur(20px);display:flex;justify-content:space-around;
  align-items:flex-end;position:relative}
.tab{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ink-4);
  min-width:50px;padding:6px 4px 0;transition:color .2s,transform .15s var(--ease-spring)}
.tab svg{width:22px;height:22px;display:block;transition:transform .25s var(--ease-spring)}
.tab .name{font-size:10px;font-weight:600;letter-spacing:-0.005em}
.tab:active{transform:scale(0.93)}
.tab.is-active{color:var(--lime)}
.tab.is-active svg{transform:translateY(-2px) scale(1.08)}

/* home indicator */
.home-ind{position:absolute;left:50%;bottom:8px;transform:translateX(-50%);width:134px;height:5px;
  border-radius:3px;background:var(--ink);opacity:0.95;z-index:5}

/* ============================================================
   APP-WIDE PRESS FEEDBACK — one global rule so every tap target depresses identically
   (layers on top of app.html .tap lime-ring which stays the opt-in flourish)
   ============================================================ */
button,[role=button],.club-row,.round-row,.post-summary,.seg-btn,.feed-seg button,.chip,.fresh-path,.notif-item,.fw-item,.cta,a.tap,.tab,.live-card,.soc-id-share,.soc-subnav button{transition:transform var(--dur-fast) var(--ease-fast),background .15s,opacity .15s}
button:active,[role=button]:active,.chip:active,.seg-btn:active,.feed-seg button:active,.fresh-path:active,.fw-item:active,.cta:active,.live-card:active{transform:scale(.97)}
/* full-width rows depress LESS so they don't look like they slide off-canvas */
.club-row:active,.round-row:active,.post-summary:active,.notif-item:active{transform:scale(.985)}
@media(prefers-reduced-motion:reduce){button:active,[role=button]:active,.club-row:active,.round-row:active,.post-summary:active,.cta:active,.live-card:active{transform:none}}

/* ============================================================
   GET MY CLUB — submit + reveal flow
   ============================================================ */
.cta.is-loading{pointer-events:none;background:var(--night-3);color:var(--ink-3);
  border:1px solid var(--rule)}
.cta.is-loading::after{content:"";width:14px;height:14px;border-radius:50%;
  border:2px solid var(--ink-4);border-top-color:var(--lime);margin-left:6px;
  animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.caddie-result{margin-top:32px}
.caddie-result[hidden]{display:none}
.thinking{display:none;background:var(--night-3);border:1px solid var(--rule);
  border-radius:var(--r-card);padding:22px 20px;align-items:center;gap:14px;
  margin-top:32px;animation:resultIn .4s var(--ease-out)}
.thinking.is-on{display:flex}
.thinking .duck-spin{width:32px;height:32px;display:inline-flex;align-items:center;
  justify-content:center;flex:0 0 32px}
.thinking .duck-spin svg{width:32px;height:32px;animation:pulseLime 1.4s ease-in-out infinite}
@keyframes pulseLime{0%,100%{opacity:0.6;transform:scale(0.95)}50%{opacity:1;transform:scale(1)}}
.thinking .copy{display:flex;flex-direction:column;gap:3px}
.thinking .copy .h{font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--ink);
  letter-spacing:-0.01em;line-height:1.2}
.thinking .copy .s{font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:-0.005em}

.result-actions{display:flex;gap:14px;align-items:center;justify-content:space-between;
  margin-top:18px;padding:0 4px}
.result-actions .link{color:var(--ink-3);font-size:13px;font-weight:600;letter-spacing:-0.005em;
  transition:color .15s}
.result-actions .link:hover{color:var(--ink)}
.result-actions .link.lime{color:var(--lime)}

/* feedback acknowledgement card (after tapping a feedback chip) */
.feedback-thanks{display:none;margin-top:14px;padding:14px 18px;background:var(--night-3);
  border:1px solid var(--rule);border-left:2px solid var(--lime);border-radius:14px;
  animation:msgIn .35s var(--ease-out)}
.feedback-thanks.is-on{display:block}
.feedback-thanks .h{font-family:var(--font-serif);font-style:italic;font-size:15px;color:var(--ink);
  letter-spacing:-0.005em;line-height:1.4}
.feedback-thanks .h em{font-style:italic;color:var(--lime)}
.feedback-thanks .s{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em;margin-top:4px}

/* ============================================================
   SHEET SYSTEM (iOS-style bottom sheet)
   ============================================================ */
.sheet-host{position:absolute;inset:0;z-index:120;pointer-events:none}
.sheet-host.is-open{pointer-events:auto}
.backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.5);opacity:0;
  transition:opacity .28s var(--ease-out);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
.sheet-host.is-open .backdrop{opacity:1}
.sheet{position:absolute;left:0;right:0;bottom:0;background:var(--night-2);
  border-top-left-radius:22px;border-top-right-radius:22px;
  border:1px solid var(--rule);border-bottom:0;
  transform:translateY(100%);transition:transform .36s var(--ease-ios);
  max-height:88%;display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 -8px 40px rgba(0,0,0,0.5)}
.sheet.is-open{transform:translateY(0)}
.sheet-handle{height:18px;display:flex;justify-content:center;align-items:center;flex:0 0 auto}
.sheet-handle::before{content:"";width:36px;height:4px;border-radius:2px;background:var(--ink-5)}
.sheet-bar{display:flex;align-items:center;justify-content:space-between;padding:0 22px 14px;
  border-bottom:1px solid var(--rule);flex:0 0 auto;gap:14px}
.sheet-bar .title{font-family:var(--font-display);font-weight:700;font-size:18px;
  letter-spacing:-0.02em;color:var(--ink)}
.sheet-bar .sub{font-size:11px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em;margin-top:2px}
.sheet-bar .close{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-3);border-radius:var(--r-pill);transition:background .15s,color .15s}
.sheet-bar .close:hover{background:var(--rule);color:var(--ink)}
.sheet-bar .close svg{width:14px;height:14px}
.sheet-body{flex:1 1 auto;overflow-y:auto;padding:18px 22px 8px;scrollbar-width:none}
.sheet-body::-webkit-scrollbar{display:none}
.sheet-actions{padding:14px 22px max(24px,env(safe-area-inset-bottom));border-top:1px solid var(--rule);flex:0 0 auto;
  display:flex;flex-direction:column;gap:10px}
.sheet-actions .tlink{font-size:13px;color:var(--ink-3);font-weight:600;letter-spacing:-0.005em;
  padding:8px 0;text-align:center;transition:color .15s}
.sheet-actions .tlink:hover{color:var(--ink)}
.sheet-actions .tlink.danger{color:var(--flag)}

/* ============================================================
   COURSE PICKER (Start Round sheet)
   ============================================================ */
.course-list{display:flex;flex-direction:column}
.course-row{display:grid;grid-template-columns:1fr auto;gap:14px;padding:14px 16px;
  border:1px solid var(--rule);border-radius:14px;margin-bottom:8px;align-items:center;
  background:var(--night-3);transition:background .15s,transform .12s var(--ease-spring),border-color .15s}
.course-row:hover{background:var(--night-4);border-color:var(--rule-2)}
.course-row:active{transform:scale(0.985)}
.course-row.is-favourite{border-color:rgba(200,241,53,0.18)}
.course-row .nfo{display:flex;flex-direction:column;gap:4px;min-width:0}
.course-row .name{font-size:15px;font-weight:600;color:var(--ink);letter-spacing:-0.005em;
  display:inline-flex;align-items:baseline;gap:8px}
.course-row .name .star{color:var(--lime);font-size:11px}
.course-row .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);letter-spacing:0.06em;
  font-weight:500;text-transform:uppercase}
.course-row .par{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.course-row .par .v{font-family:var(--font-num);font-size:22px;font-weight:700;line-height:1;
  letter-spacing:-0.03em;color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.course-row .par .k{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.08em;
  font-weight:600;text-transform:uppercase}

.new-course{margin-top:10px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  height:48px;background:transparent;border:1px dashed var(--rule-2);border-radius:14px;
  color:var(--ink-3);font-size:14px;font-weight:600;letter-spacing:-0.005em;
  transition:background .15s,border-color .15s,color .15s}
.new-course:hover{background:var(--night-4);border-color:var(--ink-4);color:var(--ink-2)}

/* ============================================================
   LIVE ROUND
   ============================================================ */
.pane-round{padding:8px 22px 32px}

.lr-top{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 0 14px;border-bottom:1px solid var(--rule);margin-bottom:18px}
.lr-top .lr-course{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.lr-top .lr-course .name{font-family:var(--font-display);font-weight:700;font-size:18px;
  letter-spacing:-0.02em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lr-top .lr-course .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:600;text-transform:uppercase}
.lr-top .lr-course .meta .dot-live{display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--lime);margin-right:5px;animation:pulse 2s ease-out infinite;vertical-align:middle}
.lr-end{font-family:var(--font-mono);font-size:11px;color:var(--flag);letter-spacing:0.08em;
  font-weight:700;text-transform:uppercase;padding:6px 10px;border:1px solid rgba(229,86,63,0.32);
  border-radius:var(--r-pill);transition:all .15s}
.lr-end:hover{background:var(--flag-soft)}

.lr-hero{padding:20px 0 22px;border-bottom:1px solid var(--rule);margin-bottom:18px}
.lr-hero .nav-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.hole-arrow{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-2);border-radius:var(--r-pill);border:1px solid var(--rule);
  transition:all .15s,transform .12s var(--ease-spring)}
.hole-arrow:hover{background:var(--night-3);color:var(--ink);border-color:var(--rule-2)}
.hole-arrow:active{transform:scale(0.92)}
.hole-arrow.disabled{color:var(--ink-5);pointer-events:none;border-color:var(--rule)}
.hole-arrow svg{width:16px;height:16px}
.lr-hero .hole-num{display:flex;flex-direction:column;align-items:center;gap:2px}
.lr-hero .hole-num .word{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.16em;text-transform:uppercase;font-weight:600}
.lr-hero .hole-num .n{font-family:var(--font-num);font-style:normal;font-weight:700;font-size:80px;
  line-height:0.88;letter-spacing:-0.05em;color:var(--ink);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;
  transition:transform .25s var(--ease-spring)}
.lr-hero .hole-info{display:flex;justify-content:center;gap:24px;margin-top:8px}
.lr-hero .hole-info span{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);
  letter-spacing:0.08em;font-weight:600;text-transform:uppercase}
.lr-hero .hole-info span b{color:var(--ink);font-family:var(--font-num);font-style:normal;
  font-weight:700;font-size:14px;letter-spacing:-0.02em;margin-right:4px;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}
.lr-hero .open-caddie{display:flex;justify-content:center;margin-top:12px}
.lr-hero .open-caddie a{font-size:12px;color:var(--lime);font-weight:600;letter-spacing:-0.005em;
  border-bottom:1px solid rgba(200,241,53,0.28);padding-bottom:1px;transition:opacity .15s}
.lr-hero .open-caddie a:hover{opacity:0.7}

/* ============================================================
   HOLE MAP — signature hand-drawn course routing
   ============================================================ */
.hole-map{position:relative;margin:0 0 22px;background:
    radial-gradient(280px 200px at 100% 0%, rgba(94,179,228,0.05), transparent 70%),
    radial-gradient(220px 180px at 0% 100%, rgba(74,143,92,0.08), transparent 70%),
    var(--night-3);
  border:1px solid var(--rule);border-radius:var(--r-card);
  padding:14px 14px 12px;overflow:hidden}
.hole-map::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:7px 7px;pointer-events:none;opacity:0.7}
.hole-map .map-head{display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:8px;font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;
  font-weight:600;text-transform:uppercase;position:relative;z-index:2}
.hole-map .map-head .l{color:var(--lime);display:inline-flex;align-items:center;gap:6px}
.hole-map .map-head .l::before{content:"";width:14px;height:1px;background:var(--lime)}
.hole-map .map-head .r{color:var(--ink-4)}
.hole-map svg.course-svg{width:100%;height:auto;display:block;position:relative;z-index:1}
.hole-map svg.course-svg path,
.hole-map svg.course-svg line,
.hole-map svg.course-svg circle,
.hole-map svg.course-svg ellipse{vector-effect:non-scaling-stroke}
.hole-map .map-foot{display:flex;justify-content:space-between;align-items:baseline;
  margin-top:8px;padding-top:10px;border-top:1px solid var(--rule);position:relative;z-index:2;
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.1em;font-weight:600;
  color:var(--ink-4);text-transform:uppercase}
.hole-map .map-foot b{color:var(--lime);font-family:var(--font-num);font-style:normal;
  font-weight:700;font-size:13px;letter-spacing:-0.015em;text-transform:none;margin-left:5px;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}
.hole-map .map-foot .item:nth-child(2) b{color:var(--sand)}
.hole-map .map-foot .item:nth-child(3) b{color:var(--sky)}

/* animations */
.hole-map .shot-arc{stroke-dasharray:200;stroke-dashoffset:200;
  animation:hmDrawArc 1.6s var(--ease-out) .35s forwards}
@keyframes hmDrawArc{to{stroke-dashoffset:0}}
.hole-map .ball-pulse{transform-origin:center;transform-box:fill-box;
  animation:hmBallPulse 2s ease-out infinite}
@keyframes hmBallPulse{
  0%{transform:scale(0.6);opacity:0.85}
  100%{transform:scale(2.6);opacity:0}
}
.hole-map .target-zone{animation:hmZone 3s ease-in-out infinite}
@keyframes hmZone{0%,100%{opacity:0.45}50%{opacity:0.8}}
.hole-map .wind-spin{transform-origin:center;animation:hmWindRotate 24s linear infinite}
@keyframes hmWindRotate{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
.hole-map .scribble-stroke{stroke-dasharray:140;stroke-dashoffset:140;
  animation:hmDrawArc 1.4s ease-out 1.6s forwards}
.hole-map .flag-wave{transform-origin:left center;transform-box:fill-box;
  animation:hmFlagWave 3.2s ease-in-out infinite}
@keyframes hmFlagWave{0%,100%{transform:scaleX(1)}50%{transform:scaleX(0.88)}}
.hole-map .count{font-variant-numeric:tabular-nums}
@media(prefers-reduced-motion:reduce){
  .hole-map .shot-arc,.hole-map .scribble-stroke{stroke-dashoffset:0;animation:none}
  .hole-map .wind-spin,.hole-map .ball-pulse,.hole-map .target-zone,.hole-map .flag-wave{animation:none}
}

/* compact strip variant for the Caddie tab */
.hole-strip{position:relative;background:var(--night-3);border:1px solid var(--rule);
  border-radius:14px;padding:10px 14px;overflow:hidden;margin-bottom:18px}
.hole-strip::before{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:6px 6px;pointer-events:none;opacity:0.6}
.hole-strip .strip-head{display:flex;justify-content:space-between;align-items:baseline;
  position:relative;z-index:2;font-family:var(--font-mono);font-size:9px;letter-spacing:0.1em;
  font-weight:600;text-transform:uppercase;margin-bottom:4px}
.hole-strip .strip-head .l{color:var(--lime)}
.hole-strip .strip-head .r{color:var(--ink-4)}
.hole-strip svg{width:100%;height:auto;display:block;position:relative;z-index:1}
.hole-strip svg path,.hole-strip svg line,.hole-strip svg circle{vector-effect:non-scaling-stroke}

/* score block */
.score-block{margin:0 0 18px;padding:14px 0 22px;border-bottom:1px solid var(--rule)}
.score-block > .label{padding-left:4px}
.score-stepper{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:8px 0}
.stepper-btn{width:54px;height:54px;border-radius:50%;background:var(--night-3);border:1px solid var(--rule);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink);
  font-family:var(--font-display);font-weight:400;font-size:24px;letter-spacing:-0.01em;
  transition:all .15s,transform .12s var(--ease-spring)}
.stepper-btn:hover{background:var(--night-4);border-color:var(--rule-2)}
.stepper-btn:active{transform:scale(0.9)}
.stepper-btn.disabled{color:var(--ink-5);pointer-events:none}
.score-stepper .num-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.score-stepper .num{font-family:var(--font-num);font-weight:700;font-size:96px;line-height:0.88;
  letter-spacing:-0.05em;color:var(--ink);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;
  transition:transform .2s var(--ease-spring);will-change:transform}
.score-stepper .num.bump{animation:bump .35s var(--ease-spring)}
@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}
.score-stepper .num.under{color:var(--lime)}
.score-stepper .num.over{color:var(--ink)}
.score-relative{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;font-weight:700;
  text-transform:uppercase;padding:4px 10px;border-radius:var(--r-pill)}
.score-relative.under{color:var(--lime);background:var(--lime-soft)}
.score-relative.over{color:var(--flag);background:var(--flag-soft)}
.score-relative.even{color:var(--ink-3);background:var(--rule)}
.score-relative.eagle{color:var(--lime);background:var(--lime-soft)}

/* FIR / GIR / Putts list rows */
.lr-list .lr-row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--rule)}
.lr-list .lr-row:last-child{border-bottom:0}
.lr-list .lr-row .k{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-0.005em}
.lr-list .lr-row .k small{display:block;font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.06em;font-weight:500;text-transform:uppercase;margin-top:3px}

.yn-toggle{display:inline-flex;gap:6px}
.yn-toggle button{width:42px;height:36px;border-radius:10px;background:var(--night-3);
  border:1px solid var(--rule);color:var(--ink-3);font-size:13px;font-weight:600;
  letter-spacing:-0.005em;transition:all .15s,transform .12s var(--ease-spring);
  display:inline-flex;align-items:center;justify-content:center}
.yn-toggle button:hover{background:var(--night-4);border-color:var(--rule-2);color:var(--ink-2)}
.yn-toggle button:active{transform:scale(0.92)}
.yn-toggle button.is-on{background:var(--lime);color:var(--night);border-color:var(--lime)}
.yn-toggle button.is-on.no{background:var(--flag);color:var(--night);border-color:var(--flag)}

.putts-stepper{display:inline-flex;align-items:center;gap:10px}
.putts-stepper .step-mini{width:32px;height:32px;border-radius:50%;background:var(--night-3);
  border:1px solid var(--rule);color:var(--ink-2);font-size:16px;font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;transition:all .15s,transform .12s}
.putts-stepper .step-mini:hover{background:var(--night-4);color:var(--ink)}
.putts-stepper .step-mini:active{transform:scale(0.9)}
.putts-stepper .v{font-family:var(--font-num);font-size:22px;font-weight:700;letter-spacing:-0.03em;
  color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;min-width:1.4em;text-align:center;font-variant-numeric:tabular-nums;
  transition:transform .2s var(--ease-spring)}
.putts-stepper .v.bump{animation:bump .3s var(--ease-spring)}

.lr-notes{padding:14px 0 0}
.lr-notes textarea{width:100%;background:transparent;border:0;font-family:var(--font-serif);
  font-style:italic;font-size:15px;line-height:1.5;color:var(--ink);letter-spacing:-0.005em;
  resize:none;min-height:44px;padding:8px 0;border-bottom:1px solid var(--rule)}
.lr-notes textarea::placeholder{color:var(--ink-4)}
.lr-notes textarea:focus{border-bottom-color:var(--ink-3)}

/* mini scorecard for live round */
.mini-card{margin-top:24px;background:var(--night-3);border:1px solid var(--rule);
  border-radius:var(--r-card);padding:14px 16px;overflow:hidden}
.mini-card .head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
.mini-card .head .l{font-size:11px;color:var(--ink-4);font-weight:600;letter-spacing:-0.005em}
.mini-card .head .r{font-family:var(--font-num);font-style:normal;font-size:15px;color:var(--ink);
  letter-spacing:-0.02em;font-weight:700;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}
.mini-card .head .r .pos{color:var(--lime)}
.mini-card .head .r .neg{color:var(--flag)}
.mini-card .holes{display:grid;grid-template-columns:repeat(9,1fr);gap:4px}
.mini-card .hole{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--night);border:1px solid var(--rule);border-radius:6px;gap:1px;
  transition:all .15s}
.mini-card .hole.is-current{background:var(--lime);border-color:var(--lime);
  box-shadow:0 0 16px rgba(200,241,53,0.3)}
.mini-card .hole.is-current .n,.mini-card .hole.is-current .s{color:var(--night)}
.mini-card .hole .n{font-family:var(--font-mono);font-size:8px;color:var(--ink-4);font-weight:600;letter-spacing:0.04em}
.mini-card .hole .s{font-family:var(--font-num);font-size:13px;color:var(--ink-2);font-weight:700;line-height:1;letter-spacing:-0.02em;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}
.mini-card .hole.has-score .s{color:var(--ink)}
.mini-card .hole.has-score.under{background:var(--lime-soft);border-color:rgba(200,241,53,0.22)}
.mini-card .hole.has-score.under .s{color:var(--lime)}
.mini-card .hole.has-score.over{background:var(--flag-soft);border-color:rgba(255,107,74,0.22)}
.mini-card .hole.has-score.over .s{color:var(--flag)}
.mini-card .nine-totals{display:flex;justify-content:space-between;align-items:baseline;
  margin-top:10px;padding-top:10px;border-top:1px solid var(--rule);font-family:var(--font-mono);
  font-size:10px;color:var(--ink-3);letter-spacing:0.08em;font-weight:600;text-transform:uppercase}
.mini-card .nine-totals b{color:var(--ink);font-family:var(--font-num);font-style:normal;font-weight:700;
  font-size:15px;letter-spacing:-0.02em;margin-left:6px;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}

.lr-actions{margin-top:24px;display:flex;flex-direction:column;gap:10px}
.lr-actions .secondary{font-size:13px;color:var(--ink-3);font-weight:600;letter-spacing:-0.005em;
  text-align:center;padding:10px 0;transition:color .15s}
.lr-actions .secondary:hover{color:var(--ink)}

/* a "Round in progress" status pill that sits in the nav-right when a round is live */
.round-pill{display:none;align-items:center;gap:5px;padding:5px 9px;border-radius:var(--r-pill);
  background:var(--lime-soft);color:var(--lime);font-family:var(--font-mono);font-size:9px;
  font-weight:700;letter-spacing:0.12em;text-transform:uppercase;border:1px solid rgba(200,241,53,0.18);
  transition:background .15s,transform .12s var(--ease-spring);cursor:pointer}
.round-pill.is-on{display:inline-flex}
.round-pill:hover{background:rgba(200,241,53,0.18)}
.round-pill:active{transform:scale(0.95)}
.round-pill .pulse-tiny{width:5px;height:5px;border-radius:50%;background:var(--lime);
  animation:pulse 2s ease-out infinite}

/* Resume-round CTA on Rounds tab when a round is active */
.resume-banner{display:none;background:linear-gradient(180deg,rgba(200,241,53,0.06),rgba(200,241,53,0.02));
  border:1px solid rgba(200,241,53,0.22);border-radius:var(--r-card);padding:14px 16px;margin-bottom:18px;
  animation:resultIn .35s var(--ease-out)}
.resume-banner.is-on{display:block}
.resume-banner .top{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:10px}
.resume-banner .top .nm{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--ink);
  letter-spacing:-0.005em}
.resume-banner .top .nm .meta{display:block;font-family:var(--font-mono);font-size:9px;color:var(--lime);
  letter-spacing:0.12em;font-weight:600;text-transform:uppercase;margin-top:3px}
.resume-banner .top .score{font-family:var(--font-num);font-size:24px;letter-spacing:-0.03em;color:var(--ink);
  font-weight:700;font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.resume-banner .resume-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;height:42px;
  background:var(--lime);color:var(--night);border-radius:12px;font-size:14px;font-weight:700;letter-spacing:-0.005em;
  transition:background .15s,transform .12s var(--ease-spring)}
.resume-banner .resume-btn:hover{background:var(--lime-2)}
.resume-banner .resume-btn:active{transform:scale(0.985)}

/* ============================================================
   END ROUND sheet — summary
   ============================================================ */
.end-summary{display:flex;flex-direction:column;gap:18px}
.end-summary .total{display:flex;align-items:baseline;justify-content:space-between;gap:18px;
  padding-bottom:18px;border-bottom:1px solid var(--rule)}
.end-summary .total .n{font-family:var(--font-num);font-weight:700;font-size:80px;line-height:0.9;
  letter-spacing:-0.05em;color:var(--ink);font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums}
.end-summary .total .meta{text-align:right;display:flex;flex-direction:column;gap:5px}
.end-summary .total .meta .vs{font-family:var(--font-mono);font-size:11px;letter-spacing:0.12em;font-weight:700;
  text-transform:uppercase;padding:3px 8px;border-radius:var(--r-pill);align-self:flex-end}
.end-summary .total .meta .vs.over{color:var(--flag);background:var(--flag-soft)}
.end-summary .total .meta .vs.under{color:var(--lime);background:var(--lime-soft)}
.end-summary .total .meta .holes{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.1em;font-weight:600;text-transform:uppercase}

.end-summary .stat-line{display:grid;grid-template-columns:14px 1fr auto;gap:10px;align-items:baseline;
  padding:8px 0;font-size:14px}
.end-summary .stat-line .em{color:var(--ink-4)}
.end-summary .stat-line .k{color:var(--ink-3);font-weight:500;letter-spacing:-0.005em}
.end-summary .stat-line .v{color:var(--ink);font-weight:500;font-variant-numeric:tabular-nums;text-align:right}

/* ============================================================
   EDIT CLUB sheet
   ============================================================ */
.edit-form{display:flex;flex-direction:column;gap:18px}
.edit-form .f-row{display:flex;flex-direction:column;gap:8px}
.edit-form .f-row > label{font-size:11px;color:var(--ink-4);font-weight:600;letter-spacing:-0.005em;
  text-transform:uppercase;letter-spacing:0.08em}
.edit-form input[type=text],
.edit-form input[type=number]{width:100%;background:var(--night-3);border:1px solid var(--rule);
  border-radius:10px;padding:12px 14px;font-size:15px;color:var(--ink);transition:border-color .15s,background .15s;
  font-family:var(--font-sans);font-weight:500;letter-spacing:-0.005em}
.edit-form input:focus{border-color:var(--ink-4);background:var(--night-4)}
.edit-form input::placeholder{color:var(--ink-4)}
.edit-form .twin{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.edit-form .seg-wide{display:flex;background:var(--night-3);border:1px solid var(--rule);border-radius:10px;padding:3px;gap:2px}
.edit-form .seg-wide button{flex:1;padding:8px;font-size:13px;font-weight:600;color:var(--ink-3);
  border-radius:8px;transition:all .2s var(--ease-out);letter-spacing:-0.005em}
.edit-form .seg-wide button[aria-pressed="true"]{background:var(--lime);color:var(--night)}

/* ============================================================
   ROUND DETAIL sheet
   ============================================================ */
.detail-hero{display:flex;align-items:baseline;justify-content:space-between;gap:14px;
  padding-bottom:18px;border-bottom:1px solid var(--rule);margin-bottom:18px}
.detail-hero .left{display:flex;flex-direction:column;gap:4px}
.detail-hero .left .when{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);letter-spacing:0.12em;
  font-weight:600;text-transform:uppercase}
.detail-hero .left .course{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--ink);
  letter-spacing:-0.015em}
.detail-hero .left .conditions{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase}
.detail-hero .right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.detail-hero .right .n{font-family:var(--font-num);font-size:48px;line-height:0.92;letter-spacing:-0.04em;
  color:var(--ink);font-variation-settings:'wdth' 85,'wght' 700,'opsz' 72;font-weight:700;font-variant-numeric:tabular-nums}
.detail-hero .right .vs{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;font-weight:700;
  text-transform:uppercase;padding:3px 7px;border-radius:var(--r-pill)}
.detail-hero .right .vs.over{color:var(--flag);background:var(--flag-soft)}
.detail-hero .right .vs.under{color:var(--lime);background:var(--lime-soft)}

.detail-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);
  border:1px solid var(--rule);border-radius:14px;overflow:hidden;margin-bottom:18px}
.detail-stats .gcell{background:var(--night-3);padding:12px;display:flex;flex-direction:column;gap:3px;text-align:left}
.detail-stats .gcell .v{font-family:var(--font-num);font-size:18px;font-weight:700;letter-spacing:-0.025em;line-height:1;
  color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.detail-stats .gcell .k{font-size:10px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}

/* ============================================================
   responsive (mobile takes full screen)
   ============================================================ */

/* ---------- responsive: real mobile takes full screen ---------- */
@media (max-width:430px){
  html,body{overflow:hidden;height:100dvh;overscroll-behavior:none}
  .stage{padding:0;gap:0;background:var(--night);min-height:100dvh}
  .stage-cap{display:none}
  .device{width:100%;max-width:100%;height:100vh;height:100dvh;overflow:hidden;border-radius:0;box-shadow:none}
}

/* ============================================================
   DAY-MODE SURGICAL OVERRIDES
   Cases where the token swap alone isn't enough.
   ============================================================ */

/* page chrome */
[data-theme="day"] html,
[data-theme="day"] body{background:#e9e4d4}
[data-theme="day"] .stage{
  background:
    radial-gradient(700px 420px at 18% -4%, rgba(155,183,29,0.10), transparent 60%),
    radial-gradient(800px 500px at 88% 18%, rgba(58,143,200,0.07), transparent 64%),
    radial-gradient(700px 600px at 50% 110%, rgba(220,122,47,0.06), transparent 70%),
    #ece7d6}
[data-theme="day"] .stage-cap{color:rgba(60,60,67,0.45)}

/* device — soft drop shadow on parchment, dark bezel preserved */
[data-theme="day"] .device{
  background:#f5f3ec;
  box-shadow:0 30px 80px rgba(40,30,20,0.18), 0 0 0 10px #2a2a2e, 0 0 0 11px #1a1a1d}

/* status bar: time + battery icons must read dark; they inherit currentColor */

/* nav-action button hover (lighter ink) */
[data-theme="day"] .icon-btn:hover{background:rgba(0,0,0,0.05)}

/* tab bar — frosted white, lifts off content */
[data-theme="day"] .tabbar{
  background:rgba(255,255,255,0.78);
  border-top:1px solid rgba(0,0,0,0.06);
  box-shadow:0 -1px 0 rgba(255,255,255,0.5) inset}

/* cards — Apple-grade soft shadow + 0.5px keyline */
[data-theme="day"] .card,
[data-theme="day"] .stat-row .stat-card,
[data-theme="day"] .stat-grid,
[data-theme="day"] .hole-map,
[data-theme="day"] .hole-strip,
[data-theme="day"] .resume-banner,
[data-theme="day"] .mini-card,
[data-theme="day"] .about-card,
[data-theme="day"] .course-row{
  box-shadow:0 1px 2px rgba(40,30,20,0.04), 0 1px 0 rgba(255,255,255,0.4) inset;
  border-color:rgba(0,0,0,0.08)}

/* about card — paper warmth */
[data-theme="day"] .about-card{background:#faf7eb}

/* sheets — light backdrop, soft shadow */
[data-theme="day"] .backdrop{background:rgba(40,30,20,0.22);backdrop-filter:blur(4px) saturate(140%)}
[data-theme="day"] .sheet{background:#fafaf6;box-shadow:0 -10px 50px rgba(40,30,20,0.16)}
[data-theme="day"] .sheet-handle::before{background:rgba(0,0,0,0.16)}

/* text on lime / brand background — keep dark constant */
[data-theme="day"] .cta,
[data-theme="day"] .resume-banner .resume-btn,
[data-theme="day"] .fb.is-on,
[data-theme="day"] .yn-toggle button.is-on,
[data-theme="day"] .chat-input .send,
[data-theme="day"] .avatar-big{color:#0a0a0c}
[data-theme="day"] .seg button[aria-pressed="true"],
[data-theme="day"] [aria-label="Shot shape"].seg button[aria-pressed="true"]{color:#0a0a0c}
[data-theme="day"] .mini-card .hole.is-current .n,
[data-theme="day"] .mini-card .hole.is-current .s{color:#0a0a0c}
[data-theme="day"] .mini-card .hole.is-current{box-shadow:0 0 18px rgba(155,183,29,0.32)}

/* CTA — slightly richer shadow on light bg */
[data-theme="day"] .cta:hover{box-shadow:0 8px 24px rgba(155,183,29,0.28)}

/* Conditions card — fresh-air gradient */
[data-theme="day"] .conditions{
  background:linear-gradient(180deg, rgba(58,143,200,0.06), rgba(220,122,47,0.05))}

/* Distance — fairway warmth on white card */
[data-theme="day"] .distance{
  background:
    radial-gradient(220px 140px at 0% 100%, rgba(58,138,76,0.20), transparent 70%),
    radial-gradient(180px 120px at 100% 0%, rgba(155,183,29,0.12), transparent 70%),
    #ffffff}
[data-theme="day"] .pin-input .num{color:var(--lime-deep);text-shadow:0 0 28px rgba(155,183,29,0.25)}
[data-theme="day"] .pin-input .num:focus{color:var(--fairway)}

/* Result card — sunlit lime glow on paper */
[data-theme="day"] .result-card{
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(155,183,29,0.16), transparent 70%),
    radial-gradient(220px 180px at 0% 100%, rgba(58,138,76,0.14), transparent 70%),
    #fffef8;
  border:1px solid rgba(155,183,29,0.36);
  box-shadow:0 14px 44px rgba(155,183,29,0.12), 0 1px 0 rgba(255,255,255,0.7) inset}
[data-theme="day"] .result-club .it{color:var(--lime-deep)}

/* Caddie thinking state */
[data-theme="day"] .thinking{background:#fafaf6}

/* Bag — keep ladder + group dots visible */
[data-theme="day"] .ladder .dot.is-active{
  background:#0a0a0c;
  box-shadow:0 0 0 3px rgba(0,0,0,0.10), 0 0 24px rgba(155,183,29,0.45)}
[data-theme="day"] .conf-bar{background:rgba(0,0,0,0.08)}

/* Rounds — handicap spark line stays lime-deep */
[data-theme="day"] .spark .spark-line{stroke:var(--lime-deep)}

/* Stat row colour stripes already use --lime/sky/sand (themed correctly) */
[data-theme="day"] .stat-row .stat-card{background:#ffffff}

/* You — avatar contrast */
[data-theme="day"] .avatar-big{background:var(--lime);color:#0a0a0c;
  box-shadow:0 6px 18px rgba(155,183,29,0.32)}

/* Ace tab — chat */
[data-theme="day"] .ace-avatar{background:#ffffff;border-color:rgba(0,0,0,0.08)}
[data-theme="day"] .ace-avatar .pulse-dot{border-color:#ffffff;background:var(--lime-deep)}
[data-theme="day"] .msg.ace .body{
  background:linear-gradient(90deg, rgba(155,183,29,0.10), transparent 80%);
  border-left-color:var(--lime-deep)}
[data-theme="day"] .msg.ace .body em{color:var(--lime-deep)}
[data-theme="day"] .msg.you .body{background:#ffffff;box-shadow:0 1px 2px rgba(40,30,20,0.04)}
[data-theme="day"] .typing{background:#ffffff;border-left-color:var(--lime-deep)}
[data-theme="day"] .chat-input-area{background:linear-gradient(180deg,transparent,#f5f3ec 24%)}
[data-theme="day"] .chat-input{background:#ffffff;box-shadow:0 1px 2px rgba(40,30,20,0.04)}

/* Resume-banner — softer lime on paper */
[data-theme="day"] .resume-banner{
  background:linear-gradient(180deg,rgba(155,183,29,0.10),rgba(155,183,29,0.02));
  border-color:rgba(155,183,29,0.36)}

/* Round pill in nav */
[data-theme="day"] .round-pill{
  background:rgba(155,183,29,0.14);color:var(--lime-deep);
  border-color:rgba(155,183,29,0.30)}
[data-theme="day"] .round-pill .pulse-tiny{background:var(--lime-deep)}
[data-theme="day"] .ace-header .who .sub,
[data-theme="day"] .beta-tag{color:var(--ink-3)}

/* Mini scorecard hole tiles — light hole bg */
[data-theme="day"] .mini-card .hole{background:#faf8ee;border-color:rgba(0,0,0,0.08)}

/* Hole map / strip — looks like a printed yardage book on paper */
[data-theme="day"] .hole-map{
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(58,143,200,0.06), transparent 70%),
    radial-gradient(220px 180px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    #faf6e6}
[data-theme="day"] .hole-strip{background:#faf6e6}
[data-theme="day"] .hole-map::before,
[data-theme="day"] .hole-strip::before{
  background-image:radial-gradient(rgba(40,30,20,0.07) 1px, transparent 1px);opacity:0.65}
/* Map labels — readable on parchment */
[data-theme="day"] .hole-map .course-svg text,
[data-theme="day"] .hole-strip svg text{fill:#2a2618 !important}
[data-theme="day"] .hole-map .course-svg [fill="#c8f135"]:not(text):not(circle):not(path[d^="M"]){fill:#7a9512}
[data-theme="day"] .hole-map .course-svg [stroke="#c8f135"]{stroke:#7a9512 !important}
[data-theme="day"] .hole-map .course-svg .scribble-stroke{stroke:#7a9512 !important}
[data-theme="day"] .hole-map .course-svg [fill="#5eb3e4"]{fill:#3a8fc8}
[data-theme="day"] .hole-map .course-svg [stroke="#5eb3e4"]{stroke:#3a8fc8 !important}
[data-theme="day"] .hole-strip svg [stroke="#c8f135"]{stroke:#7a9512 !important}
[data-theme="day"] .hole-strip svg [fill="#c8f135"]{fill:#7a9512}
[data-theme="day"] .hole-map .course-svg text[fill="#ffffff"]{fill:rgba(42,38,24,0.7) !important}
[data-theme="day"] .hole-map .course-svg text[fill*="255,255,255"]{fill:rgba(42,38,24,0.5) !important}
[data-theme="day"] .hole-map .course-svg [stroke="#ffffff"]{stroke:rgba(42,38,24,0.4) !important}
[data-theme="day"] .hole-map .course-svg [stroke*="255,255,255"]{stroke:rgba(42,38,24,0.25) !important}
[data-theme="day"] .hole-strip svg [stroke="#ffffff"]{stroke:rgba(42,38,24,0.4) !important}
[data-theme="day"] .hole-map .ball-pulse,
[data-theme="day"] .hole-strip .ball-pulse{fill:#2a2618;opacity:0.45}
[data-theme="day"] .hole-map circle[fill="#ffffff"]{fill:#fafafa;stroke:var(--lime-deep) !important}
[data-theme="day"] .hole-strip svg circle[fill="#ffffff"]{fill:#fafafa;stroke:var(--lime-deep) !important}

/* Sheet body rows look like iOS grouped lists */
[data-theme="day"] .course-row{background:#ffffff}
[data-theme="day"] .course-row.is-favourite{border-color:rgba(155,183,29,0.36)}

/* Edit-field backgrounds inside sheets */
[data-theme="day"] .edit-form input[type=text],
[data-theme="day"] .edit-form input[type=number]{background:#ffffff;border-color:rgba(0,0,0,0.10)}

/* Live round bits */
[data-theme="day"] .stepper-btn{background:#ffffff}
[data-theme="day"] .lr-notes textarea{border-bottom-color:rgba(0,0,0,0.10)}
[data-theme="day"] .yn-toggle button{background:#ffffff}

/* status-bar icons stay dark via currentColor inheritance — no override needed */

/* ============================================================
   SOCIAL TAB · Strava for golf
   ============================================================ */

/* avatars — initials on a tinted disc, one tint per friend */
.avatar-xs, .avatar-sm, .avatar-md, .avatar-xl{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;letter-spacing:-0.02em;
  color:var(--night);background:var(--lime);flex-shrink:0;
  border-radius:50%;line-height:1}
.avatar-xs{width:22px;height:22px;font-size:9px}
.avatar-sm{width:32px;height:32px;font-size:11px}
.avatar-md{width:44px;height:44px;font-size:14px}
.avatar-xl{width:84px;height:84px;font-size:28px}
/* one tint per person — paint avatars consistently across the app */
.av-mh{background:var(--lime);color:var(--night)}
.av-sc{background:var(--sky);color:#06121a}
.av-lo{background:var(--dusk);color:#1a0a02}
.av-jp{background:var(--violet);color:#0d061a}
.av-dw{background:var(--fairway);color:#fff}
.av-mr{background:var(--sand);color:#1a1308}
.av-tv{background:var(--flag);color:#fff}
.av-ps{background:#e15a96;color:#fff}
.av-ad{background:#5cc9a8;color:#0a1814}
.av-kt{background:#c8a8ff;color:#0d061a}
.av-eb{background:#ffb84d;color:#1a0a02}
[data-theme="day"] .av-mh{color:#fff}
[data-theme="day"] .av-dw{background:#3a8a4c}
[data-theme="day"] .av-mr{background:#c9a85e}

.live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--lime);
  margin-right:6px;vertical-align:1px;animation:pulse 2s ease-out infinite;
  box-shadow:0 0 0 0 rgba(200,241,53,0.55)}
.label-row .label{display:inline-flex;align-items:center}
.label-row .label-meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:600;text-transform:uppercase}

/* ── Social hero card ── */
.soc-me{padding:0}
.soc-me-row{display:flex;align-items:center;gap:14px;padding:16px 18px 12px}
.soc-me-row .who{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.soc-me-row .who .nm{font-family:var(--font-display);font-weight:700;font-size:17px;
  letter-spacing:-0.02em;color:var(--ink)}
.soc-me-row .who .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase}
.soc-share{width:36px;height:36px;border-radius:50%;background:var(--night-4);color:var(--ink-2);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s,transform .12s var(--ease-spring)}
.soc-share svg{width:14px;height:14px}
.soc-share:hover{background:var(--night-5);color:var(--lime)}
.soc-share:active{transform:scale(0.92)}
.soc-share.flash{background:var(--lime);color:var(--night)}
[data-theme="day"] .soc-share{background:#fff;border:1px solid var(--rule)}
[data-theme="day"] .soc-share:hover{background:#fffef8}
.soc-me-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--rule)}
.soc-me-stats .cell{padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:2px;
  position:relative;transition:background .15s}
.soc-me-stats .cell:hover{background:var(--night-4)}
.soc-me-stats .cell:active{background:var(--night-5)}
.soc-me-stats .cell + .cell::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:1px;background:var(--rule)}
.soc-me-stats .v{font-family:var(--font-num);font-size:22px;font-weight:700;
  letter-spacing:-0.03em;color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.soc-me-stats .k{font-size:10px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}

/* ── Live now strip ── */
.live-strip{display:flex;gap:10px;overflow-x:auto;padding:2px 4px 6px;
  scroll-snap-type:x mandatory;scrollbar-width:none;margin:0 -22px;padding-left:22px;padding-right:22px}
.live-strip::-webkit-scrollbar{display:none}
.live-card{flex:0 0 122px;background:var(--night-3);border:1px solid var(--rule);
  border-radius:14px;padding:12px 12px 10px;display:flex;flex-direction:column;align-items:flex-start;
  gap:6px;scroll-snap-align:start;transition:background .15s,border-color .15s,transform .12s var(--ease-spring);
  position:relative;text-align:left}
.live-card:hover{background:var(--night-4);border-color:var(--rule-2)}
.live-card:active{transform:scale(0.97)}
.live-card .lc-top{position:relative}
.live-card .live-pulse{position:absolute;right:-3px;bottom:-2px;width:10px;height:10px;
  border-radius:50%;background:var(--lime);border:2px solid var(--night-3);
  animation:pulse 2s ease-out infinite}
[data-theme="day"] .live-card .live-pulse{background:var(--lime-deep);border-color:#fff}
.live-card .nm{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03'}
.live-card .thru{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);
  letter-spacing:0.04em;font-weight:600;text-transform:uppercase}
.live-card .thru em{font-style:normal;color:var(--lime);margin-left:3px;font-weight:700}
.live-card .thru.rest em{color:var(--ink-2)}
.live-card .course{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase}
.live-card.is-rest{opacity:0.7}

/* ── Feed ── */
.feed-seg{display:inline-flex;background:var(--night-4);border-radius:10px;padding:2px}
.feed-seg button{font-size:11px;font-weight:600;letter-spacing:-0.005em;padding:5px 9px;
  border-radius:8px;color:var(--ink-3);transition:all .2s var(--ease-out)}
.feed-seg button.is-on{background:var(--ink);color:var(--night)}
[data-theme="day"] .feed-seg button.is-on{background:var(--ink);color:#fff}

/* E9 · compact feed = divided list (no per-card gap; hairline dividers) */
.feed{display:flex;flex-direction:column;gap:0}
.post{background:transparent;border:0;border-bottom:1px solid var(--rule);border-radius:0;
  overflow:visible;animation:postIn var(--dur-enter) var(--ease-ios) both;transition:background var(--dur-base) var(--ease-ios),margin var(--dur-base) var(--ease-spring),border-radius var(--dur-base) var(--ease-ios),box-shadow var(--dur-base) var(--ease-ios)}
.post:last-child{border-bottom:0}
/* feed post stagger on tab/view enter (CSS nth-child cascade — keeps renderFeed untouched, SLICECO_MOTION replays it) */
.post:nth-child(2){animation-delay:var(--stagger)}
.post:nth-child(3){animation-delay:calc(var(--stagger)*2)}
.post:nth-child(4){animation-delay:calc(var(--stagger)*3)}
.post:nth-child(5){animation-delay:calc(var(--stagger)*4)}
.post:nth-child(6){animation-delay:calc(var(--stagger)*5)}
.post:nth-child(7){animation-delay:calc(var(--stagger)*6)}
.post:nth-child(8){animation-delay:calc(var(--stagger)*7)}
.post:nth-child(n+9){animation-delay:calc(var(--stagger)*8)}
/* E9 · open post blooms into a card */
.post.is-open{background:var(--night-3);border-bottom-color:transparent;border-radius:16px;margin:6px 0;box-shadow:0 8px 28px -12px rgba(0,0,0,.5)}
@keyframes postIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* Feed summary toggle (ROW1 identity + ROW2 condensed result + chev) */
.post-summary{display:block;width:100%;text-align:left;padding:12px 14px;cursor:pointer;
  transition:opacity .15s}
.post-summary:active{opacity:.78;transform:scale(.992)}
.post-summary .ps-row1{display:flex;align-items:center;gap:12px;min-width:0}
.post-summary .nm-wrap{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.post-summary .ps-row2{display:flex;align-items:center;gap:8px;margin-top:8px;min-width:0}
.post-summary .ps-result{flex:1;min-width:0;font-family:var(--font-sans);font-size:13px;
  color:var(--ink-2);letter-spacing:-0.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-summary .ps-result b{font-family:var(--font-num);font-weight:700;color:var(--ink);
  font-variant-numeric:tabular-nums;letter-spacing:-0.02em;margin-right:4px}
.chev{width:16px;height:16px;flex-shrink:0;color:var(--ink-4);
  transition:transform var(--dur-base) var(--ease-spring),color .2s var(--ease-out)}
.post.is-open .chev{transform:rotate(180deg);color:var(--lime)}

/* D1 · feed expand — grid-rows bloom animation */
.post-detail{display:grid;grid-template-rows:0fr;
  transition:grid-template-rows var(--dur-slow) var(--ease-ios)}
.post-detail > div{overflow:hidden;min-height:0;opacity:0;transition:opacity .3s var(--ease-out) .08s}
.post.is-open .post-detail{grid-template-rows:1fr}
.post.is-open .post-detail > div{opacity:1}
@media (prefers-reduced-motion: reduce){
  .post{animation:none;opacity:1}
  .post-detail{transition:none}
  .post-detail > div{opacity:1;transition:none}
  .post.is-open{transition:none}
  .chev{transition:none}
}

/* E16 · avatar with inset ring */
.avatar-md{position:relative;flex-shrink:0}
.avatar-md::after{content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.08);pointer-events:none}
[data-theme="day"] .avatar-md::after{box-shadow:inset 0 0 0 1px rgba(0,0,0,0.06)}
.post-summary .avatar-md{width:40px;height:40px}

.post-head{display:flex;align-items:center;gap:12px;padding:12px 14px 8px}
.post-head .who{display:flex;align-items:center;gap:10px;flex:1;min-width:0;text-align:left;
  transition:opacity .15s}
.post-head .who:active{opacity:0.7}
.post-head .nm-wrap{display:flex;flex-direction:column;gap:2px;min-width:0}
/* C0 · kill Bricolage on feed names → Inter 600 */
.post-head .nm,.post-summary .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03';
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
/* E7 · feed meta — Inter, sentence-case, ellipsis */
.post-head .meta,.post-summary .meta{font-family:var(--font-sans);font-size:12px;color:var(--ink-3);
  letter-spacing:-0.005em;font-weight:500;text-transform:none;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.post-badge{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--lime);background:var(--lime-soft);
  padding:4px 8px;border-radius:var(--r-pill);flex-shrink:0}
.post-badge.under{color:var(--lime);background:var(--lime-soft)}
.post-badge.warn{color:var(--sand);background:var(--sand-soft)}

.post-hero{display:flex;align-items:center;justify-content:space-between;
  padding:6px 14px 14px;gap:14px}
.score-block-sm{display:inline-flex;align-items:baseline;gap:10px}
.score-block-sm .n{font-family:var(--font-num);font-size:44px;font-weight:700;line-height:0.95;
  letter-spacing:-0.04em;color:var(--ink);font-variation-settings:'wdth' 85,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums}
.score-block-sm .vs{font-family:var(--font-mono);font-size:11px;font-weight:700;
  letter-spacing:0.06em;padding:3px 8px;border-radius:var(--r-pill);text-transform:uppercase}
.score-block-sm .vs.under{color:var(--lime);background:var(--lime-soft)}
.score-block-sm .vs.over{color:var(--flag);background:var(--flag-soft)}
.score-block-sm .vs.even{color:var(--ink-3);background:var(--rule)}
.post-stats{display:flex;gap:14px}
.post-stats .ps{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.post-stats .ps b{font-family:var(--font-num);font-size:16px;font-weight:700;letter-spacing:-0.02em;
  color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.post-stats .ps i{font-family:var(--font-mono);font-style:normal;font-size:9px;
  letter-spacing:0.1em;color:var(--ink-4);font-weight:600;text-transform:uppercase}

/* hole-by-hole bars on a feed post */
.post-holes{display:grid;grid-template-columns:repeat(18,1fr);gap:2px;padding:0 14px 14px;
  align-items:end;height:38px}
.post-holes .ph{background:var(--ink-5);border-radius:2px 2px 0 0;height:calc(var(--h) * 100%);min-height:2px;
  transform-origin:bottom;animation:phIn .5s var(--ease-out) both}
.post-holes .ph[data-r="under"]{background:var(--lime)}
.post-holes .ph[data-r="over"]{background:var(--flag);opacity:0.7}
.post-holes .ph[data-r="par"]{background:var(--ink-3)}
@keyframes phIn{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.post-holes .ph:nth-child(n){animation-delay:calc(var(--i, 0) * 18ms)}
.post-holes .ph:nth-child(1){animation-delay:0ms}.post-holes .ph:nth-child(2){animation-delay:25ms}
.post-holes .ph:nth-child(3){animation-delay:50ms}.post-holes .ph:nth-child(4){animation-delay:75ms}
.post-holes .ph:nth-child(5){animation-delay:100ms}.post-holes .ph:nth-child(6){animation-delay:125ms}
.post-holes .ph:nth-child(7){animation-delay:150ms}.post-holes .ph:nth-child(8){animation-delay:175ms}
.post-holes .ph:nth-child(9){animation-delay:200ms}.post-holes .ph:nth-child(10){animation-delay:225ms}
.post-holes .ph:nth-child(11){animation-delay:250ms}.post-holes .ph:nth-child(12){animation-delay:275ms}
.post-holes .ph:nth-child(13){animation-delay:300ms}.post-holes .ph:nth-child(14){animation-delay:325ms}
.post-holes .ph:nth-child(15){animation-delay:350ms}.post-holes .ph:nth-child(16){animation-delay:375ms}
.post-holes .ph:nth-child(17){animation-delay:400ms}.post-holes .ph:nth-child(18){animation-delay:425ms}

/* E6 · post-note → Inter (content font), not serif */
.post-note{font-family:var(--font-sans);font-style:normal;font-size:14px;color:var(--ink-2);
  letter-spacing:-0.005em;line-height:1.5;padding:0 14px 12px}
.post-note em{color:var(--lime);font-style:normal;font-weight:600}

/* E5 · flatten ACE card — transparent, top-rule only */
.shot-card{margin:0 14px 12px;padding:12px 0 8px;background:transparent;
  border:0;border-top:1px solid var(--rule);border-radius:0;color:var(--lime)}
.shot-card .tag{font-family:var(--font-mono);font-size:9px;letter-spacing:0.12em;
  font-weight:700;text-transform:uppercase}
.shot-card .shot-line{font-family:var(--font-sans);font-size:14px;color:var(--ink);font-style:normal;
  letter-spacing:-0.005em;line-height:1.4;margin-top:3px}
.shot-card .shot-line em{font-style:normal;color:var(--lime);font-weight:700;font-size:16px}
.shot-card .shot-trail svg{width:100%;height:24px;display:block;margin-top:2px;color:var(--lime)}
[data-theme="day"] .shot-card{color:var(--lime-deep);background:transparent;border-top-color:var(--rule)}
[data-theme="day"] .shot-card .shot-line em{color:var(--lime-deep)}

/* E8 · lighter reaction footer — no uppercase, Inter */
.post-foot{display:flex;align-items:center;gap:4px;padding:6px 10px 12px;border-top:1px solid var(--rule)}
.post-foot .rt{font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--ink-3);
  letter-spacing:-0.005em;text-transform:none}
.react{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--r-pill);
  color:var(--ink-3);font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:-0.005em;text-transform:none;
  transition:all .15s,transform .12s var(--ease-spring)}
.react svg{width:14px;height:14px}
.react:hover{background:var(--night-4);color:var(--ink)}
.react:active{transform:scale(0.92)}
.react.is-on{color:var(--lime);background:var(--lime-soft)}
.react.is-on svg{color:var(--lime);stroke:var(--lime);fill:rgba(200,241,53,0.18)}
.react.bump{animation:bump .35s var(--ease-spring)}
.react.flash{background:var(--night-5)}
.react.ghost{margin-left:auto;color:var(--ink-4);padding:6px 8px}
.react-cta{margin-left:6px;font-family:var(--font-sans);font-size:12px;font-weight:600;
  letter-spacing:-0.005em;text-transform:none;color:var(--lime);
  padding:6px 12px;border:1px solid rgba(200,241,53,0.36);border-radius:var(--r-pill);
  transition:all .15s,transform .12s var(--ease-spring)}
.react-cta:hover{background:var(--lime-soft);border-color:var(--lime)}
.react-cta:active{transform:scale(0.96)}

/* Feed comments (inside .post-detail; DELETE /comments/:id) */
.post-comments{padding:4px 14px 12px;display:flex;flex-direction:column;gap:10px}
.cmt{display:flex;align-items:flex-start;gap:8px}
.cmt .cmt-body{flex:1;min-width:0;font-family:var(--font-sans);font-size:13px;color:var(--ink-2);
  letter-spacing:-0.005em;line-height:1.45}
.cmt .cmt-body .cmt-nm{font-weight:600;color:var(--ink);margin-right:5px;font-feature-settings:'cv01','ss03'}
.cmt .cmt-when{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.06em;
  font-weight:500;text-transform:uppercase;margin-top:2px}
.cmt .cmt-del{flex-shrink:0;color:var(--ink-4);opacity:0;transition:opacity .15s,color .15s;
  width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}
.cmt:hover .cmt-del{opacity:1}
.cmt .cmt-del:hover{color:var(--flag)}
.cmt .cmt-del svg{width:13px;height:13px}
.cmt-add{display:flex;align-items:center;gap:8px;margin-top:2px}
.cmt-add input{flex:1;font-family:var(--font-sans);font-size:13px;color:var(--ink);letter-spacing:-0.005em;
  background:var(--night-4);border:1px solid var(--rule);border-radius:var(--r-pill);padding:8px 14px;height:34px}
.cmt-add input::placeholder{color:var(--ink-4)}
.cmt-add .cmt-send{font-family:var(--font-sans);font-weight:600;font-size:12px;color:var(--lime);
  letter-spacing:-0.005em;padding:6px 4px}
[data-theme="day"] .cmt-add input{background:#ffffff}

.you-empty{padding:24px 14px;text-align:center;background:var(--night-3);border:1px dashed var(--rule-2);
  border-radius:var(--r-card)}
.you-empty .h{font-family:var(--font-serif);font-style:italic;font-size:16px;color:var(--ink);
  letter-spacing:-0.005em}
.you-empty .s{font-size:12px;color:var(--ink-3);margin-top:5px;letter-spacing:-0.005em;line-height:1.45}
.you-empty b{color:var(--lime)}

/* E15 · single unified social empty-state (no dashed border) */
.soc-empty{padding:48px 20px;text-align:center;background:transparent;border:0;
  display:flex;flex-direction:column;align-items:center;gap:6px}
.soc-empty .glyph{width:48px;height:48px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  background:var(--lime-soft);color:var(--lime);margin-bottom:8px}
.soc-empty .glyph svg{width:26px;height:26px}
.soc-empty .h{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-0.01em}
.soc-empty .s{font-family:var(--font-sans);font-size:13px;color:var(--ink-3);letter-spacing:-0.005em;line-height:1.45;max-width:30ch}
.soc-empty b{color:var(--lime);font-weight:600}
[data-theme="day"] .soc-empty .glyph{color:var(--lime-deep)}

/* ── Leaderboard ── */
.lb{padding:0}
.lb-tabs{display:flex;gap:4px;padding:12px 12px 10px;border-bottom:1px solid var(--rule);
  overflow-x:auto;scrollbar-width:none}
.lb-tabs::-webkit-scrollbar{display:none}
.lb-tabs button{flex:0 0 auto;font-family:var(--font-sans);font-size:11px;font-weight:600;
  letter-spacing:-0.005em;color:var(--ink-3);padding:6px 11px;border-radius:var(--r-pill);
  border:1px solid var(--rule);transition:all .2s var(--ease-out);white-space:nowrap}
.lb-tabs button:hover{color:var(--ink-2);border-color:var(--rule-2)}
.lb-tabs button.is-on{background:var(--lime);color:var(--night);border-color:var(--lime)}
.lb-list{padding:6px 0}
.lb-row{display:grid;grid-template-columns:28px auto 1fr auto;gap:10px;align-items:center;
  padding:10px 16px;width:100%;text-align:left;transition:background .15s}
.lb-row:hover{background:var(--night-4)}
.lb-row.is-you{background:rgba(200,241,53,0.05)}
.lb-row.is-you:hover{background:rgba(200,241,53,0.08)}
.rk{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.04em;
  color:var(--ink-4);width:22px;height:22px;border-radius:50%;display:inline-flex;
  align-items:center;justify-content:center;background:var(--night-4);border:1px solid var(--rule)}
.rk.gold{background:linear-gradient(180deg,#f0d97a,#c9a85e);color:#1a1308;border-color:transparent}
.rk.silver{background:linear-gradient(180deg,#e6e6e6,#c4c4c4);color:#0a0a0c;border-color:transparent}
.rk.bronze{background:linear-gradient(180deg,#d99d6e,#a4724a);color:#1a0a02;border-color:transparent}
.lb-who{display:inline-flex;align-items:center;gap:8px;min-width:0}
.lb-who .t{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03';white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-bar{position:relative;height:6px;background:var(--night-5);border-radius:3px;overflow:hidden}
.lb-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--lime-deep),var(--lime));
  border-radius:3px;transform-origin:left;animation:barIn .8s var(--ease-out) .1s both}
.lb-row.is-you .lb-bar i{background:linear-gradient(90deg,var(--ink),var(--lime))}
.lb-val{font-family:var(--font-num);font-size:15px;font-weight:700;letter-spacing:-0.02em;
  color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;min-width:44px;text-align:right}

/* ── Course showdown ── */
.lb-course-pick{display:inline-flex;align-items:center;gap:4px;color:var(--lime);font-size:12px;
  font-weight:600;letter-spacing:-0.005em;border-bottom:1px solid rgba(200,241,53,0.28);
  padding-bottom:1px;transition:opacity .15s}
.lb-course-pick svg{width:10px;height:10px}
.lb-course-pick:hover{opacity:0.7}
.course-showdown{padding:0;overflow:hidden}
.cs-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:16px 18px 14px;background:
    radial-gradient(220px 160px at 0% 100%, rgba(200,241,53,0.10), transparent 70%),
    radial-gradient(220px 160px at 100% 0%, rgba(94,179,228,0.08), transparent 70%);
  border-bottom:1px solid var(--rule)}
.cs-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.cs-tag{font-family:var(--font-mono);font-size:9px;color:var(--lime);letter-spacing:0.14em;
  font-weight:700;text-transform:uppercase}
.cs-title{font-family:var(--font-display);font-weight:700;font-size:16px;
  letter-spacing:-0.02em;color:var(--ink)}
.cs-sub{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.08em;
  font-weight:500;text-transform:uppercase}
.cs-king{display:flex;flex-direction:column;align-items:center;gap:2px;flex-shrink:0}
.cs-king .crown{width:24px;height:18px;color:#e8c878;display:inline-flex;align-items:center;justify-content:center}
.cs-king .crown svg{width:18px;height:14px}
.cs-king .kn{font-family:var(--font-mono);font-size:9px;color:var(--sand);letter-spacing:0.1em;
  font-weight:700;text-transform:uppercase}
.cs-king .ks{font-family:var(--font-num);font-size:24px;font-weight:700;letter-spacing:-0.03em;
  color:var(--ink);font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;line-height:1;font-variant-numeric:tabular-nums}
.cs-rows{padding:6px 0}
.cs-row{display:grid;grid-template-columns:28px 22px 1fr auto;gap:10px;align-items:center;
  padding:9px 16px;cursor:pointer;transition:background .15s}
.cs-row:hover{background:var(--night-4)}
.cs-row.is-you{background:rgba(200,241,53,0.05)}
.cs-row.is-king{background:linear-gradient(90deg, rgba(232,200,120,0.08), transparent 60%)}
.cs-row .nm{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03'}
.score-pair{display:inline-flex;align-items:baseline;gap:6px}
.score-pair .n{font-family:var(--font-num);font-size:18px;font-weight:700;letter-spacing:-0.025em;
  color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.score-pair .vs{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:0.06em;
  padding:2px 6px;border-radius:4px}
.score-pair .vs.over{color:var(--flag);background:var(--flag-soft)}
.score-pair .vs.under{color:var(--lime);background:var(--lime-soft)}
.score-pair .vs.even{color:var(--ink-3);background:var(--rule)}

/* ── Driver shootout ── */
.driver-shootout{padding:0}
.ds-head{display:flex;justify-content:space-between;align-items:baseline;padding:12px 16px 4px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;font-weight:600;text-transform:uppercase}
.ds-head .ds-l{color:var(--ink-3)}
.ds-head .ds-r{color:var(--ink-4)}
.ds-list{padding:4px 0}
.ds-row{display:grid;grid-template-columns:28px 22px auto 1fr auto;gap:10px;align-items:center;
  padding:9px 16px;width:100%;text-align:left;transition:background .15s}
.ds-row:hover{background:var(--night-4)}
.ds-row.is-you{background:rgba(200,241,53,0.05)}
.ds-row .nm{font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03'}
.ds-bar{position:relative;height:8px;background:var(--night-5);border-radius:4px;overflow:hidden}
.ds-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--sky),var(--lime));
  border-radius:4px;animation:barIn .9s var(--ease-out) .15s both}
.ds-row.is-you .ds-bar i{background:linear-gradient(90deg,var(--ink),var(--lime))}
.ds-val{font-family:var(--font-num);font-size:16px;font-weight:700;letter-spacing:-0.02em;
  color:var(--ink);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;line-height:1}
.ds-val small{font-family:var(--font-sans);font-size:10px;color:var(--ink-4);margin-left:2px;font-weight:500}
.ds-foot{display:flex;justify-content:space-between;align-items:baseline;padding:10px 16px 12px;
  margin-top:4px;border-top:1px solid var(--rule);font-family:var(--font-mono);font-size:9px;
  letter-spacing:0.1em;font-weight:600;text-transform:uppercase;color:var(--ink-4)}
.ds-foot .winner{color:var(--lime);text-transform:none;font-family:var(--font-sans);font-size:12px;
  letter-spacing:-0.005em;font-weight:600}
.ds-foot .winner em{color:var(--lime);font-family:var(--font-num);font-style:normal;font-size:14px;font-weight:700;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}

/* ── Club compare ── */
.club-compare{padding:0;overflow:hidden}
.cc-head{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;
  padding:12px 16px;border-bottom:1px solid var(--rule);background:
    linear-gradient(90deg, rgba(200,241,53,0.05), transparent 50%, rgba(94,179,228,0.05))}
.cc-head .who-l, .cc-head .who-r{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);
  font-weight:600;font-size:13px;color:var(--ink);letter-spacing:-0.005em}
.cc-head .who-r{justify-content:flex-end;text-align:right;background:transparent;cursor:pointer;
  padding:4px 6px;border-radius:8px;transition:background .15s}
.cc-head .who-r:hover{background:var(--night-4)}
.cc-head .who-r .chev{width:10px;height:10px;color:var(--ink-4)}
.cc-head .vs{font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;font-weight:700;
  color:var(--ink-4);text-transform:uppercase}
.cc-rows{padding:6px 0}
.cc-row{display:grid;grid-template-columns:32px 1fr 36px 1fr;gap:6px;align-items:center;
  padding:8px 14px;transition:background .15s}
.cc-row:hover{background:var(--night-4)}
.cc-club{font-family:var(--font-mono);font-size:10px;color:var(--ink-3);font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase}
.cc-side{display:inline-flex;align-items:center;gap:6px}
.cc-side.cc-you{justify-content:flex-end;flex-direction:row}
.cc-side.cc-them{justify-content:flex-start;flex-direction:row-reverse}
.cc-side .v{font-family:var(--font-num);font-size:14px;font-weight:700;letter-spacing:-0.02em;
  color:var(--ink-2);font-variation-settings:'wdth' 92,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;min-width:26px;text-align:center}
.cc-side .bar{position:relative;height:5px;background:var(--night-5);border-radius:3px;
  width:60px;overflow:hidden}
.cc-side.cc-you .bar{transform:scaleX(-1)}  /* mirror left bar */
.cc-side .bar i{display:block;height:100%;border-radius:3px;background:var(--lime)}
.cc-side .bar.them i{background:var(--sky)}
.cc-diff{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:0.04em;
  text-align:center;color:var(--ink-4)}
.cc-row.lead-you .cc-diff{color:var(--lime)}
.cc-row.lead-you .cc-side.cc-you .v{color:var(--ink)}
.cc-row.lead-them .cc-diff{color:var(--sky)}
.cc-row.lead-them .cc-side.cc-them .v{color:var(--ink)}
.cc-row.lead-even .cc-diff{color:var(--ink-4)}

/* ── Friends list ── */
.friends-list{padding:0}
.friend-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:12px 14px;text-align:left;width:100%;transition:background .15s}
.friend-row + .friend-row{border-top:1px solid var(--rule)}
.friend-row:hover{background:var(--night-4)}
.friend-row:active{background:var(--night-5)}
.friend-row .fr-mid{display:flex;flex-direction:column;gap:3px;min-width:0}
.friend-row .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03';display:inline-flex;align-items:center;gap:6px}
.friend-row .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.06em;font-weight:500;text-transform:uppercase}
.friend-row .meta b{color:var(--ink-2);font-family:var(--font-serif);font-style:italic;
  font-weight:400;font-size:12px;letter-spacing:-0.01em;text-transform:none;margin:0 1px}
.live-tag{font-family:var(--font-mono);font-size:9px;letter-spacing:0.08em;font-weight:700;
  color:var(--lime);background:var(--lime-soft);padding:2px 7px;border-radius:var(--r-pill);
  text-transform:uppercase;display:inline-flex;align-items:center;gap:4px}
.live-tag .live-dot{width:5px;height:5px;margin-right:0}
.fr-actions{display:inline-flex;align-items:center;gap:6px;color:var(--ink-4)}
.fr-actions .cmp{font-family:var(--font-mono);font-size:10px;letter-spacing:0.08em;
  font-weight:700;color:var(--lime);text-transform:uppercase}
.fr-actions svg{width:12px;height:12px;color:var(--ink-4)}

.cta.soc-add{background:var(--night-3);color:var(--lime);border:1px solid rgba(200,241,53,0.36)}
.cta.soc-add:hover{background:var(--lime-soft);box-shadow:0 8px 24px rgba(200,241,53,0.08)}
[data-theme="day"] .cta.soc-add{background:#ffffff;color:var(--lime-deep);border-color:rgba(155,183,29,0.36)}

/* ── Friend sheet ── */
.sheet.sheet-tall{max-height:92%}
.friend-hero{display:flex;align-items:center;gap:14px;padding:8px 0 18px;border-bottom:1px solid var(--rule)}
.friend-hero .who{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.friend-hero .who .nm{font-family:var(--font-display);font-weight:700;font-size:22px;
  letter-spacing:-0.025em;color:var(--ink)}
.friend-hero .who .handle{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase}
.friend-hero .badges{display:inline-flex;flex-wrap:wrap;gap:4px;margin-top:2px}
.badge{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--ink-3);background:var(--night-4);padding:3px 7px;border-radius:var(--r-pill);
  border:1px solid var(--rule)}
.badge.lime{color:var(--lime);background:var(--lime-soft);border-color:rgba(200,241,53,0.28)}
.friend-quick{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:16px 0 18px;
  border-bottom:1px solid var(--rule)}
.friend-quick .fq{display:flex;flex-direction:column;align-items:center;gap:3px;background:var(--night-3);
  border:1px solid var(--rule);border-radius:14px;padding:14px 8px}
.friend-quick .fq .v{font-family:var(--font-serif);font-size:24px;font-weight:400;letter-spacing:-0.02em;
  color:var(--ink);font-variation-settings:'opsz' 72;line-height:1}
.friend-quick .fq .k{font-size:10px;color:var(--ink-4);font-weight:500;letter-spacing:-0.005em}
.friend-stat-grid{margin-top:8px}

/* small round row variant used inside sheets */
.round-row.mini{padding:12px 4px}
.round-row.mini + .round-row.mini{border-top:1px solid var(--rule)}

/* ── Compare sheet ── */
.compare-hero{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;
  padding:6px 0 14px;border-bottom:1px solid var(--rule)}
.ch-side{display:flex;flex-direction:column;align-items:center;gap:4px}
.ch-side .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;letter-spacing:-0.01em;font-feature-settings:'cv01','ss03';color:var(--ink)}
.ch-side .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase}
.ch-vs{font-family:var(--font-serif);font-style:italic;font-size:24px;color:var(--ink-3);
  letter-spacing:-0.025em;font-variation-settings:'opsz' 72}

.compare-score{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:14px 0 14px;border-bottom:1px solid var(--rule)}
.compare-score .cs-l, .compare-score .cs-r{display:flex;flex-direction:column;align-items:center;gap:2px}
.compare-score b{font-family:var(--font-serif);font-size:28px;font-weight:400;
  letter-spacing:-0.025em;color:var(--ink);font-variation-settings:'opsz' 72;line-height:1}
.compare-score i{font-family:var(--font-mono);font-size:9px;font-style:normal;
  letter-spacing:0.1em;color:var(--ink-4);font-weight:600;text-transform:uppercase}
.cs-bar{position:relative;height:8px;background:var(--night-4);border-radius:4px;overflow:hidden;display:flex}
.cs-fill{display:block;height:100%;transition:width .6s var(--ease-out)}
.cs-fill.cs-you{background:linear-gradient(90deg,var(--lime),var(--lime-2))}
.cs-fill.cs-them{background:linear-gradient(90deg,var(--sky),#7cc4ec)}

.compare-rows{padding:6px 0}
.cmp-row{display:grid;grid-template-columns:48px 1fr 48px;gap:8px;align-items:center;
  padding:10px 14px 8px;border-bottom:1px solid var(--rule);position:relative}
.cmp-row:last-child{border-bottom:0}
.cmp-row .cmp-k{grid-column:1 / -1;font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.1em;font-weight:600;text-transform:uppercase;text-align:center;margin-top:2px}
.cmp-row .cmp-you, .cmp-row .cmp-them{font-family:var(--font-serif);font-size:15px;font-weight:400;
  letter-spacing:-0.015em;color:var(--ink-2);font-variation-settings:'opsz' 72;font-variant-numeric:tabular-nums}
.cmp-row .cmp-you{text-align:right}
.cmp-row .cmp-them{text-align:left}
.cmp-row.lead-you .cmp-you{color:var(--lime);font-size:18px}
.cmp-row.lead-them .cmp-them{color:var(--sky);font-size:18px}
.cmp-row.tie .cmp-you, .cmp-row.tie .cmp-them{color:var(--ink-2)}
.cmp-bar{position:relative;height:7px;background:var(--night-4);border-radius:4px;overflow:visible;
  display:flex;justify-content:center}
.cmp-bar .cmp-fill{position:absolute;top:0;bottom:0;width:calc(var(--p) / 2 * 1%);
  border-radius:4px;animation:cmpBarIn .8s var(--ease-out) both}
@keyframes cmpBarIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.cmp-bar .cmp-you-fill{right:50%;background:linear-gradient(270deg,var(--lime),rgba(200,241,53,0.4));
  transform-origin:right}
.cmp-bar .cmp-them-fill{left:50%;background:linear-gradient(90deg,var(--sky),rgba(94,179,228,0.4));
  transform-origin:left}
.cmp-bar .cmp-pin{position:absolute;left:50%;top:-2px;bottom:-2px;width:1px;
  background:var(--ink-4);transform:translateX(-50%);opacity:0.5}

/* Best round head-to-head card */
.best-card{display:grid;grid-template-columns:1fr 32px 1fr;align-items:center;padding:14px;gap:12px}
.bc-side{display:flex;flex-direction:column;align-items:center;gap:4px}
.bc-side .t{font-family:var(--font-mono);font-size:9px;letter-spacing:0.12em;font-weight:700;
  text-transform:uppercase;color:var(--ink-4)}
.bc-side.you .t{color:var(--lime)}
.bc-side.them .t{color:var(--sky)}
.bc-side .n{font-family:var(--font-serif);font-size:48px;font-weight:400;letter-spacing:-0.03em;
  color:var(--ink);font-variation-settings:'opsz' 72;line-height:1;font-variant-numeric:tabular-nums}
.bc-side .vs{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:0.06em;
  padding:2px 7px;border-radius:4px;text-transform:uppercase}
.bc-side .vs.under{color:var(--lime);background:var(--lime-soft)}
.bc-side .vs.over{color:var(--flag);background:var(--flag-soft)}
.bc-side .when{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.08em;font-weight:500;text-transform:uppercase;text-align:center}
.bc-mid{display:flex;align-items:center;justify-content:center}
.bc-mid .dash{width:1px;height:60px;background:var(--rule)}

/* Driver duel */
.driver-duel{padding:14px}
.dd-row{display:grid;grid-template-columns:60px 1fr 60px;align-items:center;gap:10px;
  padding:8px 0;font-family:var(--font-display);font-weight:600}
.dd-row .t{font-size:13px;color:var(--ink);letter-spacing:-0.005em}
.dd-row.them .t{text-align:right}
.dd-row .bar{height:10px;background:var(--night-5);border-radius:6px;overflow:hidden}
.dd-row .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--lime-deep),var(--lime));
  border-radius:6px;animation:barIn 1s var(--ease-out) .2s both}
.dd-row .bar.them i{background:linear-gradient(90deg,var(--sky),#7cc4ec)}
.dd-row .v{font-family:var(--font-serif);font-size:18px;font-weight:400;letter-spacing:-0.015em;
  color:var(--ink);font-variation-settings:'opsz' 72;text-align:right;font-variant-numeric:tabular-nums}
.dd-row.them .v{text-align:left}
.dd-row .v small{font-family:var(--font-sans);font-size:11px;color:var(--ink-4);margin-left:2px;font-weight:500}
.dd-foot{padding-top:8px;border-top:1px solid var(--rule);margin-top:4px;text-align:center}
.dd-foot .diff{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;font-weight:600;
  color:var(--ink-3);text-transform:uppercase}

/* ── Add friends sheet ── */
.search-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--night-3);
  border:1px solid var(--rule);border-radius:12px;margin-bottom:14px}
.search-bar svg{width:14px;height:14px;color:var(--ink-4)}
.search-bar input{flex:1;font-size:15px;color:var(--ink);letter-spacing:-0.005em;height:24px}
.search-bar input::placeholder{color:var(--ink-4)}
[data-theme="day"] .search-bar{background:#ffffff}

.saf-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.saf-m{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:14px 12px;
  background:var(--night-3);border:1px solid var(--rule);border-radius:14px;text-align:left;
  color:var(--ink-2);transition:background .15s,border-color .15s,transform .12s var(--ease-spring)}
.saf-m:hover{background:var(--night-4);border-color:var(--rule-2)}
.saf-m:active{transform:scale(0.96)}
.saf-m svg{width:18px;height:18px;color:var(--lime)}
.saf-m .t{font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--ink);
  letter-spacing:-0.005em}
.saf-m .s{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);letter-spacing:0.08em;
  font-weight:500;text-transform:uppercase;line-height:1.2}
[data-theme="day"] .saf-m{background:#ffffff}

.suggest-list{display:flex;flex-direction:column;gap:8px}
.suggest-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:12px 14px;background:var(--night-3);border:1px solid var(--rule);border-radius:14px}
.suggest-row .who{display:flex;flex-direction:column;gap:3px;min-width:0}
.suggest-row .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03'}
.suggest-row .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.06em;font-weight:500;text-transform:uppercase}
.suggest-row .meta em{color:var(--lime);font-style:normal;font-weight:700}
.follow-btn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--night);background:var(--lime);padding:8px 14px;
  border-radius:var(--r-pill);transition:all .15s,transform .12s var(--ease-spring)}
.follow-btn:hover{background:var(--lime-2)}
.follow-btn:active{transform:scale(0.94)}
.follow-btn.is-on{background:var(--night-4);color:var(--lime);border:1px solid rgba(200,241,53,0.36)}
.empty{padding:24px;text-align:center;color:var(--ink-3);font-family:var(--font-serif);font-style:italic;font-size:14px}
[data-theme="day"] .suggest-row{background:#ffffff}

/* Following / followers list */
.ssl-list{display:flex;flex-direction:column;gap:8px}
.ssl-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:12px 14px;background:var(--night-3);border:1px solid var(--rule);border-radius:14px;
  text-align:left;transition:background .15s,border-color .15s,transform .12s var(--ease-spring)}
.ssl-row:hover{background:var(--night-4);border-color:var(--rule-2)}
.ssl-row:active{transform:scale(0.985)}
.ssl-row .who{display:flex;flex-direction:column;gap:3px;min-width:0}
.ssl-row .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);
  letter-spacing:-0.01em;font-feature-settings:'cv01','ss03'}
.ssl-row .meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4);
  letter-spacing:0.06em;font-weight:500;text-transform:uppercase}
.ssl-tag{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--lime);background:var(--lime-soft);padding:4px 9px;border-radius:var(--r-pill)}
[data-theme="day"] .ssl-row{background:#ffffff}

/* Course picker — active state */
.course-row.is-active{border-color:rgba(200,241,53,0.45);background:rgba(200,241,53,0.04)}
[data-theme="day"] .course-row.is-active{border-color:rgba(155,183,29,0.5);background:rgba(155,183,29,0.06)}

/* tabbar — when 6 tabs, tighten min-width and hide a hair */
.tabbar .tab{min-width:44px}
.tabbar .tab .name{font-size:9.5px}

/* ============================================================
   DAY THEME — Social tweaks
   ============================================================ */
[data-theme="day"] .post{background:transparent;box-shadow:none;border-bottom-color:var(--rule)}
[data-theme="day"] .post.is-open{background:#ffffff;box-shadow:0 1px 2px rgba(40,30,20,0.04);border-bottom-color:transparent}
[data-theme="day"] .post-holes .ph[data-r="under"]{background:var(--lime-deep)}
[data-theme="day"] .post-holes .ph[data-r="par"]{background:rgba(0,0,0,0.32)}
[data-theme="day"] .post-holes .ph[data-r="over"]{background:var(--flag)}
[data-theme="day"] .post-note em{color:var(--lime-deep)}
[data-theme="day"] .post-badge{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .post-badge.warn{color:#a87a2a;background:rgba(201,168,94,0.18)}
[data-theme="day"] .react.is-on{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .react.is-on svg{color:var(--lime-deep);stroke:var(--lime-deep);fill:rgba(155,183,29,0.18)}
[data-theme="day"] .react-cta{color:var(--lime-deep);border-color:rgba(155,183,29,0.36)}
[data-theme="day"] .react-cta:hover{background:rgba(155,183,29,0.10);border-color:var(--lime-deep)}
[data-theme="day"] .live-card{background:#ffffff}
[data-theme="day"] .live-card .thru em{color:var(--lime-deep)}
[data-theme="day"] .live-strip{padding-top:2px}
[data-theme="day"] .live-card .live-pulse{border-color:#fff}
[data-theme="day"] .lb-tabs button.is-on{background:var(--lime-deep);color:#fff;border-color:var(--lime-deep)}
[data-theme="day"] .lb-row.is-you{background:rgba(155,183,29,0.08)}
[data-theme="day"] .lb-row.is-you:hover{background:rgba(155,183,29,0.12)}
[data-theme="day"] .lb-bar i{background:linear-gradient(90deg,#7a9512,var(--lime-deep))}
[data-theme="day"] .lb-row.is-you .lb-bar i{background:linear-gradient(90deg,var(--ink),var(--lime-deep))}
[data-theme="day"] .ds-bar i{background:linear-gradient(90deg,var(--sky),var(--lime-deep))}
[data-theme="day"] .ds-row.is-you .ds-bar i{background:linear-gradient(90deg,var(--ink),var(--lime-deep))}
[data-theme="day"] .cs-row.is-you{background:rgba(155,183,29,0.06)}
[data-theme="day"] .cs-row.is-king{background:linear-gradient(90deg, rgba(201,168,94,0.14), transparent 60%)}
[data-theme="day"] .cs-king .crown{color:#a87a2a}
[data-theme="day"] .cs-king .kn{color:#8a6a32}
[data-theme="day"] .lb-course-pick{color:var(--lime-deep);border-bottom-color:rgba(155,183,29,0.36)}
[data-theme="day"] .lb-row:hover{background:#fafaf6}
[data-theme="day"] .cs-row:hover{background:#fafaf6}
[data-theme="day"] .ds-row:hover{background:#fafaf6}
[data-theme="day"] .cs-tag{color:var(--lime-deep)}
[data-theme="day"] .friend-row:hover{background:#fafaf6}
[data-theme="day"] .friend-row .meta b{color:var(--ink-2)}
[data-theme="day"] .live-tag{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .fr-actions .cmp{color:var(--lime-deep)}
[data-theme="day"] .cmp-row.lead-you .cmp-you{color:var(--lime-deep)}
[data-theme="day"] .cmp-row.lead-them .cmp-them{color:var(--sky)}
[data-theme="day"] .cmp-bar .cmp-you-fill{background:linear-gradient(270deg,var(--lime-deep),rgba(155,183,29,0.4))}
[data-theme="day"] .cs-fill.cs-you{background:linear-gradient(90deg,var(--lime-deep),var(--lime))}
[data-theme="day"] .dd-row .bar i{background:linear-gradient(90deg,#7a9512,var(--lime-deep))}
[data-theme="day"] .follow-btn{background:var(--lime-deep);color:#fff}
[data-theme="day"] .follow-btn:hover{background:#7a9512}
[data-theme="day"] .follow-btn.is-on{background:#fff;color:var(--lime-deep);border-color:rgba(155,183,29,0.36)}
[data-theme="day"] .ssl-tag{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .badge.lime{color:var(--lime-deep);background:rgba(155,183,29,0.14);
  border-color:rgba(155,183,29,0.32)}
[data-theme="day"] .friend-quick .fq{background:#ffffff}
[data-theme="day"] .soc-me-stats .cell:hover{background:#fafaf6}
[data-theme="day"] .lb-tabs button{background:#fffef8}
[data-theme="day"] .saf-methods .saf-m svg{color:var(--lime-deep)}
[data-theme="day"] .shot-card .tag{color:var(--lime-deep)}
[data-theme="day"] .shot-card .shot-trail svg{color:var(--lime-deep)}
[data-theme="day"] .score-block-sm .vs.under{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .score-pair .vs.under{color:var(--lime-deep);background:rgba(155,183,29,0.14)}
[data-theme="day"] .you-empty b{color:var(--lime-deep)}


/* ============================================================
   HERO TYPE LAYER · Instrument Serif for the giant numbers
   Brings editorial-magazine soul to the hero moments —
   158-yard distance, 7-iron result, 8.4 handicap, hole #, score.
   ============================================================ */
:root{
  --font-hero:'Instrument Serif', 'Newsreader', Georgia, serif;
}

/* the 158 — the single most important number in the whole app */
.pin-input .num{
  font-family:var(--font-hero);
  font-style:italic;
  font-weight:400;
  font-size:108px;
  line-height:0.88;
  letter-spacing:-0.045em;
  font-variation-settings:normal;
}

/* recommended club result — "7 iron" */
.result-club{
  font-family:var(--font-hero);
  font-weight:400;
  font-size:80px;
  letter-spacing:-0.04em;
  line-height:0.9;
  font-variation-settings:normal;
}
.result-club .it{font-style:italic;color:var(--lime);font-family:var(--font-hero)}

/* handicap "8.4" */
.hc-num{
  font-family:var(--font-hero);
  font-weight:400;
  font-size:72px;
  letter-spacing:-0.04em;
  line-height:0.88;
  font-variation-settings:normal;
}
.hc-num .it{font-family:var(--font-hero);font-style:italic;color:var(--lime)}

/* live round hole number */
.lr-hero .hole-num .n{
  font-family:var(--font-hero);
  font-style:italic;
  font-weight:400;
  font-size:96px;
  letter-spacing:-0.045em;
  line-height:0.88;
  font-variation-settings:normal;
}

/* live round score stepper number */
.score-stepper .num{
  font-family:var(--font-hero);
  font-weight:400;
  font-size:108px;
  letter-spacing:-0.045em;
  line-height:0.88;
  font-variation-settings:normal;
}

/* large-title h1's (Caddie / My bag / Rounds / Social / You) */
.large-title h1{
  font-family:var(--font-display);
  font-feature-settings:'ss01' on, 'cv11' on;
  /* keep Bricolage for screen titles — strong + modern. */
}

/* ============================================================
   LIVE FEEL — micro-refinements for the Apple-product feel
   ============================================================ */

/* slight text-shadow on hero numbers — gives type a soft glow against dark */
.pin-input .num,
.result-club{
  text-shadow:0 0 38px rgba(200,241,53,0.10), 0 0 80px rgba(200,241,53,0.04);
}
[data-theme="day"] .pin-input .num{
  color:var(--lime-deep);
  text-shadow:0 1px 0 rgba(255,255,255,0.5), 0 0 28px rgba(155,183,29,0.08);
}
[data-theme="day"] .result-club{text-shadow:none}
[data-theme="day"] .result-club .it{color:var(--lime-deep);font-family:var(--font-hero)}
[data-theme="day"] .hc-num .it{color:var(--lime-deep)}

/* unit "metres" sits as a small italic afterthought beside the 158 */
.pin-input .unit{
  font-family:var(--font-hero);
  font-style:italic;
  font-size:18px;
  color:var(--ink-3);
  letter-spacing:-0.01em;
  font-weight:400;
}

/* meta carry/plays under the result — friendlier */
.result-meta .carry{font-family:var(--font-sans);font-size:14px;color:var(--ink-3)}
.result-meta .carry b{font-family:var(--font-hero);font-weight:400;font-style:italic;
  color:var(--ink);font-size:18px;letter-spacing:-0.015em;margin:0 1px}

/* round-row big score number, conditions cells, club distances, mini-card holes,
   compare best-card, friend hero quick stats — bump them all to the hero face */
.round-row .score .n,
.conditions .num,
.stat-row .v,
.stat-grid .gcell .v,
.bag-hero .fig .v,
.club-row .stat .dist,
.score-pair .n,
.score-block-sm .n,
.lb-val,
.cs-king .ks,
.ds-val,
.cs-side .v,
.cmp-row .cmp-you,
.cmp-row .cmp-them,
.friend-quick .fq .v,
.bc-side .n,
.dd-row .v,
.putts-stepper .v,
.profile-hero .who .hc b,
.lr-hero .hole-info span b,
.round-row .date .d,
.feedback-thanks .h,
.thinking .copy .h,
.about-card .credit{
  font-family:var(--font-hero);
  font-variation-settings:normal;
}

/* preserve italic ones */
.profile-hero .who .hc b,
.feedback-thanks .h,
.thinking .copy .h,
.about-card .credit{font-style:italic}

/* the giant "Caddie" / "Bag" / "Rounds" / "Social" / "You" titles — keep grotesque
   but make them a touch more confident */
.large-title h1{
  font-weight:600;
  font-variation-settings:'wdth' 90,'wght' 600,'opsz' 96;
}

/* feed post score — gentler weight feels less invoice-y */
.score-block-sm .n{font-size:48px;letter-spacing:-0.035em;line-height:0.88}

/* ============================================================
   DUCK LOGO — day-mode visibility fix
   Deeper green fill + soft outline + drop-shadow so the duck reads
   on parchment. Night mode unchanged — lime on dark is perfect.
   ============================================================ */
[data-theme="day"] .duck-mark{
  filter:drop-shadow(0 1px 1px rgba(40,30,20,0.18))
         drop-shadow(0 0 0.4px rgba(40,30,20,0.32));
}
[data-theme="day"] .duck-mark path[fill="#c8f135"]{
  fill:#6a8210;
  stroke:rgba(20,30,10,0.30);
  stroke-width:0.35;
  paint-order:stroke fill;
}
[data-theme="day"] .duck-mark line[stroke="#c8f135"]:not(.arc),
[data-theme="day"] .duck-mark path[stroke="#c8f135"]:not(.arc){
  stroke:#6a8210;
}
[data-theme="day"] .duck-mark .arc{stroke:#9bb71d;opacity:0.95}
[data-theme="day"] .duck-mark .ball-tip{fill:#6a8210}
/* duck "eye" stays dark — looks like a real eye */
[data-theme="day"] .duck-mark circle[fill="#050505"]{fill:#0a0a0c}
/* the white stroke through the duck (the slice line) — make it deeper for contrast */
[data-theme="day"] .duck-mark line[stroke="#ffffff"]{stroke:#fff;opacity:0.85;
  filter:drop-shadow(0 0 0.6px rgba(0,0,0,0.6))}
[data-theme="day"] .duck-mark path[fill="#ffffff"]{fill:#fff;
  filter:drop-shadow(0 0 0.4px rgba(0,0,0,0.5))}

/* same treatment for the duck used in the About card + Ace avatar + thinking spinner */
[data-theme="day"] .about-card .duck-foot path[fill="#c8f135"],
[data-theme="day"] .ace-avatar svg path[fill="#c8f135"],
[data-theme="day"] .thinking .duck-spin svg path[fill="#c8f135"]{
  fill:#6a8210;
  stroke:rgba(20,30,10,0.28);
  stroke-width:0.32;
  paint-order:stroke fill;
}
[data-theme="day"] .about-card .duck-foot{
  filter:drop-shadow(0 1px 1px rgba(40,30,20,0.14));
}
[data-theme="day"] .ace-avatar svg,
[data-theme="day"] .thinking .duck-spin svg{
  filter:drop-shadow(0 1px 0.5px rgba(40,30,20,0.16));
}

/* brand wordmark on day mode: slice "/" + period are lime — bump contrast */
[data-theme="day"] .brand-word .bw-slash,
[data-theme="day"] .brand-word .bw-co::after{
  color:var(--lime-deep);
  text-shadow:0 0 0.3px rgba(0,0,0,0.2);
}

/* ============================================================
   "Soul" touches — tiny details Apple sweats
   ============================================================ */

/* subtle gradient pulse behind the 158 — like a green well of energy */
.distance{
  background:
    radial-gradient(360px 220px at 50% 100%, rgba(200,241,53,0.07), transparent 70%),
    radial-gradient(220px 140px at 0% 100%, rgba(74,143,92,0.16), transparent 70%),
    radial-gradient(180px 120px at 100% 0%, rgba(200,241,53,0.06), transparent 70%),
    var(--night-3);
}
[data-theme="day"] .distance{
  background:
    radial-gradient(360px 220px at 50% 100%, rgba(155,183,29,0.10), transparent 70%),
    radial-gradient(220px 140px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    var(--night-3);
}

/* caret tick on the 158 while editing — alive feeling */
.pin-input .num:focus{
  color:var(--lime-2);
  text-shadow:0 0 28px rgba(216,255,74,0.30), 0 0 64px rgba(200,241,53,0.10);
}

/* slight bump on serif numerals — old-style figures off, proportional on */
.pin-input .num,
.result-club,
.hc-num,
.score-stepper .num,
.lr-hero .hole-num .n,
.round-row .score .n,
.conditions .num,
.stat-row .v,
.stat-grid .gcell .v,
.bag-hero .fig .v,
.club-row .stat .dist,
.lb-val,
.cs-king .ks,
.ds-val,
.bc-side .n,
.dd-row .v,
.friend-quick .fq .v,
.score-pair .n,
.score-block-sm .n,
.putts-stepper .v{
  font-variant-numeric:proportional-nums lining-nums;
}

/* tabular for ledger contexts (mini scorecard hole tiles, etc.) */
.mini-card .hole .s,
.score-stepper .num,
.lr-hero .hole-num .n{
  font-variant-numeric:tabular-nums lining-nums;
}


/* ============================================================
   ADD-BY-USERNAME — first-class flow
   ============================================================ */
.my-handle{display:flex;align-items:center;gap:12px;padding:14px 16px;background:
    linear-gradient(135deg, rgba(200,241,53,0.10), rgba(200,241,53,0.02));
  border:1px solid rgba(200,241,53,0.24);border-radius:14px;margin-bottom:8px}
.my-handle .lbl{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.14em;font-weight:700;text-transform:uppercase;flex-shrink:0}
.my-handle .hand{font-family:var(--font-display);font-weight:700;font-size:18px;
  letter-spacing:-0.02em;color:var(--ink);flex:1;display:inline-flex;align-items:baseline}
.my-handle .hand .at{color:var(--lime);margin-right:1px}
.copy-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;
  background:var(--night-4);border:1px solid var(--rule);border-radius:var(--r-pill);
  color:var(--ink-2);font-family:var(--font-mono);font-size:11px;font-weight:700;
  letter-spacing:0.08em;text-transform:uppercase;transition:all .15s,transform .12s var(--ease-spring)}
.copy-btn svg{width:12px;height:12px;color:var(--ink-3);transition:color .15s}
.copy-btn:hover{background:var(--night-5);color:var(--ink)}
.copy-btn:hover svg{color:var(--lime)}
.copy-btn:active{transform:scale(0.95)}
.copy-btn.is-on{background:var(--lime);color:var(--night);border-color:var(--lime)}
.copy-btn.is-on svg{color:var(--night)}
[data-theme="day"] .my-handle{
  background:linear-gradient(135deg, rgba(155,183,29,0.14), rgba(155,183,29,0.03));
  border-color:rgba(155,183,29,0.36)}
[data-theme="day"] .my-handle .hand .at{color:var(--lime-deep)}
[data-theme="day"] .copy-btn{background:#fff}
[data-theme="day"] .copy-btn:hover{background:#fafaf6}
[data-theme="day"] .copy-btn:hover svg{color:var(--lime-deep)}
[data-theme="day"] .copy-btn.is-on{background:var(--lime-deep);color:#fff;border-color:var(--lime-deep)}
[data-theme="day"] .copy-btn.is-on svg{color:#fff}

.my-handle-hint{font-size:11px;color:var(--ink-4);letter-spacing:-0.005em;
  padding:0 4px 12px;font-weight:500}

/* search-bar refined for @ usernames */
.search-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--night-3);
  border:1px solid var(--rule);border-radius:12px;margin-bottom:12px;
  transition:border-color .15s,background .15s}
.search-bar:focus-within{border-color:rgba(200,241,53,0.40);background:var(--night-4)}
.search-bar .at-prefix{font-family:var(--font-display);font-weight:700;font-size:18px;
  color:var(--lime);line-height:1;letter-spacing:-0.02em}
.search-bar input{flex:1;font-size:15px;color:var(--ink);letter-spacing:-0.005em;
  height:26px;font-family:var(--font-sans);font-weight:500}
.search-bar input::placeholder{color:var(--ink-4);font-weight:400}
[data-theme="day"] .search-bar:focus-within{border-color:rgba(155,183,29,0.45);background:#fffef8}
[data-theme="day"] .search-bar .at-prefix{color:var(--lime-deep)}

/* live lookup result */
.lookup-result{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;
  animation:lookupIn .35s var(--ease-out) both}
@keyframes lookupIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.lookup-result .lookup-head{font-family:var(--font-mono);font-size:9px;color:var(--ink-4);
  letter-spacing:0.14em;font-weight:700;text-transform:uppercase;padding:2px 4px}
.lookup-result .lookup-head .lbl{color:var(--ink-3)}
.lookup-result .suggest-row.is-exact{border-color:rgba(200,241,53,0.45);
  background:linear-gradient(135deg, rgba(200,241,53,0.08), rgba(200,241,53,0.01));
  box-shadow:0 0 0 3px rgba(200,241,53,0.06)}
[data-theme="day"] .lookup-result .suggest-row.is-exact{
  border-color:rgba(155,183,29,0.5);
  background:linear-gradient(135deg, rgba(155,183,29,0.10), rgba(155,183,29,0.02));
  box-shadow:0 0 0 3px rgba(155,183,29,0.08)}

.ok-tick{display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:14px;border-radius:50%;background:var(--lime);color:var(--night);
  font-size:9px;font-weight:700;margin-left:5px;vertical-align:1px}
[data-theme="day"] .ok-tick{background:var(--lime-deep);color:#fff}

/* unknown handle → invite */
.lookup-empty{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
  padding:12px 14px;background:var(--night-3);border:1px dashed var(--rule-2);border-radius:14px}
.av-empty{background:var(--night-5)!important;color:var(--ink-4)!important}
.lookup-empty .who{display:flex;flex-direction:column;gap:3px;min-width:0}
.lookup-empty .nm{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--ink);
  letter-spacing:-0.005em}
.lookup-empty .meta{font-size:11px;color:var(--ink-4);letter-spacing:-0.005em;font-weight:500}
.invite-btn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--ink);background:var(--night-4);padding:8px 14px;
  border-radius:var(--r-pill);border:1px solid var(--rule-2);
  transition:all .15s,transform .12s var(--ease-spring)}
.invite-btn:hover{background:var(--night-5);border-color:var(--lime);color:var(--lime)}
.invite-btn:active{transform:scale(0.94)}
.invite-btn.is-on{background:var(--lime);color:var(--night);border-color:var(--lime);pointer-events:none}
[data-theme="day"] .lookup-empty{background:#fafaf6}
[data-theme="day"] .invite-btn{background:#fff}
[data-theme="day"] .invite-btn:hover{color:var(--lime-deep);border-color:var(--lime-deep)}
[data-theme="day"] .invite-btn.is-on{background:var(--lime-deep);color:#fff;border-color:var(--lime-deep)}


/* ============================================================
   Caddie complication — Direction C (committed)
   The 158 framed by a 240° dial; wind notch, value pip, pin mark
   ============================================================ */
.complication{
  padding:18px 14px 14px;
  background:
    radial-gradient(200px 200px at 50% 46%, rgba(200,241,53,0.22), rgba(200,241,53,0.06) 55%, transparent 75%),
    radial-gradient(380px 300px at 50% 30%, rgba(200,241,53,0.10), transparent 65%),
    radial-gradient(300px 200px at 50% 100%, rgba(74,143,92,0.14), transparent 72%),
    linear-gradient(180deg, #14181f 0%, #0c0f12 100%);
  border-radius:18px;border:1px solid var(--rule);position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.05) inset, 0 20px 48px -22px rgba(0,0,0,0.6);
}
.complication .comp-head{
  display:flex;justify-content:space-between;align-items:baseline;padding:0 6px 4px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-3);font-weight:600;
}
.complication .comp-head .l b{color:var(--lime)}
.complication .comp-head .unit-toggle{padding:2px}
.complication .dial-stage{
  position:relative;width:100%;aspect-ratio:1;max-width:320px;margin:4px auto 0;
}
.complication .dial-stage svg{width:100%;height:100%;display:block;overflow:visible}
.complication .dial-readout{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:2px;pointer-events:none;
}
.complication .dial-readout .num{
  font-family:var(--font-display);font-weight:700;
  font-variation-settings:'wdth' 82,'wght' 700,'opsz' 96;
  font-size:108px;line-height:0.84;letter-spacing:-0.05em;
  font-variant-numeric:tabular-nums;color:var(--ink);
  outline:0;cursor:text;
  text-shadow:0 0 56px rgba(200,241,53,0.14);
}
.complication .dial-readout .num:focus{color:var(--lime-2);text-shadow:0 0 48px rgba(200,241,53,0.32)}
.complication .dial-readout .unit{
  font-family:var(--font-serif,'Newsreader');font-style:italic;font-weight:400;
  font-size:18px;color:var(--ink-2);letter-spacing:-0.01em;margin-top:-2px;
  font-variation-settings:'opsz' 72;
}
.complication .dial-readout .plays{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.28em;text-transform:uppercase;color:var(--ink-3);
  margin-top:8px;font-weight:600;
  display:inline-flex;align-items:baseline;gap:4px;
}
.complication .dial-readout .plays em{
  font-family:var(--font-num);font-style:normal;font-weight:700;font-size:13px;
  color:var(--lime);letter-spacing:-0.02em;text-transform:none;
  font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums;
}
.complication .below-dial{
  margin-top:6px;padding:14px 10px 4px;display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--rule);
}
.complication .below-dial .c{
  padding:0 10px;position:relative;display:flex;flex-direction:column;gap:5px;
}
.complication .below-dial .c + .c::before{
  content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--rule);
}
.complication .below-dial .k{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-4);display:flex;align-items:center;gap:5px;font-weight:600;
}
.complication .below-dial .k::before{
  content:"";width:5px;height:5px;border-radius:50%;background:currentColor;
}
.complication .below-dial .v{
  font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-0.02em;
  font-variant-numeric:tabular-nums;color:var(--ink);
}
.complication .below-dial .v em{
  font-family:var(--font-mono);font-style:normal;font-weight:500;font-size:0.5em;
  color:var(--lime);margin-left:3px;letter-spacing:0.04em;text-transform:lowercase;
}
.complication .below-dial .c.wind .k{color:var(--sky,#6db9ff)}
.complication .below-dial .c.elev .k{color:var(--dusk,#f0c879)}
.complication .below-dial .c.air .k{color:var(--violet,#b78dff)}

/* Day-theme parity */
[data-theme="day"] .complication{
  background:
    radial-gradient(200px 200px at 50% 46%, rgba(155,183,29,0.30), rgba(155,183,29,0.08) 55%, transparent 75%),
    radial-gradient(380px 300px at 50% 30%, rgba(155,183,29,0.16), transparent 65%),
    radial-gradient(300px 200px at 50% 100%, rgba(58,138,76,0.14), transparent 72%),
    #ffffff;
}
[data-theme="day"] .complication .dial-readout .num{color:var(--ink);text-shadow:0 1px 0 rgba(255,255,255,0.6), 0 0 28px rgba(155,183,29,0.18)}
[data-theme="day"] .complication .dial-readout .num:focus{color:var(--lime-deep)}
[data-theme="day"] .complication .dial-readout .unit{color:rgba(42,38,24,0.7)}
[data-theme="day"] .complication .dial-readout .plays em{color:var(--lime-deep)}
[data-theme="day"] .complication .below-dial .v em{color:var(--lime-deep)}
[data-theme="day"] .complication svg [stroke="rgba(255,255,255,0.32)"]{stroke:rgba(42,38,24,0.32) !important}
[data-theme="day"] .complication svg [stroke="rgba(255,255,255,0.08)"]{stroke:rgba(42,38,24,0.12) !important}
[data-theme="day"] .complication svg text[fill*="255,255,255"]{fill:rgba(42,38,24,0.55) !important}
[data-theme="day"] .complication svg [fill="#c8f135"]{fill:var(--lime-deep)}
[data-theme="day"] .complication svg [stroke="#c8f135"]{stroke:var(--lime-deep) !important}

/* Subtle slow breathing on the focal pip · the data is 'live' */
@keyframes dialPipBreathe {
  0%,100% { stroke-opacity:0.14; }
  50%     { stroke-opacity:0.34; }
}
@keyframes dialPipBreatheInner {
  0%,100% { stroke-opacity:0.34; }
  50%     { stroke-opacity:0.6; }
}
.complication .dial-pip:nth-of-type(odd){ animation:dialPipBreathe 3.4s ease-in-out infinite }
.complication .dial-pip:nth-of-type(even){ animation:dialPipBreatheInner 3.4s ease-in-out infinite }
.complication .dial-value-arc{ /* no animation — let the pip carry the life */ }


/* ============================================================
   POST-ROUND SUMMARY  (new pane #pane-summary)
   ============================================================ */
.summary-screen{font-family:var(--font-display);position:relative}
.summary-screen .sum-head{padding:6px 0 0;text-align:center}
.summary-screen .sum-head .crumb{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--lime);font-weight:600;
}
.summary-screen .sum-head .h{
  margin-top:10px;font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:38px;line-height:1.0;letter-spacing:-0.02em;color:var(--ink);
  font-variation-settings:'opsz' 72;
}
.summary-screen .sum-head .h b{
  font-style:normal;font-family:var(--font-display);font-weight:700;
  font-variation-settings:'wdth' 88,'wght' 700;color:var(--ink);
}

.summary-screen .score-block{
  padding:20px 4px 8px;text-align:center;position:relative;
}
.summary-screen .score-block .lbl{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.summary-screen .score-block .n{
  font-family:var(--font-display);font-weight:700;font-size:188px;line-height:0.84;letter-spacing:-0.06em;
  font-variation-settings:'wdth' 80,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;
  background:linear-gradient(180deg, var(--ink), color-mix(in oklab, var(--ink) 50%, transparent));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
  margin-top:-4px;
}
.summary-screen .score-block .vs{
  display:inline-flex;align-items:baseline;gap:8px;
  font-family:var(--font-num);font-style:normal;font-weight:700;font-size:20px;color:var(--lime);letter-spacing:-0.025em;
  font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;
}
.summary-screen .score-block .vs b{
  font-style:normal;font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-3);font-weight:600;
}

.summary-screen .mid-strip{
  margin:18px 0 4px;padding:14px 0;display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.summary-screen .mid-strip .c{padding:0 10px;display:flex;flex-direction:column;gap:3px;position:relative}
.summary-screen .mid-strip .c + .c::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--rule)}
.summary-screen .mid-strip .k{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-4);font-weight:600;
}
.summary-screen .mid-strip .v{
  font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-0.025em;font-variant-numeric:tabular-nums;color:var(--ink);
}
.summary-screen .mid-strip .v small{
  font-family:var(--font-mono);font-weight:500;font-size:10px;color:var(--ink-3);letter-spacing:0.04em;margin-left:3px;
}

.summary-screen .holes-row{
  padding:14px 0 6px;display:flex;justify-content:space-between;align-items:flex-end;gap:3px;
}
.summary-screen .holes-row .h{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.05em;color:var(--ink-4);
}
.summary-screen .holes-row .h .bar{
  width:100%;height:44px;border-radius:3px;background:var(--rule);position:relative;
}
.summary-screen .holes-row .h .bar i{
  display:block;position:absolute;left:0;right:0;bottom:0;border-radius:3px;background:var(--ink-4);
}
.summary-screen .holes-row .h.under .bar i{background:var(--lime)}
.summary-screen .holes-row .h.even .bar i{background:var(--ink-3)}
.summary-screen .holes-row .h.over .bar i{background:var(--flag,#ff6b4a);opacity:0.7}
.summary-screen .holes-row .h.way-over .bar i{background:var(--flag,#ff6b4a)}
.summary-screen .holes-row .h .num{font-weight:500}

.summary-screen .holes-legend{
  display:flex;justify-content:space-between;padding:4px 2px 0;
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-4);
}

.summary-screen .moments{
  padding:18px 0 0;display:flex;flex-direction:column;gap:10px;
}
.summary-screen .moments-head{
  display:flex;justify-content:space-between;align-items:baseline;padding-bottom:6px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.summary-screen .moment{
  display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:12px;
  padding:12px 14px;border-radius:14px;border:1px solid var(--rule);background:var(--night-3);
}
.summary-screen .moment .gly{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-size:16px;font-weight:600;
  background:rgba(200,241,53,0.10);color:var(--lime);border:1px solid rgba(200,241,53,0.22);
}
.summary-screen .moment.tough .gly{background:rgba(255,107,74,0.10);color:var(--flag,#ff6b4a);border-color:rgba(255,107,74,0.22)}
.summary-screen .moment .mid .k{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.summary-screen .moment .mid .v{
  font-family:var(--font-serif);font-style:italic;font-size:17px;color:var(--ink);letter-spacing:-0.01em;line-height:1.25;margin-top:2px;
  font-variation-settings:'opsz' 72;
}
.summary-screen .moment .mid .v b{
  font-style:normal;font-family:var(--font-display);font-weight:700;
  font-variation-settings:'wdth' 88,'wght' 700;
}
.summary-screen .moment .r{
  font-family:var(--font-mono);font-size:11px;color:var(--ink-3);letter-spacing:0.04em;font-variant-numeric:tabular-nums;
}

.summary-screen .summary-actions{
  margin-top:22px;display:flex;flex-direction:column;gap:8px;
}
.summary-screen .summary-actions .primary{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:16px 22px;border-radius:var(--r-pill);background:var(--ink);color:var(--night);
  font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:-0.005em;border:0;cursor:pointer;
  transition:transform .12s var(--ease-out);
}
.summary-screen .summary-actions .primary:active{transform:scale(0.985)}
.summary-screen .summary-actions .primary .arr{font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em}
.summary-screen .summary-actions .ghost{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:12px;border-radius:var(--r-pill);
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-3);background:transparent;border:0;cursor:pointer;
}

[data-theme="day"] .summary-screen .moment{background:#faf6e6;border-color:rgba(42,38,24,0.08)}
[data-theme="day"] .summary-screen .summary-actions .primary{background:var(--ink);color:#faf6e6}
[data-theme="day"] .summary-screen .score-block .n{
  background:linear-gradient(180deg, var(--ink), color-mix(in oklab, var(--ink) 30%, transparent));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}


/* ============================================================
   EDITORIAL HANDICAP POSTER (Rounds tab)
   ============================================================ */
.hc-poster{
  padding:22px 22px 18px;border-radius:18px;
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(200,241,53,0.08), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(74,143,92,0.10), transparent 70%),
    var(--night-3);
  border:1px solid var(--rule);position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 18px 40px -22px rgba(0,0,0,0.55);
}
.hc-poster .hd{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;
}
.hc-poster .hd .lbl{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;line-height:1.6;
}
.hc-poster .hd .lbl b{display:block;color:var(--ink-2);letter-spacing:0.18em;font-weight:600;margin-top:4px}
.hc-poster .hd .delta{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.10em;color:var(--lime);font-weight:600;
  padding:5px 10px;border-radius:var(--r-pill);
  border:1px solid rgba(200,241,53,0.22);background:rgba(200,241,53,0.06);
}
.hc-poster .num-block{
  margin:8px 0 6px;display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
}
.hc-poster .num{
  font-family:var(--font-num);font-style:normal;font-weight:700;
  font-size:140px;line-height:0.86;letter-spacing:-0.05em;color:var(--ink);
  font-variation-settings:'wdth' 80,'wght' 700,'opsz' 96;font-variant-numeric:tabular-nums;
  margin-left:-4px;
}
.hc-poster .num em{font-style:normal;color:var(--lime);font-weight:700;text-shadow:0 0 40px rgba(200,241,53,0.36)}
.hc-poster .sm-meta{
  display:flex;flex-direction:column;gap:4px;text-align:right;padding-bottom:14px;
}
.hc-poster .sm-meta .k{font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-4);font-weight:600}
.hc-poster .sm-meta .v{font-family:var(--font-display);font-weight:600;font-size:20px;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;color:var(--ink)}
.hc-poster .sm-meta .v em{font-family:var(--font-num);font-style:normal;font-weight:700;font-size:0.72em;color:var(--lime);margin-left:3px;font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums}

.hc-poster .chart{margin-top:6px;display:block;width:100%;height:80px}
.hc-poster .chart-meta{
  display:flex;justify-content:space-between;padding-top:8px;
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-4);font-weight:600;
}
.hc-poster .chart-meta b{color:var(--lime);font-weight:600}

[data-theme="day"] .hc-poster{
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(155,183,29,0.16), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    #ffffff;
}
[data-theme="day"] .hc-poster .num em{color:var(--lime-deep)}
[data-theme="day"] .hc-poster .sm-meta .v em{color:var(--lime-deep)}
[data-theme="day"] .hc-poster .delta{color:var(--lime-deep);background:rgba(155,183,29,0.08);border-color:rgba(155,183,29,0.28)}


/* ============================================================
   MISS-PATTERN COMPASS (You tab)
   ============================================================ */
.miss-card{
  padding:18px;border-radius:18px;
  background:var(--night-3);border:1px solid var(--rule);
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 18px 40px -22px rgba(0,0,0,0.55);
}
.miss-card .hd{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.miss-card .hd .k{font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.miss-card .hd .k b{color:var(--ink)}
.miss-card .hd .meta{font-family:var(--font-serif);font-style:italic;font-size:14px;color:var(--ink-3);font-variation-settings:'opsz' 36}
.miss-card .body{display:grid;grid-template-columns:1fr 1.05fr;gap:14px;align-items:center}
.miss-card svg{width:100%;height:auto;display:block}
.miss-card .breakdown{display:flex;flex-direction:column;gap:8px}
.miss-card .row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.08em;color:var(--ink-3);
}
.miss-card .row .sw{width:8px;height:8px;border-radius:50%;flex:0 0 8px}
.miss-card .row .lbl{text-transform:uppercase;letter-spacing:0.14em;color:var(--ink-3)}
.miss-card .row .pct{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}

[data-theme="day"] .miss-card{background:#ffffff;border-color:rgba(42,38,24,0.08)}
[data-theme="day"] .miss-card svg [stroke*="255,255,255"]{stroke:rgba(42,38,24,0.16) !important}
[data-theme="day"] .miss-card svg [fill*="255,255,255"]{fill:rgba(42,38,24,0.4) !important}
[data-theme="day"] .miss-card svg [fill="#c8f135"]{fill:var(--lime-deep)}


/* ============================================================
   ROUND-ROW editorial bump (Recent rounds list)
   ============================================================ */
.round-row .info .course{
  font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:17px;
  letter-spacing:-0.01em;color:var(--ink);font-variation-settings:'opsz' 72;line-height:1.2;
}
.round-row .info .course b{
  font-style:normal;font-family:var(--font-display);font-weight:600;
  font-variation-settings:'wdth' 92,'wght' 600;color:var(--ink);letter-spacing:-0.02em;
}


/* ============================================================
   BAG · Layout A · Premium hero stack (committed)
   ============================================================ */
.bag-pane{position:relative}
/* B6 · de-table top strip — soft surface card, radius, more air */
.bag-top-strip{
  padding:16px 4px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:var(--night-3);border:1px solid var(--rule);border-radius:14px;margin-bottom:18px;
}
.bag-top-strip .c{padding:0 12px;position:relative;display:flex;flex-direction:column;gap:6px}
.bag-top-strip .c + .c::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--rule)}
.bag-top-strip .k{font-family:var(--font-mono);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-4);font-weight:600}
.bag-top-strip .v{font-family:var(--font-num);font-weight:700;font-size:22px;letter-spacing:-0.025em;color:var(--ink);
  font-variant-numeric:tabular-nums;font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72}
.bag-top-strip .v small{font-family:var(--font-mono);font-weight:500;font-size:10px;color:var(--ink-3);margin-left:3px;letter-spacing:0.04em;text-transform:lowercase}
[data-theme="day"] .bag-top-strip{background:#ffffff}

/* B6 · group marks — more air, softer */
.bag-group-mark{
  display:flex;justify-content:space-between;align-items:baseline;padding:18px 2px 8px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.bag-group-mark b{color:var(--ink);font-weight:600}
.bag-group-mark .r{color:var(--ink-4)}
.bag-group-mark:first-child{padding-top:6px}

/* ── B0 · ONE premium club-card spec (collapsed from 3 stacked defs) ── */
.club-stack{display:flex;flex-direction:column;gap:10px}
.club-card{
  padding:16px 16px 14px;border-radius:16px;
  background:linear-gradient(180deg, #14181f 0%, #0c0f12 100%);
  border:1px solid var(--rule);position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.05) inset, 0 18px 36px -22px rgba(0,0,0,0.6);
  display:grid;grid-template-columns:44px 1fr auto;grid-template-rows:auto auto auto;
  gap:0 14px;align-items:start;min-height:56px;
  cursor:pointer;transition:transform .15s var(--ease-out), border-color .2s, box-shadow .2s;
}
.club-card:hover{border-color:var(--rule-2)}
/* B5 · active press + focus ring */
.club-card:active{transform:scale(0.975)}
.club-card:focus-visible{outline:none;box-shadow:0 0 0 2px var(--night), 0 0 0 4px var(--lime)}
.club-card.is-most{
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(200,241,53,0.10), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(74,143,92,0.10), transparent 70%),
    linear-gradient(180deg, #161a14 0%, #0d100c 100%);
  border-color:rgba(200,241,53,0.22);
  box-shadow:0 1px 0 rgba(200,241,53,0.08) inset, 0 0 0 1px rgba(200,241,53,0.10) inset, 0 18px 36px -22px rgba(0,0,0,0.7);
}
.club-card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.10), transparent);
  pointer-events:none;
}
/* B3 · monochrome category glyph (colour-blind safe; lime only on hero) */
.club-card .icon-box{
  grid-row:1 / span 2;grid-column:1;width:44px;height:44px;border-radius:11px;
  background:rgba(255,255,255,0.04);border:1px solid var(--rule);
  display:flex;align-items:center;justify-content:center;color:var(--ink-3);
}
.club-card .icon-box svg{width:28px;height:28px}
.club-card.is-most .icon-box{background:rgba(200,241,53,0.10);border-color:rgba(200,241,53,0.22);color:var(--lime)}
.club-card .head{grid-row:1;grid-column:2;display:flex;flex-direction:column;gap:1px}
/* B1 · type scale */
.club-card .head .nm,.club-card .nm{
  font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-0.02em;
  font-variation-settings:'wdth' 92,'wght' 700;color:var(--ink);
}
.club-card .head .nm em,.club-card .nm em{
  font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--ink-3);
  font-size:0.85em;margin-left:4px;font-variation-settings:'opsz' 72;letter-spacing:-0.015em;
}
.club-card .head .sub,.club-card .sub{
  font-family:var(--font-sans);font-style:italic;font-weight:400;font-size:11px;
  text-transform:none;letter-spacing:-0.005em;color:var(--ink-3);
}
.club-card .pin{
  grid-row:1;grid-column:3;display:flex;align-items:center;gap:5px;padding-top:4px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-4);font-weight:600;
}
.club-card.is-most .pin{color:var(--lime)}
.club-card .dist{
  grid-row:2;grid-column:1 / -1;display:flex;align-items:baseline;justify-content:space-between;
  margin-top:8px;padding-top:8px;border-top:1px solid var(--rule);
}
.club-card .dist .n{
  font-family:var(--font-num);font-weight:700;font-size:40px;line-height:0.88;letter-spacing:-0.04em;
  font-variation-settings:'wdth' 84,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;color:var(--ink);
}
.club-card.is-most .dist .n{font-size:56px;line-height:0.86;text-shadow:0 0 36px rgba(200,241,53,0.32)}
.club-card .dist .u{
  font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:13px;color:var(--ink-3);
  font-variation-settings:'opsz' 36;letter-spacing:-0.01em;margin-left:2px;
}
/* B2 · arc backdrop visible on ALL cards */
.club-card .arc-bg{
  display:block;position:absolute;right:-4px;bottom:6px;width:96px;height:54px;
  opacity:0.22;pointer-events:none;
}
.club-card.is-most .arc-bg{opacity:0.6}
/* B4 · used caption */
.club-card .used{
  grid-row:1;grid-column:3;font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:11px;color:var(--ink-4);letter-spacing:-0.005em;
}
.club-card .foot{
  grid-row:3;grid-column:1 / -1;margin-top:12px;padding-top:10px;border-top:1px solid var(--rule);
  display:none;grid-template-columns:repeat(3,1fr);gap:0;
}
.club-card.is-most .foot{display:grid}
.club-card .foot .c{padding:0 10px;position:relative;display:flex;flex-direction:column;gap:3px}
.club-card .foot .c:first-child{padding-left:0}
.club-card .foot .c:last-child{padding-right:0}
.club-card .foot .c + .c::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--rule)}
.club-card .foot .k{font-family:var(--font-mono);font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-4);font-weight:600}
.club-card .foot .v{font-family:var(--font-num);font-weight:700;font-size:14px;letter-spacing:-0.02em;
  font-variation-settings:'wdth' 92,'wght' 700;font-variant-numeric:tabular-nums;color:var(--ink)}
.club-card .foot .v small{font-family:var(--font-mono);font-weight:500;font-size:9px;color:var(--ink-3);margin-left:2px;letter-spacing:0.04em;text-transform:lowercase}

.bag-build-card{
  margin-top:14px;padding:22px 20px;border-radius:18px;
  border:1px dashed var(--rule-2);background:transparent;width:100%;
  display:flex;align-items:center;justify-content:space-between;gap:14px;color:var(--ink);cursor:pointer;
  transition:border-color .2s, background .2s, transform .12s var(--ease-out);
}
.bag-build-card:hover{border-color:rgba(200,241,53,0.3);background:rgba(200,241,53,0.02)}
.bag-build-card:active{transform:scale(0.99)}
.bag-build-card .l{display:flex;flex-direction:column;gap:4px;text-align:left}
.bag-build-card .l .k{font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--lime);font-weight:600}
.bag-build-card .l .v{font-family:var(--font-serif);font-style:italic;font-size:20px;line-height:1.2;letter-spacing:-0.01em;color:var(--ink);font-variation-settings:'opsz' 72}
.bag-build-card .l .v b{font-style:normal;font-family:var(--font-display);font-weight:700;font-variation-settings:'wdth' 88,'wght' 700}
.bag-build-card .arr{
  width:44px;height:44px;border-radius:50%;background:rgba(200,241,53,0.10);color:var(--lime);
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(200,241,53,0.22);flex:0 0 44px;
}

/* ── Bag empty hero card (paintBagEmpty → .bag-empty) ── */
.bag-empty{
  margin-top:14px;padding:40px 24px;border-radius:16px;
  background:
    radial-gradient(280px 200px at 50% 0%, rgba(200,241,53,0.08), transparent 70%),
    var(--night-3);
  border:1px solid var(--rule);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.bag-empty .be-icon{
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:rgba(200,241,53,0.10);border:1px solid rgba(200,241,53,0.22);color:var(--lime);
  margin-bottom:10px;
}
.bag-empty .be-icon svg{width:30px;height:30px}
.bag-empty .be-title{font-family:var(--font-sans);font-weight:600;font-size:15px;letter-spacing:-0.01em;color:var(--ink)}
.bag-empty .be-sub{font-family:var(--font-sans);font-size:13px;color:var(--ink-3);letter-spacing:-0.005em;line-height:1.45;max-width:30ch}
.bag-empty .acts{display:flex;flex-direction:column;gap:8px;width:100%;max-width:280px;margin-top:14px}
#bag-empty-add{
  font-family:var(--font-sans);font-weight:600;font-size:14px;letter-spacing:-0.005em;
  background:var(--lime);color:var(--night);padding:12px 18px;border-radius:var(--r-pill);width:100%;
  transition:transform .12s var(--ease-spring),background .15s;
}
#bag-empty-add:hover{background:var(--lime-2)}
#bag-empty-add:active{transform:scale(0.97)}
#bag-empty-quickset{
  font-family:var(--font-sans);font-weight:600;font-size:13px;letter-spacing:-0.005em;
  background:transparent;color:var(--lime);padding:10px 18px;border-radius:var(--r-pill);width:100%;
  border:1px solid rgba(200,241,53,0.36);transition:transform .12s var(--ease-spring),background .15s;
}
#bag-empty-quickset:hover{background:var(--lime-soft)}
#bag-empty-quickset:active{transform:scale(0.97)}
[data-theme="day"] .bag-empty{background:radial-gradient(280px 200px at 50% 0%, rgba(155,183,29,0.10), transparent 70%),#ffffff}
[data-theme="day"] .bag-empty .be-icon{background:rgba(155,183,29,0.10);border-color:rgba(155,183,29,0.30);color:var(--lime-deep)}
[data-theme="day"] #bag-empty-add{background:var(--lime-deep);color:#fff}
[data-theme="day"] #bag-empty-quickset{color:var(--lime-deep);border-color:rgba(155,183,29,0.36)}

/* Day theme parity */
[data-theme="day"] .club-card{
  background:linear-gradient(180deg, #ffffff 0%, #faf8f0 100%);border-color:rgba(42,38,24,0.08);
  box-shadow:0 1px 0 rgba(255,255,255,0.6) inset, 0 18px 36px -24px rgba(42,38,24,0.18);
}
[data-theme="day"] .club-card.is-most{
  background:
    radial-gradient(280px 200px at 100% 0%, rgba(155,183,29,0.16), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    #ffffff;
  border-color:rgba(155,183,29,0.32);
}
[data-theme="day"] .club-card .icon-box{background:rgba(42,38,24,0.04);border-color:rgba(42,38,24,0.08)}
[data-theme="day"] .club-card.is-most .icon-box{background:rgba(155,183,29,0.10);border-color:rgba(155,183,29,0.30);color:var(--lime-deep)}
[data-theme="day"] .club-card.is-most .pin{color:var(--lime-deep)}
[data-theme="day"] .bag-build-card{border-color:rgba(42,38,24,0.16)}
[data-theme="day"] .bag-build-card .arr{background:rgba(155,183,29,0.10);color:var(--lime-deep);border-color:rgba(155,183,29,0.30)}
[data-theme="day"] .bag-build-card .l .k{color:var(--lime-deep)}


/* ============================================================
   WELCOME / ONBOARDING — full-bleed overlay, shown once
   ============================================================ */
.welcome-screen{
  position:absolute;inset:0;z-index:30;
  background:
    radial-gradient(120% 70% at 50% -10%, #1a201d 0%, #06080a 65%),
    var(--night);
  color:var(--ink);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:transform .55s var(--ease-out), opacity .35s ease-out;
}
.welcome-screen.is-hidden{display:none}
.welcome-screen.is-dismissed{transform:translateY(-110%);opacity:0;pointer-events:none}
.welcome-screen .bg-grid{
  position:absolute;inset:0;pointer-events:none;opacity:0.5;
  background-image:
    linear-gradient(to right, rgba(200,241,53,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(200,241,53,0.045) 1px, transparent 1px);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(70% 65% at 50% 45%, black 30%, transparent 75%);
          mask-image:radial-gradient(70% 65% at 50% 45%, black 30%, transparent 75%);
}
.welcome-screen .welcome-mark{
  padding:60px 26px 0;display:flex;justify-content:space-between;align-items:baseline;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
  position:relative;z-index:2;
}
.welcome-screen .welcome-mark b{color:var(--lime);font-weight:600}
.welcome-screen .welcome-body{
  flex:1;padding:0 26px;display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;z-index:2;
}
.welcome-screen .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.28em;text-transform:uppercase;color:var(--lime);font-weight:600;
}
.welcome-screen .eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime)}
.welcome-screen .headline{
  margin-top:16px;font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:62px;line-height:0.92;letter-spacing:-0.035em;color:var(--ink);
  font-variation-settings:'opsz' 144;
}
.welcome-screen .headline b{
  font-style:normal;font-family:var(--font-display);font-weight:800;
  font-variation-settings:'wdth' 78,'wght' 800;color:var(--lime);
  letter-spacing:-0.045em;
}
.welcome-screen .sub{
  margin-top:18px;padding-bottom:18px;
  font-family:var(--font-serif);font-style:italic;font-size:16px;line-height:1.4;color:var(--ink-2);letter-spacing:-0.005em;
  border-bottom:1px solid var(--rule-2);
}
.welcome-screen .roles{margin-top:12px;display:flex;flex-direction:column}
.welcome-screen .role{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;
  padding:14px 4px;border-bottom:1px solid var(--rule);
  background:transparent;border-left:0;border-right:0;border-top:0;
  font:inherit;color:inherit;cursor:pointer;text-align:left;
  transition:transform .12s var(--ease-out);
}
.welcome-screen .role:last-child{border-bottom:0}
.welcome-screen .role:active{transform:scale(0.99)}
.welcome-screen .role .n{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;color:var(--ink-4);font-weight:600;width:22px;
}
.welcome-screen .role .t{
  font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:22px;letter-spacing:-0.015em;color:var(--ink);
  font-variation-settings:'opsz' 72;
}
.welcome-screen .role .t i{font-style:italic}
.welcome-screen .role .t b{
  font-style:normal;font-family:var(--font-display);font-weight:700;
  font-variation-settings:'wdth' 88,'wght' 700;color:var(--ink);
}
.welcome-screen .role .arr{
  width:34px;height:34px;border-radius:50%;border:1px solid var(--rule-2);
  display:flex;align-items:center;justify-content:center;color:var(--ink-3);
  font-family:var(--font-mono);font-size:11px;font-weight:700;
}
.welcome-screen .role.is-on .t b{color:var(--lime)}
.welcome-screen .role.is-on .arr{background:var(--lime);color:var(--night);border-color:transparent}

.welcome-screen .welcome-cta{
  margin:18px 26px 36px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:18px 22px;border-radius:var(--r-pill);background:var(--ink);color:var(--night);
  font-family:var(--font-display);font-weight:700;font-size:16px;letter-spacing:-0.005em;border:0;cursor:pointer;
  position:relative;z-index:2;transition:transform .12s var(--ease-out);
}
.welcome-screen .welcome-cta:active{transform:scale(0.985)}
.welcome-screen .welcome-cta i{font-family:var(--font-serif);font-style:italic;font-weight:400;margin-left:4px}
.welcome-screen .welcome-cta .arr{font-family:var(--font-mono);font-size:11px;letter-spacing:0.18em}

[data-theme="day"] .welcome-screen{
  background:radial-gradient(120% 70% at 50% -10%, #ece7d6 0%, #ddd5be 65%), #ddd5be;
}
[data-theme="day"] .welcome-screen .welcome-cta{background:var(--ink);color:#faf6e6}
[data-theme="day"] .welcome-screen .bg-grid{
  background-image:
    linear-gradient(to right, rgba(122,149,18,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(122,149,18,0.06) 1px, transparent 1px);
}
[data-theme="day"] .welcome-screen .role.is-on .t b{color:var(--lime-deep)}
[data-theme="day"] .welcome-screen .role.is-on .arr{background:var(--lime-deep);color:#faf6e6}
[data-theme="day"] .welcome-screen .eyebrow{color:var(--lime-deep)}
[data-theme="day"] .welcome-screen .eyebrow .dot{background:var(--lime-deep);box-shadow:0 0 10px var(--lime-deep)}
[data-theme="day"] .welcome-screen .headline b{color:var(--lime-deep)}


/* ============================================================
   ACE · editorial opening card (above chat)
   ============================================================ */
.ace-poster{
  margin:8px 0 18px;padding:22px 22px 18px;border-radius:18px;
  background:
    radial-gradient(280px 220px at 100% 0%, rgba(200,241,53,0.08), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(74,143,92,0.10), transparent 70%),
    linear-gradient(180deg, #14181f 0%, #0c0f12 100%);
  border:1px solid var(--rule);position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.05) inset, 0 18px 36px -22px rgba(0,0,0,0.55);
}
.ace-poster::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(200,241,53,0.32), transparent);
  pointer-events:none;
}
.ace-poster .top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:6px;
}
.ace-poster .top .crumb{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;line-height:1.55;
}
.ace-poster .top .crumb b{display:block;color:var(--ink);letter-spacing:0.18em;font-weight:600;margin-top:4px}
.ace-poster .top .live{
  display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  padding:5px 10px;border-radius:var(--r-pill);background:rgba(200,241,53,0.10);color:var(--lime);font-weight:600;
  border:1px solid rgba(200,241,53,0.22);
}
.ace-poster .top .live .dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 12px var(--lime)}
.ace-poster .invocation{
  margin-top:8px;
  font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:42px;line-height:0.96;letter-spacing:-0.025em;
  color:var(--ink);font-variation-settings:'opsz' 144;
}
.ace-poster .invocation b{
  font-style:normal;font-family:var(--font-display);font-weight:800;color:var(--lime);
  font-variation-settings:'wdth' 80,'wght' 800;letter-spacing:-0.045em;
}
.ace-poster .footnote{
  margin-top:14px;padding-top:14px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:baseline;gap:10px;
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.ace-poster .footnote b{color:var(--ink);font-weight:600}

[data-theme="day"] .ace-poster{
  background:
    radial-gradient(280px 220px at 100% 0%, rgba(155,183,29,0.16), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    #ffffff;
  border-color:rgba(42,38,24,0.08);
}
[data-theme="day"] .ace-poster .invocation b{color:var(--lime-deep)}
[data-theme="day"] .ace-poster .top .live{color:var(--lime-deep);background:rgba(155,183,29,0.08);border-color:rgba(155,183,29,0.28)}
[data-theme="day"] .ace-poster .top .live .dot{background:var(--lime-deep);box-shadow:0 0 10px var(--lime-deep)}


/* ============================================================
   YOU · profile poster (replaces plain profile-hero on the You tab)
   ============================================================ */
.profile-poster{
  margin:0 0 22px;padding:22px 22px 18px;border-radius:18px;
  background:
    radial-gradient(320px 220px at 100% 0%, rgba(200,241,53,0.10), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(74,143,92,0.08), transparent 70%),
    linear-gradient(180deg, #14181f 0%, #0c0f12 100%);
  border:1px solid var(--rule);position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(255,255,255,0.05) inset, 0 18px 36px -22px rgba(0,0,0,0.55);
}
.profile-poster::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(200,241,53,0.32), transparent);
  pointer-events:none;
}
.profile-poster .crumb{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--lime);font-weight:600;
}
.profile-poster .name-row{
  margin-top:8px;display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
}
.profile-poster .name-row .nm{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:54px;line-height:0.92;letter-spacing:-0.03em;color:var(--ink);
  font-variation-settings:'opsz' 144;
}
.profile-poster .name-row .nm b{
  font-style:normal;font-family:var(--font-display);font-weight:700;color:var(--ink);
  font-variation-settings:'wdth' 88,'wght' 700;letter-spacing:-0.04em;
}
.profile-poster .name-row .av{
  width:56px;height:56px;border-radius:50%;background:var(--lime);color:var(--night);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);
  font-weight:800;font-size:20px;letter-spacing:-0.025em;flex:0 0 56px;
  font-variation-settings:'wdth' 92,'wght' 800;
  box-shadow:0 0 24px rgba(200,241,53,0.32);
}
.profile-poster .stats{
  margin-top:18px;padding-top:14px;border-top:1px solid var(--rule);
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
}
.profile-poster .stats .c{padding:0 10px;position:relative;display:flex;flex-direction:column;gap:4px}
.profile-poster .stats .c + .c::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--rule)}
.profile-poster .stats .k{font-family:var(--font-mono);font-size:9px;letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-4);font-weight:600}
.profile-poster .stats .v{
  font-family:var(--font-num);font-weight:700;font-size:24px;letter-spacing:-0.03em;
  font-variation-settings:'wdth' 85,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;color:var(--ink);
}
.profile-poster .stats .v small{font-family:var(--font-mono);font-weight:500;font-size:10px;color:var(--ink-3);margin-left:3px;letter-spacing:0.04em;text-transform:lowercase}

[data-theme="day"] .profile-poster{
  background:
    radial-gradient(320px 220px at 100% 0%, rgba(155,183,29,0.16), transparent 65%),
    radial-gradient(280px 220px at 0% 100%, rgba(58,138,76,0.10), transparent 70%),
    #ffffff;
  border-color:rgba(42,38,24,0.08);
}
[data-theme="day"] .profile-poster .av{background:var(--lime-deep);color:#faf6e6;box-shadow:0 0 20px rgba(155,183,29,0.4)}
[data-theme="day"] .profile-poster .crumb{color:var(--lime-deep)}


/* ============================================================
   SOCIAL · compact Apple-Contacts identity row (replaces .soc-poster)
   ============================================================ */
.soc-id{display:flex;align-items:center;gap:12px;padding:4px 4px 0}
.soc-id-av{width:44px;height:44px;border-radius:50%;flex:0 0 44px;background:var(--lime);color:var(--night);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:-.025em;font-variation-settings:'wdth' 92,'wght' 800;box-shadow:0 0 0 1px rgba(255,255,255,.06) inset,0 4px 14px -6px rgba(200,241,53,.45)}
.soc-id-txt{flex:1;min-width:0}
.soc-id-nm{font-family:var(--font-sans);font-weight:600;font-size:19px;line-height:1.15;letter-spacing:-.02em;color:var(--ink);font-feature-settings:'cv01','ss03';margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.soc-id-nm b{font-weight:600} /* neutralise old <b> */
.soc-id-line{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;color:var(--ink-4);font-weight:500;margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.soc-id-line b{color:var(--ink-3);font-weight:600}
.soc-id-share{flex:0 0 auto;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-3);background:transparent;border:1px solid var(--rule-2);border-radius:50%;cursor:pointer;transition:color .15s var(--ease-out),border-color .15s var(--ease-out),transform var(--dur-fast) var(--ease-fast)}
.soc-id-share svg{width:14px;height:14px}
.soc-id-share:active{transform:scale(.92)}
.soc-id-share:hover{color:var(--lime);border-color:rgba(200,241,53,.32)}
.soc-id-stats{display:flex;align-items:center;gap:8px;padding:10px 4px 2px;font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--ink-4);text-transform:uppercase;font-weight:600}
.soc-id-stats button{background:0;border:0;padding:0;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;transition:color .15s}
.soc-id-stats button:active{color:var(--ink-2)}
.soc-id-stats b{font-family:var(--font-num);font-size:13px;color:var(--ink);font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;margin-right:2px}
.soc-id-stats .sep{color:var(--ink-5)}
[data-theme="day"] .soc-id-av{background:var(--lime-deep);color:#faf6e6}

/* SOCIAL · sticky Apple segmented sub-nav (Feed · Stats · Friends) */
.soc-subnav{position:sticky;top:0;z-index:6;display:flex;margin:14px 0 16px;padding:3px;background:var(--night-4);border-radius:12px;-webkit-backdrop-filter:saturate(1.4) blur(12px);backdrop-filter:saturate(1.4) blur(12px)}
.soc-subnav button{flex:1;position:relative;z-index:2;font-family:var(--font-sans);font-size:13px;font-weight:600;letter-spacing:-.01em;color:var(--ink-3);background:0;border:0;padding:8px 0;border-radius:9px;cursor:pointer;transition:color .25s var(--ease-ios)}
.soc-subnav button.is-on{color:var(--night)}
[data-theme="day"] .soc-subnav button.is-on{color:#fff}
.soc-subnav-pill{position:absolute;z-index:1;top:3px;bottom:3px;left:3px;width:calc((100% - 6px)/3);border-radius:9px;background:var(--ink);box-shadow:0 2px 8px -2px rgba(0,0,0,.4);transition:transform .42s var(--ease-spring)}
.soc-view{animation:socViewIn .4s var(--ease-ios) both}
.soc-view[hidden]{display:none !important}
@keyframes socViewIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){.soc-subnav-pill{transition:none}.soc-view{animation:none}}

/* SOCIAL · Stats/Friends mono section dividers (mirror the Bag's WOODS/IRONS hairlines) + tidy view gaps */
.soc-sec{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-4);padding:0 4px 10px;margin-top:4px;display:flex;align-items:center;gap:10px}
.soc-sec::after{content:"";flex:1;height:1px;background:var(--rule)}
.soc-view[data-view="stats"],.soc-view[data-view="friends"]{display:flex;flex-direction:column;gap:18px}


/* ── welcome multi-step ── */
.welcome-screen .welcome-step{
  flex:1;padding:0 26px;display:none;flex-direction:column;justify-content:flex-end;
  position:relative;z-index:2;
  opacity:0;transform:translateY(8px);transition:opacity .35s ease-out, transform .4s var(--ease-out);
}
.welcome-screen .welcome-step.is-on{display:flex;opacity:1;transform:none}

/* ── step 02 · handicap chips ── */
.welcome-screen .handicap-chips{
  margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:8px;
}
.welcome-screen .chip{
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:3px;
  padding:14px 14px;border-radius:14px;border:1px solid var(--rule-2);background:transparent;
  color:var(--ink);cursor:pointer;text-align:left;
  transition:all .15s var(--ease-out), transform .12s var(--ease-out);
}
.welcome-screen .chip:active{transform:scale(0.985)}
.welcome-screen .chip .n{
  font-family:var(--font-num);font-weight:700;font-size:22px;letter-spacing:-0.025em;
  font-variation-settings:'wdth' 88,'wght' 700,'opsz' 72;font-variant-numeric:tabular-nums;
}
.welcome-screen .chip .t{
  font-family:var(--font-mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.welcome-screen .chip.is-on{
  background:rgba(200,241,53,0.10);border-color:rgba(200,241,53,0.45);
}
.welcome-screen .chip.is-on .n{color:var(--lime);text-shadow:0 0 24px rgba(200,241,53,0.4)}
.welcome-screen .chip.is-on .t{color:var(--lime)}
.welcome-screen .chip[data-hcp="unknown"]{grid-column:span 2}

/* ── step 03 · ready cards ── */
.welcome-screen .ready-cards{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.welcome-screen .ready-card{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  padding:14px 16px;border-radius:14px;border:1px solid var(--rule);background:rgba(255,255,255,0.02);
}
.welcome-screen .ready-card .k{
  font-family:var(--font-mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-3);font-weight:600;
}
.welcome-screen .ready-card .v{
  font-family:var(--font-serif);font-style:italic;font-weight:400;font-size:18px;color:var(--ink);letter-spacing:-0.01em;
  font-variation-settings:'opsz' 72;
}
.welcome-screen .ready-card .v b{
  font-style:normal;font-family:var(--font-num);font-weight:700;
  font-variation-settings:'wdth' 88,'wght' 700;color:var(--lime);letter-spacing:-0.025em;
  font-variant-numeric:tabular-nums;
}
.welcome-screen .ready-card .v i{color:var(--ink-3)}

[data-theme="day"] .welcome-screen .chip.is-on{background:rgba(155,183,29,0.10);border-color:rgba(155,183,29,0.42)}
[data-theme="day"] .welcome-screen .chip.is-on .n,
[data-theme="day"] .welcome-screen .chip.is-on .t{color:var(--lime-deep)}
[data-theme="day"] .welcome-screen .ready-card{background:rgba(42,38,24,0.02)}
[data-theme="day"] .welcome-screen .ready-card .v b{color:var(--lime-deep)}

/* ============================================================
   PRE-BETA FIXES v33  (slice-app.css, frontend-css owner)
   Source-ordered last in THIS file, but the app's inline
   <style id="slice-hole-redesign-css"> block lives later in the
   document and would win at equal specificity — so each rule below
   is written one notch more specific than its inline counterpart.
   ============================================================ */

/* ── Finding 13 + scorecard colour-blind shape cues ──
   Mark is colour-blind: encode relative-to-par by SHAPE, not just colour.
   Native golf convention — circle = under par (birdie/eagle),
   square = over par (bogey/double). The JS already toggles these
   classes; we only add the non-colour visual shape. */

/* Live in-round scorecard (.sc-cell.under / .over) — inline base .sc-cell
   (0,1,0) sets border-radius:8px + a hairline border; these two-class
   rules (0,2,0) beat it, and add a distinct ring colour + corner shape. */
.sc-cell.under{
  border-radius:50%;
  border-color:var(--lime);
  box-shadow:inset 0 0 0 1px var(--lime);
}
.sc-cell.over{
  border-radius:3px;
  border-color:var(--flag);
  box-shadow:inset 0 0 0 1px var(--flag);
}

/* Round-detail strip (.rd-cell.birdie/.eagle/.bogey/.double) — inline
   rules are scoped as .rd-cell.<class> (0,2,0) and source-ordered after
   this file, so we scope under #rd-strip (1,2,0) to win. The cells are
   aspect-ratio 1/1 squares, so border-radius:50% renders a true circle. */
#rd-strip .rd-cell.eagle,
#rd-strip .rd-cell.birdie{
  border-radius:50%;
  border-color:currentColor;
}
#rd-strip .rd-cell.bogey,
#rd-strip .rd-cell.double{
  border-radius:2px;
  border-color:currentColor;
}
/* keep the open/selected ring authoritative when a cell is tapped */
#rd-strip .rd-cell.is-open{ border-color:var(--lime); }
[data-theme="day"] #rd-strip .rd-cell.is-open{ border-color:var(--lime-deep); }

/* ── Finding 25 · live-round prev/next arrows below 44px touch target ──
   Inline .lr-headbar .hole-arrow.lr-nav (1,2,0) shrinks the visible
   circle to 32x32. Keep the 32px circle but expand the tappable hit
   region to >=44px via an invisible ::before. Scope to beat the inline
   rule's specificity (1,2,0) -> add another class via #pane-round. */
#pane-round .lr-headbar .hole-arrow.lr-nav{ position:relative; }
#pane-round .lr-headbar .hole-arrow.lr-nav::before{
  content:"";
  position:absolute;
  top:50%; left:50%;
  width:44px; height:44px;
  transform:translate(-50%,-50%);
}

/* ── Finding 27 · weak scrim blur on generic modal sheets ──
   .backdrop only blurs 2px — far weaker than the tabbar's 20px frost.
   Bump to a native-feeling 18px (kept under the day-mode override which
   is more specific). */
.backdrop{
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
}

/* ── Finding 28 + 93 · promote the to-pin distance to a tabular-nums hero ──
   The live GPS to-pin number lives in .lr-you .you-d at 11px mono and
   jitters because it lacks tabular figures. Inline .lr-you .you-d is
   (0,2,0); scope under #pane-round (1,2,0) to win. Make the <b> (the
   actual number) a large hero with fixed-advance tabular figures; keep
   the trailing label small. Also stabilise the ladder rungs. */
#pane-round .lr-you .you-d{
  font:600 13px/1.05 var(--font-sans);
  letter-spacing:-0.01em;
  font-variant-numeric:tabular-nums;
}
#pane-round .lr-you .you-d b{
  font-family:var(--font-num);
  font-weight:800;
  font-size:30px;
  line-height:0.9;
  letter-spacing:-0.02em;
  font-variation-settings:'wdth' 84,'wght' 800,'opsz' 64;
  font-variant-numeric:tabular-nums;
  display:inline-block;
}
#pane-round .lr-dist-ladder .rung{ font-variant-numeric:tabular-nums; }

/* ── Finding 30 · no keyboard focus ring anywhere ──
   One global :focus-visible ring so desktop Tab navigation is visible.
   Honour the existing outline:none-for-mouse pattern (this only fires
   for keyboard focus). */
:focus-visible{
  outline:2px solid var(--lime);
  outline-offset:2px;
  border-radius:inherit;
}

/* ── Finding 71 · scrollbars globally hidden hurt desktop discoverability ──
   Show a thin styled scrollbar at desktop widths only. */
@media (min-width:769px){
  .scroll{ scrollbar-width:thin; }
  .scroll::-webkit-scrollbar{ display:block; width:6px; }
  .scroll::-webkit-scrollbar-thumb{ background:rgba(255,255,255,0.18); border-radius:3px; }
  [data-theme="day"] .scroll::-webkit-scrollbar-thumb{ background:rgba(0,0,0,0.18); }
}

/* ── Finding 72 · crowdsource unlock modal breaks out of the phone frame ──
   Scope the JS-injected #unlockModal to the device frame on desktop so it
   stays inside the phone, consistent with .ace-sheet. (The modal is
   position:fixed;inset:0 inline; on desktop pin it to the .device box.) */
@media (min-width:769px){
  .device #unlockModal{ position:absolute; }
}

/* ── Finding 29 + 95 · desktop fit-to-viewport + consolidate phone breakpoint ──
   The .device is a fixed 844px frame; on a laptop the bottom tab nav falls
   below the fold. Add a desktop rule that fits the frame to the viewport.
   It starts at 769px so it sits above the app.html full-bleed block (768px),
   which is the canonical phone breakpoint. The legacy 430px phone rule above
   is widened to 768px below to remove the 431-768px dead zone. */
@media (min-width:769px){
  .stage{ padding:24px; justify-content:center; }
  .device{
    height:min(844px, calc(100vh - 48px));
    max-height:calc(100vh - 48px);
  }
}

/* Consolidate the phone full-bleed breakpoint to 768px (was 430px) so the
   431-768px range no longer leaves the frame neither full-bleeding nor
   fitting. Matches the canonical 768px breakpoint used in app.html. */
@media (max-width:768px){
  .stage{ padding:0; gap:0; background:var(--night); }
  .device{ width:100%; max-width:100%; height:100vh; height:100dvh; border-radius:0; box-shadow:none; }
}

/* ── Finding 74 + 94 · hide the dev-preview caption at ALL widths ──
   "Home · iPhone 14 · 390 × 844" is a dev caption; it must never show to a
   tester (it currently renders on desktop > 768px). Hide unconditionally. */
.stage-cap{ display:none !important; }


/* ============================================================
   RECONCILE (integration) — style the classes FE actually emits
   ============================================================ */

/* Feed compact result line: .post-summary .ps-row2 > .cr > (.cr-score/.cr-vs/.cr-gir) */
.post-summary .ps-row2 .cr{flex:1;min-width:0;display:flex;align-items:baseline;gap:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-summary .cr-score{font-family:var(--font-num);font-weight:700;font-size:15px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-0.02em}
.post-summary .cr-vs{font-family:var(--font-num);font-weight:600;font-size:13px;font-variant-numeric:tabular-nums;letter-spacing:-0.01em}
.post-summary .cr-vs.under{color:var(--lime)}
.post-summary .cr-vs.over{color:var(--flag)}
.post-summary .cr-vs.even{color:var(--ink-3)}
[data-theme="day"] .post-summary .cr-vs.under{color:var(--lime-deep)}
.post-summary .cr-gir{font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--ink-3);letter-spacing:-0.005em}

/* Comment delete button: .soc-cmt > button.cmt-del (×) — appears on hover/focus */
.soc-cmt .cmt-del{flex:0 0 auto;margin-left:auto;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;color:var(--ink-4);font-size:17px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s,color .15s;border-radius:6px}
.soc-cmt:hover .cmt-del,.soc-cmt .cmt-del:focus-visible{opacity:1}
.soc-cmt .cmt-del:hover{color:var(--flag)}

/* Friend-requests section: #saf-requests.saf-requests > .label + .req-row(avatar-md/.who>.nm+.meta/.req-accept/.req-decline) */
.saf-requests{display:flex;flex-direction:column;gap:6px;padding:2px 0 14px;margin-bottom:8px;border-bottom:1px solid var(--rule)}
.saf-requests .req-row{display:flex;align-items:center;gap:10px;padding:6px 2px}
.saf-requests .req-row .who{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.saf-requests .req-row .nm{font-family:var(--font-sans);font-weight:600;font-size:14px;color:var(--ink);letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-feature-settings:'cv01','ss03'}
.saf-requests .req-row .meta{font-family:var(--font-sans);font-size:11px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.saf-requests .req-accept{font-family:var(--font-sans);font-weight:600;font-size:13px;background:var(--lime);color:var(--night);padding:7px 14px;border-radius:var(--r-pill);border:0;cursor:pointer;flex:0 0 auto;transition:transform .12s var(--ease-spring)}
.saf-requests .req-accept:active{transform:scale(0.96)}
.saf-requests .req-decline{font-family:var(--font-sans);font-weight:600;font-size:13px;background:transparent;color:var(--ink-3);padding:7px 12px;border-radius:var(--r-pill);border:1px solid var(--rule);cursor:pointer;flex:0 0 auto}
[data-theme="day"] .saf-requests .req-accept{background:var(--lime-deep);color:#fff}


/* chev svg sizing fix — feed chevron is a <span class="chev"><svg> with no svg size;
   inline span ignores width and the svg had no intrinsic size -> rendered huge. */
.chev{display:inline-flex;align-items:center;justify-content:center;flex:0 0 16px}
.chev > svg{width:100%;height:100%;display:block}


/* Bag: "Set carry" affordance for a club with no carry entered yet (clubs-only auto-fill) */
.club-card .dist .set-carry{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-sans);font-weight:600;font-size:13px;color:var(--lime);letter-spacing:-0.01em;white-space:nowrap}
.club-card .dist .set-carry .arr{font-size:16px;line-height:1;opacity:0.9}
[data-theme="day"] .club-card .dist .set-carry{color:var(--lime-deep)}


/* Expanded-post header (.post-detail > .who) — stack name+meta like the compact row */
.post-detail .who{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:0;border:0;padding:2px 0 6px;cursor:pointer}
.post-detail .who .nm-wrap{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.post-detail .who .nm{font-family:var(--font-sans);font-weight:600;font-size:15px;color:var(--ink);letter-spacing:-.01em;line-height:1.2;font-feature-settings:'cv01','ss03';white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.post-detail .who .meta{font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
