/* GolfCoach — modern pro-competition sports UI (dark, performance-grade) */
:root{
  --bg:#0A0D12; --bg-2:#0E131A; --surface:#141B24; --surface-2:#1B232F;
  --ink:#EAEEF4; --muted:#9AA5B4; --faint:#5C6573;
  --line:#283140; --line-soft:#1B2330;
  --accent:#C8F24E; --accent-2:#5FE9C4; --accent-ink:#0A0D12;
  --good:#39E08B; --warn:#FFC24B; --bad:#FF5C6C;
  /* legacy aliases kept so any un-rewritten rule still reads on dark */
  --navy:#9FB7E6; --gold:#C8F24E; --gold-soft:#3E4A24;
  --heather:#EAEEF4; --heather-2:#39E08B; --card:var(--surface);
  --parchment:#0A0D12; --line-soft2:#1B2330;
  --shadow:0 20px 48px rgba(0,0,0,.5);
  --radius:14px;
  --serif:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --display:"Sora","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:radial-gradient(1100px 520px at 50% -8%, rgba(200,242,78,.07), transparent 62%), var(--bg);
  color:var(--ink); font-family:var(--serif); font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased; letter-spacing:.1px;
}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px 96px}
.hidden{display:none !important}

/* masthead */
.masthead{text-align:center;padding:40px 0 22px;border-bottom:1px solid var(--line)}
.crest{width:52px;height:52px;margin:0 auto 10px;display:block}
.masthead .kicker{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-weight:600}
.masthead h1{font-family:var(--display);font-weight:800;font-size:34px;letter-spacing:-.5px;margin:0;color:var(--ink)}
.masthead .tag{color:var(--muted);margin-top:6px;font-size:14px}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px;margin-top:20px}
.section-title{font-family:var(--display);font-weight:700;font-size:23px;color:var(--ink);margin:0 0 4px;letter-spacing:-.3px}
.section-sub{color:var(--muted);font-size:14px;margin:0 0 18px}
.eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--eyebrow,#8A94A6);font-weight:600}

/* form */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label.field{display:block;margin:0 0 14px}
label.field>span{display:block;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-weight:600}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=search],input[type=date],select,textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2);font-family:var(--serif);font-size:15px;color:var(--ink)}
input::placeholder,textarea::placeholder{color:var(--faint)}
select{appearance:none}
textarea{resize:vertical;min-height:58px}
.seg{display:inline-flex;border:1px solid var(--line);border-radius:11px;overflow:hidden;background:var(--surface-2)}
.seg button{border:0;background:transparent;padding:11px 17px;font-family:var(--serif);font-size:14px;font-weight:600;cursor:pointer;color:var(--muted);transition:.15s}
.seg button.on{background:var(--accent);color:var(--accent-ink)}
.drop{border:1.5px dashed #3a4a24;border-radius:14px;background:rgba(200,242,78,.03);padding:32px;text-align:center;cursor:pointer;transition:.15s;color:var(--muted)}
.drop:hover,.drop.over{background:rgba(200,242,78,.08);border-color:var(--accent)}
.drop .big{font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink);margin-bottom:4px}
.drop.filled{border-style:solid;border-color:var(--accent);background:rgba(200,242,78,.06);color:var(--ink)}
.filelist{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.fl-item{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px}
.fl-item .fl-n{flex:1;color:var(--ink);font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fl-item .fl-sz{color:var(--muted);font-size:12px;flex:0 0 auto}
.fl-item .fl-x{flex:0 0 auto;width:26px;height:26px;border-radius:7px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;font-size:13px;line-height:1}
.fl-item .fl-x:hover{border-color:var(--bad);color:var(--bad)}
.btn{font-family:var(--display);font-weight:700;font-size:15px;border:0;border-radius:11px;padding:14px 26px;cursor:pointer;transition:.15s;letter-spacing:.2px}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 8px 24px rgba(200,242,78,.22)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-primary:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;transform:none;filter:none}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-row{display:flex;gap:12px;align-items:center;margin-top:8px;flex-wrap:wrap}

/* progress */
.progress{text-align:center;padding:60px 20px}
.progress .spin{width:48px;height:48px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;margin:0 auto 22px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.progress h2{font-family:var(--display);color:var(--ink);font-weight:700}
.steps{list-style:none;padding:0;max-width:440px;margin:18px auto 0;text-align:left}
.steps li{padding:8px 0 8px 28px;position:relative;color:var(--faint)}
.steps li::before{content:"○";position:absolute;left:4px}
.steps li.done{color:var(--ink)} .steps li.done::before{content:"✓";color:var(--good)}
.steps li.active{color:var(--ink)} .steps li.active::before{content:"…";color:var(--accent)}

/* score hero */
.hero{display:grid;grid-template-columns:210px 1fr;gap:34px;align-items:center}
.ring{position:relative;width:190px;height:190px;margin:0 auto;filter:drop-shadow(0 0 16px rgba(200,242,78,.18))}
.ring .num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .num b{font-family:var(--display);font-weight:800;font-size:58px;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}
.ring .num small{font-size:10px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-top:2px}
.verdict .label{font-family:var(--display);font-weight:700;font-size:27px;color:var(--accent);margin:0 0 6px;letter-spacing:-.3px}
.verdict p{margin:0 0 14px;color:var(--muted)}
.subs{display:flex;flex-direction:column;gap:9px}
.sub{display:grid;grid-template-columns:170px 1fr 40px;gap:10px;align-items:center;font-size:13px;color:var(--muted)}
.sub .bar{height:8px;border-radius:5px;background:var(--surface-2);overflow:hidden}
.sub .bar>i{display:block;height:100%;border-radius:5px}
.sub .v{text-align:right;color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}

.s-good{color:var(--good)} .s-warning{color:var(--warn)} .s-bad{color:var(--bad)} .s-unknown{color:var(--faint)}
.bg-good{background:var(--good)} .bg-warning{background:var(--warn)} .bg-bad{background:var(--bad)} .bg-unknown{background:var(--faint)}
.pill{display:inline-block;font-size:10px;letter-spacing:.8px;text-transform:uppercase;font-weight:700;padding:3px 10px;border-radius:20px;color:var(--accent-ink)}

/* stage strip */
.strip{display:flex;gap:10px;overflow-x:auto;padding:4px 2px 12px}
.chip{flex:0 0 auto;width:100px;cursor:pointer;text-align:center;border:1px solid var(--line);border-radius:12px;background:var(--surface-2);padding:6px;transition:.15s}
.chip.on{border-color:var(--accent);box-shadow:0 6px 18px rgba(200,242,78,.18)}
.chip img{width:100%;height:114px;object-fit:cover;border-radius:8px;background:#0d1116}
.chip .ph{width:100%;height:114px;border-radius:8px;background:#0d1116;display:flex;align-items:center;justify-content:center;color:var(--faint);font-size:10px}
.chip .nm{font-size:11px;margin-top:5px;color:var(--ink);line-height:1.2;font-weight:500}
.chip .dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;vertical-align:middle}

/* stage detail */
.stage-head{display:flex;align-items:baseline;gap:10px;margin-top:6px}
.stage-head h3{font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink);margin:0}
.stage-head .sub{color:var(--muted);display:block}
.stage-detail{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:12px}
.stage-detail.cols3{grid-template-columns:1fr 1fr 1fr;gap:14px}
.cap.cap-you{background:rgba(255,92,108,.9)} .cap.cap-ref{background:rgba(57,224,139,.9);color:var(--accent-ink)}
.ref-cue-line{margin:14px 0 2px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:12px 15px;font-size:14px;color:var(--ink);line-height:1.5}
.ref-cue-line b{color:var(--accent)}
.ref-eg{color:var(--faint);font-size:12.5px}
.lowconf{margin:10px 0 4px;background:rgba(255,194,75,.1);border:1px solid rgba(255,194,75,.4);border-radius:11px;padding:11px 14px;color:#FFD98A;font-size:13.5px;line-height:1.5}
.framebox{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#0d1116}
.framebox img{width:100%;display:block}
.framebox .cap{position:absolute;left:0;top:0;background:rgba(10,13,18,.85);color:var(--ink);font-size:11px;letter-spacing:.8px;text-transform:uppercase;font-weight:600;padding:5px 10px;border-bottom-right-radius:9px}
.framebox.ref .cap{background:rgba(57,224,139,.92);color:var(--accent-ink)}
.marker{position:absolute;width:40px;height:40px;border-radius:50%;border:3px solid;transform:translate(-50%,-50%);box-shadow:0 0 0 2px rgba(0,0,0,.4)}
.marker.b-bad{border-color:var(--bad)} .marker.b-warning{border-color:var(--warn)} .marker.b-good{border-color:var(--good)}
.marker span{position:absolute;top:-10px;right:-10px;min-width:20px;height:20px;padding:0 4px;border-radius:11px;font-size:12px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(0,0,0,.45)}
.marker.b-bad span{background:var(--bad)} .marker.b-warning span{background:var(--warn);color:var(--accent-ink)} .marker.b-good span{background:var(--good);color:var(--accent-ink)}
.marker-legend{margin:14px 0 2px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.marker-legend .ml-title{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:9px;font-weight:600}
.marker-legend ol{margin:0;padding:0;list-style:none}
.marker-legend li{display:flex;align-items:center;gap:9px;font-size:14px;margin-bottom:7px;color:var(--ink)}
.marker-legend li:last-child{margin-bottom:0}
.marker-legend li em{color:var(--muted)}
.ml-n{flex:0 0 auto;width:22px;height:22px;border-radius:50%;color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center}
.ml-n.b-bad{background:var(--bad)} .ml-n.b-warning{background:var(--warn);color:var(--accent-ink)} .ml-n.b-good{background:var(--good);color:var(--accent-ink)}
.pose-svg{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}
.pose-legend .ml-dot{flex:0 0 auto;width:13px;height:13px;border-radius:50%;display:inline-block}
.pose-legend ul{margin:0;padding:0;list-style:none}
.pose-legend li{display:flex;align-items:flex-start;gap:9px;font-size:14px;margin-bottom:7px;color:var(--ink);line-height:1.4}
.pose-legend li b{color:var(--ink)}
.sk-key{display:flex;gap:16px;margin:2px 0 11px;font-size:13px;color:var(--muted)}
.sk-key span{display:inline-flex;align-items:center;gap:6px}
.sk-key .kc{width:13px;height:13px;border-radius:3px;display:inline-block}
.sk-allgood{margin:0;color:var(--good);font-size:14px}
.framebox .empty,.chip .ph{font-size:11px}
.framebox .empty{aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;color:var(--faint);text-align:center;padding:20px;background:#0d1116}
.findings{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.findings ul{margin:6px 0 0;padding-left:18px} .findings li{margin:3px 0;font-size:14px;color:var(--muted)}
.findings h4{margin:0;font-size:12px;letter-spacing:1px;text-transform:uppercase}

/* metric cards */
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:14px}
.metric{border:1px solid var(--line);border-radius:12px;padding:15px;background:var(--surface-2)}
.metric .top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.metric .lbl{font-size:13px;color:var(--muted)}
.metric .val{font-family:var(--display);font-weight:700;font-size:25px;color:var(--ink);font-variant-numeric:tabular-nums}
.metric .val .u{font-size:13px;color:var(--muted);font-family:var(--serif);font-weight:400}
.metric .track{height:7px;border-radius:5px;background:#0d1116;margin:11px 0 7px;position:relative;overflow:hidden}
.metric .track .ideal{position:absolute;top:0;bottom:0;background:rgba(57,224,139,.35)}
.metric .track .dot{position:absolute;top:-2px;width:11px;height:11px;border-radius:50%;transform:translateX(-50%);border:2px solid var(--surface-2)}
.metric .plain{font-size:13px;color:var(--muted);margin-top:6px}
.metric .ideal-txt{font-size:12px;color:var(--faint)}

/* error cards */
.err{border:1px solid var(--line);border-left:4px solid var(--warn);border-radius:12px;padding:18px;background:var(--surface-2);margin-bottom:14px}
.err.sev-high{border-left-color:var(--bad)} .err.sev-low{border-left-color:var(--good)}
.err h3{font-family:var(--display);font-weight:700;font-size:19px;margin:0 0 10px;color:var(--ink)}
.err .qa{margin:8px 0;font-size:14px;color:var(--muted)}
.err .qa b{display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:2px}
.drillrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.drill{display:inline-flex;align-items:center;gap:8px;text-decoration:none;border:1px solid var(--line);border-radius:10px;padding:10px 14px;color:var(--ink);background:var(--surface);font-size:14px;font-weight:500;transition:.15s}
.drill:hover{border-color:var(--accent);color:var(--accent)}
.drill .yt{display:inline-block;width:22px;height:16px;background:#ff0033;border-radius:3px;position:relative}
.drill .yt::after{content:"";position:absolute;left:8px;top:4px;border-left:7px solid #fff;border-top:4px solid transparent;border-bottom:4px solid transparent}

/* glossary / limitations / history */
.acc summary{cursor:pointer;font-family:var(--display);font-weight:600;font-size:17px;color:var(--ink);padding:6px 0}
.gloss{display:grid;grid-template-columns:1fr 1fr;gap:10px 26px;margin-top:10px}
.gloss div{font-size:14px;color:var(--muted)} .gloss b{color:var(--ink)}
.limits{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px 18px;color:var(--muted);font-size:14px}
.limits ul{margin:6px 0 0;padding-left:18px} .limits li{margin:4px 0}
.note-ai{font-size:12px;color:var(--faint);margin-top:8px}
.hist{display:flex;flex-direction:column;gap:8px}
.hist a{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink);border:1px solid var(--line);border-radius:10px;padding:9px 12px;background:var(--surface-2);font-size:14px;transition:.15s}
.hist a:hover{border-color:var(--accent)}
.hist .sc{font-family:var(--display);font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.hist .hi-thumb{flex:0 0 auto;width:64px;height:48px;border-radius:8px;object-fit:cover;background:#0d1116}
.hist .hi-ph{display:flex;align-items:center;justify-content:center;color:var(--faint);font-size:11px}
.hist .hi-main{flex:1 1 auto;display:flex;flex-direction:column;gap:2px;min-width:0}
.hist .hi-main b{font-family:var(--display);font-weight:700;font-variant-numeric:tabular-nums}
.hist .hi-club{color:var(--muted);font-size:12px;font-style:normal;text-transform:capitalize}
.hist .hi-n{flex:0 0 auto;color:var(--muted);font-size:12.5px;font-variant-numeric:tabular-nums}
.statusline{font-size:12px;color:var(--muted);text-align:right;margin-top:6px}
.dotled{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:5px;vertical-align:middle}

/* nav tabs */
.nav{display:flex;gap:8px;justify-content:center;margin-top:20px}
.nav button{font-family:var(--serif);font-weight:600;font-size:14px;border:1px solid var(--line);background:var(--surface);color:var(--muted);
  padding:10px 20px;border-radius:24px;cursor:pointer;transition:.15s}
.nav button:hover{color:var(--ink);border-color:var(--faint)}
.nav button.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* coach card */
.coach{background:linear-gradient(180deg,rgba(200,242,78,.06),var(--surface));border:1px solid #2c3a1c}
.coach .who{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.coach .who .badge{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:16px}
.coach .narr{font-size:18px;line-height:1.6;color:var(--ink)}
.coach .focus{margin-top:12px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.coach .focus b{display:block;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:3px}
.coach .cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:14px}
.coach .cols h4{margin:0 0 4px;font-size:12px;letter-spacing:1px;text-transform:uppercase}
.coach ul{margin:4px 0 0;padding-left:18px}.coach li{margin:3px 0;font-size:14px;color:var(--muted)}

/* trends */
.spark{display:block}
.trend{display:grid;grid-template-columns:1fr 120px 110px;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.trend:last-child{border-bottom:0}
.trend .nm{font-size:14px;color:var(--ink)}.trend .nm small{display:block;color:var(--faint);font-size:12px}
.trend .vals{font-size:13px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.trend .dir{text-align:right;font-size:13px;font-weight:700}
.dir-mejora{color:var(--good)} .dir-empeora{color:var(--bad)} .dir-estable,.dir-\—{color:var(--faint)}

/* error lifecycle */
.life{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.life .col h4{font-family:var(--display);font-weight:700;font-size:16px;margin:0 0 8px}
.life .col.ok h4{color:var(--good)} .life .col.warn h4{color:var(--bad)} .life .col.new h4{color:var(--warn)}
.life .item{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:var(--surface-2);margin-bottom:8px;font-size:14px;color:var(--ink)}
.life .item small{display:block;color:var(--faint);font-size:12px;margin-top:2px}
.life .none{color:var(--faint);font-size:13px}

/* club cards + bag */
.clubgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.clubcard{border:1px solid var(--line);border-radius:12px;padding:16px;background:var(--surface-2)}
.clubcard .ct{display:flex;justify-content:space-between;align-items:baseline}
.clubcard .cn{font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink);text-transform:capitalize}
.clubcard .big{font-family:var(--display);font-weight:800;font-size:30px;color:var(--accent);font-variant-numeric:tabular-nums}
.clubcard .meta{font-size:13px;color:var(--muted);margin-top:4px}
.clubcard .te{font-size:13px;color:var(--muted);margin-top:8px}
.bag{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.bag .tag{border:1px solid var(--line);border-radius:20px;padding:6px 14px;background:var(--surface-2);font-size:14px;text-transform:capitalize;color:var(--ink)}
.bag .tag.new{border-color:var(--good);color:var(--good)}

/* 3D biomechanics card */
.b3d-card{background:linear-gradient(180deg,rgba(95,233,196,.05),var(--surface));border-color:#1f3a34}
.b3d-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:8px}
.b3d-metric{border:1px solid var(--line);border-radius:12px;padding:15px;background:var(--surface-2);border-top:3px solid var(--accent-2)}
.b3d-metric .b3d-val{font-family:var(--display);font-weight:800;font-size:34px;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.b3d-metric .b3d-val .u{font-family:var(--serif);font-weight:400;font-size:16px;color:var(--muted);margin-left:2px}
.b3d-metric .b3d-lbl{font-weight:600;color:var(--ink);margin-top:6px}
.b3d-metric .b3d-ideal{font-size:12px;color:var(--accent-2);margin-top:3px}
.b3d-metric .plain{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.45}
.b3d-seq{border:1px solid var(--line);border-radius:12px;padding:18px;background:var(--surface-2);margin-top:12px}
.b3d-seq-head{display:flex;justify-content:space-between;align-items:center;gap:12px}
.b3d-seq-head h3{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);margin:0}
.seq-track{position:relative;height:74px;margin:26px 6px 10px;border-top:2px dashed var(--line)}
.seq-axis-l,.seq-axis-r{position:absolute;top:-22px;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--faint)}
.seq-axis-l{left:0} .seq-axis-r{right:0}
.seq-node{position:absolute;top:-7px;transform:translateX(-50%);text-align:center;min-width:60px}
.seq-dot{display:block;width:14px;height:14px;border-radius:50%;background:var(--accent-2);margin:0 auto;box-shadow:0 0 0 4px rgba(95,233,196,.16)}
.seq-name{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-top:6px;white-space:nowrap}
.seq-t{display:block;font-size:12px;color:var(--accent-2)}
.b3d-note{font-size:12px;color:var(--faint);margin:8px 0 0}
.b3d-confrow{margin:-6px 0 14px}
.b3d-metric.flagged{border-top-color:var(--warn)}
.b3d-warn{font-size:18px;color:var(--warn);margin-left:8px;vertical-align:middle}
.b3d-flag{font-size:12px;color:var(--warn);margin-top:8px;line-height:1.4;border-top:1px dashed var(--line);padding-top:7px}

/* onboarding: how-to-film guide */
.card.howto{padding:0;overflow:hidden}
.howto details{padding:0}
.howto summary{list-style:none;cursor:pointer;padding:20px 26px;display:flex;flex-direction:column;gap:2px;border-left:3px solid var(--accent);position:relative}
.howto summary::-webkit-details-marker{display:none}
.howto summary::after{content:"＋";position:absolute;right:30px;top:22px;color:var(--accent);font-size:22px}
.howto details[open] summary::after{content:"－"}
.howto-eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);font-weight:600}
.howto-title{font-family:var(--display);font-weight:700;font-size:21px;color:var(--ink)}
.howto-hint{font-size:12px;color:var(--faint)}
.howto .section-sub{padding:0 26px;margin:4px 0 10px}
.howto-steps{margin:0;padding:0 26px 4px 46px;line-height:1.6;color:var(--muted)}
.howto-steps li{margin-bottom:9px}
.howto-steps b{color:var(--ink)}
.howto-foot{padding:8px 26px 22px;margin:0;color:var(--accent);font-weight:600}

/* loading card */
.card.loading{text-align:center;padding:54px 24px}
.card.loading .spin{width:48px;height:48px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;margin:0 auto 22px;animation:spin 1s linear infinite}
main.hidden .spin{animation:none}

/* field helper text */
.field-hint{display:block;margin-top:7px;font-size:12.5px;color:var(--muted);line-height:1.45}
.field-hint b{color:var(--ink)}

/* visible keyboard focus */
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,summary:focus-visible,.drop:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}

/* trimmed swing clip + capture-quality badge */
.clipwrap{display:grid;grid-template-columns:minmax(0,1.1fr) 1fr;gap:18px;align-items:start;margin:6px 0 18px}
.clipbox{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#000}
.clipbox .cap{position:absolute;top:8px;left:8px;z-index:2;background:rgba(10,13,18,.82);color:var(--ink);font-size:11px;letter-spacing:.5px;padding:5px 10px;border-radius:6px}
.clip{display:block;width:100%;max-height:440px;object-fit:contain;background:#000}
.clipside{padding-top:4px}
.cap-badge{display:inline-block;font-size:13px;padding:7px 13px;border-radius:20px;border:1px solid var(--line)}
.cap-badge b{text-transform:capitalize}
.cap-high{background:rgba(57,224,139,.12);border-color:var(--good);color:var(--good)}
.cap-medium{background:rgba(255,194,75,.12);border-color:var(--warn);color:var(--warn)}
.cap-low{background:rgba(255,92,108,.12);border-color:var(--bad);color:var(--bad)}
.clipside .plain{font-size:13px;color:var(--muted);margin:10px 0 0;line-height:1.5}
.caplist{margin:8px 0 0;padding-left:18px;font-size:13px;color:var(--muted)}
.caplist li{margin-bottom:4px}

/* rotatable 3D model */
.m3d-card{background:linear-gradient(180deg,rgba(95,233,196,.05),var(--surface));border-color:#1f3a34}
.m3d-mode{display:inline-flex;gap:4px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:4px;margin-bottom:14px}
.m3d-mode button{border:0;background:transparent;color:var(--muted);font-family:var(--serif);font-weight:600;font-size:13px;padding:7px 16px;border-radius:8px;cursor:pointer}
.m3d-mode button.on{background:var(--accent);color:var(--accent-ink)}
.m3d-mode .beta{font-size:9px;letter-spacing:1px;text-transform:uppercase;opacity:.7;margin-left:3px}
.m3d-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.m3d-tabs button{font-family:var(--serif);font-weight:600;font-size:13px;border:1px solid var(--line);background:var(--surface-2);color:var(--muted);padding:8px 14px;border-radius:20px;cursor:pointer;transition:.15s}
.m3d-tabs button:hover{color:var(--ink);border-color:var(--faint)}
.m3d-tabs button.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.m3d-stage{width:100%;height:440px;border:1px solid var(--line);border-radius:12px;background:radial-gradient(circle at 50% 35%, #11161e, #0b0e13);overflow:hidden;cursor:grab;touch-action:none}
.m3d-stage:active{cursor:grabbing}
.m3d-stage canvas{display:block;margin:0 auto}

/* multi-swing session overview */
/* per-swing gallery (clickable thumbnails) */
.swgallery{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 10px;-webkit-overflow-scrolling:touch}
.swgallery::-webkit-scrollbar{height:6px}.swgallery::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.sw-card{flex:0 0 auto;width:128px;background:transparent;border:0;padding:0;cursor:pointer;text-align:center}
.sw-thumb{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#0d1116;aspect-ratio:.66;
  transition:transform .15s,border-color .15s,box-shadow .15s}
.sw-card:hover .sw-thumb{transform:translateY(-2px);border-color:var(--accent)}
.sw-card.on .sw-thumb{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}
.sw-card.prim .sw-thumb{border-color:var(--accent)}
.sw-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.sw-ph{display:flex;align-items:center;justify-content:center;height:100%;color:var(--faint);font-size:12px}
.sw-badge{position:absolute;top:7px;right:7px;min-width:28px;padding:2px 8px;border-radius:20px;font-family:var(--display);
  font-weight:700;font-size:14px;color:#0A0D12;text-align:center}
.sw-badge.prac{background:rgba(10,13,18,.78);color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.sw-star{position:absolute;left:7px;bottom:7px;background:var(--accent);color:#0A0D12;font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:20px;letter-spacing:.3px}
.sw-cap{margin-top:7px;font-size:13px;color:var(--ink);font-weight:600}
.sw-detail{margin-top:6px}
.sw-detail.show{margin-top:14px;border-top:1px solid var(--line);padding-top:14px;animation:rise .3s both}
.sw-dhead{display:flex;align-items:center;gap:14px}
.sw-dscore{font-family:var(--display);font-weight:700;font-size:24px;color:#0A0D12;width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.sw-dhead b{font-size:16px}.sw-dhead small{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.sw-tag{font-size:11px;padding:2px 8px;border-radius:20px;margin-left:7px;vertical-align:middle}
.sw-tag.prac{background:var(--surface-2);color:var(--muted)}.sw-tag.prim{background:var(--accent);color:#0A0D12;font-weight:700}
.sw-faults{margin:4px 0 0;padding-left:18px}.sw-faults li{font-size:14px;margin-bottom:5px;color:var(--ink)}
.stage-swing-label{margin:2px 0 10px;font-size:14px;color:var(--muted)}
.stage-swing-label:empty{display:none}
.ssl-pill{display:inline-block;background:var(--accent);color:#0A0D12;font-weight:700;font-size:12px;padding:2px 9px;border-radius:20px;margin-right:8px}
.patbox{margin-top:14px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.patbox .ml-title{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-weight:600}
.patbox ul{margin:8px 0 0;padding-left:18px}.patbox li{font-size:14px;margin-bottom:5px;color:var(--ink)}
.patbox li em{color:var(--muted)}

/* motion */
.ring circle.ring-prog{transition:stroke-dashoffset 1.1s cubic-bezier(.2,.7,.2,1)}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion: no-preference){
  .card{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
}

/* ---------- interactive session timeline + compare ---------- */
.tl-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:4px 0 14px}
.tl-fromto{font-family:var(--display);font-size:30px;font-weight:700}
.tl-top .dir{margin-left:8px}
.tl-sub{display:block;color:var(--muted);font-size:13px;margin-top:2px}
.tl-top .btn{margin-left:auto}
.timeline{display:flex;gap:10px;overflow-x:auto;padding:6px 2px 12px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}
.timeline::-webkit-scrollbar{height:6px}
.timeline::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.tl-node{flex:0 0 auto;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;gap:7px;
  background:#0d1116;border:1px solid var(--line);border-radius:14px;padding:12px 14px;cursor:pointer;min-width:78px;
  transition:transform .15s,border-color .15s,box-shadow .15s}
.tl-node:hover{transform:translateY(-2px);border-color:var(--accent)}
.tl-node.opening{opacity:.5}
.tl-num{font-family:var(--display);font-weight:700;font-size:21px;color:#0A0D12;width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center}
.tl-meta{text-align:center;line-height:1.25}
.tl-meta b{display:block;font-size:13px;color:var(--ink)}
.tl-meta em{font-style:normal;font-size:11px;color:var(--muted);text-transform:capitalize}
.timeline.cmp-on .tl-node{border-style:dashed}
.timeline.cmp-on .tl-node.sel{border-color:var(--accent);border-style:solid;box-shadow:0 0 0 2px var(--accent) inset}
.cmp-hint{color:var(--muted);font-size:14px;margin-top:14px}
.cmp-load{display:flex;align-items:center;gap:10px;color:var(--muted);margin-top:14px}
.cmp-panel{margin-top:16px;border-top:1px solid var(--line);padding-top:16px;animation:rise .35s both}
.cmp-head{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin-bottom:18px}
.cmp-col{text-align:center}
.cmp-when{color:var(--muted);font-size:13px;margin-bottom:6px}.cmp-when em{font-style:normal;color:var(--ink);text-transform:capitalize}
.cmp-big{font-family:var(--display);font-weight:700;font-size:30px;color:#0A0D12;width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto}
.cmp-lbl{font-size:12px;color:var(--muted);margin-top:6px}
.cmp-arrow{text-align:center}
.cmp-delta{font-family:var(--display);font-weight:700;font-size:24px;display:block}
.cmp-arrow small{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.6px}
.cmp-up{color:var(--good)}.cmp-down{color:var(--bad)}.cmp-flat{color:var(--muted)}
.cmp-section h4,.cmp-errs h5{font-family:var(--display);margin:0 0 8px}
.cmp-metric{display:grid;grid-template-columns:1fr auto 64px;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line);font-size:14px}
.cmp-metric .cmn{color:var(--ink)}
.cmp-metric .cmv{color:var(--muted);font-size:13px}
.cmp-metric .cmv i{font-style:normal;color:var(--faint);margin:0 3px}
.cmp-metric .cmv b{color:#0A0D12;padding:2px 7px;border-radius:6px;font-size:12px}
.cmd{font-size:12px;text-align:right;font-weight:600}
.cmd-up{color:var(--good)}.cmd-down{color:var(--bad)}.cmd-flat{color:var(--faint)}
.cmp-errs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.cmp-ecol{background:#0d1116;border:1px solid var(--line);border-radius:12px;padding:12px}
.cmp-ecol h5{font-size:13px}.cmp-ecol.ok h5{color:var(--good)}.cmp-ecol.warn h5{color:var(--warn)}.cmp-ecol.new h5{color:var(--bad)}
.cmp-ecol span{display:block;font-size:13px;color:var(--ink);padding:3px 0}
.cmp-ecol .none{color:var(--faint)}

/* ---- Simple/Completo report mode (T8) ---- */
.mode-toggle{display:flex;justify-content:flex-end;margin-top:20px}
.sess-facts{font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums;margin:2px 0 12px}
.datos-acc>summary{font-size:16px}
.datos-acc .datos-body>.card{margin-top:14px;background:var(--surface-2)}
.datos-acc .datos-body>.card:first-child{margin-top:14px}
/* honesty badge: detectado vs estimado-por-tempo (T5 frame_basis) */
.fb-badge{display:inline-block;font-family:var(--serif);font-size:11px;font-weight:600;letter-spacing:.3px;padding:2px 8px;border-radius:999px;vertical-align:middle;margin-left:6px}
.fb-det{background:rgba(57,224,139,.14);color:var(--good);border:1px solid rgba(57,224,139,.4)}
.fb-est{background:rgba(255,194,75,.12);color:#FFD98A;border:1px solid rgba(255,194,75,.4);cursor:help}

@media(max-width:760px){
  body{font-size:16px}
  .grid2,.hero,.stage-detail,.stage-detail.cols3,.findings,.gloss,.coach .cols,.life,.clipwrap{grid-template-columns:1fr}
  .ring{width:160px;height:160px}.hero{gap:20px}
  .masthead h1{font-size:28px}
  .sub{grid-template-columns:120px 1fr 36px}
  .trend{grid-template-columns:1fr 80px 80px}
  .clipbox .clip{max-height:none}
  .b3d-seq-head{flex-wrap:wrap}
  .cmp-metric{grid-template-columns:1fr auto;row-gap:2px}.cmp-metric .cmd{grid-column:2;text-align:right}
  .cmp-errs{grid-template-columns:1fr}
}

/* ============================================================================
   APP SHELL v2 — "Caddie": compact topbar + bottom tab-bar + Home «Hoy» + Yo
   dark-sports premium · lime restricted to interactive/accent · gray eyebrows
   ============================================================================ */
:root{ --lime:var(--accent); --eyebrow:#8A94A6; }
.wrap{padding-bottom:108px}                 /* room for the fixed tab-bar */

/* --- top bar (brand + account status) --- */
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:13px 2px;margin-bottom:4px;background:linear-gradient(var(--bg),rgba(10,13,18,.86));
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-soft)}
.brand{display:flex;align-items:center;gap:9px}
.brand .crest{width:30px;height:30px;display:block;margin:0}
.brand .wordmark{font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:-.4px;color:var(--ink)}

/* login brand hero */
.auth-brand{text-align:center;max-width:440px;margin:34px auto 0;padding:0 8px}
.auth-logo{width:62px;height:62px;display:block;margin:0 auto 14px}
.auth-word{font-family:var(--display);font-weight:800;font-size:32px;letter-spacing:-.6px;color:var(--ink)}
.auth-tag{color:var(--muted);font-size:15px;line-height:1.5;margin:8px auto 0;max-width:390px}
.topbar .statusline{margin:0;font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;white-space:nowrap}

/* --- screen headers --- */
.screen-head{padding:18px 0 6px}
.screen-head .eyebrow{color:var(--eyebrow)}
.screen-title{font-family:var(--display);font-weight:800;font-size:28px;letter-spacing:-.6px;margin:4px 0 0;color:var(--ink)}
.screen-tag{color:var(--muted);font-size:14.5px;margin:7px 0 0;max-width:56ch}

/* --- bottom tab bar --- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;gap:2px;justify-content:center;
  padding:7px 8px calc(7px + env(safe-area-inset-bottom,0px));background:rgba(14,19,26,.92);
  backdrop-filter:blur(14px);border-top:1px solid var(--line)}
.tab{flex:1;max-width:108px;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;
  border:0;cursor:pointer;color:var(--faint);font:600 11px/1 var(--serif);padding:6px 4px 4px;border-radius:12px;
  transition:color .15s}
.tab svg{width:23px;height:23px;stroke:currentColor}
.tab span{letter-spacing:.2px}
.tab.on{color:var(--lime)}
.tab:not(.locked):not(.on):hover{color:var(--muted)}
.tab.locked{color:var(--line);cursor:default}
.tab.locked::after{content:"pronto";position:absolute;transform:translateY(-26px);font-size:8px;letter-spacing:.5px;
  text-transform:uppercase;color:var(--faint);opacity:0;transition:opacity .15s}
.tab.locked:hover::after{opacity:.7}

/* --- Home «Hoy» --- */
.chiprow{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.lvlchip,.minichip{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;
  padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--ink)}
.lvlchip .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 3px rgba(200,242,78,.18)}
.minichip{color:var(--muted)} .minichip b{color:var(--ink);font-variant-numeric:tabular-nums}
.gradchip{color:var(--good);border-color:rgba(57,224,139,.32)}

/* re-test verdict banner (the coach loop made visible) */
.retest{display:flex;align-items:flex-start;gap:11px;margin-top:14px;padding:13px 15px;border-radius:13px;
  border:1px solid var(--line);background:var(--surface-2);font-size:14px;line-height:1.45}
.retest-ico{flex:none;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:13px;margin-top:1px}
.retest-body{color:var(--muted)}.retest-body b{color:var(--ink)}
.retest--graduated{border-color:rgba(57,224,139,.42);background:linear-gradient(120deg,rgba(57,224,139,.13),var(--surface-2))}
.retest--graduated .retest-ico{background:var(--good);color:#062a16}
.retest--neutral .retest-ico{background:var(--surface);color:var(--muted);border:1px solid var(--line)}
.retest--bad{border-color:rgba(255,92,108,.36)}
.retest--bad .retest-ico{background:var(--bad);color:#2a0608}

.coachcard{position:relative;overflow:hidden;border-color:#2A3647;
  background:linear-gradient(150deg,#18222E,#131A23 62%)}
.coachcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--lime),var(--accent-2))}
.coachcard-eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--eyebrow);font-weight:700}
.coachcard-title{font-family:var(--display);font-weight:800;font-size:24px;line-height:1.15;letter-spacing:-.4px;
  margin:8px 0 0;color:var(--ink)}
.coachcard-detail{color:var(--accent-2);font-weight:600;font-size:14px;margin:8px 0 0}
.coachcard-fix{color:var(--muted);font-size:14.5px;margin:12px 0 0;line-height:1.5}
.coachcard-fix .lbl{color:var(--ink);font-weight:700}
.coachcard-cta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.coachcard-hint{color:var(--faint);font-size:12.5px;margin:12px 0 0}
.coachcard--empty::before{background:var(--line)}
/* onboarding (primer swing) */
.onb{padding:6px 2px}
.onb-step{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--line-soft)}
.onb-step:last-child{border-bottom:0}
.onb-n{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:15px;background:var(--lime);color:var(--accent-ink)}
.onb-tx{display:flex;flex-direction:column;gap:2px}
.onb-tx b{font-size:15px;color:var(--ink)}
.onb-tx span{font-size:13.5px;color:var(--muted);line-height:1.45}
/* coach: estrategia / course management */
.inslist{display:flex;flex-direction:column;gap:11px;margin-top:10px}
.insitem{display:flex;gap:12px;align-items:flex-start}
.ins-ic{flex:none;width:28px;height:28px;border-radius:9px;display:grid;place-items:center;font-weight:800;font-size:15px;background:var(--surface-2);color:var(--accent-2);border:1px solid var(--line)}
.ins-ic.ins-pro{color:var(--lime)}.ins-ic.ins-strategy{color:var(--warn)}
.ins-tx{display:flex;flex-direction:column;gap:2px}
.ins-tx b{font-size:14px;color:var(--ink)}
.ins-tx span{font-size:13px;color:var(--muted);line-height:1.45}

.drillrow{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}
.drillpill{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:11px;font-size:13px;font-weight:600;
  color:var(--ink);background:var(--surface-2);border:1px solid var(--line);transition:border-color .15s,transform .1s}
.drillpill:hover{border-color:var(--lime);transform:translateY(-1px)}
.drillpill svg{width:15px;height:15px;color:var(--lime);flex:none}

.trendrow{display:flex;align-items:center;gap:16px;margin:2px 0 16px}
.trend-spark{flex:none}.spark{width:120px;height:34px;display:block}
.spark-empty{font-size:12.5px;color:var(--faint)}
.trend-text{color:var(--muted);font-size:14px}

.recentlist{display:flex;flex-direction:column;gap:8px}
.recentitem{display:grid;grid-template-columns:46px 1fr auto;align-items:center;gap:12px;width:100%;text-align:left;
  background:var(--surface-2);border:1px solid var(--line-soft);border-radius:12px;padding:11px 13px;cursor:pointer;
  color:var(--ink);transition:border-color .15s}
.recentitem:hover{border-color:var(--line)}
.ri-score{font-family:var(--display);font-weight:800;font-size:19px;text-align:center;font-variant-numeric:tabular-nums;
  border-radius:9px;padding:4px 0;color:var(--ink);background:var(--surface)}
.ri-score.sc-good{color:var(--good)} .ri-score.sc-warn{color:var(--warn)} .ri-score.sc-bad{color:var(--bad)}
.ri-meta{font-size:13.5px;color:var(--muted)}.ri-meta b{color:var(--ink)}
.ri-date{font-size:12.5px;color:var(--faint);font-variant-numeric:tabular-nums}

/* Home · unified hub: tu juego (hándicap + última ronda) */
.golfcard{background:linear-gradient(150deg,#16202B,#121922 62%);border-color:#27323F}
.golfrow{display:flex;gap:22px;align-items:flex-end;margin-top:12px;flex-wrap:wrap}
.gh-k,.gl-k{font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--eyebrow);font-weight:600}
.gh-v{font-family:var(--display);font-weight:800;font-size:34px;color:var(--lime);line-height:1;margin-top:5px;font-variant-numeric:tabular-nums}
.golflast{flex:1;min-width:150px}
.gl-v{font-family:var(--display);font-weight:700;font-size:22px;color:var(--ink);margin-top:5px;font-variant-numeric:tabular-nums}
.gl-v .sc-good{color:var(--good)}.gl-v .sc-warn{color:var(--warn)}.gl-v .sc-bad{color:var(--bad)}
.gl-sub{font-size:12.5px;color:var(--muted);margin-top:3px}

/* --- Yo --- */
.yo-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.yo-row:last-child{border-bottom:0}
.yo-k{color:var(--muted);font-size:14px}.yo-v{color:var(--ink);font-weight:600;font-size:14px}
.btn-block{display:block;width:100%;margin-top:18px}

/* --- Jugar (rondas / hándicap / stats) --- */
.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:16px 0 6px}
.statbox{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:13px}
.statbox .statk{font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--eyebrow);font-weight:600}
.statbox .statv{font-family:var(--display);font-weight:800;font-size:22px;color:var(--ink);margin-top:5px;font-variant-numeric:tabular-nums}
.statbox .statnote{font-size:10px;color:var(--faint);margin-top:3px}
.stathero{grid-column:span 3;background:linear-gradient(150deg,#18222E,#131A23 62%);border-color:#2A3647}
.stathero .statv{font-size:38px;color:var(--lime)}
.roundlist{display:flex;flex-direction:column;gap:8px}
.rounditem{display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;width:100%;text-align:left;
  background:var(--surface-2);border:1px solid var(--line-soft);border-radius:12px;padding:11px 13px;cursor:pointer;color:var(--ink)}
.rounditem:hover{border-color:var(--line)}
.ro-date{font-size:12.5px;color:var(--faint);font-variant-numeric:tabular-nums}
.ro-course{font-size:13.5px;color:var(--muted)}
.ro-score{font-weight:700;font-size:14px;font-variant-numeric:tabular-nums;white-space:nowrap}
.ro-score.sc-good{color:var(--good)}.ro-score.sc-warn{color:var(--warn)}.ro-score.sc-bad{color:var(--bad)}
/* scorecard entry */
.scorecard .schead,.scrow{display:grid;grid-template-columns:28px 50px 1fr 1fr 34px 34px;gap:7px;align-items:center}
.scorecard .schead{font-size:10px;letter-spacing:.3px;text-transform:uppercase;color:var(--eyebrow);font-weight:600;padding:0 2px 9px;border-bottom:1px solid var(--line-soft)}
.scrow{padding:6px 0;border-bottom:1px solid var(--line-soft)}
.sc-h{font-weight:700;color:var(--muted);text-align:center;font-variant-numeric:tabular-nums}
.sc-par,.sc-in{padding:9px 4px;border:1px solid var(--line);border-radius:9px;background:var(--surface-2);color:var(--ink);font-size:15px;width:100%;text-align:center;font-variant-numeric:tabular-nums}
.sc-in{appearance:textfield;-moz-appearance:textfield}
.sc-in::-webkit-outer-spin-button,.sc-in::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.sc-tog{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:var(--surface-2);color:transparent;cursor:pointer;font-weight:800;font-size:14px;display:grid;place-items:center}
.sc-tog.on{background:var(--good);color:#062a16;border-color:var(--good)}
.sctotal{margin-top:14px;padding-top:13px;border-top:1px solid var(--line);font-size:15px;color:var(--muted);font-variant-numeric:tabular-nums}
.sctotal b{color:var(--ink);font-size:18px}
.sctotal .sc-good{color:var(--good)}.sctotal .sc-warn{color:var(--warn)}.sctotal .sc-bad{color:var(--bad)}
@media(max-width:480px){
  .statgrid{grid-template-columns:repeat(2,1fr)}.stathero{grid-column:span 2}
}

/* --- Social (compartir privado) --- */
.btn-sm{padding:8px 13px;font-size:13px}
.sharelist{display:flex;flex-direction:column;gap:10px}
.shareitem{display:flex;flex-wrap:wrap;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:12px;padding:12px 13px}
.shi-main{flex:1;min-width:150px;font-size:14px;color:var(--muted)}.shi-main b{color:var(--ink)}
.shi-date{color:var(--faint);font-size:12.5px;margin-left:4px}
.shi-row{flex-basis:100%;display:flex;gap:8px;align-items:center}
.shi-url{flex:1;min-width:0;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:var(--bg-2);color:var(--muted);font-size:12.5px;font-family:var(--serif)}
.shi-revoke{color:var(--bad)}
/* shared public view (/s/<token>) */
.shared-mode .tabbar{display:none}
.shared-mode .wrap{padding-bottom:40px}
.shared-badge{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--accent-2);border:1px solid var(--line);border-radius:999px;padding:4px 10px}
.sharedcta{text-align:center;background:linear-gradient(150deg,#18222E,#131A23 62%);border-color:#2A3647}

/* --- Yo: nivel + logros --- */
.levelpath{display:flex;align-items:flex-start;gap:0;margin-top:14px}
.lvlnode{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;color:var(--faint);font-size:12px;font-weight:600;text-align:center}
.lvlnode .lvldot{width:13px;height:13px;border-radius:50%;background:var(--surface-2);border:2px solid var(--line)}
.lvlnode.done .lvldot{background:var(--accent-2);border-color:var(--accent-2)}
.lvlnode.on{color:var(--lime)}
.lvlnode.on .lvldot{background:var(--lime);border-color:var(--lime);box-shadow:0 0 0 4px rgba(200,242,78,.18)}
.lvlsep{height:2px;flex:1;background:var(--line);margin-top:5px;max-width:70px}
.badgegrid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}
.badge{display:flex;flex-direction:column;gap:3px;padding:13px;border-radius:12px;border:1px solid var(--line-soft);background:var(--surface-2);opacity:.5}
.badge.earned{opacity:1;border-color:rgba(200,242,78,.3)}
.badge-ic{font-size:17px;color:var(--faint)}.badge.earned .badge-ic{color:var(--lime)}
.badge-t{font-weight:700;font-size:13.5px;color:var(--ink)}
.badge-d{font-size:11.5px;color:var(--muted);line-height:1.35}

/* Yo · Tu progreso (curva de puntaje + focos superados) */
.progtop{display:flex;gap:18px;align-items:center;margin-top:12px;flex-wrap:wrap}
.prog-k{font-size:10.5px;letter-spacing:.4px;text-transform:uppercase;color:var(--eyebrow);font-weight:600}
.prog-v{font-family:var(--display);font-weight:800;font-size:34px;color:var(--ink);line-height:1;margin-top:4px;font-variant-numeric:tabular-nums}
.prog-delta{font-size:12.5px;font-weight:600;margin-top:5px}.prog-delta.up{color:var(--good)}.prog-delta.down{color:var(--bad)}
.prog-chart{flex:1;min-width:160px}.progsvg{width:100%;height:56px;display:block}
.prog-single{font-family:var(--display);font-weight:800;font-size:24px;color:var(--lime)}
.focuslist{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.focusitem{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line-soft);border-radius:11px;padding:10px 12px}
.focus-ic{color:var(--lime);font-size:14px}
.focus-t{flex:1;font-size:13.5px;color:var(--ink);font-weight:600}
.focus-d{font-size:12px;color:var(--good);font-variant-numeric:tabular-nums;white-space:nowrap}

/* Yo · plan / facturación (PayPal) */
.planhead{display:flex;align-items:center;gap:11px;margin-top:12px}
.planpill{font-family:var(--display);font-weight:800;font-size:13px;padding:5px 13px;border-radius:999px;background:var(--lime);color:var(--accent-ink)}
.plansub{font-size:14px;color:var(--muted)}
.ppbtn{max-width:340px}
.probadge{font-weight:800;font-size:11px;letter-spacing:.4px;color:var(--accent-ink);background:var(--lime);padding:2px 9px;border-radius:999px}

/* Yo · zona de peligro (borrado de cuenta) */
.card.danger{border-color:rgba(255,92,108,.35)}
.danger-k{color:var(--bad)}
.danger-title{font-family:var(--display);font-weight:800;font-size:18px;margin:8px 0 4px;color:var(--ink)}
.btn-danger{background:transparent;color:var(--bad);border:1px solid rgba(255,92,108,.5)}
.btn-danger:hover{background:var(--bad);color:#fff;border-color:var(--bad)}
/* consentimiento (age-gate en signup) */
.consent{display:flex;align-items:flex-start;gap:10px;margin-top:14px;font-size:13px;color:var(--muted);line-height:1.45;cursor:pointer}
.consent input[type=checkbox]{width:18px;height:18px;flex:0 0 auto;margin-top:1px;accent-color:var(--accent);cursor:pointer}
.consent a{color:var(--accent);text-decoration:none}
.consent a:hover{text-decoration:underline}
/* link discreto (¿olvidaste tu contraseña?) */
.linklike{display:inline-block;margin-top:12px;background:none;border:0;padding:0;color:var(--muted);font-family:var(--serif);font-size:13px;cursor:pointer;text-decoration:none}
.linklike:hover{color:var(--accent);text-decoration:underline}
.linklike.hidden{display:none}

/* Yo · ajustes (tema / idioma) */
.setrow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.setrow:last-child{border-bottom:0}
.set-k{font-size:14px;color:var(--ink);font-weight:600}
.setseg{width:auto;display:inline-flex}

/* --- motion: sutil, premium (no toca el informe pesado) --- */
@keyframes reveal-up{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.screen-head,.chiprow,.coachcard,.retest,.statgrid,.reveal{animation:reveal-up .34s cubic-bezier(.2,.7,.3,1) both}
.screen-head{animation-duration:.26s}
.coachcard{animation-delay:.05s}.retest{animation-delay:.03s}
.reveal:nth-child(3){animation-delay:.05s}.reveal:nth-child(4){animation-delay:.09s}.reveal:nth-child(5){animation-delay:.13s}
.btn{transition:transform .08s ease,filter .15s,background .15s,border-color .15s}
.btn:active{transform:translateY(1px) scale(.985)}
.tab{transition:color .15s,transform .08s}.tab:active{transform:scale(.92)}
.rounditem,.recentitem,.shareitem,.drillpill,.statbox{transition:border-color .15s,transform .1s,background .15s}
.rounditem:active,.recentitem:active{transform:scale(.99)}
@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important}}

/* ============================================================================
   TEMA CLARO (día) — html[data-theme="light"]. El oscuro es el default.
   En claro, --accent pasa a un verde más oscuro: legible como FILL de botón
   (texto blanco) Y como texto/acento sobre blanco. Los gradientes hardcodeados
   se reescriben acá.
   ============================================================================ */
html[data-theme="light"]{
  --bg:#F3F5F8; --bg-2:#ECEFF3; --surface:#FFFFFF; --surface-2:#F1F4F7;
  --ink:#16202B; --muted:#56616F; --faint:#97A1AE;
  --line:#DCE2E9; --line-soft:#E8ECF1;
  --accent:#4E9D1A; --accent-2:#1FA88A; --accent-ink:#FFFFFF;
  --good:#1FA055; --warn:#C6890B; --bad:#E0394A;
  --lime:#4E9D1A; --eyebrow:#6B7686;
  --navy:#2C4A86; --gold:#4E9D1A; --heather:#16202B; --card:#FFFFFF;
  --shadow:0 16px 40px rgba(22,32,43,.12);
}
html[data-theme="light"] body{background:radial-gradient(1100px 520px at 50% -8%, rgba(78,157,26,.07), transparent 62%), var(--bg)}
html[data-theme="light"] .topbar{background:linear-gradient(var(--bg),rgba(255,255,255,.85))}
html[data-theme="light"] .tabbar{background:rgba(255,255,255,.92)}
html[data-theme="light"] .coachcard,
html[data-theme="light"] .golfcard,
html[data-theme="light"] .stathero,
html[data-theme="light"] .sharedcta{background:linear-gradient(150deg,#FFFFFF,#EEF3F7 62%);border-color:#DCE2E9}
html[data-theme="light"] .retest--graduated{background:linear-gradient(120deg,rgba(31,160,85,.1),var(--surface-2))}
html[data-theme="light"] .lvlnode.on .lvldot{box-shadow:0 0 0 4px rgba(78,157,26,.16)}
html[data-theme="light"] .drillpill svg,
html[data-theme="light"] .focus-ic,
html[data-theme="light"] .badge.earned .badge-ic{color:var(--accent)}
html[data-theme="light"] .btn-primary{box-shadow:0 8px 22px rgba(78,157,26,.22)}
html[data-theme="light"] .sc-tog.on{color:#fff}
html[data-theme="light"] .ri-score{background:var(--bg-2)}
html[data-theme="light"] .lowconf,html[data-theme="light"] .fb-est{color:#8A5E00;background:rgba(198,137,11,.12);border-color:rgba(198,137,11,.4)}

/* QA fixes: ocultar acciones gated en la vista compartida; scorecard mobile */
.shared-mode #againBtn,.shared-mode #progBtn{display:none}
@media(max-width:480px){
  .card{padding:18px}
  .scorecard .schead,.scrow{gap:5px;grid-template-columns:24px 44px 1fr 1fr 30px 30px}
}

/* ============================================================================
   LANDING PAGE (pública, /) — marketing dark-sports premium
   ============================================================================ */
body.lp{padding:0}
.lp a{color:inherit}
.lp-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 22px;max-width:1140px;margin:0 auto;backdrop-filter:blur(10px);
  background:linear-gradient(var(--bg),rgba(10,13,18,.7))}
.lp-brand{display:flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;font-size:20px;color:var(--ink);text-decoration:none}
.lp-navlinks{display:flex;align-items:center;gap:22px;font-size:14.5px;font-weight:600}
.lp-navlinks a{color:var(--muted);text-decoration:none;transition:color .15s}
.lp-navlinks a:hover{color:var(--ink)}
.lp-navlinks .lp-login{color:var(--ink)}
.lp-navlinks .lp-cta{padding:10px 18px;font-size:14px;color:var(--accent-ink)}
.lp-navlinks .lp-cta:hover{color:var(--accent-ink)}

.lp-eyebrow{font-size:12px;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-2);font-weight:700}
.lp-eyebrow.center{text-align:center}
.lp-accent{color:var(--lime)}

.lp-hero{max-width:820px;margin:0 auto;padding:60px 22px 30px;text-align:center}
.lp-hero h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,8vw,68px);line-height:1.02;letter-spacing:-1.5px;margin:14px 0 0;color:var(--ink)}
.lp-sub{color:var(--muted);font-size:clamp(16px,2.4vw,19px);line-height:1.55;margin:20px auto 0;max-width:600px}
.lp-herocta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.lp-heronote{color:var(--faint);font-size:13px;margin-top:16px}

.lp-strip{max-width:1000px;margin:30px auto 0;padding:24px 22px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.lp-stripitem{display:flex;flex-direction:column;gap:5px}
.lp-stripitem b{font-family:var(--display);font-size:16px;color:var(--ink)}
.lp-stripitem span{font-size:13.5px;color:var(--muted);line-height:1.5}
.lp-stripitem em{color:var(--lime);font-style:normal;font-weight:600}

.lp-section{max-width:1080px;margin:0 auto;padding:74px 22px 0}
.lp-h2{font-family:var(--display);font-weight:800;font-size:clamp(28px,5vw,40px);letter-spacing:-.8px;text-align:center;margin:10px 0 0;color:var(--ink)}

.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
.lp-step{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:28px}
.lp-stepn{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:19px;background:var(--lime);color:var(--accent-ink)}
.lp-step h3{font-family:var(--display);font-weight:700;font-size:19px;margin:16px 0 0;color:var(--ink)}
.lp-step p{color:var(--muted);font-size:14.5px;line-height:1.55;margin:8px 0 0}

.lp-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.lp-feat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px}
.lp-featic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:22px;font-weight:800;background:var(--surface-2);color:var(--accent-2);border:1px solid var(--line)}
.lp-feat h3{font-family:var(--display);font-weight:700;font-size:17px;margin:15px 0 0;color:var(--ink)}
.lp-feat p{color:var(--muted);font-size:14px;line-height:1.55;margin:7px 0 0}

.lp-pricing{display:grid;grid-template-columns:repeat(2,minmax(0,340px));gap:18px;justify-content:center;margin-top:42px}
.lp-plan{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:30px}
.lp-plan--pro{background:linear-gradient(160deg,#18222E,#131A23 65%);border-color:#2A3647}
.lp-planbadge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--lime);color:var(--accent-ink);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:5px 13px;border-radius:999px}
.lp-planname{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink)}
.lp-planprice{font-family:var(--display);font-weight:800;font-size:46px;color:var(--ink);margin:6px 0 0;font-variant-numeric:tabular-nums}
.lp-planprice span{font-size:16px;font-weight:600;color:var(--muted)}
.lp-planfeats{list-style:none;padding:0;margin:20px 0 0;display:flex;flex-direction:column;gap:11px}
.lp-planfeats li{position:relative;padding-left:26px;font-size:14.5px;color:var(--muted);line-height:1.4}
.lp-planfeats li b{color:var(--ink)}
.lp-planfeats li::before{content:"✓";position:absolute;left:0;color:var(--accent-2);font-weight:800}
.lp-planbtn{display:block;text-align:center;margin-top:24px;text-decoration:none}
.lp-pricenote{text-align:center;color:var(--faint);font-size:13px;margin-top:18px}

.lp-faq{max-width:760px}
.lp-q{border-bottom:1px solid var(--line-soft);padding:4px 0}
.lp-q summary{cursor:pointer;list-style:none;padding:16px 0;font-family:var(--display);font-weight:600;font-size:17px;color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.lp-q summary::-webkit-details-marker{display:none}
.lp-q summary::after{content:"+";color:var(--accent-2);font-size:22px;font-weight:400}
.lp-q[open] summary::after{content:"–"}
.lp-q p{color:var(--muted);font-size:14.5px;line-height:1.6;margin:0 0 16px}
.lp-faq .lp-h2{margin-bottom:8px}

.lp-final{max-width:760px;margin:90px auto 0;padding:60px 22px;text-align:center;border-top:1px solid var(--line-soft)}
.lp-final h2{font-family:var(--display);font-weight:800;font-size:clamp(26px,4.5vw,38px);letter-spacing:-.6px;color:var(--ink);margin:0 0 26px;line-height:1.1}

.lp-footer{max-width:1080px;margin:70px auto 0;padding:34px 22px 50px;border-top:1px solid var(--line-soft);
  display:flex;flex-direction:column;align-items:center;gap:16px}
.lp-foot-brand{display:flex;align-items:center;gap:8px;font-family:var(--display);font-weight:800;font-size:17px;color:var(--ink)}
.lp-footlinks{display:flex;gap:22px;font-size:14px}
.lp-footlinks a{color:var(--muted);text-decoration:none}.lp-footlinks a:hover{color:var(--ink)}
.lp-foot-fine{color:var(--faint);font-size:12.5px;text-align:center}

@media(max-width:760px){
  .lp-navlinks{gap:14px}.lp-navlinks a:not(.lp-cta):not(.lp-login){display:none}
  .lp-strip,.lp-steps,.lp-features{grid-template-columns:1fr}
  .lp-pricing{grid-template-columns:1fr}
  .lp-section{padding-top:56px}
}

/* legal pages (términos / privacidad) */
.legal{max-width:760px;margin:0 auto;padding:40px 22px 80px}
.legal h1{font-family:var(--display);font-weight:800;font-size:32px;letter-spacing:-.6px;color:var(--ink)}
.legal h2{font-family:var(--display);font-weight:700;font-size:20px;margin:30px 0 0;color:var(--ink)}
.legal p,.legal li{color:var(--muted);font-size:15px;line-height:1.65}
.legal .legal-meta{color:var(--faint);font-size:13px;margin-top:6px}
.legal a{color:var(--lime)}

/* --- toast --- */
.toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%,12px);z-index:60;opacity:0;pointer-events:none;
  background:var(--surface-2);color:var(--ink);border:1px solid var(--line);border-radius:11px;padding:11px 16px;
  font-size:13.5px;box-shadow:var(--shadow);transition:opacity .2s,transform .2s;max-width:88vw}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* desktop: center the app column like a tall phone, tab-bar follows */
@media(min-width:720px){
  .tabbar{padding-left:0;padding-right:0}
  .tab{max-width:120px}
}
