:root{--azure:#003152;--paper:#F5F2EC;--ink:#26221C;--steel:#8FB6CC}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Hanken Grotesk',sans-serif;background:var(--paper);color:var(--ink)}
img{max-width:100%;display:block;filter:grayscale(1)}
a{color:inherit}

/* NAV */
nav{position:sticky;top:0;z-index:10;background:var(--azure);display:flex;justify-content:space-between;align-items:center;padding:16px 24px}
nav .logo{font-family:'Spline Sans Mono',monospace;font-size:13px;letter-spacing:.3em;color:var(--paper);text-decoration:none}
nav .logo .deg{color:var(--steel)}
nav .links{display:flex;gap:20px;flex-wrap:wrap}
nav .links a{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);text-decoration:none}
nav .links a:hover{color:var(--paper)}

/* HERO */
.hero{min-height:88vh;background:var(--azure);color:var(--paper);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:64px 24px;position:relative}
.hero.compact{min-height:56vh}
.rose{width:44px;height:44px;margin-bottom:32px}
.eyebrow{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.6;margin-bottom:18px}
.hero .eyebrow{color:var(--steel);opacity:1}
h1{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(36px,6.4vw,62px);line-height:1.08;max-width:15ch}
.hero .desc{font-size:15px;font-weight:300;margin-top:24px;opacity:.9;max-width:52ch}
.geo{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.14em;margin-top:16px;color:var(--steel)}
.cta{display:inline-block;margin-top:40px;padding:14px 36px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;background:var(--paper);color:var(--ink)}
.cta.dark{background:var(--azure);color:var(--paper)}

/* SECTIONS */
.section{padding:88px 24px;max-width:1040px;margin:0 auto}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
@media(max-width:760px){.split{grid-template-columns:1fr}}
h2{font-family:'Newsreader',serif;font-weight:300;font-size:clamp(26px,4vw,40px);line-height:1.16}
.lead{font-size:16px;font-weight:300;line-height:1.65;margin-top:22px;max-width:58ch}
.small{font-size:13.5px;font-weight:300;line-height:1.6;opacity:.85}

/* WINDS GRID */
.winds{margin-top:56px;display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1px;background:var(--ink)}
.wind{background:var(--paper);padding:30px 24px;text-decoration:none;display:block}
.wind:hover{background:#EDE9E0}
.wind .dir{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;color:var(--azure);opacity:.7}
.wind h3{font-family:'Newsreader',serif;font-weight:400;font-size:23px;margin:10px 0 4px}
.wind .by{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.5;margin-bottom:13px}

/* DARK BAND */
.band{background:var(--azure);color:var(--paper);padding:80px 24px;text-align:center}
.band .q{font-family:'Newsreader',serif;font-style:italic;font-weight:300;font-size:clamp(20px,3vw,27px);max-width:34ch;margin:0 auto;line-height:1.4}
.band .src{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--steel);margin-top:20px}
.band .cta{margin-top:36px}

/* PHOTO TREATMENT */
.photo{position:relative}
.photo img{width:100%;height:auto}
.photo .cap{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.5;margin-top:12px}

footer{background:var(--azure);color:var(--steel);text-align:center;padding:44px 24px;font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.2em;line-height:2}
footer a{color:var(--steel);text-decoration:none}

/* ===== INTERACTION LAYER — practices ported from the design system ===== */
html{scroll-behavior:smooth}
h1,h2,h3{text-wrap:balance}
:focus-visible{outline:2px solid var(--steel);outline-offset:3px}
::selection{background:var(--azure);color:var(--paper)}

/* Nav: solid at top, glass on scroll */
nav{transition:background .3s cubic-bezier(.22,.61,.36,1),box-shadow .3s cubic-bezier(.22,.61,.36,1)}
nav.scrolled{background:rgba(0,49,82,.86);backdrop-filter:blur(14px) saturate(1.1);-webkit-backdrop-filter:blur(14px) saturate(1.1);box-shadow:0 1px 0 rgba(143,182,204,.22)}

/* Quiet hovers */
.cta{transition:background .3s cubic-bezier(.22,.61,.36,1),color .3s cubic-bezier(.22,.61,.36,1)}
.cta:hover{background:var(--steel);color:var(--azure)}
.wind{transition:background .3s cubic-bezier(.22,.61,.36,1)}
nav .links a{transition:color .3s cubic-bezier(.22,.61,.36,1)}

/* Scroll reveal (elements are tagged by js/main.js; no JS — no hiding) */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s cubic-bezier(.22,.61,.36,1),transform .9s cubic-bezier(.22,.61,.36,1)}
.reveal.is-visible{opacity:1;transform:none}

/* Coordinate strip — city + coordinates in mono, hairline borders */
.coords{display:flex;border-top:1px solid rgba(38,34,28,.18);border-bottom:1px solid rgba(38,34,28,.18);font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.14em;overflow-x:auto;scrollbar-width:none}
.coords::-webkit-scrollbar{display:none}
.coords .place{display:flex;align-items:baseline;gap:12px;flex:1 0 auto;padding:16px 24px;white-space:nowrap;border-right:1px solid rgba(38,34,28,.18)}
.coords .place:last-child{border-right:0}
.coords .city{text-transform:uppercase;letter-spacing:.2em}
.coords .coord{color:var(--azure);opacity:.65}

/* Stat strip — serif numeral + mono label on the 1px grid */
.stats{margin-top:56px;display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;background:var(--ink)}
.stat{background:var(--paper);padding:28px 24px}
.stat .n{font-family:'Newsreader',serif;font-weight:300;font-size:44px;line-height:1;color:var(--azure)}
.stat .l{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.55;margin-top:10px;line-height:1.6}

/* FAQ accordion */
.faq{max-width:60ch;margin-top:36px;border-top:1px solid rgba(38,34,28,.18)}
.faq details{border-bottom:1px solid rgba(38,34,28,.18)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:18px 0;font-family:'Newsreader',serif;font-weight:400;font-size:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:'Spline Sans Mono',monospace;font-size:16px;color:var(--azure);opacity:.6;transition:transform .3s cubic-bezier(.22,.61,.36,1)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .small{padding:0 0 20px;max-width:56ch}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* Even column counts — the 1px grid never shows empty dark cells */
.winds{grid-template-columns:repeat(3,1fr)}
.winds:has(> :last-child:nth-child(4)){grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){
  .winds{grid-template-columns:1fr}
  .winds:has(> :last-child:nth-child(4)){grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .winds:has(> :last-child:nth-child(4)){grid-template-columns:1fr}
}
.stats{grid-template-columns:repeat(4,1fr)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:380px){.stats{grid-template-columns:1fr}}

/* ===== SITE V3 — revision per brief (2026-07) ===== */

/* Soft geometry — the house is soft */
.cta{border-radius:999px}

/* Hero v3 — the fact first, the feeling right under it */
.hero .sub{font-family:'Newsreader',serif;font-style:italic;font-weight:300;font-size:clamp(19px,2.6vw,25px);margin-top:18px;color:var(--steel)}

/* NAV v3: dropdowns + separate language switcher */
nav{gap:16px}
nav .links{align-items:center}
nav .nav-item{position:relative}
nav .nav-item>a,nav .nav-item>button{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);text-decoration:none;background:none;border:0;cursor:pointer;padding:8px 0;transition:color .3s cubic-bezier(.22,.61,.36,1)}
nav .nav-item>a:hover,nav .nav-item>button:hover{color:var(--paper)}
nav .drop{position:absolute;top:100%;left:0;transform:translateY(6px);width:320px;max-width:calc(100vw - 32px);background:var(--azure);border:1px solid rgba(143,182,204,.25);border-radius:10px;padding:10px;opacity:0;visibility:hidden;transition:opacity .25s cubic-bezier(.22,.61,.36,1),transform .25s cubic-bezier(.22,.61,.36,1),visibility .25s;box-shadow:0 18px 40px rgba(0,20,35,.35)}
nav .nav-item:hover .drop,nav .nav-item:focus-within .drop,nav .nav-item.open .drop{opacity:1;visibility:visible;transform:translateY(0)}
nav .drop a{display:block;padding:10px 12px;border-radius:7px;text-decoration:none;transition:background .25s}
nav .drop a:hover{background:rgba(143,182,204,.12)}
nav .drop .t{display:block;font-family:'Newsreader',serif;font-size:16px;color:var(--paper);letter-spacing:0;text-transform:none}
nav .drop .d{display:block;font-size:11.5px;font-weight:300;color:var(--steel);letter-spacing:.02em;text-transform:none;font-family:'Hanken Grotesk',sans-serif;margin-top:2px;line-height:1.45}
nav .lang{display:flex;gap:10px;align-items:center;border-left:1px solid rgba(143,182,204,.3);padding-left:16px;margin-left:4px}
nav .lang a,nav .lang span{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.16em;color:var(--steel);text-decoration:none}
nav .lang .active{color:var(--paper)}
nav .lang a:hover{color:var(--paper)}
@media(max-width:860px){
  nav{flex-wrap:wrap}
  nav .drop{position:static;transform:none;opacity:1;visibility:visible;display:none;min-width:0;box-shadow:none;border:0;padding:4px 0 4px 10px}
  nav .nav-item.open .drop{display:block}
  nav .lang{border-left:0;padding-left:0}
}

/* Meteogram strip — coordinates + live weather + distance from the visitor */
.coords .place{text-decoration:none;transition:background .3s cubic-bezier(.22,.61,.36,1)}
a.place:hover{background:rgba(0,49,82,.05)}
.coords .wx{color:var(--azure);opacity:.8}
.coords .dist{opacity:.45}

/* Services — gradient cards that read as doors, not text */
.winds.gradient{background:transparent;gap:14px}
.winds.gradient .wind{position:relative;overflow:hidden;border-radius:14px;color:var(--paper);padding:34px 28px 30px;background:linear-gradient(160deg,var(--g-from,#00263F) 0%,var(--g-to,#33607F) 100%);transition:transform .45s cubic-bezier(.22,.61,.36,1),box-shadow .45s cubic-bezier(.22,.61,.36,1)}
.winds.gradient .wind::before{content:'';position:absolute;inset:-40%;background:
  radial-gradient(38% 30% at 25% 30%,rgba(245,242,236,.10),transparent 70%),
  radial-gradient(30% 26% at 75% 60%,rgba(143,182,204,.16),transparent 70%),
  radial-gradient(26% 22% at 55% 20%,rgba(245,242,236,.07),transparent 70%);
  animation:clouds 26s ease-in-out infinite alternate;pointer-events:none}
.winds.gradient .wind:nth-child(2)::before{animation-duration:32s}
.winds.gradient .wind:nth-child(3)::before{animation-duration:22s}
.winds.gradient .wind:nth-child(4)::before{animation-duration:36s}
@keyframes clouds{from{transform:translate3d(-4%,-2%,0) scale(1)}to{transform:translate3d(4%,3%,0) scale(1.06)}}
.winds.gradient .wind:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(0,30,50,.28);background:linear-gradient(160deg,var(--g-from,#00263F) 0%,var(--g-to,#33607F) 100%)}
.winds.gradient .wind .dir{color:var(--steel);opacity:.9}
.winds.gradient .wind .by{opacity:.6}
.winds.gradient .wind .small{opacity:.92;color:var(--paper)}
.winds.gradient .wind .go{position:absolute;right:24px;top:28px;font-family:'Spline Sans Mono',monospace;font-size:12px;color:var(--steel);transition:transform .35s cubic-bezier(.22,.61,.36,1),color .35s}
.winds.gradient .wind:hover .go{transform:translateX(5px);color:var(--paper)}
.winds.gradient .wind .plain{display:inline-block;margin-top:2px;font-family:'Spline Sans Mono',monospace;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--steel);opacity:.85}

/* Section contrast — block by block, not one flat page */
.section.mist{background:#E9E4DA;max-width:none}
.section.mist>.inner,.section.wide>.inner{max-width:1040px;margin:0 auto}
.section.deep{background:var(--azure);color:var(--paper);max-width:none}
.section.deep .eyebrow{color:var(--steel);opacity:1}
.section.deep .small{opacity:.85}

/* Case tiles — large, categorical */
.cases{margin-top:56px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:760px){.cases{grid-template-columns:1fr}}
.case-tile{display:block;text-decoration:none;border:1px solid rgba(38,34,28,.18);border-radius:14px;padding:34px 30px;background:var(--paper);transition:background .3s,transform .45s cubic-bezier(.22,.61,.36,1),box-shadow .45s}
.case-tile:hover{background:#EDE9E0;transform:translateY(-3px);box-shadow:0 16px 34px rgba(38,34,28,.10)}
.case-tile .k{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--azure);opacity:.7}
.case-tile h3{font-family:'Newsreader',serif;font-weight:400;font-size:24px;margin:12px 0 8px}
.section.deep .case-tile{background:rgba(245,242,236,.04);border-color:rgba(143,182,204,.3);color:var(--paper)}
.section.deep .case-tile:hover{background:rgba(245,242,236,.09)}
.section.deep .case-tile .k{color:var(--steel)}

/* Case entries on the cases page */
.case{border-top:1px solid rgba(38,34,28,.18);padding:34px 0}
.case:last-child{border-bottom:1px solid rgba(38,34,28,.18)}
.case .meta{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--azure);opacity:.7;margin-bottom:10px}
.case h3{font-family:'Newsreader',serif;font-weight:400;font-size:24px;margin-bottom:10px}
.case .note{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.45;margin-top:14px}

/* Process — expandable, humane */
.process{max-width:62ch;margin-top:36px;border-top:1px solid rgba(38,34,28,.18)}
.process details{border-bottom:1px solid rgba(38,34,28,.18)}
.process summary{cursor:pointer;list-style:none;display:flex;align-items:baseline;gap:18px;padding:20px 0;font-family:'Newsreader',serif;font-weight:400;font-size:21px}
.process summary::-webkit-details-marker{display:none}
.process .no{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.18em;color:var(--azure);opacity:.65;min-width:34px}
.process summary::after{content:'+';margin-left:auto;font-family:'Spline Sans Mono',monospace;font-size:16px;color:var(--azure);opacity:.6;transition:transform .3s cubic-bezier(.22,.61,.36,1)}
.process details[open] summary::after{transform:rotate(45deg)}
.process .small{padding:0 0 22px 52px;max-width:54ch}

/* Video placeholder — a promise, not an absence */
.film{position:relative;border-radius:14px;overflow:hidden;background:linear-gradient(165deg,#00263F,#3A6889);color:var(--paper);min-height:280px;display:flex;flex-direction:column;justify-content:flex-end;padding:28px}
.film::before{content:'';position:absolute;inset:-40%;background:radial-gradient(40% 32% at 30% 35%,rgba(245,242,236,.10),transparent 70%),radial-gradient(30% 24% at 72% 55%,rgba(143,182,204,.14),transparent 70%);animation:clouds 30s ease-in-out infinite alternate}
.film .badge{position:absolute;top:24px;left:26px;font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--steel)}
.film .t{position:relative;font-family:'Newsreader',serif;font-weight:300;font-size:21px;max-width:26ch;line-height:1.3}

/* Booking */
.quiz{max-width:560px;margin:48px auto 0}
.quiz fieldset{border:0;margin-bottom:34px}
.quiz legend{font-family:'Newsreader',serif;font-weight:400;font-size:21px;margin-bottom:16px}
.quiz .opts{display:grid;gap:10px}
.quiz label.opt{display:flex;gap:12px;align-items:baseline;border:1px solid rgba(38,34,28,.22);border-radius:12px;padding:14px 18px;cursor:pointer;font-size:14px;font-weight:300;transition:background .25s,border-color .25s}
.quiz label.opt:hover{background:#EDE9E0}
.quiz input[type=radio]{accent-color:var(--azure)}
.quiz label.opt:has(input:checked){border-color:var(--azure);background:#E9E4DA}
.quiz .actions{text-align:center;margin-top:8px}
.quiz-result{max-width:560px;margin:40px auto 0;text-align:center}
.hint{font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;opacity:.5;margin-top:14px}

/* Footer v3 — full map of the house */
footer.v3{text-align:left;letter-spacing:normal;padding:56px 24px 40px}
footer.v3 .cols{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:760px){footer.v3 .cols{grid-template-columns:1fr 1fr}}
footer.v3 .col .h{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper);opacity:.9;margin-bottom:14px}
footer.v3 .col a{display:block;font-family:'Hanken Grotesk',sans-serif;font-size:12.5px;font-weight:300;letter-spacing:.02em;color:var(--steel);text-decoration:none;line-height:2;transition:color .25s}
footer.v3 .col a:hover{color:var(--paper)}
footer.v3 .brand{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.3em;color:var(--paper)}
footer.v3 .brand .deg{color:var(--steel)}
footer.v3 .meteo{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.14em;color:var(--steel);margin-top:16px;line-height:1.9;opacity:.85}
footer.v3 .legal{max-width:1040px;margin:40px auto 0;padding-top:20px;border-top:1px solid rgba(143,182,204,.2);font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.18em;text-align:center;line-height:2}
