:root{
  --navy:#061735;--navy-2:#0b244f;--orange:#ff6b12;--orange-2:#ff8a21;--blue:#1268f3;--green:#10b981;--slate:#526070;--muted:#758195;--line:#e6edf5;--soft:#f6f8fb;--white:#fff;--shadow:0 22px 60px rgba(6,23,53,.14);--radius:22px;--radius-sm:14px;--max:1520px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--navy);background:#fff;line-height:1.5}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.container{width:min(var(--max),calc(100% - 40px));margin-inline:auto}.narrow{max-width:820px}.skip-link{position:absolute;left:-999px;top:1rem;background:var(--orange);color:white;padding:.8rem 1rem;border-radius:10px;z-index:99}.skip-link:focus{left:1rem}.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid rgba(230,237,245,.8)}.header-inner{height:76px;display:flex;align-items:center;justify-content:space-between;gap:28px}.brand{display:flex;align-items:center}.brand img{width:226px;height:auto}.main-nav{display:flex;align-items:center;gap:30px;font-weight:650}.main-nav a:not(.btn){color:#0d1832}.main-nav a:not(.btn):hover{color:var(--orange)}.nav-toggle{display:none;border:0;background:transparent;padding:8px}.nav-toggle span{display:block;width:25px;height:2px;background:var(--navy);margin:5px 0;border-radius:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.65rem;border:0;border-radius:11px;padding:15px 24px;font-weight:800;cursor:pointer;transition:.2s transform,.2s box-shadow,.2s background,.2s border}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--orange),var(--orange-2));color:#fff;box-shadow:0 12px 24px rgba(255,107,18,.28)}.btn-primary:hover{box-shadow:0 16px 34px rgba(255,107,18,.36)}.btn-outline{background:#fff;color:var(--navy);border:1px solid #d8e1ec}.btn-ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.65);color:#fff}.btn-dark{background:var(--navy);color:white;border-radius:10px;padding:12px 18px}.btn-small{padding:11px 18px;border-radius:9px}.full{width:100%}.hero{position:relative;min-height:620px;color:#fff;overflow:hidden}.hero-bg{position:absolute;inset:0;z-index:-2}.hero-bg img{width:100%;height:100%;object-fit:cover}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 40%,rgba(255,255,255,.1),transparent 28%),linear-gradient(90deg,rgba(6,23,53,.96) 0%,rgba(6,23,53,.86) 45%,rgba(6,23,53,.48) 100%);z-index:-1}.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(370px,.85fr);gap:58px;align-items:center;padding:74px 0 48px}.rating-pill{display:inline-flex;align-items:center;gap:12px;margin-bottom:20px;font-weight:700}.stars,.orange-stars{letter-spacing:2px}.stars{background:#00b67a;color:#fff;border-radius:4px;padding:2px 6px}.orange-stars{color:#ffb000}.hero h1{font-size:clamp(3rem,6.6vw,5.75rem);line-height:.96;letter-spacing:-.065em;margin:0 0 24px;max-width:780px}.hero h1 span{color:var(--orange);position:relative}.hero h1 span:after{content:"";position:absolute;left:2px;right:2px;bottom:-7px;height:5px;border-radius:99px;background:var(--orange);transform:rotate(-2deg)}.hero p{font-size:clamp(1.05rem,1.5vw,1.38rem);max-width:700px;margin:0 0 28px;color:#edf4ff}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}.icon{font-size:1.55rem;line-height:0}.play-icon{width:25px;height:25px;border:1px solid currentColor;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem}.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;padding:0;margin:0}.trust-row li{position:relative;padding-left:34px}.trust-row li:before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border:2px solid var(--green);color:var(--green);border-radius:50%;display:grid;place-items:center;font-size:.8rem;font-weight:900}.trust-row strong{display:block;font-size:.96rem}.trust-row span{display:block;color:#c9d6e8;font-size:.82rem;margin-top:3px}.search-card{background:#fff;color:var(--navy);border:1px solid rgba(255,255,255,.7);border-radius:18px;padding:28px;box-shadow:var(--shadow)}.search-card h2{margin:0 0 15px;font-size:1.35rem}.input-label{display:block;font-size:0;clip-path:inset(100%);position:absolute}.field-with-icon{height:54px;border:1px solid #dbe4ee;border-radius:10px;display:grid;grid-template-columns:38px 1fr 38px;align-items:center;padding:0 8px;background:#fff}.field-with-icon span{color:var(--blue);font-size:1.2rem;text-align:center}.field-with-icon input{border:0;outline:0;color:var(--navy);width:100%}.field-clear{border:0;background:transparent;color:#a5afbf;font-size:1.5rem;cursor:pointer}.search-card .btn-outline{height:54px;margin:13px 0 24px}.search-card fieldset{border:0;padding:0;margin:0 0 20px}.search-card legend{font-weight:850;margin-bottom:12px}.chips{display:flex;flex-wrap:wrap;gap:10px}.chips input{position:absolute;opacity:0}.chips span{display:inline-flex;border:1px solid #dbe4ee;border-radius:99px;padding:10px 15px;font-weight:750;font-size:.93rem;cursor:pointer}.chips input:checked+span{background:var(--navy);color:white;border-color:var(--navy);box-shadow:0 10px 20px rgba(6,23,53,.18)}.safe-note{text-align:center;color:#496070;font-size:.88rem;margin:16px 0 0}.results-section{background:linear-gradient(180deg,#f8fbff 0%,#fff 100%);padding:18px 0 40px}.results-layout{display:grid;grid-template-columns:230px minmax(520px,1fr) 395px;gap:24px;align-items:start}.filters,.map-card,.school-card,.content-card,.step-grid article,.review-grid article{background:#fff;border:1px solid var(--line);box-shadow:0 14px 38px rgba(6,23,53,.06)}.filters{border-radius:16px;padding:18px;position:sticky;top:94px}.filters-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.filters h2,.filters h3{margin:0}.filters h2{font-size:1.05rem}.filters h3{font-size:.95rem;margin-bottom:10px}.filters button{border:0;background:transparent;color:var(--blue);font-weight:750;cursor:pointer}.filter-group{border-top:1px solid var(--line);padding:18px 0}.filter-group:first-of-type{border-top:0;padding-top:0}.filter-label{display:flex;justify-content:space-between;font-size:.9rem}.range{width:100%;accent-color:var(--blue);margin-top:14px}.check{display:flex;gap:10px;margin:12px 0;color:#31425c;font-size:.94rem}.check input{width:18px;height:18px;accent-color:var(--blue)}.results-toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin:8px 0 16px}.results-toolbar h2{font-size:1.08rem;margin:0}.results-toolbar p{margin:4px 0 0;color:var(--muted);font-size:.92rem}.sort-label{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:.9rem}.sort-label select{background:#fff;border:1px solid #dfe8f2;border-radius:9px;padding:12px 40px 12px 12px;color:var(--navy);font-weight:700}.school-list{display:grid;gap:14px}.school-card{display:grid;grid-template-columns:185px 1fr 235px auto;gap:18px;align-items:center;border-radius:16px;padding:12px}.school-card[hidden]{display:none}.school-image-wrap{position:relative;border-radius:12px;overflow:hidden;min-height:124px}.school-image-wrap img{width:100%;height:124px;object-fit:cover}.badge{display:inline-flex;align-items:center;width:max-content;border-radius:8px;padding:6px 9px;color:white;font-weight:850;font-size:.78rem}.school-image-wrap .badge{position:absolute;top:8px;left:8px}.green{background:var(--green)}.orange{background:var(--orange)}.blue{background:var(--blue)}.favorite{position:absolute;top:8px;right:8px;border:0;background:#fff;width:36px;height:36px;border-radius:50%;font-size:1.35rem;color:var(--navy);box-shadow:0 6px 14px rgba(0,0,0,.18);cursor:pointer}.favorite.active{color:#e11d48}.school-title-row{display:flex;align-items:center;gap:8px}.school-title-row h3{font-size:1.38rem;margin:0}.school-title-row a:hover{color:var(--blue)}.verified{display:inline-grid;place-items:center;background:var(--blue);color:#fff;width:19px;height:19px;border-radius:50%;font-size:.75rem;font-weight:900}.rating-line,.meta-line,.tag-row{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.rating-line{margin:5px 0;font-size:.88rem}.success{color:#059669;font-weight:800;margin-left:5px}.meta-line{color:#5b687a;font-size:.88rem}.tag-row{margin-top:8px}.tag-row span{background:#eef3f8;color:#44546a;border-radius:99px;padding:5px 11px;font-size:.82rem;font-weight:700}.school-card blockquote{background:#f8fafc;margin:0;border-radius:12px;padding:14px;color:#31425c;font-size:.9rem}.school-card blockquote cite{display:block;color:#64748b;font-style:normal}.school-card blockquote span{display:block;color:var(--green);letter-spacing:2px;margin-top:4px}.map-card{border-radius:18px;overflow:hidden;position:sticky;top:94px}.map-card img{width:100%;height:518px;object-fit:cover}.pagination{display:flex;justify-content:center;gap:14px;align-items:center;margin:18px 0 0}.pagination button{border:0;background:#fff;color:var(--navy);border-radius:50%;width:34px;height:34px;font-weight:800;cursor:pointer}.pagination .active{background:var(--navy);color:#fff}.steps{padding:40px 0 70px}.section-heading{text-align:center;max-width:760px;margin:0 auto 28px}.eyebrow{display:inline-flex;color:var(--orange);font-weight:900;text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;margin-bottom:8px}.section-heading h2,.split-section h2,.simple-page h1{font-size:clamp(2rem,3.4vw,3.25rem);line-height:1.05;letter-spacing:-.04em;margin:0}.step-grid{display:grid;grid-template-columns:repeat(4,1fr);border-radius:22px;overflow:hidden}.step-grid article{border-radius:0;box-shadow:none;padding:28px}.step-icon{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;border:1px solid #dfe8f2;color:var(--blue);font-size:1.8rem;margin-bottom:14px}.step-grid h3{margin:0 0 8px}.step-grid p{margin:0;color:#536176}.split-section{background:var(--soft);padding:80px 0}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}.split-grid p{color:#536176;font-size:1.1rem}.feature-list{list-style:none;margin:24px 0 0;padding:0}.feature-list li{position:relative;padding-left:32px;margin:13px 0;font-weight:700}.feature-list li:before{content:"✓";position:absolute;left:0;top:1px;color:#fff;background:var(--green);border-radius:50%;width:22px;height:22px;display:grid;place-items:center;font-size:.75rem}.split-image{border-radius:24px;box-shadow:var(--shadow);width:100%;aspect-ratio:3/2;object-fit:cover}.reviews{padding:78px 0}.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.review-grid article{border-radius:18px;padding:26px}.review-grid img{width:72px;height:72px;border-radius:50%;margin-bottom:12px}.review-grid span{color:var(--green);letter-spacing:2px}.review-grid p{color:#405068;font-size:1.03rem}.faq{padding:0 0 80px}.faq details{border:1px solid var(--line);border-radius:14px;padding:18px 22px;margin:12px 0;background:#fff}.faq summary{cursor:pointer;font-weight:850}.faq p{color:#526176}.site-footer{background:var(--navy);color:white;padding:48px 0}.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px}.site-footer img{filter:brightness(0) invert(1)}.site-footer p,.site-footer a{color:#bfccdf}.site-footer nav{display:grid;gap:8px}.site-footer h3{margin:0 0 8px}.profile-page,.simple-page{background:linear-gradient(180deg,#f8fbff,#fff)}.profile-hero{padding:54px 0;background:#071a3e;color:#fff}.profile-grid{display:grid;grid-template-columns:440px 1fr;gap:44px;align-items:center}.profile-photo{border-radius:24px;box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}.back-link{display:inline-block;color:#c7d7ee;margin-bottom:14px}.profile-summary h1{font-size:clamp(2.5rem,4.6vw,4.7rem);line-height:1;margin:14px 0}.lead{font-size:1.15rem;color:#5d6b80}.profile-summary .lead{color:#dce8fb;max-width:780px}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:28px 0}.profile-stats span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:14px;color:#dce8fb}.profile-stats strong{display:block;color:#fff;font-size:1.5rem}.profile-actions{display:flex;gap:12px;flex-wrap:wrap}.profile-content{display:grid;grid-template-columns:1fr 1fr;gap:22px;padding:40px 0 72px}.content-card{border-radius:18px;padding:26px}.content-card h2{margin:0 0 12px}.content-card p{color:#526176}.price-table{display:grid;gap:10px}.price-table div{display:flex;justify-content:space-between;gap:20px;background:#f8fafc;border-radius:12px;padding:14px}.price-table span{color:#526176}.profile-map img{width:100%;border-radius:14px;max-height:360px;object-fit:cover}.simple-page{min-height:70vh;padding:64px 0}.simple-page .lead{max-width:780px}.city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}.city-grid a{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;font-weight:850;box-shadow:0 10px 26px rgba(6,23,53,.05)}.city-grid a:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-1px)}
.city-grid a.is-active{border-color:var(--navy);background:var(--navy);color:#fff}
@media (max-width:1180px){.results-layout{grid-template-columns:220px 1fr}.map-card img{height:360px}.school-card{grid-template-columns:170px 1fr auto}.trust-row{grid-template-columns:repeat(2,1fr)}}
@media (max-width:900px){.container{width:min(100% - 28px,var(--max))}.nav-toggle{display:block}.main-nav{position:absolute;right:14px;top:76px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:16px;padding:18px;display:none;align-items:flex-start;flex-direction:column;min-width:230px}.main-nav.open{display:flex}.main-nav.static{display:flex;position:static;box-shadow:none;border:0;flex-direction:row;min-width:0;padding:0}.hero-grid{grid-template-columns:1fr;padding:52px 0}.hero h1{font-size:clamp(2.8rem,11vw,4.7rem)}.results-layout{grid-template-columns:1fr}.filters,.map-card{position:static}.filters{order:2}.results-main{order:1}.map-card{order:3}.school-card{grid-template-columns:150px 1fr}.school-card .btn-dark{grid-column:2;width:max-content}.step-grid,.review-grid,.split-grid,.profile-grid,.profile-content,.footer-grid{grid-template-columns:1fr}.profile-stats{grid-template-columns:repeat(2,1fr)}.city-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.header-inner{height:68px}.brand img{width:190px}.hero{min-height:auto}.search-card{padding:20px}.hero-actions,.profile-actions{flex-direction:column}.hero-actions .btn,.profile-actions .btn{width:100%}.trust-row{grid-template-columns:1fr}.results-section{padding-top:0}.school-card{grid-template-columns:1fr;padding:12px}.school-image-wrap img{height:124px;max-height:124px;object-fit:cover;object-position:center}.school-card .btn-dark{grid-column:auto;width:100%}.results-toolbar{align-items:stretch;flex-direction:column}.sort-label{justify-content:space-between}.step-grid{border-radius:18px}.step-grid article{padding:22px}.profile-stats{grid-template-columns:1fr}.city-grid{grid-template-columns:1fr}.price-table div{display:grid}.main-nav.static a:not(.btn){display:none}}
/* Live Serper.dev states */
.state-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 14px 38px rgba(6,23,53,.06);padding:34px;text-align:center;color:var(--navy)}
.state-card h3{margin:0 0 8px;font-size:1.35rem}.state-card p{margin:.4rem auto;color:#526176;max-width:680px}.small-muted{font-size:.92rem;color:#66758b!important}.spinner{width:42px;height:42px;margin:0 auto 16px;border-radius:50%;border:3px solid #dbe8f7;border-top-color:var(--orange);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.error-card{border-color:#fecaca;background:#fff7f7}.empty-card{border-color:#dbe8f7;background:#f8fbff}.loading-card{border-color:#dbe8f7}
.school-actions{display:grid;gap:8px;align-items:center}.btn.compact{padding:10px 14px;font-size:.9rem}.mini-link{display:inline-flex;align-items:center;justify-content:center;border:1px solid #dbe4ee;border-radius:10px;padding:10px 14px;font-weight:800;color:var(--blue);background:#fff}.mini-link:hover{border-color:var(--blue)}
.live-map{width:100%;height:518px;border:0;display:block}.map-results{position:static;background:#fff;border-top:1px solid var(--line);border-radius:0;box-shadow:none;padding:12px}.map-results ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}.map-results li{display:grid;grid-template-columns:28px 1fr auto;gap:8px;align-items:center;font-size:.86rem}.map-results span{width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;font-weight:900;display:grid;place-items:center}.map-results em{font-style:normal;color:#64748b}.map-card{min-height:360px}.map-card:has(.live-map) img{display:none}
@media (max-width:1180px){.live-map{height:360px}.map-results{position:static;border-radius:0;border-left:0;border-right:0;border-bottom:0}.school-actions{grid-column:3}}
@media (max-width:900px){.school-actions{grid-column:2;display:flex;flex-wrap:wrap}.live-map{height:340px}}
@media (max-width:620px){.school-actions{grid-column:auto;display:grid}.live-map{height:300px}.state-card{padding:24px}.map-results li{grid-template-columns:24px 1fr;}.map-results em{grid-column:2}}

/* ── Image modes, filters mobile & polish ── */
.school-image-wrap{align-self:stretch}
.school-image-wrap.is-photo,.school-image-wrap.is-logo,.school-image-wrap.is-initial{width:185px;min-width:185px;height:124px;max-height:124px}
.school-image-wrap.is-photo img,.school-image-wrap.is-initial{width:100%;height:100%;min-height:0;max-height:124px;object-fit:cover;object-position:center}
.school-image-wrap.is-logo{background:linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);display:grid;place-items:center}
.school-image-wrap.is-logo img{height:72px;width:auto;max-width:82%;max-height:72px;object-fit:contain;filter:drop-shadow(0 6px 14px rgba(6,23,53,.08))}
.school-image-wrap.is-initial{display:grid;place-items:center;background:linear-gradient(135deg,hsl(var(--school-hue,210) 62% 42%),hsl(calc(var(--school-hue,210) + 24) 58% 34%))}
.school-initials{font-size:1.8rem;font-weight:900;color:#fff;letter-spacing:.06em}
.school-profile-btn{white-space:nowrap;align-self:center}
.cbr-badge{font-size:.78rem;font-weight:800;color:#0369a1;background:#e0f2fe;border-radius:999px;padding:4px 10px}
.filters-toggle{display:none;width:100%;margin-bottom:12px;border:1px solid var(--line);background:#fff;color:var(--navy);border-radius:10px;padding:12px 14px;font-weight:800;cursor:pointer}
.review-avatar{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;font-size:1.5rem;font-weight:900;margin-bottom:12px}
.pagination{margin-top:20px;flex-wrap:wrap}
.pagination button:disabled{opacity:.35;cursor:not-allowed;transform:none}
.pagination-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:20px;color:var(--muted);font-weight:800}

/* Font Awesome icon polish */
.field-icon{display:grid;place-items:center;color:var(--blue)}
.field-icon i,.field-clear i{font-size:1rem}
.field-clear{display:grid;place-items:center;color:#a5afbf}
.chips span{display:inline-flex;align-items:center;gap:.45rem}
.chips span i{font-size:.95rem;opacity:.9}
.chips input:checked+span i{opacity:1}
.btn i,.safe-note i,.step-icon i{pointer-events:none}
.safe-note{display:flex;align-items:center;justify-content:center;gap:.5rem}
.step-icon i{font-size:1.35rem}
.meta-line i{font-size:.82rem;color:var(--blue)}

@media (max-width:1180px){
  .school-image-wrap.is-photo,.school-image-wrap.is-logo,.school-image-wrap.is-initial{width:150px;min-width:150px;height:112px;max-height:112px}
  .school-image-wrap.is-photo img,.school-image-wrap.is-initial{max-height:112px}
}

@media (max-width:900px){
  .filters-toggle{display:inline-flex}
  .filters-panel{display:none}
  .filters-panel.open{display:block;padding-top:4px}
  .school-image-wrap.is-photo,.school-image-wrap.is-logo,.school-image-wrap.is-initial{width:120px;min-width:120px;height:112px;max-height:112px}
  .school-image-wrap.is-photo img,.school-image-wrap.is-initial{max-height:112px}
}

@media (max-width:620px){
  .school-image-wrap.is-photo,.school-image-wrap.is-logo,.school-image-wrap.is-initial{width:100%;min-width:0;height:168px;max-height:168px}
  .school-image-wrap.is-photo img,.school-image-wrap.is-initial{max-height:168px}
  .school-image-wrap.is-logo img{height:88px;max-height:88px}
}

/* Hero USP row — icon + text alignment */
.hero-actions{margin-bottom:28px}
.hero-trust{
  grid-column:1 / -1;
  margin-top:4px;
}
.trust-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px 22px;
  align-items:start;
}
.trust-row li{
  display:flex;
  align-items:center;
  gap:11px;
  padding-left:0;
  min-width:0;
}
.trust-row li:before{display:none}
.trust-icon{
  flex:0 0 22px;
  width:22px;
  height:22px;
  display:grid;
  place-items:center;
  color:var(--green);
  font-size:1.15rem;
  line-height:1;
  margin-top:0;
}
.trust-copy{
  display:flex;
  flex-direction:column;
  gap:3px;
  min-width:0;
}
.trust-row strong{
  display:block;
  font-size:.94rem;
  line-height:1.25;
  letter-spacing:-.01em;
  text-wrap:balance;
}
.trust-copy > span{
  display:block;
  color:#c9d6e8;
  font-size:.8rem;
  line-height:1.35;
}

@media (max-width:900px){
  .hero-trust{grid-column:auto;margin-top:18px}
  .trust-row{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:620px){
  .trust-row{grid-template-columns:1fr;gap:14px}
}

/* ── Desktop breedte + results/map layout ── */
.container{width:min(var(--max),calc(100% - 32px))}

.results-layout{
  display:grid;
  grid-template-columns:240px minmax(0,1fr) minmax(380px,420px);
  grid-template-areas:"filters results map";
  gap:20px 24px;
  align-items:start;
}
.results-layout > .filters{grid-area:filters}
.results-layout > .results-main{grid-area:results;min-width:0;position:relative;z-index:2}
.results-layout > .map-card{
  grid-area:map;
  grid-column:auto;
  grid-row:auto;
  display:flex;
  flex-direction:column;
  position:sticky;
  top:94px;
  align-self:start;
  overflow:hidden;
  min-height:0;
  padding:0;
  width:100%;
  max-width:420px;
  justify-self:stretch;
}
.map-frame{
  position:relative;
  width:100%;
  aspect-ratio:1;
  min-height:340px;
  max-height:min(72vh,520px);
  background:#eef2f7;
  flex-shrink:0;
}
.live-map{
  width:100%;
  height:100%;
  min-height:340px;
  border:0;
  display:block;
}
.map-results{
  position:static;
  inset:auto;
  right:auto;
  bottom:auto;
  left:auto;
  margin:0;
  border-radius:0;
  border:0;
  border-top:1px solid var(--line);
  box-shadow:none;
  backdrop-filter:none;
  background:#fff;
  padding:12px 14px 14px;
  flex-shrink:0;
}
.map-results ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.map-results-footer{margin-top:10px}
.map-list-btn{
  width:100%;
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
  padding:11px 14px;
  font-weight:800;
  color:var(--navy);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  transition:border-color .2s,background .2s;
}
.map-list-btn:hover{border-color:var(--navy);background:#f8fafc}

/* Onder 1280px: kaart onder de lijst, nooit ernaast/over elkaar */
@media (max-width:1280px){
  .results-layout{
    grid-template-columns:220px minmax(0,1fr);
    grid-template-areas:
      "filters results"
      "filters map";
  }
  .results-layout > .map-card{
    position:static;
    top:auto;
    max-width:none;
    justify-self:stretch;
    grid-column:auto;
    grid-row:auto;
    grid-area:map;
  }
  .map-frame{
    aspect-ratio:16/9;
    min-height:260px;
    max-height:none;
  }
  .live-map{min-height:260px;height:100%}
}

@media (max-width:900px){
  .container{width:min(100% - 28px,var(--max))}
  .results-layout{
    grid-template-columns:1fr;
    grid-template-areas:
      "results"
      "filters"
      "map";
  }
  .results-layout > .map-card{max-width:none}
  .map-frame{aspect-ratio:16/10;min-height:240px}
  .live-map{min-height:240px}
}

/* ── School cards ── */
.school-card{
  grid-template-columns:185px minmax(0,1fr);
  grid-template-areas:"media body";
  gap:16px 20px;
  align-items:start;
}
.school-card.has-cbr{
  grid-template-areas:
    "media body"
    "cbr cbr";
  row-gap:14px;
}
.school-image-wrap{grid-area:media;overflow:hidden;isolation:isolate}
.school-body{grid-area:body;min-width:0;display:flex;flex-direction:column;gap:0}
.school-card-cbr{grid-area:cbr;min-width:0}
.school-website-link{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  margin-top:10px;
  font-size:.86rem;
  font-weight:750;
  color:var(--blue);
  width:max-content;
}
.school-website-link:hover{text-decoration:underline;color:#0b4fd1}
.school-website-link i{font-size:.75rem}
.school-lead-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  margin-top:12px;
  padding:11px 16px;
  border:0;
  border-radius:12px;
  background:var(--orange);
  color:#fff;
  font:inherit;
  font-size:.9rem;
  font-weight:800;
  cursor:pointer;
  width:max-content;
  transition:background .15s ease,transform .15s ease;
}
.school-lead-btn:hover{background:#e86f12}
.school-lead-btn:disabled{opacity:.7;cursor:not-allowed}
.school-lead-btn-submit{width:100%}
.lead-modal-intro{margin:0 0 14px;color:#475569;line-height:1.5;font-size:.92rem}
.lead-form{display:grid;gap:12px}
.lead-form label{display:grid;gap:6px;font-size:.84rem;font-weight:650;color:var(--navy)}
.lead-form label em{font-style:normal;font-weight:500;color:#64748b}
.lead-form input,
.lead-form textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:10px;
  font:inherit;
  background:#fff;
}
.lead-form input:focus,
.lead-form textarea:focus{
  outline:2px solid rgba(15,76,129,.15);
  border-color:var(--blue);
}
.lead-consent{
  display:grid !important;
  grid-template-columns:18px 1fr;
  gap:10px !important;
  align-items:start;
  font-weight:500 !important;
  color:#475569 !important;
}
.lead-consent input{margin-top:2px}
.lead-form-status{
  margin:0;
  font-size:.84rem;
  color:#64748b;
}
.lead-form-status.is-error{color:#b91c1c}
.lead-success{
  text-align:center;
  padding:18px 8px 8px;
}
.lead-success-icon{
  width:56px;height:56px;margin:0 auto 12px;border-radius:50%;
  display:grid;place-items:center;background:#ecfdf5;color:#059669;font-size:1.6rem;
}
.lead-success h3{margin:0 0 8px}
.lead-success p{margin:0 0 16px;color:#475569}
.school-card blockquote.school-card-aside{
  margin:0;
  background:#f8fafc;
  border-radius:12px;
  padding:14px;
  color:#31425c;
  font-size:.88rem;
  line-height:1.45;
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:124px;
}
.school-card blockquote cite{
  display:block;
  color:#64748b;
  font-style:normal;
  margin-top:6px;
  font-size:.82rem;
}
.school-card blockquote .orange-stars{
  margin-top:6px;
  font-size:.82rem;
}
.school-image-wrap .badge{
  z-index:2;
  max-width:calc(100% - 44px);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.favorite{
  z-index:3;
  display:grid;
  place-items:center;
  width:32px;
  height:32px;
  padding:0;
  font-size:.95rem;
  line-height:1;
}
.favorite.active{color:#e11d48}
.verified{
  display:inline-grid;
  place-items:center;
  font-size:.72rem;
}
.verified i{line-height:1}

@media (max-width:1180px){
  .school-card{
    grid-template-columns:150px minmax(0,1fr);
  }
}

@media (max-width:900px){
  .school-card{
    grid-template-columns:120px minmax(0,1fr);
    gap:12px 14px;
  }
}

@media (max-width:620px){
  .school-card{
    grid-template-columns:1fr;
    grid-template-areas:
      "media"
      "body"
      "cbr";
  }
  .school-card.has-cbr{
    grid-template-areas:
      "media"
      "body"
      "cbr";
  }
}

/* CBR profile donut chart */
.cbr-profile{
  display:flex;
  flex-direction:column;
  gap:12px;
  background:#fff;
  border-top:1px solid var(--line);
  margin-top:2px;
  padding-top:14px;
}
.cbr-head{
  display:flex;
  align-items:center;
  gap:14px;
}
.cbr-ring{
  position:relative;
  width:72px;
  height:72px;
  flex:0 0 72px;
}
.cbr-ring svg{
  width:100%;
  height:100%;
  display:block;
}
.cbr-ring-track{
  fill:none;
  stroke:#e8edf3;
  stroke-width:3.2;
}
.cbr-ring-progress{
  fill:none;
  stroke:var(--navy);
  stroke-width:3.2;
  stroke-linecap:round;
}
.cbr-ring-value{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  font-size:1.02rem;
  font-weight:800;
  color:var(--navy);
  letter-spacing:-.03em;
}
.cbr-details{
  min-width:0;
  flex:1;
}
.cbr-details h4{
  margin:0 0 4px;
  font-size:.98rem;
  font-weight:800;
  color:var(--navy);
}
.cbr-location-text{
  margin:0;
  font-size:.9rem;
  font-weight:700;
  color:var(--blue);
  text-decoration:underline;
  line-height:1.3;
}
.cbr-stat-rows{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cbr-stat-row{
  margin:0;
  background:#f3f5f8;
  border-radius:10px;
  padding:12px 14px;
  font-size:.86rem;
  line-height:1.45;
  color:#526176;
}
.cbr-stat-row strong{
  color:var(--navy);
  font-weight:800;
}
.cbr-location-note{
  margin:0;
  font-size:.8rem;
  line-height:1.4;
  color:#6b7c90;
}

@media (max-width:1180px){
  .cbr-profile{padding:12px}
  .cbr-ring{width:66px;height:66px;flex-basis:66px}
}

.map-results-note{
  margin:0 0 8px;
  font-size:.78rem;
  color:#64748b;
}
.map-results li{
  display:block;
}
.map-school-link{
  width:100%;
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:8px 10px;
  margin:0;
  border:1px solid transparent;
  border-radius:12px;
  background:transparent;
  color:inherit;
  text-align:left;
  cursor:pointer;
  font:inherit;
  transition:background .15s ease,border-color .15s ease;
}
.map-school-link:hover,
.map-school-link:focus-visible{
  background:#f8fafc;
  border-color:var(--line);
  outline:none;
}
.map-rank{
  flex:0 0 24px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--navy);
  color:#fff;
  font-weight:900;
  font-size:.78rem;
  display:grid;
  place-items:center;
}
.map-rank.is-accent{background:var(--orange)}
.map-school{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.map-school strong{
  font-size:.84rem;
  line-height:1.35;
  display:block;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.school-card.is-highlighted{
  outline:3px solid var(--orange);
  outline-offset:2px;
  border-radius:18px;
}

.rating-line-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin:0;
  padding:4px 8px;
  margin-left:-8px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:inherit;
  cursor:pointer;
  font:inherit;
  text-align:left;
  transition:background .15s ease;
}
.rating-line-btn:hover,
.rating-line-btn:focus-visible{
  background:#f1f5f9;
  outline:none;
}
.rating-line-btn span:last-child{
  text-decoration:underline;
  text-decoration-color:rgba(15,76,129,.35);
  text-underline-offset:2px;
}

body.reviews-modal-open{overflow:hidden}
.reviews-modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:grid;
  place-items:center;
  padding:20px;
}
.reviews-modal[hidden]{display:none}
.reviews-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(15,23,42,.55);
  backdrop-filter:blur(2px);
}
.reviews-modal-panel{
  position:relative;
  width:min(560px,100%);
  max-height:min(82vh,760px);
  overflow:auto;
  background:#fff;
  border-radius:20px;
  box-shadow:0 24px 60px rgba(15,23,42,.22);
  border:1px solid var(--line);
}
.reviews-modal-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:20px 20px 12px;
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  background:#fff;
  z-index:1;
}
.reviews-modal-eyebrow{
  margin:0 0 4px;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:#64748b;
}
.reviews-modal-header h2{
  margin:0;
  font-size:1.15rem;
  line-height:1.3;
}
.reviews-modal-close{
  flex:0 0 36px;
  width:36px;
  height:36px;
  border:1px solid var(--line);
  border-radius:50%;
  background:#fff;
  color:var(--navy);
  cursor:pointer;
  display:grid;
  place-items:center;
}
.reviews-modal-close:hover{background:#f8fafc}
.reviews-modal-summary{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:12px 20px 0;
  font-size:.92rem;
}
.reviews-modal-body{padding:12px 20px 20px}
.reviews-modal-note{
  margin:0 0 12px;
  font-size:.8rem;
  color:#64748b;
}
.reviews-modal-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:14px;
}
.review-item{
  padding:14px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fafcff;
}
.review-item-head{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom:8px;
}
.review-avatar{
  flex:0 0 40px;
  width:40px;
  height:40px;
  border-radius:50%;
  object-fit:cover;
}
.review-avatar-fallback{
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff;
  font-weight:800;
  font-size:.95rem;
}
.review-item-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:0;
}
.review-item-meta strong{font-size:.9rem}
.review-item-rating{
  font-size:.82rem;
  color:#64748b;
}
.review-item-rating em{
  font-style:normal;
  font-weight:700;
  color:var(--navy);
}
.review-item-meta time{
  font-size:.78rem;
  color:#94a3b8;
}
.review-item-text{
  margin:0;
  font-size:.9rem;
  line-height:1.55;
  color:#334155;
  white-space:pre-wrap;
}
.reviews-modal-loading,
.reviews-modal-error,
.reviews-modal-empty{
  padding:24px 0;
  text-align:center;
  color:#64748b;
}
.reviews-modal-loading .spinner{margin:0 auto 12px}
.map-school em{
  font-style:normal;
  color:#64748b;
  font-size:.78rem;
}

/* Brand logo */
.brand img{width:240px;height:auto;max-height:58px;object-fit:contain}
.site-footer img.footer-logo{
  filter:none;
  width:200px;
  height:auto;
  max-height:48px;
  object-fit:contain;
  background:#fff;
  border-radius:10px;
  padding:8px 12px;
}
@media (max-width:620px){
  .brand img{width:190px;max-height:46px}
}

.partner-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin:24px 0;
}
.partner-card h2{margin:0 0 8px}
.partner-price{
  margin:0 0 14px;
  font-size:1.8rem;
  font-weight:900;
  color:var(--navy);
}
.partner-price span{font-size:.95rem;font-weight:600;color:#64748b}
.partner-card ul{
  margin:0 0 18px;
  padding-left:18px;
  color:#475569;
  display:grid;
  gap:6px;
}
.partner-steps{
  margin:0;
  padding-left:20px;
  display:grid;
  gap:8px;
  color:#475569;
}
@media (max-width:720px){
  .partner-grid{grid-template-columns:1fr}
}

.pricing-page{max-width:1180px}
.pricing-section-title{margin:32px 0 8px;font-size:1.35rem;color:var(--navy)}
.pricing-section-intro{margin:0 0 18px;color:#64748b;max-width:720px}
.pricing-partner-row{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:0 0 8px;
}
.partner-card--featured{border-color:var(--orange);box-shadow:0 12px 32px rgba(249,115,22,.12)}
.partner-leads{margin:-6px 0 12px;font-weight:700;color:var(--orange)}
.pricing-loading{color:#94a3b8;margin:0}
.pricing-flex-card{margin-top:8px}
.pricing-flex-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.pricing-flex-label{display:block;font-weight:700;margin-bottom:8px;color:var(--navy)}
.pricing-flex-input{
  width:100%;max-width:200px;padding:12px 14px;border:1px solid #dbeafe;border-radius:10px;
  font-size:1.2rem;font-weight:800;color:var(--navy);
}
.pricing-flex-quote{margin:12px 0 16px;font-size:1.05rem;color:#475569}
.pricing-quote-total{color:var(--navy);font-size:1.15rem}
.pricing-quote-error{color:#b91c1c}
.pricing-quote-note{color:#64748b;font-size:.9rem}
.pricing-tier-table{margin-top:8px}
.pricing-overview-wrap{margin:12px 0 28px;overflow:auto}
.pricing-overview-table{min-width:720px}
@media (max-width:980px){
  .pricing-partner-row{grid-template-columns:repeat(2,minmax(0,1fr))}
  .pricing-flex-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .pricing-partner-row{grid-template-columns:1fr}
}

.admin-settings-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.admin-inline-input{width:100%;padding:6px 8px;border:1px solid #dbeafe;border-radius:8px}
.admin-inline-input--short{max-width:110px}
.admin-pricing-add{margin-top:16px;padding-top:16px;border-top:1px solid #e2e8f0}
.admin-pricing-config{margin-bottom:8px}
@media (max-width:720px){
  .admin-settings-grid-3{grid-template-columns:1fr}
}

.lead-detail-card{margin-top:18px}
.lead-dl{display:grid;gap:12px;margin:0}
.lead-dl div{display:grid;gap:4px}
.lead-dl dt{font-size:.78rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.03em}
.lead-dl dd{margin:0}
.lead-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.lead-badge{display:inline-block;margin:8px 0 0;padding:6px 10px;border-radius:999px;font-size:.78rem;font-weight:800}
.lead-badge-free{background:#ecfdf5;color:#047857}
.lead-badge-paid{background:#eff6ff;color:#1d4ed8}
.lead-lock-note{margin:14px 0;color:#64748b}
.lead-footnote{margin-top:18px;color:#64748b;font-size:.88rem}

.admin-page{padding-top:28px;padding-bottom:40px}
.admin-login-body{
  min-height:100vh;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(255,107,18,.12), transparent 60%),
    linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
}
.admin-login-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px 16px;
}
.admin-login-card{
  width:min(100%, 420px);
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.admin-login-inner{
  padding:36px 32px 32px;
  display:grid;
  gap:24px;
}
.admin-login-brand{
  display:flex;
  justify-content:center;
}
.admin-login-brand img{
  width:min(200px, 70vw);
  height:auto;
}
.admin-login-head{
  text-align:center;
  display:grid;
  gap:10px;
}
.admin-login-icon{
  width:52px;
  height:52px;
  margin:0 auto;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg, var(--navy), var(--blue));
  color:#fff;
  font-size:1.25rem;
}
.admin-login-head h1{
  margin:0;
  font-size:1.5rem;
  letter-spacing:-.02em;
}
.admin-login-head p{
  margin:0;
  color:#64748b;
  font-size:.92rem;
  line-height:1.55;
}
.admin-login-form{
  display:grid;
  gap:16px;
}
.admin-login-field{
  display:grid;
  gap:8px;
}
.admin-login-field > span{
  font-size:.84rem;
  font-weight:700;
  color:var(--navy);
}
.admin-login-input-wrap{
  position:relative;
  display:flex;
  align-items:center;
}
.admin-login-input-wrap i{
  position:absolute;
  left:14px;
  color:#94a3b8;
  font-size:.9rem;
  pointer-events:none;
}
.admin-login-input-wrap input{
  width:100%;
  padding:13px 14px 13px 42px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#f8fafc;
  color:var(--navy);
  transition:border-color .15s, box-shadow .15s, background .15s;
}
.admin-login-input-wrap input:focus{
  outline:none;
  border-color:var(--blue);
  background:#fff;
  box-shadow:0 0 0 3px rgba(18,104,243,.12);
}
.admin-login-input-wrap input::placeholder{
  color:#94a3b8;
}
.admin-login-submit{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 18px;
  font-size:1rem;
}
.admin-login-error{
  margin:0;
  padding:10px 12px;
  border-radius:10px;
  background:#fef2f2;
  color:#b91c1c;
  font-size:.88rem;
  text-align:center;
}
.admin-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}
.admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.admin-stats .content-card{display:grid;gap:4px;padding:16px}
.admin-stats strong{font-size:1.5rem;color:var(--navy)}
.admin-stats span{color:#64748b;font-size:.88rem}
.admin-filters{margin-bottom:18px}
.admin-filter-form{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;align-items:end}
.admin-filter-form label{display:grid;gap:6px;font-size:.84rem;font-weight:650}
.admin-filter-form input,.admin-filter-form select{padding:10px 12px;border:1px solid var(--line);border-radius:10px}
.admin-section{margin-bottom:18px}
.admin-section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.admin-enrich-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.admin-enrich-btn{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.admin-enrich-stop{white-space:nowrap}
.admin-enrich-note{margin:0 0 12px;font-size:.88rem;color:#64748b}
.admin-enrich-note.is-success{color:#047857}
.admin-enrich-note.is-error{color:#b91c1c}
.admin-email-form{display:flex;gap:6px;align-items:center;min-width:220px}
.admin-email-form input{
  flex:1;min-width:0;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:.82rem;
}
.admin-email-save{padding:8px 10px!important;font-size:.78rem!important;white-space:nowrap}
.admin-enrich-current{margin-top:0!important;color:var(--navy)!important;font-weight:600}
.admin-table tr.admin-row-new-email td{
  background:linear-gradient(90deg,rgba(255,107,18,.07),rgba(255,107,18,.02));
}
.admin-table tr.admin-row-new-email .admin-email-form input{
  border-color:rgba(255,107,18,.35);
  background:#fffaf6;
  box-shadow:inset 3px 0 0 var(--orange);
}
.admin-table-wrap{overflow:auto}
.admin-table{width:100%;border-collapse:collapse;font-size:.86rem}
.admin-table th,.admin-table td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.admin-table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;color:#64748b;background:#f8fafc}
.admin-table small{display:block;color:#64748b;margin-top:4px}
.admin-pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:800}
.admin-pill-free{background:#ecfdf5;color:#047857}
.admin-pill-paid{background:#eff6ff;color:#1d4ed8}
.admin-pill-locked{background:#fff7ed;color:#c2410c}
@media (max-width:1100px){
  .admin-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .admin-filter-form{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:620px){
  .admin-stats{grid-template-columns:1fr}
  .admin-filter-form{grid-template-columns:1fr}
  .admin-login-inner{padding:28px 22px 24px}
}

/* Zoeken / uitbreiden na filter */
.results-section{scroll-margin-top:88px}
.expand-banner-wrap{margin-bottom:16px}
.expand-banner{
  display:flex;align-items:center;gap:18px;
  padding:18px 20px;border-radius:16px;
  background:linear-gradient(135deg,#eff6ff,#f8fafc);
  border:1px solid #dbeafe;
  box-shadow:0 10px 30px rgba(6,23,53,.06);
}
.expand-banner-text{display:grid;gap:4px;flex:1;min-width:0}
.expand-banner-text strong{color:var(--navy);font-size:1rem}
.expand-banner-text p{margin:0;color:#64748b;font-size:.88rem}
.car-loader{position:relative;width:72px;height:40px;flex-shrink:0}
.car-loader-icon{
  position:absolute;left:0;top:50%;transform:translateY(-50%);
  font-size:1.35rem;color:var(--orange);
  animation:car-drive 1.4s ease-in-out infinite;
}
.car-loader-road{
  position:absolute;left:0;right:0;bottom:4px;height:3px;
  background:repeating-linear-gradient(90deg,#cbd5e1 0 8px,transparent 8px 16px);
  animation:road-scroll 0.7s linear infinite;
}
@keyframes car-drive{
  0%,100%{left:0;transform:translateY(-50%) scaleX(1)}
  49%{left:calc(100% - 28px);transform:translateY(-50%) scaleX(1)}
  50%{left:calc(100% - 28px);transform:translateY(-50%) scaleX(-1)}
  99%{left:0;transform:translateY(-50%) scaleX(-1)}
}
@keyframes road-scroll{to{background-position:16px 0}}

/* Admin e-mail voortgang */
.admin-progress-wrap{display:grid;gap:8px;margin:0 0 14px}
.admin-progress-track{height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}
.admin-progress-bar{
  height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--orange-2));
  transition:width .25s ease;
}
.admin-progress-meta{display:flex;justify-content:space-between;gap:12px;font-size:.84rem;color:#64748b;flex-wrap:wrap}
.admin-progress-meta strong{color:var(--navy)}

/* Affiliate banners */
.affiliate-strip{
  background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:8px 16px;text-align:center;
}
.affiliate-strip--footer{border-top:1px solid #e2e8f0;border-bottom:0;margin-top:8px}
.affiliate-slot{margin:12px 0}
.affiliate-slot--sidebar{margin-top:16px;padding-top:12px;border-top:1px solid #e2e8f0}
.affiliate-slot--hero{margin-top:14px}
.affiliate-slot--results{margin:0 0 16px}
.affiliate-slot--inline{margin:8px 0 16px}
.affiliate-banner{
  display:block;border-radius:12px;overflow:hidden;
  box-shadow:0 6px 20px rgba(6,23,53,.06);transition:transform .15s ease, box-shadow .15s ease;
}
.affiliate-banner:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(6,23,53,.1)}
.affiliate-banner img{display:block;width:100%;height:auto;max-height:120px;object-fit:contain;background:#fff}
.affiliate-banner--sidebar img,.affiliate-banner--results_top img{max-height:96px}
.affiliate-banner--header img{max-height:52px;margin:0 auto}
.affiliate-banner--footer img{max-height:72px;margin:0 auto}
.affiliate-html-banner{width:100%;display:flex;justify-content:center;margin:0 auto}
.affiliate-html-banner .haal-banner{max-width:100%;width:min(825px,100%);height:auto;min-height:80px;flex-wrap:wrap;padding:12px 16px;gap:12px}
.affiliate-html-banner .haal-logo{min-width:0;font-size:clamp(18px,3vw,27px)}
.affiliate-html-banner .headline{font-size:clamp(16px,2.8vw,28px);white-space:normal}
.affiliate-html-banner .subline{font-size:clamp(12px,2vw,15px)}
.affiliate-html-banner .cta{min-width:120px;height:48px;font-size:clamp(14px,2.2vw,21px)}
@media (max-width:720px){
  .affiliate-html-banner .haal-banner{flex-direction:column;text-align:center;min-height:0}
  .affiliate-html-banner .haal-logo,.affiliate-html-banner .haal-content,.affiliate-html-banner .cta{width:100%;justify-content:center}
}

/* Admin tabs & settings */
.admin-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.admin-tab{
  border:1px solid #dbeafe;background:#fff;color:var(--navy);
  padding:10px 14px;border-radius:999px;font-weight:600;cursor:pointer;
}
.admin-tab.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.admin-settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:0 0 16px}
.admin-settings-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:760px){.admin-settings-grid-2{grid-template-columns:1fr}}
.admin-settings-page{display:grid;gap:18px}
.admin-settings-section{padding:0;overflow:hidden}
.admin-settings-section-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
  padding:20px 22px 0;margin-bottom:14px;
}
.admin-settings-section-head h2{margin:0 0 4px;font-size:1.15rem}
.admin-settings-section-head p{margin:0;color:#64748b;font-size:.88rem}
.admin-settings-section .admin-settings-grid,.admin-settings-section .admin-settings-toggles,.admin-settings-section .admin-check{padding:0 22px 20px}
.admin-settings-toggles{display:grid;gap:10px}
.admin-settings-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding-bottom:8px}
.admin-settings-testmail{background:linear-gradient(180deg,#fff,#f8fafc)}
.admin-testmail-row{
  display:grid;grid-template-columns:1fr minmax(220px,280px) auto;gap:12px;align-items:end;
  padding:0 22px 20px;
}
@media (max-width:900px){.admin-testmail-row{grid-template-columns:1fr}}
.admin-testmail-email,.admin-testmail-type{margin:0}
.admin-settings-grid label{display:grid;gap:6px;font-size:.88rem;color:#475569}
.admin-settings-grid input,.admin-settings-grid select{
  width:100%;padding:10px 12px;border:1px solid #dbeafe;border-radius:10px;
}
.admin-check{display:flex!important;align-items:center;gap:8px}
.admin-affiliate-thumb{max-width:120px;max-height:48px;border-radius:8px;object-fit:contain;background:#f8fafc}
.admin-affiliates-intro{margin:.35rem 0 0;color:#64748b;font-size:.92rem}
.admin-affiliate-table td{vertical-align:middle}
.admin-affiliate-link-cell{max-width:180px;word-break:break-all;font-size:.84rem}
.admin-affiliate-actions{display:flex;gap:8px;flex-wrap:wrap}
.admin-empty-cell{padding:28px!important;text-align:center;color:#64748b}
.admin-btn-danger{color:#b91c1c;border-color:#fecaca}
.admin-btn-danger:hover{background:#fef2f2}

.admin-dialog{
  border:none;border-radius:18px;padding:0;max-width:560px;width:calc(100% - 32px);
  box-shadow:0 24px 60px rgba(6,23,53,.22);overflow:hidden;
}
.admin-dialog::backdrop{background:rgba(6,23,53,.5);backdrop-filter:blur(2px)}
.admin-dialog-form{display:flex;flex-direction:column;max-height:min(92vh,760px)}
.admin-dialog-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 22px;border-bottom:1px solid #e2e8f0;background:#f8fafc;
}
.admin-dialog-header h3{margin:0;font-size:1.15rem;color:var(--navy)}
.admin-dialog-close{
  width:36px;height:36px;border:none;border-radius:10px;background:#fff;color:#64748b;
  cursor:pointer;display:grid;place-items:center;box-shadow:0 1px 0 #e2e8f0;
}
.admin-dialog-close:hover{background:#f1f5f9;color:var(--navy)}
.admin-dialog-body{padding:20px 22px;display:grid;gap:14px;overflow:auto}
.admin-field{display:grid;gap:6px}
.admin-field>span{font-size:.84rem;font-weight:650;color:#475569}
.admin-field input,.admin-field select{
  width:100%;padding:11px 12px;border:1px solid #dbeafe;border-radius:10px;background:#fff;
}
.admin-field input:focus,.admin-field select:focus{
  outline:2px solid rgba(255,106,0,.25);border-color:var(--orange);
}
.admin-field-hint{margin:0;font-size:.78rem;color:#94a3b8}
.admin-field-inline{max-width:140px}
.admin-field-check{align-items:center}
.admin-upload-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.admin-file-btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;
  background:var(--navy);color:#fff;font-weight:650;font-size:.88rem;cursor:pointer;
}
.admin-file-btn:hover{background:#0f2744}
.admin-file-name{font-size:.84rem;color:#64748b}
.admin-image-preview{
  border:1px dashed #cbd5e1;border-radius:12px;padding:12px;background:#f8fafc;text-align:center;
}
.admin-image-preview img{max-height:120px;width:auto;margin:0 auto;border-radius:8px}
.admin-dialog-actions{
  display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid #e2e8f0;background:#fff;
}
.admin-dialog .btn-primary{
  background:var(--orange);color:#fff;border:none;box-shadow:none;
  padding:.72rem 1.2rem;border-radius:10px;font-weight:700;cursor:pointer;
}
.admin-dialog .btn-primary:hover{background:var(--orange-2)}
.admin-dialog .btn-primary:disabled{opacity:.65;cursor:not-allowed}
.admin-dialog .btn-outline{
  background:#fff;border:1px solid #dbeafe;color:var(--navy);padding:.72rem 1.1rem;border-radius:10px;cursor:pointer;
}
.btn-small{padding:6px 10px;font-size:.82rem}
.admin-dialog--wide{max-width:min(920px,96vw)}
.admin-html-editor{
  width:100%;min-height:220px;padding:12px;border:1px solid #dbeafe;border-radius:10px;
  font-family:Consolas,Monaco,monospace;font-size:.82rem;line-height:1.45;resize:vertical;
}
.admin-html-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.admin-html-live-preview{margin-top:4px}
.admin-html-live-preview-label{display:block;font-size:.82rem;font-weight:600;color:#64748b;margin-bottom:8px}
.admin-html-live-preview-frame{
  padding:12px;border:1px dashed #cbd5e1;border-radius:12px;background:#f8fafc;overflow:auto;
}
.admin-html-preview-empty{margin:0;color:#94a3b8;font-size:.88rem}
.admin-affiliates-intro code{font-size:.85em;background:#f1f5f9;padding:2px 6px;border-radius:4px}
