/* ═══════════════════════════════════════════
   First Down Academy — style.css
   Shared styles for all pages
   ═══════════════════════════════════════════ */

/* ── FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,700&family=DM+Mono:wght@400;500&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  /* Navy */
  --navy-950: #04091A;
  --navy-900: #080F2A;
  --navy-800: #0D1A3E;
  --navy-700: #132252;
  --navy-600: #1A2D6B;
  --navy-500: #1E3A8A;

  /* Orange */
  --orange-600: #C2510A;
  --orange-500: #E8630A;
  --orange-400: #F07A2A;
  --orange-300: #F5A060;
  --orange-100: #FEE8D0;

  /* Neutrals */
  --white:     #FFFFFF;
  --grey-50:   #F7F8FC;
  --grey-100:  #EEF1F8;
  --grey-200:  #DDE3EF;
  --grey-300:  #C2CBDE;
  --grey-500:  #8896B0;
  --grey-700:  #4A5568;

  /* Legacy aliases for v14 compatibility */
  --navy:      var(--navy-900);
  --blue:      var(--navy-500);
  --blue-mid:  var(--navy-600);
  --sky:       #2E6BE6;
  --orange:    var(--orange-500);
  --orange-lt: var(--orange-100);
  --silver:    var(--grey-300);
  --white:     #FFFFFF;
  --off:       var(--grey-50);
  --gray:      var(--grey-200);
  --text:      var(--navy-900);
  --muted:     var(--grey-500);
  --green:     #22C55E;
  --r-sm:6px; --r-md:14px; --r-lg:24px; --r-xl:40px;
  --shadow-sm: 0 2px 8px rgba(10,26,62,.08);
  --shadow-md: 0 8px 32px rgba(10,26,62,.12);
  --shadow-lg: 0 20px 64px rgba(10,26,62,.18);

  /* Typography */
  --font-d: 'Bebas Neue', 'Arial Narrow', Impact, sans-serif;
  --font-b: 'DM Sans', 'Helvetica Neue', Arial, sans-serif;
  --font-m: 'DM Mono', 'Courier New', monospace;

  --max-w: 1280px;
  --gutter: clamp(16px, 4vw, 80px);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-b);
  background: var(--white);
  color: var(--navy-900);
  line-height: 1.6;
  overflow-x: hidden;
}


*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --navy:    #0A1A3E;
  --blue:    #1B3A8C;
  --blue-mid:#1E4DB7;
  --sky:     #2E6BE6;
  --orange:  #E8630A;
  --orange-lt:#FEE8D0;
  --silver:  #A8B4C8;
  --white:   #FFFFFF;
  --off:     #F4F7FF;
  --gray:    #DDE3EE;
  --text:    #0F1E3C;
  --muted:   #5A6A88;
  --green:   #22C55E;
  --r-sm:6px; --r-md:14px; --r-lg:24px; --r-xl:40px;
  --shadow-sm:0 2px 8px rgba(10,26,62,.08);
  --shadow-md:0 8px 32px rgba(10,26,62,.12);
  --shadow-lg:0 20px 64px rgba(10,26,62,.18);
  --font-d:'Barlow Condensed',sans-serif;
  --font-b:'Barlow',sans-serif;
}
html { scroll-behavior:smooth; }
body { font-family:var(--font-b); background:var(--off); color:var(--text); line-height:1.6; overflow-x:hidden; }

/* ── UTILITY ── */
.container { max-width:1120px; margin:0 auto; padding:0 24px; }
.tag { display:inline-block; font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:4px 12px; border-radius:100px; background:var(--orange-lt); color:#6B2500; }
.tag-white { background:rgba(255,255,255,.15); color:var(--white); }
.tag-blue { background:rgba(46,107,230,.15); color:var(--blue); }
.btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-d); font-weight:700; font-size:17px; letter-spacing:.03em; text-transform:uppercase; padding:14px 32px; border-radius:var(--r-md); border:none; cursor:pointer; transition:all .2s ease; text-decoration:none; }
.btn-primary { background:var(--orange); color:var(--white); box-shadow:0 4px 20px rgba(232,99,10,.35); }
.btn-primary:hover { background:#D4580A; transform:translateY(-2px); box-shadow:0 8px 28px rgba(232,99,10,.45); }
.btn-outline { background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.4); }
.btn-outline:hover { border-color:var(--white); background:rgba(255,255,255,.1); }
.btn-navy { background:var(--navy); color:var(--white); box-shadow:var(--shadow-md); }
.btn-navy:hover { background:var(--blue); transform:translateY(-2px); }
.btn-ghost { background:var(--off); color:var(--navy); border:2px solid var(--gray); }
.btn-ghost:hover { border-color:var(--navy); background:var(--white); }

/* ── NAV ── */
nav { position:fixed; top:0; left:0; right:0; z-index:200; background:rgba(8,20,46,.98); backdrop-filter:blur(12px); border-bottom:1px solid rgba(200,208,220,.12); padding:0 24px; }
.nav-inner { max-width:1120px; margin:0 auto; padding:0 var(--gutter); display:flex; align-items:center; justify-content:space-between; height:72px; }
.logo { display:flex; align-items:center; gap:10px; font-family:var(--font-d); font-weight:900; font-size:20px; color:#EEF2FF; letter-spacing:.04em; text-transform:uppercase; text-decoration:none; cursor:pointer; border:none; background:none; }
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link { font-family:var(--font-d); font-weight:600; font-size:14px; letter-spacing:.04em; text-transform:uppercase; color:rgba(255,255,255,.7); padding:8px 12px; border-radius:var(--r-sm); text-decoration:none; transition:all .15s; cursor:pointer; border:none; background:none; }
.nav-link:hover { color:var(--white); background:rgba(255,255,255,.1); }
.nav-link.active { color:var(--orange); }
.nav-cta { margin-left:8px; font-size:13px; padding:10px 20px; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; border:none; background:none; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:all .2s; }
.mobile-menu { display:none; position:fixed; top:64px; left:0; right:0; background:var(--navy); border-bottom:1px solid rgba(255,255,255,.1); z-index:199; padding:16px; flex-direction:column; gap:4px; }
.mobile-menu.open { display:flex; }
.mobile-nav-link { font-family:var(--font-d); font-weight:700; font-size:18px; text-transform:uppercase; color:rgba(255,255,255,.8); padding:12px 16px; border-radius:var(--r-sm); cursor:pointer; border:none; background:none; text-align:left; }
.mobile-nav-link:hover { background:rgba(255,255,255,.1); color:var(--white); }

/* ── PAGES ── */
.page { display:none; }
.page.active { display:block; }

/* ── SHARED SECTION ── */
.section { padding:96px 0; }
.section-alt { background:var(--white); }
.section-dark { background:var(--navy); }
.section-header { text-align:center; margin-bottom:64px; }
.section-title { font-family:var(--font-d); font-weight:900; font-size:clamp(36px,5vw,56px); color:var(--navy); text-transform:uppercase; line-height:1; margin-top:12px; }
.section-title-white { color:var(--white); }
.section-sub { font-size:17px; color:var(--muted); max-width:540px; margin:16px auto 0; }
.section-sub-white { color:rgba(255,255,255,.65); }

/* PAGE HERO */
.page-hero { background:linear-gradient(135deg,var(--navy) 0%,#1B3A8C 100%); padding:120px 0 72px; position:relative; overflow:hidden; }
.page-hero::after { content:''; position:absolute; right:-80px; top:-80px; width:360px; height:360px; background:radial-gradient(circle,rgba(232,99,10,.12) 0%,transparent 70%); }
.page-hero-inner { position:relative; z-index:1; }
.page-hero h1 { font-family:var(--font-d); font-weight:900; font-size:clamp(40px,6vw,72px); color:var(--white); text-transform:uppercase; line-height:1; margin:12px 0 16px; }
.page-hero p { font-size:17px; color:rgba(255,255,255,.7); max-width:560px; }

/* FOOTER */
footer { background:var(--navy); padding:48px 0 32px; border-top:1px solid rgba(255,255,255,.06); }
.footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-logo { color:rgba(255,255,255,.7); font-family:var(--font-d); font-weight:800; font-size:18px; text-transform:uppercase; }
.footer-links { display:flex; gap:24px; flex-wrap:wrap; }
.footer-link { font-size:13px; color:rgba(255,255,255,.4); text-decoration:none; transition:color .15s; cursor:pointer; border:none; background:none; }
.footer-link:hover { color:rgba(255,255,255,.8); }
.footer-copy { font-size:12px; color:rgba(255,255,255,.25); }

/* ══════════════════════════════════════
   PAGE: HOME
══════════════════════════════════════ */
.hero { min-height:100vh; background:linear-gradient(145deg,#08142E 0%,#0F2260 50%,#0A1A3E 100%); display:flex; align-items:center; padding-top:64px; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 50% at 70% 50%,rgba(27,58,140,.3) 0%,transparent 70%),radial-gradient(ellipse 40% 60% at 20% 80%,rgba(232,99,10,.08) 0%,transparent 60%); }
.hero-grid { display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:64px; padding:80px 0; position:relative; z-index:1; }
.hero h1 { font-family:var(--font-d); font-weight:900; font-size:clamp(52px,7vw,88px); line-height:.95; color:var(--white); letter-spacing:-.01em; text-transform:uppercase; margin-bottom:24px; }
.hero h1 span { color:var(--orange); display:block; }
.hero-sub { font-size:18px; color:rgba(255,255,255,.7); max-width:440px; margin-bottom:40px; line-height:1.7; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero-note { font-size:13px; color:rgba(255,255,255,.4); margin-top:16px; }

/* Hero visual card */
.hero-visual { display:flex; justify-content:center; }
.hero-card { background:rgba(255,255,255,.07); border:1px solid rgba(200,208,220,.18); border-radius:var(--r-lg); padding:28px; backdrop-filter:blur(8px); width:100%; max-width:400px; }
.hero-card-label { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--orange); margin-bottom:16px; }
.giq-score-display { background:linear-gradient(135deg,var(--navy),#1B3A8C); border-radius:var(--r-md); padding:24px; text-align:center; margin-bottom:16px; }
.giq-score-num { font-family:var(--font-d); font-weight:900; font-size:72px; color:var(--orange); line-height:1; letter-spacing:-.02em; }
.giq-score-label { font-family:var(--font-d); font-weight:700; font-size:13px; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:.1em; margin-top:4px; }
.giq-score-title { font-family:var(--font-d); font-weight:800; font-size:18px; color:var(--white); text-transform:uppercase; margin-top:8px; }
.giq-breakdown { display:flex; flex-direction:column; gap:8px; }
.giq-row { display:flex; align-items:center; gap:10px; }
.giq-cat { font-size:12px; color:rgba(255,255,255,.7); width:100px; flex-shrink:0; }
.giq-bar-wrap { flex:1; height:6px; background:rgba(255,255,255,.1); border-radius:100px; overflow:hidden; }
.giq-bar-fill { height:100%; border-radius:100px; }
.giq-score-sm { font-family:var(--font-d); font-weight:700; font-size:12px; color:var(--orange); width:28px; text-align:right; }

/* Stats */
.stats-bar { background:var(--navy); border-top:1px solid rgba(255,255,255,.08); padding:32px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item { text-align:center; padding:8px 16px; border-right:1px solid rgba(255,255,255,.08); }
.stat-item:last-child { border-right:none; }
.stat-num { font-family:var(--font-d); font-weight:900; font-size:42px; color:var(--orange); line-height:1; letter-spacing:-.02em; }
.stat-label { font-size:12px; color:rgba(255,255,255,.45); margin-top:4px; letter-spacing:.06em; text-transform:uppercase; font-weight:600; }

/* How it works */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.step-card { background:var(--white); border-radius:var(--r-lg); padding:36px 28px; box-shadow:var(--shadow-sm); border:1px solid var(--gray); position:relative; overflow:hidden; transition:transform .2s,box-shadow .2s; }
.step-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.step-num { font-family:var(--font-d); font-weight:900; font-size:72px; color:var(--gray); line-height:1; position:absolute; top:16px; right:20px; letter-spacing:-.04em; }
.step-icon { width:52px; height:52px; border-radius:var(--r-md); background:linear-gradient(135deg,#1B3A8C,#2E6BE6); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:20px; }
.step-title { font-family:var(--font-d); font-weight:800; font-size:21px; color:var(--navy); text-transform:uppercase; margin-bottom:10px; }
.step-desc { font-size:14px; color:var(--muted); line-height:1.7; }

/* Gridiron IQ feature band */
.giq-band { background:linear-gradient(135deg,#08142E,#0A1A3E,#0F2260); border-radius:var(--r-xl); padding:72px 64px; position:relative; overflow:hidden; }
.giq-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(232,99,10,.12),transparent); }
.giq-band-inner { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; z-index:1; }
.giq-band-text h2 { font-family:var(--font-d); font-weight:900; font-size:clamp(36px,5vw,56px); color:var(--white); text-transform:uppercase; line-height:1; margin:12px 0 16px; }
.giq-band-text p { font-size:16px; color:rgba(255,255,255,.7); line-height:1.7; margin-bottom:24px; }
.giq-features { display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }
.giq-feature { display:flex; align-items:center; gap:12px; }
.giq-feature-icon { width:32px; height:32px; background:rgba(232,99,10,.2); border:1px solid rgba(232,99,10,.3); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.giq-feature-text { font-size:15px; color:rgba(255,255,255,.8); }
.giq-score-card { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-lg); padding:32px; }
.giq-big-score { text-align:center; margin-bottom:24px; }
.giq-big-num { font-family:var(--font-d); font-weight:900; font-size:96px; color:var(--orange); line-height:1; letter-spacing:-.04em; }
.giq-big-label { font-family:var(--font-d); font-weight:700; font-size:14px; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.1em; }
.giq-big-title { font-family:var(--font-d); font-weight:900; font-size:22px; color:var(--white); text-transform:uppercase; margin-top:8px; }
.giq-cats { display:flex; flex-direction:column; gap:10px; }
.giq-cat-row { display:flex; align-items:center; gap:12px; }
.giq-cat-name { font-size:13px; color:rgba(255,255,255,.65); width:120px; flex-shrink:0; }
.giq-cat-bar { flex:1; height:8px; background:rgba(255,255,255,.1); border-radius:100px; overflow:hidden; }
.giq-cat-fill { height:100%; border-radius:100px; }
.giq-cat-score { font-family:var(--font-d); font-weight:700; font-size:13px; color:var(--orange); width:32px; text-align:right; }

/* Coach band */
.coach-band { background:linear-gradient(135deg,#3D1A00,#7A3200,#5C2400); border-radius:var(--r-xl); padding:64px 56px; display:grid; grid-template-columns:1fr auto; align-items:center; gap:40px; border:1px solid rgba(232,99,10,.3); position:relative; overflow:hidden; }
.coach-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%, rgba(232,99,10,.2), transparent); }
.coach-band > * { position:relative; z-index:1; }
.coach-band h2 { font-family:var(--font-d); font-weight:900; font-size:44px; color:var(--white); text-transform:uppercase; line-height:1; margin-bottom:12px; }
.coach-band p { font-size:16px; color:rgba(255,255,255,.7); max-width:420px; }
.coach-band-btns { display:flex; flex-direction:column; gap:10px; align-items:flex-end; }

/* ══════════════════════════════════════
   PAGE: COURSE
══════════════════════════════════════ */
.course-overview { padding:72px 0; }
.course-intro { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; margin-bottom:72px; }
.course-intro-text h2 { font-family:var(--font-d); font-weight:900; font-size:42px; color:var(--navy); text-transform:uppercase; line-height:1; margin-bottom:16px; }
.course-intro-text p { font-size:16px; color:var(--muted); line-height:1.75; margin-bottom:16px; }
.course-stats-box { background:var(--navy); border-radius:var(--r-lg); padding:32px; }
.course-stat-row { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.08); }
.course-stat-row:last-child { border-bottom:none; }
.course-stat-label { font-size:14px; color:rgba(255,255,255,.6); }
.course-stat-val { font-family:var(--font-d); font-weight:800; font-size:20px; color:var(--orange); }

.modules-title-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; flex-wrap:wrap; gap:16px; }
.modules-heading { font-family:var(--font-d); font-weight:900; font-size:32px; color:var(--navy); text-transform:uppercase; }
.module-list { display:flex; flex-direction:column; gap:12px; }
.module-row { background:var(--white); border-radius:var(--r-md); border:1px solid var(--gray); padding:20px 24px; display:flex; align-items:center; gap:16px; box-shadow:var(--shadow-sm); transition:all .2s; }
.module-row:hover { box-shadow:var(--shadow-md); border-color:var(--sky); transform:translateX(4px); }
.module-row-num { font-family:var(--font-d); font-weight:900; font-size:20px; color:var(--white); background:var(--navy); width:44px; height:44px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.module-row-num.orange { background:var(--orange); }
.module-row-body { flex:1; }
.module-row-name { font-family:var(--font-d); font-weight:800; font-size:18px; color:var(--navy); text-transform:uppercase; }
.module-row-desc { font-size:13px; color:var(--muted); margin-top:2px; }
.module-row-count { font-family:var(--font-d); font-weight:700; font-size:13px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; flex-shrink:0; }

/* Login gate */
.login-gate { background:linear-gradient(135deg,var(--navy),var(--blue)); border-radius:var(--r-xl); padding:56px; text-align:center; margin-top:48px; position:relative; overflow:hidden; }
.login-gate::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 120%,rgba(232,99,10,.15),transparent); }
.login-gate-inner { position:relative; z-index:1; }
.login-gate h2 { font-family:var(--font-d); font-weight:900; font-size:40px; color:var(--white); text-transform:uppercase; line-height:1; margin-bottom:12px; }
.login-gate p { font-size:16px; color:rgba(255,255,255,.7); margin-bottom:32px; }
.login-gate-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ══════════════════════════════════════
   PAGE: GRIDIRON IQ
══════════════════════════════════════ */
.giq-hero { background:linear-gradient(145deg,#08142E,#0A1A3E,#0F2260); padding:120px 0 80px; position:relative; overflow:hidden; text-align:center; }
.giq-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 100%,rgba(232,99,10,.15),transparent); }
.giq-hero-inner { position:relative; z-index:1; }
.giq-hero h1 { font-family:var(--font-d); font-weight:900; font-size:clamp(48px,8vw,96px); color:var(--white); text-transform:uppercase; line-height:.9; margin:16px 0 20px; }
.giq-hero h1 span { color:var(--orange); display:block; }
.giq-hero p { font-size:18px; color:rgba(255,255,255,.7); max-width:560px; margin:0 auto 40px; line-height:1.7; }
.giq-coming-badge { display:inline-block; font-family:var(--font-d); font-weight:800; font-size:13px; letter-spacing:.12em; text-transform:uppercase; padding:8px 20px; border-radius:100px; background:rgba(232,99,10,.2); color:var(--orange); border:1px solid rgba(232,99,10,.3); margin-bottom:20px; }

.giq-what { padding:80px 0; }
.giq-what-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.giq-what-card { background:var(--white); border-radius:var(--r-lg); padding:36px 28px; box-shadow:var(--shadow-sm); border:1px solid var(--gray); text-align:center; transition:all .2s; }
.giq-what-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.giq-what-icon { width:64px; height:64px; border-radius:var(--r-lg); background:linear-gradient(135deg,var(--navy),var(--blue)); display:flex; align-items:center; justify-content:center; font-size:28px; margin:0 auto 20px; }
.giq-what-title { font-family:var(--font-d); font-weight:800; font-size:20px; color:var(--navy); text-transform:uppercase; margin-bottom:10px; }
.giq-what-desc { font-size:14px; color:var(--muted); line-height:1.7; }

.giq-categories { padding:80px 0; background:var(--white); }
.giq-cat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:56px; }
.giq-cat-card { display:flex; align-items:flex-start; gap:16px; padding:28px; background:var(--off); border-radius:var(--r-lg); border:1px solid var(--gray); transition:all .2s; }
.giq-cat-card:hover { box-shadow:var(--shadow-md); border-color:var(--orange); }
.giq-cat-card-icon { width:48px; height:48px; border-radius:var(--r-sm); flex-shrink:0; background:linear-gradient(135deg,var(--navy),var(--blue)); display:flex; align-items:center; justify-content:center; font-size:22px; }
.giq-cat-card-text h3 { font-family:var(--font-d); font-weight:800; font-size:17px; color:var(--navy); text-transform:uppercase; margin-bottom:6px; }
.giq-cat-card-text p { font-size:13px; color:var(--muted); line-height:1.7; }

.giq-notify { padding:80px 0; }
.giq-notify-box { background:linear-gradient(135deg,var(--navy),var(--blue-mid)); border-radius:var(--r-xl); padding:64px; text-align:center; position:relative; overflow:hidden; }
.giq-notify-box::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 120%,rgba(232,99,10,.15),transparent); }
.giq-notify-inner { position:relative; z-index:1; }
.giq-notify-box h2 { font-family:var(--font-d); font-weight:900; font-size:48px; color:var(--white); text-transform:uppercase; line-height:1; margin-bottom:16px; }
.giq-notify-box p { font-size:16px; color:rgba(255,255,255,.7); margin-bottom:36px; max-width:480px; margin-left:auto; margin-right:auto; }
.notify-form { display:flex; gap:0; max-width:480px; margin:0 auto; border-radius:var(--r-md); overflow:hidden; border:1px solid rgba(255,255,255,.2); }
.notify-input { flex:1; padding:14px 20px; font-family:var(--font-b); font-size:15px; background:rgba(255,255,255,.1); border:none; color:var(--white); outline:none; }
.notify-input::placeholder { color:rgba(255,255,255,.4); }
.notify-btn { padding:14px 24px; background:var(--orange); border:none; font-family:var(--font-d); font-weight:800; font-size:14px; color:var(--white); cursor:pointer; text-transform:uppercase; letter-spacing:.06em; transition:background .2s; white-space:nowrap; }
.notify-btn:hover { background:#D4580A; }

/* ══════════════════════════════════════
   PAGE: LEVELS / ROADMAP
══════════════════════════════════════ */
.roadmap-hero { background:linear-gradient(135deg,#08142E,var(--navy)); padding:120px 0 80px; position:relative; overflow:hidden; }
.roadmap-hero::before { content:'🏈'; position:absolute; right:60px; top:50%; transform:translateY(-50%) rotate(15deg); font-size:220px; opacity:.04; user-select:none; }
.roadmap-hero-inner { position:relative; z-index:1; }
.roadmap-hero h1 { font-family:var(--font-d); font-weight:900; font-size:clamp(44px,6vw,76px); color:var(--white); text-transform:uppercase; line-height:1; margin:12px 0 20px; }
.roadmap-hero p { font-size:17px; color:rgba(255,255,255,.7); max-width:520px; }

.roadmap-section { padding:80px 0; }
.roadmap-grid { display:flex; flex-direction:column; gap:24px; max-width:860px; margin:0 auto; }
.roadmap-card { border-radius:var(--r-xl); padding:40px 48px; position:relative; overflow:hidden; border:2px solid; }
.roadmap-card.current { background:var(--white); border-color:var(--orange); box-shadow:0 8px 48px rgba(232,99,10,.15); }
.roadmap-card.upcoming { background:var(--white); border-color:var(--gray); opacity:.8; }
.roadmap-card-badge { position:absolute; top:24px; right:28px; font-family:var(--font-d); font-weight:800; font-size:12px; letter-spacing:.1em; text-transform:uppercase; padding:6px 14px; border-radius:100px; }
.badge-live { background:rgba(34,197,94,.15); color:#15803D; border:1px solid rgba(34,197,94,.3); }
.badge-soon { background:var(--off); color:var(--muted); border:1px solid var(--gray); }
.roadmap-level { font-family:var(--font-d); font-weight:700; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--orange); margin-bottom:8px; }
.roadmap-level.muted { color:var(--muted); }
.roadmap-title { font-family:var(--font-d); font-weight:900; font-size:clamp(32px,4vw,48px); color:var(--navy); text-transform:uppercase; line-height:1; margin-bottom:12px; }
.roadmap-subtitle { font-size:16px; color:var(--muted); margin-bottom:24px; line-height:1.6; }
.roadmap-who { display:inline-flex; align-items:center; gap:8px; background:var(--off); border:1px solid var(--gray); border-radius:100px; padding:6px 16px; font-family:var(--font-d); font-weight:700; font-size:13px; color:var(--navy); text-transform:uppercase; letter-spacing:.06em; margin-bottom:24px; }
.roadmap-modules { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:28px; }
.roadmap-module-chip { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:4px 12px; border-radius:100px; background:var(--off); color:var(--navy); border:1px solid var(--gray); }
.roadmap-card.current .roadmap-module-chip { background:rgba(232,99,10,.08); border-color:rgba(232,99,10,.2); color:var(--orange); }
.roadmap-coming-note { font-size:14px; color:var(--muted); font-style:italic; margin-top:8px; }

/* ══════════════════════════════════════
   PAGE: COACHES
══════════════════════════════════════ */
.coach-hero { background:linear-gradient(135deg,#08142E,var(--navy)); padding:120px 0 80px; position:relative; overflow:hidden; }
.coach-hero::before { content:'🏈'; position:absolute; right:80px; top:50%; transform:translateY(-50%) rotate(15deg); font-size:200px; opacity:.04; user-select:none; }
.coach-hero-inner { position:relative; z-index:1; }
.coach-hero h1 { font-family:var(--font-d); font-weight:900; font-size:clamp(44px,6vw,76px); color:var(--white); text-transform:uppercase; line-height:1; margin:12px 0 20px; }
.coach-hero p { font-size:17px; color:rgba(255,255,255,.7); max-width:500px; margin-bottom:36px; }
.coach-steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:56px; }
.coach-step { text-align:center; padding:36px 24px; background:var(--white); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); border:1px solid var(--gray); transition:all .2s; }
.coach-step:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.coach-step-num { font-family:var(--font-d); font-weight:900; font-size:56px; color:var(--orange); line-height:1; margin-bottom:12px; }
.coach-step h3 { font-family:var(--font-d); font-weight:800; font-size:19px; color:var(--navy); text-transform:uppercase; margin-bottom:10px; }
.coach-step p { font-size:14px; color:var(--muted); line-height:1.7; }
.referral-box { background:linear-gradient(135deg,var(--navy),var(--blue-mid)); border-radius:var(--r-xl); padding:64px; text-align:center; position:relative; overflow:hidden; }
.referral-box::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 50% 120%,rgba(232,99,10,.15),transparent); }
.referral-box-inner { position:relative; z-index:1; }
.referral-box h2 { font-family:var(--font-d); font-weight:900; font-size:44px; color:var(--white); text-transform:uppercase; line-height:1; margin-bottom:14px; }
.referral-box p { font-size:16px; color:rgba(255,255,255,.7); margin-bottom:36px; }
.referral-link-demo { display:flex; align-items:stretch; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:var(--r-md); overflow:hidden; max-width:500px; margin:0 auto 28px; }
.referral-link-text { flex:1; padding:14px 18px; font-family:var(--font-d); font-size:15px; color:rgba(255,255,255,.8); font-weight:600; }
.referral-copy-btn { padding:14px 22px; background:var(--orange); border:none; font-family:var(--font-d); font-weight:800; font-size:13px; color:var(--white); cursor:pointer; text-transform:uppercase; letter-spacing:.06em; transition:all .2s; }
.referral-copy-btn:hover { background:#D4580A; }
.benefits-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:56px; }
.benefit-card { display:flex; align-items:flex-start; gap:18px; padding:28px; background:var(--off); border-radius:var(--r-lg); border:1px solid var(--gray); transition:all .2s; }
.benefit-card:hover { box-shadow:var(--shadow-md); border-color:var(--sky); }
.benefit-icon { width:48px; height:48px; border-radius:var(--r-sm); flex-shrink:0; background:linear-gradient(135deg,var(--navy),var(--blue)); display:flex; align-items:center; justify-content:center; font-size:22px; }
.benefit-text h3 { font-family:var(--font-d); font-weight:800; font-size:17px; color:var(--navy); text-transform:uppercase; margin-bottom:6px; }
.benefit-text p { font-size:13px; color:var(--muted); line-height:1.7; }

/* ══════════════════════════════════════
   PAGE: AUTH
══════════════════════════════════════ */
.auth-page { min-height:100vh; padding-top:64px; display:flex; align-items:center; justify-content:center; background:linear-gradient(145deg,var(--navy),#112068); }
.auth-card { background:var(--white); border-radius:var(--r-xl); padding:48px; width:100%; max-width:440px; box-shadow:var(--shadow-lg); margin:24px; }
.auth-logo-area { text-align:center; margin-bottom:28px; }
.auth-title { font-family:var(--font-d); font-weight:900; font-size:28px; color:var(--navy); text-transform:uppercase; }
.auth-sub { font-size:14px; color:var(--muted); margin-top:4px; }
.auth-tabs { display:flex; background:var(--off); border-radius:var(--r-md); padding:4px; margin-bottom:24px; gap:4px; }
.auth-tab { flex:1; padding:10px; font-family:var(--font-d); font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.04em; border:none; border-radius:var(--r-sm); cursor:pointer; transition:all .2s; color:var(--muted); background:transparent; }
.auth-tab.active { background:var(--white); color:var(--navy); box-shadow:var(--shadow-sm); }
.form-group { margin-bottom:16px; }
.form-label { display:block; font-family:var(--font-d); font-weight:700; font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--navy); margin-bottom:6px; }
.form-input { width:100%; padding:12px 16px; border:2px solid var(--gray); border-radius:var(--r-md); font-family:var(--font-b); font-size:15px; color:var(--text); transition:border-color .2s; outline:none; }
.form-input:focus { border-color:var(--blue); }
.form-select { width:100%; padding:12px 16px; border:2px solid var(--gray); border-radius:var(--r-md); font-family:var(--font-b); font-size:15px; color:var(--text); background:var(--white); cursor:pointer; outline:none; }

/* ══════════════════════════════════════
   PAGE: DASHBOARD
══════════════════════════════════════ */
.dashboard { padding-top:68px; min-height:100vh; background:var(--off); }
.dash-header { background:linear-gradient(135deg,var(--navy),var(--blue)); padding:40px 0; }
.dash-header-inner { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.dash-welcome { font-family:var(--font-d); font-weight:900; font-size:36px; color:var(--white); text-transform:uppercase; }
.dash-welcome span { color:var(--orange); }
.dash-rank-badge { display:flex; align-items:center; gap:14px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); border-radius:var(--r-md); padding:14px 20px; }
.dash-rank-name { font-family:var(--font-d); font-weight:900; font-size:18px; color:var(--orange); text-transform:uppercase; }
.dash-rank-level { font-size:12px; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.06em; }
.dash-body { padding:48px 0; }
.dash-grid { display:grid; grid-template-columns:2fr 1fr; gap:28px; align-items:start; }
.dash-card { background:var(--white); border-radius:var(--r-lg); border:1px solid var(--gray); overflow:hidden; box-shadow:var(--shadow-sm); }
.dash-card-header { padding:20px 24px; border-bottom:1px solid var(--gray); display:flex; align-items:center; justify-content:space-between; }
.dash-card-title { font-family:var(--font-d); font-weight:800; font-size:18px; color:var(--navy); text-transform:uppercase; }
.dash-card-body { padding:24px; }
.op-row { display:flex; justify-content:space-between; margin-bottom:8px; }
.op-label { font-family:var(--font-d); font-weight:700; font-size:14px; color:var(--navy); text-transform:uppercase; }
.op-val { font-family:var(--font-d); font-weight:700; font-size:14px; color:var(--blue); }
.op-bar { height:10px; background:var(--off); border-radius:100px; overflow:hidden; border:1px solid var(--gray); margin-bottom:20px; }
.op-fill { height:100%; background:linear-gradient(90deg,#2E6BE6,#E8630A); border-radius:100px; }
.module-progress-list { display:flex; flex-direction:column; gap:12px; }
.mod-prog-item { display:flex; align-items:center; gap:12px; }
.mod-prog-num { font-family:var(--font-d); font-weight:900; font-size:13px; color:var(--white); background:var(--navy); width:28px; height:28px; border-radius:6px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mod-prog-name { font-size:13px; color:var(--text); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mod-prog-bar-wrap { width:80px; height:6px; background:var(--off); border-radius:100px; overflow:hidden; flex-shrink:0; border:1px solid var(--gray); }
.mod-prog-fill { height:100%; background:var(--sky); border-radius:100px; }
.mod-prog-pct { font-family:var(--font-d); font-weight:700; font-size:12px; color:var(--muted); width:32px; text-align:right; }
.streak-card-inner { text-align:center; padding:8px 0; }
.streak-num { font-family:var(--font-d); font-weight:900; font-size:64px; color:var(--orange); line-height:1; }
.streak-label { font-size:13px; color:var(--muted); margin-top:4px; }
.streak-days { display:grid; grid-template-columns:repeat(7,1fr); gap:4px; margin-top:20px; }
.streak-day { aspect-ratio:1; border-radius:6px; display:flex; align-items:center; justify-content:center; font-family:var(--font-d); font-weight:700; font-size:10px; }
.streak-day.on { background:var(--orange); color:var(--white); }
.streak-day.off { background:var(--off); color:var(--muted); border:1px solid var(--gray); }
.streak-day.today { background:var(--navy); color:var(--white); }
.next-lesson-card { background:linear-gradient(135deg,var(--navy),var(--blue-mid)); border-radius:var(--r-lg); padding:24px; margin-top:20px; }
.nl-label { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:8px; }
.nl-title { font-family:var(--font-d); font-weight:900; font-size:20px; color:var(--white); text-transform:uppercase; margin-bottom:16px; line-height:1.1; }
.nl-btn { width:100%; justify-content:center; font-size:15px; padding:12px; }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);} }
.fade-up { animation:fadeUp .5s ease forwards; }
.d1{animation-delay:.1s;opacity:0;} .d2{animation-delay:.2s;opacity:0;} .d3{animation-delay:.3s;opacity:0;} .d4{animation-delay:.4s;opacity:0;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-grid,.giq-band-inner,.coach-band,.dash-grid { grid-template-columns:1fr; }
  .hero-visual,.giq-band-visual { display:none; }
  .steps-grid,.coach-steps-grid,.giq-what-grid { grid-template-columns:1fr; }
  .benefits-grid,.giq-cat-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-item { border-right:none; border-bottom:1px solid rgba(255,255,255,.08); }
  .course-intro { grid-template-columns:1fr; }
  .coach-band-btns { align-items:flex-start; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .giq-band { padding:48px 28px; }
  .referral-box,.login-gate { padding:36px 24px; }
}

/* GIQ Concept section */
.giq-concept-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.giq-concept-title { font-family:var(--font-d); font-weight:900; font-size:clamp(28px,4vw,42px); color:var(--navy); text-transform:uppercase; line-height:1.05; margin:12px 0 20px; }
.giq-concept-body { font-size:15px; color:var(--muted); line-height:1.8; margin-bottom:16px; }
.field-svg-wrap { background:linear-gradient(135deg,#0A1A3E,#1B3A8C); border-radius:var(--r-lg); padding:24px; box-shadow:var(--shadow-lg); border:1px solid rgba(255,255,255,.08); }

/* The Loop */
.loop-grid { display:grid; grid-template-columns:1fr auto 1fr auto 1fr; align-items:center; gap:16px; }
.loop-card { background:var(--white); border-radius:var(--r-lg); padding:32px 24px; box-shadow:var(--shadow-sm); border:1px solid var(--gray); text-align:center; transition:all .2s; }
.loop-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.loop-icon-wrap { display:flex; justify-content:center; margin-bottom:16px; }
.loop-step-num { font-family:var(--font-d); font-weight:900; font-size:36px; color:var(--gray); line-height:1; margin-bottom:8px; }
.loop-title { font-family:var(--font-d); font-weight:800; font-size:18px; color:var(--navy); text-transform:uppercase; margin-bottom:10px; }
.loop-desc { font-size:14px; color:var(--muted); line-height:1.7; }
.loop-arrow { display:flex; align-items:center; justify-content:center; flex-shrink:0; }

/* Pillars */
.pillars-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.pillar-card { background:var(--navy); border-radius:var(--r-lg); padding:24px 20px; cursor:pointer; transition:all .2s; border:1px solid rgba(255,255,255,.06); }
.pillar-card:hover { background:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pillar-icon { margin-bottom:12px; }
.pillar-num { font-family:var(--font-d); font-weight:900; font-size:28px; color:rgba(255,255,255,.15); line-height:1; margin-bottom:6px; }
.pillar-name { font-family:var(--font-d); font-weight:800; font-size:16px; color:var(--white); text-transform:uppercase; margin-bottom:8px; }
.pillar-edge { font-size:12px; color:rgba(255,255,255,.55); line-height:1.6; }

/* Levels progression */
.levels-progression { text-align:center; }
.levels-trophy-wrap { margin-bottom:24px; }

/* Responsive additions */
@media(max-width:900px) {
  .giq-concept-grid { grid-template-columns:1fr; }
  .field-svg-wrap { display:none; }
  .loop-grid { grid-template-columns:1fr; gap:24px; }
  .loop-arrow { transform:rotate(90deg); }
  .pillars-grid { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:480px) {
  .pillars-grid { grid-template-columns:1fr; }
}


.nav-dropdown { position:relative; }
.nav-dropdown-menu { display:none; position:absolute; top:calc(100% + 8px); left:50%; transform:translateX(-50%); background:var(--navy); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-md); padding:8px; min-width:260px; z-index:300; box-shadow:0 16px 48px rgba(0,0,0,.4); }
.nav-dropdown-menu.open { display:flex; flex-direction:column; gap:4px; }
.nav-dropdown-item { display:flex; align-items:center; gap:10px; padding:12px 16px; border-radius:var(--r-sm); border:none; background:transparent; cursor:pointer; text-align:left; width:100%; color:rgba(255,255,255,.8); font-family:var(--font-b); font-size:14px; transition:background .15s; }
.nav-dropdown-item:hover { background:rgba(255,255,255,.1); color:var(--white); }
.nav-dropdown-item strong { color:var(--white); }

/* Role toggle */
.role-toggle { display:flex; background:var(--off); border-radius:var(--r-md); padding:4px; margin-bottom:20px; gap:4px; }
.role-btn { flex:1; padding:10px; font-family:var(--font-d); font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.04em; border:none; border-radius:var(--r-sm); cursor:pointer; transition:all .2s; color:var(--muted); background:transparent; }
.role-btn.active { background:var(--white); color:var(--navy); box-shadow:var(--shadow-sm); }
.role-btn#roleCoach.active { background:var(--navy); color:var(--white); }

/* Coach link preview */
.coach-link-preview { background:var(--off); border:1px solid var(--gray); border-radius:var(--r-md); padding:14px 16px; margin-bottom:16px; }
.clp-label { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.clp-link { font-size:14px; color:var(--text); word-break:break-all; }
.clp-link strong { color:var(--orange); }


/* ── MODULE OVERVIEW ── */
.module-overview { display:flex; flex-direction:column; gap:20px; }
.overview-meta { display:flex; gap:8px; flex-wrap:wrap; }
.overview-chip { font-family:var(--font-d); font-weight:700; font-size:12px; letter-spacing:.08em; text-transform:uppercase; padding:6px 14px; border-radius:100px; background:var(--off); color:var(--navy); border:1px solid var(--gray); }
.overview-desc { font-size:16px; color:var(--muted); line-height:1.7; }
.overview-lessons { display:flex; flex-direction:column; gap:10px; }
.overview-lesson-item { display:flex; align-items:center; gap:14px; padding:14px 18px; background:var(--white); border-radius:var(--r-md); border:1px solid var(--gray); }
.overview-lesson-num { width:32px; height:32px; background:var(--navy); border-radius:8px; display:flex; align-items:center; justify-content:center; font-family:var(--font-d); font-weight:900; font-size:15px; color:var(--white); flex-shrink:0; }
.overview-lesson-title { font-family:var(--font-d); font-weight:800; font-size:16px; color:var(--navy); text-transform:uppercase; }
.overview-lesson-count { font-size:12px; color:var(--muted); margin-top:2px; }

/* ── SLIDE ── */
.slide-container { display:flex; flex-direction:column; gap:20px; user-select:none; }
.slide-lesson-label { font-family:var(--font-d); font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.slide-card { background:var(--white); border-radius:var(--r-xl); padding:40px 36px; box-shadow:var(--shadow-md); border:1px solid var(--gray); min-height:220px; display:flex; flex-direction:column; justify-content:center; transition:opacity 0.2s ease, transform 0.2s ease; }
.slide-heading { font-family:var(--font-d); font-weight:900; font-size:clamp(22px,4vw,32px); color:var(--navy); text-transform:uppercase; line-height:1.1; margin-bottom:20px; }
.slide-body { font-size:17px; color:var(--text); line-height:1.8; }
.slide-dots { display:flex; gap:5px; flex-wrap:wrap; justify-content:center; padding:4px 0; }
.slide-dot { width:8px; height:8px; border-radius:100px; background:var(--gray); transition:all .2s; flex-shrink:0; }
.slide-dot.active { background:var(--orange); width:24px; }
.slide-dot.past { background:var(--navy); opacity:.4; }
.slide-nav { display:flex; gap:12px; }
.slide-btn-back { flex:1; padding:14px; font-family:var(--font-d); font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.04em; border:2px solid var(--gray); border-radius:var(--r-md); background:var(--white); color:var(--muted); cursor:pointer; transition:all .2s; }
.slide-btn-back:hover:not([disabled]) { border-color:var(--navy); color:var(--navy); }
.slide-btn-back:disabled { opacity:.3; cursor:not-allowed; }
.slide-btn-next { flex:2; padding:14px; font-family:var(--font-d); font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.04em; border:2px solid var(--navy); border-radius:var(--r-md); background:var(--navy); color:var(--white); cursor:pointer; transition:all .2s; }
.slide-btn-next.primary { background:var(--orange); border-color:var(--orange); box-shadow:0 4px 16px rgba(232,99,10,.3); }
.slide-btn-next:hover { opacity:.9; transform:translateY(-1px); }

/* ── MODULE QUIZ ── */
.module-quiz-section { display:flex; flex-direction:column; gap:24px; }
.module-quiz-header { background:linear-gradient(135deg,var(--navy),var(--blue)); border-radius:var(--r-lg); padding:24px 28px; }
.module-quiz-title { font-family:var(--font-d); font-weight:900; font-size:26px; color:var(--white); text-transform:uppercase; margin-bottom:6px; }
.module-quiz-sub { font-size:14px; color:rgba(255,255,255,.6); }
.module-quiz-q { display:flex; flex-direction:column; gap:12px; background:var(--white); border-radius:var(--r-lg); padding:24px; border:1px solid var(--gray); box-shadow:var(--shadow-sm); }
.module-quiz-num { font-family:var(--font-d); font-weight:900; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--orange); }

/* ── MODULE ROW PROGRESS ── */
.module-row-right { display:flex; flex-direction:column; align-items:flex-end; gap:4px; flex-shrink:0; }
.module-row-count { font-family:var(--font-d); font-weight:700; font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; }
.module-row-progress-wrap { width:80px; height:5px; background:var(--gray); border-radius:100px; overflow:hidden; }
.module-row-progress-fill { height:100%; background:var(--orange); border-radius:100px; transition:width .4s ease; }
.module-row-pct { font-family:var(--font-d); font-weight:700; font-size:11px; color:var(--muted); }

/* ── LESSON PAGE HEADER / BASE ── */
.lesson-module-label { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--orange); margin-bottom:4px; }
.lesson-title { font-family:var(--font-d); font-weight:900; font-size:clamp(20px,3vw,28px); color:var(--white); text-transform:uppercase; line-height:1.1; margin-bottom:10px; }
.lesson-progress-row { display:flex; align-items:center; gap:10px; }
.lesson-progress-bar { flex:1; height:3px; background:rgba(255,255,255,.15); border-radius:100px; overflow:hidden; max-width:180px; }
.lesson-progress-fill { height:100%; background:var(--orange); border-radius:100px; transition:width .4s ease; }
.lesson-progress-label { font-size:11px; color:rgba(255,255,255,.5); font-family:var(--font-d); font-weight:700; text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; }
.lesson-advance-btn { width:100%; justify-content:center; font-size:16px; padding:16px; }
.lesson-quiz-opt { display:flex; align-items:flex-start; gap:14px; padding:14px 18px; border-radius:var(--r-md); border:2px solid var(--gray); cursor:pointer; background:var(--white); text-align:left; font-size:15px; color:var(--text); transition:all .2s; width:100%; font-family:var(--font-b); }
.lesson-quiz-opt:hover:not([disabled]) { border-color:var(--navy); background:var(--off); }
.lesson-quiz-opt.correct { border-color:var(--green); background:#F0FDF4; }
.lesson-quiz-opt.wrong { border-color:#EF4444; background:#FEF2F2; }
.lesson-opt-letter { font-family:var(--font-d); font-weight:900; font-size:16px; color:var(--muted); flex-shrink:0; width:20px; margin-top:1px; }
.lesson-quiz-q { font-size:18px; font-weight:600; color:var(--text); line-height:1.5; }
.lesson-quiz-opts { display:flex; flex-direction:column; gap:10px; }
.lesson-quiz-result { padding:14px 18px; border-radius:var(--r-md); font-size:14px; line-height:1.6; display:none; }
.lesson-quiz-result.show { display:block; }
.lesson-quiz-result.correct { background:#F0FDF4; border:2px solid #BBF7D0; color:#15803D; }
.lesson-quiz-result.wrong { background:#FEF2F2; border:2px solid #FECACA; color:#B91C1C; }
.lesson-complete-section { text-align:center; padding:40px 0; display:flex; flex-direction:column; align-items:center; gap:16px; }
.lesson-complete-icon { font-size:64px; }
.lesson-complete-title { font-family:var(--font-d); font-weight:900; font-size:40px; color:var(--navy); text-transform:uppercase; }
.lesson-complete-sub { font-size:16px; color:var(--muted); }
.lesson-module-complete-badge { background:linear-gradient(135deg,var(--orange),#B84E08); color:var(--white); font-family:var(--font-d); font-weight:800; font-size:15px; text-transform:uppercase; padding:10px 22px; border-radius:100px; }


.module-row-locked { opacity:.55; cursor:not-allowed; }
.module-row-preview { border-left:3px solid var(--orange); }


/* ── LESSON INTRO CARD ── */
.lesson-intro-card { background:var(--white); border-radius:var(--r-xl); padding:40px 36px; box-shadow:var(--shadow-md); border:1px solid var(--gray); display:flex; flex-direction:column; gap:16px; }
.lesson-intro-eyebrow { font-family:var(--font-d); font-weight:800; font-size:12px; letter-spacing:.12em; text-transform:uppercase; }
.lesson-intro-title { font-family:var(--font-d); font-weight:900; font-size:clamp(26px,4vw,38px); color:var(--navy); text-transform:uppercase; line-height:1.1; }
.lesson-intro-slides { font-size:14px; color:var(--muted); font-family:var(--font-d); font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.lesson-intro-previews { display:flex; flex-direction:column; gap:8px; border-top:1px solid var(--gray); padding-top:16px; }
.lesson-intro-preview-item { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--muted); }
.lesson-intro-preview-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ── ENHANCED SLIDE LESSON BANNER ── */
.slide-lesson-banner { display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--white); border-radius:var(--r-md); padding:10px 16px; border:1px solid var(--gray); }
.slide-lesson-banner-left { display:flex; align-items:center; gap:10px; min-width:0; }
.slide-lesson-chip { font-family:var(--font-d); font-weight:800; font-size:11px; letter-spacing:.08em; text-transform:uppercase; background:var(--navy); color:var(--white); padding:4px 10px; border-radius:100px; white-space:nowrap; flex-shrink:0; }
.slide-lesson-name { font-family:var(--font-d); font-weight:700; font-size:13px; color:var(--navy); text-transform:uppercase; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.slide-lesson-pos { font-family:var(--font-d); font-weight:700; font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; flex-shrink:0; }

/* ── DOT SEPARATOR ── */
.slide-dot-sep { width:1px; height:12px; background:var(--gray); border-radius:1px; margin:0 4px; display:inline-block; vertical-align:middle; }


.nav-auth-btns { display:flex; gap:8px; align-items:center; }
.nav-login-btn { font-size:14px !important; padding:9px 18px !important; border-color:rgba(255,255,255,.35) !important; }
.nav-login-btn:hover { border-color:var(--white) !important; background:rgba(255,255,255,.1) !important; }
.nav-signup-btn { font-size:14px !important; padding:9px 18px !important; }
@media(max-width:900px) { .nav-auth-btns { display:none; } }

.locked-badge { font-family:var(--font-d); font-weight:700; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); background:var(--off); padding:4px 10px; border-radius:100px; border:1px solid var(--gray); }


/* ═══════════════════════════════════════
   HOMEPAGE SPECIFIC
═══════════════════════════════════════ */
.home-hero { min-height:100vh; background:var(--navy-950); display:grid; grid-template-columns:1fr 1fr; overflow:hidden; position:relative; padding-top:68px; }
.home-hero-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px); background-size:60px 60px; pointer-events:none; }
.home-hero-glow { position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(232,99,10,.08),transparent 70%); top:50%; left:20%; transform:translate(-50%,-50%); pointer-events:none; }
.home-hero-inner { display:contents; }
.home-hero-left { padding:60px var(--gutter) 60px; display:flex; flex-direction:column; justify-content:center; position:relative; z-index:1; }
.home-hero-eyebrow { display:flex; align-items:center; gap:8px; margin-bottom:24px; }
.home-hero-dot { width:6px; height:6px; border-radius:50%; background:var(--orange-500); animation:pulse 2s infinite; }
.home-hero-eyebrow-text { font-family:var(--font-m); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--orange-300); }
.home-hero-headline { font-family:var(--font-d); font-size:clamp(64px,8vw,120px); line-height:.9; letter-spacing:.02em; color:white; margin-bottom:20px; }
.home-hero-accent { color:var(--orange-500); display:block; }
.home-hero-ghost { -webkit-text-stroke:2px rgba(255,255,255,.2); color:transparent; display:block; }
.home-hero-sub { font-size:17px; font-weight:300; color:rgba(255,255,255,.5); max-width:440px; line-height:1.75; margin-bottom:36px; }
.home-hero-ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:48px; }
.btn-home-primary { padding:15px 32px; background:var(--orange-500); color:white; font-family:var(--font-m); font-size:13px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; border:none; border-radius:8px; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all .2s; }
.btn-home-primary:hover { background:var(--orange-400); transform:translateY(-2px); }
.btn-home-secondary { padding:15px 32px; background:rgba(255,255,255,.06); color:rgba(255,255,255,.75); font-family:var(--font-m); font-size:13px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; border:1px solid rgba(255,255,255,.12); border-radius:8px; cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; transition:all .2s; }
.btn-home-secondary:hover { background:rgba(255,255,255,.1); }
.home-hero-stats { display:flex; gap:36px; padding-top:36px; border-top:1px solid rgba(255,255,255,.07); flex-wrap:wrap; }
.home-stat-num { font-family:var(--font-d); font-size:36px; color:var(--orange-500); line-height:1; letter-spacing:.04em; }
.home-stat-label { font-family:var(--font-m); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-top:3px; }
.home-hero-right { position:relative; display:flex; flex-direction:column; justify-content:center; align-items:center; padding:80px 32px 40px; gap:14px; z-index:1; }
.home-hero-right-bg { position:absolute; inset:0; background:linear-gradient(135deg,#0D1A3E,#132252,#1A2D6B); }
.home-hero-right-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px); background-size:48px 48px; }
.home-hero-right-glow { position:absolute; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(232,99,10,.1),transparent 70%); top:50%; left:50%; transform:translate(-50%,-50%); }
.home-iq-card { width:100%; max-width:320px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09); border-radius:16px; padding:22px; position:relative; z-index:1; }
.home-iq-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.home-iq-label { font-family:var(--font-m); font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.35); }
.home-iq-badge { font-family:var(--font-m); font-size:9px; letter-spacing:.08em; text-transform:uppercase; color:var(--orange-300); background:rgba(232,99,10,.15); border:1px solid rgba(232,99,10,.3); border-radius:100px; padding:3px 10px; }
.home-iq-score-row { display:flex; align-items:flex-end; gap:12px; margin-bottom:16px; }
.home-iq-num { font-family:var(--font-d); font-size:72px; color:var(--orange-500); line-height:1; letter-spacing:.04em; }
.home-iq-title { font-family:var(--font-d); font-size:20px; color:white; line-height:1.1; letter-spacing:.04em; }
.home-iq-sub { font-size:11px; color:rgba(255,255,255,.3); margin-top:4px; }
.home-iq-bars { display:flex; flex-direction:column; gap:7px; }
.home-iq-bar-row { display:flex; align-items:center; gap:8px; }
.home-iq-bar-label { font-size:11px; color:rgba(255,255,255,.45); width:90px; flex-shrink:0; }
.home-iq-bar-track { flex:1; height:4px; background:rgba(255,255,255,.08); border-radius:100px; overflow:hidden; }
.home-iq-bar-fill { height:100%; background:var(--orange-500); border-radius:100px; }
.home-iq-bar-val { font-family:var(--font-m); font-size:11px; color:var(--orange-300); width:26px; text-align:right; }
.home-pill-row { display:flex; gap:10px; width:100%; max-width:320px; position:relative; z-index:1; }
.home-pill { flex:1; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:10px; padding:12px 14px; }
.home-pill-val { font-family:var(--font-d); font-size:22px; color:white; line-height:1; }
.home-pill-label { font-family:var(--font-m); font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-top:3px; }

/* Ticker */
.ticker { background:var(--orange-500); overflow:hidden; padding:12px 0; }
.ticker-track { display:flex; animation:ticker 22s linear infinite; white-space:nowrap; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item { display:inline-flex; align-items:center; gap:16px; padding:0 24px; font-family:var(--font-d); font-size:14px; letter-spacing:.15em; color:white; }
.ticker-dot { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,.5); flex-shrink:0; }

/* Concept section */
.home-concept { padding:100px 0; background:white; }
.home-concept-inner { max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter); display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.section-eyebrow { display:flex; align-items:center; gap:10px; font-family:var(--font-m); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--orange-500); margin-bottom:16px; }
.section-eyebrow::before { content:''; display:block; width:20px; height:2px; background:var(--orange-500); flex-shrink:0; }
.section-title { font-family:var(--font-d); font-size:clamp(36px,5vw,60px); line-height:.95; letter-spacing:.03em; color:var(--navy-900); margin-bottom:20px; }
.section-body { font-size:16px; font-weight:300; color:var(--grey-700); line-height:1.8; margin-bottom:14px; }
.section-body strong { color:var(--navy-900); font-weight:600; }
.text-orange { color:var(--orange-500); }
.home-pillars { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.home-pillar { background:var(--grey-50); border:0.5px solid var(--grey-200); border-radius:14px; padding:20px 16px; border-left:3px solid var(--orange-500); transition:transform .2s; }
.home-pillar:hover { transform:translateY(-3px); }
.home-pillar.featured { grid-column:span 2; background:var(--navy-900); border-left:3px solid var(--orange-500); }
.home-pillar-num { font-family:var(--font-d); font-size:36px; color:var(--grey-200); line-height:1; margin-bottom:8px; }
.home-pillar.featured .home-pillar-num { color:rgba(255,255,255,.07); }
.home-pillar-name { font-family:var(--font-m); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--navy-900); margin-bottom:4px; }
.home-pillar.featured .home-pillar-name { color:white; }
.home-pillar-desc { font-size:12px; color:var(--grey-500); line-height:1.5; }
.home-pillar.featured .home-pillar-desc { color:rgba(255,255,255,.4); }

/* Loop section */
.home-loop { background:var(--navy-950); padding:100px 0; position:relative; overflow:hidden; }
.home-loop-grid { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px); background-size:80px 80px; }
.home-loop-inner { max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter); position:relative; z-index:1; }
.home-loop-header { text-align:center; margin-bottom:72px; }
.home-loop-sub { font-size:16px; font-weight:300; color:rgba(255,255,255,.4); max-width:480px; margin:12px auto 0; line-height:1.7; }
.home-loop-steps { display:grid; grid-template-columns:1fr 40px 1fr 40px 1fr; align-items:start; }
.home-loop-step { text-align:center; padding:0 16px; }
.home-step-num { font-family:var(--font-d); font-size:48px; color:rgba(255,255,255,.05); line-height:1; margin-bottom:12px; }
.home-step-icon { width:64px; height:64px; border-radius:14px; margin:0 auto 20px; display:flex; align-items:center; justify-content:center; }
.home-step-icon.orange { background:var(--orange-500); }
.home-step-icon.navy { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); }
.home-step-icon.green { background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.25); }
.home-step-title { font-family:var(--font-d); font-size:20px; letter-spacing:.06em; color:white; margin-bottom:10px; }
.home-step-body { font-size:13px; color:rgba(255,255,255,.38); line-height:1.7; max-width:220px; margin:0 auto; }
.home-loop-arrow { padding-top:70px; color:rgba(255,255,255,.15); font-size:24px; text-align:center; }

/* Bento grid */
.home-bento { padding:100px var(--gutter); max-width:var(--max-w); margin:0 auto; }
.home-bento-header { margin-bottom:48px; }
.home-bento-grid { display:grid; grid-template-columns:2fr 1fr; gap:14px; }
.home-bcard { border-radius:20px; padding:32px 28px; position:relative; overflow:hidden; transition:transform .2s; }
.home-bcard:hover { transform:translateY(-4px); }
.home-bcard.dark { background:var(--navy-900); color:white; }
.home-bcard.orange { background:var(--orange-500); color:white; }
.home-bcard.full { grid-column:span 2; background:var(--navy-900); color:white; }
.home-bcard-tag { font-family:var(--font-m); font-size:9px; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:14px; }
.home-bcard-title { font-family:var(--font-d); font-size:clamp(24px,3vw,34px); letter-spacing:.04em; line-height:1; color:white; margin-bottom:14px; }
.home-bcard-body { font-size:14px; line-height:1.7; color:rgba(255,255,255,.55); font-weight:300; }
.home-bcard-checks { display:flex; flex-direction:column; gap:9px; margin-top:14px; }
.home-bcard-check { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:rgba(255,255,255,.6); }
.home-check-dot { width:16px; height:16px; border-radius:50%; background:rgba(232,99,10,.2); border:1px solid rgba(232,99,10,.35); flex-shrink:0; margin-top:2px; display:flex; align-items:center; justify-content:center; }
.home-check-dot::after { content:''; width:5px; height:3px; border-left:1.5px solid var(--orange-400); border-bottom:1.5px solid var(--orange-400); transform:rotate(-45deg) translateY(-1px); }
.home-bcard-link { display:inline-flex; align-items:center; gap:6px; font-family:var(--font-m); font-size:11px; letter-spacing:.1em; text-transform:uppercase; margin-top:22px; color:var(--orange-300); text-decoration:none; transition:gap .2s; }
.home-bcard.orange .home-bcard-link { color:rgba(255,255,255,.8); }
.home-bcard-link:hover { gap:10px; }
.home-bcard-bgnum { position:absolute; right:-10px; bottom:-16px; font-family:var(--font-d); font-size:140px; color:rgba(255,255,255,.04); pointer-events:none; letter-spacing:-.04em; }
.home-bcard-full-inner { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.home-levels-bar { display:flex; gap:10px; flex:1; min-width:280px; }
.home-level { flex:1; padding:14px 12px; border-radius:10px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); opacity:.5; }
.home-level.active { background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.14); opacity:1; }
.home-level-num { font-family:var(--font-d); font-size:24px; color:var(--orange-500); line-height:1; }
.home-level:not(.active) .home-level-num { color:rgba(255,255,255,.2); }
.home-level-name { font-family:var(--font-m); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-top:4px; }
.home-level-badge { display:inline-block; margin-top:6px; font-family:var(--font-m); font-size:8px; letter-spacing:.1em; text-transform:uppercase; padding:2px 8px; border-radius:100px; }
.home-level-badge.live { background:rgba(34,197,94,.18); color:#22C55E; border:1px solid rgba(34,197,94,.3); }
.home-level-badge.soon,.home-level-badge.future { background:rgba(255,255,255,.05); color:rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.08); }

/* CTA section */
.home-cta-section { padding:0 var(--gutter) 100px; max-width:calc(var(--max-w) + var(--gutter) * 2); margin:0 auto; }
.home-cta-box { background:var(--navy-900); border-radius:24px; padding:64px 56px; display:grid; grid-template-columns:1fr auto; gap:40px; align-items:center; position:relative; overflow:hidden; }
.home-cta-glow { position:absolute; right:0; top:0; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(232,99,10,.1),transparent 70%); transform:translate(30%,-30%); pointer-events:none; }
.home-cta-tag { font-family:var(--font-m); font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--orange-300); margin-bottom:12px; }
.home-cta-title { font-family:var(--font-d); font-size:clamp(32px,4vw,52px); letter-spacing:.04em; color:white; line-height:.95; margin-bottom:12px; }
.home-cta-sub { font-size:15px; font-weight:300; color:rgba(255,255,255,.4); max-width:420px; line-height:1.7; }
.home-cta-right { display:flex; flex-direction:column; gap:10px; position:relative; z-index:1; flex-shrink:0; }
.home-cta-note { font-family:var(--font-m); font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.2); text-align:center; }

/* Footer */
.footer-inner { max-width:var(--max-w); margin:0 auto; padding:0 var(--gutter); display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
.footer-brand { max-width:260px; }
.footer-tagline { font-size:13px; color:rgba(255,255,255,.3); line-height:1.6; margin-top:10px; }
.footer-col ul li a { font-size:14px; }

/* GIQ page */
.giq-pillar-card { background:var(--grey-50); border:0.5px solid var(--grey-200); border-radius:14px; padding:20px 14px; border-top:3px solid var(--orange-500); }
.giq-pillar-num { font-family:var(--font-d); font-size:32px; color:var(--grey-200); line-height:1; margin-bottom:8px; }
.giq-pillar-name { font-family:var(--font-m); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--navy-900); margin-bottom:4px; font-weight:600; }
.giq-pillar-desc { font-size:11px; color:var(--grey-500); line-height:1.5; }

/* Tag variants */
.tag-orange { background:rgba(232,99,10,.12); color:var(--orange-600); border:1px solid rgba(232,99,10,.25); }
.tag-white { background:rgba(255,255,255,.15); color:white; border:1px solid rgba(255,255,255,.2); }

/* Mobile menu */
.mobile-menu { display:none; position:fixed; top:68px; left:0; right:0; background:var(--navy-950); border-bottom:1px solid rgba(255,255,255,.08); z-index:99; flex-direction:column; padding:8px 0 16px; }
.mobile-menu.open { display:flex; }
.mobile-menu-item { padding:14px 24px; font-family:var(--font-m); font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.6); text-decoration:none; transition:color .15s; }
.mobile-menu-item:hover { color:white; }
.mobile-menu-divider { height:1px; background:rgba(255,255,255,.06); margin:8px 0; }

/* Responsive for homepage */
@media(max-width:899px) {
  .home-hero { grid-template-columns:1fr; padding-top:68px; }
  .home-hero-right { display:none; }
  .home-hero-left { padding:48px 20px 48px; }
  .home-hero-headline { font-size:clamp(56px,13vw,88px); }
  .home-concept-inner { grid-template-columns:1fr; gap:40px; padding:0 20px; }
  .home-concept { padding:60px 0; }
  .home-pillars { grid-template-columns:1fr; }
  .home-pillar.featured { grid-column:span 1; }
  .home-loop-steps { grid-template-columns:1fr; gap:0; }
  .home-loop-arrow { display:none; }
  .home-loop-step { display:flex; align-items:flex-start; gap:16px; text-align:left; padding:20px 0; border-bottom:1px solid rgba(255,255,255,.06); }
  .home-loop-step:last-child { border-bottom:none; }
  .home-step-icon { margin:0; flex-shrink:0; }
  .home-step-num { display:none; }
  .home-step-body { margin:0; text-align:left; }
  .home-bento { padding:60px 20px; }
  .home-bento-grid { grid-template-columns:1fr; }
  .home-bcard.full { grid-column:span 1; }
  .home-bcard-full-inner { flex-direction:column; }
  .home-cta-section { padding:0 16px 60px; }
  .home-cta-box { grid-template-columns:1fr; padding:40px 28px; }
  .home-cta-right { flex-direction:row; flex-wrap:wrap; }
  .home-hero-stats { gap:20px; }
  .giq-pillar-card { padding:16px 12px; }
}
@media(max-width:600px) {
  .home-bento-grid { grid-template-columns:1fr; }
  .home-levels-bar { flex-direction:column; min-width:0; }
  nav .nav-links, nav .nav-auth-btns, nav .nav-cta { display:none; }
  .hamburger { display:flex; }
  .home-cta-right { flex-direction:column; }
  .steps-grid { grid-template-columns:1fr 1fr; }
}

/* ── PROGRAM PAGE MODULE ROWS ── */
.prog-module-row { display:flex; align-items:flex-start; gap:20px; background:var(--white); border:1px solid var(--gray); border-radius:var(--r-lg); padding:24px 28px; transition:border-color .2s; border-left:4px solid var(--orange); }
.prog-module-num { font-family:var(--font-d); font-size:36px; color:var(--orange); line-height:1; width:40px; flex-shrink:0; letter-spacing:.04em; }
.prog-module-body { flex:1; min-width:0; }
.prog-module-name { font-family:var(--font-d); font-size:22px; color:var(--navy); letter-spacing:.04em; margin-bottom:4px; text-transform:uppercase; }
.prog-module-desc { font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:12px; }
.prog-module-lessons { display:flex; flex-wrap:wrap; gap:6px; }
.prog-lesson-pill { font-family:var(--font-m); font-size:11px; letter-spacing:.04em; color:var(--navy); background:var(--off); border:1px solid var(--gray); border-radius:100px; padding:4px 12px; }
.prog-module-meta { flex-shrink:0; text-align:right; }
.prog-module-count { font-family:var(--font-m); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--navy); }
.prog-module-slides { font-family:var(--font-m); font-size:11px; color:var(--muted); margin-top:3px; }

@media(max-width:600px) {
  .prog-module-row { flex-direction:column; gap:12px; padding:18px 16px; }
  .prog-module-meta { text-align:left; }
  .prog-module-num { font-size:28px; }
}

/* ── HOME PILLAR CARDS — improved ── */
.home-pillar-icon-wrap { margin-bottom: 16px; }
.home-pillar-label { font-family: var(--font-d); font-size: 48px; color: rgba(255,255,255,.07); line-height: 1; margin-bottom: 10px; }
.home-pillar:not(.featured) .home-pillar-label { color: var(--grey-200); }
.home-pillar-name { font-family: var(--font-m); font-size: 12px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 8px; }
.home-pillar:not(.featured) .home-pillar-name { color: var(--navy-800); }
.home-pillar.featured .home-pillar-name { color: white; }
.home-pillar-desc { font-size: 13px; line-height: 1.65; }
.home-pillar:not(.featured) .home-pillar-desc { color: var(--grey-500); }
.home-pillar.featured .home-pillar-desc { color: rgba(255,255,255,.45); }

/* ── GIQ PILLAR CARDS — improved ── */
.giq-pillars-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.giq-pillar-card {
  background: var(--white);
  border: 1px solid var(--grey-200);
  border-top: 3px solid var(--orange-500);
  border-radius: 14px;
  padding: 22px 18px;
  transition: transform .2s, box-shadow .2s;
}
.giq-pillar-card:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(10,26,62,.1); }
.giq-pillar-icon { margin-bottom: 14px; }
.giq-pillar-num { font-family: var(--font-d); font-size: 32px; color: var(--grey-200); line-height: 1; margin-bottom: 8px; letter-spacing: .04em; }
.giq-pillar-name { font-family: var(--font-m); font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--navy-900); margin-bottom: 8px; }
.giq-pillar-desc { font-size: 13px; color: var(--grey-500); line-height: 1.6; }

@media(max-width: 768px) {
  .giq-pillars-grid { grid-template-columns: 1fr 1fr; }
  .giq-pillars-grid .giq-pillar-card:first-child { grid-column: span 2; }
}
@media(max-width: 480px) {
  .giq-pillars-grid { grid-template-columns: 1fr; }
  .giq-pillars-grid .giq-pillar-card:first-child { grid-column: span 1; }
}

/* ── COACHES BENEFIT CARDS — improved ── */
.coaches-benefits-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.coach-benefit-card {
  background: var(--white);
  border: 1px solid var(--grey-200);
  border-radius: var(--r-lg);
  padding: 28px 28px;
  transition: transform .2s, box-shadow .2s;
}
.coach-benefit-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(10,26,62,.08); }
.coach-benefit-icon {
  width: 48px;
  height: 48px;
  background: rgba(232,99,10,.08);
  border: 1px solid rgba(232,99,10,.2);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  flex-shrink: 0;
}
.coach-benefit-title { font-family: var(--font-d); font-size: 22px; color: var(--navy-900); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 10px; line-height: 1.1; }
.coach-benefit-desc { font-size: 14px; color: var(--grey-700); line-height: 1.75; }

@media(max-width: 600px) {
  .coaches-benefits-grid { grid-template-columns: 1fr; }
}

/* ── DASHBOARD HEADER — improved ── */
.dash-header {
  background: linear-gradient(135deg, var(--navy-900) 0%, var(--navy-700) 60%, var(--navy-600) 100%);
  padding: 44px 0 40px;
  position: relative;
  overflow: hidden;
}
.dash-header-coach {
  background: linear-gradient(135deg, #1a0a00 0%, #3d1a00 50%, #5c2800 100%);
}
.dash-header::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 100% at 100% 50%, rgba(232,99,10,.12), transparent);
  pointer-events: none;
}

/* Helmet decoration */
.dash-header-helmet {
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 260px;
  height: 240px;
  pointer-events: none;
  opacity: .6;
}
.dash-header-helmet svg { width: 100%; height: 100%; }

/* Field decoration */
.dash-header-field {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 320px;
  pointer-events: none;
}
.dash-header-field svg { width: 100%; height: 100%; }

.dash-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.dash-header-left { display: flex; flex-direction: column; gap: 6px; }
.dash-welcome-label {
  font-family: var(--font-m);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
}
.dash-welcome {
  font-family: var(--font-d);
  font-size: clamp(32px, 4vw, 48px);
  color: white;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1;
}
.dash-welcome span { color: var(--orange-400); }
.dash-header-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
}
.dash-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22C55E;
  flex-shrink: 0;
}
.dash-signout-btn {
  font-size: 12px !important;
  padding: 9px 18px !important;
  color: rgba(255,255,255,.5) !important;
  border-color: rgba(255,255,255,.15) !important;
  background: rgba(255,255,255,.05) !important;
  letter-spacing: .08em;
  white-space: nowrap;
}
.dash-signout-btn:hover {
  color: white !important;
  border-color: rgba(255,255,255,.4) !important;
  background: rgba(255,255,255,.1) !important;
}

/* Dashboard body */
.dash-body { padding: 36px 0 60px; }
.dash-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 20px;
  align-items: start;
}
.dash-card {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--grey-200);
  overflow: hidden;
}
.dash-card-label {
  font-family: var(--font-m);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--grey-500);
  padding: 18px 20px 0;
}

/* Progress card */
.dash-progress-bar-wrap {
  height: 8px;
  background: var(--grey-100);
  border-radius: 100px;
  overflow: hidden;
  margin: 10px 20px 0;
}
.dash-progress-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--orange-600), var(--orange-400));
  border-radius: 100px;
  transition: width .6s ease;
}

/* Next Up card */
.dash-next-card {
  background: var(--navy-900);
  border-radius: var(--r-lg);
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  cursor: pointer;
  transition: all .2s;
  border: 1px solid rgba(255,255,255,.06);
}
.dash-next-card:hover { background: var(--navy-700); transform: translateY(-2px); }
.dash-next-inner { display: flex; align-items: center; gap: 16px; }
.dash-next-icon-wrap {
  width: 44px;
  height: 44px;
  background: var(--orange-500);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(232,99,10,.35);
}
.dash-next-label {
  font-family: var(--font-m);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 4px;
}
.dash-next-title {
  font-family: var(--font-d);
  font-size: 20px;
  color: white;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.dash-next-arrow {
  font-size: 20px;
  color: rgba(255,255,255,.3);
  flex-shrink: 0;
  transition: transform .2s;
}
.dash-next-card:hover .dash-next-arrow { transform: translateX(4px); color: var(--orange-400); }

/* Module progress list */
.mod-prog-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 20px;
  border-bottom: 1px solid var(--grey-100);
  transition: background .15s;
}
.mod-prog-item:last-child { border-bottom: none; }
.mod-prog-item:hover { background: var(--grey-50); }
.mod-prog-num {
  width: 28px;
  height: 28px;
  background: var(--navy-900);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-d);
  font-size: 14px;
  color: white;
  flex-shrink: 0;
}
.mod-prog-name {
  flex: 1;
  font-size: 14px;
  color: var(--navy-900);
  font-weight: 500;
}
.mod-prog-bar-wrap {
  width: 80px;
  height: 5px;
  background: var(--grey-100);
  border-radius: 100px;
  overflow: hidden;
  flex-shrink: 0;
}
.mod-prog-fill {
  height: 100%;
  background: var(--orange-500);
  border-radius: 100px;
  transition: width .5s ease;
}
.mod-prog-pct {
  font-family: var(--font-m);
  font-size: 11px;
  color: var(--grey-500);
  width: 32px;
  text-align: right;
  flex-shrink: 0;
}

/* Coach ref box */
.coach-ref-box {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--grey-50);
  border: 1px solid var(--grey-200);
  border-radius: 10px;
  padding: 14px 16px;
}

/* Streak days */
.streak-day {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-m);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
}
.streak-day.today { background: var(--orange-500); color: white; }
.streak-day.off { background: var(--grey-100); color: var(--grey-500); border: 1px solid var(--grey-200); }

/* Responsive */
@media(max-width: 768px) {
  .dash-grid { grid-template-columns: 1fr; }
  .dash-header-helmet { width: 160px; right: -10px; opacity: .35; }
  .dash-header-field { width: 200px; }
}

.logo { line-height: 0; }
.logo img { display: block; }

/* ═══════════════════════════════════════
   MOBILE FIXES
═══════════════════════════════════════ */

/* Footer — fix logo text overlap on mobile */
@media(max-width: 768px) {
  footer { padding: 40px 0 24px; }

  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 20px;
    gap: 32px;
  }

  .footer-brand { width: 100%; }

  /* Logo in footer — img only, no text overflow */
  .footer-brand .logo {
    font-size: 0; /* hide any leftover text nodes */
    gap: 0;
    margin-bottom: 12px;
  }
  .footer-brand .logo img {
    height: 44px;
  }

  .footer-links {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px 16px;
  }

  .footer-col { min-width: 0; }
  .footer-col ul li a { font-size: 13px; }

  .footer-bottom {
    flex-direction: column;
    gap: 8px;
    text-align: center;
    padding: 16px 20px;
  }
}

/* Program page — level cards stack vertically on mobile */
@media(max-width: 640px) {
  /* Override the inline repeat(3,1fr) grid */
  div[style*="repeat(3,1fr)"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    max-width: 100% !important;
  }
}

/* Home bento levels bar — stack on mobile */
@media(max-width: 500px) {
  .home-levels-bar {
    flex-direction: column;
    gap: 8px;
  }
  .home-level {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
  }
  .home-level-num { font-size: 20px; margin-bottom: 0; }
}

/* Nav logo on mobile — proper sizing */
@media(max-width: 768px) {
  .nav-inner { padding: 0 16px; height: 68px; }
  .nav-inner .logo img { height: 48px; }

  /* Hamburger visible */
  .hamburger { display: flex; }

  /* Hide desktop nav items */
  .nav-links, .nav-auth-btns, .nav-cta { display: none !important; }
}

/* General mobile padding */
@media(max-width: 480px) {
  .container { padding: 0 16px; }

  .home-hero-left { padding: 40px 16px; }
  .home-hero-headline { font-size: clamp(48px, 12vw, 72px); }
  .home-hero-sub { font-size: 15px; }
  .home-hero-ctas { flex-direction: column; }
  .btn-home-primary, .btn-home-secondary { width: 100%; justify-content: center; text-align: center; }

  .home-bento { padding: 48px 16px; }
  .home-cta-box { padding: 32px 20px; }

  .section-title { font-size: clamp(28px, 8vw, 44px); }

  /* Program page module rows */
  .prog-module-lessons { display: none; } /* hide lesson pills on very small screens */

  /* Auth page */
  .auth-right { padding: 32px 16px 48px; }

  /* Dashboard */
  .dash-header { padding: 32px 0 28px; }
  .dash-welcome { font-size: 28px; }
  .dash-header-helmet { display: none; }
  .dash-body { padding: 24px 0 48px; }
  .dash-grid { grid-template-columns: 1fr; gap: 14px; }
}

/* Program page level cards — stack on mobile */
@media(max-width: 640px) {
  .level-cards-grid {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }
}

/* ═══════════════════════════════════════
   PLAYER DASHBOARD — REDESIGN
═══════════════════════════════════════ */

.dash-body { padding: 32px 0 64px; }

/* Top row layout */
.pdb-top-row {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
  margin-bottom: 24px;
  align-items: start;
}

/* Section label */
.pdb-section-label {
  font-family: var(--font-m);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--grey-400);
  margin-bottom: 4px;
}

/* Progress card */
.pdb-progress-card {
  background: white;
  border-radius: 20px;
  padding: 28px 32px;
  border: 1px solid var(--grey-100);
  box-shadow: 0 2px 12px rgba(10,26,62,.04);
}
.pdb-progress-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 16px;
}
.pdb-prog-fraction {
  font-family: var(--font-d);
  font-size: 52px;
  color: var(--navy-900);
  letter-spacing: .04em;
  line-height: 1;
}
.pdb-prog-fraction::after {
  content: ' modules';
  font-size: 16px;
  color: var(--grey-400);
  font-family: var(--font-m);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.pdb-prog-track {
  height: 6px;
  background: var(--grey-100);
  border-radius: 100px;
  overflow: hidden;
  margin-bottom: 12px;
}
.pdb-prog-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--orange-600), var(--orange-400));
  border-radius: 100px;
  transition: width .8s cubic-bezier(.4,0,.2,1);
}
.pdb-prog-pillars {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
}
.pdb-pillar-dot {
  flex: 1;
  height: 4px;
  border-radius: 100px;
  background: var(--grey-100);
  transition: background .4s ease;
}
.pdb-pillar-dot.done { background: var(--orange-500); }
.pdb-pillar-dot.active { background: var(--orange-300); }
.pdb-prog-note {
  font-size: 13px;
  color: var(--grey-400);
  font-style: italic;
}

/* Right column */
.pdb-right-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Next Up card */
.pdb-next-card {
  background: var(--navy-900);
  border-radius: 16px;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  cursor: pointer;
  transition: background .2s, transform .2s;
  border: 1px solid rgba(255,255,255,.06);
}
.pdb-next-card:hover { background: #0d1f4a; transform: translateY(-2px); }
.pdb-next-left { display: flex; align-items: center; gap: 14px; }
.pdb-next-icon {
  width: 40px;
  height: 40px;
  background: var(--orange-500);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(232,99,10,.35);
}
.pdb-next-title {
  font-family: var(--font-d);
  font-size: 17px;
  color: white;
  letter-spacing: .04em;
  text-transform: uppercase;
  line-height: 1.2;
}
.pdb-next-arrow { flex-shrink: 0; transition: transform .2s; }
.pdb-next-card:hover .pdb-next-arrow { transform: translateX(4px); }

/* This Week card */
.pdb-week-card {
  background: white;
  border-radius: 16px;
  padding: 20px 22px;
  border: 1px solid var(--grey-100);
  box-shadow: 0 2px 12px rgba(10,26,62,.04);
}
.pdb-week-days {
  display: flex;
  gap: 6px;
}
.pdb-day {
  flex: 1;
  aspect-ratio: 1;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-m);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  transition: all .2s;
}
.pdb-day.today {
  background: var(--orange-500);
  color: white;
  box-shadow: 0 3px 10px rgba(232,99,10,.3);
}
.pdb-day.off {
  background: var(--grey-50);
  color: var(--grey-400);
  border: 1px solid var(--grey-100);
}

/* Module list section */
.pdb-modules-section {
  background: white;
  border-radius: 20px;
  border: 1px solid var(--grey-100);
  box-shadow: 0 2px 12px rgba(10,26,62,.04);
  overflow: hidden;
}
.pdb-modules-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 24px 28px 20px;
  border-bottom: 1px solid var(--grey-100);
}
.pdb-modules-title {
  font-family: var(--font-d);
  font-size: 22px;
  color: var(--navy-900);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.pdb-modules-sub {
  font-family: var(--font-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--grey-400);
}
.pdb-module-list { display: flex; flex-direction: column; }

/* Module row */
.pdb-mod-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 28px;
  border-bottom: 1px solid var(--grey-50);
  cursor: pointer;
  transition: background .15s;
  text-decoration: none;
}
.pdb-mod-row:last-child { border-bottom: none; }
.pdb-mod-row:hover { background: #FAFBFF; }
.pdb-mod-num {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-d);
  font-size: 16px;
  letter-spacing: .04em;
  flex-shrink: 0;
  transition: all .2s;
}
.pdb-mod-num.done { background: var(--orange-500); color: white; }
.pdb-mod-num.next { background: var(--navy-900); color: white; }
.pdb-mod-num.locked { background: var(--grey-100); color: var(--grey-400); }
.pdb-mod-name {
  flex: 1;
  font-size: 15px;
  color: var(--navy-900);
  font-weight: 500;
  min-width: 0;
}
.pdb-mod-name.locked { color: var(--grey-400); }
.pdb-mod-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.pdb-mod-bar-track {
  width: 72px;
  height: 4px;
  background: var(--grey-100);
  border-radius: 100px;
  overflow: hidden;
}
.pdb-mod-bar-fill {
  height: 100%;
  background: var(--orange-500);
  border-radius: 100px;
  transition: width .5s ease;
}
.pdb-mod-pct {
  font-family: var(--font-m);
  font-size: 12px;
  color: var(--grey-400);
  width: 32px;
  text-align: right;
}
.pdb-mod-pct.done { color: var(--orange-500); font-weight: 700; }
.pdb-mod-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(232,99,10,.1);
  border: 1.5px solid var(--orange-400);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pdb-mod-check svg { display: block; }

@media(max-width: 900px) {
  .pdb-top-row { grid-template-columns: 1fr; }
  .pdb-right-col { flex-direction: row; }
  .pdb-next-card { flex: 2; }
  .pdb-week-card { flex: 1; }
}
@media(max-width: 540px) {
  .pdb-right-col { flex-direction: column; }
  .pdb-progress-card { padding: 22px 20px; }
  .pdb-prog-fraction { font-size: 40px; }
  .pdb-mod-bar-track { display: none; }
  .pdb-modules-header { padding: 18px 20px 14px; }
  .pdb-mod-row { padding: 14px 20px; }
}

/* ── GRIDIRON IQ DASHBOARD CARD ── */
.giq-dash-card {
  background: var(--navy-900);
  border-radius: 20px;
  padding: 28px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
  flex-wrap: wrap;
}
.giq-dash-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 100% at 100% 50%, rgba(232,99,10,.1), transparent);
  pointer-events: none;
}
.giq-dash-left { position: relative; z-index: 1; }
.giq-dash-eyebrow {
  font-family: var(--font-m);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--orange-300);
  margin-bottom: 8px;
}
.giq-dash-score {
  font-family: var(--font-d);
  font-size: 64px;
  color: white;
  letter-spacing: .04em;
  line-height: .9;
  margin-bottom: 8px;
}
.giq-dash-score span.giq-dash-denom {
  font-size: 28px;
  color: rgba(255,255,255,.3);
}
.giq-dash-no-score {
  font-family: var(--font-m);
  font-size: 18px;
  color: rgba(255,255,255,.35);
  letter-spacing: .04em;
}
.giq-dash-meta {
  font-family: var(--font-m);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.35);
}
.giq-dash-tier {
  font-family: var(--font-d);
  font-size: 18px;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.giq-dash-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 16px;
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}
.giq-dash-pillars {
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-width: 200px;
}
.giq-dash-pillar-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.giq-dash-pillar-name {
  font-size: 11px;
  color: rgba(255,255,255,.45);
  width: 110px;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.giq-dash-pillar-track {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,.08);
  border-radius: 100px;
  overflow: hidden;
  min-width: 60px;
}
.giq-dash-pillar-fill {
  height: 100%;
  border-radius: 100px;
  transition: width .8s ease;
}
.giq-dash-pillar-pct {
  font-family: var(--font-m);
  font-size: 10px;
  color: rgba(255,255,255,.35);
  width: 28px;
  text-align: right;
  flex-shrink: 0;
}
.giq-dash-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 11px 22px;
  background: var(--orange-500);
  color: white;
  font-family: var(--font-m);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: 10px;
  text-decoration: none;
  transition: all .2s;
  white-space: nowrap;
}
.giq-dash-btn:hover { background: var(--orange-400); transform: translateY(-1px); }
.giq-dash-btn.retake { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); }
.giq-dash-btn.retake:hover { background: rgba(255,255,255,.14); }

@media(max-width: 600px) {
  .giq-dash-card { flex-direction: column; align-items: flex-start; padding: 22px 20px; }
  .giq-dash-right { align-items: flex-start; width: 100%; }
  .giq-dash-pillars { min-width: 0; width: 100%; }
  .giq-dash-score { font-size: 48px; }
}

/* ═══════════════════════════════════════════════
   DASHBOARD v2 — IQ-FIRST LAYOUT
═══════════════════════════════════════════════ */

/* ── Row 1: IQ + Right col ── */
.db-iq-row {
  display:grid;
  grid-template-columns:300px 1fr;
  gap:16px;
  margin-bottom:16px;
  align-items:start;
}

/* ── IQ Score Card ── */
.db-iq-card {
  background:var(--navy-900);
  border-radius:20px;
  padding:24px 26px 22px;
  border:1px solid rgba(255,255,255,.06);
  position:relative;
  overflow:hidden;
}
.db-iq-card::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 120% 80% at 80% 120%,rgba(232,99,10,.12),transparent);
  pointer-events:none;
}
.db-iq-top {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:16px;position:relative;z-index:1;
}
.db-iq-eyebrow {
  font-family:var(--font-m);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--orange-300);
}
.db-iq-live-dot {
  width:7px;height:7px;border-radius:50%;background:#22C55E;
  box-shadow:0 0 0 3px rgba(34,197,94,.2);
}

/* Empty state */
.db-iq-empty { text-align:center;padding:8px 0 16px;position:relative;z-index:1; }
.db-iq-empty-grade {
  font-family:var(--font-d);font-size:72px;color:rgba(255,255,255,.08);
  line-height:1;margin-bottom:8px;letter-spacing:.04em;
}
.db-iq-empty-text {
  font-size:13px;color:rgba(255,255,255,.3);line-height:1.5;
}

/* Score state */
.db-iq-score-state { text-align:center;padding:4px 0 12px;position:relative;z-index:1; }
.db-iq-grade {
  font-family:var(--font-d);font-size:72px;color:white;
  line-height:.9;letter-spacing:.02em;margin-bottom:4px;
}
.db-iq-tier {
  font-family:var(--font-d);font-size:14px;letter-spacing:.08em;
  text-transform:uppercase;margin-bottom:4px;
}
.db-iq-score-num {
  font-family:var(--font-m);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(255,255,255,.3);
}

/* Pillar mini bars */
.db-iq-pillars {
  display:flex;flex-direction:column;gap:6px;margin-bottom:16px;
  position:relative;z-index:1;
}
.db-iq-pillar-row { display:flex;align-items:center;gap:8px; }
.db-iq-pillar-name {
  font-size:10px;color:rgba(255,255,255,.35);
  width:72px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.db-iq-pillar-track {
  flex:1;height:3px;background:rgba(255,255,255,.08);border-radius:100px;overflow:hidden;
}
.db-iq-pillar-fill { height:100%;border-radius:100px;transition:width .8s ease; }
.db-iq-pillar-pct {
  font-family:var(--font-m);font-size:10px;color:rgba(255,255,255,.3);
  width:28px;text-align:right;flex-shrink:0;
}

/* IQ Actions */
.db-iq-actions {
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  position:relative;z-index:1;
}
.db-iq-btn {
  display:inline-flex;align-items:center;gap:6px;padding:10px 18px;
  background:var(--orange-500);color:white;
  font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;border-radius:10px;text-decoration:none;
  transition:all .2s;white-space:nowrap;
}
.db-iq-btn:hover { background:var(--orange-400);transform:translateY(-1px); }
.db-iq-quiz-count {
  font-family:var(--font-m);font-size:10px;letter-spacing:.06em;
  color:rgba(255,255,255,.25);text-align:right;line-height:1.4;
}

/* ── Right column ── */
.db-iq-right { display:flex;flex-direction:column;gap:12px; }

/* ── Recommendation Card ── */
.db-rec-card {
  background:white;border-radius:16px;padding:22px 22px 20px;
  border:1px solid var(--grey-100);
  border-left:4px solid var(--orange-500);
  box-shadow:0 2px 12px rgba(10,26,62,.04);
  flex:1;
}
.db-rec-eyebrow {
  font-family:var(--font-m);font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--orange-500);margin-bottom:8px;
}
.db-rec-title {
  font-family:var(--font-d);font-size:18px;color:var(--navy-900);
  letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px;line-height:1.1;
}
.db-rec-body {
  font-size:13px;color:var(--grey-500);line-height:1.6;margin-bottom:14px;
}
.db-rec-btn {
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--orange-500);text-decoration:none;
  transition:gap .2s;
}
.db-rec-btn:hover { gap:9px; }

/* ── Row 2: Progress row ── */
.db-progress-row {
  display:grid;
  grid-template-columns:1fr 260px;
  gap:16px;
  margin-bottom:16px;
  align-items:start;
}

/* ── Quiz History ── */
.db-history-section {
  background:white;border-radius:20px;border:1px solid var(--grey-100);
  box-shadow:0 2px 12px rgba(10,26,62,.04);overflow:hidden;margin-bottom:20px;
}
.db-history-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px 16px;border-bottom:1px solid var(--grey-100);
}
.db-history-title {
  font-family:var(--font-d);font-size:18px;color:var(--navy-900);
  letter-spacing:.04em;text-transform:uppercase;
}
.db-history-cta {
  font-family:var(--font-m);font-size:11px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--orange-500);text-decoration:none;
  transition:letter-spacing .2s;
}
.db-history-cta:hover { letter-spacing:.14em; }
.db-history-list { display:flex;flex-direction:column; }
.db-history-row {
  display:flex;align-items:center;gap:16px;
  padding:14px 24px;border-bottom:1px solid var(--grey-50);
}
.db-history-row:last-child { border-bottom:none; }
.db-history-grade {
  font-family:var(--font-d);font-size:28px;letter-spacing:.02em;
  color:var(--navy-900);width:44px;flex-shrink:0;text-align:center;
}
.db-history-info { flex:1;min-width:0; }
.db-history-tier {
  font-family:var(--font-m);font-size:12px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--navy-900);margin-bottom:2px;
}
.db-history-meta { font-size:12px;color:var(--grey-400); }
.db-history-score {
  font-family:var(--font-d);font-size:20px;color:var(--grey-300);
  letter-spacing:.04em;flex-shrink:0;
}
.db-history-score span { font-size:12px;color:var(--grey-300); }

/* ── Responsive ── */
@media(max-width:900px) {
  .db-iq-row { grid-template-columns:1fr; }
  .db-iq-card { display:grid;grid-template-columns:auto 1fr;gap:0 20px; }
  .db-iq-top { grid-column:span 2;margin-bottom:8px; }
  .db-iq-main { align-self:center; }
  .db-iq-pillars { display:none !important; }
  .db-iq-actions { grid-column:span 2; }
  .db-progress-row { grid-template-columns:1fr; }
}
@media(max-width:540px) {
  .db-iq-card { display:flex;flex-direction:column; }
  .db-iq-grade { font-size:56px; }
  .db-iq-empty-grade { font-size:56px; }
  .db-history-row { padding:12px 16px; }
  .db-history-header { padding:16px 16px 12px; }
}

/* ── PILLAR LINE CHART ── */
.pillar-chart-wrap {
  background:rgba(10,15,40,.6);
  border-radius:12px;
  padding:16px 12px 8px;
  margin-bottom:16px;
  border:1px solid rgba(255,255,255,.06);
}
.pillar-section-unlocked { }
.pillar-unlocked-head {
  font-family:var(--font-m);
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--grey-400);
  margin-bottom:14px;
}
.pillar-unlocked-body { display:flex;flex-direction:column;gap:8px; }
.pillar-row-full { display:flex;align-items:center;gap:12px; }
.pillar-name-full {
  font-size:11px;font-weight:600;
  width:80px;flex-shrink:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pillar-track-full {
  flex:1;height:5px;background:var(--grey-100);border-radius:100px;overflow:hidden;
}
.pillar-fill-full { height:100%;border-radius:100px;transition:width 1s ease; }
.pillar-pct-full {
  font-family:var(--font-m);font-size:11px;color:var(--grey-500);
  width:32px;text-align:right;flex-shrink:0;
}
