/* Château Portofino — chateauportofino.com */
:root{
  --green:#0d3b2e; --green-deep:#082a20; --green-soft:#11503e;
  --gold:#c8a04b; --gold-soft:#e3c98a;
  --paper:#f7f4ed; --ink:#1b231f; --muted:#5c6660;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
  --max:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--green-soft)}
h1,h2,h3,.serif{font-family:var(--serif);font-weight:500;line-height:1.15;color:var(--green)}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem);margin-bottom:.6em}
h3{font-size:1.35rem;margin:1.6em 0 .5em}
p{margin-bottom:1.1em}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.narrow{max-width:760px}
section{padding:84px 0}
.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.lead{font-size:1.18rem;color:var(--muted)}

/* header */
header.site{position:absolute;top:0;left:0;right:0;z-index:50;padding:22px 0}
header.site.solid{position:sticky;background:var(--green);box-shadow:0 1px 0 rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 24px}
.logo{font-family:var(--serif);font-size:1.35rem;color:#fff;text-decoration:none;letter-spacing:.02em}
.logo b{color:var(--gold-soft);font-weight:600}
.nav ul{display:flex;gap:26px;list-style:none}
.nav ul a{color:rgba(255,255,255,.88);text-decoration:none;font-size:.92rem;letter-spacing:.04em}
.nav ul a:hover{color:var(--gold-soft)}
.burger{display:none;background:none;border:0;cursor:pointer;width:34px;height:26px;position:relative}
.burger span{position:absolute;left:0;right:0;height:2px;background:#fff;transition:.25s}
.burger span:nth-child(1){top:2px}.burger span:nth-child(2){top:12px}.burger span:nth-child(3){top:22px}
@media(max-width:900px){
  .burger{display:block}
  .nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:var(--green-deep);flex-direction:column;gap:0;padding:10px 0}
  .nav ul.open{display:flex}
  .nav ul li{padding:12px 26px;border-top:1px solid rgba(255,255,255,.07)}
}

/* hero */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;color:#fff;background:linear-gradient(160deg,var(--green-deep),var(--green-soft));background-size:cover;background-position:center}
.hero.parallax{background-attachment:fixed}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(8,30,23,.78) 0%,rgba(8,30,23,.18) 55%,rgba(8,30,23,.35) 100%)}
.hero .wrap{position:relative;z-index:2;padding-bottom:90px}
.hero h1{color:#fff;max-width:14em}
.hero p{color:rgba(255,255,255,.9);max-width:36em;font-size:1.2rem}
.hero.short{min-height:58vh}
@media(max-width:900px){.hero.parallax,.band.parallax{background-attachment:scroll}}

/* full-bleed image band */
.band{position:relative;min-height:64vh;background-size:cover;background-position:center;display:flex;align-items:center;color:#fff}
.band.parallax{background-attachment:fixed}
.band::after{content:"";position:absolute;inset:0;background:rgba(8,30,23,.45)}
.band .wrap{position:relative;z-index:2}
.band h2{color:#fff}

/* dark sections */
.dark{background:var(--green);color:#e8e6de}
.dark h2,.dark h3{color:#fff}
.dark .eyebrow{color:var(--gold-soft)}
.dark p{color:rgba(232,230,222,.85)}
.dark a{color:var(--gold-soft)}

/* buttons */
.btn{display:inline-block;background:var(--gold);color:var(--green-deep);text-decoration:none;font-weight:600;font-size:.95rem;letter-spacing:.05em;padding:15px 34px;border-radius:2px;transition:.2s}
.btn:hover{background:var(--gold-soft)}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.55)}
.btn.ghost:hover{border-color:var(--gold-soft);color:var(--gold-soft)}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split img{width:100%;height:100%;object-fit:cover;min-height:420px}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:32px}.split img{min-height:260px}}

/* teaser rows */
.teasers{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;margin-top:40px}
.teaser{text-decoration:none;color:inherit}
.teaser .ph{aspect-ratio:16/10;background:linear-gradient(150deg,var(--green-soft),var(--green-deep));background-size:cover;background-position:center;margin-bottom:18px;transition:.3s}
.teaser:hover .ph{transform:translateY(-4px)}
.teaser h3{margin:0 0 6px}
.teaser p{color:var(--muted);font-size:.95rem;margin:0}
.teaser .more{color:var(--gold);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600}

/* article */
.article h2{margin-top:1.8em}
.article ul,.article ol{margin:0 0 1.2em 1.3em}
.article li{margin-bottom:.4em}
figure.fig{margin:2.4em 0}
figure.fig img{width:100%}
figure.fig figcaption{font-size:.85rem;color:var(--muted);margin-top:8px}
.crumbs{font-size:.82rem;letter-spacing:.04em;margin-bottom:26px;color:var(--muted)}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--green)}
.related{border-top:1px solid #ddd6c6;margin-top:60px;padding-top:34px}
.related ul{list-style:none;margin:0}
.related li{margin-bottom:10px}

/* map page */
#map,#map-teaser{width:100%;height:72vh;min-height:480px;background:var(--green-deep)}
#map-teaser{height:440px;min-height:340px}
.map-shell{position:relative}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 18px}
.chip{border:1px solid var(--green);background:transparent;color:var(--green);font:600 .82rem var(--sans);letter-spacing:.06em;text-transform:uppercase;padding:9px 18px;border-radius:30px;cursor:pointer;transition:.15s}
.chip.on,.chip:hover{background:var(--green);color:#fff}
.maplibregl-popup-content{font-family:var(--sans);background:var(--green-deep);color:#ece9e0;border-radius:4px;padding:16px 18px;box-shadow:0 8px 30px rgba(0,0,0,.4);max-width:260px}
.maplibregl-popup-content h4{font-family:var(--serif);font-size:1.05rem;color:var(--gold-soft);margin-bottom:4px}
.maplibregl-popup-content p{font-size:.85rem;margin:0 0 8px;color:rgba(236,233,224,.85)}
.maplibregl-popup-content a{color:var(--gold-soft);font-size:.82rem}
.maplibregl-popup-tip{border-top-color:var(--green-deep)!important}
.poi-marker{width:16px;height:16px;border-radius:50%;background:var(--gold);border:2px solid #fff;box-shadow:0 1px 6px rgba(0,0,0,.5);cursor:pointer}
.poi-marker.chalet{width:22px;height:22px;background:#fff;border:3px solid var(--gold)}
.poi-list{list-style:none;margin:30px 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.poi-list li{border-left:3px solid var(--gold);padding:10px 16px;background:#fff}
.poi-list button{background:none;border:0;font:600 1rem var(--serif);color:var(--green);cursor:pointer;padding:0;text-align:left}
.poi-list button:hover{color:var(--gold)}
.poi-list span{display:block;font-size:.85rem;color:var(--muted)}

/* contact */
.contact-card{background:var(--green);color:#ece9e0;padding:64px 48px;text-align:center}
.contact-card h2{color:#fff}
.contact-card .email{font-family:var(--serif);font-size:clamp(1.3rem,3vw,2rem);color:var(--gold-soft);text-decoration:none}

/* stats strip */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:34px;text-align:center}
.stats .n{font-family:var(--serif);font-size:2.6rem;color:var(--gold)}
.stats .l{font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(232,230,222,.7)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* footer */
footer.site{background:var(--green-deep);color:rgba(232,230,222,.75);padding:70px 0 40px;font-size:.92rem}
footer.site h4{font-family:var(--serif);color:#fff;font-size:1.05rem;margin-bottom:14px}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px}
@media(max-width:800px){.fgrid{grid-template-columns:1fr 1fr}}
footer.site ul{list-style:none}
footer.site li{margin-bottom:8px}
footer.site a{color:rgba(232,230,222,.75);text-decoration:none}
footer.site a:hover{color:var(--gold-soft)}
.fbottom{border-top:1px solid rgba(255,255,255,.1);margin-top:48px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem}
.fbottom a{color:var(--gold-soft)}
