:root{
  --ivory:#FAF7F1;--ivory-2:#F2EDE3;--ink:#181611;--ink-soft:#42403A;
  --bronze:#A98A5B;--bronze-dark:#8A6F45;--bronze-light:#E4CFA7;
  --line:rgba(24,22,17,.12);--white:#FFFFFF;
  --serif:'Fraunces',serif;--sans:'Jost',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--ivory);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:var(--sans);cursor:pointer}
::selection{background:var(--bronze-light)}

.wrap{max-width:1380px;margin:0 auto;padding:0 44px}
.content-narrow{max-width:820px}
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--bronze-dark);font-weight:500}
.h-display{font-family:var(--serif);font-weight:300;line-height:1.04;letter-spacing:-.01em}
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.btn{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--ink);background:var(--ink);color:var(--ivory);padding:17px 38px;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;transition:all .4s}
.btn:hover{background:var(--bronze);border-color:var(--bronze);color:#fff}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--ivory)}
.btn.light{background:transparent;border-color:rgba(255,255,255,.65);color:#fff}
.btn.light:hover{background:#fff;color:var(--ink);border-color:#fff}
.page-top{padding-top:130px}

/* ---------- nav ---------- */
#homz-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:28px 0;transition:all .45s}
#homz-nav .wrap{display:flex;align-items:center;justify-content:space-between}
#homz-nav.solid{background:rgba(250,247,241,.94);backdrop-filter:blur(16px);padding:15px 0;border-bottom:1px solid var(--line)}
.logo{font-family:var(--serif);font-size:22px;letter-spacing:.05em;color:#fff;transition:color .4s;display:flex;align-items:baseline;gap:9px}
.logo b{font-weight:500;letter-spacing:.15em}
.logo span{font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;opacity:.7;font-family:var(--sans)}
#homz-nav.solid .logo{color:var(--ink)}
.nav-links{display:flex;gap:40px;align-items:center}
.nav-links a{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.88);font-weight:500;transition:color .3s}
.nav-links a:hover{color:#fff}
#homz-nav.solid .nav-links a{color:var(--ink-soft)}
#homz-nav.solid .nav-links a:hover{color:var(--bronze-dark)}
.nav-cta{border:1px solid rgba(255,255,255,.55);padding:11px 24px !important;color:#fff !important}
#homz-nav.solid .nav-cta{border-color:var(--ink);color:var(--ink) !important}
.nav-cta:hover{background:var(--bronze);border-color:var(--bronze) !important;color:#fff !important}

/* ---------- hero ---------- */
.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('https://unsplash.com/photos/hap-fa_gV1A/download?force=true&w=2200') center/cover;transform:scale(1.05);animation:heroZoom 16s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,12,8,.78) 0%,rgba(14,12,8,.12) 48%,rgba(14,12,8,.3) 100%)}
.hero .wrap{position:relative;z-index:2;padding-bottom:74px;width:100%}
.hero .eyebrow{color:var(--bronze-light);display:block;margin-bottom:24px;opacity:0;animation:fadeUp 1s .3s forwards}
.hero h1{font-size:clamp(42px,6.2vw,88px);max-width:14ch;opacity:0;animation:fadeUp 1.1s .5s forwards}
.hero h1 em{font-style:italic;color:var(--bronze-light)}
.hero p.sub{margin-top:28px;max-width:52ch;font-size:17px;font-weight:300;color:rgba(255,255,255,.88);opacity:0;animation:fadeUp 1.1s .75s forwards}
.cta-row-hero{margin-top:38px;opacity:0;animation:fadeUp 1.1s .95s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* ---------- trust strip ---------- */
.ticker{background:var(--ivory-2);border-bottom:1px solid var(--line);padding:24px 0}
.ticker-track{display:flex;justify-content:center;align-items:center;gap:26px;flex-wrap:wrap}
.ticker span{font-family:var(--serif);font-style:italic;font-size:16.5px;font-weight:300;color:var(--ink-soft)}
.ticker i{font-style:normal;font-size:8px;color:var(--bronze)}

/* ---------- intro ---------- */
.intro{padding:140px 0 120px;text-align:center}
.intro h2{font-size:clamp(32px,3.8vw,56px);max-width:23ch;margin:26px auto 0}
.intro h2 em{font-style:italic;color:var(--bronze-dark)}
.intro p{max-width:62ch;margin:30px auto 0;font-weight:300;font-size:17px;color:var(--ink-soft)}
.intro-stats{display:flex;justify-content:center;margin-top:70px;flex-wrap:wrap}
.stat{padding:0 70px;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat b{font-family:var(--serif);font-size:56px;font-weight:300;display:block;line-height:1}
.stat span{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- collection ---------- */
.collection{padding:100px 0 130px;background:var(--ivory-2)}
.coll-head{margin-bottom:48px}
.coll-head h2{font-size:clamp(34px,4.2vw,62px)}
.term-intro{max-width:70ch;font-weight:300;font-size:16.5px;color:var(--ink-soft);margin-top:18px}
.coll-layout{display:grid;grid-template-columns:290px 1fr;gap:64px;align-items:start}
.side{position:sticky;top:100px}
.fgroup{border-top:1px solid var(--line);padding:26px 0}
.fgroup:first-child{border-top:0;padding-top:0}
.fgroup h4{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);font-weight:600;margin-bottom:20px}
.range-vals{display:flex;justify-content:space-between;font-family:var(--serif);font-size:17px;margin-bottom:14px}
.range-vals small{font-family:var(--sans);font-size:11px;color:var(--ink-soft);letter-spacing:.06em}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:1px;background:linear-gradient(to right,var(--bronze) var(--fill,100%),rgba(24,22,17,.15) var(--fill,100%));outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:19px;height:19px;border-radius:50%;background:var(--ivory);border:1px solid var(--bronze-dark);cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.stepper{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);padding:10px 14px;background:var(--ivory)}
.stepper span{font-family:var(--serif);font-size:17px}
.stepper .st-btns{display:flex;gap:6px}
.stepper button{width:30px;height:30px;border:1px solid var(--line);background:transparent;font-size:15px;color:var(--ink);transition:all .25s;line-height:1}
.stepper button:hover{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.check{display:flex;align-items:center;gap:13px;padding:7px 0;cursor:pointer;font-weight:300;font-size:14.5px;color:var(--ink-soft);transition:color .25s;user-select:none}
.check:hover{color:var(--ink)}
.check .box{width:17px;height:17px;border:1px solid rgba(24,22,17,.35);flex:none;display:flex;align-items:center;justify-content:center;transition:all .25s;background:var(--ivory)}
.check.on{color:var(--ink)}
.check.on .box{background:var(--ink);border-color:var(--ink)}
.check.on .box::after{content:'';width:9px;height:5px;border-left:1.5px solid var(--bronze-light);border-bottom:1.5px solid var(--bronze-light);transform:rotate(-45deg) translateY(-1px)}
.check .cnt{margin-left:auto;font-size:11.5px;color:rgba(24,22,17,.4)}
.side-reset{width:100%;margin-top:8px;border:1px solid var(--line);background:transparent;padding:13px;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--ink-soft);transition:all .3s}
.side-reset:hover{border-color:var(--ink);color:var(--ink)}
.filter-toggle{display:none;border:1px solid var(--ink);background:transparent;padding:14px 24px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;margin-bottom:26px;width:100%}

.coll-tabs{display:flex;margin-bottom:30px;border-bottom:1px solid var(--line)}
.ctab{border:0;background:none;padding:16px 30px 18px;font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;color:var(--ink-soft);position:relative;transition:color .3s;display:flex;align-items:baseline;gap:10px}
.ctab em{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--bronze-dark);letter-spacing:0;text-transform:none}
.ctab::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--bronze);transform:scaleX(0);transition:transform .4s cubic-bezier(.16,1,.3,1);transform-origin:left}
.ctab.active{color:var(--ink)}
.ctab.active::after{transform:scaleX(1)}
.ctab:hover{color:var(--ink)}
.scope-note{font-size:13.5px;font-weight:300;color:var(--ink-soft);margin:-12px 0 28px;max-width:72ch}

.toolbar{display:flex;gap:12px;align-items:stretch;margin-bottom:34px;flex-wrap:wrap}
.tb-field{border:1px solid var(--line);background:var(--ivory);padding:12px 20px;display:flex;flex-direction:column;justify-content:center;min-width:190px}
.tb-field label{font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600}
.tb-field select{border:0;background:transparent;font-family:var(--sans);font-size:14px;outline:none;color:var(--ink)}
.tb-spacer{flex:1}
.result-line{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:26px;font-size:13px;color:var(--ink-soft)}
.result-line b{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--ink)}

/* ---------- cards ---------- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:44px 34px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{cursor:pointer}
.card-img{position:relative;overflow:hidden;aspect-ratio:16/11;background:var(--ivory)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.16,1,.3,1)}
.card:hover .card-img img{transform:scale(1.06)}
.card-curated{position:absolute;top:20px;left:20px;background:var(--ink);color:var(--bronze-light);padding:8px 15px;font-size:9.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:8px}
.card-curated::before{content:'✦';font-size:9px}
.card-body{padding:22px 2px 0}
.card-top{display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.card-loc{font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600}
.card-name{font-family:var(--serif);font-size:29px;font-weight:400;margin-top:5px;color:var(--ink)}
.card-specs{display:flex;gap:22px;margin-top:12px;font-size:13.5px;color:var(--ink-soft);font-weight:300}
.card-specs em{font-style:normal;font-family:var(--serif);font-size:16px;color:var(--ink);margin-right:5px}
.deal-line{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--bronze-dark);margin-top:10px}
.card-price{margin-top:16px;padding-top:16px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline;gap:14px;flex-wrap:wrap}
.card-price .now b{font-family:var(--serif);font-size:23px;font-weight:500}
.card-price .now span{font-size:12.5px;color:var(--ink-soft)}
.card-price .was{font-size:13px;color:rgba(24,22,17,.4);text-decoration:line-through;margin-right:10px}
.card-price .view{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600}
.empty{grid-column:1/-1;text-align:center;padding:90px 0;font-family:var(--serif);font-size:25px;font-weight:300;color:var(--ink-soft)}

/* ---------- editorial / regions / team ---------- */
.editorial{padding:150px 0}
.ed-grid{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center}
.ed-imgs{position:relative;height:640px}
.ed-imgs .im1{position:absolute;top:0;left:0;width:72%;height:78%;object-fit:cover}
.ed-imgs .im2{position:absolute;bottom:0;right:0;width:52%;height:52%;object-fit:cover;border:10px solid var(--ivory);box-shadow:0 30px 80px rgba(24,22,17,.18)}
.ed-txt h2{font-size:clamp(30px,3.6vw,50px);margin-top:24px}
.ed-txt h2 em{font-style:italic;color:var(--bronze-dark)}
.ed-txt p{margin-top:26px;font-weight:300;font-size:16.5px;color:var(--ink-soft);max-width:46ch}

.regions{padding:20px 0 140px}
.region-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.region-card{position:relative;overflow:hidden;aspect-ratio:3/4.1;display:block}
.region-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.16,1,.3,1)}
.region-card:hover img{transform:scale(1.06)}
.region-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,12,8,.62),transparent 55%)}
.region-txt{position:absolute;left:26px;right:26px;bottom:24px;z-index:2;color:#fff}
.region-txt h3{font-family:var(--serif);font-size:27px;font-weight:400}
.region-txt p{font-size:12.5px;font-weight:300;color:rgba(255,255,255,.85);margin-top:4px}
.region-txt span{display:inline-block;margin-top:12px;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze-light)}

.team{padding:140px 0;background:var(--ivory-2)}
.team-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:90px;align-items:center}
.team-photos{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.member img{width:100%;aspect-ratio:3/3.7;object-fit:cover;filter:saturate(.92)}
.member:nth-child(2){margin-top:44px}
.member h5{font-family:var(--serif);font-size:19px;font-weight:400;margin-top:14px}
.member span{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze-dark)}
.team-txt h2{font-size:clamp(30px,3.6vw,50px);margin-top:24px}
.team-txt h2 em{font-style:italic;color:var(--bronze-dark)}
.team-txt p{margin-top:26px;font-weight:300;font-size:16.5px;color:var(--ink-soft);max-width:48ch}
.team-contact{margin-top:36px;padding-top:28px;border-top:1px solid var(--line);display:flex;gap:44px;flex-wrap:wrap}
.team-contact div b{font-family:var(--serif);font-size:19px;font-weight:400;display:block}
.team-contact div span{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft)}

/* ---------- cta ---------- */
.cta{padding:150px 0;text-align:center}
.cta h2{font-size:clamp(34px,4.6vw,64px)}
.cta h2 em{font-style:italic;color:var(--bronze-dark)}
.cta p{margin:26px auto 44px;max-width:52ch;font-weight:300;font-size:17px;color:var(--ink-soft)}
.cta-row{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
footer{background:var(--ivory-2);border-top:1px solid var(--line);padding:90px 0 44px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px}
.foot-logo{font-family:var(--serif);font-size:27px}
.foot-logo b{font-weight:500}
footer p{font-size:14px;font-weight:300;color:var(--ink-soft);margin-top:16px;max-width:34ch}
footer h4{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--bronze-dark);margin-bottom:20px}
footer ul{list-style:none}
footer li{margin-bottom:11px}
footer li a{font-size:14px;font-weight:300;color:var(--ink-soft);transition:color .3s}
footer li a:hover{color:var(--bronze-dark)}
.foot-base{margin-top:76px;padding-top:28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft);flex-wrap:wrap;gap:10px}

/* ---------- villa detail ---------- */
.detail-page{background:var(--ivory)}
.detail-hero{display:grid;grid-template-columns:1.65fr 1fr;gap:8px;height:66vh;min-height:460px;padding:88px 8px 8px;overflow:hidden}
.detail-hero .main{overflow:hidden;min-height:0;min-width:0}
.detail-hero img{width:100%;height:100%;object-fit:cover}
.detail-hero .side2{display:grid;grid-template-rows:minmax(0,1fr) minmax(0,1fr);gap:8px;min-height:0;min-width:0}
.detail-hero .side2 div{overflow:hidden;position:relative;min-height:0}
.more-photos{position:absolute;bottom:16px;right:16px;background:rgba(250,247,241,.96);padding:12px 22px;font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.detail-body{display:grid;grid-template-columns:1.55fr .9fr;gap:76px;padding:76px 0 60px}
.d-loc{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600}
.d-name{font-size:clamp(36px,4.2vw,58px);margin-top:10px}
.d-specs{display:flex;gap:38px;margin:30px 0;padding:24px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);flex-wrap:wrap}
.d-spec b{font-family:var(--serif);font-size:25px;font-weight:400;display:block}
.d-spec b.d-pool{font-size:18px;padding-top:6px}
.d-spec span{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft)}
.d-desc{font-weight:300;font-size:16.5px;color:var(--ink-soft)}
.d-desc p{margin-bottom:1.2em}
.d-h{font-family:var(--serif);font-size:29px;font-weight:400;margin:54px 0 26px}
.amenities{display:grid;grid-template-columns:1fr 1fr;gap:14px 32px}
.amenity{display:flex;gap:13px;align-items:center;font-weight:300;font-size:15px;color:var(--ink-soft)}
.amenity::before{content:'—';color:var(--bronze)}
.d-gallery{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.plan-box{background:var(--ivory-2);border:1px solid var(--line);height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-family:var(--serif);font-style:italic;color:var(--ink-soft)}
.plan-box small{font-family:var(--sans);font-style:normal;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze-dark)}
.license-line{margin-top:30px;font-size:12px;color:var(--ink-soft)}
.related{padding-bottom:110px}

.book{position:sticky;top:110px;background:var(--white);border:1px solid var(--line);padding:40px;box-shadow:0 28px 80px rgba(24,22,17,.09)}
.book-deal{display:inline-block;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--bronze-dark);margin-bottom:14px}
.book-price{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.book-price b{font-family:var(--serif);font-size:38px;font-weight:400}
.book-price .was{font-size:15px;color:rgba(24,22,17,.4);text-decoration:line-through}
.book-price span.per{font-size:13px;color:var(--ink-soft)}
.book-form{margin-top:28px;display:grid;gap:12px}
.book-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.f{border:1px solid var(--line);padding:13px 16px}
.f label{display:block;font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600;margin-bottom:3px}
.f input,.f select{border:0;width:100%;background:transparent;font-family:var(--sans);font-size:14px;outline:none;color:var(--ink)}
.book .btn{width:100%;justify-content:center;margin-top:8px}
.book-alt{margin-top:16px;text-align:center;font-size:13px;color:var(--ink-soft)}
.book-alt a{color:var(--bronze-dark);font-weight:500;border-bottom:1px solid currentColor}
.book-note{margin-top:22px;padding-top:20px;border-top:1px solid var(--line);font-size:12.5px;font-weight:300;color:var(--ink-soft);display:flex;gap:10px}
.book-note::before{content:'✓';color:var(--bronze-dark);font-weight:600}
.book-success{text-align:center;padding:32px 0 12px}
.book-success .big{font-family:var(--serif);font-size:27px;margin-bottom:10px}
.book-success p{font-size:14px;font-weight:300;color:var(--ink-soft)}

/* ---------- beschikbaarheidskalender ---------- */
.cal-legend{display:flex;gap:26px;margin-bottom:18px;font-size:13px;color:var(--ink-soft);font-weight:300}
.cal-legend span{display:flex;align-items:center;gap:8px}
.cal-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.cal-dot.free{background:var(--ivory-2);border:1px solid var(--line)}
.cal-dot.busy{background:var(--ink)}
.cal-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cal{background:var(--white);border:1px solid var(--line);padding:18px}
.cal-title{font-family:var(--serif);font-size:16px;margin-bottom:10px;text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal-h{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--bronze-dark);font-weight:600;padding:3px 0}
.cal-day{font-size:11.5px;font-weight:300;padding:4px 0;border-radius:2px;color:var(--ink-soft)}
.cal-day.busy{background:var(--ink);color:var(--bronze-light)}
.cal-day.past{opacity:.32}
@media(max-width:1020px){.cal-wrap{grid-template-columns:1fr 1fr}}
@media(max-width:720px){.cal-wrap{grid-template-columns:1fr}}

/* ---------- prijstabel ---------- */
.price-table{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--line)}
.price-table th{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--bronze-dark);text-align:left;padding:13px 18px;border-bottom:1px solid var(--line);font-weight:600}
.price-table td{padding:12px 18px;border-bottom:1px solid var(--line);font-weight:300;font-size:14.5px;color:var(--ink-soft)}
.price-table td:last-child{font-family:var(--serif);font-size:16px;color:var(--ink)}
.pt-deal{font-family:var(--sans);font-style:normal;font-size:11px;color:var(--bronze-dark);margin-left:8px}

/* ---------- generic pages ---------- */
.entry{padding:60px 0 120px}
.entry-title{font-size:clamp(36px,4.5vw,60px);margin:16px 0 30px}
.entry-content{font-weight:300;font-size:16.5px;color:var(--ink-soft)}
.entry-content p{margin-bottom:1.3em}
.entry-content h2,.entry-content h3{font-family:var(--serif);font-weight:400;margin:1.6em 0 .6em;color:var(--ink)}

/* ---------- responsive ---------- */
@media(max-width:1180px){.grid,.grid-3{grid-template-columns:1fr 1fr;gap:36px 26px}}
@media(max-width:1020px){
  .coll-layout{grid-template-columns:1fr}
  .side{position:static;display:none;background:var(--ivory);border:1px solid var(--line);padding:28px}
  .side.open{display:block}
  .filter-toggle{display:block}
  .ed-grid{grid-template-columns:1fr;gap:56px}
  .ed-imgs{height:480px}
  .region-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr;gap:56px}
  .detail-body{grid-template-columns:1fr;gap:54px}
  .book{position:static}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .wrap{padding:0 22px}
  .nav-links a:not(.nav-cta){display:none}
  .grid,.grid-3{grid-template-columns:1fr}
  .stat{padding:0 30px;border-right:0}
  .intro-stats{gap:36px}
  .detail-hero{grid-template-columns:1fr;height:auto;padding-top:80px}
  .detail-hero .side2{grid-template-rows:none;grid-template-columns:1fr 1fr;height:150px}
  .toolbar .tb-field{min-width:140px;flex:1}
  .region-grid{grid-template-columns:1fr}
  .region-card{aspect-ratio:16/10}
}
