*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --petrol:#0097B2;--petrol-dark:#0A4A58;--petrol-deeper:#062E38;
  --petrol-light:#D3F1F1;--petrol-lightest:#EAF6F7;
  --petrol-mid:#00788c;--bg-main:#00788c;--petrol-glow:rgba(0,151,178,.15);
  --bg-grad-top:#0a92a8;--bg-grad-bottom:#005f70;
  --bg-gradient:linear-gradient(165deg,var(--bg-grad-top) 0%,#00788c 45%,var(--bg-grad-bottom) 100%);
  --orange:#E8723A;--orange-hover:#D4622E;--orange-glow:rgba(232,114,58,.12);--orange-light:#FF9E63;
  --green:#5BA85C;--green-light:#8FD18F;
  --cream:#FAFAF8;--dark:#1A2832;--dark2:#0B1A1D;
  --muted:#8FA5A8;--muted-dark:#5A7578;--border-light:rgba(255,255,255,.08);
  --border-dark:rgba(0,0,0,.08);--white:#FFFFFF;
}
html{scroll-behavior:smooth}
/* Offset anchor jumps so targets are not hidden behind the fixed navbar */
:target{scroll-margin-top:90px}
#gift,#methods,#method,#drive,#reviews,#contact,#hero-section,#retreats,#workshops,#teams,#faq{scroll-margin-top:90px}
body{font-family:'DM Sans',sans-serif;color:var(--white);background:var(--bg-grad-bottom);-webkit-font-smoothing:antialiased}
/* Seamless page-wide gradient: fixed layer behind everything so sections share one continuous wash */
body::before{content:'';position:fixed;inset:0;z-index:-1;background:var(--bg-gradient);background-attachment:fixed}
h1,h2,h3,h4,h5{font-family:'Outfit',sans-serif}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

/* ===== ANIMATIONS ===== */
.fi{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.fi.v{opacity:1;transform:translateY(0)}
/* Header zoom-in like KILI48 */
.fi-zoom{opacity:0;transform:scale(.88);transition:opacity 1s cubic-bezier(.22,1,.36,1),transform 1.2s cubic-bezier(.22,1,.36,1)}
.fi-zoom.v{opacity:1;transform:scale(1)}
.fi-grow{opacity:0;transform:scale(.92);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform 1.4s cubic-bezier(.22,1,.36,1)}
.fi-grow.v{opacity:1;transform:scale(1)}
/* Slide from left */
.fi-left{opacity:0;transform:translateX(-50px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.fi-left.v{opacity:1;transform:translateX(0)}
/* Slide from right */
.fi-right{opacity:0;transform:translateX(50px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.fi-right.v{opacity:1;transform:translateX(0)}

/* Parallax container */
.parallax-wrap{overflow:hidden;position:relative}
.parallax-img{width:100%;height:120%;position:absolute;top:-10%;left:0;object-fit:cover;will-change:transform}

/* Wave dividers */
.wave-div{width:100%;overflow:hidden;line-height:0;margin:-1px 0;position:relative;z-index:2}
.wave-div svg{display:block;width:calc(100% + 2px);height:auto;margin-left:-1px}
.wave-div.flip{transform:rotate(180deg)}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:18px 48px;transition:all .35s ease}
nav.scrolled{background:rgba(255,255,255,.97);padding:12px 48px;box-shadow:0 1px 20px rgba(0,0,0,.08);backdrop-filter:blur(12px)}
nav.scrolled .nav-links a{color:var(--petrol-dark)}
nav.scrolled .nav-links a:hover{color:var(--orange)}
nav.scrolled .lang-toggle{color:var(--petrol-dark);border-color:var(--petrol-dark)}
nav.scrolled .hamburger span{background:var(--petrol-dark)}
nav.scrolled .nav-logo img{filter:none}
.nav-logo img{height:60px;width:auto;object-fit:contain;transition:filter .35s;filter:brightness(0) invert(1)}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{font-family:'Outfit',sans-serif;font-size:13px;font-weight:500;color:rgba(255,255,255,.6);transition:color .25s}
.nav-links a:hover{color:#fff}
.btn-nav{font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;background:var(--orange);color:#fff;border:none;border-radius:4px;padding:10px 22px;cursor:pointer;transition:background .2s,transform .2s}
.btn-nav:hover{background:var(--orange-hover);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:200}
.hamburger span{width:24px;height:2px;background:#fff;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile menu */
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(6,46,56,.97);z-index:150;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(12px)}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{font-family:'Outfit',sans-serif;font-size:20px;font-weight:500;color:rgba(255,255,255,.7);transition:color .2s}
.mobile-menu a:hover{color:#fff}
.mobile-menu .btn-nav{font-size:16px;padding:14px 32px;margin-top:12px}

/* ===== HERO ===== */
.hero{position:relative;height:100vh;min-height:640px;max-height:920px;overflow:hidden}
.hero-img{width:100%;height:130%;position:absolute;top:-15%;left:0;object-fit:cover;object-position:center 20%;will-change:transform}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(6,46,56,.6) 0%,rgba(6,46,56,.38) 38%,rgba(10,74,88,.16) 62%,rgba(6,46,56,.12) 100%)}
.hero-wave{position:absolute;bottom:-2px;left:-1px;right:-1px;z-index:2;width:calc(100% + 2px);display:block}
.hero-body{position:absolute;bottom:0;left:0;right:0;padding:0 64px 100px;z-index:3}
.hero-tag{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--orange-light);font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.hero-tag::before{content:'';width:32px;height:1px;background:var(--orange)}
.hero h1{font-size:58px;font-weight:800;color:#fff;line-height:1.02;letter-spacing:-.035em;margin-bottom:20px;max-width:620px;text-shadow:0 2px 24px rgba(0,0,0,.5)}
.hero h1 span{color:var(--orange)}
.hero-sub{font-size:16px;font-weight:400;color:rgba(255,255,255,.95);line-height:1.75;max-width:440px;margin-bottom:32px;text-shadow:0 1px 16px rgba(0,0,0,.55)}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-p{font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;background:var(--orange);color:#fff;border:none;border-radius:4px;padding:14px 32px;cursor:pointer;transition:all .2s}
.btn-p:hover{background:var(--orange-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,114,58,.3)}
.btn-g{font-family:'Outfit',sans-serif;font-size:14px;color:rgba(255,255,255,.6);background:0 0;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:13px 26px;cursor:pointer;transition:all .2s}
.btn-g:hover{border-color:rgba(255,255,255,.4);color:#fff}

/* Page hero (subpages) */
.page-hero{height:420px;min-height:auto;max-height:none}
.page-hero .hero-body{padding:90px 64px 48px}
.page-hero h1{font-size:44px;max-width:500px}

/* ===== TRUST STRIP ===== */
.cred{display:grid;grid-template-columns:repeat(4,1fr);background:var(--petrol)}
.cred-item{padding:24px 28px;border-right:1px solid rgba(255,255,255,.08);text-align:center}
.cred-item:last-child{border-right:none}
.cred-num{font-family:'Outfit',sans-serif;font-size:24px;font-weight:700;color:#fff;margin-bottom:4px}
.cred-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75)}

/* ===== SECTIONS ===== */
/* Dark section (petrol-dark) */
.sec{padding:80px 64px}
.sec.dark{background:transparent;color:#fff}
.sec.dark .sec-p{color:rgba(255,255,255,.85)}
.sec.dark h2{color:#fff}
.sec.dark h2 span{color:var(--petrol-light)}

/* Light section (petrol-lightest) */
.sec.light{background:var(--petrol-lightest);color:var(--dark);border-bottom:1px solid var(--border-dark)}
.sec.light .sec-p{color:var(--muted-dark)}
.sec.light h2{color:var(--petrol-dark)}
.sec.light h2 span{color:var(--petrol-mid)}
.sec.light .tag{color:var(--petrol)}

.tag{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--orange-light);font-weight:700;margin-bottom:12px}
h2{font-size:40px;font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:12px}
h2 span{color:var(--petrol-light)}
.sec-p{font-size:15px;line-height:1.8;max-width:520px;font-weight:400;color:rgba(255,255,255,.85)}

/* ===== CARD GRIDS ===== */
.r-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}
.rc{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.14);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s,background .4s;display:flex;flex-direction:column;background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%)}
.rc > *{position:relative;z-index:2}
.rc:hover{transform:translateY(-6px);background:rgba(255,255,255,.12);box-shadow:0 18px 48px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.18)}
.rc-iw{overflow:hidden;flex-shrink:0}
.rc-img{width:100%;height:200px;object-fit:cover;transition:transform .5s}
.rc:hover .rc-img{transform:scale(1.03)}
.rc-body{padding:22px 24px 28px;display:flex;flex-direction:column;flex:1}
.rc-loc{font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--orange-light);font-weight:700;margin-bottom:8px}
.rc-title{font-family:'Outfit',sans-serif;font-size:17px;font-weight:600;color:#fff;line-height:1.35;margin-bottom:6px}
.rc-desc{font-size:13px;color:rgba(255,255,255,.85);line-height:1.6;margin-bottom:16px;font-weight:300;flex:1}
.rc-meta{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--border-light)}
.rc-date{font-size:12px;color:rgba(255,255,255,.7)}
.rc-price{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:#fff}
.eb{display:inline-block;font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--orange);background:var(--orange-glow);border-radius:4px;padding:4px 10px;margin-top:8px}
.rc-cta{display:block;width:100%;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;background:transparent;color:#fff;border:1.5px solid var(--orange);border-radius:4px;padding:12px;cursor:pointer;margin-top:18px;text-align:center;transition:background .2s,color .2s;flex-shrink:0}
.rc-cta:hover{background:var(--orange);color:#fff}

/* Light section cards */
.sec.light .rc{background:var(--white);border-color:var(--border-dark)}
.sec.light .rc-title{color:var(--orange)}
.sec.light .rc-desc{color:var(--muted-dark)}
.sec.light .rc-price{color:var(--petrol-dark)}
.sec.light .rc-meta{border-color:var(--border-dark)}

/* Small service cards */
.s-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
.s-grid.col3{grid-template-columns:repeat(3,1fr)}
.s-grid.projects-grid{grid-template-columns:repeat(2,minmax(0,360px));justify-content:center;max-width:760px;margin-left:auto;margin-right:auto}
.sc{position:relative;border-radius:16px;padding:28px 24px;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(0,0,0,.26),inset 0 1px 0 rgba(255,255,255,.14);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s,background .4s;display:flex;flex-direction:column;overflow:hidden;background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%)}
.sc > *{position:relative;z-index:2}
.sc:hover{transform:translateY(-6px);background:rgba(255,255,255,.12);box-shadow:0 18px 48px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.18)}
.sc-icon{font-size:28px;margin-bottom:14px}
.project-card{padding:0;overflow:hidden}
.project-card .sc-preview{width:100%;height:160px;overflow:hidden;background:var(--petrol-deeper)}
.project-card .sc-preview img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.project-card:hover .sc-preview img{transform:scale(1.05)}
.project-card .sc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.sc-title{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;color:#fff;margin-bottom:6px}
.sc-title,.rc-title{color:var(--orange-light)}
.sec.light .sc-title,.sec.light .rc-title{color:var(--orange)}
.glass-sec .sc-title{color:var(--orange-light)}
h2 .faq-accent{color:var(--orange)}
.faq-intro h2{color:var(--petrol-dark)}
.sc-desc{font-size:13px;color:rgba(255,255,255,.92);line-height:1.65;margin-bottom:14px;font-weight:400;flex:1}
.sc-foot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-light)}
.sc-dur{font-size:11.5px;color:rgba(255,255,255,.88)}
.sc-price{font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;color:#fff}
.sc-cta{display:block;width:100%;font-family:'Outfit',sans-serif;font-size:12px;font-weight:600;background:transparent;color:#fff;border:1.5px solid var(--orange);border-radius:4px;padding:10px;cursor:pointer;margin-top:14px;text-align:center;transition:background .2s,color .2s;flex-shrink:0}
.sc-cta:hover{background:var(--orange);color:#fff}

/* Light section small cards */
.sec.light .sc{background:var(--white);border-color:var(--border-dark)}
.sec.light .sc-title{color:var(--orange)}
.sec.light .sc-desc{color:var(--muted-dark)}
.sec.light .sc-price{color:var(--petrol-dark)}
.sec.light .sc-foot{border-color:var(--border-dark)}

/* ===== PARALLAX IMAGE BREAK ===== */
.img-break{position:relative;height:400px;overflow:hidden}
.img-break img{width:100%;height:180%;position:absolute;top:-45%;left:0;object-fit:cover;object-position:center 0%;will-change:transform}
.img-break-overlay{position:absolute;inset:0;background:radial-gradient(ellipse 65% 70% at center,rgba(6,46,56,.72) 0%,rgba(6,46,56,.4) 55%,rgba(6,46,56,.18) 100%)}
.img-break-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:2;padding:0 24px}
.img-break-text blockquote{font-family:'Outfit',sans-serif;font-size:28px;font-weight:400;font-style:italic;color:#fff;line-height:1.45;max-width:640px;margin-bottom:16px;text-shadow:0 2px 22px rgba(0,0,0,.6)}
.img-break-text .qt-attr{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.9);text-shadow:0 1px 12px rgba(0,0,0,.6)}
.img-break-text .qt-stars{text-shadow:0 1px 12px rgba(0,0,0,.5)}

/* ===== ABOUT SPLIT ===== */
.split{display:grid;grid-template-columns:5fr 7fr;align-items:center;padding:72px 56px}
.sp-iw{overflow:hidden;position:relative;height:440px;border-radius:18px;box-shadow:0 16px 44px rgba(0,0,0,.28)}
.sp-iw img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.sp-txt{padding:0 0 0 56px;display:flex;flex-direction:column;justify-content:center;background:transparent}
.sp-txt p{font-size:15px;color:rgba(255,255,255,.9);line-height:1.85;margin-bottom:16px;font-weight:400}
.sp-quote{font-family:'Outfit',sans-serif;font-size:18px;color:#fff;font-weight:500;font-style:italic;line-height:1.55;padding-left:20px;border-left:3px solid var(--petrol);margin:12px 0 24px}
.cert-row{display:flex;gap:10px;margin-top:28px;flex-wrap:wrap}
.cert-pill{font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--petrol-light);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:4px;padding:8px 16px}
.btn-sec{font-family:'Outfit',sans-serif;display:inline-block;font-size:13px;font-weight:600;background:var(--orange);color:#fff;border:none;border-radius:4px;padding:13px 28px;cursor:pointer;margin-top:28px;width:fit-content;transition:all .2s}
.btn-sec:hover{background:var(--orange-hover);transform:translateY(-2px)}

/* ===== ACHIEVEMENTS ===== */
.ach-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:32px}
.ach{background:var(--petrol-mid);border-radius:8px;padding:32px 28px;border:1px solid var(--border-light);display:flex;gap:20px;align-items:flex-start;transition:transform .3s}
.ach:hover{transform:translateY(-3px)}
.ach-num{font-family:'Outfit',sans-serif;font-size:36px;font-weight:800;color:var(--orange);line-height:1;min-width:60px}
.ach-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;color:#fff;margin-bottom:6px}
.ach-desc{font-size:13.5px;color:var(--muted-dark);line-height:1.6;font-weight:400}
.sec.light .ach{background:var(--white);border-color:var(--border-dark)}
.sec.light .ach-title{color:var(--petrol-dark)}
.sec.light .ach-desc{color:var(--muted-dark)}
.sec.light .ach-num{color:var(--orange)}

/* ===== METHOD ===== */
.m-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.mc{position:relative;background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);padding:32px 28px;border-radius:16px;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.16);transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s,background .4s;overflow:hidden}
.mc::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--mc-accent,var(--petrol-light));opacity:1}
.mc:hover{transform:translateY(-6px);box-shadow:0 18px 48px rgba(0,0,0,.34),inset 0 1px 0 rgba(255,255,255,.22)}
.mc-icon{width:52px;height:52px;background:var(--mc-accent-soft,rgba(255,255,255,.12));border:1px solid var(--mc-accent-border,rgba(255,255,255,.3));border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:22px}
.mc-icon svg{stroke:var(--mc-accent,#fff)}
/* Wim Hof logo colour scheme per pillar */
.mc.mc-breath{--mc-accent:#5BAFC9;--mc-accent-soft:rgba(62,141,166,.28);--mc-accent-border:rgba(91,175,201,.4);background:rgba(62,141,166,.16);border-color:rgba(91,175,201,.4)}
.mc.mc-breath:hover{background:rgba(62,141,166,.24)}
.mc.mc-breath .mc-icon{background:rgba(62,141,166,.18);border-color:rgba(91,175,201,.38)}
.mc.mc-breath .mc-icon svg{stroke:#7FC4DA}
.mc.mc-cold{--mc-accent:#A9CDD6;--mc-accent-soft:rgba(169,205,214,.22);--mc-accent-border:rgba(169,205,214,.45);background:rgba(169,205,214,.14);border-color:rgba(169,205,214,.4)}
.mc.mc-cold:hover{background:rgba(169,205,214,.2)}
.mc.mc-cold .mc-icon{background:rgba(169,205,214,.16);border-color:rgba(169,205,214,.36)}
.mc.mc-cold .mc-icon svg{stroke:#C5E0E8}
.mc.mc-mind{--mc-accent:var(--orange-light);--mc-accent-soft:rgba(232,114,58,.22);--mc-accent-border:rgba(232,114,58,.45);background:rgba(232,114,58,.18);border-color:rgba(232,114,58,.42)}
.mc.mc-mind:hover{background:rgba(232,114,58,.26)}
.mc.mc-mind .mc-icon{background:rgba(232,114,58,.16);border-color:rgba(232,114,58,.34)}
.mc.mc-mind .mc-icon svg{stroke:var(--orange-light)}
.mc-num{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mc-accent,var(--orange-light));font-weight:700;margin-bottom:10px}
.mc-title{font-family:'Outfit',sans-serif;font-size:18px;font-weight:600;color:#fff;margin-bottom:10px}
.mc-desc{font-size:14px;color:rgba(255,255,255,.9);line-height:1.75;font-weight:400}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.bc{background:var(--petrol-mid);border-radius:8px;overflow:hidden;border:1px solid var(--border-light);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.bc:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,0,0,.15)}
.bc-iw{overflow:hidden;flex-shrink:0}
.bc-img{width:100%;height:180px;object-fit:cover;transition:transform .5s}
.bc:hover .bc-img{transform:scale(1.04)}
.bc-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.bc-cat{font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--petrol);font-weight:600;margin-bottom:8px}
.bc-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;color:#fff;line-height:1.35;margin-bottom:10px}
.bc-excerpt{font-size:13px;color:var(--muted);line-height:1.65;font-weight:300;flex:1}
.bc-link{font-family:'Outfit',sans-serif;display:inline-block;font-size:12px;font-weight:600;color:var(--orange);margin-top:14px;transition:color .2s;flex-shrink:0}
.bc-link:hover{color:var(--orange-hover)}

/* ===== GIFT CARD ===== */
.gc-wrap{display:grid;grid-template-columns:1fr 1fr}
.gc-visual{background:linear-gradient(135deg,var(--petrol) 0%,var(--petrol-mid) 100%);padding:64px 48px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;overflow:hidden}
.gc-visual h3{font-family:'Outfit',sans-serif;font-size:32px;font-weight:700;color:#fff;margin-bottom:12px;position:relative}
.gc-visual p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.6;position:relative;max-width:320px}
.gc-txt{padding:64px 48px;display:flex;flex-direction:column;justify-content:center;background:var(--petrol-lightest)}
.gc-txt h2{color:var(--petrol-dark)}
.gc-txt h2 span{color:var(--petrol-light)}
.gc-txt .tag{color:var(--petrol)}
.gc-txt p{font-size:15px;color:var(--muted-dark);line-height:1.8;margin-bottom:16px;font-weight:300}

/* ===== GALLERY ===== */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:260px;gap:6px}
.gal-w{overflow:hidden;border-radius:4px}
.gal-w img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal-w:hover img{transform:scale(1.04)}

/* ===== BOTTOM CTA ===== */
.cta-bottom{padding:100px 64px;text-align:center;background:transparent;position:relative;overflow:hidden}
.cta-bottom::before{content:'';position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:760px;height:760px;background:radial-gradient(circle,rgba(0,151,178,.10) 0%,transparent 72%);border-radius:50%;pointer-events:none}
.cta-bottom h2{color:#fff;margin-bottom:14px;position:relative;font-size:42px}
.cta-bottom h2 span{color:var(--orange)}
.cta-bottom p{font-size:15px;color:rgba(255,255,255,.8);margin-bottom:36px;position:relative;font-weight:300}
.btn-lg{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;background:var(--orange);color:#fff;border:none;border-radius:4px;padding:16px 40px;cursor:pointer;position:relative;transition:all .2s}
.btn-lg:hover{background:var(--orange-hover);transform:translateY(-2px);box-shadow:0 10px 30px rgba(232,114,58,.3)}

/* ===== FOOTER ===== */
footer{padding:40px 64px;background:var(--bg-grad-bottom);border-top:1px solid rgba(255,255,255,.08)}
.ft-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px}
.ft-brand p{font-size:13px;color:rgba(255,255,255,.85);line-height:1.6;margin-top:12px;font-weight:300}
.ft-logo{height:50px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.9}
.ft-col h4{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:14px}
.ft-col a{display:block;font-size:13px;color:rgba(255,255,255,.85);margin-bottom:8px;transition:color .2s}
.ft-col a:hover{color:#fff}
.ft-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,.04)}
.ft-copy{font-size:11px;color:rgba(255,255,255,.7)}
.ft-legal a{font-size:11px;color:rgba(255,255,255,.7);margin-left:20px}

/* ===== MOBILE ===== */
@media(max-width:900px){
  nav{padding:14px 24px}
  nav.scrolled{padding:10px 24px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-body{padding:0 28px 60px}
  .hero h1{font-size:34px;max-width:100%}
  .page-hero .hero-body{padding:80px 28px 36px}
  .page-hero h1{font-size:28px}
  .page-hero{height:360px}
  .cred{grid-template-columns:repeat(2,1fr)}
  .cred-item{padding:16px}
  .cred-num{font-size:18px}
  .sec{padding:48px 24px}
  h2{font-size:28px}
  .r-grid,.m-grid,.blog-grid{grid-template-columns:1fr}
  .s-grid,.s-grid.col3{grid-template-columns:1fr}
  .s-grid.projects-grid{grid-template-columns:minmax(0,360px);max-width:360px}
  .split{grid-template-columns:1fr}
  .sp-iw{height:320px;min-height:auto}
  .sp-txt{padding:40px 24px}
  .ach-grid{grid-template-columns:1fr}
  .gc-wrap{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .img-break{height:auto;min-height:360px;padding:40px 0}
  .img-break img{height:200%;top:-50%;object-position:center 38%}
  .img-break-text{position:relative;inset:auto;min-height:280px}
  .img-break-text blockquote{font-size:20px}
  .cta-bottom{padding:60px 24px}
  .cta-bottom h2{font-size:28px}
  footer{padding:32px 24px}
  .ft-top{grid-template-columns:1fr;gap:24px}
  .ft-bottom{flex-direction:column;gap:12px;text-align:center}
}
@media(max-width:480px){
  .hero h1{font-size:28px}
  .cred{grid-template-columns:1fr 1fr}
  .cred-num{font-size:16px}
  .cred-label{font-size:9px}
}

/* ===== METHODS SECTION (Katja's three approaches) ===== */
.methods-sec{position:relative;padding:100px 64px;background:var(--petrol-dark);overflow:hidden}
.methods-sec .methods-bg{position:absolute;top:-20%;left:0;right:0;height:140%;background:url('/uploads/methods-water.jpg') center/cover;opacity:1;will-change:transform}
.methods-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto}
.methods-head{text-align:center;margin-bottom:16px}
.methods-head h2{text-shadow:0 2px 20px rgba(0,0,0,.55)}
.methods-head .tag{text-shadow:0 1px 10px rgba(0,0,0,.5)}
.methods-intro{text-align:center;max-width:620px;margin:0 auto 56px;color:rgba(255,255,255,.92);font-size:16px;line-height:1.8;font-weight:300;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.methods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
/* connecting thread */
.methods-grid::before{content:'';position:absolute;top:90px;left:16%;right:16%;height:2px;background:linear-gradient(to right,transparent,var(--petrol) 20%,var(--orange) 50%,var(--petrol) 80%,transparent);opacity:.4;z-index:0}
.method-card{position:relative;z-index:1;background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:40px 32px;text-align:center;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s,background .4s;overflow:hidden}
.method-card:hover{transform:translateY(-8px);background:rgba(255,255,255,.12);box-shadow:0 20px 50px rgba(0,0,0,.35)}
.method-card.primary{background:rgba(232,114,58,.22);border-color:rgba(232,114,58,.45)}
.method-card.primary:hover{background:rgba(232,114,58,.3)}
.method-badge{display:inline-block;font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;padding:5px 14px;border-radius:20px;margin-bottom:20px}
.method-badge.main{background:var(--orange);color:#fff}
.method-badge.soon{background:rgba(255,255,255,.12);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2)}
.method-badge.active{background:rgba(91,168,92,.18);color:var(--green-light);border:1px solid rgba(91,168,92,.45)}
/* Nature card: green accents */
.method-card.nature{background:rgba(91,168,92,.16);border-color:rgba(91,168,92,.38)}
.method-card.nature:hover{background:rgba(91,168,92,.24)}
.method-card.nature .method-icon{background:rgba(91,168,92,.16);border-color:rgba(91,168,92,.34)}
.method-card.nature .method-icon svg{stroke:var(--green-light)}
/* Oxygen card: neutral grey accents */
.method-card.oxygen{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.2)}
.method-card.oxygen:hover{background:rgba(255,255,255,.11)}
.method-card.oxygen .method-icon{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.24)}
.method-card.oxygen .method-icon svg{stroke:rgba(255,255,255,.85)}
.method-icon{width:72px;height:72px;margin:0 auto 22px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center}
.method-card.primary .method-icon{background:rgba(232,114,58,.15);border-color:rgba(232,114,58,.3)}
.method-icon svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:1.4}
.method-card.primary .method-icon svg{stroke:var(--orange)}
.method-name{font-family:'Outfit',sans-serif;font-size:21px;font-weight:700;color:#fff;margin-bottom:10px}
.method-desc{font-size:14px;color:rgba(255,255,255,.85);line-height:1.7;font-weight:300}
.methods-foot{text-align:center;margin-top:48px;color:rgba(255,255,255,.85);font-size:15px;font-style:italic;font-weight:300;text-shadow:0 1px 12px rgba(0,0,0,.5)}
@media(max-width:900px){
  .methods-sec{padding:60px 24px}
  .methods-grid{grid-template-columns:1fr;gap:20px}
  .methods-grid::before{display:none}
}

/* ===== REVIEWS / TESTIMONIALS ===== */
.reviews-sec{padding:100px 64px;background:transparent;position:relative;overflow:hidden}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.review-card{background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:32px 28px;display:flex;flex-direction:column;box-shadow:0 8px 30px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.14);transition:transform .4s cubic-bezier(.22,1,.36,1),background .4s,box-shadow .4s}
.review-card:hover{transform:translateY(-6px);background:rgba(10,74,88,.6);box-shadow:0 18px 48px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.2)}
.review-head{margin-bottom:14px}
.review-author{font-family:'Outfit',sans-serif;font-size:16px;font-weight:600;color:#fff}
.review-date{font-size:12px;color:var(--orange-light);font-weight:500;margin-top:3px}
.review-stars{color:var(--orange-light);font-size:15px;letter-spacing:3px;margin-bottom:16px}
.review-text{font-size:14px;color:rgba(255,255,255,.94);line-height:1.8;font-weight:400;font-style:italic;flex:1;text-shadow:0 1px 2px rgba(0,0,0,.18)}
@media(max-width:900px){.reviews-sec{padding:60px 24px}.reviews-grid{grid-template-columns:1fr;gap:20px}}

/* mobile close button */
.mobile-close{position:absolute;top:24px;right:28px;width:32px;height:32px;cursor:pointer}
.mobile-close span{position:absolute;top:50%;left:0;width:32px;height:2px;background:#fff}
.mobile-close span:nth-child(1){transform:rotate(45deg)}
.mobile-close span:nth-child(2){transform:rotate(-45deg)}
/* glassmorphism service cards + hover */
.sc{transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s,background .4s}
.sc:hover{transform:translateY(-8px);box-shadow:0 18px 44px rgba(0,0,0,.16)}
.sc-icon{transition:transform .4s}
.sc:hover .sc-icon{transform:scale(1.12) rotate(-4deg)}
/* parallax break for services page */
.svc-break{position:relative;height:340px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.svc-break img{position:absolute;top:-35%;left:0;width:100%;height:175%;object-fit:cover;will-change:transform}
.svc-break .svc-break-ov{position:absolute;inset:0;background:radial-gradient(ellipse 75% 65% at center,rgba(6,46,56,.52) 0%,rgba(6,46,56,.25) 60%,rgba(6,46,56,.15) 100%);z-index:1}
.svc-break-txt{position:relative;z-index:2;text-align:center;max-width:760px;padding:0 32px}
.svc-break-txt blockquote{font-family:'Outfit',sans-serif;font-size:26px;font-weight:300;color:#fff;line-height:1.5;font-style:italic;text-shadow:0 2px 20px rgba(0,0,0,.6)}
.svc-break-txt .sb-attr{margin-top:18px;color:var(--orange-light);font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;text-shadow:0 1px 12px rgba(0,0,0,.6)}
@media(max-width:768px){
  .svc-break{height:auto;min-height:380px;padding:40px 0}
  .svc-break img{height:120%;top:-10%;object-position:top!important}
  .svc-break-txt blockquote{font-size:20px}
}

/* ===== COOKIE BANNER ===== */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;max-width:560px;margin:0 auto;background:rgba(10,74,88,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:24px 26px;z-index:9999;box-shadow:0 20px 60px rgba(0,0,0,.35);transform:translateY(140%);transition:transform .5s cubic-bezier(.22,1,.36,1)}
.cookie-banner.show{transform:translateY(0)}
.cookie-title{font-family:'Outfit',sans-serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:8px}
.cookie-text{font-size:13px;color:rgba(255,255,255,.78);line-height:1.6;margin-bottom:18px}
.cookie-text a{color:var(--orange);text-decoration:underline}
.cookie-btns{display:flex;gap:12px;flex-wrap:wrap}
.cookie-btns button{flex:1;min-width:120px;padding:12px 20px;border-radius:30px;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:transform .2s,opacity .2s}
.cookie-btns button:hover{transform:translateY(-2px)}
.ck-accept{background:var(--orange);color:#fff}
.ck-decline{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)!important}
@media(max-width:600px){.cookie-banner{left:12px;right:12px;bottom:12px;padding:20px}}

/* ===== ABOUT STORY BLOCK ===== */
.story-block{max-width:760px;margin:40px auto 0;text-align:center}
.story-block p{font-size:16px;line-height:1.9;color:rgba(255,255,255,.82);font-weight:300;margin-bottom:22px}
.story-invite{font-family:'Outfit',sans-serif;font-size:19px!important;font-weight:500!important;color:#fff!important;font-style:italic;margin-top:8px}

/* ===== GLASS SECTION (offer page) ===== */
.sec.glass-sec{position:relative;background:transparent;overflow:hidden}
.sec.glass-sec .glass-bg{position:absolute;inset:0;background:url('/uploads/parallax-group.jpg') center/cover;opacity:.15;will-change:transform}
.sec.glass-sec>*{position:relative;z-index:2}
.sec.glass-sec h2,.sec.glass-sec .sec-p{color:#fff}
.sec.glass-sec .sec-p{color:rgba(255,255,255,.78)}
/* glass cards */
.glass-sec .sc{border:1px solid rgba(255,255,255,.22)}
.glass-sec .sc:hover{transform:translateY(-6px)}
.glass-sec .sc-title{color:var(--orange-light)}
.glass-sec .sc-desc{color:rgba(255,255,255,.92)}
.glass-sec .sc-icon{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15)}
.glass-sec .sc-icon svg{stroke:#fff}
.glass-sec .sc-dur{color:rgba(255,255,255,.88)}
.glass-sec .sc-price{color:#fff}
.glass-sec .sc-foot{border-top-color:rgba(255,255,255,.12)}
.glass-sec .sc-cta{background:transparent;color:#fff;border:1.5px solid var(--orange)}
.glass-sec .sc-cta:hover{background:var(--orange);border-color:var(--orange);color:#fff}

/* ===== FAQ / GAIN CLARITY ===== */
.faq-sec{padding:100px 64px;background:var(--petrol-lightest)}
.faq-wrap{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:.85fr 1.4fr;gap:56px;align-items:start}
.faq-intro h2{margin-bottom:14px}
.faq-intro p{color:var(--muted-dark);font-size:16px;line-height:1.7}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid rgba(10,74,88,.15)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:22px 36px 22px 0;font-family:'Outfit',sans-serif;font-size:17px;font-weight:500;color:var(--petrol-dark);cursor:pointer;position:relative;transition:color .2s}
.faq-q:hover{color:var(--petrol)}
.faq-q::after{content:'';position:absolute;right:4px;top:50%;width:10px;height:10px;border-right:2px solid var(--petrol);border-bottom:2px solid var(--petrol);transform:translateY(-70%) rotate(45deg);transition:transform .3s}
.faq-item.open .faq-q::after{transform:translateY(-30%) rotate(-135deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-a p{color:var(--muted-dark);font-size:15px;line-height:1.8;padding:0 40px 4px 0}
.faq-item.open .faq-a{max-height:320px;padding-bottom:22px}
@media(max-width:860px){.faq-sec{padding:60px 24px}.faq-wrap{grid-template-columns:1fr;gap:32px}}

/* ===== REVIEWS PAGE ===== */
.rev-gallery{columns:4;column-gap:14px;max-width:1200px;margin:0 auto;padding:0 0 20px}
.rev-gallery img{width:100%;border-radius:12px;margin-bottom:14px;display:block;break-inside:avoid;transition:transform .4s,filter .4s;filter:saturate(.95)}
.rev-gallery img:hover{transform:scale(1.02);filter:saturate(1.1)}
@media(max-width:900px){.rev-gallery{columns:2;column-gap:10px}.rev-gallery img{margin-bottom:10px}}
.rev-page-grid{columns:3;column-gap:24px;max-width:1100px;margin:48px auto 0}
.rev-page-grid .review-card{break-inside:avoid;margin-bottom:24px;display:block}
@media(max-width:900px){.rev-page-grid{columns:1}}
.reviews-more-btn{display:none;margin:28px auto 0;font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;color:#fff;background:rgba(255,255,255,.08);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1.5px solid var(--orange);border-radius:30px;padding:13px 28px;cursor:pointer;transition:background .2s,transform .2s}
.reviews-more-btn:hover{background:var(--orange);transform:translateY(-2px)}
@media(max-width:900px){.reviews-more-btn{display:block}}
/* leave a review form */
.rev-form-sec{padding:90px 64px;background:transparent}
.rev-form{max-width:620px;margin:36px auto 0;background:rgba(255,255,255,.05);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px}
.rev-form label{display:block;font-family:'Outfit',sans-serif;font-size:13px;font-weight:600;color:rgba(255,255,255,.85);margin-bottom:8px;margin-top:20px}
.rev-form label:first-of-type{margin-top:0}
.rev-form input,.rev-form textarea{width:100%;padding:13px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:#fff;font-family:'DM Sans',sans-serif;font-size:15px}
.rev-form input::placeholder,.rev-form textarea::placeholder{color:rgba(255,255,255,.4)}
.rev-form input:focus,.rev-form textarea:focus{outline:none;border-color:var(--orange)}
.rev-form textarea{min-height:120px;resize:vertical}
.star-pick{display:flex;gap:6px;margin-top:4px}
.star-pick span{font-size:30px;color:rgba(255,255,255,.25);cursor:pointer;transition:color .15s,transform .15s}
.star-pick span:hover{transform:scale(1.15)}
.star-pick span.on{color:var(--orange)}
.rev-form button{margin-top:28px;width:100%;padding:15px;border:none;border-radius:30px;background:var(--orange);color:#fff;font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .2s}
.rev-form button:hover{background:var(--orange-hover);transform:translateY(-2px)}
.rev-consent{font-size:12px!important;color:rgba(255,255,255,.55)!important;font-weight:400!important;margin-top:18px!important;line-height:1.5}
.rev-thanks{display:none;text-align:center;color:#fff;padding:40px;font-size:17px}

/* ===== BLOG POST PAGE ===== */
body.post-page{background:var(--cream);color:var(--dark)}
.post-wrap{max-width:760px;margin:0 auto;padding:140px 24px 80px}
.post-loading{text-align:center;color:var(--muted-dark);padding:60px 0}
.post-head{margin-bottom:32px}
.post-back{font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;color:var(--petrol);text-decoration:none;display:block;margin-bottom:24px;transition:color .2s}
.post-back:hover{color:var(--orange)}
.post-head .bc-cat{display:inline-block;margin-bottom:14px}
.post-head h1{font-family:'Outfit',sans-serif;font-size:clamp(30px,5vw,46px);font-weight:700;line-height:1.15;color:var(--dark);margin:0 0 16px}
.post-date{font-family:'Outfit',sans-serif;font-size:14px;color:var(--muted-dark);font-weight:500}
.post-hero{margin:8px 0 36px;border-radius:10px;overflow:hidden}
.post-hero img{width:100%;height:auto;display:block}
.post-body{font-family:'DM Sans',sans-serif;font-size:18px;line-height:1.75;color:var(--dark)}
.post-body h2{font-family:'Outfit',sans-serif;font-size:26px;font-weight:700;color:var(--dark);margin:40px 0 14px}
.post-body h3{font-family:'Outfit',sans-serif;font-size:21px;font-weight:600;color:var(--dark);margin:32px 0 12px}
.post-body p{margin:0 0 20px}
.post-body ul,.post-body ol{margin:0 0 20px;padding-left:24px}
.post-body li{margin-bottom:8px}
.post-body img{max-width:100%;height:auto;border-radius:8px;margin:24px 0}
.post-body a{color:var(--petrol);text-decoration:underline}
.post-body blockquote{border-left:3px solid var(--petrol);padding-left:20px;margin:24px 0;font-style:italic;color:var(--muted-dark)}
.post-body strong{font-weight:600;color:var(--dark)}
.post-foot{margin-top:48px;padding-top:32px;border-top:1px solid var(--border-dark);text-align:center}

/* ===== LANGUAGE TOGGLE ===== */
.lang-toggle{font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;letter-spacing:.05em;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:4px;padding:8px 12px;cursor:pointer;transition:background .2s,border-color .2s;min-width:42px}
.lang-toggle:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.45)}
.mobile-menu .lang-toggle{font-size:16px;padding:10px 18px;margin-top:8px}

/* ===== Popup forms (contact + gift) ===== */
.vform-overlay{position:fixed;inset:0;background:rgba(18,70,82,.62);backdrop-filter:blur(10px) saturate(110%);-webkit-backdrop-filter:blur(10px) saturate(110%);display:none;align-items:center;justify-content:center;z-index:3000;padding:24px}
.vform-overlay.open{display:flex}
.vform-box{position:relative;width:100%;max-width:480px;background:rgba(255,255,255,.14);backdrop-filter:blur(20px) saturate(120%);-webkit-backdrop-filter:blur(20px) saturate(120%);border:1px solid rgba(255,255,255,.28);border-radius:20px;padding:38px 32px;box-shadow:0 8px 30px rgba(6,46,56,.18),inset 0 1px 0 rgba(255,255,255,.22);max-height:90vh;overflow-y:auto}
.vform-box,.vform-box *{box-sizing:border-box}
.vform-box h3{font-family:'Outfit',sans-serif;font-size:26px;color:var(--orange-light);margin-bottom:6px;font-weight:700}
.vform-sub{font-size:14px;color:rgba(255,255,255,.75);margin-bottom:22px;line-height:1.6}
.vform-close{position:absolute;top:16px;right:18px;background:none;border:none;color:rgba(255,255,255,.6);font-size:26px;cursor:pointer;line-height:1;transition:color .2s}
.vform-close:hover{color:var(--orange)}
.vform-hp{position:absolute;left:-9999px}
.vfield{margin-bottom:16px}
.vfield label{display:block;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#fff;margin-bottom:6px;font-weight:600}
.vfield input,.vfield textarea{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);border-radius:6px;padding:12px 14px;color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;transition:border-color .2s}
.vfield input:focus,.vfield textarea:focus{outline:none;border-color:var(--orange)}
.vfield textarea{resize:vertical;min-height:90px}
.vform-submit{width:100%;background:var(--orange);color:#fff;border:none;border-radius:6px;padding:13px;font-family:'Outfit',sans-serif;font-weight:600;font-size:15px;cursor:pointer;transition:background .2s;margin-top:4px}
.vform-submit:hover{background:var(--orange-hover)}
.vform-success{display:none;text-align:center;padding:20px 0}
.vform-success.show{display:block}
.vform-success .vform-check{font-size:42px;color:var(--orange);margin-bottom:12px}
.vform-success h3{color:#fff;margin-bottom:8px}
.vform-success p{color:rgba(255,255,255,.85);font-size:15px;line-height:1.6}

/* ===== IMAGE CAROUSEL (Reviews / Wim Hof / About) ===== */
.vcar{position:relative;max-width:720px;margin:0 auto;padding:0 52px}
.vcar-view{overflow:hidden;border-radius:14px;position:relative;background:var(--petrol-deeper)}
.vcar-track{display:flex;transition:transform .55s cubic-bezier(.22,1,.36,1);will-change:transform}
.vcar-slide{flex:0 0 100%;min-width:0;position:relative;height:460px;display:flex;align-items:center;justify-content:center;overflow:hidden}
/* blurred fill behind the contained image, so any format looks intentional */
.vcar-slide::before{content:"";position:absolute;inset:0;background-image:var(--bg);background-size:cover;background-position:center;filter:blur(22px) brightness(.55);transform:scale(1.15)}
.vcar-slide img{position:relative;max-width:100%;max-height:460px;width:auto;height:auto;object-fit:contain;border-radius:6px;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.vcar-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(11,26,29,.55);backdrop-filter:blur(6px);color:#fff;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;z-index:3}
.vcar-btn:hover{background:var(--orange);border-color:var(--orange)}
.vcar-prev{left:0}
.vcar-next{right:0}
.vcar-dots{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:20px}
.vcar-dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,.28);cursor:pointer;padding:0;transition:background .2s,transform .2s}
.vcar-dot.active{background:var(--orange);transform:scale(1.25)}
@media(max-width:760px){
  .vcar{padding:0 14px;max-width:100%}
  .vcar-slide{height:340px}
  .vcar-slide img{max-height:340px}
  .vcar-btn{width:36px;height:36px;font-size:17px}
  .vcar-prev{left:-2px}
  .vcar-next{right:-2px}
}

/* ===== ABOUT COLLAGE ===== */
.about-collage{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:12px;max-width:980px;margin:0 auto}
.about-collage img{width:100%;height:100%;object-fit:cover;border-radius:10px;background:var(--petrol-deeper);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.about-collage img:hover{transform:scale(1.03)}
.about-collage .span2{grid-column:span 2;grid-row:span 2}
@media(max-width:760px){
  .about-collage{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .about-collage .span2{grid-column:span 2;grid-row:span 2}
}

/* ===== ACTIVE NAV LINK (visible on both dark + scrolled nav) ===== */
.nav-links a.nav-active{color:var(--orange)!important;font-weight:600}
.nav-links a.nav-active:hover{color:var(--orange-hover)!important}
nav.scrolled .nav-links a.nav-active{color:var(--orange)!important}
.mobile-link.nav-active{color:var(--orange)!important;font-weight:600}

/* ===== GIFT CARD (frosted glass, centered below the project cards) ===== */
.gift-card-block{display:flex;justify-content:center;padding:160px 56px 16px;scroll-margin-top:90px}
.gift-card-glass{max-width:620px;width:100%;text-align:center;padding:48px 44px;border-radius:20px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);
  border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(6,46,56,.3),inset 0 1px 0 rgba(255,255,255,.14)}
.gift-card-glass .tag{display:block;margin-bottom:6px}
.gift-card-glass h2{line-height:1.2}
@media(max-width:760px){
  .gift-card-block{padding:48px 24px 16px}
  .gift-card-glass{padding:40px 26px}
  .gift-card-glass h2{font-size:24px!important}
}

/* ===== Workshop booking modal (dropdown + total) ===== */
.wshop-select{width:100%;font-family:'DM Sans',sans-serif;font-size:15px;color:var(--dark);background:#fff;border:1px solid var(--petrol-light);border-radius:8px;padding:11px 12px;margin-top:6px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23007A8A' stroke-width='1.6' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.wshop-select:focus{outline:none;border-color:var(--petrol)}
.wshop-select option:disabled{color:#b0b0b0}
.wshop-total{font-family:'Outfit',sans-serif;font-weight:600;font-size:18px;color:var(--petrol-deeper);margin:18px 0 6px;text-align:right}
.wshop-secure{font-size:12px;color:var(--muted-dark);text-align:center;margin-top:12px}
.sc-cta-soldout{background:#d8d8d8 !important;color:#888 !important;cursor:not-allowed;border-color:#d8d8d8 !important}
.glass-sec .sc-cta-soldout{background:rgba(255,255,255,.06) !important;color:rgba(255,255,255,.45) !important;border:1px solid rgba(255,255,255,.12) !important}

/* ===== Service card images ===== */
.sc-iw{overflow:hidden;flex-shrink:0;margin:-28px -24px 0;border-radius:14px 14px 0 0}
.sc-img{width:100%;aspect-ratio:16/10;height:auto;object-fit:cover;object-position:center 28%;display:block;transition:transform .5s}
.sc-has-img:hover .sc-img{transform:scale(1.04)}
.sc-has-img{padding-top:0;overflow:hidden}
.sc-body{display:flex;flex-direction:column;flex:1;padding-top:22px}
.sc-has-img .sc-body{flex:1}
/* Image cards: keep title/desc/foot/button flowing naturally in the body */
.sc-has-img .sc-foot{margin-top:auto}

/* ===== Service card location tag ===== */
.sc-loc{font-family:'Outfit',sans-serif;font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--petrol-light);margin-bottom:6px}
.sec.light .sc-loc{color:var(--petrol)}

/* ===== Retreat info popup ===== */
.winfo-box{max-width:560px;max-height:85vh;overflow-y:auto;text-align:left}
.winfo-loc{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.7);margin-bottom:6px}
.winfo-box h3{font-family:'Outfit',sans-serif;font-size:24px;color:var(--orange-light);margin-bottom:8px;line-height:1.2}
.winfo-meta{font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;color:var(--orange-light);margin-bottom:18px}
.winfo-video{position:relative;width:100%;aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-bottom:20px;background:rgba(0,0,0,.25);box-shadow:0 8px 24px rgba(0,0,0,.28)}
.winfo-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.winfo-text{font-size:14px;line-height:1.7;color:rgba(255,255,255,.88);margin-bottom:22px}
.winfo-text p{margin-bottom:14px}
.winfo-text p:last-child{margin-bottom:0}

/* ===== PAGE-WIDE LIGHT THEME (#eaf6f7) - "My offer" page (punkt 9) ===== */
body.page-light::before{background:#eaf6f7}
body.page-light{background:var(--petrol-dark);color:#fff}
body.page-light::before{content:"";position:fixed;inset:0;background:url('/uploads/methods-water.jpg') center/cover;z-index:-2}
body.page-light::after{content:"";position:fixed;inset:0;background:rgba(6,46,56,.12);z-index:-1}
/* All sections transparent so the water shows through */
body.page-light .sec.dark,
body.page-light .sec{background:transparent;color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
body.page-light .sec.dark h2,
body.page-light .sec h2{color:#fff}
body.page-light .sec.dark h2 span,
body.page-light .sec h2 span{color:var(--petrol-light)}
body.page-light .sec.dark .sec-p,
body.page-light .sec .sec-p{color:rgba(255,255,255,.85)}
/* Tags */
body.page-light .sec .tag{color:var(--orange-light)}
/* Glass workshop section */
body.page-light .glass-sec{background:transparent}
body.page-light .glass-sec .glass-bg{display:none}
body.page-light .glass-sec h2{color:#fff}
body.page-light .glass-sec .sec-p{color:rgba(255,255,255,.85)}
/* Service cards: frosted glass like the methods cards */
body.page-light .sc{background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 30px rgba(6,46,56,.3),inset 0 1px 0 rgba(255,255,255,.14)}
body.page-light .sc:hover{background:rgba(255,255,255,.12);box-shadow:0 18px 48px rgba(6,46,56,.36),inset 0 1px 0 rgba(255,255,255,.18)}
body.page-light .sc-cta{background:transparent;color:#fff;border:1.5px solid var(--orange)}
body.page-light .sc-cta:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
/* Project cards follow the same frosted style */
body.page-light .project-card .sc-preview{background:var(--petrol-deeper)}
/* CTA bottom */
body.page-light .cta-bottom{background:transparent}
body.page-light .cta-bottom h2{color:#fff}
body.page-light .cta-bottom h2 span{color:var(--orange)}
body.page-light .cta-bottom p{color:rgba(255,255,255,.8)}
/* FAQ */
/* FAQ */
body.page-light .faq-sec{background:transparent}
body.page-light .faq-intro h2{color:#fff}
body.page-light .faq-intro p{color:rgba(255,255,255,.85)}
body.page-light .faq-list{background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:8px 28px;box-shadow:0 8px 30px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.14)}
body.page-light .faq-item{border-bottom:1px solid rgba(255,255,255,.14)}
body.page-light .faq-q{color:#fff}
body.page-light .faq-q:hover{color:var(--orange-light)}
body.page-light .faq-q::after{border-right-color:var(--orange-light);border-bottom-color:var(--orange-light)}
body.page-light .faq-a p{color:rgba(255,255,255,.85)}
/* Carousel section heading */
body.page-light #whm-carousel-sec h2{color:#fff}
body.page-light #whm-carousel-sec .sec-p{color:rgba(255,255,255,.85)}
/* Footer stays solid dark */
body.page-light footer{background:var(--bg-grad-bottom)}

/* ===== DRIVE PARALLAX BANNER (home "what drives me") ===== */
.drive-parallax{position:relative;padding:110px 64px;overflow:hidden}
.drive-parallax .drive-bg{position:absolute;top:-20%;left:0;right:0;height:140%;background:url('/uploads/header-review.jpg') center/cover;will-change:transform;z-index:0}
/* readable text without a flat color wash: soft vignette + bottom-weighted darkening */
.drive-parallax::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,46,56,.55) 0%,rgba(6,46,56,.35) 45%,rgba(6,46,56,.6) 100%)}
.drive-parallax .drive-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto}
.drive-parallax h2{text-shadow:0 2px 18px rgba(0,0,0,.45)}
.drive-parallax .sec-p{text-shadow:0 1px 12px rgba(0,0,0,.4)}
.drive-parallax .ach{background:rgba(255,255,255,.1);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.2)}
.drive-parallax .ach:hover{background:rgba(255,255,255,.15)}
.drive-parallax .ach-title{color:#fff}
.drive-parallax .ach-desc{color:rgba(255,255,255,.9)}
.drive-parallax .ach-num{color:var(--orange-light)}
@media(max-width:768px){.drive-parallax{padding:70px 24px}}

/* ===== FROSTED QUOTE CARD (over parallax banners) ===== */
.quote-card{
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:18px;
  padding:44px 48px;
  max-width:680px;
  margin:0 auto;
  box-shadow:0 18px 50px rgba(0,0,0,.28);
}
.quote-card .qt-stars{margin-bottom:14px}
.quote-card blockquote{margin:0}
.svc-break-txt .quote-card blockquote{text-shadow:none}
@media(max-width:768px){
  .quote-card{padding:30px 26px;max-width:90%}
}


/* Lightbox for gallery images */
.gal-w img,.about-collage img{cursor:zoom-in}
.lightbox-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:rgba(6,30,38,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;padding:24px}
.lightbox-overlay.open{opacity:1;visibility:visible}
.lightbox-img{max-width:92vw;max-height:88vh;width:auto;height:auto;border-radius:10px;box-shadow:0 24px 70px rgba(0,0,0,.5);transform:scale(.96);transition:transform .3s cubic-bezier(.22,1,.36,1);object-fit:contain}
.lightbox-overlay.open .lightbox-img{transform:scale(1)}
.lightbox-close{position:absolute;top:20px;right:24px;width:46px;height:46px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:30px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
@media(max-width:768px){.lightbox-close{top:14px;right:14px;width:42px;height:42px;font-size:26px}}

/* Water-background section (matches the methods section look) */
.water-sec{position:relative;overflow:hidden;background:var(--petrol-dark)}
.water-sec::before{content:"";position:absolute;inset:0;background:url('/uploads/methods-water.jpg') center/cover;background-attachment:fixed;z-index:0}
.water-sec::after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(to bottom,rgba(6,46,56,.28) 0%,rgba(6,46,56,.06) 18%,rgba(6,46,56,.06) 82%,rgba(6,46,56,.28) 100%)}
.water-sec > *{position:relative;z-index:1}

/* Methods section: blend edges so it merges with adjacent water sections */
.methods-sec::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;pointer-events:none;background:linear-gradient(to bottom,rgba(6,46,56,.5) 0%,rgba(6,46,56,0) 16%,rgba(6,46,56,0) 84%,rgba(6,46,56,.5) 100%)}
.methods-sec .methods-intro,.methods-sec .methods-grid{position:relative;z-index:1}

/* ===== SHARED WATER BACKGROUND BAND (home: reviews + methods + pillars) ===== */
.water-band{position:relative;background:var(--petrol-dark)}
.water-band::before{content:"";position:absolute;inset:0;background:url('/uploads/methods-water.jpg') center/cover;background-attachment:fixed;z-index:0}
.water-band::after{content:"";position:absolute;inset:0;background:rgba(6,46,56,.16);z-index:0}
.water-band > *{position:relative;z-index:1}
/* Sections inside the band are transparent so the shared image shows through */
.water-band .reviews-sec,.water-band .methods-sec,.water-band #method{background:transparent}
.water-band .methods-sec::after,.water-band .methods-sec::before{display:none}
.methods-sec-flat{background:transparent}

/* Frosted card behind the bottom CTA on the offers page ("Not sure where to start") */
body.page-light .cta-bottom .fi-zoom{background:rgba(255,255,255,.08);backdrop-filter:blur(20px) saturate(115%);-webkit-backdrop-filter:blur(20px) saturate(115%);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:56px 48px;max-width:720px;margin:0 auto;box-shadow:0 8px 30px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.14)}
@media(max-width:768px){body.page-light .cta-bottom .fi-zoom{padding:40px 28px}}
