*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --ink:#0B1929; --ink-mid:#122236; --navy:#1A3A5C; --slate:#3E6185;
  --steel:#6B90AE; --cloud:#B8CDD9; --mist:#EDF2F7; --white:#FFFFFF;
  --accent:#2A7DE1; --accent-dk:#1C5CB5;
  --text-dark:#0B1929; --text-body:#3A4E62; --text-muted:#6B8499;
  --success:#16A34A; --success-lt:#DCFCE7; --fail:#DC2626; --fail-lt:#FEE2E2;
  --border:#D1DDE8;
}
html { scroll-behavior: smooth; }
body { font-family:'Inter',system-ui,sans-serif; background:var(--white); color:var(--text-dark); line-height:1.7; -webkit-font-smoothing:antialiased; }
.container { max-width:820px; margin:0 auto; padding:0 40px; }
@media(max-width:680px){ .container{padding:0 20px;} }

/* NAV */
nav { position:fixed; top:0; left:0; right:0; z-index:100; background:rgba(11,25,41,0.96); backdrop-filter:blur(12px); border-bottom:1px solid rgba(255,255,255,0.06); }
.nav-inner { max-width:1100px; margin:0 auto; padding:0 40px; height:60px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
@media(max-width:680px){ .nav-inner{padding:0 20px;} }
.logo { text-decoration:none; font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:22px; text-transform:uppercase; flex-shrink:0; }
.logo-scaff{color:var(--white);} .logo-skills{color:var(--accent);}
.scroll-bar-track { position:fixed; top:60px; left:0; right:0; height:3px; background:rgba(255,255,255,0.07); z-index:99; }
.scroll-bar-fill { height:100%; background:var(--accent); width:0%; transition:width 0.1s linear; }
.nav-back { color:var(--cloud); font-size:13px; font-weight:500; text-decoration:none; display:flex; align-items:center; gap:6px; transition:color 0.2s; }
.nav-back:hover{color:var(--white);}
.nav-module-label { color:var(--cloud); font-size:12px; font-weight:500; letter-spacing:0.3px; }
@media(max-width:480px){ .nav-module-label{display:none;} }

/* FREE BANNER */
.free-banner { background:rgba(42,125,225,0.12); border-bottom:1px solid rgba(42,125,225,0.2); padding:10px 40px; text-align:center; margin-top:63px; }
.free-banner p { color:var(--ink); font-size:13px; font-weight:500; }
.free-banner strong{color:var(--accent-dk);}

/* MODULE HEADER */
.module-header { background:linear-gradient(135deg,var(--ink) 0%,#0E2540 60%,var(--navy) 100%); padding:115px 0 44px; position:relative; overflow:hidden; }
.module-header::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(42,125,225,0.4),transparent); }
.module-eyebrow { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.mod-num-pill { background:rgba(42,125,225,0.18); border:1px solid rgba(42,125,225,0.35); color:var(--accent); font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; padding:4px 12px; border-radius:4px; }
.mod-course-label { color:var(--steel); font-size:12px; font-weight:500; }
.module-header h1 { font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:clamp(40px,6vw,72px); line-height:0.95; text-transform:uppercase; color:var(--white); letter-spacing:-0.5px; margin-bottom:18px; }
.module-header .subtitle { color:var(--cloud); font-size:17px; max-width:560px; line-height:1.5; }

/* MODULE INTRO VIDEO */
.module-intro-video { width:min(1100px,calc(100vw - 32px)); margin:32px 0 36px; margin-left:50%; transform:translateX(-50%); border-radius:10px; overflow:hidden; background:var(--ink); border:1px solid rgba(42,125,225,0.22); box-shadow:0 4px 28px rgba(0,0,0,0.18); }
.miv-header { display:flex; align-items:center; gap:10px; padding:10px 16px; background:rgba(42,125,225,0.09); border-bottom:1px solid rgba(42,125,225,0.15); }
.miv-platform-badge { width:22px; height:22px; background:var(--accent); border-radius:4px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.miv-platform-badge svg{fill:white;width:12px;height:12px;}
.miv-label-text { font-size:11px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; color:var(--cloud); flex:1; }
.miv-duration { font-size:11px; color:var(--steel); font-weight:500; letter-spacing:0.3px; }
.miv-player { position:relative; width:100%; padding-bottom:56.25%; }
.miv-placeholder { position:absolute; top:0; left:0; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; background:#0a1929; }
.miv-play-circle { width:68px; height:68px; border-radius:50%; background:rgba(42,125,225,0.12); border:2px solid rgba(42,125,225,0.28); display:flex; align-items:center; justify-content:center; }
.miv-play-circle svg{fill:rgba(42,125,225,0.55);width:30px;height:30px;margin-left:4px;}
.miv-coming-soon { color:var(--cloud); font-size:15px; font-weight:600; margin:0!important; }
.miv-hosted-note { color:var(--steel); font-size:12px; margin:0!important; }

/* ABOUT BOX / OBJECTIVES */
.about-box { border-left:4px solid var(--accent); background:var(--white); border-radius:0 8px 8px 0; padding:32px 36px; margin:24px 0; box-shadow:0 2px 16px rgba(11,25,41,0.06); }
.about-box-title { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:18px; text-transform:uppercase; letter-spacing:0.3px; color:var(--ink); margin-bottom:16px; }
.objectives { list-style:none; display:flex; flex-direction:column; gap:10px; }
.objectives li { display:flex; align-items:flex-start; gap:12px; color:var(--text-body); font-size:15px; line-height:1.5; }
.obj-tick { width:20px; height:20px; background:var(--accent); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.obj-tick svg{width:10px;height:10px;fill:var(--white);}
.about-meta { display:flex; gap:24px; margin-top:20px; padding-top:20px; border-top:1px solid var(--border); flex-wrap:wrap; }
.meta-item { color:var(--text-muted); font-size:13px; font-weight:500; }
.meta-item strong{color:var(--ink);}

/* CONTENT SECTIONS */
.content-section { padding:36px 0; border-bottom:1px solid var(--border); }
.content-section:last-of-type{border-bottom:none;}
.section-heading { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:clamp(26px,3.5vw,38px); text-transform:uppercase; color:var(--ink); letter-spacing:-0.3px; margin-bottom:8px; padding-bottom:14px; border-bottom:2px solid var(--accent); display:inline-block; }
.content-section p { color:var(--text-body); font-size:16px; line-height:1.75; margin-bottom:14px; margin-top:12px; }
.content-section p:last-child{margin-bottom:0;}
.sub-heading { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:22px; color:var(--navy); margin:32px 0 10px; letter-spacing:0.2px; }
.sub-heading-sm { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:17px; color:var(--navy); margin:24px 0 8px; letter-spacing:0.2px; text-transform:uppercase; }
.content-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin:16px 0 20px; padding:0; }
.content-list li { position:relative; padding-left:20px; font-size:15px; color:var(--text-body); line-height:1.65; }
.content-list li::before { content:'\2014'; position:absolute; left:0; color:var(--accent); font-weight:700; }

/* INFO BOX */
.info-box { background:var(--mist); border-left:3px solid var(--accent); border-radius:0 6px 6px 0; padding:20px 24px; margin:28px 0; }
.info-box-label { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--accent); margin-bottom:8px; }
.info-box p { color:var(--text-body); font-size:15px; line-height:1.65; margin:0!important; }

/* V2 CALLOUT BANNERS */
.v2-banner { border-radius:6px; overflow:hidden; margin:32px 0; border:1px solid rgba(0,0,0,0.08); }
.v2-banner-hdr { color:#fff; padding:12px 20px; font-weight:700; font-size:11px; letter-spacing:1.2px; text-transform:uppercase; }
.v2-banner-hdr--navy { background:#002B5B; }
.v2-banner-hdr--grey { background:#555555; }
.v2-banner-hdr--slate { background:#37474F; }
.v2-banner-body { padding:18px 20px; background:var(--white); }
.v2-banner-body p { font-size:15px; color:var(--text-body); line-height:1.7; margin:0 0 10px!important; }
.v2-banner-body p:last-child{ margin:0!important; }
.v2-banner-body ul { list-style:none; padding:0; display:flex; flex-direction:column; gap:6px; margin:8px 0 0; }
.v2-banner-body ul li { font-size:14px; color:var(--text-body); line-height:1.6; padding-left:16px; position:relative; }
.v2-banner-body ul li::before { content:'\2014'; position:absolute; left:0; color:var(--accent); font-weight:700; }

/* V2 TEACHING POINT */
.v2-tp { background:rgba(232,144,15,0.08); border-left:4px solid #E8900F; border-radius:0 6px 6px 0; padding:16px 20px; margin:24px 0; }
.v2-tp-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:#B8700A; margin-bottom:6px; }
.v2-tp p { font-size:15px; color:var(--text-body); line-height:1.65; margin:0!important; font-weight:600; }

/* V2 SOURCE REFS */
.v2-src { padding:14px 18px; border-radius:0 6px 6px 0; margin:16px 0; font-size:14px; color:var(--text-body); line-height:1.65; }
.v2-src-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:5px; display:block; }
.v2-src p { margin:0!important; font-size:14px; line-height:1.65; color:var(--text-body); }
.v2-src--nasc { background:rgba(31,78,121,0.07); border-left:3px solid #1F4E79; }
.v2-src--nasc .v2-src-label { color:#1F4E79; }
.v2-src--rics { background:rgba(46,125,50,0.06); border-left:3px solid #2E7D32; }
.v2-src--rics .v2-src-label { color:#2E7D32; }
.v2-src--ciob { background:rgba(94,53,177,0.07); border-left:3px solid #5E35B1; }
.v2-src--ciob .v2-src-label { color:#5E35B1; }
.v2-src--law { background:rgba(139,0,0,0.06); border-left:3px solid #8B0000; }
.v2-src--law .v2-src-label { color:#8B0000; }
.v2-src--case { background:rgba(139,0,0,0.05); border-left:3px solid #8B0000; border-style:dashed; border-width:0 0 0 3px; }
.v2-src--case .v2-src-label { color:#8B0000; }
.v2-src--industry { background:rgba(11,25,41,0.04); border-left:3px solid #6B90AE; }
.v2-src--industry .v2-src-label { color:#3E6185; }

/* V2 VISUAL COMPANION */
.v2-vc { padding:12px 16px; background:rgba(94,53,177,0.06); border:1px solid rgba(94,53,177,0.2); border-radius:6px; margin:18px 0; font-size:13px; font-style:italic; color:var(--text-muted); }
.v2-vc-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:#5E35B1; margin-bottom:4px; font-style:normal; display:block; }

/* V2 INDUSTRY FACTS BOX */
.v2-facts { background:var(--ink); border-radius:8px; padding:24px 28px; margin:28px 0; }
.v2-facts-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.v2-facts ul { list-style:none; padding:0; display:flex; flex-direction:column; gap:12px; }
.v2-facts ul li { color:var(--steel); font-size:14px; line-height:1.65; padding-left:18px; position:relative; }
.v2-facts ul li::before { content:'\2014'; position:absolute; left:0; color:var(--accent); font-weight:700; }
.v2-facts ul li strong { color:var(--cloud); }

/* THREE-COLUMN CARDS */
.three-col-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:24px 0; }
@media(max-width:680px){ .three-col-cards{grid-template-columns:1fr;} }
.three-col-card { background:var(--white); border-radius:8px; overflow:hidden; border:1px solid var(--border); box-shadow:0 2px 8px rgba(11,25,41,0.05); }
.tcc-header { background:var(--navy); padding:10px 14px; }
.tcc-category { font-size:10px; font-weight:700; letter-spacing:1.8px; text-transform:uppercase; color:var(--cloud); display:block; margin-bottom:2px; }
.tcc-org { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:22px; text-transform:uppercase; color:var(--white); }
.tcc-body { padding:14px; }
.tcc-full-name { font-size:12px; font-weight:600; color:var(--accent); margin-bottom:6px; letter-spacing:0.2px; }
.tcc-body p { font-size:13px; color:var(--text-body); line-height:1.55; margin:0!important; }

/* NASC REFERENCE BOX */
.nasc-ref-box { background:var(--ink); border-left:3px solid var(--accent); border-radius:0 8px 8px 0; padding:22px 26px; margin:28px 0; }
.nasc-ref-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.nasc-ref-title { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:15px; text-transform:uppercase; color:var(--white); margin-bottom:12px; letter-spacing:0.3px; line-height:1.2; }
.nasc-ref-box p { color:var(--steel)!important; font-size:14px!important; line-height:1.6; margin:0 0 8px!important; }
.nasc-ref-box p:last-child{margin-bottom:0!important;}
.nasc-ref-box em{color:var(--cloud); font-style:italic;}
.nasc-ref-list { list-style:none; padding:0; display:flex; flex-direction:column; gap:5px; margin-top:10px; }
.nasc-ref-list li { color:var(--steel); font-size:13px; line-height:1.55; padding-left:16px; position:relative; }
.nasc-ref-list li::before { content:'\2014'; position:absolute; left:0; color:var(--accent); font-weight:700; }

/* COMPARE GRID */
.compare-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin:24px 0; }
@media(max-width:540px){ .compare-grid{grid-template-columns:1fr;} }
.compare-card { background:var(--mist); border-radius:10px; padding:24px; border-top:3px solid var(--border); }
.compare-card.compare-highlight { background:rgba(42,125,225,0.06); border-top-color:var(--accent); }
.compare-card h4 { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:15px; text-transform:uppercase; color:var(--ink); margin:0 0 10px; letter-spacing:0.3px; }
.compare-card p { font-size:14px!important; color:var(--text-body); line-height:1.6; margin:0!important; }

/* CM CHECKLIST */
.cm-checklist { background:var(--mist); border-left:4px solid var(--accent); border-radius:0 8px 8px 0; padding:22px 26px; margin:28px 0; }
.cm-checklist-title { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:15px; text-transform:uppercase; color:var(--accent); margin-bottom:14px; letter-spacing:0.5px; }
.cm-checklist-list { list-style:none; padding:0; display:flex; flex-direction:column; gap:8px; }
.cm-checklist-list li { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--text-body); line-height:1.55; }
.cm-tick { width:18px; height:18px; background:var(--accent); border-radius:4px; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.cm-tick svg{width:9px;height:9px;fill:var(--white);}

/* KEY CLAUSES / DARK RULE BOX */
.dark-rule-box { background:var(--ink); border-radius:8px; padding:24px 28px; margin:28px 0; }
.dark-rule-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.dark-rule-title { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:17px; text-transform:uppercase; color:var(--white); margin-bottom:12px; letter-spacing:0.2px; line-height:1.2; }
.dark-rule-box p { color:var(--steel)!important; font-size:14px!important; line-height:1.65; margin:0 0 8px!important; }
.dark-rule-box p:last-child{margin-bottom:0!important;}
.dark-rule-list { list-style:none; padding:0; display:flex; flex-direction:column; gap:6px; margin-top:10px; }
.dark-rule-list li { color:var(--steel); font-size:13px; line-height:1.55; padding-left:16px; position:relative; }
.dark-rule-list li::before{content:'\2014';position:absolute;left:0;color:var(--accent);font-weight:700;}

/* ROLE CARDS */
.role-card { display:flex; align-items:flex-start; gap:18px; margin:28px 0 16px; padding:20px 24px; background:var(--mist); border-radius:10px; border-left:4px solid var(--accent); }
.role-card.role-you { background:rgba(42,125,225,0.06); border:2px solid rgba(42,125,225,0.2); border-left:4px solid var(--accent); }
.role-icon { flex-shrink:0; width:48px; height:48px; background:var(--ink); border-radius:10px; display:flex; align-items:center; justify-content:center; }
.role-icon svg{width:24px;height:24px;}
.role-icon.role-you-icon{background:var(--accent);}
.role-card-text h3 { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:18px; color:var(--navy); margin:0 0 4px; letter-spacing:0.2px; }
.role-card-text .role-oneliner { font-size:14px; color:var(--text-muted); margin:0; line-height:1.5; }

/* HIERARCHY CHAIN */
.hier-chain-wrap { background:var(--ink); border-radius:10px; padding:32px 28px; margin:32px 0; display:flex; flex-direction:column; align-items:center; gap:0; }
.hier-chain-node { background:var(--ink-mid); border:1px solid var(--slate); border-radius:7px; padding:14px 28px; text-align:center; width:100%; max-width:500px; }
.hier-chain-node.you-node { background:rgba(42,125,225,0.15); border-color:var(--accent); }
.hier-chain-node-title { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:14px; text-transform:uppercase; color:var(--white); letter-spacing:0.5px; }
.hier-chain-node-sub { font-size:12px; color:var(--steel); margin-top:4px; line-height:1.45; }
.hier-chain-arrow { width:2px; height:24px; background:var(--slate); margin:0 auto; position:relative; flex-shrink:0; }
.hier-chain-arrow::after { content:''; position:absolute; bottom:-1px; left:50%; transform:translateX(-50%); border-left:5px solid transparent; border-right:5px solid transparent; border-top:6px solid var(--slate); }

/* LIFECYCLE CHAIN */
.lifecycle-wrap { background:var(--ink); border-radius:10px; padding:28px; margin:28px 0; display:flex; flex-direction:column; gap:0; }
.lifecycle-row { display:grid; grid-template-columns:80px 1fr; gap:16px; align-items:flex-start; margin-bottom:0; }
.lifecycle-num { font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:32px; color:rgba(42,125,225,0.25); line-height:1; padding-top:14px; text-align:center; }
.lifecycle-node { background:var(--ink-mid); border:1px solid var(--slate); border-radius:6px; padding:14px 18px; margin-bottom:8px; }
.lifecycle-node-title { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:14px; text-transform:uppercase; color:var(--white); letter-spacing:0.5px; margin-bottom:4px; }
.lifecycle-node-sub { font-size:12px; color:var(--steel); line-height:1.5; }

/* ACTION CHECKLIST */
.action-checklist { background:var(--mist); border-left:4px solid var(--accent); border-radius:0 8px 8px 0; padding:22px 26px; margin:28px 0; }
.action-checklist-title { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:15px; text-transform:uppercase; color:var(--accent); margin-bottom:14px; letter-spacing:0.5px; }
.action-list { list-style:none; padding:0; display:flex; flex-direction:column; gap:8px; }
.action-list li { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--text-body); line-height:1.55; }
.action-box { width:16px; height:16px; border:2px solid var(--accent); border-radius:3px; flex-shrink:0; margin-top:2px; }

/* CONTRACT FORMS MATRIX */
.contract-matrix { margin:28px 0; border-radius:8px; overflow:hidden; border:1px solid var(--border); }
.cmat-row { display:grid; grid-template-columns:140px repeat(4,1fr); }
@media(max-width:640px){ .cmat-row{grid-template-columns:90px repeat(4,1fr);} }
.cmat-header-row { background:var(--ink); }
.cmat-cell { padding:10px 12px; font-size:13px; color:var(--text-body); line-height:1.4; border-right:1px solid var(--border); }
.cmat-cell:last-child { border-right:none; }
.cmat-label-col { font-weight:600; font-size:12px; color:var(--text-muted); background:var(--mist); }
.cmat-head-cell { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:15px; text-transform:uppercase; color:var(--white); letter-spacing:0.3px; }
.cmat-head.cmat-warn { color:#F59E0B; }
.cmat-alt { background:var(--mist); }
.cmat-warn-cell { color:#92400E; background:rgba(251,191,36,0.07); }
.cmat-head-cell.cmat-warn { color:#F59E0B; }
.cmat-yes { color:var(--success); font-weight:700; }
.cmat-no { color:var(--text-muted); }
.cmat-low { color:var(--success); font-weight:600; }
.cmat-med { color:#D97706; font-weight:600; }
.cmat-high { color:var(--fail); font-weight:700; }

/* LEGAL PYRAMID */
.legal-pyramid { margin:28px 0; display:flex; flex-direction:column; gap:4px; }
.lp-layer { border-radius:6px; padding:14px 20px; position:relative; }
.lp-top { background:rgba(139,0,0,0.08); border:1px solid rgba(139,0,0,0.2); }
.lp-mid { background:rgba(42,125,225,0.08); border:1px solid rgba(42,125,225,0.2); }
.lp-base { background:rgba(31,78,121,0.08); border:1px solid rgba(31,78,121,0.2); }
.lp-contract { background:var(--mist); border:1px solid var(--border); border-top:3px solid var(--accent); }
.lp-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:3px; }
.lp-top .lp-label { color:#8B0000; }
.lp-mid .lp-label { color:var(--accent-dk); }
.lp-base .lp-label { color:#1F4E79; }
.lp-contract .lp-label { color:var(--accent); }
.lp-title { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:17px; text-transform:uppercase; color:var(--ink); letter-spacing:0.3px; margin-bottom:3px; }
.lp-sub { font-size:12px; color:var(--text-muted); }

/* CASE CARDS */
.case-cards { display:flex; flex-direction:column; gap:12px; margin:24px 0; }
.case-card { background:var(--mist); border-radius:8px; padding:18px 22px; border-left:3px solid #8B0000; }
.case-card-citation { font-size:11px; font-weight:700; letter-spacing:0.5px; color:#8B0000; margin-bottom:6px; }
.case-card-rule { font-size:14px; color:var(--text-body); line-height:1.6; margin:0; }

/* DOWNLOADS */
.dl-section { background:var(--ink); border-radius:12px; padding:40px; margin:48px 0 0; }
@media(max-width:480px){ .dl-section{padding:24px 20px;} }
.dl-hdr { margin-bottom:28px; padding-bottom:20px; border-bottom:1px solid rgba(255,255,255,0.1); }
.dl-hdr h2 { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:28px; text-transform:uppercase; color:var(--white); margin-bottom:4px; }
.dl-hdr p { color:var(--steel); font-size:14px; margin:0; }
.dl-featured { display:flex; align-items:center; gap:20px; background:rgba(42,125,225,0.12); border:1px solid rgba(42,125,225,0.3); border-radius:10px; padding:22px 24px; margin-bottom:16px; text-decoration:none; transition:background 0.2s,border-color 0.2s; }
.dl-featured:hover { background:rgba(42,125,225,0.2); border-color:rgba(42,125,225,0.5); }
.dl-featured-icon { flex-shrink:0; width:52px; height:52px; background:var(--accent); border-radius:10px; display:flex; align-items:center; justify-content:center; }
.dl-featured-icon svg { width:24px; height:24px; fill:none; stroke:var(--white); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.dl-featured-text { flex:1; }
.dl-featured-text strong { display:block; font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:19px; text-transform:uppercase; color:var(--white); letter-spacing:0.3px; margin-bottom:3px; }
.dl-featured-text span { font-size:13px; color:var(--steel); }
.dl-badge { flex-shrink:0; display:inline-flex; align-items:center; gap:6px; padding:9px 16px; background:var(--accent); border-radius:6px; font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:14px; letter-spacing:0.5px; text-transform:uppercase; color:var(--white); white-space:nowrap; }
.dl-badge svg { width:14px; height:14px; fill:none; stroke:var(--white); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
@media(max-width:540px){ .dl-featured{flex-wrap:wrap;} .dl-badge{width:100%;justify-content:center;} }
.dl-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
@media(max-width:560px){ .dl-grid{grid-template-columns:1fr;} }
.dl-card { display:flex; align-items:center; gap:14px; background:var(--ink-mid); border:1px solid rgba(255,255,255,0.07); border-radius:8px; padding:16px 18px; text-decoration:none; transition:border-color 0.2s,background 0.2s; }
.dl-card:hover { border-color:rgba(42,125,225,0.35); background:rgba(42,125,225,0.05); }
.dl-card-icon { flex-shrink:0; width:40px; height:40px; background:rgba(42,125,225,0.1); border-radius:8px; display:flex; align-items:center; justify-content:center; }
.dl-card-icon svg { width:18px; height:18px; fill:none; stroke:var(--accent); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.dl-card-text { flex:1; min-width:0; }
.dl-card-text strong { display:block; font-size:13px; font-weight:600; color:var(--cloud); margin-bottom:2px; line-height:1.3; }
.dl-card-text span { font-size:12px; color:var(--steel); line-height:1.3; display:block; }
.dl-card-arrow { flex-shrink:0; }
.dl-card-arrow svg { width:16px; height:16px; fill:none; stroke:var(--slate); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; transition:stroke 0.2s; }
.dl-card:hover .dl-card-arrow svg { stroke:var(--accent); }

/* QUIZ */
.quiz-section { background:var(--ink); border-radius:12px; padding:40px; margin:56px 0 0; }
@media(max-width:480px){ .quiz-section{padding:24px 20px;} }
.quiz-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,0.1);}
.quiz-header h2 { font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:28px; text-transform:uppercase; color:var(--white); margin-bottom:6px; }
.quiz-header p{color:var(--steel);font-size:14px;margin:0;}
.quiz-question{margin-bottom:28px;}
.quiz-question p { font-size:15px; font-weight:600; color:var(--cloud); margin-bottom:12px; line-height:1.5; }
.q-num { display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; background:var(--accent); color:var(--white); border-radius:50%; font-size:12px; font-weight:700; margin-right:8px; flex-shrink:0; }
.quiz-options{list-style:none;display:flex;flex-direction:column;gap:8px;}
.quiz-options li label { display:flex; align-items:flex-start; gap:10px; padding:12px 16px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:6px; cursor:pointer; font-size:14px; color:var(--cloud); line-height:1.5; transition:border-color 0.15s,background 0.15s; }
.quiz-options li label:hover{border-color:var(--accent);background:rgba(42,125,225,0.1);}
.quiz-options li input[type="radio"]{margin-top:2px;accent-color:var(--accent);flex-shrink:0;}
.quiz-options li.correct label{border-color:var(--success);background:var(--success-lt);color:var(--success);font-weight:600;}
.quiz-options li.incorrect label{border-color:var(--fail);background:var(--fail-lt);color:var(--fail);}
.quiz-submit-row{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;}
.btn { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:16px; letter-spacing:0.6px; text-transform:uppercase; padding:13px 28px; border-radius:6px; border:none; cursor:pointer; transition:background 0.2s,transform 0.15s; }
.btn-primary{background:var(--accent);color:var(--white);}
.btn-primary:hover{background:var(--accent-dk);transform:translateY(-1px);}
.btn-secondary{background:rgba(255,255,255,0.07);color:var(--cloud);border:1px solid rgba(255,255,255,0.15);}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);}
.quiz-result { margin-top:20px; padding:16px 20px; border-radius:6px; font-size:15px; font-weight:600; display:none; }
.quiz-result.pass{background:var(--success-lt);color:var(--success);border:1px solid #86EFAC;}
.quiz-result.fail{background:var(--fail-lt);color:var(--fail);border:1px solid #FCA5A5;}

/* COMPLETION */
.completion-capture { display:none; background:var(--ink); border-radius:12px; padding:48px 40px; margin:32px 0 56px; position:relative; overflow:hidden; }
.completion-capture::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--accent); }
.completion-heading { font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:clamp(32px,5vw,52px); line-height:0.95; text-transform:uppercase; color:var(--white); margin-bottom:12px; }
.completion-heading span{color:var(--accent);}
.completion-sub{color:var(--steel);font-size:16px;line-height:1.6;margin-bottom:32px;max-width:480px;}
.completion-coming { background:rgba(42,125,225,0.1); border:1px solid rgba(42,125,225,0.2); border-radius:8px; padding:20px 24px; margin-top:16px; }
.coming-label { font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.coming-list{list-style:none;display:flex;flex-direction:column;gap:6px;}
.coming-list li { color:var(--cloud); font-size:14px; display:flex; align-items:center; gap:8px; }
.coming-list li::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0;}

/* REFERENCES */
.references-section{padding:48px 0;border-top:1px solid var(--border);}
.references-section h3 { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:20px; text-transform:uppercase; color:var(--ink); margin-bottom:6px; letter-spacing:0.3px; }
.references-section h4 { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:14px; text-transform:uppercase; color:var(--navy); margin:20px 0 8px; letter-spacing:0.5px; }
.ref-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-bottom:8px;}
.ref-list li { font-size:13px; color:var(--text-muted); line-height:1.6; padding-left:16px; border-left:2px solid var(--border); }
.ref-list li strong{color:var(--text-body);}

/* FOOTER */
footer { background:var(--ink); border-top:1px solid rgba(255,255,255,0.06); padding:24px 40px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
@media(max-width:680px){footer{padding:20px;}}
.footer-logo{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:18px;text-transform:uppercase;}
.footer-copy{color:#2E4560;font-size:13px;}

/* LOCKED STATE (free-tier signup gate) */
.locked-state { background: var(--mist); padding: 64px 40px; border-bottom: 1px solid var(--border); }
@media (max-width: 680px) { .locked-state { padding: 48px 20px; } }
.locked-box { max-width: 500px; margin: 0 auto; text-align: center; }
.locked-icon { width: 56px; height: 56px; background: rgba(42,125,225,0.1); border: 1px solid rgba(42,125,225,0.25); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; }
.locked-icon svg { stroke: var(--accent); }
.locked-box h2 { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 30px; text-transform: uppercase; color: var(--text-dark); margin-bottom: 12px; letter-spacing: 0.2px; }
.locked-box p { color: var(--text-body); font-size: 16px; line-height: 1.65; max-width: 400px; margin: 0 auto 28px; }
.locked-cta { display: inline-flex; align-items: center; gap: 8px; background: var(--accent); color: var(--white); font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 18px; text-transform: uppercase; letter-spacing: 0.5px; padding: 14px 28px; border-radius: 6px; text-decoration: none; transition: background 0.2s, transform 0.15s; }
.locked-cta:hover { background: var(--accent-dk); transform: translateY(-1px); }
.locked-note { font-size: 13px; color: var(--text-muted); margin-top: 16px; }
.locked-login { background: none; border: none; color: var(--accent); font-size: 13px; font-family: inherit; cursor: pointer; padding: 0; text-decoration: underline; }

/* COMPARISON TABLE (v2 module additions) */
.cmp-table { width:100%; border-collapse:collapse; margin:24px 0; border:1px solid var(--border); border-radius:8px; overflow:hidden; font-size:13px; }
.cmp-table thead th { background:var(--ink); color:var(--white); font-family:'Barlow Condensed',sans-serif; font-weight:800; font-size:14px; text-transform:uppercase; letter-spacing:0.4px; padding:12px 14px; text-align:left; border-right:1px solid rgba(255,255,255,0.08); }
.cmp-table thead th:last-child { border-right:none; }
.cmp-table thead th.cmp-topic { background:var(--navy); }
.cmp-table tbody td { padding:12px 14px; vertical-align:top; line-height:1.55; color:var(--text-body); border-top:1px solid var(--border); border-right:1px solid var(--border); }
.cmp-table tbody td:last-child { border-right:none; }
.cmp-table tbody td.cmp-row-label { background:var(--mist); font-weight:600; color:var(--ink); font-size:12px; text-transform:uppercase; letter-spacing:0.3px; width:140px; }
@media(max-width:680px) { .cmp-table tbody td.cmp-row-label { width:auto; } .cmp-table { font-size:12px; } .cmp-table thead th, .cmp-table tbody td { padding:10px 12px; } }
.cmp-flow-arrow td { background:var(--mist); border-top:none !important; border-right:none !important; text-align:center; padding:4px 0; line-height:1; }
.cmp-flow-arrow td svg { display:inline-block; vertical-align:middle; }

/* DOWNLOADS (pre-quiz resources block) */
.download-section { margin: 48px 0 0; }
.download-inner { display: flex; align-items: center; gap: 16px; background: var(--mist); border: 1px solid var(--border); border-left: 4px solid var(--accent); border-radius: 8px; padding: 20px 24px; }
.download-inner + .download-inner { margin-top: 10px; }
.download-icon { flex-shrink: 0; width: 48px; height: 48px; background: var(--accent); border-radius: 8px; display: flex; align-items: center; justify-content: center; color: var(--white); }
.download-icon svg { stroke: var(--white); }
.download-text { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.download-text strong { font-size: 15px; font-weight: 600; color: var(--ink); }
.download-text span { font-size: 13px; color: var(--text-muted); }
.download-btn { flex-shrink: 0; display: inline-block; padding: 10px 20px; background: var(--accent); color: var(--white); border: 1.5px solid var(--accent); border-radius: 6px; font-size: 14px; font-weight: 600; text-decoration: none; transition: background 0.15s, color 0.15s; white-space: nowrap; cursor: pointer; }
.download-btn:hover { background: var(--accent-dk); border-color: var(--accent-dk); }
.download-btn--outline { background: transparent; color: var(--accent); }
.download-btn--outline:hover { background: var(--accent); color: var(--white); }
.download-btn--disabled, .download-btn--disabled:hover { background: var(--mist); color: var(--text-muted); border-color: var(--border); cursor: not-allowed; pointer-events: none; }
.download-inner--secondary { background: var(--white); }
.download-icon--light { background: var(--mist); color: var(--navy); }
.download-icon--light svg { stroke: var(--navy); }
@media (max-width: 540px) {
  .download-inner { flex-wrap: wrap; }
  .download-btn { width: 100%; text-align: center; }
}

/* CONTINUE CTA on completion-capture, matches site CTA family
   (Barlow Condensed uppercase). Label kept short so it doesn't crowd
   the chevron. */
.continue-cta { display: inline-flex; align-items: center; gap: 10px; padding: 14px 28px; background: var(--accent); color: var(--white); border-radius: 6px; text-decoration: none; font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 17px; letter-spacing: 0.5px; text-transform: uppercase; transition: background 0.2s, transform 0.15s; }
.continue-cta:hover { background: var(--accent-dk); transform: translateY(-1px); }
.continue-cta svg { flex-shrink: 0; }
