:root{
  --ink:#132238;
  --ink-2:#20344f;
  --blue:#2e74b5;
  --blue-deep:#1f4d78;
  --cyan:#18a4a6;
  --gold:#d8b267;
  --paper:#f7f8fb;
  --surface:#ffffff;
  --mist:#edf3f8;
  --line:rgba(19,34,56,.12);
  --muted:#607086;
  --shadow:0 24px 70px -46px rgba(19,34,56,.58);
}

*{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
}

img{max-width:100%;display:block}

a{color:inherit}

.wrap{width:min(1160px,calc(100% - 40px));margin-inline:auto}

.topbar{
  position:sticky;
  top:0;
  z-index:30;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:14px 28px;
  background:rgba(247,248,251,.9);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}

.brand{display:inline-flex;align-items:center;gap:12px;text-decoration:none;font-weight:900}

.brand-logo{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:10px;
  background:var(--ink);
  padding:5px;
  border:1px solid rgba(19,34,56,.1);
  box-shadow:0 12px 26px -18px rgba(19,34,56,.8);
}

.brand-text{display:grid;gap:1px;line-height:1.08}
.brand-text strong{font-size:1rem;color:var(--ink)}
.brand-text small{font-size:.72rem;color:var(--muted);font-weight:850}

.nav{display:flex;align-items:center;gap:22px;font-size:.9rem;font-weight:850;color:#42556f}
.nav a{text-decoration:none;transition:.2s}
.nav a:hover{color:var(--blue)}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:var(--blue);
  font-size:.75rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:900;
}

.eyebrow::before{
  content:"";
  width:26px;
  height:2px;
  border-radius:20px;
  background:var(--gold);
}

.hero{
  position:relative;
  overflow:hidden;
  padding:84px 0 78px;
  background:
    linear-gradient(135deg,rgba(19,34,56,.96),rgba(31,77,120,.95) 58%,rgba(24,164,166,.82)),
    url("assets/course-blueprint-cover.png") center/cover;
  color:#fff;
}

.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.06fr) minmax(330px,.82fr);
  gap:54px;
  align-items:center;
}

.program-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  border-radius:999px;
  padding:8px 14px 8px 9px;
  color:rgba(255,255,255,.86);
  font-size:.82rem;
  font-weight:900;
}

.program-brand img{
  width:28px;
  height:28px;
  object-fit:contain;
  border-radius:8px;
  background:rgba(255,255,255,.11);
  padding:3px;
}

.hero .eyebrow{color:#f4d99d}

.hero h1{
  font-size:clamp(2.4rem,5vw,5rem);
  line-height:1;
  margin:18px 0 22px;
  max-width:11em;
}

.hero-lead{
  max-width:44rem;
  color:rgba(255,255,255,.8);
  font-size:1.08rem;
  font-weight:550;
}

.hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:30px}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:13px 22px;
  border-radius:999px;
  text-decoration:none;
  font-weight:900;
  transition:.25s;
}

.btn.primary{background:var(--gold);color:var(--ink);box-shadow:0 18px 38px -24px rgba(216,178,103,.9)}
.btn.primary:hover{background:#fff;transform:translateY(-2px)}
.btn.ghost{border:1px solid rgba(255,255,255,.3);color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5)}

.stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:34px;
  max-width:660px;
}

.stats div{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  border-radius:14px;
  padding:18px;
}

.stats b{display:block;font-size:1.6rem;line-height:1;color:#f4d99d}
.stats span{display:block;margin-top:8px;color:rgba(255,255,255,.68);font-size:.84rem;font-weight:800}

.hero-visual{position:relative}
.hero-visual img{
  border-radius:18px;
  box-shadow:0 38px 90px -42px rgba(0,0,0,.92);
  border:1px solid rgba(255,255,255,.18);
}

.floating-card{
  position:absolute;
  width:min(252px,70%);
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.92);
  color:var(--ink);
  border-radius:14px;
  padding:16px 18px;
  box-shadow:0 20px 54px -34px rgba(0,0,0,.85);
  backdrop-filter:blur(12px);
}

.floating-card b{display:block;font-size:.95rem}
.floating-card span{display:block;margin-top:4px;color:var(--muted);font-size:.8rem;font-weight:750}
.card-one{left:-22px;bottom:26px}
.card-two{right:20px;top:-22px}

section{padding:84px 0}

.section-head{max-width:780px;margin-bottom:38px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}

.section-head h2,.positioning h2,.tools h2,.outcome h2,.summary h2{
  font-size:clamp(1.85rem,3.35vw,2.72rem);
  line-height:1.08;
  margin:14px 0 12px;
}

.section-head p,.logic p,.tools p,.outcome p,.summary p{color:var(--muted);font-weight:550}

.positioning{
  background:var(--surface);
  border-bottom:1px solid var(--line);
}

.positioning-grid{
  display:grid;
  grid-template-columns:.78fr 1.22fr;
  gap:48px;
  align-items:start;
}

.positioning-copy p{
  margin:0;
  color:#34445b;
  font-size:1.08rem;
  font-weight:550;
}

.quote-box{
  margin-top:22px;
  border-left:5px solid var(--gold);
  background:var(--mist);
  padding:20px 22px;
  border-radius:0 12px 12px 0;
  color:var(--blue-deep);
  font-size:1.05rem;
  font-weight:850;
}

.audience{background:var(--paper)}

.audience-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

.audience article{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:24px;
  box-shadow:var(--shadow);
}

.audience article span{font-size:.75rem;font-weight:900;color:var(--blue);letter-spacing:.12em}
.audience h3{margin:14px 0 8px;font-size:1.08rem}
.audience p{margin:0;color:var(--muted);font-size:.94rem;font-weight:550}

.logic{
  background:linear-gradient(180deg,var(--mist),var(--paper));
  border-block:1px solid var(--line);
}

.path-line{
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:8px;
  margin-top:34px;
}

.path-line span{
  position:relative;
  min-height:84px;
  display:grid;
  place-items:center;
  text-align:center;
  border:1px solid rgba(19,34,56,.13);
  background:#fff;
  border-radius:12px;
  padding:12px;
  font-size:.82rem;
  font-weight:900;
  box-shadow:0 16px 34px -30px rgba(19,34,56,.55);
}

.path-line span::after{
  content:"";
  position:absolute;
  right:-9px;
  top:50%;
  width:10px;
  height:2px;
  background:var(--gold);
}

.path-line span:last-child::after{display:none}

.modules{background:var(--paper)}

.module-stack{display:grid;gap:18px}

.module-card{
  display:grid;
  grid-template-columns:136px 1fr;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.module-card.accent{
  border-color:rgba(46,116,181,.24);
  box-shadow:0 28px 82px -50px rgba(46,116,181,.55);
}

.module-side{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:18px;
  padding:24px 18px;
  background:linear-gradient(180deg,var(--ink),var(--blue-deep));
  color:#fff;
}

.module-card.accent .module-side{background:linear-gradient(180deg,var(--blue),var(--cyan))}

.module-side span{font-size:2.4rem;line-height:1;font-weight:900;color:#fff}
.module-side b{
  display:inline-flex;
  width:max-content;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.12);
  border-radius:999px;
  padding:7px 11px;
  font-size:.82rem;
}

.module-body{padding:26px}

.module-head{
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(260px,1fr);
  gap:24px;
  align-items:start;
  margin-bottom:18px;
}

.module-head h3{
  margin:0;
  color:var(--blue-deep);
  font-size:1.45rem;
  line-height:1.16;
}

.module-head p{
  margin:0;
  color:var(--muted);
  font-size:.96rem;
  font-weight:550;
}

.lesson-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}

.lesson-list li{
  display:grid;
  grid-template-columns:46px 1fr auto;
  gap:10px;
  align-items:center;
  min-height:46px;
  border:1px solid rgba(19,34,56,.1);
  background:#fdfefe;
  border-radius:10px;
  padding:10px 12px;
  color:#2e4058;
  font-size:.91rem;
  font-weight:700;
}

.lesson-list span{
  display:grid;
  place-items:center;
  min-width:38px;
  height:28px;
  border-radius:8px;
  background:var(--mist);
  color:var(--blue);
  font-size:.78rem;
  font-weight:900;
}

.lesson-list b{
  white-space:nowrap;
  color:var(--muted);
  font-size:.78rem;
  font-weight:850;
}

.module-body footer{
  margin-top:18px;
  border-top:1px solid var(--line);
  padding-top:16px;
  color:var(--blue-deep);
  font-size:.95rem;
  font-weight:900;
}

.tools{
  background:var(--ink);
  color:#fff;
}

.tools-grid{
  display:grid;
  grid-template-columns:.74fr 1.26fr;
  gap:48px;
  align-items:start;
}

.tools .eyebrow{color:#f4d99d}
.tools p{color:rgba(255,255,255,.72)}

.tool-groups{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

.tool-groups article{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.07);
  border-radius:12px;
  padding:20px;
}

.tool-groups h3{margin:0 0 9px;font-size:1rem;color:#f4d99d}
.tool-groups p{margin:0;color:rgba(255,255,255,.82);font-size:.92rem;font-weight:700}

.outcome{background:linear-gradient(180deg,var(--paper),#eef3f7)}

.outcome-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:42px;
  align-items:start;
}

.outcome-card{
  position:sticky;
  top:100px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--line);
  padding:32px;
  box-shadow:var(--shadow);
}

.deliverables{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}

.deliverables div{
  display:grid;
  grid-template-columns:44px 1fr;
  gap:13px;
  align-items:start;
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:18px;
  box-shadow:0 18px 40px -36px rgba(19,34,56,.5);
}

.deliverables b{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:var(--mist);
  color:var(--blue);
  font-size:.78rem;
}

.deliverables span{font-weight:800;color:#32445e}

.summary{
  background:#eef3f7;
  padding-top:0;
}

.summary-panel{
  text-align:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--ink),var(--blue-deep));
  color:#fff;
  padding:54px 34px;
  box-shadow:0 34px 90px -50px rgba(19,34,56,.82);
}

.summary-panel .eyebrow{color:#f4d99d;justify-content:center}
.summary-panel h2{max-width:880px;margin-inline:auto}
.summary-panel p{max-width:660px;margin:0 auto 26px;color:rgba(255,255,255,.74)}

.summary-brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  border-radius:999px;
  padding:8px 15px 8px 9px;
  color:#f4d99d;
  font-size:.86rem;
  font-weight:900;
}

.summary-brand img{
  width:30px;
  height:30px;
  object-fit:contain;
  border-radius:8px;
  background:rgba(255,255,255,.1);
  padding:3px;
}

.site-footer{
  background:var(--ink);
  color:rgba(255,255,255,.72);
  border-top:1px solid rgba(216,178,103,.2);
  padding:30px 0;
}

.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.footer-brand{display:flex;align-items:center;gap:13px}

.footer-brand img{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:10px;
  background:rgba(255,255,255,.07);
  padding:5px;
  border:1px solid rgba(255,255,255,.12);
}

.footer-brand b{display:block;color:#fff;line-height:1.1}
.footer-brand span{display:block;margin-top:3px;color:rgba(255,255,255,.56);font-size:.82rem;font-weight:750}

.site-footer p{
  margin:0;
  max-width:480px;
  color:rgba(255,255,255,.64);
  font-size:.9rem;
  font-weight:600;
}

@media(max-width:1080px){
  .audience-grid{grid-template-columns:repeat(2,1fr)}
  .path-line{grid-template-columns:repeat(4,1fr)}
  .path-line span:nth-child(4)::after{display:none}
  .lesson-list{grid-template-columns:1fr}
  .module-head{grid-template-columns:1fr}
}

@media(max-width:900px){
  .nav{display:none}
  .hero{padding:62px 0 66px}
  .hero-grid,.positioning-grid,.tools-grid,.outcome-grid{grid-template-columns:1fr}
  .hero h1{font-size:3rem}
  .hero-visual{max-width:620px}
  .outcome-card{position:relative;top:auto}
}

@media(max-width:700px){
  .wrap{width:min(100% - 28px,1160px)}
  section{padding:60px 0}
  .topbar{padding:13px 16px}
  .brand-logo{width:38px;height:38px}
  .brand-text strong{font-size:.92rem}
  .brand-text small{font-size:.68rem}
  .hero h1{font-size:2.32rem}
  .hero-lead{font-size:1rem}
  .hero-actions,.stats{display:grid;grid-template-columns:1fr}
  .floating-card{position:relative;left:auto;right:auto;top:auto;bottom:auto;width:100%;margin-top:10px}
  .audience-grid,.deliverables,.tool-groups{grid-template-columns:1fr}
  .module-card{grid-template-columns:1fr}
  .module-side{display:grid;grid-template-columns:1fr auto;align-items:center;padding:18px 20px}
  .module-side span{font-size:1.8rem}
  .module-body{padding:20px}
  .lesson-list li{grid-template-columns:42px 1fr}
  .lesson-list b{grid-column:2;color:var(--blue)}
  .path-line{grid-template-columns:repeat(2,1fr)}
  .path-line span{min-height:70px}
  .path-line span::after{display:none}
  .summary-panel{padding:38px 20px;border-radius:16px}
  .footer-inner{display:grid;gap:18px}
}
