/* ============================================================
   THE INSTITUTE FRANKFURT — Shared Stylesheet
   ============================================================ */
:root{
  --offwhite:#F7F4EE; --offwhite-2:#FBF9F5; --beige:#EDE7DC;
  --stone:#DAD3C6; --stone-deep:#C6BDAC;
  --olive:#6E745B; --olive-soft:#8B9079; --olive-muted:#A8AC98;
  --ink:#171614; --ink-soft:#3A3733;
  --champagne:#B79F76; --champagne-soft:#CBB792;
  --line:rgba(23,22,20,0.12); --line-soft:rgba(23,22,20,0.07);
  --serif:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1); --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
body{font-family:var(--sans);background:var(--offwhite);color:var(--ink);font-weight:300;line-height:1.7;overflow-x:hidden;max-width:100%;}
::selection{background:var(--champagne);color:#fff;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:300;line-height:1.05;letter-spacing:-0.01em;}
.eyebrow{font-family:var(--sans);font-weight:400;font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--olive);}

section{position:relative;}
section[id]{scroll-margin-top:96px;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,5vw,3.4rem);}
.pad{padding-top:clamp(5rem,12vh,9rem);padding-bottom:clamp(5rem,12vh,9rem);}
.section-head{max-width:46rem;}
.section-head h2{font-size:clamp(2.4rem,5.5vw,4.4rem);margin-top:1.1rem;font-weight:300;}
.section-head h2 em{font-style:italic;color:var(--olive);}

/* ---------- Header / Nav ---------- */
.topbar{position:fixed;top:0;left:0;right:0;z-index:1100;transition:transform .45s cubic-bezier(.16,1,.3,1);will-change:transform;}
.topbar.hide{transform:translateY(-115%);}
.nav{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;width:calc(100% - clamp(1.4rem,4vw,2.8rem));max-width:1180px;margin:.8rem auto 0;padding:.85rem 1.4rem;border-radius:100px;background:rgba(22,21,19,0.46);backdrop-filter:blur(20px) saturate(175%);-webkit-backdrop-filter:blur(20px) saturate(175%);border:1px solid rgba(255,255,255,0.14);box-shadow:0 14px 44px rgba(0,0,0,0.22);transition:background .5s var(--ease),box-shadow .5s var(--ease),margin .5s var(--ease);}
.nav-brand{padding-left:.6rem;}
.nav.scrolled{background:rgba(18,17,15,0.68);box-shadow:0 12px 38px rgba(0,0,0,0.3);margin-top:.6rem;}
.nav-brand{display:flex;align-items:center;gap:.6rem;color:#fff;}
.nav-logo{width:42px;height:42px;object-fit:contain;flex:none;}
.nav-name{font-family:var(--serif);font-size:1.15rem;letter-spacing:.16em;font-weight:400;line-height:1;white-space:nowrap;}
.nav-links{display:flex;align-items:center;gap:1.7rem;}
.nav-link{color:#fff;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;position:relative;transition:color .6s var(--ease),opacity .3s;padding:.2rem 0;white-space:nowrap;}
.nav-link.active{color:var(--champagne-soft);}
.nav-link::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--champagne);transition:width .4s var(--ease);}
.nav-link:hover::after{width:100%;}
.nav-drop{position:relative;display:flex;align-items:center;}
.nav-drop::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);width:260px;height:22px;}
.nav-submenu{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(20,19,17,0.86);backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);border:1px solid rgba(255,255,255,0.12);border-radius:14px;padding:.5rem 0;min-width:250px;opacity:0;pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease);box-shadow:0 18px 44px rgba(0,0,0,0.32);}
.nav-submenu::before{content:"";position:absolute;top:-18px;left:0;right:0;height:20px;}
.nav-drop:hover .nav-submenu,.nav-drop:focus-within .nav-submenu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.nav-submenu a{display:block;padding:.7rem 1.5rem;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,0.82);white-space:nowrap;transition:background .3s,color .3s;}
.nav-submenu a:hover{background:rgba(255,255,255,0.08);color:#fff;}
.nav-ig{color:#fff;display:flex;align-items:center;transition:color .6s var(--ease),transform .3s;}
.nav-ig:hover{transform:scale(1.12);}
.nav-ig svg{width:19px;height:19px;}
.nav-cta{background:transparent;border:none;padding:.2rem 0;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--champagne-soft);font-weight:500;white-space:nowrap;transition:color .4s ease;position:relative;}
.nav-cta::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--champagne);transition:width .4s var(--ease);}
.nav-cta:hover{color:#fff;}
.nav-cta:hover::after{width:100%;}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;}
.nav-burger span{width:24px;height:1.5px;background:#fff;transition:transform .4s,opacity .3s;}
.mobile-menu{position:fixed;inset:0;z-index:1050;background:var(--offwhite);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.3rem;padding:5rem 1.5rem 2.5rem;text-align:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease);overflow-y:auto;}
.mobile-menu.open{opacity:1;pointer-events:auto;}
.mobile-menu a{font-family:var(--serif);font-size:clamp(1.4rem,6vw,1.85rem);color:var(--ink);text-align:center;line-height:1.15;}
.mobile-menu .eyebrow{margin-top:1rem;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.7rem;cursor:pointer;font-family:var(--sans);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:400;padding:1.05rem 2.1rem;border-radius:2px;border:1px solid transparent;transition:all .45s var(--ease);background:none;}
.btn-arrow{transition:transform .45s var(--ease);}
.btn:hover .btn-arrow{transform:translateX(5px);}
.btn-solid{background:#fff;color:var(--ink);border-color:#fff;}
.btn-solid:hover{background:transparent;color:#fff;border-color:#fff;}
.btn-ink{background:var(--ink);color:var(--offwhite);border-color:var(--ink);}
.btn-ink:hover{background:transparent;color:var(--ink);}
.btn-outline{border-color:rgba(255,255,255,0.5);color:#fff;}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,0.08);}
.btn-line-ink{border-color:var(--line);color:var(--ink);}
.btn-line-ink:hover{border-color:var(--ink);background:var(--ink);color:var(--offwhite);}

/* ---------- Page banner ---------- */
.banner{position:relative;min-height:70vh;display:flex;align-items:flex-end;padding:clamp(7rem,12vh,10rem) clamp(1.2rem,5vw,3.4rem) clamp(3rem,7vh,5rem);background:var(--olive);overflow:hidden;}
.banner-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.04);animation:bannerZoom 12s ease-out forwards;will-change:transform;image-rendering:high-quality;-webkit-backface-visibility:hidden;backface-visibility:hidden;}
@keyframes bannerZoom{to{transform:scale(1);}}
.banner-shade{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(11,13,9,0.4) 0%,rgba(11,13,9,0.04) 30%,rgba(11,13,9,0) 50%),
  linear-gradient(95deg,rgba(11,13,9,0.65) 0%,rgba(11,13,9,0.3) 45%,rgba(11,13,9,0.08) 75%,rgba(11,13,9,0) 100%),
  linear-gradient(0deg,rgba(11,13,9,0.45) 0%,rgba(11,13,9,0.18) 22%,rgba(11,13,9,0.04) 50%,rgba(11,13,9,0) 72%);}

.banner::after{content:"";position:absolute;left:0;right:0;bottom:0;height:340px;background:linear-gradient(to bottom,
  rgba(247,244,238,0) 0%,
  rgba(247,244,238,0.05) 18%,
  rgba(247,244,238,0.18) 38%,
  rgba(247,244,238,0.42) 58%,
  rgba(247,244,238,0.72) 78%,
  rgba(247,244,238,0.92) 92%,
  var(--offwhite) 100%);z-index:2;pointer-events:none;}
.banner-inner{position:relative;z-index:3;max-width:var(--maxw);width:100%;margin:0 auto;color:#fff;}
.banner .eyebrow{color:rgba(255,255,255,0.85);text-shadow:0 1px 16px rgba(0,0,0,0.45);}
.banner h1{font-size:clamp(2.6rem,7vw,6rem);font-weight:300;color:#fff;letter-spacing:-0.02em;line-height:1;margin-top:1.2rem;text-shadow:0 2px 40px rgba(0,0,0,0.4);}
.banner h1 em{font-style:italic;color:var(--champagne-soft);}
.banner-sub{margin-top:1.4rem;max-width:34rem;font-size:1.02rem;color:rgba(255,255,255,0.92);text-shadow:0 1px 20px rgba(0,0,0,0.5);}

/* ---------- Split (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.split.flip .split-media{order:2;}
.split-media{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/5;background:var(--stone);}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.split:hover .split-media img{transform:scale(1.05);}
.split-body h2{font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1.3rem;}
.split-body h2 em{font-style:italic;color:var(--olive);}
.split-body p{font-size:1rem;color:var(--ink-soft);margin-bottom:1.1rem;max-width:34rem;}

/* ---------- Lead intro ---------- */
.lead{max-width:50rem;}
.lead p{font-size:1.05rem;color:var(--ink-soft);margin-bottom:1.2rem;}
.lead strong{font-weight:600;color:var(--ink);}

/* ---------- Vorteile list ---------- */
.benefits{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);margin-top:1rem;}
.benefit{background:var(--offwhite-2);padding:clamp(1.6rem,3vw,2.4rem);}
.benefit .num{font-size:.7rem;letter-spacing:.25em;color:var(--champagne);margin-bottom:.9rem;}
.benefit h4{font-family:var(--serif);font-weight:400;font-size:1.45rem;margin-bottom:.6rem;}
.benefit p{font-size:.92rem;color:var(--ink-soft);}

/* ---------- Zones ---------- */
.zone-row{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-top:3rem;}
.zone{position:relative;border:none;padding:0;cursor:pointer;background:var(--stone);border-radius:3px;overflow:hidden;aspect-ratio:5/6;font-family:var(--sans);}
.zone img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.zone::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(11,13,9,0.55),rgba(11,13,9,0) 60%);transition:background .4s;}
.zone span{position:absolute;left:0;right:0;bottom:.9rem;z-index:2;color:#fff;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;text-align:center;}
.zone:hover img{transform:scale(1.08);}
.zone:hover::after{background:linear-gradient(0deg,rgba(11,13,9,0.7),rgba(110,116,91,0.15) 70%);}

/* ---------- Method grid ---------- */
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2rem);margin-top:3.4rem;}
.method-card{background:var(--offwhite);border:1px solid var(--line-soft);border-radius:4px;overflow:hidden;transition:box-shadow .5s var(--ease),transform .5s var(--ease);}
.method-card:hover{box-shadow:0 20px 48px rgba(20,20,18,0.07);transform:translateY(-4px);}
.method-card figure{aspect-ratio:7/5;overflow:hidden;background:var(--stone);}
.method-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.method-card:hover img{transform:scale(1.06);}
.method-body{padding:clamp(1.4rem,2.2vw,1.9rem);}
.method-body h4{font-family:var(--serif);font-weight:400;font-size:1.35rem;margin-bottom:.7rem;}
.method-body p{font-size:.9rem;color:var(--ink-soft);line-height:1.65;}
.method-body ul{list-style:none;margin-top:.8rem;display:flex;flex-direction:column;gap:.4rem;}
.method-body li{font-size:.86rem;color:var(--ink-soft);padding-left:1rem;position:relative;}
.method-body li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:1px;background:var(--olive);}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);}
.team-card{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--line-soft);border-radius:4px;overflow:hidden;background:var(--offwhite-2);transition:box-shadow .55s var(--ease),transform .55s var(--ease);}
.team-card:hover{box-shadow:0 22px 54px rgba(20,20,18,0.08);transform:translateY(-4px);}
.team-photo{aspect-ratio:1/1.15;overflow:hidden;background:var(--stone);}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.team-card:hover .team-photo img{transform:scale(1.05);}
.team-meta{padding:clamp(1.4rem,2.6vw,2.1rem);display:flex;flex-direction:column;justify-content:center;}
.team-meta .role{font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne);}
.team-meta h4{font-family:var(--serif);font-weight:400;font-size:clamp(1.4rem,2.4vw,1.95rem);margin:.45rem 0 1.1rem;letter-spacing:.02em;}
.team-skills{list-style:none;display:flex;flex-direction:column;gap:.55rem;}
.team-skills li{font-size:.86rem;color:var(--ink-soft);padding-left:1.1rem;position:relative;}
.team-skills li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:1px;background:var(--olive);}

/* ---------- Quote cards ---------- */
.quote-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2rem);margin-top:3rem;}
.quote-card{background:var(--offwhite-2);border:1px solid var(--line-soft);border-radius:4px;padding:clamp(1.8rem,3vw,2.6rem);text-align:center;}
.quote-card .mk{font-family:var(--serif);font-size:3.5rem;line-height:.5;color:var(--champagne);display:block;height:1.6rem;}
.quote-card p{font-size:.95rem;color:var(--ink-soft);font-style:italic;line-height:1.7;margin:1.4rem 0;}
.quote-card .who{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);}

/* ---------- Price band ---------- */
.priceband{background:var(--ink);color:var(--offwhite);text-align:center;border-radius:5px;padding:clamp(2.5rem,6vw,4rem);}
.priceband .eyebrow{color:var(--champagne-soft);}
.priceband .big{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,7vw,4.5rem);line-height:1;margin:1rem 0;}
.priceband p{color:var(--olive-muted);max-width:30rem;margin:0 auto 1.8rem;font-size:.95rem;}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:56rem;margin:0 auto;}
.faq-cat{font-family:var(--sans);font-weight:500;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne);margin:2.6rem 0 .2rem;}
.faq-group:first-child .faq-cat{margin-top:0;}
.faq details{border-bottom:1px solid var(--line);}
.faq summary{list-style:none;cursor:pointer;padding:1.35rem 2.5rem 1.35rem 0;position:relative;font-size:1.04rem;font-weight:400;color:var(--ink);transition:color .3s;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"";position:absolute;right:.4rem;top:1.55rem;width:9px;height:9px;border-right:1.5px solid var(--olive);border-bottom:1.5px solid var(--olive);transform:rotate(45deg);transition:transform .35s var(--ease);}
.faq details[open] summary::after{transform:rotate(-135deg);}
.faq summary:hover{color:var(--olive);}
.faq .faq-a{padding:0 2.5rem 1.5rem 0;color:var(--ink-soft);font-size:.95rem;line-height:1.75;}
.faq .faq-a ul{margin:.6rem 0 .6rem 1.2rem;}
.faq .faq-a li{margin-bottom:.35rem;}

/* ---------- Booking menu ---------- */
.book-top{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start;}
.book-steps{margin-top:2.4rem;display:flex;flex-direction:column;gap:1.6rem;}
.book-step{display:flex;gap:1.2rem;align-items:flex-start;}
.book-step .n{font-family:var(--serif);font-size:1.5rem;color:var(--champagne);line-height:1;width:2.4rem;flex:none;border-right:1px solid var(--line);}
.book-step h4{font-family:var(--sans);font-weight:500;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.3rem;}
.book-step p{font-size:.9rem;color:var(--ink-soft);}
.book-card{background:var(--offwhite-2);border:1px solid var(--line-soft);border-radius:4px;padding:clamp(1.6rem,3vw,2.4rem);}
.book-card .label{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--olive);}
.book-card h3{font-size:1.9rem;margin:.4rem 0 1.2rem;}
.book-info{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.6rem;font-size:.9rem;color:var(--ink-soft);}
.book-info div{display:flex;gap:.7rem;align-items:center;}
.book-info svg{width:16px;height:16px;color:var(--olive);flex:none;}
.tw-headbar{margin-top:3.4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--line);}
.tw-headbar .eyebrow{color:var(--olive);}
.tw-rate{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--champagne);}
.menu{margin-top:1.4rem;border:1px solid var(--line-soft);border-radius:4px;background:var(--offwhite-2);overflow:hidden;}
.menu-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.35rem clamp(1.2rem,3vw,2.2rem);border-top:1px solid var(--line-soft);cursor:pointer;transition:background .4s var(--ease);}
.menu-row:first-child{border-top:none;}
.menu-row:hover{background:#fff;}
.menu-info h4{font-family:var(--sans);font-weight:500;font-size:.96rem;letter-spacing:.005em;margin-bottom:.28rem;line-height:1.3;}
.menu-info span{font-size:.68rem;letter-spacing:.12em;color:var(--stone-deep);text-transform:uppercase;}
.menu-price{display:flex;align-items:center;gap:1.4rem;flex:none;}
.menu-price .p{font-family:var(--sans);font-size:1.05rem;font-weight:500;white-space:nowrap;}
.menu-price .p s{color:var(--stone-deep);font-weight:300;font-size:.82rem;margin-right:.5rem;}
.menu-sel{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--line);border-radius:2px;padding:.6rem 1rem;transition:all .35s var(--ease);white-space:nowrap;color:var(--ink);}
.menu-row:hover .menu-sel{background:var(--ink);color:var(--offwhite);border-color:var(--ink);}
.menu-foot{padding:1.5rem clamp(1.2rem,3vw,2.2rem);border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.2rem;background:var(--beige);}
.menu-foot .note{font-size:.78rem;color:var(--ink-soft);letter-spacing:.02em;}
.tw-embed,#wahanda-online-booking-widget-iframe{position:relative;display:block;width:100%;height:840px;margin-top:1.4rem;border:1px solid var(--line-soft);border-radius:4px;overflow:hidden;background:var(--offwhite-2);box-shadow:0 18px 50px rgba(20,20,18,0.05);}
.tw-embed iframe,#wahanda-online-booking-widget-iframe iframe{position:relative;z-index:1;width:100%;height:100%;border:0;display:block;background:var(--offwhite-2);}
.tw-loading{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;background:var(--offwhite-2);transition:opacity .55s var(--ease);}
.tw-loading .spinner{width:38px;height:38px;border:2px solid var(--line);border-top-color:var(--olive);border-radius:50%;animation:tw-spin 1s linear infinite;}
.tw-loading span{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);}
.tw-loading small{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--stone-deep);}
#wahanda-online-booking-widget-iframe.loaded .tw-loading,.tw-embed.loaded .tw-loading{opacity:0;pointer-events:none;}
@keyframes tw-spin{to{transform:rotate(360deg);}}
@media(max-width:600px){.tw-embed,#wahanda-online-booking-widget-iframe{height:720px;}}
.tw-hint{margin-top:1.1rem;font-size:.8rem;color:var(--ink-soft);text-align:center;}
.tw-hint a{color:var(--olive);text-decoration:underline;text-underline-offset:2px;}
.tw-open{cursor:pointer;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--olive);display:inline-flex;gap:.5rem;align-items:center;}
.tw-open:hover{color:var(--ink);}
@media(max-width:600px){.tw-embed iframe{height:700px;}}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--stone);}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.5rem;padding-top:clamp(4rem,8vh,6rem);padding-bottom:3rem;}
.foot-logo{width:64px;height:64px;object-fit:contain;margin:0 0 1.2rem;display:block;}
.foot-brand .nav-name{color:#fff;font-size:1.8rem;}
.foot-brand p{margin-top:1.2rem;max-width:20rem;font-size:.9rem;color:var(--olive-muted);}
.foot-col h5{font-family:var(--sans);font-weight:400;font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--champagne-soft);margin-bottom:1.4rem;}
.foot-col a,.foot-col p{display:block;font-size:.9rem;color:var(--stone);margin-bottom:.7rem;transition:color .3s;}
.foot-col a:hover{color:#fff;}
.foot-route{display:inline-flex !important;align-items:center;gap:.45rem;margin-top:.8rem !important;padding:.5rem .85rem;font-size:.64rem !important;letter-spacing:.16em;text-transform:uppercase;color:var(--champagne-soft) !important;border:1px solid rgba(203,183,146,0.35);border-radius:100px;width:max-content;max-width:100%;white-space:nowrap;transition:background .35s ease,border-color .35s ease,color .35s ease,transform .35s ease;}
.foot-route:hover{background:var(--champagne);border-color:var(--champagne);color:var(--ink) !important;transform:translateY(-1px);}
.foot-route svg{flex:none;width:11px;height:11px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:2rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.foot-bottom span{font-size:.74rem;letter-spacing:.12em;color:var(--olive-muted);}
.foot-legal{display:flex;gap:1.6rem;}
.foot-legal a{font-size:.74rem;letter-spacing:.1em;color:var(--olive-muted);transition:color .3s;}
.foot-legal a:hover{color:#fff;}

/* ---------- Legal pages ---------- */
.legal-head{background:var(--ink);color:#fff;text-align:center;padding:clamp(8rem,20vh,12rem) clamp(1.2rem,5vw,3.4rem) clamp(3rem,6vh,4.5rem);position:relative;}
.legal-head::after{content:"";position:absolute;left:50%;bottom:clamp(1.8rem,4vh,2.8rem);transform:translateX(-50%);width:40px;height:1px;background:var(--champagne);}
.legal-head .eyebrow{color:var(--champagne-soft);}
.legal-head h1{color:#fff;font-size:clamp(2.6rem,7vw,4.5rem);font-weight:300;margin-top:.8rem;letter-spacing:-0.01em;}
.legal{max-width:50rem;margin:0 auto;}
.legal .addr{font-size:1rem;color:var(--ink);margin-bottom:2.2rem;line-height:1.9;padding:1.5rem 1.7rem;background:var(--offwhite-2);border-left:2px solid var(--champagne);border-radius:2px;}
.legal h2{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,1.75rem);font-weight:400;margin:2.8rem 0 .9rem;padding-bottom:.7rem;border-bottom:1px solid var(--line-soft);letter-spacing:0;}
.legal h2:first-child{margin-top:0;}
.legal p{font-size:.96rem;color:var(--ink-soft);margin-bottom:1rem;line-height:1.9;}
.legal ul{list-style:none;margin:.4rem 0 1.3rem;}
.legal li{font-size:.96rem;color:var(--ink-soft);margin-bottom:.55rem;padding-left:1.2rem;position:relative;line-height:1.75;}
.legal li::before{content:"";position:absolute;left:0;top:.72em;width:7px;height:1px;background:var(--champagne);}
.legal a{color:var(--olive);text-decoration:underline;text-underline-offset:2px;word-break:break-word;}
.legal strong{color:var(--ink);font-weight:600;}

/* ---------- Cookie ---------- */
.cookie{position:fixed;left:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:1300;max-width:380px;background:var(--offwhite-2);border:1px solid var(--line);border-radius:5px;padding:1.6rem 1.7rem;box-shadow:0 24px 60px rgba(0,0,0,0.18);transform:translateY(140%);opacity:0;transition:transform .7s var(--ease),opacity .5s ease;}
.cookie.show{transform:translateY(0);opacity:1;}
.cookie h5{font-family:var(--serif);font-size:1.4rem;margin-bottom:.5rem;font-weight:400;}
.cookie p{font-size:.82rem;color:var(--ink-soft);margin-bottom:1.2rem;}
.cookie p a{color:var(--olive);text-decoration:underline;text-underline-offset:2px;}
.cookie-actions{display:flex;gap:.7rem;}
.cookie-btn{flex:1;padding:.75rem 1rem;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;border-radius:2px;cursor:pointer;transition:all .35s var(--ease);border:1px solid var(--line);background:none;color:var(--ink);font-family:var(--sans);}
.cookie-btn.accept{background:var(--ink);color:var(--offwhite);border-color:var(--ink);}
.cookie-btn.accept:hover{background:var(--olive);border-color:var(--olive);}
.cookie-btn.decline:hover{border-color:var(--ink);}

/* ---------- Reveal / Animations ---------- */
.reveal,.reveal-l,.reveal-r,.reveal-zoom{opacity:0;transition:opacity 1s var(--ease),transform 1.15s var(--ease),filter 1s var(--ease);will-change:transform,opacity,filter;}
.reveal{transform:translateY(42px) scale(.99);filter:blur(3px);}
.reveal-l,.reveal-r{transform:translateY(42px);}
.reveal-zoom{transform:scale(.94);filter:blur(4px);}
.reveal.in,.reveal-l.in,.reveal-r.in,.reveal-zoom.in{opacity:1;transform:none;filter:none;}
.d1{transition-delay:.12s;}
.d2{transition-delay:.24s;}
.d3{transition-delay:.36s;}
.d4{transition-delay:.48s;}
/* hover micro-interactions */
.benefit{transition:background .5s var(--ease);}
.benefit:hover{background:#fff;}
.nav-link,.foot-col a,.foot-legal a{transition:color .4s var(--ease),opacity .3s;}
@media(hover:hover){
  .split-media img,.method-card img,.team-photo img,.zone img{backface-visibility:hidden;}
}

/* ---------- Polish ---------- */
:focus-visible{outline:2px solid var(--olive);outline-offset:3px;border-radius:2px;}
.btn:active{transform:translateY(1px);}
.quote-card{transition:box-shadow .5s var(--ease),transform .5s var(--ease);}
.quote-card:hover{box-shadow:0 20px 48px rgba(20,20,18,0.06);transform:translateY(-3px);}
.zone:focus-visible,.menu-row:focus-visible{outline-offset:-2px;}
.split-body .btn{margin-top:.4rem;}

/* ---------- Responsive ---------- */
@media(max-width:1100px){
  .quote-grid{grid-template-columns:1fr;max-width:48rem;margin-left:auto;margin-right:auto;}
}
@media(max-width:1100px){
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  .nav-brand .nav-name{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);white-space:nowrap;}
  .nav-logo{width:48px;height:48px;}
}
@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:2.4rem;}
  .split.flip .split-media{order:0;}
  .split-media{aspect-ratio:16/11;max-width:580px;}
  .benefits{grid-template-columns:1fr;}
  .method-grid{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:1fr;}
  .book-top{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:860px){.zone-row{grid-template-columns:repeat(3,1fr);}}
@media(max-width:720px){
  .banner{min-height:54vh;}
  .banner h1{font-size:clamp(2.3rem,9vw,3.6rem);}
  .banner-sub{font-size:.96rem;}
  .pad{padding-top:clamp(3.5rem,9vh,5.5rem);padding-bottom:clamp(3.5rem,9vh,5.5rem);}
  .section-head h2{font-size:clamp(2rem,7vw,3rem);}
  .nav{padding:.95rem .7rem .95rem 1.1rem;}
  .nav-name{font-size:1.22rem;}
  .nav-logo{width:44px;height:44px;}
  .mobile-menu a{font-size:1.6rem;}
}
@media(max-width:600px){
  .method-grid{grid-template-columns:1fr;}
  .method-card figure{aspect-ratio:16/10;}
  .menu-row{flex-direction:column;align-items:flex-start;gap:.9rem;}
  .menu-price{width:100%;justify-content:space-between;}
  .menu-foot{flex-direction:column;align-items:stretch;text-align:center;}
  .menu-foot .btn{width:100%;justify-content:center;}
  .book-card .btn{padding-left:1.2rem;padding-right:1.2rem;}
}
@media(max-width:560px){
  .foot-grid{grid-template-columns:1fr;gap:2.2rem;}
  .foot-bottom{flex-direction:column;align-items:flex-start;}
  .team-card{grid-template-columns:1fr;}
  .team-photo{aspect-ratio:4/3;}
  .banner{padding-bottom:2.6rem;}
  .btn{padding:.95rem 1.5rem;font-size:.72rem;letter-spacing:.18em;}
  .priceband{padding:2.2rem 1.4rem;}
  .faq summary{font-size:.96rem;padding-right:2rem;}
}
@media(max-width:480px){
  .zone-row{grid-template-columns:repeat(2,1fr);}
  .split-media{aspect-ratio:5/4;}
  .wrap{padding-left:1.2rem;padding-right:1.2rem;}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important;}.reveal{opacity:1;transform:none;}}
