:root{
  --ink:#1c2d41;--ink-mid:#52525b;--ink-light:#a1a1aa;
  --blue:#035498;--blue-hover:#0559a0;--blue-pale:#eef5fc;--blue-soft:#c2d9f0;--orange:#e8622a;--orange-pale:#fdf3ee;--orange-soft:#f9ddd0;
  --teal:#035498;--teal-pale:#eef5fc;--teal-soft:#c2d9f0;
  --red:#b91c1c;--red-pale:#fef2f2;--red-soft:#fecaca;
  --green:#15803d;--green-pale:#f0fdf4;--green-soft:#bbf7d0;
  --amber:#b45309;--amber-pale:#fffbeb;--amber-soft:#fde68a;
  --rule:#e4e4e7;--bg:#f9f9f8;--white:#fff;
  --serif:'Lora',Georgia,serif;--sans:'Outfit',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.75;font-size:16px}
#prog{position:fixed;top:0;left:0;height:4px;background:var(--blue);width:0;z-index:300;transition:width .12s}
.bc{padding:12px 32px;font-size:15px;color:var(--ink);font-weight:500;border-bottom:1px solid var(--rule);background:var(--white)}
.bc a{color:var(--blue);text-decoration:none}

/* HERO */
.hero{background:linear-gradient(135deg,#1c2d41 0%,#0d2137 100%);color:white;position:relative;overflow:hidden}
.hero-inner{;margin:0 auto;padding:72px 32px 64px;position:relative;z-index:2}
.hero-inner br { display: none;}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 10%,rgba(3,84,152,.35) 0%,transparent 55%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#035498 0%,rgba(3,84,152,.3) 70%,transparent 100%)}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(3,84,152,.15);border:1px solid rgba(3,84,152,.35);color:#5ba3d9;padding:6px 14px;border-radius:20px;font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px}
.hero h1{font-family:var(--serif);font-size:clamp(1.85rem,4.5vw,2.8rem);line-height:1.18;color:white;margin-bottom:24px;font-weight:700}
.hero h1 em{font-style:italic;color:var(--orange)}
.hero-lead{font-size:1.1rem;color:rgba(255,255,255,.92);line-height:1.9;margin-bottom:36px;font-weight:300}
.promises{display:flex;flex-wrap:wrap;gap:0;padding-top:24px;border-top:1px solid rgba(255,255,255,.12)}
.promise{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:500;color:rgba(255,255,255,.8);padding:4px 14px 4px 0;line-height:1.5}
.hero-hook{background:rgba(3,84,152,.12);border:1px solid rgba(3,84,152,.25);border-radius:12px;padding:24px 28px;margin-top:32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}
.hook-stat .n{font-family:var(--serif);font-size:1.65rem;font-weight:700;color:#5ba3d9;display:block;line-height:1}
.hook-stat .l{font-size:15px;color:rgba(255,255,255,.9);font-weight:600;margin-top:5px;display:block;text-transform:uppercase;letter-spacing:.07em;line-height:1.4}

/* TOC */
.toc-wrap{;margin:0 auto;padding:0 32px}
.toc{background:var(--blue-pale);border:2px solid var(--blue-soft);border-radius:12px;padding:32px;margin:48px 0;border-top:4px solid var(--blue)}
.toc-head{font-family:var(--serif);font-size:1rem;margin-bottom:18px;color:var(--ink);font-weight:600}
.toc ol{columns:2;column-gap:36px;font-size:15px;color:var(--ink);font-weight:500;padding-left:18px}
.toc li{margin-bottom:8px;break-inside:avoid}
.toc a{color:var(--blue);text-decoration:none;font-weight:500}
.toc a:hover{text-decoration:underline}
@media(max-width:540px){.toc ol{columns:1}}

/* ARTICLE */
.article{;margin:0 auto;padding:0 32px 100px}
.sh{margin:68px 0 26px;padding-bottom:14px;border-bottom:2px solid var(--rule);border-left:4px solid var(--blue);padding-left:16px}
.sh-eyebrow{font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.sh h2{font-family:var(--serif);font-size:clamp(1.35rem,3vw,1.85rem);color:#1c2d41;line-height:1.3}
h3.sub{font-family:var(--serif);font-size:1.1rem;color:#1c2333;margin:34px 0 13px;padding-left:10px;border-left:3px solid var(--blue)}
.body{color:var(--ink);font-weight:500;margin-bottom:16px;font-size:16px;line-height:1.82}

/* TABLES */
.tbl{width:100%;border-collapse:collapse;margin:26px 0;font-size:14px;background:var(--white);border-radius:10px;overflow:hidden;border:1px solid var(--rule)}
.tbl thead tr{background:var(--ink);color:white}
.tbl th{padding:11px 15px;text-align:left;font-weight:500;font-size:15px;letter-spacing:.06em}
.tbl td{padding:11px 15px;border-bottom:1px solid var(--rule);color:var(--ink);font-weight:500;vertical-align:top;font-size:15px}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--orange-pale)}
.risk{font-weight:700;font-size:15px;padding:2px 7px;border-radius:4px;white-space:nowrap}
.risk.h{background:var(--red-pale);color:var(--red)}
.risk.m{background:var(--amber-pale);color:var(--amber)}
.risk.l{background:var(--green-pale);color:var(--green)}

/* CALLOUTS */
.callout{display:flex;gap:14px;align-items:flex-start;border-radius:10px;padding:17px 20px;margin:22px 0}
.callout.info{background:var(--blue-pale);border-left:4px solid var(--blue)}
.callout.warn{background:var(--amber-pale);border-left:4px solid var(--amber)}
.callout.danger{background:var(--red-pale);border-left:4px solid var(--red)}
.callout.tip{background:var(--blue-pale);border-left:4px solid var(--blue)}
.callout.good{background:var(--green-pale);border-left:4px solid var(--green)}
.callout-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}
.callout-body strong{display:block;margin-bottom:4px;font-size:15px;color:var(--ink);font-weight:500;font-weight:700}
.callout-body p,.callout-body ul{font-size:15px;color:var(--ink);font-weight:500;margin:0;line-height:1.65}
.callout-body ul{padding-left:16px;margin-top:6px}
.callout-body li{margin-bottom:4px}

/* ILLO WRAPPER */
.illo{margin:30px 0;background:var(--white);border:1px solid var(--rule);border-radius:12px;overflow:hidden}
.illo svg{width:100%;display:block}
.illo-cap{padding:10px 16px;font-size:14px;color:var(--ink-mid);font-weight:500;border-top:1px solid var(--rule);background:var(--bg);font-style:italic;line-height:1.5}

/* INCLUDES/EXCLUDES GRID */
.ie{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:22px 0}
@media(max-width:540px){.ie{grid-template-columns:1fr}}
.ie-box{border-radius:10px;padding:18px}
.ie-box.inc{background:#166534;border:1px solid #166534}
.ie-box.exc{background:#b91c1c;border:1px solid #b91c1c}
.ie-box h4{font-size:15px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:11px}
.ie-box.inc h4{color:white}.ie-box.exc h4{color:white}
.ie-list{list-style:none}
.ie-list li{font-size:15px;color:white;font-weight:600;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;gap:8px;align-items:flex-start;line-height:1.5}
.ie-list li:last-child{border-bottom:none}
.ie-list li::before{flex-shrink:0;font-weight:700;margin-top:1px}
.ie-box.inc .ie-list li::before{content:'✓';color:rgba(255,255,255,.8)}
.ie-box.exc .ie-list li::before{content:'✗';color:rgba(255,255,255,.8)}

/* COST COMPARE */
.cc{display:grid;grid-template-columns:1fr 1fr;margin:26px 0;border:1px solid var(--rule);border-radius:12px;overflow:hidden;background:var(--white)}
@media(max-width:540px){.cc{grid-template-columns:1fr}}
.cc-col{padding:22px 18px}
.cc-col.cheap{background:var(--red-pale);border-right:1px solid var(--red-soft)}
.cc-col.prem{background:var(--green-pale)}
.cc-head{font-size:15px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.cc-col.cheap .cc-head{color:var(--red)}.cc-col.prem .cc-head{color:var(--green)}
.cc-row{display:flex;justify-content:space-between;padding:6px 0;font-size:15px;color:var(--ink);font-weight:600;border-bottom:1px solid rgba(0,0,0,.06)}
.cc-row:last-of-type{border-bottom:none}
.cc-row.tot{font-weight:700;font-size:15px;padding-top:10px;margin-top:4px}
.cc-col.cheap .cc-row.tot{color:var(--red)}.cc-col.prem .cc-row.tot{color:var(--green)}
.cc-verdict{padding:16px 22px;background:var(--ink);color:white;font-size:15px;grid-column:1/-1;line-height:1.65}
.cc-verdict strong{color:var(--orange)}

/* BEST PRACTICE ROWS */
.bpr{border:1px solid var(--rule);border-radius:10px;overflow:hidden;margin:22px 0}
.bpr-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--rule)}
.bpr-row:last-child{border-bottom:none}
@media(max-width:540px){.bpr-row{grid-template-columns:1fr}}
.bpr-complaint{padding:15px 17px;background:#c41f1f;border-right:1px solid #a01818}
.bpr-solution{padding:15px 17px;background:#166534}
@media(max-width:540px){.bpr-complaint{border-right:none;border-bottom:1px solid var(--red-soft)}}
.bpr-label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}
.bpr-complaint .bpr-label{color:rgba(255,255,255,.7)}.bpr-solution .bpr-label{color:rgba(255,255,255,.7)}
.bpr-text{color:white;font-weight:500;font-size:15px;color:white;font-weight:500;line-height:1.6}

/* REGION CARDS */
.regions{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:26px 0}
.region{background:var(--white);border:1px solid var(--rule);border-left:4px solid var(--blue);border-radius:8px;padding:16px;background:var(--blue)}
.region h4{font-size:15px;font-weight:700;color:white;margin-bottom:7px}
.region p{font-size:14px;color:rgba(255,255,255,.92);font-weight:500;margin:0;line-height:1.6}

/* FLAGS */
.flags{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:11px;margin:22px 0}
.flag{background:var(--red);border:1px solid var(--red);border-radius:8px;padding:13px}
.flag h4{font-size:14px;font-weight:600;color:white;margin-bottom:4px}
.flag p{font-size:14px;color:rgba(255,255,255,.92);font-weight:500;margin:0;line-height:1.5}
.gflags{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:11px;margin:22px 0}
.gflag{background:var(--green);border:1px solid var(--green);border-radius:8px;padding:13px}
.gflag h4{font-size:14px;font-weight:600;color:white;margin-bottom:4px}
.gflag p{font-size:14px;color:rgba(255,255,255,.92);font-weight:500;margin:0;line-height:1.5}

/* TIMING */
.timing{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:22px 0}
@media(max-width:500px){.timing{grid-template-columns:repeat(4,1fr)}}
.t-day{border-radius:8px;padding:11px 5px;text-align:center;font-size:15px}
.t-day .dn{font-weight:700;display:block;margin-bottom:2px}
.t-day.best{background:var(--blue-pale);color:var(--blue);border:1px solid var(--blue-soft)}
.t-day.ok{background:var(--amber-pale);color:var(--amber);border:1px solid var(--amber-soft)}
.t-day.busy{background:var(--red-pale);color:var(--red);border:1px solid var(--red-soft)}

/* CHECKLIST */
.ck{list-style:none;display:grid;gap:7px;margin:18px 0}
.ck li{display:flex;gap:11px;align-items:flex-start;background:var(--white);border:1px solid var(--rule);border-radius:7px;padding:10px 13px;font-size:15px;color:var(--ink);font-weight:600;line-height:1.55}
.ck-num{width:20px;height:20px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;font-weight:700;color:white;margin-top:1px}

/* FAQ */
.faq{margin:18px 0}
.faq-item{border:1px solid var(--rule);border-radius:10px;margin-bottom:7px;background:var(--white)}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:14px 17px;font-family:var(--sans);font-size:14.5px;font-weight:500;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;line-height:1.4}
.faq-q:hover{color:var(--orange)}
.faq-arr{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--rule);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;color:var(--ink-mid);transition:transform .25s,border-color .2s}
.faq-item.open .faq-arr{transform:rotate(45deg);border-color:var(--orange);color:var(--orange)}
.faq-a{display:none;padding:0 17px 13px;font-size:15px;color:var(--ink);font-weight:500;border-top:1px solid var(--rule);line-height:1.72}
.faq-item.open .faq-a{display:block;padding-top:12px}

/* CTA */
.cta-box{background:var(--ink);border-radius:16px;padding:44px 40px;margin:64px 0 0;color:white}
.cta-box h2{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.8rem);margin-bottom:12px;color:white}
.cta-box p{color:rgba(255,255,255,.92);font-weight:500;font-size:15px;line-height:1.75;margin-bottom:16px}
.cta-facts{list-style:none;display:grid;gap:9px;margin-bottom:30px}
.cta-facts li{display:flex;gap:10px;font-size:15px;font-weight:600;color:white}
.cta-facts li::before{content:'→';color:var(--orange);font-weight:700;flex-shrink:0}
.cta-btns{display:flex;gap:11px;flex-wrap:wrap}
.btn-main{display:inline-block;background:var(--orange);color:white;padding:14px 32px;border-radius:8px;text-decoration:none;font-weight:700;font-size:15px;letter-spacing:.02em;box-shadow:0 4px 14px rgba(232,98,42,.4)}
.btn-main:hover{background:#d4501e}
.btn-ghost{display:inline-block;color:rgba(255,255,255,.85);padding:12px 26px;border-radius:8px;text-decoration:none;font-weight:500;font-size:14.5px;border:1.5px solid rgba(255,255,255,.2)}
.btn-ghost:hover{border-color:rgba(255,255,255,.8);color:white}

@media(max-width:640px){
  .hero-inner,.toc-wrap,.article{padding-left:18px;padding-right:18px}
  .cta-box{padding:28px 20px}
  .cc-col.cheap{border-right:none;border-bottom:1px solid var(--red-soft)}
  .tbl{  display: block; overflow-x: auto; white-space: nowrap;}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.hero-inner{animation:fadeUp .45s ease both}