/* MockMate design system — Material-3 "expressive" theme. Shared by app.html + board.html. */

:root{
  /* Material-3 palette */
  --primary:#0037b0; --primary-container:#1d4ed8; --on-primary:#fff; --on-primary-container:#cad3ff;
  --primary-fixed:#dce1ff; --primary-fixed-dim:#b7c4ff; --on-primary-fixed:#001551;
  --bg:#faf8ff; --surface:#faf8ff;
  --surface-lowest:#ffffff; --surface-low:#f2f3ff; --surface-container:#eaedff;
  --surface-high:#e2e7ff; --surface-highest:#dae2fd; --surface-variant:#dae2fd;
  --on-surface:#131b2e; --on-surface-variant:#434655; --secondary:#505f76;
  --secondary-container:#d0e1fb; --on-secondary-container:#54647a;
  --outline:#747686; --outline-variant:#c4c5d7;
  --good:#008544; --good-container:#d7f5e3; --warn:#8a5a00; --bad:#ba1a1a; --error-container:#ffdad6;
  /* shape */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-card:20px; --r-xl:28px; --r-full:9999px;
  --sh-sm:0 1px 3px 0 rgba(16,24,46,.05),0 1px 2px 0 rgba(16,24,46,.04);
  --sh:0 6px 18px -6px rgba(16,24,46,.12),0 2px 6px -2px rgba(16,24,46,.06);
  --sh-lg:0 18px 48px -12px rgba(16,24,46,.20);
  --ring:0 0 0 3px rgba(0,55,176,.18);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);color:var(--on-surface);background:var(--bg);
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
.hidden{display:none!important}
.muted{color:var(--on-surface-variant);font-size:14px}
.err{color:var(--bad);font-size:13px;margin-top:10px;min-height:16px}
.material-symbols-outlined{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;
  font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;
  word-wrap:normal;direction:ltr;font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;vertical-align:middle}

/* type */
h1,h2,h3,h4{letter-spacing:-.01em;margin:0}
.display{font-size:44px;line-height:1.08;font-weight:800;letter-spacing:-.025em}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase}

/* brand */
.logo{font-family:var(--font);font-weight:700;font-size:22px;letter-spacing:-.02em;color:var(--primary);
  display:inline-flex;align-items:center;gap:8px}
.logo .material-symbols-outlined{font-size:28px}
.logo span{color:var(--on-surface)}

/* forms (Material-3 filled/outlined hybrid) */
label{display:block;font-size:13px;font-weight:600;color:var(--on-surface-variant);margin:14px 0 6px}
input,select,textarea{width:100%;border:1px solid var(--outline-variant);border-radius:var(--r);
  padding:12px 14px;font-size:15px;font-family:inherit;background:var(--surface-lowest);color:var(--on-surface);
  transition:border-color .15s,box-shadow .15s,background .15s}
input::placeholder,textarea::placeholder{color:var(--outline)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}
textarea{min-height:76px;resize:vertical;line-height:1.55}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23434655' stroke-width='1.8' stroke-linecap='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.field{margin-top:6px}

/* buttons */
.btn{border:none;background:var(--primary);color:var(--on-primary);font-weight:600;font-size:15px;
  padding:12px 22px;border-radius:var(--r);cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;
  justify-content:center;gap:9px;transition:.18s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-sm)}
.btn:hover{background:var(--primary-container);box-shadow:var(--sh)}
.btn:active{transform:scale(.98)}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn:disabled{opacity:.5;cursor:default;box-shadow:none}
.btn.block{width:100%}
.btn .material-symbols-outlined{font-size:20px}
.btn-ghost{background:var(--surface-lowest);border:1px solid var(--outline-variant);color:var(--on-surface);
  font-weight:600;font-size:14px;padding:10px 18px;border-radius:var(--r);cursor:pointer;font-family:inherit;
  transition:.15s;display:inline-flex;align-items:center;gap:8px}
.btn-ghost:hover{background:var(--surface-container);text-decoration:none}
.btn-ghost:focus-visible{outline:none;box-shadow:var(--ring)}
.btn-ghost .material-symbols-outlined{font-size:19px}
.link{background:none;border:none;color:var(--primary);font-weight:600;padding:0;cursor:pointer;font-family:inherit;font-size:inherit}

/* cards / pills / badges */
.card{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-card);box-shadow:var(--sh-sm)}
.pill{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--r-full);
  background:var(--primary-fixed);color:var(--primary);letter-spacing:.02em;text-transform:capitalize}
.badge{font-size:11px;font-weight:700;padding:4px 11px;border-radius:var(--r-full);color:#fff;white-space:nowrap}
.b-strong{background:var(--good)}.b-partial{background:var(--secondary)}.b-weak{background:var(--bad)}.b-na{background:var(--outline)}
h2{font-size:13px;text-transform:uppercase;letter-spacing:.07em;color:var(--on-surface-variant);margin:28px 0 12px;font-weight:700;font-family:var(--mono)}

/* ================= APP SHELL ================= */
.app{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.scrim{display:none}
.sidebar{background:var(--surface-lowest);border-right:1px solid var(--outline-variant);display:flex;flex-direction:column;
  padding:20px 16px;position:sticky;top:0;height:100vh}
.sidebar .brand{padding:6px 8px 2px}
.nav{margin-top:22px;display:flex;flex-direction:column;gap:4px}
.nav-item{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:var(--r);color:var(--on-surface-variant);
  font-weight:500;font-size:15px;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit;transition:.15s}
.nav-item .material-symbols-outlined{font-size:22px}
.nav-item:hover{background:var(--surface-low);color:var(--on-surface);text-decoration:none}
.nav-item.active{position:relative;background:var(--secondary-container);color:var(--primary);font-weight:700}
/* persistent left bar so the current page reads without relying on the subtle fill colour alone */
.nav-item.active::before{content:"";position:absolute;left:0;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--primary)}
.sidebar .spacer{flex:1}
.chip-label{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--outline);margin:0 0 6px 10px}
.user-chip{display:flex;align-items:center;gap:11px;padding:10px;border-radius:var(--r-lg);background:var(--surface-low);cursor:pointer;border:1px solid transparent;transition:.13s}
.user-chip:hover{background:var(--surface-container);border-color:var(--outline-variant)}
.user-chip.active{border-color:var(--primary);background:var(--secondary-container)}
.user-chip .ava{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:0 0 38px}
.user-chip .meta{flex:1;min-width:0}
.user-chip .nm{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .em{font-size:11px;color:var(--on-surface-variant);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip-admin{display:inline-flex;align-items:center;gap:5px;margin-top:5px;border:1px solid var(--primary-fixed-dim);background:var(--primary-fixed);
  color:var(--primary);font-weight:700;font-size:11px;padding:3px 9px;border-radius:var(--r-full);cursor:pointer;font-family:inherit;transition:.13s}
.chip-admin:hover{background:var(--primary-container);color:#fff;border-color:var(--primary-container)}
.chip-admin .material-symbols-outlined{font-size:15px}
.icon-btn{border:none;background:none;color:var(--on-surface-variant);cursor:pointer;padding:7px;border-radius:10px;display:inline-flex;transition:.13s}
.icon-btn:hover{background:var(--surface-container);color:var(--primary)}
.icon-btn .material-symbols-outlined{font-size:20px}

.main{min-width:0;background:var(--bg)}
.topbar-mobile{display:none}
.page{max-width:1280px;margin:0 auto;padding:40px 32px 110px}  /* unified container width for ALL in-app pages */
.page-head{margin-bottom:26px}
.page-head h1{font-size:30px;margin:0 0 6px;letter-spacing:-.02em;font-weight:700}
.page-head .sub{color:var(--on-surface-variant);font-size:16px;margin:0;max-width:600px}

/* level selector */
.levels{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}
.level{border:1px solid var(--outline-variant);border-radius:var(--r-lg);padding:16px 14px;text-align:left;font-weight:700;
  font-size:16px;cursor:pointer;background:var(--surface-lowest);transition:.16s}
.level:hover{border-color:var(--primary)}
.level.sel{border-color:var(--primary-container);background:var(--primary-container);color:#fff;box-shadow:var(--sh-sm)}
.level small{display:block;font-weight:500;color:var(--on-surface-variant);font-size:12px;margin-top:4px}
.level.sel small{color:rgba(255,255,255,.85)}

/* disclosure */
details{border:1px solid var(--outline-variant);border-radius:var(--r-lg);background:var(--surface-container);overflow:hidden}
details>summary{cursor:pointer;font-weight:600;font-size:15px;padding:16px 18px;list-style:none;color:var(--on-surface);
  user-select:none;display:flex;align-items:center;gap:10px}
details>summary::-webkit-details-marker{display:none}
details>summary::after{content:'expand_more';font-family:'Material Symbols Outlined';margin-left:auto;color:var(--on-surface-variant);transition:transform .25s}
details[open]>summary::after{transform:rotate(180deg)}
details .body{padding:16px 18px;background:var(--surface-lowest);border-top:1px solid var(--outline-variant)}

/* profile builder */
.profile-page{padding-bottom:96px}
.card-title{font-size:16px;font-weight:700;margin:0;letter-spacing:-.01em}
.sec{padding:22px;margin-top:16px}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.add-inline{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--outline-variant);background:var(--surface-lowest);
  color:var(--primary);font-weight:600;font-size:13px;padding:7px 13px;border-radius:var(--r-full);cursor:pointer;font-family:inherit;transition:.13s}
.add-inline:hover{background:var(--surface-container)}
.add-inline .material-symbols-outlined{font-size:18px}

/* hero header */
.profile-hero{padding:22px 24px}
.phead{display:flex;align-items:center;gap:16px}
.phead .pid{flex:1;min-width:0}
.ava-lg{width:60px;height:60px;flex:0 0 60px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#0037b0);
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px}
.pid .pname{font-size:21px;font-weight:700;letter-spacing:-.01em}
.pid .pemail{color:var(--on-surface-variant);font-size:14px}
.pid .psub{color:var(--primary);font-size:13px;font-weight:600;margin-top:3px}
.vblock{margin-top:20px;padding-top:18px;border-top:1px solid var(--outline-variant)}
.vlabel{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:14px;color:var(--on-surface)}
.vlabel .material-symbols-outlined{font-size:20px;color:var(--good)}
.vexplain{color:var(--on-surface-variant);font-size:13px;line-height:1.5;margin:8px 0 14px;max-width:640px}
.vexplain b{color:var(--on-surface);font-weight:700}
.vbadges{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.vbadge{padding:14px;border-radius:var(--r-lg);border:1px solid var(--outline-variant);background:var(--surface-low)}
.vbadge.on{border-color:var(--good);background:var(--good-container)}
.vb-top{display:flex;align-items:center;gap:8px}
.vb-top .material-symbols-outlined{font-size:20px;color:var(--outline)}
.vbadge.on .vb-top .material-symbols-outlined{color:var(--good)}
.vb-top b{text-transform:capitalize;font-size:15px;flex:1}
.vb-tag{font-size:11px;font-weight:700;padding:2px 9px;border-radius:var(--r-full);background:var(--surface-highest);color:var(--on-surface-variant)}
.vb-tag.on{background:var(--good);color:#fff}
.vbar{height:6px;border-radius:var(--r-full);background:var(--surface-highest);margin:10px 0 8px;overflow:hidden}
.vbar i{display:block;height:100%;background:var(--primary);border-radius:var(--r-full)}
.vbadge .vb-meta{color:var(--on-surface-variant);font-size:12px;line-height:1.35}
.vbadge.on .vb-meta{color:var(--good);font-weight:600;margin-top:6px}

.dash-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:30px}
.dash-hero h1{font-size:30px;font-weight:700;letter-spacing:-.02em;margin:0}
.dash-hero .sub{color:var(--on-surface-variant);font-size:15px;margin:5px 0 0}
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:18px}
.stat{display:flex;align-items:center;gap:16px;background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-lg);padding:22px;box-shadow:var(--sh-sm)}
.stat-ic{width:48px;height:48px;flex:0 0 48px;border-radius:var(--r);background:var(--primary-fixed);color:var(--primary);display:flex;align-items:center;justify-content:center}
.stat-ic .material-symbols-outlined{font-size:25px}
.stat-v{font-size:26px;font-weight:800;letter-spacing:-.01em;line-height:1.1}
.stat-l{color:var(--on-surface-variant);font-size:13px;margin-top:3px}
.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:24px;align-items:start}
.dash-cols .sec{padding:24px}
.dash-cols .comp{margin-top:18px}
.dash-cols .comp:first-of-type{margin-top:10px}
.dash-cols .hrow{margin-top:14px}
#dashFocus .focus-card{margin-top:24px;padding:26px}
@media (max-width:900px){ .dash-cols{grid-template-columns:1fr} }
@media (max-width:820px){ .dash-hero{flex-direction:column;align-items:flex-start} .dash-hero .btn{width:100%} }

/* All in-app pages share one container width via .page (1280px). */
/* report card: 2-column dashboard at wide screens (questions | summary rail) */
.report-cols{display:grid;grid-template-columns:1.55fr 1fr;gap:24px;align-items:start;margin-top:8px}
.rc-side{display:flex;flex-direction:column;gap:0}
.rc-side .grid2{grid-template-columns:1fr}   /* stack strengths/gaps on the narrower rail */
.rc-main .section-h{margin-top:8px}
/* full-width footer below the two columns — keeps Focus/Coach/Cost from orphaning the short right rail */
.report-foot{margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.report-foot > *{margin-top:0!important;min-width:0}
.report-foot > .focus-card:only-child,
.report-foot > .coach-card:only-child{grid-column:1/-1}
.report-foot > .card{grid-column:1/-1}   /* admin cost estimate spans full width */
@media (max-width:1000px){ .report-cols{grid-template-columns:1fr} .report-foot{grid-template-columns:1fr} }

/* practice: action-first hero */
.practice-hero{display:flex;align-items:center;justify-content:space-between;gap:24px;
  background:linear-gradient(135deg,#0037b0,#1d4ed8);color:#fff;border-radius:var(--r-xl);padding:32px 34px;box-shadow:var(--sh-lg);overflow:hidden}
.ph-left{max-width:560px}
.ph-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:#cdd7ff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:5px 12px;border-radius:var(--r-full);margin-bottom:16px}
.ph-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#7ee0a8;box-shadow:0 0 0 0 rgba(126,224,168,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(126,224,168,.55)}70%{box-shadow:0 0 0 8px rgba(126,224,168,0)}100%{box-shadow:0 0 0 0 rgba(126,224,168,0)}}
.practice-hero h1{font-size:30px;line-height:1.1;letter-spacing:-.02em;margin:0 0 8px;color:#fff}
.ph-sub{color:#dce4ff;font-size:16px;line-height:1.5;margin:0 0 22px;max-width:480px}
.btn-lg{font-size:16px;padding:15px 28px;border-radius:var(--r-lg)}
.practice-hero .btn-lg{background:#fff;color:var(--primary)}
.practice-hero .btn-lg:hover{background:#eef0ff}
.practice-hero .err{color:#ffd7d3}
.ph-art{position:relative;flex:0 0 150px;height:150px;display:flex;align-items:center;justify-content:center}
.ph-avatar{width:104px;height:104px;border-radius:50%;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.ph-avatar .material-symbols-outlined{font-size:54px;color:#fff}
.ph-ring{position:absolute;width:150px;height:150px;border-radius:50%;border:2px solid rgba(255,255,255,.22);animation:phpulse 2.4s ease-out infinite}
@keyframes phpulse{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.15);opacity:0}}

/* quick-pick role chips */
.role-quick{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.rolechip{border:1px solid var(--outline-variant);background:var(--surface-lowest);color:var(--on-surface);
  font-weight:600;font-size:13.5px;padding:9px 15px;border-radius:var(--r-full);cursor:pointer;font-family:inherit;transition:.13s}
.rolechip:hover{border-color:var(--primary);background:var(--surface-container)}
.rolechip.sel{border-color:var(--primary-container);background:var(--primary-container);color:#fff}
@media (max-width:760px){ .practice-hero{flex-direction:column;align-items:flex-start} .ph-art{display:none} .btn-lg{width:100%} }
@media (prefers-reduced-motion:reduce){ .ph-eyebrow .dot,.ph-ring{animation:none} }

/* profile: main column + sidebar */
.profile-cols{display:grid;grid-template-columns:1.6fr 1fr;gap:22px;align-items:start}
.pcol-main{display:flex;flex-direction:column;gap:16px}
.pcol-side{display:flex;flex-direction:column;gap:16px}
.pcol-main .sec, .pcol-side .sec{margin-top:0}
#profileEdit{max-width:760px}
@media (max-width:900px){ .profile-cols{grid-template-columns:1fr} }

/* reports + admin: responsive card grid instead of one long column */
.hist, #adminList{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}
.hist .empty, #adminList > .muted, #adminList > .empty{grid-column:1/-1}
.hist .hrow, #adminList .hrow{margin-top:0}

/* competency bars (report + profile) */
.comp{margin-top:14px}
.comp:first-of-type{margin-top:4px}
.comp-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.comp-name{font-weight:600;font-size:14px}
.comp-score{font-family:var(--mono);font-size:12px;color:var(--on-surface-variant);white-space:nowrap}
.comp-n{margin-left:6px;opacity:.8}
.cbar{height:8px;border-radius:var(--r-full);background:var(--surface-highest);margin-top:7px;overflow:hidden}
.cbar i{display:block;height:100%;border-radius:var(--r-full);transition:width .4s ease}
.comp-note{color:var(--on-surface-variant);font-size:12px;margin-top:5px}

/* toggle switch (privacy/consents) */
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--outline-variant)}
.switch-row:last-child{border-bottom:none}
.switch-row > span:first-child{display:flex;flex-direction:column}
.switch-row b{font-size:14px;font-weight:600}
.switch-row small{color:var(--on-surface-variant);font-size:12.5px;margin-top:2px}
.switch{position:relative;flex:0 0 auto;width:44px;height:26px;display:inline-block}
.switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;z-index:2}
.switch i{position:absolute;inset:0;background:var(--surface-highest);border-radius:var(--r-full);transition:.18s}
.switch i::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--sh-sm);transition:.18s}
.switch input:checked + i{background:var(--primary)}
.switch input:checked + i::after{transform:translateX(18px)}
.switch input:focus-visible + i{box-shadow:var(--ring)}

/* open-to-work pill + details/projects view */
.pill-open{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;vertical-align:middle;
  padding:3px 10px;border-radius:var(--r-full);background:var(--good-container);color:var(--good);margin-left:8px}
.pill-open .material-symbols-outlined{font-size:14px}
.drow{display:flex;align-items:center;gap:9px;color:var(--on-surface-variant);font-size:14px;padding:5px 0}
.drow .material-symbols-outlined{font-size:19px;color:var(--outline)}
.dlabel{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--on-surface-variant);margin:12px 0 8px}
.vdesc{color:var(--on-surface-variant);font-size:14px;line-height:1.5;margin-top:3px}
.vlink{color:var(--primary);vertical-align:middle}.vlink .material-symbols-outlined{font-size:16px}

/* view mode */
.view-bio{margin:0;color:var(--on-surface-variant);line-height:1.6;white-space:pre-wrap}
.ventry{padding:14px 0;border-bottom:1px solid var(--outline-variant)}
.ventry:first-child{padding-top:2px}
.ventry:last-child{border-bottom:none;padding-bottom:0}
.vrole{font-weight:700;font-size:15px}
.vrole .vat{color:var(--on-surface-variant);font-weight:400}
.vdates{color:var(--on-surface-variant);font-size:13px;font-family:var(--mono);margin-top:2px}
.vbullets{margin:10px 0 0;padding-left:20px}
.vbullets li{margin:5px 0;color:var(--on-surface-variant);line-height:1.5}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;font-size:13px;font-weight:600;padding:6px 13px;border-radius:var(--r-full);
  background:var(--primary-fixed);color:var(--primary)}

/* resume upload */
.hidden-file{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.filedrop{display:flex;align-items:center;gap:10px;justify-content:center;padding:16px;border:1.5px dashed var(--outline-variant);
  border-radius:var(--r);background:var(--surface-low);color:var(--on-surface-variant);cursor:pointer;font-weight:600;font-size:14px;transition:.15s}
.filedrop:hover{border-color:var(--primary);color:var(--primary);background:var(--surface-container)}
.filedrop .material-symbols-outlined{font-size:22px}

/* structured entries */
.entry{border:1px solid var(--outline-variant);border-radius:var(--r-lg);padding:16px;margin-bottom:12px;background:var(--surface-low)}
.entry .erow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.entry textarea{min-height:64px}
.entry .ehead{display:flex;justify-content:flex-end;margin-bottom:6px}
.entry .rm{border:none;background:none;color:var(--bad);cursor:pointer;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:4px;font-family:inherit}
.entry .rm .material-symbols-outlined{font-size:16px}

/* action row — plain end-of-form footer (no sticky, never overlaps content) */
.action-bar{display:flex;align-items:center;gap:14px;margin-top:24px;padding-top:18px;border-top:1px solid var(--outline-variant)}

/* skeleton loaders (shimmer) */
.skel{position:relative;overflow:hidden;background:var(--surface-highest);border-radius:8px;display:block}
.skel::after{content:'';position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:shimmer 1.3s ease-in-out infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
@media (prefers-reduced-motion:reduce){ .skel::after{animation:none} }

/* history / list rows */
.hist{margin-top:6px}
.hrow{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--outline-variant);
  border-radius:var(--r-lg);padding:16px 18px;margin-top:12px;background:var(--surface-lowest);transition:.16s}
.hrow:hover{box-shadow:var(--sh);border-color:var(--primary);transform:translateY(-1px)}
.empty{text-align:center;color:var(--on-surface-variant);padding:44px 20px;border:1px dashed var(--outline-variant);
  border-radius:var(--r-card);background:var(--surface-lowest);margin-top:8px}

/* report */
.scorehead{display:flex;gap:22px;align-items:center;padding:26px}
.scorering{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto;padding:11px}
.scorering .inner{background:var(--surface-lowest);width:100%;height:100%;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center}
.scorering .inner b{font-size:32px;line-height:1;color:var(--primary);font-weight:800}
.scorering .inner small{font-size:11px;color:var(--on-surface-variant);font-family:var(--mono);letter-spacing:.05em}
.bigscore{width:88px;height:88px;border-radius:50%;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:var(--sh)}
.bigscore b{font-size:28px;line-height:1}.bigscore small{font-size:10px;opacity:.9}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.metric{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface-container);border-radius:var(--r);margin-top:10px;font-weight:600}
.focus-card{background:var(--primary);color:#fff;border-radius:var(--r-card);padding:24px;position:relative;overflow:hidden;margin-top:16px}
.focus-card h3{font-size:20px;margin-bottom:8px}
.q{border:1px solid var(--outline-variant);border-radius:var(--r-card);overflow:hidden;margin:12px 0;background:var(--surface-lowest);box-shadow:var(--sh-sm)}
.q .qtop{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:18px 20px}
.q h3{font-size:16px;margin:0 0 6px;font-weight:600}
.q dl{padding:0 20px 18px}
.q dt{font-size:11px;color:var(--primary);font-weight:700;margin-top:12px;text-transform:uppercase;letter-spacing:.05em;font-family:var(--mono)}
.q dt.you{color:var(--on-surface)}
.q dd{margin:4px 0 0;font-size:15px;color:var(--on-surface-variant)}
ul.tight{margin:10px 0 0;padding-left:20px}ul.tight li{margin:6px 0;color:var(--on-surface-variant)}

/* ================= LANDING ================= */
.landing{min-height:100vh;display:flex;flex-direction:column;background:var(--surface-lowest)}
.lnav{display:flex;justify-content:space-between;align-items:center;padding:18px 32px;width:100%;max-width:1180px;margin:0 auto}
.lmain{flex:1;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;width:100%;max-width:1180px;margin:0 auto;
  padding:36px 32px 70px;align-items:center}
.lhero .badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:600;
  color:var(--primary);background:var(--surface-container);border:1px solid var(--outline-variant);
  padding:6px 14px;border-radius:var(--r-full);margin-bottom:22px;letter-spacing:.06em;text-transform:uppercase}
.lhero .badge .dot{width:8px;height:8px;border-radius:50%;background:var(--primary);animation:pulse2 1.8s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.35}}
.lhero h1{font-size:48px;line-height:1.06;letter-spacing:-.03em;margin:0 0 20px;font-weight:800}
.lhero h1 .accent{color:var(--primary)}
.lhero .lead{font-size:18px;color:var(--on-surface-variant);max-width:540px;margin:0;line-height:1.55}
.features{display:flex;flex-direction:column;gap:18px;margin-top:34px}
.feature{display:flex;gap:14px;align-items:flex-start}
.feature .fi{width:48px;height:48px;flex:0 0 48px;border-radius:var(--r);background:var(--primary-container);color:#fff;
  display:flex;align-items:center;justify-content:center}
.feature .fi .material-symbols-outlined{font-size:24px}
.feature h4{margin:0 0 3px;font-size:16px}
.feature p{margin:0;font-size:14px;color:var(--on-surface-variant)}
.auth-card{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-xl);box-shadow:var(--sh-lg);padding:34px}
.auth-card h2{font-size:24px;text-transform:none;letter-spacing:-.02em;color:var(--on-surface);margin:0 0 4px;font-family:var(--font)}
.auth-card .sub{color:var(--on-surface-variant);font-size:15px;margin:0 0 8px}
.steps{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap}
.step{font-size:13px;color:var(--on-surface-variant);display:flex;align-items:center;gap:8px}
.step b{width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:12px;display:inline-flex;align-items:center;justify-content:center}

/* ================= MEETING (live, dark) ================= */
#meeting{position:fixed;inset:0;background:#0b101a;color:#fff;display:flex;flex-direction:column;z-index:60;font-family:var(--font)}
.mtop{padding:16px 24px;display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#aab3c9}
.mtop .live{display:inline-flex;align-items:center;gap:9px;padding:6px 14px;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--r-full);font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75)}
.mtop .live::before{content:'';width:9px;height:9px;border-radius:50%;background:#ff5a52;animation:blink 1.5s step-start infinite}
@keyframes blink{50%{opacity:0}}
/* interview countdown — light hues for the dark meeting backdrop */
.mtimer{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:14px;font-weight:700;letter-spacing:.04em;
  padding:6px 14px;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);color:#fff;transition:color .2s,border-color .2s,background .2s}
.mtimer .material-symbols-outlined{font-size:18px}
.mtimer.ok{color:#7ee0a8;border-color:rgba(126,224,168,.35)}
.mtimer.warn{color:#ffcf6b;border-color:rgba(255,207,107,.4);background:rgba(255,207,107,.08)}
.mtimer.danger{color:#ff8a82;border-color:rgba(255,90,82,.55);background:rgba(255,90,82,.14);animation:timerpulse 1s ease-in-out infinite}
@keyframes timerpulse{0%,100%{opacity:1}50%{opacity:.5}}
/* visible keyboard focus for controls the design otherwise leaves bare */
.ctrl:focus-visible,.icon-btn:focus-visible,.bn:focus-visible,.user-chip:focus-visible,.coach-fab:focus-visible,.coach-close:focus-visible,.rolechip:focus-visible,.chatchips .chip:focus-visible,.kbtn:focus-visible,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
#meeting button:focus-visible,.coach-fab:focus-visible{outline-color:#fff}
/* meeting screen — small-screen layout (was desktop-only) */
@media(max-width:640px){
  .mtop{padding:12px 14px;gap:8px;flex-wrap:wrap}
  .mtop #mRole{flex-basis:100%;order:3;font-size:12px;text-align:center}
  .mtimer{font-size:13px;padding:5px 11px}
  #meeting .avatar{width:88px;height:88px}
  .self{width:104px;height:70px;right:12px;bottom:92px}
  .captions{width:92%;bottom:84px}
  .controls{padding:14px;gap:12px}
  .ctrl{width:50px;height:50px;font-size:20px}
  .ctrl.danger{padding:0 16px;font-size:14px}
}
.stage{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:18px}
.interviewer{text-align:center;width:100%;max-width:920px;aspect-ratio:16/9;background:#131b2e;border:1px solid rgba(255,255,255,.06);
  border-radius:var(--r-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;box-shadow:var(--sh-lg)}
.avatar{position:relative;width:120px;height:120px;border-radius:50%;margin:0 auto 18px;
  background:radial-gradient(circle at 36% 30%, #3360e6, #0037b0 72%);
  display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 30px rgba(29,78,216,.35);transition:box-shadow .3s}
.avatar.speaking{box-shadow:0 0 34px rgba(41,90,224,.55), 0 0 0 10px rgba(29,78,216,.14)}
.avatar .material-symbols-outlined{font-size:54px;position:relative;z-index:2}
/* whisper-subtle "presence" orb: idle breathing + expanding rings while Jordan speaks */
@media (prefers-reduced-motion: no-preference){
  @keyframes orbBreath{0%,100%{transform:scale(1)}50%{transform:scale(1.035)}}
  @keyframes orbRing{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.7);opacity:0}}
  .avatar{animation:orbBreath 4.8s ease-in-out infinite}
  .avatar.speaking{animation:orbBreath 1.7s ease-in-out infinite}
  .avatar::before,.avatar::after{content:'';position:absolute;inset:-2px;border-radius:50%;border:2px solid rgba(120,160,255,.5);opacity:0;pointer-events:none;z-index:1}
  .avatar.speaking::before{animation:orbRing 1.9s ease-out infinite}
  .avatar.speaking::after{animation:orbRing 1.9s ease-out infinite .95s}
}
.iname{font-size:20px;font-weight:700}.irole{color:#aab3c9;font-size:14px;margin-top:3px}
.self{position:absolute;right:26px;bottom:26px;width:200px;height:132px;border-radius:var(--r-lg);overflow:hidden;background:#000;border:2px solid rgba(255,255,255,.2);box-shadow:var(--sh-lg);z-index:5}
.self video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.self .selflabel{position:absolute;left:9px;top:8px;font-size:10px;font-weight:700;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.45);padding:2px 8px;border-radius:6px;display:inline-flex;align-items:center;gap:4px}
.captions{position:absolute;left:50%;transform:translateX(-50%);bottom:26px;max-width:680px;width:86%;text-align:center;z-index:4}
.cap{display:inline-block;background:rgba(11,16,26,.75);backdrop-filter:blur(12px);padding:12px 20px;border-radius:var(--r-lg);
  font-size:16px;line-height:1.5;overflow-wrap:anywhere;white-space:normal;border:1px solid rgba(255,255,255,.1)}
.cap .who{font-weight:700;color:#b7c4ff;margin-right:6px}
.connbar{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#131b2e;border:1px solid rgba(255,90,82,.3);
  color:#fff;padding:26px;border-radius:var(--r-xl);text-align:center;z-index:30;max-width:420px;box-shadow:var(--sh-lg)}
.connbar h4{margin:0 0 6px;font-size:18px}
.connbar p{margin:0 0 18px;color:#cbd5e1;font-size:13px;line-height:1.5}
.connbar .row{display:flex;gap:10px;justify-content:center}
.connbar button{padding:10px 18px;border-radius:var(--r);border:0;cursor:pointer;font-weight:600;font-size:14px;font-family:inherit}
.connbar .primary{background:var(--primary-container);color:#fff}
.connbar .ghost{background:rgba(255,255,255,.1);color:#cbd5e1}
.controls{padding:22px;display:flex;gap:16px;justify-content:center;align-items:center;background:rgba(11,16,26,.85);backdrop-filter:blur(8px)}
.ctrl{width:56px;height:56px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.08);color:#fff;
  font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.ctrl:hover{background:rgba(255,255,255,.18)}
.ctrl .material-symbols-outlined{font-size:24px}
.ctrl.danger{background:var(--bad);width:auto;border-radius:var(--r);padding:0 24px;font-size:15px;font-weight:700;gap:8px;border:none}
.ctrl.danger:hover{filter:brightness(1.1)}
.ctrl.off{background:var(--bad);border-color:transparent}

/* ================= MOBILE BOTTOM NAV ================= */
.botnav{display:none}

/* ================= BOARD (kanban) ================= */
.bhead{display:flex;align-items:center;justify-content:space-between;padding:16px 26px;background:var(--surface-lowest);border-bottom:1px solid var(--outline-variant);position:sticky;top:0;z-index:10}
.bhead .sub{color:var(--on-surface-variant);font-size:13px;margin-left:10px;font-weight:500}
.bhead .actions{display:flex;align-items:center;gap:14px}
.board{display:flex;gap:16px;padding:22px 26px;overflow-x:auto;align-items:flex-start;min-height:calc(100vh - 120px)}
.col{background:var(--surface-low);border:1px solid var(--outline-variant);border-radius:var(--r-card);width:300px;min-width:300px;flex-shrink:0;padding:14px}
.col h2{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--on-surface-variant);margin:2px 4px 12px;display:flex;justify-content:space-between;font-weight:700;font-family:var(--mono)}
.col h2 .count{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-full);padding:0 8px;font-size:11px;color:var(--on-surface-variant)}
.kcard{background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r);padding:13px 14px;margin-bottom:10px;box-shadow:var(--sh-sm);transition:.15s}
.kcard:hover{border-color:var(--primary);box-shadow:var(--sh)}
.kcard .t{font-weight:600;font-size:14px;line-height:1.4}
.kcard .d{color:var(--on-surface-variant);font-size:12.5px;margin-top:5px;white-space:pre-wrap;line-height:1.45}
.klabels{margin-top:8px;display:flex;flex-wrap:wrap;gap:5px}
.klabel{font-size:10px;font-weight:600;background:var(--primary-fixed);color:var(--primary);border-radius:6px;padding:1px 7px}
.krow{display:flex;gap:6px;margin-top:10px;align-items:center}
.krow .sp{flex:1}
.kbtn{cursor:pointer;border:1px solid var(--outline-variant);border-radius:8px;font-size:12px;padding:4px 9px;background:var(--surface-lowest);color:var(--on-surface-variant);transition:.13s;font-family:inherit}
.kbtn:hover{background:var(--surface-container);border-color:var(--primary)}
.kbtn:disabled{opacity:.4;cursor:default}
.kbtn.del{border-color:transparent;color:var(--bad)}
.kbtn.del:hover{background:var(--error-container)}
.add{width:100%;margin-top:4px;background:transparent;border:1px dashed var(--outline);color:var(--on-surface-variant);padding:9px;border-radius:var(--r);cursor:pointer;font-family:inherit;font-size:13px;transition:.13s}
.add:hover{color:var(--primary);border-color:var(--primary);background:var(--surface-container)}
dialog{background:var(--surface-lowest);color:var(--on-surface);border:1px solid var(--outline-variant);border-radius:var(--r-lg);padding:24px;width:400px;box-shadow:var(--sh-lg)}
dialog::backdrop{background:rgba(11,16,26,.45)}
dialog h3{margin:0 0 6px}

/* ================= RESPONSIVE ================= */
@media (max-width:900px){
  .lmain{grid-template-columns:1fr;gap:32px;padding-top:12px}
  .lhero h1{font-size:36px}
}
@media (max-width:820px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .topbar-mobile{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--surface-lowest);
    border-bottom:1px solid var(--outline-variant);position:sticky;top:0;z-index:40}
  .page{padding:24px 18px 110px}
  .grid2{grid-template-columns:1fr}
  /* mobile bottom nav */
  .botnav{display:flex;position:fixed;bottom:0;left:0;width:100%;z-index:60;background:var(--surface-lowest);
    border-top:1px solid var(--outline-variant);box-shadow:0 -4px 20px rgba(16,24,46,.06);
    justify-content:space-around;align-items:center;padding:8px 8px calc(8px + env(safe-area-inset-bottom))}
  .botnav .bn{display:flex;flex-direction:column;align-items:center;gap:2px;border:none;background:none;color:var(--on-surface-variant);
    font-size:10px;font-weight:600;cursor:pointer;font-family:inherit;padding:4px 14px;border-radius:var(--r-full);transition:.13s}
  .botnav .bn .material-symbols-outlined{font-size:24px}
  .botnav .bn.active{color:var(--on-primary-container);background:var(--primary-container)}
  .botnav .bn.active{color:#fff}
}

/* ---------- chat with your report ---------- */
.chatcard{display:flex;flex-direction:column}
.chathead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--surface-highest)}
.transcriptbox{max-height:260px;overflow-y:auto;background:var(--surface-container);border-bottom:1px solid var(--surface-highest)}
.transcriptbox .trow{display:flex;flex-direction:column;gap:2px;padding:9px 16px;border-bottom:1px solid var(--surface-highest)}
.transcriptbox .trow b{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--on-surface-variant)}
.transcriptbox .trow.you b{color:var(--primary)}
.chatlog{display:flex;flex-direction:column;gap:10px;padding:16px;max-height:420px;overflow-y:auto}
.chatlog .bubble{max-width:82%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}
.chatlog .bubble.bot{align-self:flex-start;background:var(--surface-highest);color:var(--on-surface);border-bottom-left-radius:5px}
.chatlog .bubble.me{align-self:flex-end;background:var(--primary);color:#fff;border-bottom-right-radius:5px}
.chatlog .bubble.typing{opacity:.6;letter-spacing:3px}
.chatchips{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 4px}
.chatchips .chip{cursor:pointer;border:none;font-family:inherit;transition:.13s}
.chatchips .chip:hover{background:var(--primary-container);color:#fff}
.chatbar{display:flex;gap:8px;padding:12px 16px 16px;border-top:1px solid var(--surface-highest)}
.chatbar input{flex:1;padding:11px 14px;border:1px solid var(--outline);border-radius:var(--r-full);background:var(--surface);color:var(--on-surface);font-family:inherit;font-size:14px}
.chatbar input:focus{outline:none;border-color:var(--primary)}
.chatbar .btn-primary{padding:0 16px;display:flex;align-items:center;justify-content:center}

/* ---------- report card (polished single-scroll) ---------- */
.rhero{display:flex;align-items:center;gap:24px;background:linear-gradient(135deg,var(--primary),var(--primary-container));color:#fff;border-radius:var(--r-card);padding:26px 28px;box-shadow:var(--sh-md,0 8px 28px rgba(0,55,176,.22))}
.rhero .scorering.rhero-ring{width:108px;height:108px;padding:10px}
/* opaque deep-blue center so the % stays readable at ANY fill (was translucent → white-on-white at high scores) */
.rhero .scorering.rhero-ring .inner{background:#01205f}
.rhero .scorering.rhero-ring .inner b{color:#fff;font-size:28px}
.rhero .scorering.rhero-ring .inner small{color:rgba(255,255,255,.85)}
.rhero-main{flex:1;min-width:0}
.rhero-band{display:inline-block;background:rgba(255,255,255,.2);color:#fff;font-weight:700;font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:4px 12px;border-radius:var(--r-full);margin-bottom:9px}
.rhero-main h1{font-size:22px;margin:0 0 7px;color:#fff;font-weight:800}
.rhero-main h1 .pill{background:rgba(255,255,255,.22);color:#fff}
.rhero-main p{margin:0;opacity:.96;font-size:15px;line-height:1.55}
.hpills{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:12px;margin-top:16px}
.hpill{display:flex;align-items:center;gap:12px;background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-card);padding:14px 16px;box-shadow:var(--sh-sm)}
.hpill>.material-symbols-outlined{color:var(--primary);font-size:26px;flex:0 0 auto}
.hpill-t{display:flex;flex-direction:column;min-width:0}
.hpill-t b{font-size:17px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hpill-t small{color:var(--on-surface-variant);font-size:12px}
.rcard-h{display:flex;align-items:center;gap:8px;font-weight:700;margin-bottom:8px}
.rcard-h .material-symbols-outlined{font-size:20px}
.rcard-h.ok{color:var(--good)}
.rcard-h.warn{color:var(--warn)}
.rsec{margin:26px 0 8px;font-size:18px}
.qacc{display:flex;flex-direction:column;gap:10px}
/* dashboard section header (icon + title) */
.section-h{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px;margin:26px 0 12px;color:var(--on-surface)}
.section-h .material-symbols-outlined{font-size:20px;color:var(--primary)}
.section-h.sm{font-size:14px;margin:0 0 10px}
/* report-card KPI tiles + reports-page KPI header */
.report-kpis{margin-top:18px}
.report-kpis .stat,.reports-kpis .stat{padding:16px 18px}
.reports-kpis{margin-bottom:18px}
/* score-trend area/line chart */
.trend-card{padding:16px 18px;margin-bottom:18px}
.trend-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.trend-svg{width:100%;height:auto;display:block;margin-top:8px;max-height:220px;overflow:visible}
.trend-line{fill:none;stroke:var(--primary);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.trend-grid{stroke:var(--outline-variant);stroke-width:1;stroke-dasharray:5 5}
.trend-val{fill:var(--on-surface-variant);font-size:13px;font-weight:700;font-family:var(--font)}
/* view-all toggle for the interview list */
.histmore{text-align:center;margin-top:18px}
.histmore .btn-ghost{padding:10px 24px;font-weight:600}
/* clickable report cards + score chip */
.rcard{cursor:pointer}
.rcard-score{display:inline-flex;align-items:baseline;gap:2px;font-size:22px;font-weight:800;border:2px solid;border-radius:var(--r-full);padding:6px 14px;line-height:1}
.rcard-score small{font-size:11px;font-weight:600;opacity:.7}
.qa{border:1px solid var(--outline-variant);border-left:4px solid var(--outline);border-radius:var(--r-card);background:var(--surface-lowest);overflow:hidden;box-shadow:var(--sh-sm)}
.qa.qa-strong{border-left-color:var(--good)}
.qa.qa-partial{border-left-color:var(--primary)}
.qa.qa-weak{border-left-color:var(--warn)}
.qa.qa-not_answered{border-left-color:var(--bad)}
.qa>summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;cursor:pointer;list-style:none;font-weight:600}
.qa>summary::-webkit-details-marker{display:none}
.qa>summary::after{content:'expand_more';font-family:'Material Symbols Outlined';color:var(--on-surface-variant);transition:transform .2s;margin-left:2px}
.qa[open]>summary::after{transform:rotate(180deg)}
.qa-q{flex:1;min-width:0}
.qa-body{padding:0 18px 18px;display:flex;flex-direction:column;gap:12px}
.ans{border-radius:var(--r);padding:12px 14px}
.ans .ans-h{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-family:var(--mono);margin-bottom:5px}
.ans .ans-h .material-symbols-outlined{font-size:16px}
.ans p{margin:0;font-size:15px;color:var(--on-surface);line-height:1.55;white-space:pre-wrap}
.ans.you{background:var(--surface-container)}
.ans.you .ans-h{color:var(--on-surface)}
.ans.model{background:var(--primary-fixed)}
.ans.model .ans-h{color:var(--primary)}
.ans-tip{display:flex;align-items:flex-start;gap:8px;background:var(--warn-container,rgba(176,122,20,.12));color:var(--on-surface);border-radius:var(--r);padding:10px 12px;font-size:14px;line-height:1.5}
.ans-tip .material-symbols-outlined{font-size:18px;color:var(--warn);flex:0 0 auto}
@media(max-width:640px){.rhero{flex-direction:column;text-align:center;gap:16px}.rhero-main h1{font-size:20px}}

/* ---------- coach: floating launcher + slide-in drawer ---------- */
.coach-fab{position:fixed;right:24px;bottom:24px;z-index:58;display:none;align-items:center;gap:8px;
  background:var(--primary);color:#fff;border:none;border-radius:var(--r-full);padding:14px 20px;font-family:inherit;
  font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 8px 24px rgba(0,55,176,.35);transition:transform .15s,box-shadow .15s}
.coach-fab.show{display:inline-flex;animation:fabpop .3s ease both}
.coach-fab:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,55,176,.42)}
.coach-fab .material-symbols-outlined{font-size:22px}
.coach-fab>span:last-child{max-width:170px;overflow:hidden;white-space:nowrap;transition:max-width .2s ease,opacity .2s ease}
.coach-fab.collapsed{gap:0;padding:14px}
.coach-fab.collapsed>span:last-child{max-width:0;opacity:0}
@keyframes fabpop{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}
.coach-scrim{position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.42);opacity:0;pointer-events:none;transition:opacity .25s}
.coach-scrim.open{opacity:1;pointer-events:auto}
.coach-drawer{position:fixed;z-index:80;top:0;right:0;height:100%;width:min(440px,94vw);
  background:var(--surface-lowest);box-shadow:-12px 0 40px rgba(0,0,0,.2);
  display:flex;flex-direction:column;transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);border-radius:0}
.coach-drawer.open{transform:translateX(0)}
.coach-drawer .chathead{flex:0 0 auto}
.coach-drawer .chathead-t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.coach-drawer .transcriptbox{flex:0 0 auto}
.coach-drawer .chatlog{flex:1 1 auto;max-height:none}
.coach-drawer .chatchips,.coach-drawer .chatbar{flex:0 0 auto}
.coach-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:50%;
  background:transparent;color:var(--on-surface-variant);cursor:pointer;transition:.13s}
.coach-close:hover{background:var(--surface-container);color:var(--on-surface)}
.coach-close .material-symbols-outlined{font-size:20px}
body.coach-locked{overflow:hidden}

/* ---------- inline load-error + retry ---------- */
.errbox{display:flex;align-items:center;gap:12px;background:var(--surface-container);border:1px solid var(--outline-variant);
  border-radius:var(--r-card);padding:16px 18px;margin-top:10px}
.errbox>.material-symbols-outlined{color:var(--on-surface-variant);font-size:26px;flex:0 0 auto}
.errbox b{font-size:14px}
@media(max-width:640px){
  .coach-fab{right:16px;bottom:84px;padding:13px 18px}   /* clear the bottom nav */
  .coach-drawer{top:auto;bottom:0;right:0;width:100%;height:auto;max-height:88vh;border-radius:18px 18px 0 0;transform:translateY(100%)}
  .coach-drawer.open{transform:translateY(0)}
}

/* ===== Batch-1 UX polish ===== */
/* Start button dimmed until a role is chosen (still clickable → shows guidance) */
.btn.dim{opacity:.5;filter:saturate(.6)}
.btn.dim:hover{box-shadow:none}

/* Surfaced "tailor to a job" block (was a collapsed accordion) */
.tailor-block{margin-top:18px;padding-top:16px;border-top:1px solid var(--outline-variant)}

/* Per-level colour on the level pill so mixed histories scan at a glance */
.pill.lvl-junior{background:var(--good-container);color:var(--good)}
.pill.lvl-intermediate{background:var(--primary-fixed);color:var(--primary)}
.pill.lvl-senior{background:#efe2ff;color:#6b3fb0}
.pill.lvl-lead,.pill.lvl-principal,.pill.lvl-leadprincipal{background:#ffe2cc;color:var(--warn)}

/* Always-visible coach card inside the report (complements the floating launcher) */
.coach-card{margin-top:16px;background:var(--surface-low);border:1px solid var(--outline-variant);border-radius:var(--r-card);padding:18px}
.coach-card-h{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--primary)}
.coach-card-h .material-symbols-outlined{font-size:20px}
.coach-card-chips{display:flex;flex-wrap:wrap;gap:8px}
.coach-card-chips .chip{cursor:pointer;border:none;font-family:inherit;transition:.13s}
.coach-card-chips .chip:hover{background:var(--primary-container);color:#fff}

/* ===== Batch-2 ===== */
/* Reports filter + sort bar */
.rep-filters{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 14px}
.rep-filters .field{width:auto;min-width:160px;flex:1 1 160px;max-width:240px}

/* Interactive score-trend points (hover tooltip via <title>, click-through) */
.trend-hit{cursor:pointer}
.trend-hit:focus-visible{outline:none;stroke:var(--primary);stroke-width:2}

/* First-run onboarding checklist */
.ob-card{padding:20px;margin:0 0 18px}
.ob-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.ob-head > .material-symbols-outlined{font-size:26px;color:var(--primary);flex:0 0 auto}
.ob-step{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--outline-variant)}
.ob-ic{font-size:24px;color:var(--outline);flex:0 0 auto}
.ob-step.done .ob-ic{color:var(--good)}
.ob-body{flex:1;min-width:0}
.ob-t{font-weight:700}
.ob-d{font-size:13px;margin-top:1px}
.ob-step.done .ob-t{color:var(--on-surface-variant);text-decoration:line-through}
.ob-done{font-size:12px;font-weight:700;color:var(--good);flex:0 0 auto}
.ob-step .btn,.ob-step .btn-ghost{flex:0 0 auto;white-space:nowrap}

/* Inline info callout (e.g. "what recruiters see") */
.info-note{display:flex;gap:10px;background:var(--secondary-container);border-radius:var(--r);padding:12px 14px;margin:0 0 16px;font-size:13px;line-height:1.5;color:var(--on-surface)}
.info-note > .material-symbols-outlined{font-size:20px;color:var(--primary);flex:0 0 auto}

/* Mobile Practice: stack level cards, tighten hero, keep gated-Start scroll clear of the sticky topbar */
.role-quick + label, #roleSelect{scroll-margin-top:84px}
#levels{scroll-margin-top:84px}
@media (max-width:640px){
  .levels{grid-template-columns:1fr}
  .practice-hero{padding:22px 20px}
  .practice-hero h1{font-size:24px}
  .ph-sub{font-size:15px;margin-bottom:18px}
  .rep-filters .field{max-width:none}
}

/* ===== Batch-3: competency progress (over time) ===== */
.ct-heads{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.ct-head{display:flex;align-items:center;gap:10px;flex:1 1 240px;border:1px solid var(--outline-variant);border-radius:var(--r);padding:12px 14px;background:var(--surface-lowest)}
.ct-head .material-symbols-outlined{font-size:24px}
.ct-head.up .material-symbols-outlined{color:var(--good)}
.ct-head.down .material-symbols-outlined{color:var(--bad)}
.ct-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.ct-card{border:1px solid var(--outline-variant);border-radius:var(--r-card);padding:14px 16px;background:var(--surface-lowest)}
.ct-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.ct-name{font-weight:700;font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dchip{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);flex:0 0 auto}
.dchip.up{background:var(--good-container);color:var(--good)}
.dchip.down{background:var(--error-container);color:var(--bad)}
.dchip.flat{background:var(--surface-container);color:var(--on-surface-variant)}
.spark{width:100%;height:48px;display:block}
.spark-line{fill:none;stroke:var(--primary);stroke-width:2;vector-effect:non-scaling-stroke}
.ct-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:12px}
.ct-last{font-weight:700}

/* ===== Batch-3b: target-interview goal (countdown + cadence) ===== */
.goal-card{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  background:linear-gradient(135deg,var(--primary),var(--primary-container));color:#fff;
  border-radius:var(--r-card);padding:22px 24px;margin:0 0 18px;box-shadow:var(--sh-md,0 8px 28px rgba(0,55,176,.22))}
.goal-card.urgent{box-shadow:0 0 0 2px #ffd7a0,0 8px 28px rgba(0,55,176,.28)}
.goal-main{min-width:0}
.goal-eyebrow{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.9}
.goal-eyebrow .material-symbols-outlined{font-size:16px}
.goal-title{font-size:16px;font-weight:600;margin-top:6px;opacity:.96}
.goal-big{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:2px 0 6px}
.goal-sub{font-size:14px;line-height:1.5;opacity:.92;max-width:520px}
.goal-sub b{font-weight:700}
.goal-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:0 0 auto}
.btn-light{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--primary);border:none;border-radius:var(--r);
  font-weight:700;font-size:15px;padding:11px 18px;cursor:pointer;font-family:inherit}
.btn-light:hover{background:#eef0ff}
.btn-light .material-symbols-outlined{font-size:20px}
.goal-note{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:13px;opacity:.92}
.goal-note .material-symbols-outlined{font-size:17px}
.goal-note .link-on-dark{font-size:13px}
.goal-links{display:flex;gap:14px}
.link-on-dark{background:none;border:none;color:rgba(255,255,255,.85);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;padding:0;text-decoration:underline}
.link-on-dark:hover{color:#fff}
.goal-empty{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:18px 20px;margin:0 0 18px}
.goal-empty-l{display:flex;align-items:center;gap:12px}
.goal-empty-l > .material-symbols-outlined{font-size:26px;color:var(--primary);flex:0 0 auto}
.goal-edit{padding:20px;margin:0 0 18px}
.goal-edit .goal-eyebrow.dark-eyebrow{color:var(--primary);opacity:1}
.goal-form{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:12px}

/* ===== Prep planner v1 (readiness + pace + intensity) ===== */
.goal-card.planner{align-items:flex-start}
.goal-main{flex:1}
.goal-side{display:flex;flex-direction:column;align-items:center;gap:12px;flex:0 0 auto}
.readiness{text-align:center;line-height:1.05}
.r-num{font-size:42px;font-weight:800;letter-spacing:-.02em}
.r-num span{font-size:20px;opacity:.85;font-weight:700}
.r-label{font-size:13px;font-weight:700;margin-top:2px}
.r-cap{font-size:11px;opacity:.8;text-transform:uppercase;letter-spacing:.05em}
.plan-progress{margin-top:14px;max-width:380px}
.pp-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:6px}
.pp-pace{font-size:11px;font-weight:700;padding:2px 9px;border-radius:var(--r-full);background:rgba(255,255,255,.2)}
.pp-pace.behind{background:#ffd7a0;color:#5a3b00}
.pp-pace.ahead{background:#bff0d0;color:#0a5a2c}
.pp-bar{height:7px;border-radius:6px;background:rgba(255,255,255,.22);overflow:hidden}
.pp-bar i{display:block;height:100%;background:#fff;border-radius:6px;transition:width .4s ease}
.intensity{display:flex;align-items:center;gap:6px;margin-top:14px;flex-wrap:wrap}
.int-label{font-size:12px;opacity:.85;margin-right:2px}
.int-btn{font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;cursor:pointer;font-family:inherit;transition:.13s}
.int-btn.sel{background:#fff;color:var(--primary);border-color:#fff;font-weight:700}
/* intensity buttons inside the (light) edit card */
.goal-edit .intensity .int-btn{border-color:var(--outline-variant);color:var(--on-surface)}
.goal-edit .intensity .int-btn.sel{background:var(--primary);color:#fff;border-color:var(--primary)}

@media (max-width:640px){
  .goal-card{flex-direction:column;align-items:flex-start}
  .goal-actions,.goal-side{flex-direction:row;align-items:center;width:100%;justify-content:space-between;flex-wrap:wrap}
  .goal-form{grid-template-columns:1fr}
}

/* ===== Voice / mic check ===== */
.mic-check-btn{display:inline-flex;align-items:center;gap:6px;margin-top:12px;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:var(--r);font-weight:600;font-size:13px;padding:8px 14px;cursor:pointer;font-family:inherit;transition:.13s}
.mic-check-btn:hover{background:rgba(255,255,255,.24)}
.mic-check-btn .material-symbols-outlined{font-size:18px}
/* ===== Practice: action-first setup summary + on-demand option toggles ===== */
.practice-setup-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:0 0 18px}
.setup-summary{font-size:15px;color:#eaf0ff}
.setup-summary b{color:#fff;font-weight:700}
.setup-change{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:var(--r-full);font-weight:600;font-size:13px;padding:6px 12px;cursor:pointer;font-family:inherit;transition:.13s}
.setup-change .material-symbols-outlined{font-size:16px}
.setup-change:hover,.setup-change.active{background:rgba(255,255,255,.26)}
.practice-more{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.opt-toggle{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.30);border-radius:var(--r-full);font-weight:600;font-size:13px;padding:8px 14px;cursor:pointer;font-family:inherit;transition:.13s}
.opt-toggle .material-symbols-outlined{font-size:18px}
.opt-toggle:hover{background:rgba(255,255,255,.2)}
.opt-toggle.active{background:#fff;color:var(--primary);border-color:#fff}
.mc-prompt{font-size:16px;font-weight:600;color:var(--on-surface);background:var(--surface-low);border-left:3px solid var(--primary);border-radius:8px;padding:10px 14px;margin:0 0 12px}
.mc-controls{display:flex;align-items:center;gap:14px}
.mc-meter{flex:1;height:10px;border-radius:6px;background:var(--surface-container);overflow:hidden}
.mc-meter i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--good),var(--warn),var(--bad));transition:width .06s linear}
.btn.recording,.btn.recording:hover{background:var(--bad)}
.mc-head{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px}
.mc-conf{font-size:12px;font-weight:700;padding:2px 9px;border:1px solid;border-radius:var(--r-full)}
.mc-transcript{font-size:16px;line-height:1.6;color:var(--on-surface);margin:8px 0 0;background:var(--surface-low);border-radius:8px;padding:12px 14px}
.mc-transcript .mc-low{background:#ffe2cc;color:#7a4a00;border-radius:4px;padding:0 3px}
.info-note.warn{background:#fff4e5;color:#5a3b00}
.info-note.warn > .material-symbols-outlined{color:var(--warn)}
.info-note code{background:rgba(0,0,0,.06);padding:1px 5px;border-radius:4px;font-size:12px}

/* ===== Multi-goal switcher (Prep Journey v2) ===== */
.goal-switcher{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}
.goal-tab{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;padding:7px 14px;border-radius:var(--r-full);
  border:1px solid var(--outline-variant);background:var(--surface-lowest);color:var(--on-surface);cursor:pointer;font-family:inherit;transition:.13s}
.goal-tab:hover{border-color:var(--primary);background:var(--surface-container)}
.goal-tab.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
.goal-tab.add{border-style:dashed;color:var(--on-surface-variant)}
.goal-tab.add:hover{color:var(--primary)}
.goal-tab .material-symbols-outlined{font-size:16px}

/* ===== Prep journey view ===== */
.phase-track{display:flex;gap:10px;margin:0 0 20px;flex-wrap:wrap}
.phase-seg{flex:1 1 130px;border:1px solid var(--outline-variant);border-radius:var(--r);padding:12px 14px;background:var(--surface-lowest);position:relative}
.phase-seg .ph-name{font-weight:700;font-size:13px}
.phase-seg .ph-count{font-size:12px;color:var(--on-surface-variant);margin-top:2px}
.phase-seg.cur{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-fixed)}
.phase-seg.cur .ph-name{color:var(--primary)}
.phase-seg.done{background:var(--good-container);border-color:transparent}
.phase-seg.done .ph-name{color:var(--good)}
.sess-list{display:flex;flex-direction:column;gap:10px}
.sess-card{display:flex;align-items:center;gap:14px;border:1px solid var(--outline-variant);border-radius:var(--r-card);padding:14px 16px;background:var(--surface-lowest)}
.sess-card.overdue{border-color:#ffd7a0;background:#fff8ef}
.sess-card.s-completed .sess-body{opacity:.7}
.sess-card.s-skipped .sess-body{opacity:.55}
.sess-ic{flex:0 0 40px;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--primary-fixed);color:var(--primary)}
.sess-ic.ph-foundations{background:var(--good-container);color:var(--good)}
.sess-ic.ph-depth{background:var(--primary-fixed);color:var(--primary)}
.sess-ic.ph-mock{background:#efe2ff;color:#6b3fb0}
.sess-ic.ph-final{background:#ffe2cc;color:var(--warn)}
.sess-ic .material-symbols-outlined{font-size:22px}
.sess-body{flex:1;min-width:0}
.sess-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:15px}
.sess-type{font-weight:700}
.sess-date{font-size:12px;margin-top:2px}
.sess-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--r-full)}
.sess-badge.done{background:var(--good-container);color:var(--good)}
.sess-badge.skip{background:var(--surface-container);color:var(--on-surface-variant)}
.sess-badge.over{background:#ffe2cc;color:var(--warn)}
.sess-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end}
.sess-actions .btn-light{padding:8px 14px;font-size:14px}
.mc-link{background:none;border:none;color:var(--primary);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;padding:0}
.mc-link:hover{text-decoration:underline}
/* timeline rail connecting session nodes (progression) */
.sess-timeline .sess-card{position:relative}
.sess-timeline .sess-card::before{content:'';position:absolute;left:35px;top:0;bottom:-10px;width:2px;background:var(--outline);z-index:0}
.sess-timeline .sess-card:first-child::before{top:34px}
.sess-timeline .sess-card:last-child::before{display:none}
.sess-timeline .sess-card.s-completed::before{background:var(--good)}
.sess-timeline .sess-ic{position:relative;z-index:1}
.sess-card.current .sess-ic{outline:2px solid var(--primary);box-shadow:0 0 0 4px var(--primary-fixed)}
.sess-card.s-completed .sess-ic::after{content:'check';font-family:'Material Symbols Outlined';position:absolute;right:-4px;bottom:-4px;width:18px;height:18px;border-radius:50%;background:var(--good);color:#fff;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface-lowest);z-index:2}
.sess-card.s-skipped .sess-ic{filter:grayscale(.6)}
@media (max-width:640px){
  .sess-card{flex-wrap:wrap}
  .sess-actions{width:100%;justify-content:flex-start;margin-top:4px}
}

/* ===== Task 7: journey calendar ===== */
.jcal{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:8px}
.jcal-month{flex:1 1 300px;min-width:0;max-width:420px;border:1px solid var(--outline-variant);border-radius:var(--r-card);padding:14px 16px;background:var(--surface-lowest)}
.jcal-title{font-weight:700;font-size:14px;margin-bottom:10px}
.jcal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}
.jcal-wd{text-align:center;font-size:11px;font-weight:700;color:var(--on-surface-variant);padding-bottom:4px}
.jcal-cell{position:relative;aspect-ratio:1/1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:9px;font-size:13px}
.jcal-cell.empty{visibility:hidden}
.jcal-cell .jcal-num{color:var(--on-surface-variant)}
.jcal-cell.has{background:var(--surface-container);cursor:pointer;transition:.12s}
.jcal-cell.has .jcal-num{color:var(--on-surface);font-weight:600}
.jcal-cell.has:hover{background:var(--primary-fixed)}
.jcal-cell.today{box-shadow:inset 0 0 0 2px var(--primary)}
.jcal-cell.today .jcal-num{color:var(--primary);font-weight:700}
.jcal-cell.sel{background:var(--primary);}
.jcal-cell.sel .jcal-num{color:#fff}
.jcal-dots{display:flex;gap:2px;margin-top:3px;height:6px}
.jcal-dot{width:6px;height:6px;border-radius:50%;background:var(--primary)}
.jcal-dot.ph-foundations{background:var(--good)}
.jcal-dot.ph-depth{background:var(--primary)}
.jcal-dot.ph-mock{background:#6b3fb0}
.jcal-dot.ph-final{background:var(--warn)}
.jcal-cell.sel .jcal-dot{background:#fff}
.cal-clear{margin-left:8px;border:1px solid var(--outline-variant);background:var(--surface-lowest);color:var(--primary);font-weight:600;font-size:12px;border-radius:var(--r-full);padding:3px 10px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;vertical-align:middle;font-family:inherit}
.cal-clear .material-symbols-outlined{font-size:15px}
.cal-clear:hover{background:var(--surface-container)}
/* calendar as an on-demand date filter (popover) */
.sessions-h{position:relative}
.cal-filter{margin-left:auto;position:relative}
.cal-toggle{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--outline-variant);background:var(--surface-lowest);color:var(--on-surface-variant);font-weight:600;font-size:13px;border-radius:var(--r-full);padding:7px 13px;cursor:pointer;font-family:inherit;transition:.13s}
.cal-toggle .material-symbols-outlined{font-size:17px}
.cal-toggle:hover{border-color:var(--primary);color:var(--primary)}
.cal-toggle.open{border-color:var(--primary);color:var(--primary);background:var(--primary-fixed)}
.cal-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:45;background:var(--surface-lowest);border:1px solid var(--outline-variant);border-radius:var(--r-card);box-shadow:var(--sh-lg,0 16px 40px rgba(16,24,46,.18));padding:14px;width:336px;max-width:88vw}
.cal-pop .jcal{margin:0}
.cal-pop .jcal-month{flex-basis:100%;max-width:none;border:none;padding:0}

/* ===== P2 polish: report verdict legend ===== */
.verdict-legend{display:flex;flex-wrap:wrap;gap:8px 14px;margin:0 0 14px;font-size:12px;color:var(--on-surface-variant)}
.verdict-legend .vl{display:inline-flex;align-items:center;gap:6px}
.verdict-legend .badge{font-size:10px;padding:2px 8px}

/* ===== Interview-quality report: dimension chips + covered/to-improve + persona badge ===== */
.qa-dims{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 12px}
.qa-dim{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--on-surface-variant);background:var(--surface-container);border-radius:var(--r-full);padding:3px 11px}
.qa-dim b{font-size:13px}
.qa-list{margin:0 0 12px}
.qa-list .ans-h{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;margin-bottom:4px}
.qa-list .ans-h .material-symbols-outlined{font-size:18px}
.qa-list.good .ans-h{color:var(--good)}
.qa-list.warn .ans-h{color:var(--warn)}
.qa-list ul{margin:0;padding-left:22px;font-size:14px;line-height:1.5}
.qa-list li{margin:3px 0}
.persona-badge{display:inline-block;margin-left:8px;font-size:11px;font-weight:700;background:rgba(255,255,255,.18);color:#fff;border-radius:var(--r-full);padding:3px 10px;vertical-align:middle}
/* interviewer-style picker on the Practice setup */
.persona-picker{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:6px}
.persona-opt{display:flex;flex-direction:column;gap:2px;text-align:left;border:1px solid var(--outline-variant);background:var(--surface-lowest);border-radius:var(--r);padding:11px 13px;cursor:pointer;font-family:inherit;transition:.13s}
.persona-opt b{font-size:14px;color:var(--on-surface)}
.persona-opt small{font-size:11px;color:var(--on-surface-variant)}
.persona-opt:hover{border-color:var(--primary)}
.persona-opt.sel{border-color:var(--primary);background:var(--primary-fixed);box-shadow:0 0 0 1px var(--primary)}
.persona-opt.sel b{color:var(--primary)}
@media (max-width:640px){ .persona-picker{grid-template-columns:1fr} }

@media (max-width:640px){
  .jcal{gap:12px}
  .jcal-month{flex-basis:100%;max-width:none;padding:12px 10px}
  .jcal-grid{gap:3px}
  .jcal-cell{font-size:12px;border-radius:7px}
  .jcal-dot{width:5px;height:5px}
}

/* ===== Critique Batch 1: connectivity + labels ===== */
.stat.stat-link{cursor:pointer;transition:.13s}
.stat.stat-link:hover{border-color:var(--primary);box-shadow:var(--sh-sm);transform:translateY(-1px)}
.score-pending{display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--r-full);background:#fff4e5;color:#5a3b00;white-space:nowrap}
.practice-focus{display:inline-flex;align-items:center;gap:6px;margin-top:12px;background:rgba(255,255,255,.16);color:#fff;border-radius:var(--r);padding:8px 14px;font-size:13px}
.practice-focus .material-symbols-outlined{font-size:18px}
.rcard-right{display:flex;align-items:center;gap:8px}
.rcard-chev{color:var(--on-surface-variant);font-size:22px}

/* ===== Chunk A: goal modal + toast + phase stepper ===== */
.modal-scrim{position:fixed;inset:0;background:rgba(16,24,46,.45);z-index:79;opacity:0;pointer-events:none;transition:.18s}
.modal-scrim.open{opacity:1;pointer-events:auto}
.modal{position:fixed;z-index:80;top:50%;left:50%;transform:translate(-50%,-50%);width:min(520px,94vw);max-height:90vh;overflow-y:auto}
.modal.hidden{display:none}
.modal-card{padding:22px}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(12px);z-index:90;background:var(--on-surface);color:#fff;padding:11px 18px;border-radius:var(--r-full);font-size:14px;font-weight:600;box-shadow:var(--sh-md,0 8px 28px rgba(0,0,0,.25));opacity:0;pointer-events:none;transition:.2s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:640px){ .toast{bottom:84px} }
/* phase tracker as a connected stepper */
.phase-seg{display:flex;align-items:center;gap:10px}
.ph-step{flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--surface-container);color:var(--on-surface-variant);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.phase-seg.cur .ph-step{background:var(--primary);color:#fff}
.phase-seg.done .ph-step{background:var(--good);color:#fff}
.goal-card.summary .goal-sub{font-size:14px}
/* pace buttons inside the (light) modal need dark text like the edit card */
.modal-card .intensity .int-btn{border-color:var(--outline-variant);color:var(--on-surface)}
.modal-card .intensity .int-btn.sel{background:var(--primary);color:#fff;border-color:var(--primary)}
/* Chunk B: sticky profile save + report score legend */
.profile-save-bar{position:sticky;bottom:0;background:var(--bg);border-top:1px solid var(--outline-variant);margin-top:18px;padding:14px 2px;z-index:30}
.score-legend{font-size:12px;margin:8px 0 0;opacity:.85}

/* ===== Mobile-responsive pass (audit fixes) ===== */
@media (max-width:820px){
  /* P2-1: the "sticky" profile Save bar was hidden behind the fixed bottom nav
     mid-scroll → lift it above the 60px botnav so Save is always reachable */
  .profile-save-bar{bottom:calc(64px + env(safe-area-inset-bottom));z-index:62}
  /* P2-3: bump cramped touch targets toward the ~40px comfortable floor */
  .mc-link{min-height:40px;display:inline-flex;align-items:center}
  .goal-tab{min-height:40px}
  .int-btn{min-height:38px;display:inline-flex;align-items:center}
  .icon-btn{min-width:40px;min-height:40px;align-items:center;justify-content:center}
}
@media (max-width:640px){
  /* P1-2: board.html — one column fills the screen (swipe between), header wraps,
     card-move buttons get a bigger tap area */
  .bhead{flex-wrap:wrap;padding:12px 16px;gap:8px}
  .bhead .sub{margin-left:6px;font-size:11px}
  .board{padding:16px 14px;gap:12px;scroll-snap-type:x mandatory}
  .col{width:86vw;min-width:86vw;scroll-snap-align:start}
  .kbtn{min-height:38px;padding:7px 12px}
}

/* ===== ANIM-1: whisper-subtle app-wide micro-interactions (motion-safe only) ===== */
@media (prefers-reduced-motion: no-preference){
  @keyframes mmViewIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  /* gentle fade-up as each view becomes visible — only AFTER first paint (body.booted),
     so a refresh shows its view instantly instead of sliding in mid-data-load */
  body.booted .page:not(.hidden){animation:mmViewIn .38s cubic-bezier(.22,.61,.36,1)}
  /* staggered reveal for list grids (reports, dashboard recent) */
  body.booted .stagger > *{animation:mmViewIn .45s cubic-bezier(.22,.61,.36,1) both}
  .stagger > *:nth-child(2){animation-delay:.04s}
  .stagger > *:nth-child(3){animation-delay:.08s}
  .stagger > *:nth-child(4){animation-delay:.12s}
  .stagger > *:nth-child(5){animation-delay:.16s}
  .stagger > *:nth-child(6){animation-delay:.20s}
  .stagger > *:nth-child(7){animation-delay:.24s}
  .stagger > *:nth-child(n+8){animation-delay:.28s}
  /* subtle press feedback + card lift */
  .btn:active,.btn-light:active,.btn-ghost:active,.btn-lg:active{transform:translateY(1px)}
  .rcard{transition:transform .16s ease, box-shadow .16s ease}
  .rcard:hover{transform:translateY(-2px)}
}

/* ===== ANIM-4: report reveal ===== */
@property --ringp{syntax:'<number>';inherits:false;initial-value:0}
/* mastery ring fill is driven by --ringp so it can sweep on open */
.rhero .scorering.rhero-ring{background:conic-gradient(#fff calc(var(--ringp)*1%), rgba(255,255,255,.28) 0)}
@media (prefers-reduced-motion: no-preference){
  .rhero .scorering.rhero-ring{transition:--ringp 1.1s cubic-bezier(.22,.61,.36,1)}
  @keyframes mmBarGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
  #report .cbar i{transform-origin:left;animation:mmBarGrow .9s cubic-bezier(.22,.61,.36,1)}
}

/* ===== Critique Batch 2: a11y signals, chart axes, practice polish ===== */
/* pending pill: icon + text so "awaiting" doesn't lean on colour alone */
.score-pending{display:inline-flex;align-items:center;gap:4px}
.score-pending .material-symbols-outlined{font-size:14px}
/* score-trend axis + legend */
.trend-axis{fill:var(--on-surface-variant);font-size:11px;font-weight:600;font-family:var(--font)}
.trend-gridlabel{fill:var(--on-surface-variant);font-size:10px;font-weight:700;font-family:var(--mono);opacity:.8}
.trend-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;font-size:11px;color:var(--on-surface-variant)}
.trend-legend .lg{display:inline-flex;align-items:center;gap:5px}
.trend-legend .lg i{width:9px;height:9px;border-radius:50%;display:inline-block}
/* dashboard competency legend */
.comp-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px;font-size:11px;color:var(--on-surface-variant)}
.comp-legend .lg{display:inline-flex;align-items:center;gap:5px}
.comp-legend .lg i{width:9px;height:9px;border-radius:2px;display:inline-block}
/* tailor-to-job char counter */
.jd-count{font-size:12px;margin-top:6px;text-align:right}
.jd-count.warn{color:var(--warn);font-weight:600}
/* request-a-role response-time note */
.req-eta{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--on-surface-variant);margin-left:10px}
.req-eta .material-symbols-outlined{font-size:15px}
/* mic-check pass banner */
.mc-ok{display:flex;align-items:center;gap:10px;margin-top:12px;padding:12px 14px;border-radius:var(--r);background:var(--good-container);color:var(--good)}
.mc-ok .material-symbols-outlined{font-size:22px}
.mc-ok b{color:var(--good)}
.mc-ok .btn-light{margin-top:8px}
/* skills tag-input */
.taginput{display:flex;flex-wrap:wrap;gap:8px;min-height:20px}
.tag{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;padding:5px 6px 5px 12px;border-radius:var(--r-full);background:var(--primary-fixed);color:var(--primary)}
.tag-x{display:inline-flex;align-items:center;justify-content:center;border:none;background:none;color:var(--primary);cursor:pointer;padding:0;border-radius:50%;width:18px;height:18px;transition:.12s}
.tag-x:hover{background:var(--primary);color:#fff}
.tag-x .material-symbols-outlined{font-size:15px}
/* month/year date pickers in profile edit */
.dlbl{display:block;font-size:12px;color:var(--on-surface-variant);font-weight:600;margin-bottom:5px}
.dsel{display:flex;gap:8px}
.dsel select{width:auto;flex:1 1 0;min-width:0}
.dsel select:disabled{opacity:.5;cursor:not-allowed}
/* My Plan empty state — explainer + example roadmap */
.journey-empty{padding:28px}
.je-head{display:flex;gap:14px;align-items:flex-start}
.je-head > .material-symbols-outlined{font-size:32px;color:var(--primary);flex:0 0 auto}
.je-head h2{margin:0 0 6px;font-size:22px;letter-spacing:-.01em}
.je-head p{margin:0;max-width:620px}
.je-road{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:22px 0}
.je-step{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--outline-variant);border-radius:var(--r-lg);padding:14px;background:var(--surface-lowest)}
.je-ic{width:38px;height:38px;flex:0 0 38px;border-radius:var(--r);background:var(--primary-fixed);color:var(--primary);display:flex;align-items:center;justify-content:center}
.je-num{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--outline)}
.je-t{font-weight:700;font-size:14px;margin:2px 0 3px}
.je-d{font-size:12px;line-height:1.4}
.je-example{border:1px dashed var(--outline-variant);border-radius:var(--r-lg);padding:16px;background:var(--surface-low);margin-bottom:20px}
.je-ex-label{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;margin-bottom:10px}
.je-ex-label .material-symbols-outlined{font-size:18px;color:var(--primary)}
.je-ex-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:6px 0;border-top:1px solid var(--outline-variant);font-size:13px}
.je-ex-phase{font-weight:600}

/* ===== ANIM-2: landing hero 3D backdrop ===== */
#landing{position:relative;min-height:100vh}
#heroGfx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0;transition:opacity 1.2s ease}
#heroGfx.on{opacity:1}
#landing > :not(#heroGfx){position:relative;z-index:1}

/* ===== REV-G: accessibility — chip restructure + WCAG-AA contrast ===== */
.uc-open{display:flex;align-items:center;gap:11px;flex:1;min-width:0;background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-align:left;border-radius:var(--r)}
.user-chip{cursor:default}
.chip-label{color:var(--on-surface-variant)}     /* was --outline (4.48:1) → 8.9:1 */
.badge.b-na{background:#5b5d6b}                   /* white text ~6.6:1, distinct from b-partial */
.rcard-score small{opacity:1}                    /* restore full score colour (was .7 → 3.16:1) */
.vbadge.on .vb-meta{color:#006b39}               /* darker green on --good-container */
.pill-open{color:#006b39}                         /* "Open to work" pill text contrast */

/* ===== Button system (consolidated & documented) =====
   ACTION buttons — same rhythm + identical interaction states (press via ANIM-1 :active,
   ring :focus-visible, dim :disabled); differ only by emphasis colour:
     .btn        primary   — filled blue (the one main action per view)
     .btn-ghost  secondary — outlined on neutral surface
     .btn-light  tonal     — white/blue, for use on coloured/dark surfaces (hero, focus cards)
     .btn-lg     large primary CTA (hero)
   LOW-EMPHASIS: .link / .mc-link / .link-on-dark — inline text actions
   PILLS/TOGGLES (radius:full): .chip / .goal-tab / .opt-toggle / .cal-toggle / .add-inline / .persona-opt
   ICON-ONLY: .icon-btn (rounded utility) · .coach-close / .tag-x (circular close affordance)
   New buttons should reuse one of these — do not introduce ad-hoc button classes. */
.btn-ghost:disabled, .btn-light:disabled, .btn-lg:disabled{opacity:.5;cursor:default;box-shadow:none}
.btn-ghost:focus-visible, .btn-light:focus-visible{outline:none;box-shadow:var(--ring)}
