*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-text-size-adjust:100%}
body{overflow-x:hidden}
img,video,canvas{max-width:100%}

:root{
  --ink:#080808;
  --paper:#ffffff;
  --g50:#F9F9F9;
  --g100:#F2F2F2;
  --g150:#E8E8E8;
  --g200:#DCDCDC;
  --g300:#C0C0C0;
  --g400:#9A9A9A;
  --g500:#707070;
  --g600:#525252;
  --g800:#282828;
  --r:12px;
  --pad-x:clamp(20px,5vw,72px);
}

body{
  font-family:'Space Grotesk',sans-serif;
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 38 38'%3E%3Ccircle cx='9' cy='8.5' r='6.5' fill='%23080808'/%3E%3Ccircle cx='29' cy='8.5' r='6.5' fill='%23080808'/%3E%3Ccircle cx='19' cy='23' r='13.5' fill='white'/%3E%3Ccircle cx='19' cy='23' r='13.5' fill='none' stroke='%23ddd' stroke-width='0.8'/%3E%3Cellipse cx='14' cy='21' rx='4.2' ry='3.8' fill='%23080808'/%3E%3Cellipse cx='24' cy='21' rx='4.2' ry='3.8' fill='%23080808'/%3E%3Ccircle cx='14.9' cy='20.3' r='1.3' fill='white'/%3E%3Ccircle cx='24.9' cy='20.3' r='1.3' fill='white'/%3E%3Cellipse cx='19' cy='26' rx='2' ry='1.4' fill='%23080808'/%3E%3C/svg%3E") 18 18, auto;
}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:300;
  height:80px;display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:0 clamp(16px,3.5vw,56px);
  background:#fff;
  border-bottom:1px solid var(--g150);
  gap:24px;
}
.nav-left{display:flex;align-items:center;gap:32px;list-style:none;justify-content:flex-start}
.nav-right{display:flex;align-items:center;gap:32px;justify-content:flex-end}
.nav-left a,.nav-right a{
  font-size:11px;font-weight:600;text-decoration:none;
  color:var(--g800);letter-spacing:.12em;text-transform:uppercase;
  transition:color .12s;
}
.nav-left a:hover,.nav-right a:hover{color:var(--ink)}
.nav-logo{display:flex;align-items:center;text-decoration:none;justify-content:center}
.nav-logo img{width:72px;height:72px;max-width:72px;max-height:72px;object-fit:contain;transition:transform .2s}
.nav-logo img:hover{transform:scale(1.06)}
.brand-motto{
  text-align:center;
  font-size:11.5px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--g600);
  padding:8px 12px 10px;
  border-bottom:1px solid var(--g150);
  background:#fff;
}
.nav-divider{display:none}
.nav-toggle{display:none}
.mobile-menu{display:none}
.nav-right .nav-cta{
  font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  background:var(--ink);color:#fff !important;padding:9px 22px;border-radius:6px;
  text-decoration:none;transition:opacity .14s;
}
.nav-right .nav-cta:hover{opacity:.8}
@media(max-width:900px){.nav-left{display:none}.nav-right{gap:12px}}
@media(max-width:640px){
  nav{height:68px;padding:0 clamp(12px,4vw,24px);grid-template-columns:44px 1fr 44px}
  .nav-logo{grid-column:2;justify-self:center}
  .nav-logo img{width:52px;height:52px}
  .brand-motto{font-size:10px;letter-spacing:.08em;padding:7px 10px 9px}
  .nav-right{display:none}
  .nav-toggle{
    width:38px;height:38px;border:1px solid var(--g200);border-radius:9px;
    background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;
    cursor:pointer;grid-column:1;grid-row:1;justify-self:start;align-self:center;
  }
  .nav-toggle span,
  .nav-toggle::before,
  .nav-toggle::after{
    content:'';display:block;width:17px;height:2px;border-radius:2px;background:currentColor;
    transition:transform .18s ease,opacity .18s ease;
  }
  .nav-toggle{flex-direction:column;gap:4px}
  .nav-toggle[aria-expanded="true"] span{opacity:0}
  .nav-toggle[aria-expanded="true"]::before{transform:translateY(6px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"]::after{transform:translateY(-6px) rotate(-45deg)}
  .mobile-menu{
    position:fixed;top:68px;left:12px;right:12px;z-index:290;
    display:flex;flex-direction:column;gap:4px;padding:10px;
    background:rgba(255,255,255,.96);border:1px solid var(--g150);border-radius:14px;
    box-shadow:0 18px 52px rgba(0,0,0,.14);
    transform:translateY(-10px);opacity:0;pointer-events:none;
    transition:opacity .18s ease,transform .18s ease;
  }
  .mobile-menu.open{opacity:1;transform:translateY(0);pointer-events:auto}
  .mobile-menu a{
    padding:12px 14px;border-radius:9px;text-decoration:none;color:var(--g800);
    font-size:12px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  }
  .mobile-menu a:active,.mobile-menu a:hover{background:var(--g50);color:var(--ink)}
  .mobile-menu .mobile-menu-cta{background:var(--ink);color:#fff;text-align:center;margin-top:4px}
}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:8px;font-family:'Space Grotesk',sans-serif;font-size:13.5px;font-weight:500;text-decoration:none;cursor:pointer;border:1.5px solid transparent;transition:all .16s;white-space:nowrap}
.btn-outline{background:transparent;border-color:var(--g200);color:var(--ink)}
.btn-outline:hover{border-color:var(--ink)}
.btn-solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-solid:hover{background:var(--g800)}
.btn-lg{padding:13px 26px;font-size:15px;border-radius:10px;font-weight:500}
@media(max-width:900px){.nav-links,.nav-divider{display:none}}

/* ── HERO ── */
.hero-section{
  position:relative;
  background:url('uploads/right-image.png') center center / cover no-repeat;
  display:flex;
  align-items:center;
  min-height:clamp(560px,72vh,860px);
}
/* Fully opaque white behind the text, fades to transparent on the right */
.hero-section::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(
    to right,
    #ffffff 0%,
    #ffffff 42%,
    rgba(255,255,255,0.75) 62%,
    rgba(255,255,255,0) 100%
  );
  pointer-events:none;
}
.hero{
  position:relative;z-index:1;
  width:100%;
  max-width:760px;
  padding:clamp(28px,3.6vw,44px) var(--pad-x) clamp(22px,3vw,36px);
  margin-left:clamp(24px,7vw,120px);
  display:flex;
  align-items:flex-start;
}
.hero-content{width:100%;max-width:560px}

@media(min-width:1600px){
  .hero-section{min-height:clamp(700px,78vh,980px)}
  .hero{max-width:860px;margin-left:clamp(56px,8vw,160px)}
  .hero-content{max-width:640px}
}

@media(min-width:1100px) and (max-width:1399px){
  .hero-section{min-height:clamp(560px,70vh,760px)}
  .hero{max-width:680px;margin-left:clamp(20px,5.5vw,74px)}
  .hero-content{max-width:520px}
}

@media(min-width:861px) and (max-width:1099px){
  .hero-section{
    min-height:clamp(520px,66vh,680px);
    align-items:flex-start;
  }
  .hero-section::before{
    background:linear-gradient(to right,#ffffff 0%,#ffffff 54%,rgba(255,255,255,0.68) 76%,rgba(255,255,255,0) 100%);
  }
  .hero{
    max-width:600px;
    margin-left:clamp(14px,3.8vw,40px);
    padding-top:clamp(22px,3.2vw,34px);
  }
  .hero-content{max-width:470px}
}

@media(min-width:641px) and (max-width:860px){
  .hero-section{
    min-height:clamp(500px,62vh,640px);
    align-items:flex-start;
  }
  .hero-section::before{
    background:linear-gradient(to right,#ffffff 0%,#ffffff 62%,rgba(255,255,255,0.72) 84%,rgba(255,255,255,0) 100%);
  }
  .hero{
    max-width:540px;
    margin-left:clamp(10px,3.5vw,28px);
    padding-top:clamp(18px,2.8vw,28px);
  }
  .hero-content{max-width:420px}
  .hero-minis{grid-template-columns:1fr;max-width:100%}
}

@media(max-width:640px){
  .hero-section{
    background-image:url('uploads/image-mobile.png');
    background-position:center bottom;
    background-size:cover;
    min-height:clamp(520px,74svh,700px);
    align-items:flex-start;
    overflow:hidden;
  }
  .hero-section::before{
    background:linear-gradient(
      to bottom,
      rgba(255,255,255,0.98) 0%,
      rgba(255,255,255,0.94) 48%,
      rgba(255,255,255,0.78) 78%,
      rgba(255,255,255,0.46) 100%
    );
  }
  .hero{
    margin:0;
    max-width:100%;
    padding:clamp(18px,6vw,30px) clamp(14px,4vw,20px) clamp(24px,7vw,34px);
  }
  .hero-content{max-width:100%}
  .hero-sub{max-width:100%}
  .hero-minis{grid-template-columns:1fr;width:100%;max-width:100%}
  .hero-mini{justify-content:flex-start;text-align:left}
  .hero-ctas{width:100%}
  .hero-ctas .btn{width:100%}
}

/* hero left */
.hero-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;max-width:100%;padding:5px 12px;border-radius:40px;border:1px solid var(--g200);background:var(--g50);font-size:11.5px;font-weight:500;color:var(--g500);line-height:1.3}
.hero-badge svg{color:var(--g400);flex-shrink:0}
h1.hero-head{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(36px,5vw,68px);
  letter-spacing:-.04em;line-height:1.05;
  color:var(--ink);margin-bottom:14px;
}
h1.hero-head .underline-accent{
  display:inline-block;position:relative;
}
h1.hero-head .underline-accent::after{
  content:'';position:absolute;
  bottom:6px;left:0;right:0;height:4px;
  background:var(--ink);border-radius:2px;
}
.hero-sub{font-size:clamp(13.5px,1.2vw,15.5px);color:var(--g500);line-height:1.6;max-width:410px;margin-bottom:18px}
.hero-ctas{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.hero-minis{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-width:430px}
.hero-mini{display:flex;align-items:flex-start;gap:10px;min-width:0}
.mini-icon{width:30px;height:30px;border-radius:8px;background:var(--g100);border:1px solid var(--g150);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mini-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px}
.mini-desc{font-size:11.5px;color:var(--g400)}
@media(max-width:640px){
  .hero-minis{grid-template-columns:1fr;width:100%}
  .hero-mini{justify-content:flex-start;text-align:left}
}

/* typewriter cursor */
.tw-cursor{
  display:inline-block;
  width:3px;height:.82em;
  background:var(--ink);
  border-radius:2px;
  vertical-align:middle;
  margin-left:3px;
  animation:blink .7s step-start infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hn-cuet{transition:opacity 1.2s ease}

/* ── STATS BAR ── */
.stats-bar{background:var(--g50);border-top:1px solid var(--g150);border-bottom:1px solid var(--g150);padding:24px var(--pad-x)}
.stats-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.stat-item{display:flex;align-items:center;gap:11px}
.stat-icon{width:38px;height:38px;border-radius:10px;background:var(--paper);border:1px solid var(--g200);display:flex;align-items:center;justify-content:center;color:var(--g500);flex-shrink:0}
.stat-n{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:24px;letter-spacing:-.02em;color:var(--ink);line-height:1}
.stat-l{font-size:11.5px;color:var(--g400);margin-top:2px}
.stat-div{width:1px;height:36px;background:var(--g200)}

/* ── MOBILE STATS BAR ── */
@media(max-width:640px){
  .stats-bar{padding:20px var(--pad-x)}
  .stats-inner{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    align-items:stretch;
    gap:18px 14px;
  }
  .stat-item{
    display:grid;
    grid-template-columns:38px minmax(0,1fr);
    align-items:center;
    gap:10px;
    min-width:0;
  }
  .stat-div{display:none}
  .stat-n{font-size:20px}
  .stat-l{line-height:1.25}
}

@media(max-width:360px){
  .stats-inner{grid-template-columns:1fr}
}

/* ── SECTION COMMONS ── */
.sec{padding:clamp(60px,7vw,96px) var(--pad-x)}
.sec-alt{background:var(--g50)}
.sec-inner{max-width:1200px;margin:0 auto}
.sec-head{text-align:center;margin-bottom:52px}
.sec-head h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(26px,3.2vw,44px);letter-spacing:-.025em;margin-bottom:12px}
.sec-head p{font-size:15.5px;color:var(--g500);max-width:460px;margin:0 auto}

/* ── FEATURES GRID ── */
.features-grid{
  display:grid;grid-template-columns:repeat(6,1fr);
  border:1px solid var(--g150);border-radius:18px;overflow:hidden;
}
@media(max-width:960px){.features-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:360px){.features-grid{grid-template-columns:1fr}}
.feat-card{
  padding:28px 22px;
  border-right:1px solid var(--g150);
  transition:background .18s;
}
.feat-card:last-child{border-right:none}
@media(max-width:960px){.feat-card:nth-child(3n){border-right:none}.feat-card:nth-child(n+4){border-top:1px solid var(--g150)}}
@media(max-width:560px){
  .feat-card:nth-child(2n){border-right:none}
  .feat-card:nth-child(n+3){border-top:1px solid var(--g150)}
  .feat-card{padding:20px 16px}
}
@media(max-width:360px){.feat-card:nth-child(n+2){border-top:1px solid var(--g150)}}
.feat-card:hover{background:var(--g50)}
.feat-icon{width:40px;height:40px;border-radius:10px;background:var(--g100);border:1px solid var(--g150);display:flex;align-items:center;justify-content:center;color:var(--g500);margin-bottom:14px}
.feat-title{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;margin-bottom:5px;letter-spacing:-.01em}
.feat-desc{font-size:12px;color:var(--g400);line-height:1.6}

/* ── PRODUCTS: alternating illustrated rows ── */
.product-rows{display:flex;flex-direction:column}
.product-row{
  display:grid;grid-template-columns:1.02fr 1.1fr;
  gap:clamp(28px,5vw,64px);align-items:center;
  padding:clamp(36px,5.5vw,60px) 0;
}
.product-row:first-child{padding-top:6px}
.product-row:not(:last-child){border-bottom:1px solid var(--g150)}
.product-row:nth-child(even) .product-visual{order:-1}
.product-copy h3{
  font:700 clamp(20px,2.6vw,26px) 'Space Grotesk',sans-serif;
  letter-spacing:-.02em;margin:12px 0 10px;
}
.product-copy > p{font-size:14.5px;line-height:1.65;color:var(--g500);max-width:42ch}
.product-tag{
  display:inline-flex;align-items:center;
  font:700 10.5px 'Space Grotesk',sans-serif;letter-spacing:.12em;text-transform:uppercase;
  color:#3a5a23;background:#eef5e9;border:1px solid #d8e7cf;
  padding:5px 11px;border-radius:999px;
}
.product-points{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.product-points li{position:relative;padding-left:26px;font-size:13.5px;color:var(--g600);line-height:1.5}
.product-points li::before{
  content:'';position:absolute;left:0;top:3px;width:16px;height:16px;border-radius:50%;
  background:#6b9a5b url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/10px no-repeat;
}

/* shared visual card */
.product-visual{min-width:0}
.pv-card{
  background:#fff;border:1px solid var(--g150);border-radius:18px;
  padding:20px;box-shadow:0 18px 44px rgba(8,8,8,.06);
  display:flex;flex-direction:column;gap:14px;
}
.pv-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--g100);border:1px solid var(--g200);
  font:700 11px 'Space Grotesk',sans-serif;color:var(--g600);
}
.pv-avatar-accent{background:#6b9a5b;border-color:#6b9a5b;color:#fff}

/* 1 · Panda Review video card */
.pv-frame{
  position:relative;border-radius:12px;min-height:148px;
  background:radial-gradient(120% 120% at 30% 20%,#2b2b2b,#0c0c0c);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.pv-play{
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,.92);color:#0c0c0c;
  display:flex;align-items:center;justify-content:center;padding-left:4px;
  box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.pv-time{position:absolute;top:12px;right:14px;font:600 11px 'Space Grotesk',sans-serif;color:rgba(255,255,255,.85)}
.pv-bar{position:absolute;left:14px;right:14px;bottom:14px;height:4px;border-radius:999px;background:rgba(255,255,255,.25)}
.pv-bar span{display:block;height:100%;border-radius:999px;background:#f4b942}
.pv-meta{display:flex;align-items:center;gap:11px}
.pv-meta strong{display:block;font-size:13px}
.pv-meta span{font-size:11.5px;color:var(--g400)}
.pv-note{font-size:12.5px;color:var(--g600);background:var(--g50);border:1px solid var(--g150);border-radius:10px;padding:9px 12px}
.pv-note strong{color:#b23b3b}

/* 2 · Mentor session card */
.pv-people{display:flex;align-items:center;justify-content:center;gap:0}
.pv-connector{flex:1;max-width:120px;height:2px;background:var(--g200);position:relative;margin:0 -6px}
.pv-onepill{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font:700 10px 'Space Grotesk',sans-serif;color:#3a5a23;background:#eef5e9;
  border:1px solid #d8e7cf;border-radius:999px;padding:3px 9px;
}
.pv-slot{display:flex;align-items:center;gap:11px;background:var(--g50);border:1px solid var(--g150);border-radius:12px;padding:12px}
.pv-slot-ico{width:32px;height:32px;border-radius:9px;background:#fff;border:1px solid var(--g200);display:flex;align-items:center;justify-content:center;color:#6b9a5b;flex-shrink:0}
.pv-slot strong{display:block;font-size:13.5px}
.pv-slot span{font-size:11.5px;color:var(--g400)}
.pv-bubble{font-size:13px;color:var(--g600);font-style:italic;background:#fafdf6;border:1px solid #e2eedb;border-radius:12px;border-bottom-left-radius:3px;padding:11px 14px}

/* 3 · Blueprint roadmap card */
.pv-roadmap-head{display:flex;align-items:center;justify-content:space-between}
.pv-roadmap-head strong{font:700 14px 'Space Grotesk',sans-serif}
.pv-ring{
  position:relative;width:46px;height:46px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font:700 11px 'Space Grotesk',sans-serif;color:#3a5a23;
  background:conic-gradient(#6b9a5b var(--p),var(--g150) 0);
}
.pv-ring::before{content:'';position:absolute;width:34px;height:34px;border-radius:50%;background:#fff;z-index:-1}
.pv-weeks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.pv-weeks li{display:flex;align-items:center;gap:11px;font-size:13px;color:var(--g600)}
.pv-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--g300);flex-shrink:0;background:#fff}
.pv-dot.done{background:#6b9a5b;border-color:#6b9a5b}

/* 4 · Squad referral card */
.pv-chain{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.pv-arrow{color:var(--g300);font-size:15px}
.pv-off{font:700 10.5px 'Space Grotesk',sans-serif;color:#3a5a23;background:#eef5e9;border:1px solid #d8e7cf;border-radius:999px;padding:4px 9px}
.pv-gift{font-size:24px;line-height:1}
.pv-ladder{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.pv-ladder li{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--g600)}
.pv-rung{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:#6b9a5b;color:#fff;font:700 11px 'Space Grotesk',sans-serif}
.pv-link-text{margin-top:2px;font:600 12.5px 'Space Grotesk',sans-serif;color:#3a5a23;text-decoration:none}
.pv-link-text:hover{text-decoration:underline}

@media(max-width:780px){
  .product-row{grid-template-columns:1fr;gap:24px}
  .product-row .product-visual{order:0}
  .product-copy > p{max-width:100%}
}
@media(max-width:480px){
  .pv-card{padding:16px}
  .pv-frame{min-height:124px}
}

/* ── EVALUATION ── */
.eval-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:64px;align-items:center}
@media(max-width:860px){
  .eval-grid{grid-template-columns:1fr;gap:36px}
  .eval-sub{max-width:100%}
}
@media(max-width:560px){
  .eval-grid{gap:24px}
  .proc-vis{padding:18px}
}
.eval-tag{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--g400);margin-bottom:14px}
.eval-h{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(30px,3.2vw,50px);letter-spacing:-.03em;line-height:1.02;margin-bottom:18px}
.eval-h .em{font-style:italic;font-family:'Space Grotesk',sans-serif;font-weight:300;color:var(--g500)}
.eval-sub{font-size:15px;color:var(--g500);line-height:1.65;margin-bottom:22px;max-width:360px}
.eval-checks{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:30px}
.eval-checks li{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--g600)}
.chk{width:18px;height:18px;border-radius:50%;background:var(--g100);border:1px solid var(--g200);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* process visual */
.proc-vis{background:var(--paper);border:1px solid var(--g150);border-radius:20px;padding:28px;display:grid;grid-template-columns:1fr 28px 1fr 28px 1fr;gap:8px;align-items:start}
@media(max-width:640px){.proc-vis{grid-template-columns:1fr;gap:16px}.proc-arr{display:none}}
.proc-arr{display:flex;align-items:center;justify-content:center;color:var(--g300);font-size:20px;padding-top:40px}
@media(max-width:640px){.proc-arr{padding-top:0}}
.proc-step-n{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g400);margin-bottom:4px}
.proc-step-title{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;color:var(--ink);margin-bottom:3px}
.proc-step-sub{font-size:11.5px;color:var(--g400);margin-bottom:12px}
.proc-card{background:var(--g50);border:1px solid var(--g150);border-radius:10px;padding:12px}
.mc-opts{display:flex;flex-direction:column;gap:5px}
.mc-opt{display:flex;align-items:center;gap:7px;padding:5px 9px;border-radius:6px;border:1px solid var(--g150);font-size:11px;font-weight:500;color:var(--g500)}
.mc-opt.sel{border-color:var(--ink);background:var(--ink);color:var(--paper)}
.mc-lbl{font-weight:700;width:12px;flex-shrink:0}
.eval-stamp{
  font-family:'Space Grotesk',sans-serif;font-style:italic;font-weight:400;font-size:13.5px;
  color:var(--g600);border:1.5px solid var(--g200);border-radius:7px;
  padding:7px 12px;display:inline-block;transform:rotate(-4deg);margin-bottom:10px;
}
.expert-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.exp-av{width:26px;height:26px;border-radius:50%;background:var(--g200);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:9px;color:var(--g600);flex-shrink:0}
.exp-name{font-size:10.5px;font-weight:600;color:var(--ink)}
.exp-meta{font-size:9.5px;color:var(--g400)}
.score-circle{width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;flex-shrink:0}
.ns-list{display:flex;flex-direction:column;gap:5px}
.ns-item{font-size:10.5px;font-weight:500;background:var(--g100);border-radius:4px;padding:4px 8px;color:var(--ink)}
.ns-hd{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--g400);margin-bottom:6px}

/* ── TESTIMONIALS ── */
.tes-head{text-align:center;margin-bottom:48px}
.tes-head h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(26px,3.2vw,44px);letter-spacing:-.025em;margin-bottom:10px}
.tes-line{width:44px;height:3px;background:var(--ink);border-radius:2px;margin:0 auto}
.tes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:860px){.tes-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.tes-grid{grid-template-columns:1fr;gap:12px}}
.tes-card{background:var(--g50);border:1px solid var(--g150);border-radius:16px;padding:24px}
@media(max-width:500px){.tes-card{padding:18px}}
.tes-q{font-size:28px;color:var(--g200);font-family:Georgia,serif;line-height:1;margin-bottom:10px}
.tes-text{font-size:13px;color:var(--g500);line-height:1.72;margin-bottom:18px}
.tes-author{display:flex;align-items:center;gap:10px}
.tes-av{width:34px;height:34px;border-radius:50%;background:var(--g200);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;color:var(--g600);flex-shrink:0}
.tes-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12.5px}
.tes-inst{font-size:11px;color:var(--g400);margin-top:1px}

/* ── CTA BANNER ── */
.cta-wrap{padding:0 var(--pad-x) 72px;max-width:1340px;margin:0 auto}
.cta-band{
  background:var(--ink);border-radius:22px;
  display:grid;grid-template-columns:200px 1fr auto;
  gap:40px;align-items:center;padding:44px 52px;
  position:relative;overflow:hidden;
}
.cta-band::before{content:'';position:absolute;top:-60px;left:-60px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.03);pointer-events:none}
.cta-band::after{content:'';position:absolute;bottom:-80px;right:-40px;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.03);pointer-events:none}
@media(max-width:860px){
  .cta-band{grid-template-columns:1fr;padding:36px 28px;gap:24px}
  .cta-panda{display:none}
  .cta-benefits{flex-direction:row;flex-wrap:wrap;gap:10px 20px;min-width:auto}
}
@media(max-width:500px){
  .cta-band{padding:28px 20px;border-radius:16px}
  .cta-btns{flex-direction:column}
  .cta-btn-solid,.cta-btn-outline{width:100%;justify-content:center}
  .cta-wrap{padding-bottom:48px}
}
.cta-panda{width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}
.cta-panda img{width:100px;height:100px;object-fit:contain;filter:invert(1) brightness(2)}
.cta-body{position:relative;z-index:1}
.cta-h{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(24px,2.8vw,38px);letter-spacing:-.025em;line-height:1.05;color:var(--paper);margin-bottom:10px}
.cta-h .em{font-style:italic;font-family:'Space Grotesk',sans-serif;font-weight:300;color:var(--g400)}
.cta-sub{font-size:14px;color:rgba(255,255,255,.48);line-height:1.6}
.cta-btns{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.cta-btn-solid{background:var(--paper);color:var(--ink);padding:12px 24px;border-radius:9px;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:opacity .16s}
.cta-btn-solid:hover{opacity:.9}
.cta-btn-outline{background:transparent;color:rgba(255,255,255,.65);border:1.5px solid rgba(255,255,255,.18);padding:12px 24px;border-radius:9px;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:border-color .16s}
.cta-btn-outline:hover{border-color:rgba(255,255,255,.45);color:var(--paper)}
.cta-benefits{display:flex;flex-direction:column;gap:11px;flex-shrink:0;position:relative;z-index:1;min-width:200px}
.cta-benefit{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.62)}
.cta-benefit svg{color:rgba(255,255,255,.35);flex-shrink:0}

/* ── FOOTER ── */
footer{background:var(--g50);border-top:1px solid var(--g150);padding:clamp(44px,5vw,68px) var(--pad-x) 24px}
.foot-inner{max-width:1200px;margin:0 auto}
.foot-grid{display:grid;grid-template-columns:220px repeat(4,1fr);gap:40px;margin-bottom:44px}
@media(max-width:960px){.foot-grid{grid-template-columns:1fr 1fr;gap:28px 32px}}
@media(max-width:480px){
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .foot-tag{max-width:100%}
}
.foot-logo-row{display:flex;align-items:center;gap:8px;text-decoration:none;margin-bottom:10px}
.foot-logo-text{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15.5px;color:var(--ink);letter-spacing:-.02em}
.foot-logo-text span{color:var(--g400)}
.foot-tag{font-size:12.5px;color:var(--g400);line-height:1.6;margin-bottom:16px;max-width:180px}
.foot-social{display:flex;gap:7px}
.soc{width:30px;height:30px;border-radius:7px;border:1px solid var(--g200);background:var(--paper);display:flex;align-items:center;justify-content:center;color:var(--g400);text-decoration:none;transition:border-color .15s,color .15s}
.soc:hover{border-color:var(--ink);color:var(--ink)}
.foot-col-h{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12.5px;color:var(--ink);margin-bottom:14px}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-links a{font-size:12.5px;color:var(--g400);text-decoration:none;transition:color .14s}
.foot-links a:hover{color:var(--ink)}
.foot-email-desc{font-size:12.5px;color:var(--g400);margin-bottom:10px;line-height:1.5}
.foot-form{display:flex;gap:7px}
.foot-input{flex:1;padding:9px 13px;border-radius:8px;border:1px solid var(--g200);background:var(--paper);font:13px 'Space Grotesk',sans-serif;color:var(--ink);outline:none}
.foot-input:focus{border-color:var(--ink)}
.foot-input::placeholder{color:var(--g300)}
.foot-submit{width:34px;height:34px;border-radius:7px;background:var(--ink);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--paper);flex-shrink:0;transition:opacity .15s}
.foot-submit:hover{opacity:.75}
.foot-trust{margin-top:14px;font:italic 12.5px 'Playfair Display',serif;color:var(--g400)}
.foot-bottom{border-top:1px solid var(--g150);padding-top:18px;margin-top:6px;font-size:11.5px;color:var(--g400);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.foot-legal{display:flex;gap:18px}
.foot-legal a{color:var(--g400);text-decoration:none;transition:color .14s}
.foot-legal a:hover{color:var(--ink)}
@media(max-width:560px){.foot-bottom{flex-direction:column;text-align:center;gap:10px}}

/* ── GLOBAL MOBILE SECTION PADDING ── */
@media(max-width:480px){
  .sec{padding:clamp(44px,8vw,72px) var(--pad-x)}
  .sec-head{margin-bottom:32px}
  .sec-head p{font-size:14px}
  .tes-head{margin-bottom:32px}
  .cta-wrap{padding-left:clamp(12px,4vw,20px);padding-right:clamp(12px,4vw,20px)}
}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.au{animation:fadeUp .6s ease-out both}
.d1{animation-delay:.05s}.d2{animation-delay:.14s}.d3{animation-delay:.23s}.d4{animation-delay:.32s}.d5{animation-delay:.41s}

/* underline accent helper */
.ul-accent{display:inline-block;position:relative}
.ul-accent::after{content:'';position:absolute;bottom:4px;left:0;right:0;height:3.5px;background:var(--ink);border-radius:2px}

/* ── TWEAKS PANEL ── */
#twk{position:fixed;bottom:24px;right:24px;z-index:9999;background:#fff;border:1px solid var(--g150);border-radius:14px;padding:18px 20px;box-shadow:0 8px 40px rgba(0,0,0,.10);min-width:210px;display:none}
#twk.open{display:block}
.twk-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.twk-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--g400);font-family:'Space Grotesk',sans-serif}
.twk-x{background:none;border:none;cursor:pointer;font-size:16px;color:var(--g400);line-height:1;padding:0;font-family:inherit}
.twk-x:hover{color:var(--ink)}
.twk-sec{margin-bottom:14px}
.twk-sec:last-child{margin-bottom:0}
.twk-lbl{font-size:10.5px;font-weight:600;color:var(--g600);margin-bottom:7px;font-family:'Space Grotesk',sans-serif}
.twk-row{display:flex;gap:5px;flex-wrap:wrap}
.twk-opt{padding:5px 11px;border-radius:6px;border:1px solid var(--g200);font:500 11.5px 'Space Grotesk',sans-serif;cursor:pointer;color:var(--g500);background:#fff;transition:all .13s}
.twk-opt:hover{border-color:var(--ink);color:var(--ink)}
.twk-opt.on{border-color:var(--ink);background:var(--ink);color:#fff}

/* ── HERO HEADLINE MIXED TYPOGRAPHY ── */
h1.hero-head{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  font-size:clamp(38px,5.2vw,70px);
  letter-spacing:-.03em;line-height:1.08;
  color:var(--ink);margin-bottom:22px;
}
@media(min-width:1600px){
  h1.hero-head{font-size:clamp(62px,4.8vw,92px);line-height:1.02}
}
@media(min-width:861px) and (max-width:1099px){
  h1.hero-head{font-size:clamp(42px,5.2vw,62px);margin-bottom:16px}
}
@media(max-width:860px){
  h1.hero-head{font-size:clamp(34px,7.2vw,52px);line-height:1.04;margin-bottom:14px}
  .hn-cuet{padding:2px 14px 5px}
  .hn-prep{margin-left:8px}
}
.hn-your{
  display:block;
  font-weight:300;
  font-size:.72em;
  letter-spacing:.02em;
  color:var(--g500);
  margin-bottom:2px;
}
.hn-cuet-wrap{
  display:block;
  margin-bottom:2px;
}
.hn-cuet{
  display:inline-block;
  font-weight:800;
  font-size:1.18em;
  letter-spacing:-.05em;
  background:var(--ink);
  color:#fff;
  padding:2px 18px 6px;
  border-radius:6px;
  line-height:1.1;
}
.hn-prep{
  display:inline;
  font-weight:700;
  font-size:.95em;
  color:var(--g600);
  margin-left:10px;
}
.hn-companion{
  display:block;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:400;
  font-size:.88em;
  color:var(--g400);
  letter-spacing:-.01em;
  margin-top:4px;
}
@media(max-width:640px){
  h1.hero-head{color:var(--ink);text-shadow:none}
  .hero-badge{background:rgba(255,255,255,.86);border-color:var(--g200);color:var(--g600)}
  .hn-your{color:var(--g600);text-shadow:none}
  .hn-prep{color:var(--ink);text-shadow:none}
  .hn-companion{color:var(--g600);text-shadow:none}
  .hero-sub{color:var(--g600);text-shadow:none;font-size:14px}
  .hero-ctas{gap:8px}
  .hero-ctas .btn{font-size:14px;padding:12px 16px}
  .mini-title{color:var(--ink);text-shadow:none}
  .mini-desc{color:var(--g600);text-shadow:none}
  .hn-cuet{background:var(--ink);color:#fff;text-shadow:none}
  .tw-cursor{background:var(--ink)}
  .mini-icon{
    background:rgba(255,255,255,.86);
    border-color:var(--g200);
    color:var(--ink);
  }
}

/* Extracted inline styles */
.hero-mini-full{grid-column:1/-1}
.eval-link{padding:13px 26px;font-size:14px;border-radius:10px}
.proc-card-centered{text-align:center}
.expert-profile{display:flex;align-items:center;gap:7px}
.foot-logo-img{object-fit:contain}

/* Auth page */
.auth-page{min-height:100vh;background:var(--paper)}
.auth-main{
  min-height:calc(100svh - 118px);
  display:flex;
  align-items:center;
  padding:clamp(42px,6vw,82px) var(--pad-x);
  background:
    linear-gradient(90deg,#fff 0%,#fff 46%,rgba(249,249,249,.88) 46%,rgba(249,249,249,.88) 100%);
}
.auth-wrap{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,430px);
  gap:clamp(36px,6vw,86px);
  align-items:center;
}
.auth-copy{max-width:620px}
.auth-mark{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:7px 12px;
  border:1px solid var(--g150);
  border-radius:999px;
  background:#fff;
  color:var(--g600);
  font-size:11px;
  font-weight:700;
  letter-spacing:.11em;
  text-transform:uppercase;
  margin-bottom:24px;
}
.auth-mark img{width:28px;height:28px;object-fit:contain}
.auth-copy h1{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(42px,5.4vw,76px);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.04em;
  max-width:620px;
  margin-bottom:18px;
}
.auth-copy p{
  max-width:500px;
  color:var(--g500);
  font-size:clamp(14px,1.25vw,16px);
  line-height:1.72;
}
.auth-benefits{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  border:1px solid var(--g150);
  border-radius:18px;
  overflow:hidden;
  margin-top:34px;
  background:#fff;
}
.auth-benefit{
  padding:20px 18px;
  border-right:1px solid var(--g150);
}
.auth-benefit:last-child{border-right:none}
.auth-benefit-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  background:var(--g100);
  border:1px solid var(--g150);
  color:var(--g500);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:12px;
}
.auth-benefit strong{
  display:block;
  color:var(--ink);
  font-size:13.5px;
  margin-bottom:4px;
}
.auth-benefit span:last-child{
  display:block;
  color:var(--g400);
  font-size:11.5px;
  line-height:1.55;
}
.auth-panel{
  background:#fff;
  border:1px solid var(--g150);
  border-radius:22px;
  box-shadow:0 24px 80px rgba(0,0,0,.08);
  padding:10px;
}
.auth-tabs{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
  padding:5px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:16px;
  margin-bottom:10px;
}
.auth-tab{
  min-height:42px;
  border:0;
  border-radius:11px;
  background:transparent;
  color:var(--g500);
  font:700 12px 'Space Grotesk',sans-serif;
  letter-spacing:.11em;
  text-transform:uppercase;
  cursor:pointer;
}
.auth-tab.active{
  background:var(--ink);
  color:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.auth-form{
  display:none;
  padding:22px clamp(16px,2.6vw,26px) 24px;
}
.auth-form.active{display:block}
.auth-form-head{margin-bottom:22px}
.auth-form-head h2{
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(24px,2.5vw,32px);
  line-height:1.05;
  letter-spacing:-.025em;
  margin-bottom:8px;
}
.auth-form-head p{font-size:13px;color:var(--g500);line-height:1.55}
.auth-field{
  display:flex;
  flex-direction:column;
  gap:7px;
  margin-bottom:14px;
}
.auth-field span{
  font-size:11px;
  font-weight:700;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:var(--g500);
}
.auth-field input{
  width:100%;
  min-height:46px;
  border:1px solid var(--g200);
  border-radius:10px;
  background:#fff;
  color:var(--ink);
  font:14px 'Space Grotesk',sans-serif;
  padding:0 14px;
  outline:none;
  transition:border-color .15s,box-shadow .15s,background .15s;
}
.auth-field input:focus{
  border-color:var(--ink);
  box-shadow:0 0 0 4px rgba(8,8,8,.06);
  background:var(--g50);
}
.auth-field input::placeholder{color:var(--g300)}
.phone-affix{display:flex;align-items:stretch}
.phone-affix .phone-prefix{
  display:flex;align-items:center;
  min-height:46px;padding:0 12px;
  border:1px solid var(--g200);border-right:0;
  border-radius:10px 0 0 10px;
  background:var(--g50);color:var(--g500);
  font:600 14px 'Space Grotesk',sans-serif;
  letter-spacing:.02em;white-space:nowrap;
}
.phone-affix input{border-radius:0 10px 10px 0}
.auth-otp{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--g150)}
.auth-otp[hidden]{display:none}

/* ── Legal / policy pages ── */
.legal{max-width:820px;margin:0 auto}
.legal h1{font:700 clamp(26px,4vw,38px) 'Space Grotesk',sans-serif;letter-spacing:-.02em;margin-bottom:8px}
.legal .legal-updated{font-size:12.5px;color:var(--g400);margin-bottom:28px}
.legal h2{font:700 17px 'Space Grotesk',sans-serif;margin:28px 0 8px}
.legal p,.legal li{font-size:14.5px;line-height:1.7;color:var(--g600)}
.legal p{margin-bottom:12px}
.legal ul{margin:0 0 12px;padding-left:22px;display:flex;flex-direction:column;gap:6px}
.legal a{color:#3a5a23;text-decoration:underline}
.legal .legal-note{background:var(--g50);border:1px solid var(--g150);border-radius:12px;padding:14px 16px;margin:8px 0 16px}
.pay-agree{font-size:11.5px;color:var(--g400);text-align:center;margin-top:10px;line-height:1.5}
.pay-agree a{color:var(--g500)}
.auth-check{
  display:flex;
  align-items:flex-start;
  gap:9px;
  color:var(--g500);
  font-size:12px;
  line-height:1.55;
  margin:4px 0 18px;
}
.auth-check.compact{align-items:center;margin:0}
.auth-check input{
  width:16px;
  height:16px;
  accent-color:var(--ink);
  flex-shrink:0;
  margin-top:2px;
}
.auth-google-mount{
  display:flex;
  justify-content:center;
  min-height:44px;
  margin-top:4px;
}
.auth-submit,
.auth-google{
  width:100%;
  min-height:46px;
  border-radius:10px;
  font:700 13px 'Space Grotesk',sans-serif;
  cursor:pointer;
}
.auth-submit{
  border:1.5px solid var(--ink);
  background:var(--ink);
  color:#fff;
  transition:opacity .15s,transform .15s;
}
.auth-submit:hover{opacity:.86;transform:translateY(-1px)}
.auth-status{
  min-height:18px;
  margin-top:10px;
  color:var(--g600);
  font-size:12px;
  line-height:1.5;
}
.auth-google{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  border:1px solid var(--g200);
  background:#fff;
  color:var(--ink);
  transition:border-color .15s,background .15s;
}
.auth-google:hover{border-color:var(--ink);background:var(--g50)}
.auth-google span{
  width:22px;
  height:22px;
  border-radius:50%;
  border:1px solid var(--g200);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:12px;
}
.auth-divider{
  display:flex;
  align-items:center;
  gap:10px;
  margin:18px 0;
  color:var(--g400);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.auth-divider::before,
.auth-divider::after{
  content:'';
  height:1px;
  background:var(--g150);
  flex:1;
}
.auth-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:2px 0 18px;
}
.auth-row a{
  color:var(--ink);
  font-size:12px;
  font-weight:700;
  text-decoration:none;
}
.auth-row a:hover{text-decoration:underline}
.auth-switch{
  text-align:center;
  color:var(--g500);
  font-size:12.5px;
  margin-top:18px;
}
.auth-switch button{
  border:0;
  background:transparent;
  color:var(--ink);
  font:700 12.5px 'Space Grotesk',sans-serif;
  cursor:pointer;
  padding:0;
}
.auth-switch button:hover{text-decoration:underline}
.auth-tab:focus-visible,
.auth-submit:focus-visible,
.auth-google:focus-visible,
.auth-switch button:focus-visible,
.auth-row a:focus-visible,
.auth-field input:focus-visible{
  outline:2px solid var(--ink);
  outline-offset:3px;
}
@media(max-width:960px){
  .auth-main{
    align-items:flex-start;
    background:#fff;
  }
  .auth-wrap{grid-template-columns:1fr;max-width:720px}
  .auth-copy{text-align:left}
  .auth-panel{max-width:520px;width:100%;margin:0 auto}
}
@media(max-width:640px){
  .auth-main{min-height:auto;padding:clamp(20px,5vw,30px) clamp(14px,4vw,20px) clamp(24px,6vw,40px)}
  .auth-wrap{gap:26px}
  .auth-panel{order:-1;border-radius:18px;padding:8px}
  .auth-copy h1{font-size:clamp(36px,12vw,52px)}
  .auth-benefits{grid-template-columns:1fr;border-radius:14px}
  .auth-benefit{border-right:none;border-bottom:1px solid var(--g150)}
  .auth-benefit:last-child{border-bottom:none}
  .auth-form{padding:18px 12px 20px}
  .auth-row{align-items:flex-start;flex-direction:column;gap:10px}
}
@media(max-width:480px){
  /* 16px inputs stop iOS focus-zoom (the main "feels broken" symptom). */
  .auth-field input,.auth-field select{font-size:16px}
  .phone-affix input{min-width:0}
  .phone-affix .phone-prefix{padding:0 10px}
  .auth-panel{padding:6px}
  .auth-form{padding:14px 10px 16px}
  .auth-copy h1{font-size:clamp(30px,10vw,44px)}
  .auth-benefit{padding:14px 13px}
  .auth-tab{font-size:12px}
}

/* Student dashboard */
.dash-page{min-height:100vh;background:var(--g50);color:var(--ink)}
.dash-topbar{
  position:sticky;
  top:0;
  z-index:320;
  height:76px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:28px;
  padding:0 clamp(16px,3.5vw,46px);
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--g150);
}
.dash-brand{
  display:flex;
  align-items:center;
  gap:9px;
  color:var(--ink);
  text-decoration:none;
  font-size:15px;
  font-weight:700;
  letter-spacing:-.02em;
}
.dash-brand img{width:48px;height:48px;object-fit:contain}
.dash-brand strong{color:var(--g400)}
.dash-nav{
  display:flex;
  justify-content:center;
  gap:6px;
}
/* Mobile nav drawer hamburger + backdrop (shown only ≤900px; injected by dashboard.js) */
.dash-nav-toggle{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;flex-shrink:0;padding:0 11px;
  border:1px solid var(--g200);border-radius:10px;background:#fff;cursor:pointer;
}
.dash-nav-toggle span{height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s}
.dash-nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.dash-nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.dash-nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.dash-backdrop{display:none}
.dash-nav a,
.dash-side-link{
  text-decoration:none;
  color:var(--g500);
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.dash-nav a{
  padding:9px 13px;
  border-radius:8px;
}
.dash-nav a:hover,
.dash-nav a.active{background:var(--g50);color:var(--ink)}
.dash-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}
.dash-icon-btn,
.dash-profile{
  width:38px;
  height:38px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.dash-icon-btn{
  border:1px solid var(--g200);
  background:#fff;
  color:var(--g500);
  cursor:pointer;
}
.dash-profile{
  background:var(--ink);
  color:#fff;
  text-decoration:none;
  font-size:11px;
  font-weight:700;
}
.dash-shell{
  display:grid;
  grid-template-columns:250px minmax(0,1fr);
  gap:24px;
  padding:24px clamp(16px,3.5vw,46px) 46px;
}
.dash-side{
  position:sticky;
  top:100px;
  align-self:start;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  padding:16px;
}
.dash-student{
  display:flex;
  align-items:center;
  gap:11px;
  padding-bottom:16px;
  border-bottom:1px solid var(--g150);
  margin-bottom:14px;
}
.dash-avatar{
  width:42px;
  height:42px;
  border-radius:12px;
  background:var(--ink);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:700;
  flex-shrink:0;
}
.dash-student strong{display:block;font-size:13.5px;line-height:1.2}
.dash-student span{display:block;color:var(--g400);font-size:11.5px;margin-top:2px}
.dash-streak{
  display:flex;
  align-items:end;
  gap:8px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:14px;
  padding:14px;
  margin-bottom:12px;
}
.dash-streak-k{font-size:34px;font-weight:700;line-height:1;letter-spacing:-.04em}
.dash-streak-l{font-size:11px;color:var(--g500);line-height:1.25;text-transform:uppercase;font-weight:700;letter-spacing:.08em}
.dash-side-link{
  display:flex;
  align-items:center;
  gap:9px;
  padding:11px 10px;
  border-radius:10px;
}
.dash-side-link:hover,
.dash-side-link.active{background:var(--ink);color:#fff}
.dash-main{min-width:0}
.dash-hero{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:24px;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:22px;
  padding:clamp(24px,4vw,44px);
  margin-bottom:18px;
  overflow:hidden;
  position:relative;
}
.dash-hero::after{
  content:'';
  position:absolute;
  right:-90px;
  top:-130px;
  width:320px;
  height:320px;
  border:1px solid var(--g150);
  border-radius:50%;
  pointer-events:none;
}
.dash-kicker,
.dash-label{
  color:var(--g400);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.dash-hero h1{
  position:relative;
  z-index:1;
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(34px,4.5vw,62px);
  line-height:.98;
  letter-spacing:-.04em;
  margin:10px 0 12px;
  max-width:650px;
}
.dash-hero-copy{
  position:relative;
  z-index:1;
  max-width:560px;
  color:var(--g500);
  font-size:15px;
  line-height:1.65;
}
.dash-hero-actions{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  flex-shrink:0;
}
.dash-primary,
.dash-secondary,
.dash-mock-card a{
  min-height:42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  padding:0 18px;
  font-size:13px;
  font-weight:700;
  text-decoration:none;
}
.dash-primary,
.dash-mock-card a{background:var(--ink);color:#fff;border:1.5px solid var(--ink)}
.dash-secondary{background:#fff;color:var(--ink);border:1.5px solid var(--g200)}
.dash-primary:hover,
.dash-mock-card a:hover{opacity:.86}
.dash-secondary:hover{border-color:var(--ink)}
.dash-metrics{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:1px solid var(--g150);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
  margin-bottom:18px;
}
.dash-metric{
  padding:20px;
  border-right:1px solid var(--g150);
}
.dash-metric:last-child{border-right:none}
.dash-metric span,
.dash-metric em{
  display:block;
  color:var(--g400);
  font-style:normal;
  font-size:11.5px;
}
.dash-metric span{font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.dash-metric strong{
  display:block;
  font-size:clamp(28px,3.4vw,44px);
  line-height:1;
  letter-spacing:-.04em;
  margin:12px 0 6px;
}
.dash-grid{
  display:grid;
  grid-template-columns:minmax(0,1.18fr) minmax(310px,.82fr);
  gap:18px;
}
.dash-panel{
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  padding:22px;
}
.dash-panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:20px;
}
.dash-panel h2{
  font-size:clamp(19px,2vw,26px);
  line-height:1.08;
  letter-spacing:-.025em;
  margin-top:5px;
}
.dash-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:var(--g50);
  border:1px solid var(--g150);
  color:var(--g500);
  font-size:11px;
  font-weight:700;
  white-space:nowrap;
}
.dash-progress-row{
  display:grid;
  grid-template-columns:130px minmax(0,1fr);
  gap:18px;
  align-items:center;
  margin-bottom:18px;
}
.dash-progress-row strong{display:block;font-size:34px;line-height:1;letter-spacing:-.04em}
.dash-progress-row span{color:var(--g400);font-size:11.5px}
.dash-progress{
  height:12px;
  background:var(--g100);
  border-radius:999px;
  overflow:hidden;
}
.dash-progress span{
  display:block;
  width:62%;
  height:100%;
  background:var(--ink);
  border-radius:inherit;
}
.dash-mock-tabs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:6px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:13px;
  padding:5px;
  margin-bottom:14px;
}
.dash-mock-tabs button{
  min-height:36px;
  border:0;
  border-radius:9px;
  background:transparent;
  color:var(--g500);
  font:700 11px 'Space Grotesk',sans-serif;
  letter-spacing:.09em;
  text-transform:uppercase;
  cursor:pointer;
}
.dash-mock-tabs button.active{background:var(--ink);color:#fff}
.dash-mock-card{
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:14px;
  padding:18px;
}
.dash-mock-card strong{display:block;font-size:16px;margin-bottom:6px}
.dash-mock-card p{color:var(--g500);font-size:13px;line-height:1.6;margin-bottom:14px}
.dash-tasks{display:flex;flex-direction:column;gap:9px}
.dash-task{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:46px;
  padding:10px 12px;
  border:1px solid var(--g150);
  border-radius:12px;
  color:var(--g600);
  font-size:13px;
  cursor:pointer;
}
.dash-task input{width:16px;height:16px;accent-color:var(--ink);flex-shrink:0}
.dash-task.done{background:var(--g50);color:var(--g400)}
.dash-task.done span{text-decoration:line-through}
.dash-text-link{
  color:var(--ink);
  font-size:12px;
  font-weight:700;
  text-decoration:none;
}
.dash-text-link:hover{text-decoration:underline}
.dash-bars{display:flex;flex-direction:column;gap:14px}
.dash-bar{
  display:grid;
  grid-template-columns:80px minmax(0,1fr) 42px;
  gap:12px;
  align-items:center;
}
.dash-bar span,
.dash-bar strong{font-size:12px}
.dash-bar span{color:var(--g500)}
.dash-bar strong{text-align:right}
.dash-bar div{
  height:9px;
  background:var(--g100);
  border-radius:999px;
  overflow:hidden;
}
.dash-bar i{
  display:block;
  height:100%;
  background:var(--ink);
  border-radius:inherit;
}
.bar-english{width:91%}
.bar-reasoning{width:76%}
.bar-quant{width:68%}
.bar-domain{width:82%}
.dash-feedback blockquote{
  margin:0 0 18px;
  color:var(--g600);
  font-size:15px;
  line-height:1.72;
  border-left:3px solid var(--ink);
  padding-left:14px;
}
.dash-reviewer{
  display:flex;
  align-items:center;
  gap:10px;
}
.dash-reviewer strong{display:block;font-size:12.5px}
.dash-reviewer span{display:block;font-size:11px;color:var(--g400);margin-top:2px}
.dash-icon-btn:focus-visible,
.dash-profile:focus-visible,
.dash-nav a:focus-visible,
.dash-side-link:focus-visible,
.dash-primary:focus-visible,
.dash-secondary:focus-visible,
.dash-mock-card a:focus-visible,
.dash-mock-tabs button:focus-visible,
.dash-task:focus-within{
  outline:2px solid var(--ink);
  outline-offset:3px;
}
@media(max-width:1080px){
  .dash-shell{grid-template-columns:1fr}
  .dash-side{
    position:static;
    display:grid;
    grid-template-columns:1fr 180px;
    gap:10px;
  }
  .dash-side-link{display:none}
  .dash-student,
  .dash-streak{margin:0}
  .dash-student{border-bottom:none;padding-bottom:0}
}
@media(max-width:900px){
  .dash-topbar{display:flex;align-items:center;gap:12px}
  .dash-actions{margin-left:auto}
  .dash-nav{display:none}
  .dash-nav-toggle{display:flex}
  .dash-hero{align-items:flex-start;flex-direction:column}
  .dash-metrics{grid-template-columns:repeat(2,1fr)}
  .dash-metric:nth-child(2n){border-right:none}
  .dash-metric:nth-child(n+3){border-top:1px solid var(--g150)}
  .dash-grid{grid-template-columns:1fr}
  /* Sidebar becomes an off-canvas drawer (nav links re-shown inside it). */
  .dash-side{
    position:fixed;inset:0 auto 0 0;z-index:80;
    width:min(82vw,300px);height:100dvh;
    display:flex;flex-direction:column;gap:6px;align-items:stretch;
    overflow-y:auto;padding:18px 14px;border-radius:0;
    transform:translateX(-100%);transition:transform .25s ease;
    box-shadow:0 18px 50px rgba(0,0,0,.18);background:#fff;
  }
  .dash-side.open{transform:none}
  .dash-side-link{display:flex}
  .dash-side-logout{margin-top:auto}
  .dash-backdrop{
    display:block;position:fixed;inset:0;z-index:70;background:rgba(8,8,8,.42);
    opacity:0;visibility:hidden;transition:opacity .25s;
  }
  .dash-backdrop.show{opacity:1;visibility:visible}
  body.dash-nav-open{overflow:hidden}
}
@media(max-width:640px){
  .dash-topbar{height:68px;padding:0 14px}
  .dash-brand img{width:42px;height:42px}
  .dash-brand span{display:none}
  .dash-shell{padding:16px 12px 34px}
  .dash-side{grid-template-columns:1fr;padding:14px}
  .dash-streak{align-items:center}
  .dash-hero,
  .dash-panel{border-radius:16px;padding:18px}
  .dash-hero-actions,
  .dash-primary,
  .dash-secondary{width:100%}
  .dash-primary,
  .dash-secondary{padding:0 14px}
  .dash-metrics{grid-template-columns:1fr}
  .dash-metric{border-right:none;border-top:1px solid var(--g150)}
  .dash-metric:first-child{border-top:none}
  .dash-progress-row{grid-template-columns:1fr;gap:10px}
  .dash-mock-tabs{grid-template-columns:1fr}
  .dash-bar{grid-template-columns:74px minmax(0,1fr) 38px}
}

/* Admin demo backend */
.auth-demo{
  margin-top:10px;
  color:var(--g500);
  font-size:12px;
  line-height:1.45;
}
.admin-public-notice{
  background:var(--ink);
  color:#fff;
  text-align:center;
  padding:9px 14px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.04em;
}
.admin-page{
  min-height:100vh;
  background:var(--g50);
  color:var(--ink);
}
.admin-login{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:32px var(--pad-x);
}
.admin-login-card{
  width:min(100%,980px);
  display:grid;
  grid-template-columns:minmax(0,1fr) 390px;
  gap:28px;
  align-items:center;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:22px;
  padding:clamp(22px,4vw,42px);
}
.admin-login-brand{
  position:absolute;
  top:24px;
  left:24px;
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:var(--ink);
  text-decoration:none;
  font-weight:700;
}
.admin-login-brand img{width:42px;height:42px;object-fit:contain}
.admin-login-card{position:relative}
.admin-login-copy{padding-top:52px}
.admin-kicker{
  display:block;
  color:var(--g400);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.admin-login-copy h1,
.admin-hero h1{
  font-size:clamp(34px,4.6vw,64px);
  line-height:1;
  letter-spacing:-.045em;
  margin:12px 0;
}
.admin-login-copy p,
.admin-hero p{
  max-width:560px;
  color:var(--g500);
  font-size:15px;
  line-height:1.65;
}
.admin-login-form{
  border:1px solid var(--g150);
  border-radius:18px;
  padding:20px;
  background:var(--g50);
}
.admin-shell[hidden],
.admin-login[hidden]{display:none}
.admin-topbar{
  position:sticky;
  top:0;
  z-index:340;
  height:76px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
  padding:0 clamp(16px,3.5vw,46px);
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--g150);
}
.admin-nav{
  display:flex;
  justify-content:center;
  gap:6px;
}
.admin-nav a{
  padding:9px 13px;
  border-radius:8px;
  color:var(--g500);
  text-decoration:none;
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.admin-nav a:hover{background:var(--g50);color:var(--ink)}
.admin-logout,
.admin-soft-btn{
  min-height:36px;
  border:1px solid var(--g200);
  border-radius:9px;
  background:#fff;
  color:var(--ink);
  padding:0 13px;
  font:700 12px 'Space Grotesk',sans-serif;
  cursor:pointer;
}
.admin-main{
  padding:24px clamp(16px,3.5vw,46px) 46px;
}
.admin-hero{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:22px;
  padding:clamp(24px,4vw,44px);
  margin-bottom:18px;
}
.admin-hero-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  flex-shrink:0;
}
.admin-kpis{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  overflow:hidden;
  margin-bottom:18px;
}
.admin-kpi{
  padding:20px;
  border-right:1px solid var(--g150);
}
.admin-kpi:last-child{border-right:none}
.admin-kpi span{
  display:block;
  color:var(--g400);
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.admin-kpi strong{
  display:block;
  font-size:clamp(32px,4vw,52px);
  line-height:1;
  letter-spacing:-.045em;
  margin-top:12px;
}
.admin-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(330px,.8fr);
  gap:18px;
  margin-bottom:18px;
}
.admin-panel{
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  padding:22px;
}
.admin-panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:20px;
}
.admin-panel h2{
  font-size:clamp(20px,2vw,28px);
  line-height:1.08;
  letter-spacing:-.03em;
  margin-top:5px;
}
.admin-control-form textarea{
  width:100%;
  resize:vertical;
  padding:12px 13px;
  border:1px solid var(--g200);
  border-radius:10px;
  background:#fff;
  color:var(--ink);
  font:14px 'Space Grotesk',sans-serif;
  outline:none;
}
.admin-control-form textarea:focus{
  border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(0,0,0,.05);
}
.admin-form-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.admin-toggle{
  display:flex;
  align-items:center;
  gap:10px;
  margin:12px 0;
  color:var(--g600);
  font-size:13px;
  font-weight:600;
}
.admin-toggle input{
  width:17px;
  height:17px;
  accent-color:var(--ink);
}
.admin-feed{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.admin-feed-item{
  border:1px solid var(--g150);
  border-radius:12px;
  padding:12px;
  background:var(--g50);
}
.admin-feed-item span,
.admin-feed-item time{
  display:block;
  color:var(--g400);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.admin-feed-item strong{
  display:block;
  color:var(--ink);
  font-size:13px;
  line-height:1.35;
  margin:5px 0;
}
.admin-table-wrap{
  width:100%;
  overflow:auto;
}
.admin-table{
  width:100%;
  border-collapse:collapse;
  min-width:760px;
}
.admin-table th,
.admin-table td{
  padding:13px 12px;
  border-bottom:1px solid var(--g150);
  text-align:left;
  font-size:12.5px;
}
.admin-table th{
  color:var(--g400);
  font-size:10.5px;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.admin-table td{color:var(--g600)}
.admin-table tr:last-child td{border-bottom:none}

/* Row action controls (mentors / mocks / users tables) */
.mock-table-actions{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.mock-table-actions a,
.mock-table-actions button{
  font:600 11.5px 'Space Grotesk',sans-serif;
  padding:6px 11px;border-radius:8px;border:1px solid var(--g200);
  background:#fff;color:var(--g600);text-decoration:none;cursor:pointer;
  line-height:1;white-space:nowrap;
  transition:border-color .14s,background .14s,color .14s;
}
.mock-table-actions a:hover,
.mock-table-actions button:hover{border-color:var(--ink);color:var(--ink)}
.danger{
  font:600 11.5px 'Space Grotesk',sans-serif;
  padding:6px 11px;border-radius:8px;border:1px solid #e7c4c4;
  background:#fff;color:#b23b3b;text-decoration:none;cursor:pointer;
  line-height:1;white-space:nowrap;
  transition:border-color .14s,background .14s,color .14s;
}
.danger:hover{background:#fdecec;border-color:#b23b3b;color:#9a2f2f}
.danger:disabled{opacity:.5;cursor:default}

/* Filter pill bars (admin mock centre + mentor leaderboard) */
.mock-centre-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px}
.mock-centre-filters button{
  font:600 12px 'Space Grotesk',sans-serif;
  padding:7px 14px;border-radius:999px;border:1px solid var(--g200);
  background:#fff;color:var(--g600);cursor:pointer;line-height:1;
  transition:border-color .14s,background .14s,color .14s;
}
.mock-centre-filters button:hover{border-color:var(--ink);color:var(--ink)}
.mock-centre-filters button.active{background:var(--ink);border-color:var(--ink);color:#fff}
.admin-logout:focus-visible,
.admin-soft-btn:focus-visible,
.admin-nav a:focus-visible,
.admin-control-form textarea:focus-visible{
  outline:2px solid var(--ink);
  outline-offset:3px;
}
@media(max-width:980px){
  .admin-login-card,
  .admin-grid{grid-template-columns:1fr}
  .admin-kpis{grid-template-columns:repeat(2,1fr)}
  .admin-kpi:nth-child(2n){border-right:none}
  .admin-kpi:nth-child(n+3){border-top:1px solid var(--g150)}
  .admin-hero{align-items:flex-start;flex-direction:column}
  .admin-topbar{grid-template-columns:auto auto;justify-content:space-between}
  .admin-nav{display:none}
}
@media(max-width:640px){
  .admin-login{padding:18px 12px}
  .admin-login-card{border-radius:18px;padding:18px}
  .admin-login-copy{padding-top:58px}
  .admin-login-form{padding:14px}
  .admin-topbar{height:68px;padding:0 14px}
  .admin-main{padding:16px 12px 34px}
  .admin-hero,
  .admin-panel{border-radius:16px;padding:18px}
  .admin-hero-actions,
  .admin-hero-actions .dash-primary,
  .admin-hero-actions .dash-secondary,
  .admin-logout{width:100%}
  .admin-topbar{grid-template-columns:1fr auto}
  .admin-kpis{grid-template-columns:1fr}
  .admin-kpi{border-right:none;border-top:1px solid var(--g150)}
  .admin-kpi:first-child{border-top:none}
  .admin-form-grid{grid-template-columns:1fr 1fr}
  .admin-panel-head{align-items:flex-start;flex-direction:column}
}
@media(max-width:380px){
  .admin-form-grid{grid-template-columns:1fr}
}

/* 1 on 1 booking */
.booking-page{background:var(--paper);color:var(--ink)}
.booking-hero{
  position:relative;
  min-height:clamp(560px,72svh,820px);
  display:flex;
  align-items:center;
  padding:clamp(42px,7vw,96px) var(--pad-x);
  background:url('uploads/1-1-booking.png') center center / cover no-repeat;
  border-bottom:1px solid var(--g150);
  overflow:hidden;
}
.booking-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    to right,
    #ffffff 0%,
    #ffffff 39%,
    rgba(255,255,255,.76) 60%,
    rgba(255,255,255,0) 100%
  );
  pointer-events:none;
}
.booking-hero-copy{
  position:relative;
  z-index:1;
  width:min(100%,680px);
}
.booking-kicker{
  display:block;
  color:var(--g400);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.booking-hero h1{
  max-width:760px;
  font-size:clamp(40px,6vw,88px);
  line-height:.98;
  letter-spacing:-.05em;
  margin:14px 0 18px;
}
.booking-hero p{
  max-width:620px;
  color:var(--g500);
  font-size:clamp(15px,1.4vw,18px);
  line-height:1.65;
}
.booking-hero-actions{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:24px;
}
.booking-hero-actions span{
  color:var(--g500);
  font-size:13px;
  font-weight:700;
}
.booking-provides,
.booking-streams{
  padding:clamp(56px,7vw,92px) var(--pad-x);
}
.booking-provides{background:var(--g50)}
.booking-provide-grid{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  border:1px solid var(--g150);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.booking-provide-grid article{
  padding:24px;
  border-right:1px solid var(--g150);
}
.booking-provide-grid article:last-child{border-right:none}
.booking-provide-grid span{
  color:var(--g300);
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
}
.booking-provide-grid h3{
  font-size:17px;
  margin:12px 0 8px;
  letter-spacing:-.02em;
}
.booking-provide-grid p{
  color:var(--g500);
  font-size:13px;
  line-height:1.65;
}
.stream-tabs{
  max-width:720px;
  margin:0 auto 26px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding:6px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:15px;
}
.stream-tabs button{
  min-height:48px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:var(--g500);
  font:800 12px 'Space Grotesk',sans-serif;
  letter-spacing:.1em;
  text-transform:uppercase;
  cursor:pointer;
}
.stream-tabs button.active{background:var(--ink);color:#fff}
.stream-output{
  max-width:1180px;
  margin:0 auto;
  display:grid;
  gap:18px;
}
.booking-counsellors,
.stream-guide-card{
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  padding:clamp(18px,3vw,28px);
}
.booking-section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  margin-bottom:18px;
}
.booking-section-head h2,
.stream-guide-card h2{
  font-size:clamp(24px,3vw,38px);
  line-height:1.05;
  letter-spacing:-.035em;
}
.counsellor-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.counsellor-card{
  display:flex;
  flex-direction:column;
  gap:16px;
  min-height:100%;
  padding:18px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:14px;
}
.counsellor-avatar{
  width:46px;
  height:46px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--ink);
  color:#fff;
  font-size:13px;
  font-weight:800;
}
.counsellor-card h3{
  font-size:18px;
  letter-spacing:-.02em;
  margin-bottom:8px;
}
.counsellor-card p,
.counsellor-card span{
  display:block;
  color:var(--g500);
  font-size:13px;
  line-height:1.55;
}
.counsellor-card span{margin-top:8px;color:var(--g600)}
.counsellor-card-foot{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:auto;
}
.counsellor-card-foot small{color:var(--g400);font-size:11px;font-weight:700}
.counsellor-card-foot button,
.slot-chip{
  min-height:42px;
  border:1.5px solid var(--ink);
  border-radius:10px;
  background:var(--ink);
  color:#fff;
  padding:0 15px;
  font:800 12px 'Space Grotesk',sans-serif;
  cursor:pointer;
}
.guide-columns{
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  gap:14px;
  margin-top:22px;
}
.guide-columns article{
  padding:16px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:12px;
}
.guide-columns h3{
  font-size:14px;
  margin-bottom:10px;
}
.guide-columns p,
.guide-columns li,
.guide-note{
  color:var(--g500);
  font-size:13px;
  line-height:1.65;
}
.guide-columns ul{padding-left:18px}
.guide-columns a{
  display:inline-flex;
  margin-top:10px;
  color:var(--ink);
  font-size:12px;
  font-weight:800;
}
.guide-note{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid var(--g150);
}
.booking-modal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(0,0,0,.42);
}
.booking-modal[hidden]{display:none}
.booking-modal-card{
  width:min(100%,620px);
  max-height:calc(100svh - 36px);
  overflow:auto;
  position:relative;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:20px;
  padding:24px;
  box-shadow:0 24px 80px rgba(0,0,0,.2);
}
.booking-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border:1px solid var(--g200);
  border-radius:9px;
  background:#fff;
  color:var(--ink);
  cursor:pointer;
}
.booking-modal-head{padding-right:42px;margin-bottom:18px}
.booking-modal-head h2{
  font-size:clamp(24px,4vw,34px);
  line-height:1.05;
  letter-spacing:-.035em;
  margin:6px 0 8px;
}
.booking-modal-head p{
  color:var(--g500);
  font-size:13px;
  line-height:1.55;
}
.booking-step{display:none}
.booking-step.active{display:block}
.slot-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:12px;
}
.slot-chip{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#fff;
  color:var(--ink);
  border-color:var(--g200);
  text-align:left;
  padding:12px;
}
.slot-chip.selected{background:var(--ink);color:#fff;border-color:var(--ink)}
.slot-chip span{color:inherit;font-size:12px}
.booking-status{
  min-height:20px;
  color:var(--g500);
  font-size:12.5px;
  line-height:1.45;
  margin:8px 0 12px;
}
.demo-otp-box,
.payment-card,
.thanks-card{
  padding:18px;
  border:1px solid var(--g150);
  border-radius:14px;
  background:var(--g50);
  margin-bottom:16px;
}
.demo-otp-box span,
.payment-card span,
.thanks-card span{
  display:block;
  color:var(--g400);
  font-size:10.5px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}
.demo-otp-box strong,
.payment-card strong,
.thanks-card strong{
  display:block;
  font-size:clamp(28px,5vw,44px);
  line-height:1;
  letter-spacing:-.04em;
  margin-top:8px;
}
.payment-card p,
.thanks-card p{
  color:var(--g500);
  font-size:13px;
  line-height:1.6;
  margin-top:10px;
}
.booking-done-link{
  text-align:center;
  width:100%;
  border:0;
}
.modal-open{overflow:hidden}
.auth-field select{
  width:100%;
  padding:12px 13px;
  border:1px solid var(--g200);
  border-radius:10px;
  background:#fff;
  font:14px 'Space Grotesk',sans-serif;
  color:var(--ink);
  outline:none;
}
.auth-field select:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.05)}
.admin-form-grid-3{grid-template-columns:1.2fr 1fr 1fr}
.admin-form-grid-2{grid-template-columns:1fr 1fr}
.admin-slot-list{display:flex;flex-direction:column;gap:10px}
.admin-slot-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px;
  background:var(--g50);
  border:1px solid var(--g150);
  border-radius:12px;
}
.admin-slot-item strong{display:block;font-size:13px}
.admin-slot-item span{display:block;color:var(--g500);font-size:12px;margin-top:2px}
.admin-slot-item button{
  min-height:34px;
  border:1px solid var(--g200);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  padding:0 11px;
  font:800 11px 'Space Grotesk',sans-serif;
  cursor:pointer;
}
.empty-state{
  color:var(--g500);
  font-size:13px;
  line-height:1.55;
}
@media(min-width:981px){
  .admin-kpi:nth-child(4n){border-right:none}
  .admin-kpi:nth-child(n+5){border-top:1px solid var(--g150)}
}
@media(max-width:980px){
  .booking-hero{
    min-height:clamp(540px,68svh,720px);
    background-position:58% center;
  }
  .booking-hero::before{
    background:linear-gradient(to right,#ffffff 0%,#ffffff 55%,rgba(255,255,255,.72) 78%,rgba(255,255,255,.18) 100%);
  }
  .booking-provide-grid{grid-template-columns:repeat(2,1fr)}
  .booking-provide-grid article:nth-child(2n){border-right:none}
  .booking-provide-grid article:nth-child(n+3){border-top:1px solid var(--g150)}
  .counsellor-grid,
  .guide-columns{grid-template-columns:1fr}
}
@media(max-width:640px){
  .booking-hero{
    min-height:clamp(520px,74svh,680px);
    align-items:flex-start;
    padding:36px 14px;
    background-position:64% center;
  }
  .booking-hero::before{
    background:linear-gradient(
      to bottom,
      rgba(255,255,255,.98) 0%,
      rgba(255,255,255,.94) 46%,
      rgba(255,255,255,.74) 78%,
      rgba(255,255,255,.42) 100%
    );
  }
  .booking-provides,
  .booking-streams{padding:36px 14px}
  .booking-hero h1{font-size:clamp(38px,13vw,58px)}
  .booking-hero-actions,
  .booking-hero-actions .btn{width:100%}
  .booking-hero-actions .btn{justify-content:center}
  .booking-provide-grid,
  .stream-tabs{grid-template-columns:1fr}
  .booking-provide-grid article{border-right:none;border-top:1px solid var(--g150)}
  .booking-provide-grid article:first-child{border-top:none}
  .booking-section-head{align-items:flex-start;flex-direction:column}
  .counsellor-card-foot{align-items:stretch;flex-direction:column}
  .counsellor-card-foot button{width:100%}
  .booking-modal{
    align-items:flex-end;
    padding:0;
  }
  .booking-modal-card{
    width:100%;
    max-height:94svh;
    border-radius:20px 20px 0 0;
    padding:20px 16px 22px;
  }
  .slot-list,
  .admin-form-grid-2,
  .admin-form-grid-3{grid-template-columns:1fr}
  .admin-slot-item{align-items:flex-start;flex-direction:column}
  .admin-slot-item button{width:100%}
}

/* ── DASHBOARD V2 ADDITIONS ── */
.dash-view{display:none;flex-direction:column;gap:22px}
.dash-view.active{display:flex}
.dash-logout-btn{color:var(--g600)}
.dash-logout-btn:hover{color:var(--ink);border-color:var(--ink)}
.dash-side-logout{
  margin-top:auto;
  background:transparent;
  border:1px solid var(--g200);
  text-align:left;
  font-family:inherit;
  cursor:pointer;
}
.dash-side-logout:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.dash-side{display:flex;flex-direction:column;gap:10px;align-self:stretch}

.dash-hero-hint{
  display:inline-flex;align-items:center;
  font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--g500);
}

/* Profile form */
.dash-profile-form{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.dash-profile-form .auth-field{margin:0}
.dash-profile-form .auth-field input,
.dash-profile-form .auth-field select{
  width:100%;
  height:42px;
  padding:0 14px;
  border:1px solid var(--g200);
  border-radius:10px;
  background:#fff;
  font:inherit;
  color:var(--ink);
  transition:border-color .14s, box-shadow .14s;
}
.dash-profile-form .auth-field input:focus,
.dash-profile-form .auth-field select:focus{
  outline:none;
  border-color:var(--ink);
  box-shadow:0 0 0 3px rgba(0,0,0,.06);
}
.dash-profile-form .auth-field span{
  display:block;
  font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--g500);
  margin-bottom:6px;
}
.dash-form-actions{
  grid-column:1/-1;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-top:4px;
}
.dash-form-actions .dash-primary{height:42px;padding:0 22px}
.dash-form-actions .auth-status{margin:0;color:var(--g500);font-size:12.5px}

/* Plan list (key/value rows) */
.dash-plan-list{
  list-style:none;
  display:flex;flex-direction:column;
  border-top:1px solid var(--g150);
}
.dash-plan-list li{
  display:flex;justify-content:space-between;align-items:center;
  gap:14px;
  padding:13px 2px;
  border-bottom:1px solid var(--g150);
}
.dash-plan-list span{color:var(--g500);font-size:12.5px}
.dash-plan-list strong{font-size:13.5px;text-align:right}

/* Recent attempts / generic list */
.dash-list{
  list-style:none;
  display:flex;flex-direction:column;
}
.dash-list li{
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:center;
  gap:14px;
  padding:13px 4px;
  border-bottom:1px solid var(--g150);
  font-size:13.5px;
}
.dash-list li:last-child{border-bottom:none}
.dash-list em{color:var(--g500);font-style:normal;font-size:12px}
.dash-list strong{font-size:14px;letter-spacing:-.01em}

/* Pills */
.dash-pill-soft{background:var(--g100);color:var(--g600)}
.dash-pill-warn{background:#fff4d6;color:#7a5b00}

/* Evaluations list */
.dash-eval-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;
}
.dash-eval{
  border:1px solid var(--g150);
  border-radius:14px;
  padding:16px;
  background:#fff;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .14s, transform .14s;
}
.dash-eval:hover{border-color:var(--ink);transform:translateY(-1px)}
.dash-eval header{display:flex;justify-content:space-between;align-items:center;gap:10px}
.dash-eval header strong{font-size:14px}
.dash-eval p{color:var(--g600);font-size:13px;line-height:1.55;margin:0}
.dash-eval footer{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11.5px;color:var(--g500);
  padding-top:8px;border-top:1px solid var(--g150);
}
.dash-eval footer em{font-style:normal}

/* Booking stream cards */
.dash-stream-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.dash-stream-card{
  display:flex;flex-direction:column;gap:4px;
  padding:14px;
  border:1px solid var(--g200);
  border-radius:12px;
  background:#fff;
  text-decoration:none;color:var(--ink);
  transition:border-color .14s, background .14s, transform .14s;
}
.dash-stream-card:hover{border-color:var(--ink);background:var(--g50);transform:translateY(-1px)}
.dash-stream-card strong{font-size:14px}
.dash-stream-card span{font-size:11.5px;color:var(--g500)}

/* Booking cards on dashboard */
.dash-bookings{display:flex;flex-direction:column;gap:12px}
.dash-empty{color:var(--g500);font-size:13px;padding:8px 0}
.dash-booking{
  border:1px solid var(--g150);
  border-radius:14px;
  padding:14px 16px;
  background:#fff;
  display:flex;flex-direction:column;gap:8px;
}
.dash-booking header{display:flex;justify-content:space-between;align-items:center;gap:10px}
.dash-booking header strong{font-size:14px}
.dash-booking p{margin:0;color:var(--g600);font-size:12.5px}
.dash-booking footer{
  display:flex;justify-content:space-between;align-items:center;
  font-size:11.5px;color:var(--g500);
  padding-top:8px;border-top:1px solid var(--g150);
}
.dash-booking footer em{font-style:normal;letter-spacing:.02em}

/* Responsive tweaks */
@media(max-width:900px){
  .dash-profile-form{grid-template-columns:1fr}
  .dash-stream-grid{grid-template-columns:1fr}
  .dash-side-logout{margin-top:14px}
}
@media(max-width:640px){
  .dash-eval-list{grid-template-columns:1fr}
  .dash-list li{grid-template-columns:1fr auto;row-gap:2px}
  .dash-list em{grid-column:1;color:var(--g400);font-size:11.5px}
  .dash-list strong{grid-row:1/span 2;align-self:center}
}

/* ── Booking "Panda Mentor" typewriter ── */
.dash-mentor-h1{
  font-size:clamp(28px,4vw,40px);
  line-height:1.1;
  letter-spacing:-.025em;
  font-weight:700;
}
.dash-mentor-wrap{display:inline-block;white-space:nowrap}
.dash-mentor-tw{
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-weight:700;
  letter-spacing:-.01em;
  transition:opacity 1.2s ease;
  display:inline-block;
  min-width:1ch;
  background:linear-gradient(90deg, #080808 0%, #3a3a3a 50%, #080808 100%);
  -webkit-background-clip:text;
          background-clip:text;
  -webkit-text-fill-color:transparent;
          color:transparent;
  text-decoration:underline;
  text-decoration-color:#6b9a5b;
  text-decoration-thickness:2px;
  text-underline-offset:6px;
}
.dash-mentor-tw::after{
  content:'';
  display:inline-block;
  width:2px;height:.9em;
  margin-left:3px;
  vertical-align:-2px;
  background:#080808;
  animation:dash-mentor-blink 1s steps(1) infinite;
}
@keyframes dash-mentor-blink{50%{opacity:0}}

/* ── Mocks page redesign ── */
.mock-free-banner{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 18px;
  border:1px solid var(--g200);
  border-radius:14px;
  background:#fff;
}
.mock-free-banner strong{display:block;font-size:14px}
.mock-free-banner span{display:block;color:var(--g500);font-size:12.5px;margin-top:2px}

.mock-step{display:flex;flex-direction:column;gap:14px}
.mock-back{
  background:transparent;
  border:1px solid var(--g200);
  border-radius:999px;
  padding:6px 12px;
  font:inherit;
  font-size:12px;
  color:var(--g600);
  cursor:pointer;
  transition:border-color .14s, color .14s, background .14s;
}
.mock-back:hover{border-color:var(--ink);color:var(--ink);background:var(--g50)}
.mock-step-note{color:var(--g500);font-size:13px;margin-top:-4px}
.mock-step-foot{color:var(--g500);font-size:12.5px;margin-top:6px}

/* Step 1: type cards */
.mock-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.mock-choice{
  text-align:left;
  background:#fff;
  border:1px solid var(--g200);
  border-radius:16px;
  padding:20px;
  cursor:pointer;
  font:inherit;
  color:var(--ink);
  display:flex;flex-direction:column;gap:8px;
  transition:border-color .14s, transform .14s, background .14s;
}
.mock-choice:hover{border-color:var(--ink);transform:translateY(-2px);background:var(--g50)}
.mock-choice strong{font-size:18px;letter-spacing:-.01em}
.mock-choice p{color:var(--g600);font-size:13px;line-height:1.55;margin:0}
.mock-choice em{font-style:normal;color:var(--g500);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;margin-top:auto}
.mock-choice-kicker{
  display:inline-flex;align-self:flex-start;
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--g500);
  padding:4px 10px;
  border:1px solid var(--g200);
  border-radius:999px;
  background:#fff;
}

/* Step 2: subjects grid */
.mock-subject-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.mock-subject{
  text-align:left;
  background:#fff;
  border:1px solid var(--g200);
  border-radius:14px;
  padding:14px 16px;
  cursor:pointer;
  font:inherit;
  color:var(--ink);
  display:flex;flex-direction:column;gap:4px;
  transition:border-color .14s, transform .14s, background .14s;
}
.mock-subject:hover{border-color:var(--ink);transform:translateY(-1px);background:var(--g50)}
.mock-subject strong{font-size:14px}
.mock-subject span{color:var(--g500);font-size:11.5px}

/* Step 3: mock list */
.mock-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:12px;
}
.mock-card{
  border:1px solid var(--g200);
  border-radius:14px;
  background:#fff;
  padding:16px;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color .14s, transform .14s;
}
.mock-card:hover{border-color:var(--ink);transform:translateY(-1px)}
.mock-card.is-locked{background:var(--g50)}
.mock-card header{display:flex;justify-content:space-between;align-items:center;gap:10px}
.mock-card header strong{font-size:14px;line-height:1.3}
.mock-card p{margin:0;color:var(--g500);font-size:12.5px}
.mock-card footer{
  display:flex;flex-direction:column;gap:8px;
  padding-top:8px;border-top:1px solid var(--g150);
  margin-top:auto;
}
.mock-card .mock-go{
  height:38px;padding:0 14px;border-radius:10px;
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;border:1.5px solid var(--ink);
}
.mock-card .mock-go.dash-primary{background:var(--ink);color:#fff}
.mock-card .mock-go.dash-secondary{background:#fff;color:var(--ink);border-color:var(--g200)}
.mock-card .mock-go.dash-secondary:hover{border-color:var(--ink)}
.mock-pill-free{background:var(--ink);color:#fff}
.mock-card-meta{font-size:11.5px;color:var(--g500);min-height:14px}
.mock-card-meta.is-info{color:var(--ink)}
.mock-card-meta.is-warn{color:#7a5b00}

/* Responsive */
@media(max-width:900px){
  .mock-choice-grid{grid-template-columns:1fr}
  .mock-subject-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .mock-free-banner{flex-direction:column;align-items:flex-start;gap:8px}
  .mock-subject-grid{grid-template-columns:1fr}
  .mock-list{grid-template-columns:1fr}
  .dash-mentor-wrap{white-space:normal}
}

/* ── In-dashboard booking: stream chips + toast ── */
.dash-stream-chip-row{
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:12px 16px;background:#fff;border:1px solid var(--g150);
  border-radius:12px;font-size:13px;color:var(--g600);
}
.dash-stream-chip-row strong{color:var(--ink);font-weight:700}
.dash-stream-chip-spacer{flex:1}
.dash-stream-chip{
  font:inherit;font-size:11.5px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;background:#fff;border:1px solid var(--g200);
  color:var(--g600);padding:6px 13px;border-radius:999px;cursor:pointer;
  transition:border-color .14s, color .14s, background .14s;
}
.dash-stream-chip:hover{border-color:var(--ink);color:var(--ink)}
.dash-stream-chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

.dash-toast{
  position:fixed;right:18px;bottom:18px;z-index:500;
  background:var(--ink);color:#fff;padding:12px 18px;
  border-radius:12px;font-size:13px;max-width:320px;line-height:1.4;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  opacity:0;transform:translateY(8px);transition:opacity .25s, transform .25s;
}
.dash-toast.show{opacity:1;transform:none}

@media(max-width:640px){
  .dash-stream-chip-row{flex-direction:column;align-items:flex-start}
  .dash-stream-chip-spacer{display:none}
  .dash-toast{right:12px;left:12px;bottom:12px;max-width:none}
}

/* ── Post-session review on booking cards ── */
.dash-booking-review{
  margin-top:10px;padding-top:10px;
  border-top:1px solid var(--g150);
  display:flex;flex-direction:column;gap:8px;
}
.dash-booking-review.is-upcoming{
  color:var(--g500);font-size:12px;
}
.dash-booking-review.is-form .dash-review-label{
  font-size:12.5px;color:var(--g600);font-weight:600;
}
.dash-booking-review.is-form textarea{
  width:100%;padding:8px 12px;
  border:1px solid var(--g200);border-radius:10px;
  background:#fff;font:inherit;font-size:13px;color:var(--ink);
  resize:vertical;min-height:46px;line-height:1.5;
  transition:border-color .14s, box-shadow .14s;
}
.dash-booking-review.is-form textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.05);
}
.dash-review-submit{
  align-self:flex-start;
  height:34px;padding:0 16px;border-radius:9px;
  font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  cursor:pointer;
}
.dash-review-submit[disabled]{opacity:.4;cursor:not-allowed}
.dash-review-status{
  margin:0;color:var(--g500);font-size:11.5px;min-height:14px;
}

.dash-stars{display:flex;gap:4px;align-items:center}
.dash-star{
  font:inherit;font-size:24px;line-height:1;
  background:transparent;border:none;cursor:pointer;padding:2px 4px;
  color:var(--g300);
  transition:color .12s, transform .1s;
}
.dash-star:hover{transform:scale(1.08)}
.dash-star.is-on{color:#f4b942}

.dash-booking-review.is-done strong{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--ink);color:#fff;
  padding:4px 10px;border-radius:999px;
  font-size:12px;letter-spacing:.04em;
  align-self:flex-start;
}
.dash-booking-review.is-done p{
  margin:0;font-size:13px;color:var(--g600);line-height:1.5;
}
.dash-booking-review.is-done em{
  font-style:normal;font-size:11px;color:var(--g500);letter-spacing:.04em;
}

@media(max-width:640px){
  .dash-review-submit{align-self:stretch;text-align:center}
}

/* ── Submit-new-evaluation inline form (Results view) ── */
.dash-eval-form{
  display:flex;flex-direction:column;gap:10px;
  padding:14px;margin-bottom:14px;
  background:var(--g50);border:1px dashed var(--g200);border-radius:12px;
}
.dash-eval-form .dash-form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.dash-eval-form .auth-field input,
.dash-eval-form .auth-field select,
.dash-eval-form .auth-field textarea{
  width:100%;padding:8px 12px;
  border:1px solid var(--g200);border-radius:9px;
  background:#fff;font:inherit;font-size:13px;color:var(--ink);
  transition:border-color .14s, box-shadow .14s;
}
.dash-eval-form .auth-field textarea{min-height:46px;line-height:1.5;resize:vertical}
.dash-eval-form .auth-field input:focus,
.dash-eval-form .auth-field select:focus,
.dash-eval-form .auth-field textarea:focus{
  outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.05);
}
.dash-eval-form-actions{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-top:4px;
}
.dash-eval-form-actions .dash-primary,
.dash-eval-form-actions .dash-secondary{
  font:inherit;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:8px 16px;border-radius:9px;cursor:pointer;border:1.5px solid var(--ink);
}
.dash-eval-form-actions .dash-primary{background:var(--ink);color:#fff}
.dash-eval-form-actions .dash-secondary{background:#fff;color:var(--ink);border-color:var(--g200)}
.dash-eval-form-actions .auth-status{margin:0;color:var(--g500);font-size:11.5px}
.dash-eval .dash-text-link{
  background:transparent;border:none;font:inherit;font-size:11.5px;font-weight:600;
  color:var(--ink);cursor:pointer;text-decoration:underline;padding:0;
}
@media(max-width:640px){
  .dash-eval-form .dash-form-row{grid-template-columns:1fr}
}

/* ── CBT Player ── */
.dash-cbt-view{
  position:fixed;inset:0;background:#fff;z-index:600;
  display:flex;flex-direction:column;
  padding:0;margin:0;
}
.dash-cbt-view[hidden]{display:none}
.dash-cbt-view.active{display:flex}

.cbt-top{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  padding:14px clamp(16px,3vw,32px);
  background:var(--ink);color:#fff;
  border-bottom:1px solid var(--g800);
}
.cbt-top-left{display:flex;flex-direction:column}
.cbt-mock-title{font-size:15px;letter-spacing:-.01em;font-weight:700}
.cbt-mock-sub{font-size:11.5px;color:var(--g300);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.cbt-top-right{display:flex;align-items:center;gap:12px}
.cbt-timer{
  font-family:'Space Grotesk',monospace;font-size:22px;font-weight:700;letter-spacing:.04em;
  background:#1a1a1a;color:#fff;padding:6px 14px;border-radius:9px;
  border:1px solid var(--g800);
  min-width:84px;text-align:center;
}
.cbt-exit{
  font:inherit;background:transparent;border:1px solid var(--g600);color:#fff;
  width:34px;height:34px;border-radius:8px;cursor:pointer;font-size:16px;
}
.cbt-exit:hover{background:var(--g800)}

.cbt-body{
  flex:1;min-height:0;
  display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:0;
  background:var(--g50);
}
.cbt-main{
  padding:clamp(20px,3.5vw,40px);
  overflow-y:auto;
  display:flex;flex-direction:column;gap:14px;
  background:#fff;
}
.cbt-q-meta{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  border-bottom:1px solid var(--g150);padding-bottom:10px;
}
.cbt-q-num{font-family:'Space Grotesk',monospace;font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--g600)}
.cbt-q-marks{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  background:var(--g100);color:var(--g600);padding:5px 12px;border-radius:999px;
}
.cbt-q-text{
  font-size:16px;line-height:1.55;color:var(--ink);
  white-space:pre-wrap;
}
.cbt-q-image{max-width:100%;max-height:300px;border-radius:10px;border:1px solid var(--g200)}
.cbt-q-answer{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.cbt-hint{font-size:11px;color:var(--g500);margin:0 0 2px}

.cbt-option{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;
  border:1.5px solid var(--g200);border-radius:11px;
  background:#fff;cursor:pointer;
  transition:border-color .12s, background .12s;
}
.cbt-option:hover{border-color:var(--ink);background:var(--g50)}
.cbt-option.is-picked{border-color:var(--ink);background:#f4f4f4}
.cbt-option input{accent-color:var(--ink);width:16px;height:16px;flex-shrink:0}
.cbt-option-letter{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:var(--g100);color:var(--ink);
  font-family:'Space Grotesk',monospace;font-weight:700;font-size:12px;
  flex-shrink:0;
}
.cbt-option.is-picked .cbt-option-letter{background:var(--ink);color:#fff}
.cbt-option-text{font-size:14px;line-height:1.4}

.cbt-input{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--g200);border-radius:11px;
  background:#fff;font:inherit;font-size:15px;color:var(--ink);
  transition:border-color .12s, box-shadow .12s;
}
.cbt-input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(0,0,0,.05)}

.cbt-q-actions{display:flex;gap:8px;flex-wrap:wrap}
.cbt-nav{display:flex;justify-content:space-between;gap:10px;margin-top:auto;padding-top:14px;border-top:1px solid var(--g150)}
.cbt-btn-ghost,
.cbt-btn-primary{
  font:inherit;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:10px 18px;border-radius:10px;cursor:pointer;
  border:1.5px solid var(--ink);
  transition:opacity .14s, background .14s, color .14s;
}
.cbt-btn-ghost{background:#fff;color:var(--ink);border-color:var(--g200)}
.cbt-btn-ghost:hover{border-color:var(--ink)}
.cbt-btn-ghost.is-on{background:#fff4d6;border-color:#d5a82e;color:#7a5b00}
.cbt-btn-primary{background:var(--ink);color:#fff}
.cbt-btn-primary:hover{opacity:.85}

.cbt-palette{
  background:#fff;border-left:1px solid var(--g150);
  padding:18px;display:flex;flex-direction:column;gap:14px;
  overflow-y:auto;
}
.cbt-palette-section{
  display:flex;gap:6px;flex-wrap:wrap;padding-bottom:8px;border-bottom:1px solid var(--g150);
}
.cbt-palette-head{
  font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--g500);
}
.cbt-palette-grid{
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;
}
.cbt-palette-cell{
  font:inherit;font-size:12px;font-weight:700;
  background:#fff;border:1.5px solid var(--g200);color:var(--g600);
  border-radius:8px;height:34px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:border-color .12s, background .12s, color .12s;
}
.cbt-palette-cell:hover{border-color:var(--ink)}
.cbt-palette-cell.is-current{box-shadow:0 0 0 2px var(--ink)}
.cbt-palette-cell.is-seen{border-color:var(--g300);color:var(--g500)}
.cbt-palette-cell.is-answered{background:#6b9a5b;color:#fff;border-color:#6b9a5b}
.cbt-palette-cell.is-marked{background:#f4b942;color:#1a1a1a;border-color:#d5a82e}
.cbt-palette-cell.is-answered.is-marked{
  background:linear-gradient(135deg,#6b9a5b 50%,#f4b942 50%);color:#fff;border-color:#6b9a5b;
}

.cbt-palette-stats{
  display:flex;flex-direction:column;gap:4px;
  font-size:12px;color:var(--g600);
}
.cbt-palette-stats strong{color:var(--ink);font-weight:700;margin-right:4px}

.cbt-palette-legend{
  display:flex;flex-direction:column;gap:5px;font-size:11.5px;color:var(--g500);
}
.cbt-palette-legend span{display:inline-flex;align-items:center;gap:6px}
.cbt-chip{
  display:inline-block;width:14px;height:14px;border-radius:4px;
  border:1.5px solid var(--g200);background:#fff;
}
.cbt-chip.is-answered{background:#6b9a5b;border-color:#6b9a5b}
.cbt-chip.is-marked{background:#f4b942;border-color:#d5a82e}
.cbt-chip.is-seen{background:#fff;border-color:var(--g300)}

.cbt-submit-btn{margin-top:auto}

/* Result overlay */
.cbt-result-overlay{
  position:fixed;inset:0;z-index:610;
  background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.cbt-result-overlay[hidden]{display:none}
.cbt-result-card{
  background:#fff;border-radius:18px;
  padding:28px;max-width:520px;width:100%;
  box-shadow:0 28px 80px rgba(0,0,0,.32);
  display:flex;flex-direction:column;gap:14px;
}
.cbt-result-card .cbt-kicker{
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500);
}
.cbt-result-card h2{font-size:22px;letter-spacing:-.02em;margin:0}
.cbt-result-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.cbt-result-grid div{
  background:var(--g50);border:1px solid var(--g150);border-radius:12px;
  padding:12px 14px;display:flex;flex-direction:column;gap:2px;
}
.cbt-result-grid span{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--g500);font-weight:700}
.cbt-result-grid strong{font-size:18px;letter-spacing:-.01em}
.cbt-result-note{margin:0;color:var(--g600);font-size:13.5px;line-height:1.5}
.cbt-result-actions{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}

@media(max-width:900px){
  .cbt-body{grid-template-columns:1fr}
  .cbt-palette{
    border-left:none;border-top:1px solid var(--g150);
    max-height:300px;
  }
  .cbt-palette-grid{grid-template-columns:repeat(8,minmax(0,1fr))}
}
@media(max-width:640px){
  .cbt-result-grid{grid-template-columns:1fr}
  .cbt-result-actions{flex-direction:column-reverse}
  .cbt-result-actions .cbt-btn-primary,
  .cbt-result-actions .cbt-btn-ghost{width:100%;text-align:center}
}

/* ── AI overview (result overlay + Results disclosure) ── */
.cbt-result-ai{
  background:#f3f7ef;
  border-left:3px solid #6b9a5b;
  border-radius:10px;
  padding:12px 14px;
  max-height:240px;overflow-y:auto;
}
.cbt-result-ai[hidden]{display:none}
.cbt-result-ai .cbt-kicker{
  display:inline-block;
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:#3a5a23;margin-bottom:6px;
}
.cbt-result-ai ul{
  margin:0;padding-left:18px;list-style:disc;
  display:flex;flex-direction:column;gap:5px;
}
.cbt-result-ai li{font-size:12.5px;line-height:1.5;color:var(--g800)}

.dash-eval-ai{
  margin-top:4px;
  background:#f3f7ef;
  border:1px solid #cfe0c2;
  border-radius:10px;
  padding:8px 12px;
  font-size:12.5px;
}
.dash-eval-ai summary{
  cursor:pointer;list-style:none;
  font-weight:700;letter-spacing:.04em;color:#3a5a23;
  display:flex;align-items:center;gap:6px;
  font-size:11.5px;text-transform:uppercase;
}
.dash-eval-ai summary::-webkit-details-marker{display:none}
.dash-eval-ai summary::before{
  content:'▸';display:inline-block;transition:transform .15s;font-size:10px;
}
.dash-eval-ai[open] summary::before{transform:rotate(90deg)}
.dash-eval-ai ul{
  margin:8px 0 2px;padding-left:18px;list-style:disc;
  display:flex;flex-direction:column;gap:4px;
}
.dash-eval-ai li{font-size:12.5px;line-height:1.5;color:var(--g800)}

/* ── ANALYSIS VIEW ── */
.dash-analysis-view{display:none;background:var(--g50);min-height:100vh}
.dash-analysis-view[hidden]{display:none !important}
.dash-analysis-view.active{display:block}
.ax-shell{
  max-width:1100px;margin:0 auto;
  padding:28px clamp(16px,3vw,40px) 80px;
  display:flex;flex-direction:column;gap:24px;
}

.ax-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;
  border-bottom:1px solid var(--g150);padding-bottom:18px;
}
.ax-kicker{
  display:inline-block;
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--g500);
}
.ax-head h1{
  font-size:clamp(28px,3.4vw,42px);letter-spacing:-.025em;line-height:1.1;margin-top:6px;
}
.ax-head p{color:var(--g500);font-size:12.5px;letter-spacing:.04em;margin-top:6px}
.ax-head-actions{display:flex;gap:6px;background:#fff;border:1px solid var(--g200);border-radius:999px;padding:4px}
.ax-tab{
  font:inherit;font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:8px 16px;border-radius:999px;cursor:pointer;border:none;background:transparent;color:var(--g500);
}
.ax-tab.is-active{background:var(--ink);color:#fff}

.ax-stat-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
}
.ax-stat{
  background:#fff;border:1px solid var(--g150);border-radius:14px;
  padding:18px 20px;display:flex;flex-direction:column;gap:6px;
  min-height:108px;
}
.ax-stat span{
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500);
}
.ax-stat strong{
  font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:32px;line-height:1;letter-spacing:-.02em;color:var(--ink);
}
.ax-stat strong em{font-style:normal;font-size:14px;color:var(--g400);letter-spacing:0;margin-left:2px}
.ax-stat small{font-size:11px;color:var(--g500)}
.ax-stat strong.is-good{color:#3a5a23}
.ax-stat-hero strong{color:#3a5a23}
.ax-stat sup{font-size:10px;color:var(--g400);margin-left:2px}

.ax-coach{
  background:#f3f7ef;
  border-left:4px solid #6b9a5b;
  border-radius:14px;padding:22px 24px;
}
.ax-coach .ax-kicker{color:#3a5a23;margin-bottom:8px}
.ax-coach p{
  font-size:14.5px;line-height:1.7;color:var(--g800);margin:0 0 10px;
}
.ax-coach p:last-child{margin-bottom:0}
.ax-coach strong{color:var(--ink);font-weight:700}

.ax-next-steps{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.ax-cta-primary,
.ax-cta-ghost{
  font:inherit;font-size:12.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:12px 22px;border-radius:11px;cursor:pointer;
  border:1.5px solid var(--ink);
}
.ax-cta-primary{background:var(--ink);color:#fff}
.ax-cta-primary:hover{opacity:.86}
.ax-cta-ghost{background:#fff;color:var(--ink);border-color:var(--g200)}
.ax-cta-ghost:hover{border-color:var(--ink)}
.ax-next-steps .auth-status{margin:0;color:var(--g500);font-size:12px;flex:1;min-width:200px}

.ax-block{
  background:#fff;border:1px solid var(--g150);border-radius:18px;
  padding:24px clamp(18px,2.5vw,28px);
  display:flex;flex-direction:column;gap:16px;
}
.ax-block > header h2{
  font-size:20px;letter-spacing:-.015em;margin:0;
}
.ax-block > header p{font-size:13px;color:var(--g500);margin-top:4px}
.ax-muted{color:var(--g500);font-style:normal;font-size:12.5px}

/* Quadrants */
.ax-quadrants{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
.ax-quad{
  background:var(--g50);border:1px solid var(--g150);border-radius:12px;
  padding:14px 16px;min-height:140px;
  display:flex;flex-direction:column;gap:6px;
}
.ax-quad-mastered{border-color:#cfe0c2;background:#f3f7ef}
.ax-quad-focus{border-color:#f0d893;background:#fff8e6}
.ax-quad-rule{font-size:11px;color:var(--g500);margin:0 0 4px}
.ax-quad-body{display:flex;flex-direction:column;gap:6px}
.ax-topic-chip{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--g200);border-radius:9px;
  padding:7px 11px;font-size:12.5px;
}
.ax-topic-chip strong{font-weight:700;color:var(--ink)}
.ax-topic-chip em{font-style:normal;font-size:10.5px;color:var(--g500);letter-spacing:.04em}

/* Matrix */
.ax-matrix-grid{
  display:grid;grid-template-columns:60px repeat(var(--cols, 3), minmax(120px, 1fr));
  gap:8px;align-items:stretch;
}
.ax-matrix-col-head,
.ax-matrix-row-head{
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500);
  display:flex;align-items:center;justify-content:center;padding:8px 6px;
}
.ax-matrix-row-head{
  background:var(--g50);border-radius:8px;
  writing-mode:vertical-rl;transform:rotate(180deg);
  letter-spacing:.18em;
}
.ax-matrix-row-head.is-hard{color:var(--ink)}
.ax-matrix-row-head.is-med{color:#7a5b00}
.ax-matrix-row-head.is-easy{color:#3a5a23}
.ax-matrix-cell{
  background:var(--g50);border:1px solid var(--g150);border-radius:10px;
  padding:10px;min-height:64px;
  display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start;align-content:flex-start;
}
.ax-matrix-empty{justify-content:center;align-items:center;color:var(--g400);font-size:12px}
.ax-mq{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;font-size:11.5px;font-weight:700;
  background:#fff;border:1px solid var(--g300);color:var(--g600);
}
.ax-mq.is-correct{background:#6b9a5b;border-color:#6b9a5b;color:#fff}
.ax-mq.is-wrong{background:#2a2a2a;border-color:#2a2a2a;color:#fff;position:relative}
.ax-mq.is-wrong::after{content:'';position:absolute;inset:5px;border-radius:50%;border:1.5px solid #fff;opacity:.4}
.ax-mq.is-skipped{background:#fff;border-color:var(--g200);color:var(--g400)}

/* Pacing */
.ax-pacing{display:flex;flex-direction:column;gap:8px}
.ax-pace-legend{font-size:11.5px;color:var(--g500);letter-spacing:.04em;margin-bottom:4px}
.ax-pace-row{display:grid;grid-template-columns:42px 1fr 72px;gap:10px;align-items:center}
.ax-pace-q{font-family:'Space Grotesk',monospace;font-size:12px;font-weight:700;color:var(--g600)}
.ax-pace-track{position:relative;height:18px;background:var(--g100);border-radius:6px;overflow:hidden}
.ax-pace-bar{height:100%;border-radius:6px;transition:width .25s ease}
.ax-pace-bar.is-fast{background:#6b9a5b}
.ax-pace-bar.is-normal{background:var(--g400)}
.ax-pace-bar.is-slow{background:#f4b942}
.ax-pace-bar.is-unattempted{background:#e0e0e0}
.ax-pace-tick{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--ink);opacity:.55}
.ax-pace-time{font-size:11.5px;color:var(--g600);text-align:right;font-family:'Space Grotesk',monospace}

/* Confidence */
.ax-conf{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.ax-conf-card{
  background:var(--g50);border:1px solid var(--g150);border-radius:11px;
  padding:12px 14px;display:flex;flex-direction:column;gap:4px;
}
.ax-conf-card span{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g500)}
.ax-conf-card strong{font-size:22px;letter-spacing:-.02em;color:var(--ink)}
.ax-conf-card.is-good{background:#f3f7ef;border-color:#cfe0c2}
.ax-conf-card.is-good strong{color:#3a5a23}
.ax-conf-card.is-warn{background:#fff8e6;border-color:#f0d893}
.ax-conf-card.is-warn strong{color:#7a5b00}

/* Section breakdown */
.ax-sections{display:flex;flex-direction:column;gap:12px}
.ax-section-row{display:flex;flex-direction:column;gap:6px}
.ax-section-row header{display:flex;justify-content:space-between;align-items:center;gap:10px}
.ax-section-row strong{font-size:13.5px}
.ax-section-row span{font-size:11.5px;color:var(--g500)}
.ax-section-track{height:8px;background:var(--g100);border-radius:6px;overflow:hidden}
.ax-section-fill{height:100%;background:linear-gradient(90deg,var(--ink),#6b9a5b);transition:width .3s ease}

/* Question grid + legend */
.ax-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--g600)}
.ax-legend span{display:inline-flex;align-items:center;gap:6px}
.ax-chip{display:inline-block;width:14px;height:14px;border-radius:4px;background:#fff;border:1.5px solid var(--g200)}
.ax-chip.is-cf{background:#6b9a5b;border-color:#6b9a5b}
.ax-chip.is-cs{background:#6b9a5b;border-color:#6b9a5b;opacity:.55}
.ax-chip.is-wf{background:#2a2a2a;border-color:#2a2a2a}
.ax-chip.is-ws{background:#2a2a2a;border-color:#2a2a2a;opacity:.55}
.ax-chip.is-na{background:#fff;border-color:var(--g300)}

.ax-q-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:8px}
.ax-qcell{
  background:#fff;border:1px solid var(--g200);border-radius:10px;
  padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:2px;
  font-family:'Space Grotesk',monospace;
}
.ax-qcell strong{font-size:14px;font-weight:700;color:var(--ink)}
.ax-qcell span{font-size:10.5px;color:var(--g500)}
.ax-qcell.is-correct-fast{background:#6b9a5b;border-color:#6b9a5b}
.ax-qcell.is-correct-fast strong, .ax-qcell.is-correct-fast span{color:#fff}
.ax-qcell.is-correct-slow{background:#9bbf85;border-color:#9bbf85}
.ax-qcell.is-correct-slow strong, .ax-qcell.is-correct-slow span{color:#fff}
.ax-qcell.is-wrong-fast{background:#2a2a2a;border-color:#2a2a2a}
.ax-qcell.is-wrong-fast strong, .ax-qcell.is-wrong-fast span{color:#fff}
.ax-qcell.is-wrong-slow{background:#6a6a6a;border-color:#6a6a6a}
.ax-qcell.is-wrong-slow strong, .ax-qcell.is-wrong-slow span{color:#fff}
.ax-qcell.is-skipped{background:#fafafa;color:var(--g400)}

/* Recommend card */
.ax-recommend-card{
  display:flex;flex-direction:column;gap:6px;
  background:var(--ink);color:#fff;border-radius:14px;padding:18px 22px;
  text-decoration:none;cursor:pointer;
  transition:transform .14s, opacity .14s;
}
.ax-recommend-card:hover{transform:translateY(-2px);opacity:.92}
.ax-recommend-card .ax-kicker{color:#9a9a9a}
.ax-recommend-card strong{font-size:18px;letter-spacing:-.01em;color:#fff}
.ax-recommend-card p{margin:0;color:#c0c0c0;font-size:13px}
.ax-recommend-card em{font-style:normal;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-top:6px}

/* Responsive */
@media(max-width:900px){
  .ax-stat-strip{grid-template-columns:repeat(2,1fr)}
  .ax-quadrants{grid-template-columns:1fr}
  .ax-conf{grid-template-columns:repeat(2,1fr)}
  .ax-matrix-grid{grid-template-columns:50px repeat(var(--cols, 3), minmax(100px,1fr));overflow-x:auto}
}
@media(max-width:640px){
  .ax-stat-strip{grid-template-columns:1fr 1fr}
  .ax-q-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}
  .ax-next-steps{flex-direction:column;align-items:stretch}
  .ax-next-steps button{width:100%;text-align:center}
}

/* ── CBT Custom Confirm Modal ── */
.cbt-confirm{
  position:fixed;inset:0;z-index:620;
  background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;transition:opacity .18s ease;
}
.cbt-confirm[hidden]{display:none}
.cbt-confirm.is-open{opacity:1}
.cbt-confirm-card{
  background:#fff;border-radius:18px;
  padding:28px 30px;max-width:460px;width:100%;
  box-shadow:0 28px 80px rgba(0,0,0,.32);
  display:flex;flex-direction:column;gap:10px;
  transform:translateY(8px);transition:transform .18s ease;
}
.cbt-confirm.is-open .cbt-confirm-card{transform:none}
.cbt-confirm-card .cbt-kicker{
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--g500);
}
.cbt-confirm-card h2{font-size:22px;letter-spacing:-.02em;margin:2px 0 6px;line-height:1.2}
.cbt-confirm-stats{
  margin:0;padding:10px 14px;
  background:var(--g50);border:1px solid var(--g150);border-radius:10px;
  font-size:13.5px;color:var(--g800);font-family:'Space Grotesk',sans-serif;
}
.cbt-confirm-note{margin:4px 0 6px;color:var(--g600);font-size:12.5px;line-height:1.5}
.cbt-confirm-actions{
  display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:6px;
}
.cbt-confirm-actions .cbt-btn-ghost,
.cbt-confirm-actions .cbt-btn-primary{
  padding:10px 18px;font-size:12px;
}
.cbt-confirm.is-exit .cbt-confirm-card{border-top:3px solid #f4b942}
.cbt-confirm.is-exit .cbt-kicker{color:#7a5b00}
@media(max-width:480px){
  .cbt-confirm-actions{flex-direction:column-reverse}
  .cbt-confirm-actions button{width:100%;text-align:center}
}

/* ── Answer Review View ── */
.dash-review-view{display:none;background:var(--g50);min-height:100vh}
.dash-review-view[hidden]{display:none !important}
.dash-review-view.active{display:block}
.rv-shell{
  max-width:1100px;margin:0 auto;
  padding:28px clamp(16px,3vw,40px) 80px;
  display:flex;flex-direction:column;gap:20px;
}
.rv-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;
  border-bottom:1px solid var(--g150);padding-bottom:18px;
}
.rv-head h1{font-size:clamp(24px,3vw,34px);letter-spacing:-.02em;line-height:1.15;margin-top:6px}
.rv-head p{color:var(--g500);font-size:12.5px;letter-spacing:.04em;margin-top:6px}

.rv-palette-block{
  background:#fff;border:1px solid var(--g150);border-radius:14px;
  padding:18px 20px;display:flex;flex-direction:column;gap:12px;
}
.rv-palette-head{
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
}
.rv-palette-head strong{font-size:13px;letter-spacing:-.005em;color:var(--ink)}
.rv-palette-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--g600)}
.rv-palette-legend span{display:inline-flex;align-items:center;gap:6px}
.rv-palette{display:flex;gap:8px;flex-wrap:wrap}
.rv-pal-cell{
  font:inherit;font-size:13px;font-weight:700;font-family:'Space Grotesk',monospace;
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  background:#fff;border:1.5px solid var(--g200);color:var(--g600);
  display:flex;align-items:center;justify-content:center;
  transition:transform .12s, box-shadow .12s, background .12s, color .12s, border-color .12s;
}
.rv-pal-cell:hover{transform:translateY(-1px)}
.rv-pal-cell.is-correct{background:#6b9a5b;border-color:#6b9a5b;color:#fff}
.rv-pal-cell.is-wrong{background:#2a2a2a;border-color:#2a2a2a;color:#fff}
.rv-pal-cell.is-skipped{background:#fff;border-color:var(--g300);color:var(--g400)}
.rv-pal-cell.is-current{box-shadow:0 0 0 2px var(--ink)}

.rv-q-card{
  background:#fff;border:1px solid var(--g150);border-radius:18px;
  padding:24px clamp(18px,2.5vw,28px);
  display:flex;flex-direction:column;gap:18px;
}
.rv-q-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap;
  padding-bottom:12px;border-bottom:1px solid var(--g150);
}
.rv-q-head .ax-kicker{display:block}
.rv-q-meta{display:flex;align-items:center;gap:10px}
.rv-status{
  display:inline-flex;align-items:center;
  font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
  background:var(--g100);color:var(--g600);
}
.rv-status.is-good{background:#dde9d3;color:#3a5a23}
.rv-status.is-bad{background:#3a3a3a;color:#fff}
.rv-status.is-skip{background:var(--g100);color:var(--g500)}
.rv-q-time{font-size:11.5px;color:var(--g500);font-family:'Space Grotesk',monospace}

.rv-q-body p{font-size:15px;line-height:1.6;color:var(--ink);margin:4px 0 0;white-space:pre-wrap}
.rv-q-image{max-width:100%;max-height:300px;border-radius:10px;border:1px solid var(--g200);margin-top:8px}

.rv-options{display:flex;flex-direction:column;gap:10px}
.rv-option{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:12px 16px;border-radius:11px;
  background:#fff;border:1.5px solid var(--g200);
  font-size:14px;
}
.rv-option.is-correct{background:#f3f7ef;border-color:#9bbf85}
.rv-option.is-wrong-pick{background:#f4f4f4;border-color:#3a3a3a;border-style:solid}
.rv-opt-letter{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  background:var(--g100);color:var(--ink);
  font-family:'Space Grotesk',monospace;font-weight:700;font-size:13px;
  flex-shrink:0;
}
.rv-option.is-correct .rv-opt-letter{background:#6b9a5b;color:#fff}
.rv-option.is-wrong-pick .rv-opt-letter{background:#2a2a2a;color:#fff}
.rv-opt-text{line-height:1.5}
.rv-opt-pill{
  display:inline-flex;align-items:center;
  font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 11px;border-radius:999px;white-space:nowrap;
}
.rv-opt-pill.is-correct{background:#6b9a5b;color:#fff}
.rv-opt-pill.is-wrong{background:#2a2a2a;color:#fff}

.rv-solution{
  background:var(--g50);border:1px solid var(--g150);border-radius:14px;
  padding:18px 20px;display:flex;flex-direction:column;gap:14px;
}
.rv-solution > .ax-kicker{display:block;margin-bottom:4px}
.rv-solution-section{
  background:#fff;border:1px solid var(--g150);border-radius:11px;
  padding:14px 16px;display:flex;flex-direction:column;gap:8px;
}
.rv-solution-section h3{
  font-size:13.5px;font-weight:700;letter-spacing:-.005em;margin:0;color:var(--ink);
}
.rv-solution-section p{font-size:13px;line-height:1.6;color:var(--g800);margin:0}
.rv-solution-section strong{color:var(--ink);font-weight:700}
.rv-solution-section blockquote{
  margin:0;padding:8px 12px;
  background:#f3f7ef;border-left:3px solid #6b9a5b;border-radius:6px;
  font-size:12.5px;color:var(--g800);font-style:italic;
}
.rv-step{
  display:flex;flex-direction:column;gap:4px;
  padding:8px 12px;background:var(--g50);border-radius:9px;
}
.rv-step-label{
  display:inline-flex;align-self:flex-start;
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--g500);
  padding:3px 8px;border:1px solid var(--g200);border-radius:6px;background:#fff;
}
.rv-step p{font-size:13px;line-height:1.55;color:var(--g800);margin:0}
.rv-final{
  padding:10px 14px;background:var(--ink);color:#fff;border-radius:9px;
  font-size:13px;
}
.rv-final strong{color:#fff}
.rv-muted{color:var(--g500);font-size:12.5px;font-style:italic}

.rv-answer-pills{
  display:flex;gap:10px;flex-wrap:wrap;
  padding-top:6px;border-top:1px solid var(--g150);
}
.rv-pill{
  display:inline-flex;align-items:center;
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  padding:8px 14px;border-radius:9px;
  background:var(--g50);color:var(--g600);
}
.rv-pill.is-correct{background:#f3f7ef;color:#3a5a23;border:1px solid #9bbf85}
.rv-pill.is-wrong{background:#2a2a2a;color:#fff}
.rv-pill.is-skip{background:var(--g100);color:var(--g500)}

.rv-nav-row{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:#fff;border:1px solid var(--g150);border-radius:12px;
  padding:14px 18px;
}
.rv-nav-row button{padding:10px 18px;font-size:12px}
.rv-nav-count{font-size:12px;color:var(--g600);font-family:'Space Grotesk',monospace}

.rv-foot{
  display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--g150);border-radius:14px;
  padding:16px 20px;
}
.rv-foot button{padding:11px 20px;font-size:12.5px}

@media(max-width:640px){
  .rv-option{grid-template-columns:auto 1fr;row-gap:6px}
  .rv-opt-pill{grid-column:1 / span 2;justify-self:flex-end}
  .rv-foot{flex-direction:column}
  .rv-foot button{width:100%;text-align:center}
  .rv-nav-row{flex-direction:column;align-items:stretch}
  .rv-nav-row button{width:100%;text-align:center}
}

/* ── Homepage pricing ── */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
  margin-top:18px;
}

.price-card{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:18px;
  background:#fff;
  border:1px solid var(--g150);
  border-radius:18px;
  padding:28px clamp(20px, 3vw, 32px);
  transition:transform .18s ease, border-color .18s ease;
}
.price-card:hover{transform:translateY(-2px);border-color:var(--g300)}

.price-card.is-featured{
  border-color:#6b9a5b;
  border-width:2px;
  background:#fafdf6;
  box-shadow:0 18px 40px rgba(107,154,91,.10);
  overflow:hidden;
}

.price-flag{
  position:absolute;top:16px;right:18px;
  display:inline-flex;align-items:center;
  font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:#6b9a5b;color:#fff;
  padding:5px 11px;border-radius:999px;
}

.price-card > header{display:flex;flex-direction:column;gap:6px}
.price-tier{
  display:inline-block;
  font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--g500);
}
.price-card.is-featured .price-tier{color:#3a5a23}

.price-amount{
  margin:4px 0 2px;
  font-size:clamp(36px, 5vw, 56px);
  font-weight:700;
  letter-spacing:-.03em;
  line-height:1;
  color:var(--ink);
  font-family:'Space Grotesk', sans-serif;
}
.price-amount .price-cur{
  font-size:.55em;
  font-weight:600;
  vertical-align:0.18em;
  margin-right:2px;
  color:var(--g600);
}
.price-amount small{
  font-size:14px;
  font-weight:400;
  color:var(--g500);
  letter-spacing:0;
  margin-left:8px;
}
.price-card > header p{
  margin:0;
  color:var(--g600);
  font-size:13.5px;
  line-height:1.55;
}

.price-features{
  list-style:none;
  margin:0;padding:0;
  display:flex;flex-direction:column;gap:10px;
  border-top:1px solid var(--g150);
  border-bottom:1px solid var(--g150);
  padding:18px 0;
}
.price-features li{
  position:relative;
  padding-left:28px;
  font-size:14px;
  line-height:1.5;
  color:var(--g800);
}
.price-features li::before{
  content:'';
  position:absolute;left:0;top:4px;
  width:18px;height:18px;border-radius:50%;
  background:#6b9a5b;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18'%3E%3Cpath d='M4.5 9.5l3 3 6-6' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
}

.price-cta{
  align-self:stretch;
  text-align:center;
}

.pricing-fine-print{
  margin:22px auto 0;
  text-align:center;
  color:var(--g500);
  font-size:12px;
  letter-spacing:.04em;
}

/* ── Per-card stream course chooser ── */
.price-chooser{
  border-top:1px solid var(--g150);
  border-bottom:1px solid var(--g150);
  padding:14px 0;
  display:flex;flex-direction:column;gap:10px;
}
.price-chooser-label{
  font:700 10.5px 'Space Grotesk',sans-serif;
  letter-spacing:.1em;text-transform:uppercase;color:var(--g400);
}
.stream-pills{display:flex;flex-wrap:wrap;gap:6px}
.stream-pill{
  font:600 11.5px 'Space Grotesk',sans-serif;
  padding:6px 12px;border-radius:999px;border:1px solid var(--g200);
  background:#fff;color:var(--g600);cursor:pointer;line-height:1;
  transition:border-color .14s,background .14s,color .14s;
}
.stream-pill:hover{border-color:var(--ink);color:var(--ink)}
.stream-pill.active{background:#6b9a5b;border-color:#6b9a5b;color:#fff}
.price-subjects{display:flex;flex-direction:column;gap:6px}
.price-subj-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:12.5px;color:var(--g600);
}
.price-subj-row span:last-child{color:var(--g400);font-size:11.5px;white-space:nowrap}
.price-subj-total{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin-top:4px;padding-top:8px;border-top:1px dashed var(--g200);
  font:700 12.5px 'Space Grotesk',sans-serif;color:#3a5a23;
}

/* ── FAQ accordion (SEO-friendly native details/summary) ── */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{
  border:1px solid var(--g150);border-radius:14px;background:#fff;
  padding:2px 18px;transition:border-color .15s,box-shadow .15s;
}
.faq-item[open]{border-color:var(--g300);box-shadow:0 6px 24px rgba(0,0,0,.04)}
.faq-q{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:16px 0;
  font:600 15px 'Space Grotesk',sans-serif;color:var(--ink);
}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{
  content:'+';font-weight:400;font-size:22px;color:var(--g400);
  flex-shrink:0;transition:transform .2s;line-height:1;
}
.faq-item[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 0 18px;font-size:14px;line-height:1.65;color:var(--g600)}

/* Lock scroll while a full-screen modal is open */
body.modal-open{overflow:hidden}

@media(max-width:480px){
  .faq-q{font-size:14px}
  .faq-a{font-size:13.5px}
}

.pricing-grid-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.pricing-grid-3 .price-amount{font-size:clamp(30px,3.4vw,44px)}

/* Pay-per-use add-ons strip */
.addons-strip{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:18px;
}
.addon-card{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--g150);border-radius:14px;
  padding:16px 18px;
}
.addon-head{display:flex;flex-direction:column;gap:2px}
.addon-head strong{font-size:15px;color:var(--ink)}
.addon-sub{font-size:12px;color:var(--g500)}
.addon-prices{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--g600)}
.addon-prices b{color:var(--ink);font-family:'Space Grotesk',sans-serif}

/* Competitive positioning table */
.compare-wrap{margin-top:18px;overflow-x:auto}
.compare-table{
  width:100%;border-collapse:collapse;min-width:560px;
  font-size:13.5px;background:#fff;border:1px solid var(--g150);border-radius:14px;overflow:hidden;
}
.compare-table th,.compare-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--g150)}
.compare-table thead th{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--g500);background:var(--g50,#f7f8f6)}
.compare-table td:first-child,.compare-table th:first-child{font-weight:600;color:var(--g800)}
.compare-table .is-us{background:#fafdf6;color:#3a5a23;font-weight:700}
.compare-table tbody tr:last-child td{border-bottom:none}

@media(max-width:860px){
  .pricing-grid-3{grid-template-columns:1fr}
  .pricing-grid-3 .price-card.is-featured{order:-1}
}
@media(max-width:700px){
  .pricing-grid{grid-template-columns:1fr}
  .price-card.is-featured{order:-1}
  .addons-strip{grid-template-columns:1fr}
}
@media(max-width:520px){
  .price-card{padding:24px 20px}
  .price-flag{top:14px;right:14px}
}

/* ── Dashboard pricing layer (upgrade modal, blueprint, squad) ── */
.pp-modal{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(20,28,18,.55);backdrop-filter:blur(2px);
}
.pp-modal[hidden]{display:none}
.pp-modal-card{
  position:relative;width:min(720px,100%);max-height:90vh;overflow:auto;
  background:#fff;border-radius:18px;padding:28px clamp(20px,3vw,32px);
  box-shadow:0 30px 80px rgba(0,0,0,.25);
}
.pp-modal-close{
  position:absolute;top:14px;right:16px;border:none;background:none;
  font-size:24px;line-height:1;color:var(--g500);cursor:pointer;
}
.pp-modal-head{margin-bottom:18px}
.pp-modal-head h2{margin:4px 0 2px}
.pp-modal-head p{color:var(--g600);font-size:13px;margin:0}

.pp-tier-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.pp-tier{
  display:flex;flex-direction:column;gap:10px;
  border:1px solid var(--g150);border-radius:14px;padding:18px 16px;
}
.pp-tier.is-featured{border-color:#6b9a5b;border-width:2px;background:#fafdf6}
.pp-tier.is-current{outline:2px solid var(--g300)}
.pp-tier-name{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500)}
.pp-tier-price{font-size:26px;font-weight:700;font-family:'Space Grotesk',sans-serif;color:var(--ink)}
.pp-tier ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px;flex:1}
.pp-tier ul li{font-size:12.5px;color:var(--g700);padding-left:16px;position:relative}
.pp-tier ul li::before{content:'✓';position:absolute;left:0;color:#6b9a5b;font-weight:700}
.pp-tier button{width:100%}

.pp-addon-group{margin-bottom:16px}
.pp-addon-title{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}
.pp-addon-title strong{font-size:15px}
.pp-addon-title span{font-size:12px;color:var(--g500)}
.pp-pack-row{display:flex;gap:10px;flex-wrap:wrap}
.pp-pack{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:96px;padding:12px}
.pp-pack b{font-size:17px;font-family:'Space Grotesk',sans-serif}
.pp-pack span{font-size:11px;color:var(--g500)}

.pp-locked{text-align:center}
.pp-locked h2{margin-top:0}
.pp-locked p{color:var(--g600);max-width:520px;margin:8px auto 16px}

.pp-weak-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.pp-weak-list li{font-size:13.5px;border-bottom:1px solid var(--g150);padding-bottom:8px}
.pp-week-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.pp-week{border:1px solid var(--g150);border-radius:12px;padding:14px}
.pp-week-n{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3a5a23}
.pp-week ul{margin:8px 0 0;padding-left:16px;font-size:12.5px;color:var(--g700)}
.pp-week p{font-size:12.5px;color:var(--g500);margin:8px 0 0}
.bp-sub-h{font-size:13px;font-weight:700;color:var(--g700);margin:18px 0 8px}

/* ── Panda Blueprint: free 44-week stream roadmap ── */
.bp-streamline{font-size:12.5px;color:var(--g600);margin-bottom:12px}
.bp-streamline strong{color:var(--ink)}
.bp-streamline span{color:var(--g400)}
.bp-combo{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.bp-pill{
  padding:6px 13px;border-radius:9px;font-size:12px;cursor:pointer;font-weight:600;
  border:1.5px solid var(--g150);background:#fff;color:var(--g500);
}
.bp-pill:hover{border-color:var(--g300)}
.bp-pill.active{border-color:#6b9a5b;color:#3a5a23;background:#f1f6ec}
.bp-subjects{display:flex;gap:6px;flex-wrap:wrap;padding:9px;border-radius:9px;margin-bottom:14px}
.bp-subj{padding:3px 9px;border-radius:5px;font-size:10.5px;font-weight:600;background:#fff;border:1px solid var(--g150)}
.bp-insight{padding:11px 13px;background:var(--g50);border:1px solid var(--g150);border-radius:10px;margin-bottom:14px}
.bp-insight-h{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:3px}
.bp-insight p{font-size:11.5px;color:var(--g600);line-height:1.6;margin:0}
.bp-timeline{display:flex;gap:0;border-radius:7px;overflow:hidden;height:26px;margin-bottom:6px}
.bp-tl-seg{
  flex:1;display:flex;align-items:center;justify-content:center;min-width:0;
  font-size:9px;font-weight:600;background:var(--g300);color:var(--g700);cursor:pointer;border:none;padding:0 2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:filter .15s;
}
.bp-tl-seg.active{background:#3a5a23;color:#fff}
.bp-tl-seg:hover{filter:brightness(1.04)}
.bp-tl-hint{font-size:10px;color:var(--g400);text-align:center;margin-bottom:14px}
.bp-phases{display:flex;flex-direction:column;gap:8px}
.bp-phase{border:1px solid var(--g150);border-radius:10px;overflow:hidden}
.bp-phase-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:9px 11px;cursor:pointer}
.bp-phase-head.is-open{box-shadow:inset 3px 0 0 #6b9a5b}
.bp-phase-title{font-size:13px;font-weight:700}
.bp-phase-desc{font-size:10.5px;color:var(--g600);margin-top:2px}
.bp-phase-note{font-size:10px;color:var(--g400);margin-top:2px}
.bp-phase-meta{flex:none;text-align:right;display:flex;flex-direction:column;gap:2px;align-items:flex-end}
.bp-phase-meta span{font-size:10px;color:var(--g400)}
.bp-phase-body{border-top:1px solid var(--g150)}
.bp-week{border-bottom:1px solid var(--g100)}
.bp-week:last-child{border-bottom:none}
.bp-week.is-special .bp-week-head{background:var(--g50)}
.bp-week-head{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer}
.bp-week-n{
  flex:none;display:inline-flex;align-items:center;justify-content:center;width:30px;height:28px;
  border-radius:6px;font-size:11px;font-weight:700;
}
.bp-week-head-main{flex:1;min-width:0}
.bp-week-special{font-size:10px;font-weight:700;color:var(--ink)}
.bp-week-ms{font-size:11px;font-weight:600;line-height:1.4}
.bp-week-name{font-size:11px;color:var(--g500)}
.bp-week-daily{flex:none;font-size:10px;color:var(--g400)}
.bp-week-caret{flex:none;font-size:9px;color:var(--g400)}
.bp-week-body{padding:6px 10px 10px 44px;background:#fafafa}
.bp-tip{padding:6px 9px;background:var(--g50);border:1px solid var(--g150);border-radius:6px;font-size:11px;color:var(--g600);line-height:1.5;margin-bottom:6px}
.bp-subline{display:flex;gap:8px;padding:4px 0;border-bottom:1px solid var(--g100)}
.bp-subline:last-child{border-bottom:none}
.bp-subhrs{flex:none;width:30px;font-size:10px;font-weight:700;text-align:center;padding-top:1px}
.bp-subline strong{font-size:11px;font-weight:600;color:var(--g700)}
.bp-subline span{font-size:11px;color:var(--g500)}
.bp-foot{text-align:center;border:1px dashed #6b9a5b;background:#fafdf6}
.bp-foot-h{font-size:13.5px;font-weight:700;color:#3a5a23}
.bp-foot p{font-size:12px;color:var(--g600);max-width:460px;margin:6px auto 14px}

.pp-refcode{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.pp-refcode code{
  font-size:20px;font-weight:700;letter-spacing:.08em;
  background:#fafdf6;border:1px dashed #6b9a5b;border-radius:10px;padding:10px 16px;color:#3a5a23;
}
.pp-ladder{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.pp-ladder li{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--g700)}
.pp-ladder li.is-done{color:var(--ink);font-weight:600}
.pp-ladder-n{
  display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  background:var(--g150);color:var(--g700);font-weight:700;font-size:13px;flex:none;
}
.pp-ladder li.is-done .pp-ladder-n{background:#6b9a5b;color:#fff}
.pp-ladder-check{margin-left:auto;color:#6b9a5b;font-weight:700}
.pp-friend-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.pp-friend-list li{font-size:13.5px;border-bottom:1px solid var(--g150);padding-bottom:8px}

.dash-review-video{
  display:inline-flex;align-items:center;gap:8px;margin:6px 0;
  background:#fafdf6;border:1px solid #6b9a5b;border-radius:10px;padding:9px 14px;
  color:#3a5a23;font-weight:600;font-size:13.5px;text-decoration:none;
}
.dash-review-video:hover{background:#f0f7ea}
.dash-review-video .rv-play{
  display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;
  background:#6b9a5b;color:#fff;font-size:9px;
}

@media(max-width:760px){
  .pp-tier-grid{grid-template-columns:1fr}
  .pp-week-grid{grid-template-columns:repeat(2,1fr)}
  .bp-tl-seg{font-size:8px}
  .bp-phase-note{display:none}
  .bp-week-body{padding-left:12px}
}

/* ── Admin: pricing & products ── */
.admin-tier-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.admin-tier-card{
  display:flex;flex-direction:column;gap:4px;
  border:1px solid var(--g150);border-radius:14px;padding:18px 16px;background:#fff;
}
.admin-tier-name{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g500)}
.admin-tier-count{font-size:30px;font-weight:700;font-family:'Space Grotesk',sans-serif;line-height:1;color:var(--ink)}
.admin-tier-meta{font-size:12px;color:var(--g500)}
.admin-sub-h{margin:20px 0 6px;font-size:13px;font-weight:600;color:var(--g700)}
.admin-sub-h:first-child{margin-top:0}
.admin-revshare-hint{font-size:12.5px;color:var(--g600);background:#fafdf6;border-radius:10px;padding:10px 12px;margin:4px 0 0}
@media(max-width:700px){ .admin-tier-grid{grid-template-columns:1fr} }

/* ── Teacher: Panda Review recorder ── */
.rec-panel{border:1px solid var(--g150);border-radius:14px;padding:16px;margin:14px 0;background:#fafdf6}
.rec-head{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}
.rec-head strong{font-size:14px}
.rec-video{width:100%;max-height:360px;background:#10140f;border-radius:10px;aspect-ratio:16/9;object-fit:contain}
.rec-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}
.rec-timer{font-family:'Space Grotesk',sans-serif;font-weight:600;color:#b23b3b}
.rec-progress{height:8px;border-radius:999px;background:var(--g150);overflow:hidden;margin-top:10px}
.rec-progress > i{display:block;height:100%;width:0;background:#6b9a5b;transition:width .2s ease}
a.mb-ghost{text-decoration:none;display:inline-flex;align-items:center}

/* ============================================================
   RECONSTRUCTED admin/teacher styles (v2 sidebar shell,
   mock-builder, teacher evaluation cards). These were lost when
   the admin/teacher styles.css copies were overwritten; rebuilt
   here so root styles.css is the true superset.
   ============================================================ */

/* ── v2 sidebar shell ── */
.admin-shell-v2{
  display:grid;
  grid-template-columns:250px minmax(0,1fr);
  min-height:100vh;
  background:var(--g50);
}
.admin-shell-v2[hidden]{display:none}
.admin-sidebar{
  position:sticky;top:0;align-self:start;
  height:100vh;
  display:flex;flex-direction:column;gap:3px;
  background:#fff;border-right:1px solid var(--g150);
  padding:18px 14px;overflow-y:auto;
}
.admin-brand{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;color:var(--ink);font-weight:700;font-size:15px;
  padding:6px 8px 16px;margin-bottom:10px;
  border-bottom:1px solid var(--g150);
}
.admin-brand img{width:34px;height:34px;object-fit:contain}
.admin-side-link{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:10px 12px;border-radius:10px;
  border:none;background:none;cursor:pointer;text-align:left;
  color:var(--g600);text-decoration:none;
  font:600 13px 'Space Grotesk',sans-serif;
}
.admin-side-link svg{color:var(--g400);flex-shrink:0}
.admin-side-link:hover{background:var(--g50);color:var(--ink)}
.admin-side-link.active{background:#eef5e9;color:#3a5a23}
.admin-side-link.active svg{color:#6b9a5b}
.admin-side-logout{margin-top:auto;color:#b23b3b}
.admin-side-logout svg{color:#b23b3b}
.admin-side-logout:hover{background:#fdecec;color:#9a2f2f}
/* Locked state (admin-shell.js adds .admin-locked when no session) */
.admin-locked .admin-main{opacity:.4;pointer-events:none;filter:saturate(.4)}
.admin-controls{max-width:760px}
.teacher-page{min-height:100vh;background:var(--g50);color:var(--ink)}

/* Mobile top bar + hamburger (injected by admin-shell.js / teacher-shell.js). */
.admin-mobile-bar{display:none}
@media(max-width:860px){
  .admin-shell-v2{grid-template-columns:1fr;min-height:100dvh}
  .admin-mobile-bar{
    display:flex;align-items:center;gap:12px;
    position:sticky;top:0;z-index:60;
    padding:11px 16px;background:#fff;border-bottom:1px solid var(--g150);
  }
  .admin-mobile-title{font:700 15px 'Space Grotesk',sans-serif;color:var(--ink)}
  .admin-mobile-title strong{color:var(--g500)}
  .admin-nav-toggle{
    width:44px;height:44px;flex-shrink:0;
    display:flex;flex-direction:column;justify-content:center;gap:5px;
    padding:0 11px;border:1px solid var(--g200);border-radius:10px;background:#fff;cursor:pointer;
  }
  .admin-nav-toggle span{height:2px;background:var(--ink);border-radius:2px;transition:transform .2s,opacity .2s}
  .admin-nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .admin-nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .admin-nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* Sidebar becomes an off-canvas drawer */
  .admin-sidebar{
    position:fixed;top:0;left:0;bottom:0;z-index:80;
    width:min(82vw,290px);height:100dvh;align-self:stretch;
    flex-direction:column;align-items:stretch;overflow-y:auto;
    transform:translateX(-100%);transition:transform .25s ease;
    box-shadow:0 18px 50px rgba(0,0,0,.18);
  }
  .admin-sidebar.open{transform:none}
  .admin-side-logout{margin-top:auto}
  .admin-backdrop{
    position:fixed;inset:0;z-index:70;background:rgba(8,8,8,.42);
    opacity:0;visibility:hidden;transition:opacity .25s;
  }
  .admin-backdrop.show{opacity:1;visibility:visible}
  body.admin-nav-open{overflow:hidden}
}

/* Wide tables collapse to labelled cards on phones (td data-label from renderers). */
@media(max-width:640px){
  .admin-table-wrap{overflow:visible}
  .admin-table{min-width:0}
  .admin-table thead{display:none}
  .admin-table tbody tr{
    display:block;background:#fff;border:1px solid var(--g150);
    border-radius:12px;padding:8px 14px;margin-bottom:12px;
  }
  .admin-table td{
    display:flex;align-items:center;justify-content:space-between;gap:14px;
    padding:8px 0;border:none;font-size:13px;text-align:right;
  }
  .admin-table td::before{
    content:attr(data-label);
    font:600 11.5px 'Space Grotesk',sans-serif;color:var(--g500);
    text-transform:uppercase;letter-spacing:.03em;text-align:left;
  }
  .admin-table td[colspan]{justify-content:center}
  .admin-table td[colspan]::before{display:none}
  .admin-table td.admin-row-actions{justify-content:flex-end;flex-wrap:wrap;padding-top:10px}
  .admin-table td.admin-row-actions::before{display:none}
  .rec-video{max-height:240px}
}

/* ── Mock builder ── */
.mb-shell{
  background:#fff;border:1px solid var(--g150);border-radius:18px;
  padding:clamp(18px,3vw,28px);
}
.mb-stepper{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;border-bottom:1px solid var(--g150);padding-bottom:14px}
.mb-stepper button{
  border:1px solid var(--g200);background:#fff;color:var(--g500);
  padding:7px 13px;border-radius:999px;cursor:pointer;
  font:700 11px 'Space Grotesk',sans-serif;letter-spacing:.04em;
}
.mb-stepper button:hover{background:var(--g50);color:var(--ink)}
.mb-stepper button.active{background:#6b9a5b;border-color:#6b9a5b;color:#fff}
.mb-step{display:none}
.mb-step.active{display:block}
.mb-locked-note{
  background:#fff8e8;border:1px solid #f0dca6;border-radius:10px;
  padding:10px 12px;font-size:12.5px;color:#7a5d12;margin-bottom:14px;
}
.mb-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mb-type-card{
  text-align:left;cursor:pointer;
  border:1.5px solid var(--g200);border-radius:14px;background:#fff;
  padding:18px;display:flex;flex-direction:column;gap:6px;
}
.mb-type-card strong{font-size:15px;color:var(--ink)}
.mb-type-card p{font-size:12.5px;color:var(--g500);line-height:1.55;margin:0}
.mb-type-card em{font-size:11.5px;color:var(--g400);font-style:normal;margin-top:2px}
.mb-type-card:hover{border-color:var(--g300)}
.mb-type-card.selected{border-color:#6b9a5b;background:#fafdf6;box-shadow:0 0 0 3px rgba(107,154,91,.12)}
.mb-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mb-form .auth-field.full,.mb-form .full{grid-column:1 / -1}
.mb-form-toggle{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--g700);cursor:pointer}
.mb-form-toggle input{margin-top:2px;width:16px;height:16px;flex-shrink:0}
.mb-add-option{
  width:100%;margin:6px 0 0;
  border:1.5px dashed var(--g300);background:var(--g50);color:var(--g600);
  border-radius:10px;padding:11px;cursor:pointer;
  font:600 13px 'Space Grotesk',sans-serif;
}
.mb-add-option:hover{border-color:#6b9a5b;color:#3a5a23;background:#fafdf6}
.mb-actions{display:flex;align-items:center;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--g150)}
.mb-spacer{flex:1}
.mb-actions button:not(.mb-ghost){
  min-height:40px;padding:0 18px;border:none;border-radius:10px;
  background:#6b9a5b;color:#fff;cursor:pointer;
  font:700 13px 'Space Grotesk',sans-serif;
}
.mb-actions button:not(.mb-ghost):hover{background:#5c8a4d}
.mb-ghost{
  min-height:40px;padding:0 16px;border:1px solid var(--g200);border-radius:10px;
  background:#fff;color:var(--ink);cursor:pointer;
  font:700 13px 'Space Grotesk',sans-serif;
}
.mb-ghost:hover{background:var(--g50)}
.mb-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.mb-tabs button{
  border:1px solid var(--g200);background:#fff;color:var(--g500);
  padding:6px 12px;border-radius:8px;cursor:pointer;font:600 12px 'Space Grotesk',sans-serif;
}
.mb-tabs button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.mb-section,.mb-question{
  border:1px solid var(--g150);border-radius:12px;padding:16px;margin-bottom:14px;background:var(--g50);
}
.mb-section-head,.mb-q-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.mb-q-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;background:#6b9a5b;color:#fff;
  font:700 12px 'Space Grotesk',sans-serif;flex-shrink:0;
}
.mb-row-actions{margin-left:auto;display:flex;gap:6px}
.mb-options{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.mb-option{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--g150);border-radius:9px;padding:8px 10px}
.mb-option input[type="text"]{flex:1;border:none;background:none;font-size:13px;color:var(--ink)}
.mb-option input[type="text"]:focus{outline:none}
[class^="mb-grid-"],[class*=" mb-grid-"]{display:grid;gap:12px}
.mb-grid-2{grid-template-columns:1fr 1fr}
.mb-grid-3{grid-template-columns:1fr 1fr 1fr}
.mb-image-drop{
  border:1.5px dashed var(--g300);border-radius:10px;background:var(--g50);
  padding:16px;text-align:center;color:var(--g500);font-size:12.5px;cursor:pointer;
}
.mb-image-drop:hover{border-color:#6b9a5b;background:#fafdf6}
.mb-image-meta{font-size:11.5px;color:var(--g400);margin-top:6px}
.mb-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.mb-summary > div,.mb-summary span{
  background:var(--g50);border:1px solid var(--g150);border-radius:10px;
  padding:10px 14px;font-size:12.5px;color:var(--g600);
}
.mb-validation{border-radius:10px;padding:12px 14px;font-size:13px;background:#fdecec;border:1px solid #f0b6b6;color:#9a2f2f;margin-bottom:14px}
.mb-validation.ok{background:#eef7e9;border-color:#bcd9aa;color:#3a5a23}
.mb-empty{color:var(--g500);font-size:13px;padding:14px 0}
@media(max-width:640px){
  .mb-type-grid,.mb-form,.mb-grid-2,.mb-grid-3{grid-template-columns:1fr}
}

/* ── Teacher evaluation (Panda Review) cards ── */
.eval-card{border:1px solid var(--g150);border-radius:14px;padding:18px;background:#fff}
.eval-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.eval-card-head strong{font-size:15px;display:block}
.eval-meta{font-size:12px;color:var(--g500);display:block;margin-top:2px}
.eval-deadline{
  font:700 11px 'Space Grotesk',sans-serif;letter-spacing:.04em;
  background:#eef5e9;color:#3a5a23;border-radius:999px;padding:5px 11px;white-space:nowrap;
}
.eval-deadline.is-overdue,.eval-deadline-inline.is-overdue{background:#fdecec;color:#9a2f2f}
.eval-deadline-inline{font:700 11px 'Space Grotesk',sans-serif;color:#3a5a23}
.eval-student-notes{background:var(--g50);border-radius:10px;padding:10px 12px;font-size:13px;color:var(--g600);margin:8px 0}
.eval-teacher-notes{font-size:13px;color:var(--g600);margin:6px 0}
.eval-actions-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:12px 0}
.eval-submit-row{display:flex;gap:10px;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid var(--g150)}
.eval-submit-row .mb-spacer,.eval-submit-row span.mb-spacer{flex:1}
.eval-file-pick{cursor:pointer}
.eval-file-pick input{display:none}
.eval-upload-meta{font-size:12px;color:var(--g500)}
.eval-accept-btn{min-height:34px;padding:0 14px;border:none;border-radius:9px;background:#6b9a5b;color:#fff;font:700 12px 'Space Grotesk',sans-serif;cursor:pointer}
.eval-accept-btn:hover{background:#5c8a4d}
.eval-accept-btn:disabled{opacity:.5;cursor:not-allowed}
.eval-history-item{border:1px solid var(--g150);border-radius:12px;padding:14px;margin-bottom:10px;background:#fff}
.eval-history-item header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.eval-history-item header strong{font-size:14px}
.eval-history-item header span{font-size:12px;color:var(--g400)}

