
:root {
  --blue: #14315f;
  --blue-dark: #0b1f3f;
  --green: #27944a;
  --green-dark: #1b7237;
  --teal: #0e7b83;
  --amber: #f2a51a;
  --ink: #14213d;
  --muted: #617089;
  --line: rgba(20,49,95,.14);
  --soft: #f3f7fb;
  --white: #fff;
  --max: 1180px;
  --shadow: 0 18px 44px rgba(11,31,63,.12);
  --shadow-soft: 0 12px 34px rgba(11,31,63,.08);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Manrope", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--ink); background: linear-gradient(180deg,#f7fbff 0,#fff 320px,#fff 100%); line-height: 1.6; }
img { display:block; max-width:100%; }
a { color: inherit; text-decoration: none; }
.container { width: min(calc(100% - 40px), var(--max)); margin: 0 auto; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.site-header { position: sticky; top: 0; z-index: 20; background: rgba(255,255,255,.96); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(20,49,95,.1); box-shadow: 0 8px 24px rgba(11,31,63,.04); }
.header-inner { min-height: 82px; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:24px; }
.brand { display:inline-flex; align-items:center; justify-content:center; min-width:0; padding:12px 16px; border:1px solid rgba(20,49,95,.08); border-radius:16px; background:#fff; box-shadow:var(--shadow-soft); }
.brand-logo { width:auto; max-width:270px; object-fit:contain; }
.site-header .brand-logo { height:50px; }
.top-nav { justify-self:center; display:flex; align-items:center; justify-content:center; gap:6px; padding:6px; border:1px solid rgba(20,49,95,.08); border-radius:16px; background:#f4f8fc; font-weight:800; color:var(--blue); font-size:.94rem; }
.top-nav a { padding:10px 13px; border-radius:10px; transition: background .18s ease, color .18s ease; }
.top-nav a:hover { background:#fff; color:var(--green-dark); }
.button { display:inline-flex; align-items:center; justify-content:center; min-height:48px; padding:12px 20px; border-radius:14px; border:1px solid transparent; font-weight:800; line-height:1.1; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--green); color: var(--white); box-shadow: 0 14px 28px rgba(39,148,74,.24); }
.button-primary:hover { background: var(--green-dark); }
.button-secondary { background:#eef4fb; color:var(--blue); border-color:var(--line); }
.button-outline { background:transparent; color:var(--white); border-color:rgba(255,255,255,.45); }
.hero { padding:58px 0 42px; background: linear-gradient(135deg,#f7fbff 0%,#eef6fb 62%,#fff 100%); border-bottom: 1px solid var(--line); }
.hero-grid { display:grid; grid-template-columns: minmax(0,1.08fr) minmax(320px,.92fr); gap:34px; align-items:center; }
.badge { display:inline-flex; align-items:center; width:fit-content; max-width:100%; padding:0 0 0 14px; border:0; border-left:4px solid var(--green); border-radius:0; background:transparent; color:var(--green-dark); font-size:.82rem; font-weight:900; letter-spacing:.03em; line-height:1.25; text-transform:uppercase; }
.badge::before { display:none; }
.badge.muted { color:var(--blue); border-left-color:var(--teal); }
.badge.light { color:#fff; border-left-color:rgba(255,255,255,.72); }
h1,h2,h3,p { overflow-wrap:anywhere; }
h1 { margin:18px 0 16px; color:var(--blue-dark); font-size: clamp(2.05rem, 4.3vw, 4.05rem); line-height:1.02; letter-spacing:0; }
h2 { margin:0 0 14px; color:var(--blue-dark); font-size: clamp(1.65rem, 3vw, 2.65rem); line-height:1.12; letter-spacing:0; }
h3 { margin:0 0 10px; color:var(--blue-dark); font-size:1.12rem; line-height:1.22; letter-spacing:0; }
.lead { margin:0; color:var(--muted); font-size:1.06rem; max-width:730px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin:24px 0 16px; }
.quick-links { display:flex; flex-wrap:wrap; gap:10px; }
.quick-links a, .text-link { color:var(--blue); font-weight:800; text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 4px; }
.hero-panel { background:#fff; border:1px solid rgba(20,49,95,.12); border-radius:18px; box-shadow:var(--shadow); overflow:hidden; }
.course-image { width:100%; aspect-ratio: 16/10; object-fit:cover; background:#eef4fb; }
.course-hero .course-image { aspect-ratio: 1/1; object-fit:contain; padding:18px; }
.panel-content { padding:22px; }
.eyebrow { margin:0 0 8px; color:var(--teal); text-transform:uppercase; font-size:.78rem; letter-spacing:.03em; font-weight:900; }
.check-list { display:grid; gap:10px; list-style:none; margin:0; padding:0; }
.check-list li { position:relative; padding-left:22px; font-weight:700; color:var(--ink); }
.check-list li::before { content:""; position:absolute; left:0; top:.62em; width:8px; height:8px; border-radius:50%; background:var(--green); }
.proof-strip { background:var(--blue-dark); color:#fff; }
.proof-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:1px; background:rgba(255,255,255,.16); }
.proof-grid article { background:var(--blue-dark); padding:22px; min-height:112px; }
.proof-grid strong { display:block; font-size:1.05rem; margin-bottom:6px; }
.proof-grid span { color:rgba(255,255,255,.76); font-size:.94rem; }
.section { padding:72px 0; }
.section-soft { background:var(--soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.split { display:grid; grid-template-columns:minmax(220px,.72fr) minmax(0,1.28fr); gap:46px; align-items:start; }
.split.reverse { grid-template-columns:minmax(220px,.72fr) minmax(0,1.28fr); }
.section-heading p { margin:0; color:var(--muted); max-width:760px; }
.section-heading.wide { max-width:860px; margin-bottom:28px; }
.section-heading .badge { margin-bottom:14px; }
.rich-text { color:var(--muted); font-size:1.06rem; }
.rich-text p { margin:0 0 16px; }
.cards { display:grid; gap:18px; }
.cards.four { grid-template-columns:repeat(4,minmax(0,1fr)); }
.cards.three { grid-template-columns:repeat(3,minmax(0,1fr)); }
.card { background:#fff; border:1px solid rgba(20,49,95,.12); border-radius:16px; padding:22px; min-height:190px; box-shadow:0 10px 30px rgba(11,31,63,.05); }
.card span { display:inline-flex; color:var(--amber); font-weight:800; margin-bottom:12px; }
.card p { margin:0; color:var(--muted); }
.facts-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
.fact { background:#fff; border:1px solid rgba(20,49,95,.12); border-radius:16px; padding:18px; min-height:126px; box-shadow:0 10px 28px rgba(11,31,63,.04); }
.fact span { display:block; color:var(--muted); font-size:.86rem; font-weight:800; margin-bottom:8px; }
.fact strong { display:block; color:var(--blue-dark); font-size:1rem; line-height:1.28; }
.cta-section { padding:56px 0; }
.cta-band { display:flex; align-items:center; justify-content:space-between; gap:28px; padding:34px; border-radius:18px; background:linear-gradient(135deg,var(--blue-dark),#15467a); color:#fff; box-shadow:var(--shadow); }
.cta-band h2 { color:#fff; }
.cta-band p { margin:0; color:rgba(255,255,255,.8); max-width:720px; }
.cta-actions { display:flex; flex-wrap:wrap; gap:12px; justify-content:flex-end; }
.course-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px; }
.course-grid.compact { grid-template-columns:repeat(4,minmax(0,1fr)); }
.course-card { background:#fff; border:1px solid rgba(20,49,95,.12); border-radius:16px; padding:18px; min-height:190px; display:flex; flex-direction:column; justify-content:space-between; gap:12px; box-shadow:0 10px 28px rgba(11,31,63,.05); }
.course-card-main span { display:inline-flex; color:var(--teal); font-size:.78rem; font-weight:800; text-transform:uppercase; margin-bottom:10px; }
.course-card-main p { color:var(--muted); margin:0; }
.faq-list { display:grid; gap:12px; max-width:920px; }
.faq-item { background:#fff; border:1px solid rgba(20,49,95,.12); border-radius:16px; padding:0; }
.faq-item summary { cursor:pointer; padding:18px 20px; font-weight:800; color:var(--blue-dark); }
.faq-item p { margin:0; padding:0 20px 20px; color:var(--muted); }
.final-cta { padding-top:20px; }
.final-box { text-align:center; padding:42px 24px; border:1px solid rgba(20,49,95,.12); border-radius:18px; background:#fff; box-shadow:var(--shadow); }
.final-box p { margin:0 auto 22px; color:var(--muted); max-width:740px; }
.site-footer { background:var(--blue-dark); color:#fff; padding:38px 0; }
.footer-grid { display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:start; }
.footer-brand { display:flex; gap:16px; align-items:flex-start; }
.footer-brand .brand-logo { background:#fff; padding:10px; border-radius:14px; max-width:210px; }
.footer-brand p { margin:0; color:rgba(255,255,255,.72); max-width:520px; }
.footer-links { display:flex; flex-wrap:wrap; gap:10px 18px; justify-content:flex-end; }
.footer-links a { color:rgba(255,255,255,.86); font-weight:800; }
@media (max-width: 1020px) {
  .header-inner { min-height:auto; grid-template-columns:1fr; justify-items:center; gap:12px; padding:14px 0 12px; }
  .brand { padding:0; border:0; box-shadow:none; background:transparent; }
  .site-header .brand-logo { height:52px; max-width:285px; }
  .top-nav { width:100%; display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:6px; justify-content:stretch; overflow:visible; padding:6px; }
  .top-nav a { text-align:center; padding:10px 6px; white-space:nowrap; }
  .header-cta { display:none; }
  .hero-grid, .split { grid-template-columns:1fr; }
  .proof-grid, .facts-grid, .cards.four, .course-grid.compact { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .course-grid, .cards.three { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .cta-band { align-items:flex-start; flex-direction:column; }
  .cta-actions { justify-content:flex-start; }
}
@media (max-width: 680px) {
  .container { width:min(calc(100% - 28px), var(--max)); }
  .site-header { position:relative; }
  .site-header .brand-logo { height:48px; max-width:265px; }
  .top-nav { font-size:.8rem; border-radius:12px; }
  .top-nav a { padding:9px 4px; }
  .hero { padding:34px 0 30px; }
  .hero-grid { gap:24px; }
  .badge { font-size:.74rem; padding-left:10px; border-left-width:3px; }
  h1 { margin-top:14px; font-size:clamp(2rem, 10vw, 2.55rem); line-height:1.05; }
  h2 { font-size:1.55rem; }
  .lead { font-size:1rem; line-height:1.55; }
  .button { width:100%; }
  .hero-actions, .cta-actions { width:100%; }
  .hero-panel { border-radius:16px; }
  .course-image, .course-hero .course-image { aspect-ratio: 16/10; padding:0; object-fit:cover; }
  .panel-content { padding:20px; }
  .proof-grid, .facts-grid, .cards.four, .cards.three, .course-grid, .course-grid.compact { grid-template-columns:1fr; }
  .section { padding:48px 0; }
  .cta-band { padding:24px; }
  .footer-grid, .footer-brand { grid-template-columns:1fr; display:grid; }
  .footer-links { justify-content:flex-start; }
}
@media (max-width: 520px) {
  .top-nav { grid-template-columns:repeat(2,minmax(0,1fr)); font-size:.86rem; }
  .top-nav a { padding:10px 8px; white-space:normal; }
}
