:root {
  --bg: #0B0D10;
  --surface: #12151B;
  --surface2: #1A1E27;
  --surface3: #222733;
  --border: #2A3040;
  --text: #E4E8F1;
  --text-dim: #8B93A8;
  --green: #4ADE80;
  --green-dim: rgba(74,222,128,0.10);
  --green-glow: rgba(74,222,128,0.25);
  --red: #FB7185;
  --red-dim: rgba(251,113,133,0.10);
  --amber: #FCD34D;
  --amber-dim: rgba(252,211,77,0.10);
  --blue: #60A5FA;
  --blue-dim: rgba(96,165,250,0.10);
  --violet: #A78BFA;
  --violet-dim: rgba(167,139,250,0.10);
  --cyan: #22D3EE;
  --cyan-dim: rgba(34,211,238,0.10);
  --rose: #F472B6;
  --rose-dim: rgba(244,114,182,0.10);
  --orange: #FB923C;
  --orange-dim: rgba(251,146,60,0.10);
  --teal: #2DD4BF;
  --teal-dim: rgba(45,212,191,0.10);
}

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Nunito Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;-webkit-tap-highlight-color:transparent;overflow-x:hidden}

.grain{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

header{padding:14px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;background:rgba(11,13,16,0.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--green),#059669);display:flex;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:19px;color:var(--bg);font-weight:400}
.logo-name{font-family:'Instrument Serif',serif;font-size:21px;letter-spacing:0.5px}
.logo-name em{font-style:normal;color:var(--green);font-weight:400}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.live-pill{display:flex;align-items:center;gap:6px;padding:4px 11px;border-radius:20px;background:var(--red-dim);color:var(--red);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;opacity:0;transition:opacity .3s}
.live-pill.on{opacity:1}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.container{max-width:1280px;margin:0 auto;padding:24px}

/* Panels */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:16px;overflow:hidden;position:relative}
.panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--green),transparent 60%)}
.panel-body{padding:24px}

/* Mode Tabs */
.mode-tabs{display:flex;gap:4px;background:var(--bg);border-radius:10px;padding:4px;margin-bottom:20px}
.mode-tab{flex:1;padding:10px 16px;border-radius:8px;border:none;background:transparent;color:var(--text-dim);font-family:'Nunito Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.mode-tab.active{background:var(--surface2);color:var(--text)}
.mode-tab svg{width:16px;height:16px}

/* JP main tabs (across the top of analysis view) */
.jp-tabs{display:flex;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:5px;margin:16px 0;max-width:1100px;flex-wrap:wrap}
.jp-tab{padding:9px 12px;border-radius:7px;border:none;background:transparent;color:var(--text-dim);font-family:'Nunito Sans',sans-serif;font-size:11.5px;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap}
/* Client-facing tabs get a subtle teal tint so the coach knows at a glance
   which tabs the client will see when the session is sent to them. Active
   state uses a stronger teal fill for clarity. */
.jp-tab-client{background:rgba(20,184,166,0.08);color:var(--teal);border:1px solid rgba(20,184,166,0.22)}
.jp-tab-client:hover:not(.active){background:rgba(20,184,166,0.18);color:var(--teal)}
.jp-tab-client.active{background:var(--teal);color:#0a1a18;border-color:var(--teal)}
.jp-tab.summary-tab{background:linear-gradient(135deg,rgba(20,184,166,0.15),rgba(20,184,166,0.08));color:var(--teal);border:1px solid rgba(20,184,166,0.3)}
.jp-tab.summary-tab.active{background:var(--teal);color:#0a1a18;border-color:var(--teal)}
.jp-tab.summary-tab:hover:not(.active){background:rgba(20,184,166,0.22)}
.jp-tab.admin-tab{color:var(--text-dim);opacity:0.85}
.jp-tab.admin-tab.active{background:var(--surface2);opacity:1}
.jp-tab.active{background:var(--surface2);color:var(--text)}
.jp-tab:hover:not(.active){color:var(--text)}
#sendToClientBtn:hover{transform:translateY(-1px);box-shadow:0 5px 18px rgba(74,222,128,0.35);filter:brightness(1.05)}
#sendToClientBtn.sent{background:var(--surface2);color:var(--text-dim);box-shadow:none}
#sendToClientBtn.sent:hover{transform:none;filter:none}
.sess-tab-opt{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s}
.sess-tab-opt:hover{border-color:var(--violet)}
.sess-tab-opt input[type="checkbox"]{margin-top:3px;accent-color:var(--violet);width:16px;height:16px;cursor:pointer}
.sess-tab-opt .opt-title{font-size:13px;font-weight:700;margin-bottom:2px}
.sess-tab-opt .opt-sub{font-size:11px;color:var(--text-dim);line-height:1.5}
/* Summary tab */
.summary-section{padding:36px 40px;border-bottom:1px solid var(--border);background:var(--surface)}
.summary-section:nth-child(even){background:var(--bg)}
.summary-section:last-child{border-bottom:none}
.summary-section-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.summary-section-icon{width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}
.summary-section-title{font-family:'Instrument Serif',serif;font-size:32px;font-weight:400;margin:0;color:var(--text);letter-spacing:-0.5px;line-height:1.1}
.summary-paywall{padding:36px 40px;border-bottom:1px solid var(--border);background:var(--bg);position:relative}
.summary-paywall:nth-child(even){background:var(--surface)}
.summary-paywall::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 12px,rgba(255,255,255,0.015) 12px,rgba(255,255,255,0.015) 24px);pointer-events:none}
.summary-paywall .summary-section-title{font-size:26px}
/* Admin tab */
.admin-section{margin-bottom:18px;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.admin-section-title{padding:14px 20px;background:var(--bg);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);border-bottom:1px solid var(--border)}
.admin-section-body{padding:18px 20px}
.ai-feature-run-btn{flex-shrink:0;align-self:center;padding:7px 14px;background:var(--violet);color:#0b0d10;border:none;border-radius:7px;font-family:'Nunito Sans';font-size:11px;font-weight:800;letter-spacing:.4px;cursor:pointer;transition:all .15s;white-space:nowrap}
.ai-feature-run-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}
.ai-feature-run-btn:disabled{opacity:0.4;cursor:not-allowed;transform:none}
/* Playback transport — two-button play/pause control */
.playback-transport-btn{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg);color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}
.playback-transport-btn:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-1px)}
.playback-transport-btn.active{background:var(--teal);color:#0b0d10;border-color:var(--teal);box-shadow:0 0 14px rgba(20,184,166,0.35)}
.playback-transport-btn.active:hover{filter:brightness(1.1);transform:translateY(-1px)}
.playback-transport-btn:disabled{opacity:0.35;cursor:not-allowed;transform:none}
.playback-transport-btn.play.active svg{margin-left:2px} /* visual centering for play triangle */
/* Star button on spice rows */
.star-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:18px;line-height:1;padding:0 4px;transition:all .15s}
.star-btn:hover{color:#FBBF24;transform:scale(1.15)}
.star-btn.on{color:#FBBF24;text-shadow:0 0 8px rgba(251,191,36,0.5)}
/* Masked inputs — visually looks like a password field but type=text so browsers don't prompt to save */
.masked-input{-webkit-text-security:disc;text-security:disc;font-family:'JetBrains Mono',monospace;letter-spacing:1px}

/* 110STEPS specific styles */
.pkg-btn{padding:7px 14px;border-radius:7px;border:none;background:transparent;color:var(--text-dim);font-family:'Nunito Sans';font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px}
.pkg-btn.active{background:var(--violet);color:#fff}
.pkg-btn:hover:not(.active){color:var(--text);background:var(--surface2)}
.tu-btn{padding:6px 12px;border-radius:7px;border:none;background:transparent;color:var(--text-dim);font-family:'JetBrains Mono';font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.tu-btn.active{background:var(--teal);color:#fff}
.tu-btn:hover:not(.active){color:var(--text);background:var(--surface2)}
.spice-suggestion{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);font-size:13px;transition:background .1s}
.spice-suggestion:last-child{border-bottom:none}
.spice-suggestion:hover,.spice-suggestion.active{background:var(--surface2)}
.spice-suggestion .cat-tag{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.spice-suggestion .power-tag{font-family:'JetBrains Mono';font-size:10px;background:var(--bg);padding:2px 6px;border-radius:4px;color:var(--teal);font-weight:700}
.spice-entry-row{display:grid;grid-template-columns:60px 1fr 100px 60px 28px;gap:10px;align-items:center;padding:8px 10px;border-radius:7px;font-size:12px;cursor:pointer;transition:background .1s}
.spice-entry-row:hover{background:var(--bg)}
.spice-entry-row .ts{font-family:'JetBrains Mono';color:var(--text-dim);font-size:11px}
.spice-entry-row .ext-badge{display:inline-block;font-size:8px;padding:1px 5px;background:rgba(167,139,250,0.15);color:var(--violet);border-radius:3px;margin-left:6px;font-weight:700;text-transform:uppercase}
.spice-entry-row .pwr{font-family:'JetBrains Mono';font-weight:700;text-align:center;padding:2px 6px;border-radius:4px;font-size:11px}
.spice-entry-row .cat{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.spice-entry-row .del-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;opacity:0;transition:opacity .15s;font-size:14px}
.spice-entry-row:hover .del-btn{opacity:1}
.spice-entry-row .del-btn:hover{color:var(--red)}
.spice-entry-row .expand-chevron{display:inline-block;font-size:10px;color:var(--text-dim);transition:transform .2s;margin-left:auto}
.spice-entry-card{border-radius:8px;margin-bottom:2px}
.spice-entry-card:has(.spice-entry-desc[style*="block"]){background:var(--bg);border:1px solid var(--border);padding:2px}
.spice-entry-desc{padding:10px 14px 14px 70px;font-size:12px;line-height:1.55;color:var(--text);animation:descFadeIn .2s ease}
.spice-entry-desc .desc-block{margin-bottom:8px}
.spice-entry-desc .desc-block:last-child{margin-bottom:0}
.spice-entry-desc .desc-label{font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--teal);margin-bottom:3px}
@keyframes descFadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.steps110-sticky-header{position:sticky;top:0;z-index:10;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:stretch;gap:0;flex-wrap:wrap}
.steps110-video-wrap{flex:2 1 360px;min-width:280px;background:#000}
.steps110-score-panel{flex:1 1 260px;min-width:240px;padding:16px 20px;background:var(--bg);display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--border)}
@media (max-width:640px){
  .steps110-score-panel{border-left:none;border-top:1px solid var(--border)}
}
.skill-category-header{font-family:'Instrument Serif',serif;font-size:18px;font-weight:400;color:var(--violet);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.skill-category-header span.cat-count{font-family:'JetBrains Mono';font-size:10px;color:var(--text-dim);font-weight:400}
.category-overview-panel{margin:0 0 22px;padding:20px 22px;background:linear-gradient(135deg,rgba(20,184,166,0.04),rgba(167,139,250,0.03));border:1px solid var(--border);border-radius:14px}
.cat-overview-inner{display:grid;grid-template-columns:360px 1fr;gap:24px;align-items:start}
@media (max-width:900px){.cat-overview-inner{grid-template-columns:1fr}}
.cat-overview-chart{display:flex;align-items:center;justify-content:center}
.cat-overview-summaries{display:flex;flex-direction:column;gap:10px}
.cat-summaries-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;padding-bottom:8px;border-bottom:1px dashed var(--border)}
.cat-summary-regen{background:none;border:1px solid var(--border);color:var(--text-dim);font-size:10px;padding:4px 10px;border-radius:6px;cursor:pointer;font-weight:600}
.cat-summary-regen:hover:not(:disabled){color:var(--violet);border-color:var(--violet)}
.cat-summary-regen:disabled{opacity:0.5;cursor:wait}
.cat-summary-item{padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.04)}
.cat-summary-item:last-child{border-bottom:none}
.cat-summary-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.cat-summary-label{font-size:12px;font-weight:700;color:var(--text)}
.cat-summary-pct{font-family:'JetBrains Mono';font-size:11px;font-weight:700}
.cat-summary-text{font-size:11.5px;color:var(--text-dim);line-height:1.55}
.skill-row{display:grid;grid-template-columns:24px 1fr 120px 180px 24px 28px 28px 32px 32px;gap:10px;align-items:center;padding:10px 12px;background:var(--bg);border-radius:8px;margin-bottom:4px;border:1px solid transparent;transition:border-color .15s}
.skill-row:hover{border-color:rgba(167,139,250,0.15)}
.skill-row.touched{border-color:rgba(74,222,128,0.25)}
.skill-row.priority{border-color:rgba(252,211,77,0.5);background:rgba(252,211,77,0.03)}
.skill-row.strength{border-color:rgba(74,222,128,0.5);background:rgba(74,222,128,0.04)}
.skill-row.ai-scored:not(.touched){border-color:rgba(167,139,250,0.35);background:rgba(167,139,250,0.025)}
/* Deterministic "measured" skills get the same purple frame so the coach sees
   a consistent "this row has an auto-suggested score" visual cue — the icon
   on the chip (📊 vs ✨) tells them which source. Before this, measured rows
   looked like plain untouched rows and it was easy to miss that the app had
   already pre-filled a value. */
.skill-row.measured-scored:not(.touched){border-color:rgba(167,139,250,0.35);background:rgba(167,139,250,0.025)}
.ai-badge{display:inline-block;font-size:11px;margin-left:4px;vertical-align:baseline;cursor:help;filter:drop-shadow(0 0 3px rgba(167,139,250,0.4))}
.skill-ai-reason{font-size:10px;color:var(--violet);font-style:italic;margin-top:3px;line-height:1.4;opacity:0.85}
/* Source badges: at-a-glance chip showing where the current score came from */
.skill-source-chip{display:inline-flex;align-items:center;gap:4px;font-family:'Nunito Sans';font-size:9px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:2px 7px;border-radius:999px;margin-left:8px;vertical-align:middle;line-height:1.3;cursor:help}
.skill-source-chip.measured{background:rgba(20,184,166,0.14);color:var(--teal);border:1px solid rgba(20,184,166,0.35)}
.skill-source-chip.ai{background:rgba(167,139,250,0.14);color:var(--violet);border:1px solid rgba(167,139,250,0.35)}
.skill-source-chip.coach{background:rgba(74,222,128,0.14);color:var(--green);border:1px solid rgba(74,222,128,0.35)}
.skill-row.scored{border-left:2px solid var(--green)}
.skill-row.negative{border-left:2px solid var(--red)}
.skill-num{font-family:'JetBrains Mono';font-size:10px;color:var(--text-dim);text-align:center}
.skill-check{font-size:14px;color:var(--text-dim);text-align:center;user-select:none;transition:color .15s}
.skill-check.checked{color:var(--green);font-weight:700}
.skill-prio-btn{background:none;border:none;cursor:pointer;padding:4px;font-size:15px;border-radius:6px;color:var(--text-dim);transition:all .15s;line-height:1}
.skill-prio-btn:hover{background:var(--surface2)}
.skill-prio-btn.active{color:var(--amber)}
.skill-str-btn{background:none;border:none;cursor:pointer;padding:4px;font-size:14px;border-radius:6px;color:var(--text-dim);transition:all .15s;line-height:1;opacity:0.6}
.skill-str-btn:hover{background:var(--surface2);opacity:1}
.skill-str-btn.active{color:var(--green);opacity:1;text-shadow:0 0 6px rgba(74,222,128,0.4)}
.skill-name{font-size:13px;font-weight:600}
.skill-autoval{font-family:'JetBrains Mono';font-size:10px;color:var(--teal);margin-top:2px}
.skill-points{font-family:'JetBrains Mono';font-size:11px;color:var(--text-dim);display:flex;gap:8px}
.skill-points .minus{color:var(--red)}
.skill-points .plus{color:var(--green)}
.skill-slider-wrap{display:flex;align-items:center;gap:6px}
.skill-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--border);outline:none}
.skill-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--violet);cursor:pointer;border:2px solid var(--surface)}
.skill-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--violet);cursor:pointer;border:2px solid var(--surface)}
.skill-score-val{font-family:'JetBrains Mono';font-size:12px;font-weight:700;min-width:34px;text-align:center;padding:2px 6px;border-radius:5px;background:var(--surface2)}
.skill-score-val.positive{background:rgba(74,222,128,0.15);color:var(--green)}
.skill-score-val.negative{background:rgba(248,113,113,0.15);color:var(--red)}
.skill-cmt-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:6px;transition:all .15s;font-size:14px}
.skill-cmt-btn.has-comment{color:var(--teal)}
.skill-cmt-btn:hover{background:var(--surface2);color:var(--text)}
.skill-info-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:6px;font-size:14px;opacity:.5}
.skill-info-btn:hover{opacity:1}
.skill-comment-display{grid-column:1/-1;margin-top:6px;padding:8px 10px;background:rgba(45,212,191,0.06);border-left:2px solid var(--teal);border-radius:4px;font-size:12px;color:var(--text-dim);font-style:italic}

/* ===== CERTIFICATE LEVEL (Client View) ===== */
@keyframes certGlow{0%,100%{filter:drop-shadow(0 0 20px var(--cert-color))}50%{filter:drop-shadow(0 0 40px var(--cert-color))}}
@keyframes certFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.cert-wrap{margin-bottom:28px;padding:32px 24px;background:linear-gradient(135deg,var(--cert-bg,rgba(252,211,77,0.06)),rgba(0,0,0,0.3));border:1px solid var(--cert-border,rgba(252,211,77,0.25));border-radius:18px;text-align:center;position:relative;overflow:hidden;animation:certFadeIn .6s ease}
.cert-wrap::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,var(--cert-color,rgba(252,211,77,0.1)) 0%,transparent 45%);opacity:.25;pointer-events:none}
.cert-heading{font-family:'Nunito Sans';font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;margin-bottom:12px;position:relative;z-index:1}
.cert-img{width:120px;height:120px;margin:0 auto 16px;animation:certGlow 3s ease-in-out infinite;position:relative;z-index:1}
.cert-img::before{content:'';position:absolute;inset:-10%;background:radial-gradient(circle,var(--cert-color,var(--amber)) 0%,transparent 60%);opacity:.35;z-index:-1;border-radius:50%}
.cert-img img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 8px rgba(255,255,255,0.15))}
.cert-level-name{font-family:'Instrument Serif',serif;font-size:48px;font-weight:400;color:var(--cert-color,var(--amber));margin-bottom:4px;line-height:1;letter-spacing:.5px;position:relative;z-index:1}
.cert-tagline{font-family:'Instrument Serif',serif;font-size:20px;font-style:italic;color:var(--text);margin-bottom:20px;position:relative;z-index:1;font-weight:400}
.cert-description{font-size:14px;line-height:1.65;color:var(--text);max-width:560px;margin:0 auto 22px;position:relative;z-index:1}
.cert-score-display{display:inline-flex;align-items:baseline;gap:10px;padding:10px 20px;background:rgba(0,0,0,0.3);border:1px solid var(--cert-border,rgba(252,211,77,0.2));border-radius:999px;position:relative;z-index:1;margin-bottom:26px}
.cert-score-num{font-family:'JetBrains Mono';font-size:24px;font-weight:700;color:var(--cert-color,var(--amber))}
.cert-score-max{font-family:'JetBrains Mono';font-size:14px;color:var(--text-dim)}

/* Certificate ladder — all 6 levels on a horizontal line */
.cert-ladder{position:relative;padding:20px 30px 10px;margin:10px auto 0;max-width:900px;z-index:1}
.cert-ladder-track{position:relative;height:6px;background:#2A3040;border-radius:3px;margin:90px 0 80px;box-shadow:0 0 20px rgba(255,255,255,0.1)}

/* Icons sit ABOVE the track */
.cert-ladder-stop{position:absolute;bottom:100%;transform:translateX(-50%);text-align:center;width:80px;padding-bottom:14px}
.cert-ladder-stop-icon{width:44px;height:44px;margin:0 auto;transition:all .3s;background:#fff;border-radius:50%;padding:4px;box-sizing:border-box;box-shadow:0 2px 6px rgba(0,0,0,0.3)}
.cert-ladder-stop-icon img{width:100%;height:100%;object-fit:contain}
.cert-ladder-stop.current .cert-ladder-stop-icon{transform:scale(1.25);box-shadow:0 0 18px currentColor,0 2px 8px rgba(0,0,0,0.4)}
.cert-ladder-stop.locked{opacity:.45}
.cert-ladder-stop.locked .cert-ladder-stop-icon{filter:grayscale(0.9) brightness(0.85);background:#e5e5e5}
.cert-ladder-stop .lock-overlay{position:relative;display:inline-block;font-size:12px;margin-top:-12px;background:var(--surface);border-radius:50%;width:18px;height:18px;line-height:18px;border:1px solid var(--border)}
.cert-ladder-stop-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;margin-top:8px}
.cert-ladder-stop-range{font-family:'JetBrains Mono';font-size:9px;color:var(--text-dim);margin-top:2px}
/* Small down arrow pointing from each icon to the track */
.cert-ladder-stop::after{content:'';position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:7px solid currentColor;filter:drop-shadow(0 1px 2px rgba(0,0,0,0.3))}
.cert-ladder-stop.current::after{border-left-width:7px;border-right-width:7px;border-top-width:9px}
.cert-ladder-stop.locked::after{opacity:.4}

/* YOU marker hangs BELOW the track as a teardrop pin */
.cert-ladder-marker{position:absolute;top:100%;left:0;transform:translateX(-50%);transition:left .8s cubic-bezier(.4,2,.6,1);z-index:4;pointer-events:none}
.cert-ladder-marker-pin{position:relative;width:56px;height:64px;margin-top:8px;filter:drop-shadow(0 3px 10px rgba(0,0,0,0.4))}
.cert-ladder-marker-pin svg{width:100%;height:100%;display:block}
.cert-ladder-marker-score{position:absolute;top:16px;left:50%;transform:translateX(-50%);font-family:'Instrument Serif',serif;font-size:20px;font-weight:700;color:#111;line-height:1;letter-spacing:-0.5px}
.cert-ladder-marker-you{position:absolute;top:40px;left:50%;transform:translateX(-50%);font-family:'Nunito Sans';font-size:7px;font-weight:900;color:#111;letter-spacing:1.5px;text-transform:uppercase}
@keyframes pinDrop{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}60%{transform:translateX(-50%) translateY(6px)}100%{opacity:1;transform:translateX(-50%) translateY(0)}}
.cert-ladder-marker-pin{animation:pinDrop .8s cubic-bezier(.4,1.5,.6,1) both}

@media(max-width:640px){
  .cert-level-name{font-size:36px}
  .cert-tagline{font-size:16px}
  .cert-ladder-stop{width:52px}
  .cert-ladder-stop-icon{width:32px;height:32px}
  .cert-ladder-stop-label{font-size:8px}
  .cert-ladder-marker-pin{width:46px;height:54px}
  .cert-ladder-marker-score{font-size:16px}
}
.cert-upgrade-note{display:inline-block;margin:0 auto 22px;padding:10px 18px;background:rgba(167,139,250,0.08);border:1px solid rgba(167,139,250,0.3);border-radius:10px;font-size:12px;color:var(--text);line-height:1.5;max-width:560px;position:relative;z-index:1}
.cert-upgrade-note strong{color:var(--violet)}
.cert-diploma-btn{display:inline-flex;align-items:center;gap:8px;margin:0 auto 18px;padding:13px 26px;background:var(--cert-color,var(--amber));color:#000;border:none;border-radius:10px;font-family:'Nunito Sans';font-size:12px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;transition:all .2s;position:relative;z-index:2;box-shadow:0 4px 20px rgba(0,0,0,0.25)}
.cert-diploma-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,0.35);filter:brightness(1.1)}
.cert-diploma-btn-print{background:transparent;color:var(--cert-color,var(--amber));border:1.5px solid var(--cert-color,var(--amber))}
.cert-diploma-btn-print:hover{background:var(--cert-color,var(--amber));color:#000}

/* Client view — priority focus area cards */
.client-focus-section{margin-bottom:24px;padding:20px;background:linear-gradient(135deg,rgba(252,211,77,0.08),rgba(167,139,250,0.05));border:1px solid rgba(252,211,77,0.3);border-radius:14px}
.client-focus-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.client-focus-title{font-family:'Instrument Serif',serif;font-size:22px;color:var(--amber);font-weight:400}
.client-focus-intro{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:16px}
.client-focus-card{background:var(--surface);border:1px solid rgba(252,211,77,0.25);border-left:4px solid var(--amber);border-radius:10px;padding:16px;margin-bottom:10px}
.client-focus-card:last-child{margin-bottom:0}
.client-focus-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.7px;color:var(--amber);background:rgba(252,211,77,0.15);padding:3px 8px;border-radius:10px;text-transform:uppercase;margin-bottom:8px}
.client-focus-card .client-skill-head{margin-bottom:8px}
.client-focus-card .client-skill-body{border-top:1px solid rgba(252,211,77,0.15)}

/* Client view — read-only card layout with descriptions */
.client-skill-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:8px;transition:border-color .15s}
.client-skill-card.touched{border-color:rgba(167,139,250,0.25)}
.client-skill-card.untouched{opacity:.55}
.client-skill-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.client-skill-bar{width:100px;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}
.client-skill-body{padding:10px 0;border-top:1px solid var(--border)}
.client-skill-row{display:grid;grid-template-columns:90px 1fr;gap:12px;padding:6px 0;font-size:12px;line-height:1.5}
.client-skill-row > div{color:var(--text)}
.client-skill-label{font-family:'JetBrains Mono';font-size:9px;color:var(--text-dim);letter-spacing:.7px;font-weight:700;padding-top:2px}
.client-skill-comment{margin-top:10px;padding:12px 14px;background:linear-gradient(135deg,rgba(45,212,191,0.12),rgba(45,212,191,0.04));border:1px solid rgba(45,212,191,0.3);border-left:4px solid var(--teal);border-radius:8px;display:grid;grid-template-columns:90px 1fr;gap:12px;font-size:13px;color:var(--text);box-shadow:0 2px 8px rgba(45,212,191,0.08)}
.client-skill-comment > div:last-child{font-style:italic;line-height:1.55;font-weight:500}
.client-skill-comment .client-skill-label{color:var(--teal);font-weight:700}
@media(max-width:560px){
  .client-skill-row,.client-skill-comment{grid-template-columns:1fr}
  .client-skill-label{padding-bottom:4px}
}

@media(max-width:720px){
  .skill-row{grid-template-columns:24px 1fr;gap:8px}
  .skill-row > :nth-child(3),.skill-row > :nth-child(4),.skill-row > :nth-child(5),.skill-row > :nth-child(6),.skill-row > :nth-child(7),.skill-row > :nth-child(8){grid-column:2}
}

/* Fields */
.setup-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
@media(max-width:560px){.setup-fields{grid-template-columns:1fr}}
.field label{display:block;font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.field input,.field select{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:'Nunito Sans',sans-serif;font-size:14px}
.field input:focus,.field select:focus{outline:none;border-color:var(--green)}
.field input::placeholder{color:var(--text-dim)}
.api-row{margin-bottom:20px}
.api-row label{display:block;font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.api-input-wrap{display:flex;gap:8px}
.api-input-wrap input{flex:1;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:13px}
.api-input-wrap input:focus{outline:none;border-color:var(--green)}
.api-toggle{padding:10px 14px;border:1px solid var(--border);border-radius:9px;background:var(--surface2);color:var(--text-dim);cursor:pointer;font-size:13px;display:flex;align-items:center}

/* Mic */
.mic-area{display:flex;flex-direction:column;align-items:center;gap:10px;padding:8px 0}
.mic-btn{width:84px;height:84px;border-radius:50%;border:3px solid var(--green);background:var(--green-dim);color:var(--green);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s}
.mic-btn:hover{background:rgba(74,222,128,0.18)}
.mic-btn.rec{border-color:var(--red);background:var(--red-dim);color:var(--red);animation:pulse-ring 2s infinite}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(251,113,133,0.35)}70%{box-shadow:0 0 0 18px rgba(251,113,133,0)}100%{box-shadow:0 0 0 0 rgba(251,113,133,0)}}
@keyframes pulseLive{0%,100%{opacity:1}50%{opacity:0.35}}
.mic-btn svg{width:34px;height:34px}
.mic-text{font-size:13px;color:var(--text-dim);font-weight:600}
.mic-text b{color:var(--text)}
.timer{font-family:'JetBrains Mono';font-size:28px;font-weight:600;color:var(--text-dim);display:none}
.timer.on{display:block}

/* Upload Zone */
.upload-area{display:none}
.upload-area.on{display:block}
.upload-zone{width:100%;min-height:180px;background:var(--bg);border:2px dashed var(--border);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .3s;padding:24px}
.upload-zone:hover,.upload-zone.dragover{border-color:var(--green);background:var(--green-dim)}
.upload-zone-icon{width:52px;height:52px;border-radius:13px;background:var(--green-dim);display:flex;align-items:center;justify-content:center}
.upload-zone-icon svg{width:24px;height:24px;stroke:var(--green)}
.upload-zone-text{font-size:14px;color:var(--text-dim);text-align:center}
.upload-zone-text b{color:var(--text)}
.upload-zone-formats{font-size:11px;color:var(--text-dim);letter-spacing:.5px}
.file-input{display:none}

/* File loaded state */
.file-loaded{display:none;align-items:center;gap:14px;padding:16px 20px;background:var(--green-dim);border:1px solid rgba(74,222,128,0.2);border-radius:12px;margin-top:14px}
.file-loaded.on{display:flex}
.file-loaded-icon{width:40px;height:40px;border-radius:10px;background:var(--surface);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.file-loaded-icon svg{width:20px;height:20px;stroke:var(--green)}
.file-loaded-info{flex:1;min-width:0}
.file-loaded-name{font-weight:700;font-size:14px;color:var(--green);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-loaded-meta{font-size:12px;color:var(--text-dim);margin-top:2px}
.file-loaded-remove{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:22px;padding:0 6px;line-height:1}
.file-loaded-remove:hover{color:var(--red)}

/* Analyze button */
.analyze-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;border:none;background:linear-gradient(135deg,var(--green),#059669);color:var(--bg);font-family:'Nunito Sans';font-size:15px;font-weight:800;border-radius:12px;cursor:pointer;transition:all .2s;margin-top:16px}
.analyze-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px var(--green-glow)}
.analyze-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.analyze-btn svg{width:18px;height:18px}

/* Progress bar */
.progress-wrap{display:none;margin-top:16px}
.progress-wrap.on{display:block}
.progress-label{font-size:12px;font-weight:700;color:var(--text-dim);margin-bottom:8px;display:flex;justify-content:space-between}
.progress-track{height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green),#059669);border-radius:3px;transition:width .3s;width:0}

/* Video Preview */
.video-preview{display:none;margin-top:16px;border-radius:12px;overflow:hidden;background:var(--bg);border:1px solid var(--border)}
.video-preview.on{display:block}
.video-preview video,.video-preview audio{width:100%;display:block;max-height:300px;background:#000}

/* Transcript */
.transcript-panel{display:none}
.transcript-panel.on{display:block}
.transcript-hdr{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.transcript-hdr h3{font-family:'Instrument Serif',serif;font-size:16px;font-weight:400}
.wc-badge{margin-left:auto;font-family:'JetBrains Mono';font-size:11px;color:var(--text-dim);padding:3px 10px;background:var(--bg);border-radius:6px}
.transcript-scroll{padding:18px 20px;max-height:280px;overflow-y:auto;font-size:13.5px;line-height:1.85;color:var(--text-dim)}
/* ====================================================================
   FUNCTIONAL PACE — Highlighter marks
   ====================================================================
   Each word in the transcript is wrapped in a span[data-start]; when a
   word falls inside a saved mark range we add fp-mark-important or
   fp-mark-setup. The first word of a mark also gets fp-mark-edge-start
   and the last gets fp-mark-edge-end so we can round only the outer
   corners — making contiguous marked words look like one continuous
   highlighter stroke rather than a row of pills. */
.fp-mark-important{
  background:rgba(248,113,113,0.32);
  color:#fff;
  box-shadow:inset 0 -1px 0 rgba(239,68,68,0.6);
  padding:1px 0;
  margin:0 -1px;
}
.fp-mark-important.fp-mark-edge-start{
  border-radius:4px 0 0 4px;
  padding-left:4px;
  margin-left:0;
}
.fp-mark-important.fp-mark-edge-end{
  border-radius:0 4px 4px 0;
  padding-right:4px;
  margin-right:0;
}
.fp-mark-important.fp-mark-edge-start.fp-mark-edge-end{
  border-radius:4px;
}
.fp-mark-setup{
  background:rgba(74,222,128,0.28);
  color:#fff;
  box-shadow:inset 0 -1px 0 rgba(16,185,129,0.6);
  padding:1px 0;
  margin:0 -1px;
}
.fp-mark-setup.fp-mark-edge-start{
  border-radius:4px 0 0 4px;
  padding-left:4px;
  margin-left:0;
}
.fp-mark-setup.fp-mark-edge-end{
  border-radius:0 4px 4px 0;
  padding-right:4px;
  margin-right:0;
}
.fp-mark-setup.fp-mark-edge-start.fp-mark-edge-end{
  border-radius:4px;
}
/* Live drag preview — same colors but lighter, so the user sees what they're
   about to paint. Cleared on mouseup. */
.fp-mark-important-preview{
  background:rgba(248,113,113,0.18);
  border-radius:3px;
}
.fp-mark-setup-preview{
  background:rgba(74,222,128,0.18);
  border-radius:3px;
}
/* When the highlighter is active, change cursor + suppress text selection so the
   drag-paint feels like a real highlighter, not a text selection. */
.transcript-scroll.fp-marking-on{
  cursor:crosshair;
  user-select:none;
  -webkit-user-select:none;
}
.transcript-scroll.fp-marking-on span[data-start]{
  cursor:crosshair;
}

/* Highlighter toolbar buttons. Compact pill style with subtle accents so the
   toolbar reads as "tools" not "filters". */
.fp-tool-btn{
  background:transparent;
  color:var(--text-dim);
  border:1px solid var(--border);
  font-family:'Nunito Sans',sans-serif;
  font-size:11px;
  font-weight:700;
  padding:5px 11px;
  border-radius:6px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:5px;
  letter-spacing:.2px;
  transition:all .15s;
}
.fp-tool-btn:hover{
  color:#fff;
  border-color:rgba(255,255,255,0.3);
}
.fp-tool-btn.active{
  color:#fff;
  background:rgba(255,255,255,0.06);
  border-color:rgba(255,255,255,0.35);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.05);
}
.fp-tool-btn.fp-tool-important.active{
  color:#fff;
  background:rgba(248,113,113,0.22);
  border-color:rgba(248,113,113,0.65);
}
.fp-tool-btn.fp-tool-important:not(.active){
  color:rgba(252,165,165,0.85);
  border-color:rgba(248,113,113,0.25);
}
.fp-tool-btn.fp-tool-setup.active{
  color:#fff;
  background:rgba(74,222,128,0.22);
  border-color:rgba(74,222,128,0.6);
}
.fp-tool-btn.fp-tool-setup:not(.active){
  color:rgba(134,239,172,0.85);
  border-color:rgba(74,222,128,0.22);
}
.transcript-scroll::-webkit-scrollbar{width:3px}
.transcript-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

.hl-strong{color:var(--green);font-weight:700}
.hl-weak{color:var(--red);font-weight:700}
.hl-filler{color:var(--amber);font-weight:700}
.hl-filler-s{color:var(--amber);font-weight:700;font-style:italic}
.hl-neg{color:var(--blue);font-weight:700}
.hl-imp{color:var(--cyan);font-weight:700}
.hl-hedge{color:var(--orange);font-weight:700}
.hl-sense{color:var(--rose);font-weight:700;text-decoration:underline;text-decoration-color:rgba(244,114,182,0.3);text-underline-offset:2px}
.interim{opacity:.35}
.tw{transition:background .15s,box-shadow .15s;border-radius:3px;padding:1px 2px;cursor:pointer}
.tw:hover{background:rgba(255,255,255,0.08)}
.tw.now-playing{background:rgba(20,184,166,0.32);color:#fff;box-shadow:0 0 0 1px rgba(20,184,166,0.6)}

/* Transcript toggles */
.hl-toggle{padding:3px 10px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-dim);font-family:'Nunito Sans';font-size:10px;font-weight:700;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:5px}
.hl-toggle.on{background:var(--surface2);color:var(--text);border-color:var(--green)}
.hl-toggle:hover{border-color:var(--text-dim)}
/* Color dots on toggles matching transcript highlight colors */
.hl-cat-strong::before,.hl-cat-weak::before,.hl-cat-filler::before,.hl-cat-filler-s::before,.hl-cat-neg::before,.hl-cat-imp::before,.hl-cat-hedge::before,.hl-cat-sense::before{content:'';width:7px;height:7px;border-radius:50%;flex-shrink:0}
.hl-cat-strong::before{background:var(--green)}
.hl-cat-weak::before{background:var(--red)}
.hl-cat-filler::before{background:var(--amber)}
.hl-cat-filler-s::before{background:var(--amber);box-shadow:inset 0 0 0 1px var(--bg)}
.hl-cat-neg::before{background:var(--blue)}
.hl-cat-imp::before{background:var(--cyan)}
.hl-cat-hedge::before{background:var(--orange)}
.hl-cat-sense::before{background:var(--rose)}
/* When active, border-color matches category */
.hl-cat-strong.on{border-color:var(--green)}
.hl-cat-weak.on{border-color:var(--red)}
.hl-cat-filler.on,.hl-cat-filler-s.on{border-color:var(--amber)}
.hl-cat-neg.on{border-color:var(--blue)}
.hl-cat-imp.on{border-color:var(--cyan)}
.hl-cat-hedge.on{border-color:var(--orange)}
.hl-cat-sense.on{border-color:var(--rose)}

/* Dashboard */
.dash{display:none}
.dash.on{display:flex;flex-direction:column;gap:28px}

/* Auto Analysis section organization. Section headers + panels are ordered via flex
   `order` so we reorganize visually without moving HTML. Each panel's order value is
   assigned by JS in _organizeAutoTab(). Default order (for anything we forgot to
   assign) is 9999 so it sinks to the bottom. The `gap` above gives consistent
   vertical breathing room between every subsection without relying on per-panel
   margins (which drift as panels get restyled). */
.dash > *{order:9999}
.auto-section-header{
  order:0;
  display:flex;align-items:center;gap:18px;
  margin:52px 0 22px;padding:26px 28px 26px 32px;
  font-family:'Instrument Serif',serif;
  font-size:42px;font-weight:400;line-height:1.05;
  color:var(--text);letter-spacing:0.3px;
  background:linear-gradient(90deg,rgba(167,139,250,0.14),rgba(20,184,166,0.04) 55%,transparent);
  border-left:6px solid var(--violet);
  border-top:1px solid rgba(255,255,255,0.04);
  border-bottom:1px solid rgba(255,255,255,0.04);
  border-radius:0 18px 18px 0;
  position:relative;
  box-shadow:0 2px 0 rgba(255,255,255,0.03) inset, 0 14px 38px -18px rgba(0,0,0,0.55);
}
.auto-section-header::before{
  content:'';position:absolute;left:-6px;top:-10px;bottom:-10px;width:6px;
  background:inherit;filter:blur(14px);opacity:0.7;z-index:-1;
}
.auto-section-header::after{
  content:'';flex:1;height:2px;
  background:linear-gradient(90deg,rgba(255,255,255,0.14),transparent 70%);
  margin-left:10px;margin-top:4px;
  border-radius:2px;
}
.auto-section-header > span:nth-of-type(1){
  /* title */
  text-shadow:0 2px 24px rgba(0,0,0,0.4);
}
.auto-section-header .section-icon{
  width:64px;height:64px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;flex-shrink:0;
  background:linear-gradient(135deg,var(--violet),#8B5CF6);
  box-shadow:0 10px 28px rgba(167,139,250,0.38), 0 0 0 1px rgba(255,255,255,0.08) inset;
}
.auto-section-header .section-sub{
  font-family:'Nunito Sans',sans-serif;font-size:10.5px;
  color:var(--text-dim);font-weight:800;
  text-transform:uppercase;letter-spacing:1.6px;
  margin-left:10px;align-self:center;
  padding:5px 11px;border-radius:999px;
  background:rgba(255,255,255,0.035);
  border:1px solid rgba(255,255,255,0.06);
}
/* Per-section accent colours — each section gets its own stripe + icon gradient */
#autoSectionImmersion{border-left-color:var(--rose);background:linear-gradient(90deg,rgba(244,114,182,0.11),rgba(244,114,182,0.02) 60%,transparent)}
#autoSectionImmersion .section-icon{background:linear-gradient(135deg,var(--rose),#E11D48);box-shadow:0 6px 18px rgba(244,114,182,0.28)}
#autoSectionClarity{border-left-color:var(--green);background:linear-gradient(90deg,rgba(74,222,128,0.11),rgba(74,222,128,0.02) 60%,transparent)}
#autoSectionClarity .section-icon{background:linear-gradient(135deg,var(--green),#059669);box-shadow:0 6px 18px rgba(74,222,128,0.28)}
#autoSectionLanguage{border-left-color:var(--violet);background:linear-gradient(90deg,rgba(167,139,250,0.11),rgba(167,139,250,0.02) 60%,transparent)}
#autoSectionLanguage .section-icon{background:linear-gradient(135deg,var(--violet),#7C3AED);box-shadow:0 6px 18px rgba(167,139,250,0.28)}
#autoSectionCoachNotes{border-left-color:var(--teal);background:linear-gradient(90deg,rgba(20,184,166,0.11),rgba(20,184,166,0.02) 60%,transparent)}
#autoSectionCoachNotes .section-icon{background:linear-gradient(135deg,var(--teal),#0D9488);box-shadow:0 6px 18px rgba(20,184,166,0.28)}
#autoSectionExtras{border-left-color:var(--amber);background:linear-gradient(90deg,rgba(251,191,36,0.11),rgba(251,191,36,0.02) 60%,transparent)}
#autoSectionExtras .section-icon{background:linear-gradient(135deg,var(--amber),#EA580C);box-shadow:0 6px 18px rgba(251,191,36,0.28)}

/* Hide the first section divider's top margin so it sits flush below the AI observations */
.auto-section-header:first-of-type{margin-top:12px}

/* Teaching-moment callout — injected below each subsection's data. Displays the
   AI Coach feedback for that panel in a consistent, inviting design. Panels with
   existing dynamic coaching text (pauseNote, dop-hint, sense levelHint) use this
   class directly; panels without dynamic text get a static default via addTeach(). */
.auto-sub-teach{
  display:flex;gap:12px;align-items:flex-start;
  margin:16px 0 0;padding:13px 15px;
  background:linear-gradient(135deg,rgba(167,139,250,0.08),rgba(20,184,166,0.04) 70%,transparent);
  border:1px solid rgba(167,139,250,0.25);
  border-radius:11px;
  font-size:13px;line-height:1.55;
  color:var(--text);
}
.auto-sub-teach-icon{
  flex-shrink:0;
  font-size:18px;line-height:1.2;
  margin-top:1px;
}
.auto-sub-teach-label{
  display:block;
  font-family:'Nunito Sans',sans-serif;
  font-size:9.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:1.1px;
  color:var(--violet);
  margin-bottom:4px;
}

/* AI Coach icon in the top-right of every subsection header. Hover reveals a
   rich tooltip with the AI-generated coaching feedback for that metric. The icon
   itself is a gradient speech-bubble badge with a soft pulse so it reads as
   "there's something to click on". The tooltip (.auto-sub-coach-tip) is a
   sibling element that pops up on hover — built with CSS-only visibility so it
   works without any JS wiring. */
.auto-sub-coach-icon-wrap{
  position:relative;
  margin-left:auto;
  display:inline-flex;
  flex-shrink:0;
}
.auto-sub-coach-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:14px;
  background:linear-gradient(135deg,#A78BFA 0%,#8B5CF6 60%,#14B8A6 130%);
  border:1px solid rgba(255,255,255,0.14);
  box-shadow:
    0 6px 20px rgba(167,139,250,0.35),
    0 0 0 1px rgba(167,139,250,0.3),
    inset 0 1px 0 rgba(255,255,255,0.25);
  font-size:20px;line-height:1;cursor:help;
  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
  position:relative;
  z-index:1;
}
.auto-sub-coach-icon::before{
  content:'';position:absolute;inset:-4px;border-radius:18px;
  background:radial-gradient(circle,rgba(167,139,250,0.4),transparent 65%);
  z-index:-1;opacity:0.6;
  animation:coachIconPulse 2.8s ease-in-out infinite;
}
@keyframes coachIconPulse{
  0%,100%{transform:scale(0.92);opacity:0.45}
  50%{transform:scale(1.08);opacity:0.7}
}
.auto-sub-coach-icon:hover{
  transform:scale(1.08) translateY(-1px);
  box-shadow:
    0 10px 28px rgba(167,139,250,0.5),
    0 0 0 2px rgba(167,139,250,0.4),
    inset 0 1px 0 rgba(255,255,255,0.35);
  filter:brightness(1.08);
}
.auto-sub-coach-icon-wrap[data-state="empty"] .auto-sub-coach-icon{
  background:linear-gradient(135deg,#3A4050 0%,#2A3040 100%);
  box-shadow:0 2px 8px rgba(0,0,0,0.3);
  filter:grayscale(0.2);
}
.auto-sub-coach-icon-wrap[data-state="empty"] .auto-sub-coach-icon::before{
  display:none;
}

/* Rich hover tooltip — 320px wide, positioned to the bottom-left of the icon so
   it stays inside the panel. Shows the AI Coach label + the dynamic tip text. */
.auto-sub-coach-tip{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  width:340px;max-width:80vw;
  padding:16px 18px;
  background:linear-gradient(145deg,rgba(23,27,38,0.98),rgba(16,19,27,0.98));
  border:1px solid rgba(167,139,250,0.3);
  border-radius:14px;
  box-shadow:0 24px 60px -12px rgba(0,0,0,0.7), 0 0 0 1px rgba(167,139,250,0.1);
  font-family:'Nunito Sans',sans-serif;
  font-size:13px;line-height:1.6;color:var(--text);
  opacity:0;pointer-events:none;
  transform:translateY(-6px);
  transition:opacity .18s ease, transform .18s ease;
  z-index:50;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.auto-sub-coach-tip::before{
  /* little arrow pointing up at the icon */
  content:'';position:absolute;top:-7px;right:15px;width:12px;height:12px;
  background:linear-gradient(145deg,rgba(23,27,38,0.98),rgba(16,19,27,0.98));
  border-top:1px solid rgba(167,139,250,0.3);
  border-left:1px solid rgba(167,139,250,0.3);
  transform:rotate(45deg);
}
.auto-sub-coach-icon-wrap:hover .auto-sub-coach-tip,
.auto-sub-coach-icon-wrap:focus-within .auto-sub-coach-tip{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.auto-sub-coach-tip-label{
  display:flex;align-items:center;gap:8px;
  font-size:10px;font-weight:800;
  color:var(--violet);
  text-transform:uppercase;letter-spacing:1.2px;
  margin-bottom:8px;
}
.auto-sub-coach-tip-label-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--violet);
  box-shadow:0 0 8px var(--violet);
}
.auto-sub-coach-tip-body{color:var(--text);font-size:13px;line-height:1.6}
.auto-sub-coach-tip-empty{
  color:var(--text-dim);
  font-style:italic;
  font-size:12.5px;
}

/* "Show All" toggles — consistent look for the <details>/<summary> collapsibles
   used across Dopamine, Sense Immersion, Rhetorical Devices to reveal full lists. */
.auto-sub-showall{margin-top:12px}
.auto-sub-showall > summary{
  font-size:10px;font-weight:800;color:var(--text-dim);
  cursor:pointer;text-transform:uppercase;letter-spacing:.8px;
  padding:6px 10px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:7px;
  display:inline-block;
  list-style:none;
  transition:border-color .15s, color .15s;
}
.auto-sub-showall > summary::-webkit-details-marker{display:none}
.auto-sub-showall > summary:hover{border-color:var(--violet);color:var(--violet)}
.auto-sub-showall[open] > summary{border-color:var(--violet);color:var(--violet)}

/* Consistent, prominent help text below every subsection title. Injected by
   _organizeAutoTab via addHelp() so every panel gets one without cluttering the
   HTML. The data-accent attribute picks the border/tint colour to match the
   section theme (rose=Immersion, green=Clarity, violet=Language, amber=Extras). */
.auto-sub-help{
  font-size:13.5px;
  color:var(--text);
  line-height:1.55;
  margin:0 0 18px;
  padding:11px 14px;
  background:var(--bg);
  border-left:3px solid var(--teal);
  border-radius:0 9px 9px 0;
}
.auto-sub-help[data-accent="rose"]{border-left-color:var(--rose);background:linear-gradient(90deg,rgba(244,114,182,0.07),var(--bg))}
.auto-sub-help[data-accent="green"]{border-left-color:var(--green);background:linear-gradient(90deg,rgba(74,222,128,0.07),var(--bg))}
.auto-sub-help[data-accent="violet"]{border-left-color:var(--violet);background:linear-gradient(90deg,rgba(167,139,250,0.08),var(--bg))}
.auto-sub-help[data-accent="amber"]{border-left-color:var(--amber);background:linear-gradient(90deg,rgba(251,191,36,0.07),var(--bg))}
.auto-sub-help[data-accent="teal"]{border-left-color:var(--teal);background:linear-gradient(90deg,rgba(20,184,166,0.07),var(--bg))}

/* Normalize subsection title sizing across all panel types so every subsection
   reads at the same visual weight regardless of the underlying panel class. */
.rhet-panel > div:first-of-type h3,
.zone-chart-panel .zone-chart-header h3,
.emotion-panel > div:first-of-type h3{
  font-family:'Instrument Serif',serif;
  font-size:19px;
  font-weight:400;
  margin:0;
  letter-spacing:0.2px;
}

/* Unified subsection icon — same 32x32 rounded box with tinted background that
   the zone charts use, now applied to every subsection for visual consistency.
   The data-tint attribute selects the background colour to match the panel's
   existing stroke/theme colour. The inner SVG is sized 18x18 to match the
   zone-chart-icon pattern. */
.auto-sub-icon{
  width:32px;height:32px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.auto-sub-icon[data-tint="rose"]{background:var(--rose-dim)}
.auto-sub-icon[data-tint="green"]{background:var(--green-dim)}
.auto-sub-icon[data-tint="violet"]{background:var(--violet-dim)}
.auto-sub-icon[data-tint="teal"]{background:var(--teal-dim)}
.auto-sub-icon[data-tint="amber"]{background:var(--amber-dim)}
.auto-sub-icon[data-tint="red"]{background:var(--red-dim)}
.auto-sub-icon[data-tint="orange"]{background:var(--orange-dim)}
.auto-sub-icon[data-tint="blue"]{background:var(--blue-dim)}
.auto-sub-icon[data-tint="cyan"]{background:var(--cyan-dim)}
.auto-sub-icon svg{width:18px;height:18px;display:block}

/* Dedicated Dopamine Language card — violet-accented, compact, sits at the top of
   the Immersion section. Pulls score from get110AutoValues() at render time. */
.dopamine-card{
  background:linear-gradient(135deg,rgba(167,139,250,0.08),rgba(20,184,166,0.04));
  border:1px solid rgba(167,139,250,0.3);
  border-radius:14px;padding:22px 24px;margin-bottom:12px;
}
.dopamine-card .dop-header{
  display:flex;align-items:center;gap:12px;margin-bottom:14px;
}
.dopamine-card .dop-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--violet),#8B5CF6);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
  box-shadow:0 0 18px rgba(167,139,250,0.35);
}
.dopamine-card h4{
  font-family:'Instrument Serif',serif;
  font-size:19px;font-weight:400;margin:0;
  color:var(--text);
}
.dopamine-card .dop-score-row{
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
  margin:4px 0 18px;
}
.dopamine-card .dop-score-big{
  font-family:'Instrument Serif',serif;
  font-size:42px;font-weight:400;line-height:1;
  color:var(--violet);
}
.dopamine-card .dop-score-label{
  font-family:'Nunito Sans',sans-serif;
  font-size:13px;color:var(--text);
  text-transform:uppercase;letter-spacing:0.8px;font-weight:800;
}
.dopamine-card .dop-score-density{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--text-dim);
}
.dopamine-card .dop-cats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:8px;
}
.dopamine-card .dop-cat{
  display:flex;align-items:center;gap:8px;
  padding:7px 11px;background:var(--bg);
  border:1px solid var(--border);border-radius:8px;
  font-size:11px;
}
.dopamine-card .dop-cat-name{flex:1;color:var(--text-dim)}
.dopamine-card .dop-cat-count{
  font-family:'JetBrains Mono',monospace;
  font-weight:700;color:var(--violet);
}
.dopamine-card .dop-empty{
  padding:14px;text-align:center;font-size:12px;
  color:var(--text-dim);font-style:italic;
}
.dopamine-card .dop-hint{
  margin-top:14px;padding:10px 14px;
  background:rgba(167,139,250,0.06);border-radius:8px;
  font-size:11px;color:var(--text-dim);line-height:1.5;
}

.score-row{display:flex;align-items:center;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:14px}
.ring-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px}
.ring{position:relative;width:110px;height:110px}
.ring svg{width:110px;height:110px;transform:rotate(-90deg)}
.ring .bg{fill:none;stroke:var(--border);stroke-width:7}
.ring .fg{fill:none;stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset .7s ease}
.ring-val{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Instrument Serif',serif;font-size:34px;line-height:1}
.ring-val small{font-family:'Nunito Sans';font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin-top:2px}
.ring-label{font-size:11px;color:var(--text-dim);font-weight:700;text-transform:uppercase;letter-spacing:1.2px}
.score-info{flex:1}
.score-info h2{font-family:'Instrument Serif',serif;font-size:20px;margin-bottom:6px;font-weight:400}
.score-info p{font-size:13px;color:var(--text-dim);line-height:1.55}

.pace-bar{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 24px;margin-bottom:14px}
.pace-bar .pace-label{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}
.pace-track{flex:1;height:8px;background:var(--bg);border-radius:4px;position:relative;overflow:hidden}
.pace-zone{position:absolute;top:0;bottom:0;background:var(--green-dim);border-radius:4px}
.pace-marker{position:absolute;top:-4px;width:4px;height:16px;background:var(--green);border-radius:2px;transition:left .5s}
.pace-val{font-family:'JetBrains Mono';font-size:16px;font-weight:700;white-space:nowrap;min-width:90px;text-align:right}
.pace-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text-dim);margin-top:4px;padding:0 2px}

.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
@media(max-width:700px){.metrics{grid-template-columns:repeat(2,1fr)}}
.mc{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;transition:border-color .2s}
.mc:hover{border-color:color-mix(in srgb,var(--text-dim) 40%,transparent)}
.mc-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mc-ico{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.mc-name{font-size:11px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;line-height:1.2}
.mc-num{font-family:'JetBrains Mono';font-size:30px;font-weight:700;line-height:1;margin-bottom:4px}
.mc-chips{display:flex;flex-wrap:wrap;gap:4px}
.chip{padding:2px 8px;border-radius:5px;font-size:10px;font-weight:700;font-family:'JetBrains Mono';white-space:nowrap}
.chip .n{opacity:.55;margin-left:3px}

.rhet-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px}
.rhet-panel h3{font-family:'Instrument Serif',serif;font-size:17px;font-weight:400;margin-bottom:14px}
.rhet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}
.rh{padding:12px;background:var(--bg);border-radius:10px;text-align:center}
.rh-n{font-family:'JetBrains Mono';font-size:22px;font-weight:700;color:var(--violet)}
.rh-l{font-size:10px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin-top:3px}
.rhet-examples{margin-top:12px}
.rhet-ex{padding:10px 14px;margin-top:6px;background:var(--violet-dim);border-radius:8px;border-left:3px solid var(--violet);font-size:12px;line-height:1.55;color:var(--text-dim)}
.rhet-ex em{color:var(--violet);font-style:normal;font-weight:700}
.rhet-ex strong{color:var(--text);font-weight:700;margin-right:4px}
.rhet-toggle{background:none;border:1px solid var(--border);color:var(--text-dim);font-family:'Nunito Sans';font-size:11px;font-weight:700;padding:5px 12px;border-radius:7px;cursor:pointer;margin-top:10px;display:none}
.rhet-toggle.on{display:inline-block}
.rhet-toggle:hover{border-color:var(--violet);color:var(--violet)}

.sent-bar{display:flex;gap:4px;height:10px;border-radius:5px;overflow:hidden;margin-bottom:14px}
.sent-bar div{transition:width .5s}
.sent-legend{display:flex;gap:16px;justify-content:center;margin-bottom:14px}
.sent-legend span{font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:5px}
.sent-legend .dot{width:8px;height:8px;border-radius:50%}

.actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;display:none}
.actions.on{display:flex}
.abtn{padding:10px 20px;border-radius:10px;font-family:'Nunito Sans';font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.abtn.sec{background:var(--surface);color:var(--text);border:1px solid var(--border)}
.abtn.sec:hover{border-color:var(--green);color:var(--green)}

/* Zone Charts (Pace & Volume) */

/* Delivery items */
.del-section-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;margin:14px 0 8px;padding-left:2px}
.del-section-label.excellent{color:var(--green)}
.del-section-label.needs-work{color:#F87171}
.del-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg);border-radius:10px;margin-bottom:6px;border-left:3px solid var(--border)}
.del-item.excellent{border-left-color:var(--green)}
.del-item.needs-work{border-left-color:#F87171}
.del-type{font-weight:700;color:var(--text);white-space:nowrap;font-size:13px}
.del-quote{color:var(--text-dim);font-size:13px;font-style:italic;min-width:0;flex:1}

/* Rhetorical highlight items */
.rh-item{padding:12px 14px;background:var(--bg);border-radius:10px;margin-bottom:6px;border-left:3px solid var(--violet);font-size:13px;line-height:1.6}
.rh-item-type{font-weight:700;color:var(--violet)}
.rh-item-quote{color:var(--text-dim);font-style:italic}

/* Summary */
.summary-section{margin-bottom:14px}
.summary-section-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.summary-section-title.good{color:var(--green)}
.summary-section-title.improve{color:var(--amber)}
.summary-item{padding:8px 14px;background:var(--bg);border-radius:8px;margin-bottom:4px;font-size:13px;color:var(--text-dim);line-height:1.55}

/* Claims & Contradictions */

/* CRM / Coaching Management */
.crm-btn{padding:8px 18px;border-radius:9px;font-family:'Nunito Sans';font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.crm-btn.primary{background:linear-gradient(135deg,var(--green),#059669);color:var(--bg)}
.crm-btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--green-glow)}
.crm-btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}
.crm-btn.secondary:hover{border-color:var(--green);color:var(--green)}
.crm-btn.danger{background:var(--red-dim);color:var(--red);border:1px solid transparent}
.crm-btn.danger:hover{border-color:var(--red)}
.crm-btn.sm{padding:5px 12px;font-size:11px}

.crm-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:16px 20px;margin-bottom:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:14px}
.crm-card:hover{border-color:var(--green);background:var(--surface2)}
.crm-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.crm-card-info{flex:1;min-width:0}
.crm-card-name{font-weight:700;font-size:14px;color:var(--text)}
.crm-card-meta{font-size:11px;color:var(--text-dim);margin-top:2px}
.crm-card-actions{display:flex;gap:6px;flex-shrink:0}
.crm-card-score{font-family:'JetBrains Mono';font-size:20px;font-weight:700;flex-shrink:0;min-width:40px;text-align:center}

.crm-breadcrumb-item{color:var(--text-dim);cursor:pointer;font-weight:600;padding:4px 8px;border-radius:6px;transition:all .15s}
.crm-breadcrumb-item:hover{background:var(--surface2);color:var(--text)}
.crm-breadcrumb-item.active{color:var(--text);cursor:default}
.crm-breadcrumb-sep{color:var(--border)}

.crm-notes{width:100%;min-height:100px;padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:9px;color:var(--text);font-family:'Nunito Sans';font-size:13px;line-height:1.6;resize:vertical}
.crm-notes:focus{outline:none;border-color:var(--green)}

.crm-empty{text-align:center;padding:40px 20px;color:var(--text-dim)}
.crm-empty-icon{font-size:40px;margin-bottom:12px;opacity:.4}
.crm-empty-text{font-size:14px;margin-bottom:14px}

/* Claims & Contradictions */
.claim-item{padding:12px 14px;background:var(--bg);border-radius:10px;margin-bottom:6px;border-left:3px solid var(--amber);font-size:13px;line-height:1.6;color:var(--text-dim)}
.claim-item .claim-text{font-style:italic;color:var(--text)}
.claim-item .claim-reason{margin-top:4px;font-size:12px;color:var(--amber)}
.contra-item{padding:12px 14px;background:var(--bg);border-radius:10px;margin-bottom:6px;border-left:3px solid var(--red);font-size:13px;line-height:1.6}
.contra-item .contra-a{color:var(--text);font-style:italic}
.contra-item .contra-vs{color:var(--red);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:1px;margin:6px 0;display:block}
.contra-item .contra-b{color:var(--text);font-style:italic}

/* Zone Charts (Pace & Volume) */
.zone-chart-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:14px;overflow:hidden;position:relative}
.zone-chart-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--green),transparent 60%)}
.zone-chart-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.zone-chart-header h3{font-family:'Instrument Serif',serif;font-size:17px;font-weight:400}
.zone-chart-icon{width:32px;height:32px;border-radius:8px;background:var(--green-dim);display:flex;align-items:center;justify-content:center}
#volChartPanel .zone-chart-icon{background:var(--violet-dim)}
.zone-chart-avg{text-align:center;padding:10px 0 16px}
.zone-chart-avg-label{font-size:12px;color:var(--text-dim);font-weight:600}
.zone-chart-avg-value{font-family:'JetBrains Mono';font-size:42px;font-weight:800;color:var(--green);line-height:1.1;margin:2px 0}
.zone-chart-avg-rating{font-size:13px;font-weight:700;color:var(--text-dim)}
/* Pace chart metric row — lays out Avg / Variation / (live) Current with thin
   vertical dividers between columns for visual rhythm. Columns flex evenly so
   when Current Pace is hidden (non-live view) the remaining two sit centered
   rather than clumping on one side. */
.zone-chart-metric-row{
  display:flex;justify-content:center;align-items:stretch;
  gap:0;max-width:760px;margin:0 auto;
}
.zone-chart-metric-row > .zone-chart-avg{
  flex:1;min-width:140px;padding:10px 24px 16px;
}
.zone-chart-divider{
  flex:0 0 1px;margin:14px 0;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,0.08) 20%,rgba(255,255,255,0.08) 80%,transparent);
}
.zone-chart-canvas-wrap{position:relative;width:100%;height:200px;margin-bottom:10px}
.zone-chart-canvas-wrap canvas{width:100%;height:100%}
.chart-playhead-overlay{position:absolute;top:0;left:0;pointer-events:none}
.zone-chart-legend{display:flex;gap:16px;justify-content:center;margin-bottom:8px}
.zone-chart-legend span{font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:5px}
.zone-chart-minmax{display:flex;justify-content:space-between;font-family:'JetBrains Mono';font-size:11px;color:var(--text-dim)}

/* Emotion Timeline */
.emotion-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:14px;display:none}
.emotion-panel.on{display:block}
.emotion-panel h3{font-family:'Instrument Serif',serif;font-size:17px;font-weight:400;margin-bottom:6px}
.emotion-panel .emo-sub{font-size:12px;color:var(--text-dim);margin-bottom:16px}
.emo-loading{display:flex;align-items:center;gap:10px;padding:16px;background:var(--bg);border-radius:10px;font-size:13px;color:var(--text-dim)}
.emo-loading .spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--violet);border-radius:50%;animation:spin 0.8s linear infinite}
.expr-dot-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}
.expr-dot{width:14px;height:14px;border-radius:50%;background:var(--surface2);border:2px solid var(--border);transition:all .3s}
.expr-dot.active{width:40px;height:40px;background:var(--bg);border:3px solid var(--text);display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono';font-size:16px;font-weight:800;color:var(--text)}
.expr-dot-label{font-size:10px;color:var(--text-dim);font-weight:600}
.emo-top-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:16px}
.emo-card{padding:12px;background:var(--bg);border-radius:10px;text-align:center;border:1px solid transparent;transition:border-color .2s}
.emo-card:hover{border-color:var(--violet)}
.emo-card-score{font-family:'JetBrains Mono';font-size:22px;font-weight:700;line-height:1}
.emo-card-label{font-size:10px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px;margin-top:4px}
.emo-card-bar{height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}
.emo-card-bar div{height:100%;border-radius:2px;transition:width .5s}
.emo-timeline{margin-top:14px}
.emo-timeline-title{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.emo-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.emo-row:last-child{border-bottom:none}
.emo-time{font-family:'JetBrains Mono';font-size:11px;color:var(--text-dim);min-width:50px;flex-shrink:0}
.emo-row-text{font-size:12px;color:var(--text-dim);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.emo-row-emotions{display:flex;gap:4px;flex-wrap:wrap;flex-shrink:0;max-width:280px}
.emo-tag{padding:2px 8px;border-radius:5px;font-size:9px;font-weight:700;font-family:'JetBrains Mono';background:var(--violet-dim);color:var(--violet);white-space:nowrap}
.emo-congruence{margin-top:14px;padding:14px;background:var(--bg);border-radius:10px}
.emo-congruence-title{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.emo-congruence-bar{display:flex;gap:4px;height:10px;border-radius:5px;overflow:hidden;margin-bottom:8px}
.emo-congruence-bar div{transition:width .5s}
.emo-congruence-legend{display:flex;gap:14px;flex-wrap:wrap}
.emo-congruence-legend span{font-size:11px;color:var(--text-dim);display:flex;align-items:center;gap:5px}

.error-msg{padding:14px 18px;background:var(--red-dim);border:1px solid rgba(251,113,133,0.2);border-radius:10px;color:var(--red);font-size:13px;line-height:1.5;margin-bottom:16px;display:none}
.error-msg.on{display:block}

@media(max-width:560px){
  .score-row{flex-direction:column;text-align:center}
  .pace-bar{flex-wrap:wrap}
  .metrics{grid-template-columns:1fr 1fr;gap:8px}
  .mc{padding:14px}
  .mc-num{font-size:24px}
}
