/* ── Per-school catchment page ───────────────────────────────────────────── */
.page{max-width:1080px;margin:0 auto;padding:0 24px;}
.crumb{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--ink3);padding:16px 0 4px;flex-wrap:wrap;}
.crumb a{color:var(--ink3);} .crumb a:hover{color:var(--blue);}
.crumb .sep{opacity:.5;}
.crumb b{color:var(--ink2);}

/* hero */
.shero{position:relative;border-radius:26px;overflow:hidden;margin-top:10px;
  box-shadow:var(--shadow-lg);background:linear-gradient(125deg,var(--blue-dk),var(--blue) 58%,var(--teal));}
.shero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.shero .scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(12,28,46,.80) 0%,rgba(12,28,46,.52) 42%,rgba(12,28,46,.18) 72%);}
.shero.nophoto .scrim,.shero .scrim.nophoto{background:none;}
.shero .deco{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.shero .deco i{position:absolute;border-radius:50%;background:rgba(255,255,255,.07);}
.shero-grid{position:relative;display:grid;grid-template-columns:1fr 366px;gap:34px;align-items:center;padding:38px 40px;}
.shero-text{color:#fff;min-width:0;}
.shero .tagrow{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.shero .tag{background:rgba(255,255,255,.18);color:#fff;backdrop-filter:blur(6px);font-size:12px;}
.shero .tag.solid-super{background:#FF7A1A;color:#fff;} .shero .tag.solid-catch{background:#16A65A;color:#fff;}
.shero h1{font-size:clamp(28px,3.8vw,44px);font-weight:900;letter-spacing:-1.3px;line-height:1.04;}
.shero .subline{font-size:16px;font-weight:700;opacity:.92;margin-top:14px;}

/* answer panel (sits inside hero, right column) */
.answer-panel{background:#fff;border-radius:20px;padding:22px 22px 24px;box-shadow:var(--shadow-lg);}
.answer-panel .top{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.answer-panel .qmark{width:46px;height:46px;border-radius:13px;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:24px;}
.answer-panel .verdict-badge{font-weight:900;font-size:12.5px;padding:6px 13px;border-radius:999px;letter-spacing:.2px;}
.verdict-badge.catch{background:var(--green-lt);color:var(--green-dk);}
.verdict-badge.super{background:#FFEAD8;color:#C2540C;}
.answer-panel h3{font-size:17px;font-weight:900;letter-spacing:-.4px;line-height:1.25;}
.answer-panel p{font-size:14px;font-weight:600;color:var(--ink2);line-height:1.56;margin-top:9px;}

/* facts grid */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:34px;}
.fact{background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px 16px;min-width:0;}
.fact .ic{width:32px;height:32px;border-radius:10px;background:var(--blue-lt);color:var(--blue-dk);display:flex;align-items:center;justify-content:center;margin-bottom:10px;}
.fact .k{font-size:11.5px;font-weight:800;color:var(--ink3);text-transform:uppercase;letter-spacing:.4px;}
.fact .v{font-size:15.5px;font-weight:800;color:var(--ink);margin-top:3px;line-height:1.25;word-break:break-word;}
.fact .v a{color:var(--blue);} .fact.span2{grid-column:span 2;}
.fact .star{color:var(--xp,#FFB020);}

/* section scaffold */
.sec{padding:52px 0 0;}
.sec-eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:13px;letter-spacing:.4px;
  text-transform:uppercase;color:var(--blue-dk);background:var(--blue-lt);padding:7px 14px;border-radius:999px;}
.sec h2{font-size:clamp(24px,3.4vw,34px);font-weight:900;letter-spacing:-1px;line-height:1.1;margin-top:14px;max-width:22ch;}

/* catchment split */
.catch-split{display:grid;grid-template-columns:1fr 380px;gap:30px;margin-top:24px;align-items:start;}
.catch-prose p{font-size:16px;font-weight:600;color:var(--ink2);line-height:1.7;margin-top:14px;}
.catch-prose .big-callout{background:var(--bg);border-radius:18px;padding:18px 20px;margin-top:20px;border-left:4px solid var(--blue);
  font-size:15.5px;font-weight:700;color:var(--ink);line-height:1.6;}
.catch-prose .big-callout.super{border-left-color:var(--streak);}
.catch-mapcard{background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow);position:sticky;top:90px;}
.catch-mapcard .gs-map{height:300px;}
.catch-mapcard .maptitle{font-weight:800;font-size:14px;margin:2px 2px 12px;display:flex;align-items:center;gap:8px;}
.catch-mapcard .legend{margin-top:12px;}

/* nearest */
.near-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px;}
.near-card{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:15px;transition:.12s;display:block;}
.near-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-2px);}
.near-card .nm{font-weight:900;font-size:15px;letter-spacing:-.3px;line-height:1.2;}
.near-card .mt{font-size:12.5px;color:var(--ink3);font-weight:700;margin:4px 0 9px;}
.near-card .dist{font-size:13px;font-weight:800;color:var(--blue);}

/* admissions cards */
.adm-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:22px;}
.adm{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;}
.adm .num{width:34px;height:34px;border-radius:11px;background:var(--ink);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.adm h3{font-size:16px;font-weight:900;letter-spacing:-.3px;}
.adm p{font-size:14px;font-weight:600;color:var(--ink2);line-height:1.55;margin-top:7px;}

/* faq */
.faq{margin-top:22px;display:flex;flex-direction:column;gap:10px;}
.faq details{background:#fff;border:1px solid var(--line);border-radius:15px;padding:0 20px;transition:.15s;}
.faq details[open]{box-shadow:var(--shadow-md);}
.faq summary{list-style:none;cursor:pointer;font-weight:800;font-size:16px;padding:18px 0;display:flex;justify-content:space-between;gap:16px;align-items:center;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pl{flex:none;width:24px;height:24px;border-radius:50%;background:var(--blue-lt);color:var(--blue-dk);display:flex;align-items:center;justify-content:center;font-size:18px;transition:transform .2s;}
.faq details[open] summary .pl{transform:rotate(45deg);}
.faq .ans{padding:0 0 20px;font-size:15px;font-weight:600;color:var(--ink2);line-height:1.65;}

.disclaimer{margin-top:40px;background:var(--bg);border-radius:16px;padding:16px 20px;font-size:13px;font-weight:600;color:var(--ink2);line-height:1.55;}

@media(max-width:900px){
  .facts{grid-template-columns:1fr 1fr;}
  .catch-split{grid-template-columns:1fr;}
  .catch-mapcard{position:static;}
  .near-grid,.adm-grid{grid-template-columns:1fr;}
  .shero-grid{grid-template-columns:1fr;gap:20px;padding:24px 22px;}
}
