/* ==========================================================================
   KULAC DERS MERKEZI — Aquatic Luxe Design System v2
   Theme: Deep pool cinematic — caustics, lane lines, bubbles, liquid motion
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,800;9..144,900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

:root{
  /* Deep pool palette */
  --c-abyss:#031225;
  --c-deep:#062046;
  --c-ocean:#0a3a78;
  --c-pool:#0e5ab8;
  --c-sky:#2e90f0;
  --c-shallow:#7ecbff;
  --c-foam:#d9f0ff;
  --c-mist:#eef8ff;

  --c-aqua-900:#073b3a;
  --c-aqua-700:#0a7f6f;
  --c-aqua-500:#14c2a8;
  --c-aqua-400:#3bdabe;
  --c-aqua-300:#7ee8d4;
  --c-aqua-100:#c8f5ec;
  --c-cyan:#22d3ee;
  --c-neon:#5eead4;

  --c-white:#ffffff;
  --c-ink-50:#f6fafe;
  --c-ink-100:#e5eef7;
  --c-ink-200:#c8d6e5;
  --c-ink-300:#94a9c1;
  --c-ink-400:#637893;
  --c-ink-500:#3d516b;
  --c-ink-600:#24374f;
  --c-ink-700:#152336;
  --c-ink-800:#0a1424;
  --c-ink-900:#040b19;

  --c-danger:#ef4444;
  --c-success:#10b981;

  --font-body:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --font-display:"Fraunces","Plus Jakarta Sans",Georgia,serif;

  --fs-xs:.75rem; --fs-sm:.8125rem; --fs-base:.9375rem; --fs-md:1.0625rem;
  --fs-lg:1.25rem; --fs-xl:1.625rem; --fs-2xl:2.125rem; --fs-3xl:2.875rem;
  --fs-4xl:4rem; --fs-5xl:5rem;
  --lh-tight:1.05; --lh-snug:1.25; --lh-normal:1.6; --lh-relaxed:1.8;

  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;
  --s-8:32px;--s-10:40px;--s-12:48px;--s-14:56px;--s-16:64px;
  --s-20:80px;--s-24:96px;--s-32:128px;

  --r-sm:6px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-2xl:32px;--r-3xl:44px;--r-full:9999px;

  --sh-xs:0 1px 2px rgba(6,32,70,.06);
  --sh-sm:0 2px 8px rgba(6,32,70,.08),0 1px 2px rgba(6,32,70,.05);
  --sh-md:0 10px 28px -10px rgba(6,32,70,.18),0 4px 10px -4px rgba(6,32,70,.1);
  --sh-lg:0 24px 50px -16px rgba(6,32,70,.22),0 8px 18px -8px rgba(6,32,70,.12);
  --sh-xl:0 40px 80px -20px rgba(6,32,70,.28),0 12px 28px -12px rgba(6,32,70,.14);
  --sh-2xl:0 50px 100px -24px rgba(3,18,37,.45);
  --sh-glow-sky:0 0 0 4px rgba(46,144,240,.15),0 20px 50px -12px rgba(14,90,184,.45);
  --sh-glow-aqua:0 0 0 4px rgba(20,194,168,.18),0 20px 50px -12px rgba(20,194,168,.4);

  --max-w:1220px;
  --header-h:76px;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);

  --pool-tile:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'><rect width='64' height='64' fill='none'/><path d='M0 32h64M32 0v64' stroke='%230e5ab8' stroke-opacity='.1' stroke-width='1'/><circle cx='32' cy='32' r='1.3' fill='%230e5ab8' fill-opacity='.22'/><circle cx='0' cy='0' r='1.3' fill='%230e5ab8' fill-opacity='.15'/><circle cx='64' cy='0' r='1.3' fill='%230e5ab8' fill-opacity='.15'/><circle cx='0' cy='64' r='1.3' fill='%230e5ab8' fill-opacity='.15'/><circle cx='64' cy='64' r='1.3' fill='%230e5ab8' fill-opacity='.15'/></svg>");
  --bubbles-bg:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><g fill='none' stroke='%23ffffff' stroke-opacity='.22'><circle cx='30' cy='160' r='8'/><circle cx='30' cy='160' r='2' fill='%23ffffff' fill-opacity='.5'/><circle cx='80' cy='120' r='4'/><circle cx='140' cy='150' r='6'/><circle cx='170' cy='80' r='5'/><circle cx='60' cy='50' r='3'/><circle cx='110' cy='30' r='2'/><circle cx='180' cy='180' r='3'/></g></svg>");
  --wave-divider:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'><path fill='%23ffffff' d='M0,64L80,58.7C160,53,320,43,480,48C640,53,800,75,960,74.7C1120,75,1280,53,1360,42.7L1440,32L1440,120L0,120Z'/></svg>");
  --wave-divider-alt:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'><path fill='%23eef8ff' d='M0,32L80,42.7C160,53,320,75,480,74.7C640,75,800,53,960,48C1120,43,1280,53,1360,58.7L1440,64L1440,120L0,120Z'/></svg>");
}

/* --- BASE --- */
body{
  font-family:var(--font-body);
  font-size:var(--fs-base);
  line-height:var(--lh-normal);
  color:var(--c-ink-500);
  background:var(--c-white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  padding-top:var(--header-h);
}

::selection{background:rgba(46,144,240,.3);color:var(--c-ink-900)}

/* Scroll progress bar */
body::before{
  content:"";position:fixed;top:var(--header-h);left:0;width:100%;height:3px;z-index:99;
  background:linear-gradient(90deg,var(--c-pool),var(--c-aqua-500),var(--c-cyan));
  transform-origin:0 50%;
  transform:scaleX(var(--scroll,0));
  box-shadow:0 0 12px rgba(46,144,240,.5);
  transition:transform .05s linear;
  pointer-events:none;
}

h1,h2,h3,h4{
  font-family:var(--font-display);font-weight:800;
  line-height:var(--lh-tight);color:var(--c-ink-900);
  letter-spacing:-.03em;font-optical-sizing:auto;
}
h1{font-size:var(--fs-4xl);font-variation-settings:"opsz" 144;font-weight:900}
h2{font-size:var(--fs-3xl);font-variation-settings:"opsz" 96}
h3{font-size:var(--fs-xl);font-variation-settings:"opsz" 48}
h4{font-size:var(--fs-lg)}
p{margin-bottom:var(--s-4);line-height:var(--lh-relaxed);color:var(--c-ink-500)}
a{color:var(--c-pool);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--c-ocean)}

.skip-link{
  position:absolute;top:-200%;left:var(--s-4);
  background:var(--c-pool);color:var(--c-white);
  padding:var(--s-3) var(--s-5);border-radius:0 0 var(--r-md) var(--r-md);
  z-index:9999;font-weight:700;text-decoration:none;font-size:var(--fs-sm);
}
.skip-link:focus{top:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--s-6);position:relative}
.section{padding:var(--s-24) 0;position:relative}
.section--alt{
  background:
    radial-gradient(ellipse 900px 500px at 20% 0%,rgba(46,144,240,.08),transparent 55%),
    radial-gradient(ellipse 700px 500px at 85% 100%,rgba(20,194,168,.08),transparent 55%),
    linear-gradient(180deg,var(--c-mist) 0%,#e2f1fc 100%);
  position:relative;
}
.section--alt::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--pool-tile);background-size:64px 64px;
  opacity:.6;
  mask-image:linear-gradient(180deg,transparent,#000 15%,#000 85%,transparent);
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 15%,#000 85%,transparent);
}
.section--alt > *{position:relative}
.grid{display:grid;gap:var(--s-8)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:960px){.grid--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid--2,.grid--3{grid-template-columns:1fr}}

/* ==========================================================================
   HEADER — liquid glass with lane stripe
   ========================================================================== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--header-h);
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(234,246,255,.82));
  backdrop-filter:saturate(180%) blur(24px);
  -webkit-backdrop-filter:saturate(180%) blur(24px);
  border-bottom:1px solid rgba(14,90,184,.1);
  transition:all .3s var(--ease);
}
.header::before{
  content:"";position:absolute;left:0;right:0;top:0;height:100%;
  background-image:repeating-linear-gradient(90deg,transparent 0 40px,rgba(14,90,184,.04) 40px 41px);
  pointer-events:none;
}
.header::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:linear-gradient(90deg,transparent,var(--c-sky) 25%,var(--c-aqua-500) 50%,var(--c-sky) 75%,transparent);
  opacity:.6;
}
.header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--s-6);
  position:relative;
}
.header__logo{
  font-family:var(--font-display);
  font-size:var(--fs-xl);font-weight:900;color:var(--c-ink-900);
  text-decoration:none;display:flex;align-items:center;gap:var(--s-3);
  letter-spacing:-.025em;font-variation-settings:"opsz" 48;
}
.header__logo-icon{
  width:44px;height:44px;border-radius:14px;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.55),transparent 55%),
    linear-gradient(145deg,var(--c-pool) 0%,var(--c-sky) 50%,var(--c-aqua-500) 100%);
  display:flex;align-items:center;justify-content:center;
  box-shadow:
    0 10px 24px -6px rgba(14,90,184,.5),
    inset 0 1px 0 rgba(255,255,255,.6),
    inset 0 -6px 12px rgba(6,32,70,.2);
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease-spring);
}
.header__logo-icon::after{
  content:"";position:absolute;inset:-50%;
  background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.3),transparent 30%);
  animation:rotate 8s linear infinite;
}
@keyframes rotate{to{transform:rotate(360deg)}}
.header__logo-icon svg{width:24px;height:24px;fill:none;stroke:var(--c-white);stroke-width:2.5;stroke-linecap:round;position:relative;z-index:1;filter:drop-shadow(0 1px 2px rgba(3,18,37,.4))}
.header__logo:hover .header__logo-icon{transform:rotate(-8deg) scale(1.05)}

.header__nav{display:flex;align-items:center;gap:var(--s-1)}
.header__nav a{
  font-size:var(--fs-sm);font-weight:600;color:var(--c-ink-500);
  text-decoration:none;padding:var(--s-2) var(--s-4);border-radius:var(--r-md);
  transition:all .3s var(--ease);position:relative;
}
.header__nav a:not(.header__cta)::after{
  content:"";position:absolute;left:50%;bottom:2px;width:0;height:2px;
  background:linear-gradient(90deg,var(--c-pool),var(--c-aqua-500));
  border-radius:var(--r-full);transform:translateX(-50%);
  transition:width .3s var(--ease);
}
.header__nav a:hover{color:var(--c-ocean)}
.header__nav a:not(.header__cta):hover::after{width:60%}
.header__nav a.is-active{color:var(--c-ocean)}
.header__nav a.is-active:not(.header__cta)::after{width:60%}

.header__cta{
  background:linear-gradient(135deg,var(--c-ocean),var(--c-pool) 50%,var(--c-sky))!important;
  color:var(--c-white)!important;
  padding:11px 24px!important;border-radius:var(--r-full)!important;
  font-weight:700!important;font-size:var(--fs-sm)!important;
  box-shadow:0 10px 24px -6px rgba(14,90,184,.5),inset 0 1px 0 rgba(255,255,255,.35);
  transition:all .35s var(--ease)!important;
  position:relative;overflow:hidden;
}
.header__cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .8s var(--ease);
}
.header__cta:hover::before{transform:translateX(120%)}
.header__cta:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 32px -8px rgba(14,90,184,.65)!important;
}

.header__burger{
  display:none;background:none;border:none;cursor:pointer;
  width:46px;height:46px;border-radius:var(--r-md);
  position:relative;z-index:110;
  transition:background .2s var(--ease);
  align-items:center;justify-content:center;
}
.header__burger:hover{background:rgba(207,232,255,.7)}
.header__burger:focus-visible{outline:2px solid var(--c-sky);outline-offset:2px}
.header__burger svg{width:26px;height:26px;stroke:var(--c-ink-800);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.header__burger .icon-menu,.header__burger .icon-close{transition:opacity .3s var(--ease),transform .3s var(--ease)}
.header__burger .icon-close{position:absolute;opacity:0;transform:rotate(-90deg) scale(.7)}
.header__burger[aria-expanded="true"] .icon-menu{opacity:0;transform:rotate(90deg) scale(.7)}
.header__burger[aria-expanded="true"] .icon-close{opacity:1;transform:rotate(0) scale(1)}
.header__overlay{display:none}

@media(max-width:768px){
  .header__burger{display:flex}
  .header__nav{
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;
    width:100%;height:calc(100dvh - var(--header-h));
    background:
      radial-gradient(ellipse 700px 400px at 50% 20%,rgba(46,144,240,.2),transparent 60%),
      radial-gradient(ellipse 500px 400px at 80% 80%,rgba(20,194,168,.15),transparent 60%),
      linear-gradient(180deg,#eaf7ff,#cfe8f8);
    flex-direction:column;justify-content:center;align-items:center;gap:var(--s-3);
    z-index:105;overflow:hidden;
    transform:translateX(100%);opacity:0;
    transition:transform .5s var(--ease-out),opacity .3s var(--ease);
  }
  .header__nav.is-open{transform:translateX(0);opacity:1}
  .header__nav a{font-size:var(--fs-xl);font-weight:700;padding:var(--s-4) var(--s-10);border-radius:var(--r-lg);text-align:center}
  .header__cta{margin-top:var(--s-4);padding:var(--s-4) var(--s-12)!important;font-size:var(--fs-md)!important}
  body.nav-open{overflow:hidden}
}

/* ==========================================================================
   HERO — cinematic underwater
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  padding:var(--s-32) 0 calc(var(--s-32) + 80px);
  min-height:760px;display:flex;align-items:center;
  background:
    radial-gradient(ellipse 1400px 800px at 70% 20%,rgba(94,234,212,.25),transparent 55%),
    radial-gradient(ellipse 1000px 700px at 10% 90%,rgba(46,144,240,.35),transparent 55%),
    linear-gradient(175deg,#07306a 0%,#0a3a78 20%,#0e5ab8 50%,#1b7cc8 78%,#4ab0e8 100%);
  isolation:isolate;
  color:var(--c-white);
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--pool-tile);background-size:72px 72px;opacity:.25;
  mask-image:radial-gradient(ellipse at 50% 50%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000,transparent 75%);
  filter:brightness(2);
}
/* Light rays from surface */
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    conic-gradient(from 200deg at 60% -10%,
      transparent 0deg,
      rgba(255,255,255,.1) 10deg,
      transparent 20deg,
      rgba(255,255,255,.08) 35deg,
      transparent 50deg,
      rgba(255,255,255,.12) 70deg,
      transparent 90deg);
  filter:blur(14px);
  mix-blend-mode:screen;
  animation:rays 14s ease-in-out infinite alternate;
}
@keyframes rays{0%{transform:translateX(-30px) scaleY(1)}100%{transform:translateX(30px) scaleY(1.05)}}

/* Floating caustics + bubbles */
.hero__caustics{
  position:absolute;inset:-10%;pointer-events:none;z-index:1;
  background:
    radial-gradient(ellipse 500px 320px at 20% 30%,rgba(255,255,255,.2),transparent 60%),
    radial-gradient(ellipse 420px 280px at 75% 60%,rgba(94,234,212,.22),transparent 60%),
    radial-gradient(ellipse 360px 240px at 50% 85%,rgba(126,203,255,.22),transparent 60%),
    radial-gradient(ellipse 300px 220px at 88% 15%,rgba(255,255,255,.18),transparent 60%);
  mix-blend-mode:screen;filter:blur(2px);
  animation:caustics 16s ease-in-out infinite alternate;
}
@keyframes caustics{
  0%{transform:translate(0,0) scale(1) rotate(0deg);opacity:.85}
  50%{transform:translate(-30px,20px) scale(1.06) rotate(.6deg);opacity:1}
  100%{transform:translate(25px,-18px) scale(.96) rotate(-.4deg);opacity:.9}
}
.hero__caustics::after{
  content:"";position:absolute;inset:0;
  background-image:var(--bubbles-bg);background-size:240px 240px;
  opacity:.7;animation:bubbleRise 18s linear infinite;
}
@keyframes bubbleRise{from{background-position:0 240px}to{background-position:0 0}}

/* Lane dividers */
.hero .container::before{
  content:"";position:absolute;left:-20vw;right:-20vw;top:62%;height:4px;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.35) 0 30px,transparent 30px 60px);
  transform:rotate(-1.5deg);opacity:.5;pointer-events:none;
}

/* Wave bottom */
.hero__wave{
  position:absolute;bottom:-1px;left:0;width:100%;height:140px;overflow:hidden;z-index:3;
  pointer-events:none;
}
.hero__wave svg{
  position:absolute;bottom:0;width:220%;height:100%;
  fill:var(--c-white);animation:wave 26s linear infinite;
  filter:drop-shadow(0 -6px 14px rgba(3,18,37,.25));
}
.hero__wave::before,.hero__wave::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:70px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 2400 80' preserveAspectRatio='none'><path d='M0,50 C400,80 800,20 1200,50 C1600,80 2000,20 2400,50 L2400,80 L0,80 Z' fill='%23ffffff' fill-opacity='.45'/></svg>") repeat-x;
  background-size:1200px 70px;
  animation:wave 16s linear infinite;
}
.hero__wave::after{height:48px;opacity:.6;animation-duration:22s;animation-direction:reverse;background-size:900px 48px}
@keyframes wave{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.hero__content{position:relative;z-index:4;max-width:740px}
.hero__subtitle{
  font-size:var(--fs-xs);color:var(--c-neon);font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;margin-bottom:var(--s-6);
  display:inline-flex;align-items:center;gap:var(--s-3);
  padding:10px 20px;border-radius:var(--r-full);
  background:rgba(255,255,255,.08);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.2);
  box-shadow:0 8px 24px -8px rgba(3,18,37,.4),inset 0 1px 0 rgba(255,255,255,.2);
}
.hero__subtitle::before{
  content:"";width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--c-aqua-400));
  box-shadow:0 0 0 3px rgba(94,234,212,.25),0 0 16px rgba(94,234,212,.7);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.8}}

.hero h1{
  margin-bottom:var(--s-8);font-size:var(--fs-5xl);line-height:1;
  color:var(--c-white);font-family:var(--font-display);font-weight:900;
  font-variation-settings:"opsz" 144;letter-spacing:-.04em;
  text-shadow:0 10px 40px rgba(3,18,37,.3);
}
.hero h1 span{
  background:linear-gradient(120deg,var(--c-neon) 0%,var(--c-aqua-300) 30%,var(--c-cyan) 60%,#fff 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 6s ease-in-out infinite;
  display:inline-block;
  font-style:italic;
}
@keyframes shimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.hero__desc{
  font-size:var(--fs-md);color:rgba(255,255,255,.82);margin-bottom:var(--s-12);
  max-width:580px;line-height:var(--lh-relaxed);
}
.hero__actions{display:flex;gap:var(--s-4);flex-wrap:wrap;position:relative;z-index:4}

/* ==========================================================================
   BUTTONS — liquid ripple
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);
  padding:var(--s-3) var(--s-6);border-radius:var(--r-full);
  font-family:var(--font-body);
  font-weight:700;font-size:var(--fs-sm);cursor:pointer;
  border:1.5px solid transparent;transition:all .4s var(--ease);
  text-decoration:none;line-height:1.4;white-space:nowrap;
  position:relative;overflow:hidden;isolation:isolate;letter-spacing:-.01em;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.4) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .8s var(--ease);
}
.btn::after{
  content:"";position:absolute;left:50%;top:50%;width:0;height:0;z-index:-1;
  background:radial-gradient(circle,rgba(255,255,255,.35),transparent 65%);
  border-radius:50%;transform:translate(-50%,-50%);
  transition:width .6s var(--ease),height .6s var(--ease);
}
.btn:hover::before{transform:translateX(120%)}
.btn:hover::after{width:300px;height:300px}
.btn:focus-visible{outline:3px solid var(--c-sky);outline-offset:3px}

.btn--primary{
  background:linear-gradient(135deg,var(--c-ocean) 0%,var(--c-pool) 40%,var(--c-sky) 80%,var(--c-aqua-500) 130%);
  background-size:200% 200%;background-position:0% 50%;
  color:var(--c-white);
  box-shadow:
    0 14px 32px -10px rgba(14,90,184,.6),
    0 4px 12px -4px rgba(14,90,184,.4),
    inset 0 1px 0 rgba(255,255,255,.35);
}
.btn--primary:hover{
  background-position:100% 50%;
  box-shadow:
    0 20px 44px -10px rgba(14,90,184,.7),
    0 0 0 4px rgba(46,144,240,.2),
    inset 0 1px 0 rgba(255,255,255,.45);
  transform:translateY(-3px);color:var(--c-white);
}
.btn--primary:active{transform:translateY(-1px)}

.btn--outline{
  background:rgba(255,255,255,.1);color:var(--c-white);
  border-color:rgba(255,255,255,.4);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 8px 20px -8px rgba(3,18,37,.35),inset 0 1px 0 rgba(255,255,255,.2);
}
.btn--outline:hover{
  background:rgba(255,255,255,.2);
  border-color:rgba(255,255,255,.6);color:var(--c-white);
  transform:translateY(-3px);
}

/* On light sections, outline inverts */
.section .btn--outline,
.section--alt .btn--outline,
.form-section .btn--outline,
.cookie-settings__dialog .btn--outline{
  background:rgba(255,255,255,.8);color:var(--c-ocean);
  border-color:rgba(14,90,184,.25);
}
.section .btn--outline:hover,
.section--alt .btn--outline:hover,
.form-section .btn--outline:hover,
.cookie-settings__dialog .btn--outline:hover{
  background:var(--c-white);border-color:var(--c-sky);color:var(--c-ocean);
}

.btn--sm{padding:var(--s-2) var(--s-4);font-size:var(--fs-xs)}
.btn--lg{padding:18px var(--s-10);font-size:var(--fs-base)}

/* ==========================================================================
   SECTION HEADERS
   ========================================================================== */
.section__header{text-align:center;margin-bottom:var(--s-16);max-width:720px;margin-left:auto;margin-right:auto}
.section__header h2{margin-bottom:var(--s-4);font-size:var(--fs-3xl)}
.section__header h2::after{
  content:"";display:block;width:80px;height:4px;margin:var(--s-5) auto 0;
  border-radius:var(--r-full);
  background:linear-gradient(90deg,var(--c-pool),var(--c-aqua-500),var(--c-cyan));
  box-shadow:0 4px 16px rgba(46,144,240,.5);
}
.section__header p{color:var(--c-ink-400);font-size:var(--fs-md);margin-bottom:0}
.section__label{
  display:inline-flex;align-items:center;gap:var(--s-3);
  font-size:var(--fs-xs);font-weight:700;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--c-ocean);margin-bottom:var(--s-5);
  padding:10px 22px;border-radius:var(--r-full);
  background:linear-gradient(135deg,rgba(207,232,255,.7),rgba(200,245,236,.7));
  border:1px solid rgba(14,90,184,.14);
  box-shadow:0 6px 18px -6px rgba(14,90,184,.25),inset 0 1px 0 rgba(255,255,255,.6);
  backdrop-filter:blur(6px);
}
.section__label::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--c-pool));
  box-shadow:0 0 12px rgba(46,144,240,.6);
  animation:pulse 2.4s ease-in-out infinite;
}

/* ==========================================================================
   HIGHLIGHTS — life buoys
   ========================================================================== */
.highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s-6)}
.highlight{
  text-align:center;padding:var(--s-10) var(--s-5);
  border-radius:var(--r-2xl);
  background:linear-gradient(165deg,#ffffff,#eaf5fe);
  border:1px solid rgba(14,90,184,.1);
  box-shadow:var(--sh-md),inset 0 1px 0 rgba(255,255,255,.9);
  transition:all .45s var(--ease);
  position:relative;overflow:hidden;isolation:isolate;
}
.highlight::before{
  content:"";position:absolute;top:-50%;left:-20%;width:140%;height:120%;
  background:
    radial-gradient(ellipse at center,rgba(46,144,240,.18),transparent 55%),
    radial-gradient(ellipse at 30% 70%,rgba(20,194,168,.14),transparent 55%);
  filter:blur(20px);
  transition:transform .7s var(--ease);
}
.highlight::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--c-pool),var(--c-aqua-500),var(--c-cyan));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);
}
.highlight:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--sh-xl),inset 0 1px 0 rgba(255,255,255,.9);border-color:rgba(46,144,240,.3)}
.highlight:hover::before{transform:translateY(30px) scale(1.15)}
.highlight:hover::after{transform:scaleX(1)}
.highlight__num{
  font-family:var(--font-display);font-variation-settings:"opsz" 144;
  font-size:var(--fs-4xl);font-weight:900;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(135deg,var(--c-ocean),var(--c-sky) 50%,var(--c-aqua-500));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  filter:drop-shadow(0 4px 16px rgba(46,144,240,.3));
  font-style:italic;
}
.highlight__text{
  font-size:var(--fs-xs);color:var(--c-ink-500);margin-top:var(--s-4);
  font-weight:700;text-transform:uppercase;letter-spacing:.12em;
}
@media(max-width:768px){.highlights{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.highlights{grid-template-columns:1fr;gap:var(--s-4)}}

/* ==========================================================================
   CARDS — liquid fill on hover
   ========================================================================== */
.card{
  background:linear-gradient(165deg,rgba(255,255,255,.96),rgba(234,245,254,.88));
  border-radius:var(--r-xl);
  padding:var(--s-12) var(--s-8);position:relative;
  border:1px solid rgba(14,90,184,.12);
  box-shadow:var(--sh-sm),inset 0 1px 0 rgba(255,255,255,.9);
  transition:all .5s var(--ease);
  overflow:hidden;isolation:isolate;
}
.card::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(circle at 110% -10%,rgba(46,144,240,.18),transparent 45%),
    radial-gradient(circle at -10% 110%,rgba(20,194,168,.15),transparent 45%);
  opacity:.7;transition:opacity .6s var(--ease);
}
/* Liquid rising fill */
.card::after{
  content:"";position:absolute;left:-10%;right:-10%;bottom:-80%;height:160%;z-index:-1;
  background:
    radial-gradient(ellipse at center,rgba(94,234,212,.14),transparent 60%),
    linear-gradient(180deg,transparent,rgba(46,144,240,.1));
  border-radius:50% 50% 0 0 / 14% 14% 0 0;
  transform:translateY(100%);
  transition:transform .9s var(--ease-out);
}
.card:hover{
  box-shadow:var(--sh-xl);
  transform:translateY(-8px);
  border-color:rgba(46,144,240,.35);
}
.card:hover::before{opacity:1}
.card:hover::after{transform:translateY(0)}
.card__icon{
  width:68px;height:68px;border-radius:20px;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.55),transparent 55%),
    linear-gradient(145deg,var(--c-ocean),var(--c-sky) 50%,var(--c-aqua-500));
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--s-6);
  box-shadow:0 14px 28px -8px rgba(14,90,184,.55),inset 0 1px 0 rgba(255,255,255,.5),inset 0 -6px 14px rgba(6,32,70,.2);
  position:relative;overflow:hidden;
  transition:transform .5s var(--ease-spring);
}
.card:hover .card__icon{transform:rotate(-6deg) scale(1.08)}
.card__icon::after{
  content:"";position:absolute;inset:-50%;
  background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.25),transparent 30%);
  animation:rotate 10s linear infinite;
}
.card__icon svg{width:30px;height:30px;stroke:var(--c-white);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;filter:drop-shadow(0 1px 3px rgba(3,18,37,.35))}
.card h3{font-size:var(--fs-lg);margin-bottom:var(--s-3);font-weight:800;color:var(--c-ink-900)}
.card p{color:var(--c-ink-500);font-size:var(--fs-sm);margin-bottom:0;line-height:var(--lh-relaxed)}

/* ==========================================================================
   CONTENT WITH IMAGE — 3D refracted
   ========================================================================== */
.content-with-image{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--s-16);align-items:center;
}
.content-with-image--reverse{direction:rtl}
.content-with-image--reverse>*{direction:ltr}
.content-with-image__img{
  border-radius:var(--r-2xl);overflow:hidden;
  aspect-ratio:4/3;
  background:linear-gradient(145deg,var(--c-shallow),var(--c-aqua-300));
  box-shadow:
    0 40px 80px -24px rgba(6,32,70,.4),
    0 0 0 1px rgba(255,255,255,.6) inset,
    0 0 0 10px rgba(255,255,255,.55);
  position:relative;
  transform:perspective(1400px) rotateY(-3deg) rotateX(1deg);
  transition:transform .6s var(--ease);
}
.content-with-image--reverse .content-with-image__img{transform:perspective(1400px) rotateY(3deg) rotateX(1deg)}
.content-with-image__img::before{
  content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;
  border-radius:50%;z-index:2;pointer-events:none;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.6),rgba(94,234,212,.25) 40%,transparent 70%);
  filter:blur(1px);
  animation:floatY 6s ease-in-out infinite;
}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.content-with-image__img::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.12),transparent 40%);
}
.content-with-image__img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease);
}
.content-with-image:hover .content-with-image__img{transform:perspective(1400px) rotateY(0) translateY(-6px)}
.content-with-image:hover .content-with-image__img img{transform:scale(1.06)}
@media(max-width:768px){
  .content-with-image{grid-template-columns:1fr;gap:var(--s-10)}
  .content-with-image--reverse{direction:ltr}
  .content-with-image__img{max-width:520px;transform:none}
}

/* ==========================================================================
   SELECTOR
   ========================================================================== */
.selector{
  background:linear-gradient(165deg,rgba(255,255,255,.97),rgba(234,245,254,.9));
  border-radius:var(--r-2xl);
  padding:var(--s-14);
  border:1px solid rgba(14,90,184,.14);
  box-shadow:var(--sh-xl),inset 0 1px 0 rgba(255,255,255,.9);
  position:relative;overflow:hidden;
}
.selector::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500),var(--c-cyan),var(--c-sky),var(--c-ocean));
  background-size:200% 100%;animation:gradient-slide 8s linear infinite;
}
.selector::after{
  content:"";position:absolute;bottom:-120px;right:-120px;width:360px;height:360px;
  border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(20,194,168,.18),transparent 65%);
  filter:blur(12px);
}
@keyframes gradient-slide{0%{background-position:0% 0}100%{background-position:200% 0}}
.selector__row{display:flex;gap:var(--s-10);flex-wrap:wrap;position:relative}
.selector__group{flex:1;min-width:220px}
.selector__group-label{
  font-size:var(--fs-xs);font-weight:700;color:var(--c-ink-500);
  margin-bottom:var(--s-3);display:block;
  text-transform:uppercase;letter-spacing:.14em;
}
.selector__tabs{
  display:flex;gap:var(--s-1);
  background:linear-gradient(145deg,#e2eef7,#f0f7fc);
  border-radius:14px;padding:5px;
  border:1px solid rgba(14,90,184,.1);
  box-shadow:inset 0 2px 6px rgba(6,32,70,.08);
}
.selector__tab{
  flex:1;padding:var(--s-3) var(--s-4);
  border:none;background:none;border-radius:10px;
  font-family:var(--font-body);
  font-weight:700;font-size:var(--fs-sm);cursor:pointer;
  color:var(--c-ink-400);transition:all .35s var(--ease);
}
.selector__tab[aria-selected="true"]{
  background:linear-gradient(135deg,var(--c-white),#f2fbff);
  color:var(--c-ocean);
  box-shadow:0 6px 16px -4px rgba(14,90,184,.28),0 0 0 1px rgba(14,90,184,.1);
}
.selector__tab:hover:not([aria-selected="true"]){color:var(--c-pool)}
.selector__tab:focus-visible{outline:3px solid var(--c-sky);outline-offset:2px}

.selector__result{
  margin-top:var(--s-10);padding:var(--s-10) var(--s-12);
  background:
    radial-gradient(ellipse 400px 200px at 80% 20%,rgba(20,194,168,.18),transparent 60%),
    linear-gradient(145deg,#e6f3ff,#d2f2e8);
  border-radius:var(--r-xl);
  border:1px solid rgba(14,90,184,.15);
  min-height:150px;
  animation:fadeUp .5s var(--ease-out);
  position:relative;overflow:hidden;
}
.selector__result::before{
  content:"";position:absolute;inset:0;
  background-image:var(--pool-tile);background-size:56px 56px;
  opacity:.4;pointer-events:none;
}
.selector__result > *{position:relative}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.selector__result h4{color:var(--c-ocean);margin-bottom:var(--s-3);font-size:var(--fs-lg)}
.selector__result p{color:var(--c-ink-500);margin-bottom:var(--s-2);font-size:var(--fs-sm)}
.selector__price{
  font-family:var(--font-display);font-style:italic;
  font-size:var(--fs-2xl);font-weight:900;
  background:linear-gradient(135deg,var(--c-ocean),var(--c-aqua-500));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-top:var(--s-4);letter-spacing:-.02em;
}
.selector__price-note{font-size:var(--fs-xs);color:var(--c-ink-400);font-weight:500;margin-top:var(--s-2)}
@media(max-width:640px){.selector{padding:var(--s-8)}.selector__row{gap:var(--s-6)}}

/* ==========================================================================
   CONTENT BLOCKS
   ========================================================================== */
.content-block{margin-bottom:var(--s-14)}
.content-block:last-child{margin-bottom:0}
.content-block h3{
  margin-bottom:var(--s-5);color:var(--c-ocean);font-size:var(--fs-xl);
  position:relative;padding-left:var(--s-6);
}
.content-block h3::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:5px;
  border-radius:var(--r-full);
  background:linear-gradient(180deg,var(--c-pool),var(--c-aqua-500),var(--c-cyan));
  box-shadow:0 0 16px rgba(46,144,240,.5);
}
.content-block p{color:var(--c-ink-500);line-height:var(--lh-relaxed)}
.content-block ul{list-style:none;padding:0;margin:var(--s-6) 0}
.content-block ul li{
  position:relative;padding-left:var(--s-12);
  margin-bottom:var(--s-4);color:var(--c-ink-500);
  font-size:var(--fs-sm);line-height:var(--lh-relaxed);
}
.content-block ul li::before{
  content:"";position:absolute;left:0;top:2px;
  width:24px;height:24px;border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%,rgba(255,255,255,.9),transparent 42%),
    linear-gradient(135deg,var(--c-pool),var(--c-aqua-500));
  box-shadow:0 4px 14px rgba(46,144,240,.4),inset 0 1px 0 rgba(255,255,255,.55);
}
.content-block ul li::after{
  content:"";position:absolute;left:7px;top:11px;
  width:10px;height:5px;border:2px solid #fff;border-top:none;border-right:none;
  transform:rotate(-45deg);
}

/* ==========================================================================
   PRICING TABLE
   ========================================================================== */
.pricing-table{
  width:100%;border-collapse:separate;border-spacing:0;
  margin-top:var(--s-6);border-radius:var(--r-xl);overflow:hidden;
  background:var(--c-white);
  box-shadow:var(--sh-lg),0 0 0 1px rgba(14,90,184,.1);
}
.pricing-table th,.pricing-table td{padding:var(--s-5) var(--s-6);text-align:left}
.pricing-table th{
  font-size:var(--fs-xs);font-weight:700;color:var(--c-white);
  text-transform:uppercase;letter-spacing:.12em;
  background:linear-gradient(135deg,var(--c-ocean),var(--c-pool) 60%,var(--c-sky));
  position:relative;
}
.pricing-table th::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--c-aqua-500),var(--c-cyan),var(--c-aqua-500));
}
.pricing-table td{
  font-size:var(--fs-sm);color:var(--c-ink-600);
  border-bottom:1px solid var(--c-ink-100);
  background:var(--c-white);
}
.pricing-table tbody tr:last-child td{border-bottom:none}
.pricing-table .price-cell{
  font-family:var(--font-display);font-style:italic;
  font-weight:900;font-size:var(--fs-lg);white-space:nowrap;
  background:linear-gradient(135deg,var(--c-ocean),var(--c-aqua-500));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.pricing-table tbody tr{transition:background .3s var(--ease)}
.pricing-table tbody tr:hover td{background:linear-gradient(90deg,#eaf5fe,#d6f1ec)}
.pricing-disclaimer{
  margin-top:var(--s-6);padding:var(--s-5) var(--s-6);
  background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(234,245,254,.9));
  border-radius:var(--r-lg);
  font-size:var(--fs-xs);color:var(--c-ink-500);
  line-height:var(--lh-relaxed);
  border:1px solid rgba(14,90,184,.12);
  border-left:4px solid var(--c-sky);
  backdrop-filter:blur(6px);
}
.pricing-disclaimer a{color:var(--c-pool);font-weight:700}

/* ==========================================================================
   ACCORDION
   ========================================================================== */
.accordion{max-width:820px;margin:0 auto}
.accordion__item{
  border:1px solid rgba(14,90,184,.12);
  border-radius:var(--r-lg);
  margin-bottom:var(--s-3);
  background:linear-gradient(165deg,rgba(255,255,255,.98),rgba(234,245,254,.9));
  overflow:hidden;
  transition:all .4s var(--ease);
  box-shadow:var(--sh-xs);
  position:relative;
}
.accordion__item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--c-pool),var(--c-aqua-500));
  transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease);
}
.accordion__item:hover{
  border-color:rgba(46,144,240,.3);
  box-shadow:var(--sh-md);
  transform:translateX(6px);
}
.accordion__item:hover::before,
.accordion__item:has(.accordion__btn[aria-expanded="true"])::before{transform:scaleY(1)}
.accordion__btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-5) var(--s-6);background:none;border:none;cursor:pointer;
  text-align:left;font-size:var(--fs-base);font-weight:700;color:var(--c-ink-800);
  font-family:var(--font-body);
  transition:color .25s var(--ease);gap:var(--s-4);
}
.accordion__btn:hover{color:var(--c-ocean)}
.accordion__btn:focus-visible{outline:3px solid var(--c-sky);outline-offset:-3px;border-radius:var(--r-lg)}
.accordion__icon{
  width:36px;height:36px;flex-shrink:0;
  background:linear-gradient(145deg,#eaf5fe,#d2f2e8);
  border:1px solid rgba(14,90,184,.18);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .5s var(--ease-spring);
}
.accordion__icon line{stroke:var(--c-pool);stroke-width:2.5}
.accordion__btn[aria-expanded="true"] .accordion__icon{
  transform:rotate(135deg);
  background:linear-gradient(145deg,var(--c-ocean),var(--c-aqua-500));
  border-color:transparent;
  box-shadow:0 8px 20px -4px rgba(14,90,184,.5);
}
.accordion__btn[aria-expanded="true"] .accordion__icon line{stroke:#fff}
.accordion__panel{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.accordion__panel-inner{
  padding:var(--s-5) var(--s-6) var(--s-6);
  color:var(--c-ink-500);font-size:var(--fs-sm);line-height:var(--lh-relaxed);
  border-top:1px dashed rgba(14,90,184,.15);
}
.accordion__panel-inner p{margin-bottom:var(--s-3)}
.accordion__panel-inner p:last-child{margin-bottom:0}

/* ==========================================================================
   CTA BANNER — deep pool immersion
   ========================================================================== */
.cta-banner{
  background:
    radial-gradient(ellipse 700px 350px at 20% 20%,rgba(20,194,168,.45),transparent 60%),
    radial-gradient(ellipse 600px 300px at 80% 80%,rgba(46,144,240,.4),transparent 60%),
    linear-gradient(145deg,var(--c-abyss) 0%,var(--c-deep) 30%,var(--c-ocean) 70%,var(--c-aqua-900) 100%);
  border-radius:var(--r-3xl);
  padding:var(--s-24) var(--s-12);
  text-align:center;color:var(--c-white);
  position:relative;overflow:hidden;
  box-shadow:var(--sh-2xl),0 0 0 1px rgba(255,255,255,.1) inset;
  isolation:isolate;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--pool-tile);
  background-size:80px 80px;opacity:.3;
  filter:brightness(3);
  mask-image:radial-gradient(ellipse at center,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000,transparent 75%);
}
.cta-banner::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--bubbles-bg);background-size:220px 220px;
  opacity:.5;animation:bubbleRise 20s linear infinite;
}
.cta-banner h2{color:var(--c-white);margin-bottom:var(--s-5);position:relative;z-index:1;font-size:var(--fs-3xl)}
.cta-banner h2::after{background:linear-gradient(90deg,var(--c-aqua-300),var(--c-cyan),var(--c-neon))}
.cta-banner p{color:rgba(255,255,255,.88);margin-bottom:var(--s-10);font-size:var(--fs-md);position:relative;z-index:1;max-width:580px;margin-left:auto;margin-right:auto}
.cta-banner .btn{position:relative;z-index:1}
.cta-banner .btn--primary{
  background:linear-gradient(135deg,#fff,#e6f4ff 50%,var(--c-aqua-100));
  color:var(--c-ocean);border-color:transparent;
  box-shadow:0 18px 40px -10px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.9);
}
.cta-banner .btn--primary:hover{
  background:linear-gradient(135deg,#fff,var(--c-aqua-100));
  color:var(--c-abyss);
}

/* ==========================================================================
   FOOTER — deep ocean
   ========================================================================== */
.footer{
  background:
    radial-gradient(ellipse 1000px 500px at 80% 0%,rgba(20,194,168,.18),transparent 60%),
    radial-gradient(ellipse 800px 500px at 10% 30%,rgba(46,144,240,.14),transparent 60%),
    linear-gradient(180deg,var(--c-abyss),#010716);
  color:var(--c-ink-300);
  padding:var(--s-24) 0 var(--s-10);
  position:relative;overflow:hidden;
}
.footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--c-sky) 20%,var(--c-aqua-500) 50%,var(--c-cyan) 80%,transparent);
  filter:blur(.5px);
}
.footer::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:var(--pool-tile);background-size:70px 70px;opacity:.15;filter:brightness(3);
}
.footer .container{position:relative;z-index:1}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--s-12);margin-bottom:var(--s-14)}
.footer__brand{max-width:340px}
.footer__brand-name{
  font-family:var(--font-display);font-style:italic;
  font-size:var(--fs-xl);font-weight:900;
  margin-bottom:var(--s-4);letter-spacing:-.025em;
  background:linear-gradient(135deg,#fff,var(--c-aqua-300));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.footer__brand p{font-size:var(--fs-sm);line-height:var(--lh-relaxed);color:var(--c-ink-300)}
.footer__col h4{
  font-size:var(--fs-xs);font-weight:700;color:var(--c-aqua-300);
  text-transform:uppercase;letter-spacing:.16em;margin-bottom:var(--s-5);
}
.footer__col ul{list-style:none;padding:0}
.footer__col ul li{margin-bottom:var(--s-3);font-size:var(--fs-sm);color:var(--c-ink-300)}
.footer__col ul a{
  font-size:var(--fs-sm);color:var(--c-ink-300);text-decoration:none;
  transition:all .3s var(--ease);position:relative;padding-left:var(--s-5);
  display:inline-block;
}
.footer__col ul a::before{
  content:"";position:absolute;left:0;top:50%;width:8px;height:8px;border-radius:50%;
  background:var(--c-pool);transform:translateY(-50%);
  transition:all .35s var(--ease);
  box-shadow:0 0 0 0 rgba(46,144,240,.5);
}
.footer__col ul a:hover{color:var(--c-white);padding-left:var(--s-6)}
.footer__col ul a:hover::before{background:var(--c-aqua-400);box-shadow:0 0 0 4px rgba(20,194,168,.25),0 0 12px rgba(94,234,212,.6)}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:var(--s-8);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:var(--s-4);
}
.footer__copy{font-size:var(--fs-xs);color:var(--c-ink-400)}
.footer__legal{display:flex;gap:var(--s-6)}
.footer__legal a{font-size:var(--fs-xs);color:var(--c-ink-400);text-decoration:none;transition:color .2s var(--ease)}
.footer__legal a:hover{color:var(--c-aqua-300)}
@media(max-width:768px){.footer__grid{grid-template-columns:1fr 1fr;gap:var(--s-8)}.footer__brand{grid-column:1/-1}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}.footer__bottom{flex-direction:column;text-align:center}}

/* ==========================================================================
   FORMS
   ========================================================================== */
.form-section{
  max-width:680px;margin:0 auto;
  background:linear-gradient(165deg,rgba(255,255,255,.98),rgba(234,245,254,.92));
  border:1px solid rgba(14,90,184,.14);
  border-radius:var(--r-2xl);
  padding:var(--s-16) var(--s-12);
  box-shadow:var(--sh-xl),inset 0 1px 0 rgba(255,255,255,.9);
  position:relative;overflow:hidden;
}
.form-section::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500),var(--c-cyan));
  background-size:200% 100%;animation:gradient-slide 8s linear infinite;
}
.form-section::after{
  content:"";position:absolute;bottom:-160px;right:-160px;width:420px;height:420px;
  border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(20,194,168,.12),transparent 65%);
}
.form-section form{position:relative;z-index:1}
.form__group{margin-bottom:var(--s-6);position:relative}
.form__label{
  display:block;font-size:var(--fs-sm);font-weight:700;
  color:var(--c-ink-700);margin-bottom:var(--s-2);letter-spacing:-.005em;
}
.form__label .required{color:var(--c-danger);margin-left:3px}
.form__input,.form__textarea{
  width:100%;padding:16px var(--s-5);
  border:1.5px solid rgba(14,90,184,.18);border-radius:14px;
  font-size:var(--fs-base);font-family:var(--font-body);
  color:var(--c-ink-800);
  background:linear-gradient(180deg,#f7fbfe,#eef6fe);
  transition:all .35s var(--ease);
  box-shadow:inset 0 2px 6px rgba(6,32,70,.05);
}
.form__input::placeholder,.form__textarea::placeholder{color:var(--c-ink-300)}
.form__input:hover,.form__textarea:hover{border-color:var(--c-sky)}
.form__input:focus,.form__textarea:focus{
  outline:none;border-color:var(--c-pool);
  box-shadow:0 0 0 4px rgba(46,144,240,.18),inset 0 2px 6px rgba(6,32,70,.05),0 8px 24px -8px rgba(14,90,184,.25);
  background:var(--c-white);
  transform:translateY(-1px);
}
.form__input.is-error,.form__textarea.is-error{border-color:var(--c-danger);box-shadow:0 0 0 4px rgba(239,68,68,.12)}
.form__textarea{resize:vertical;min-height:150px}
.form__error{font-size:var(--fs-xs);color:var(--c-danger);margin-top:var(--s-2);display:none;font-weight:600}
.form__error.is-visible{display:block}
.form__check{display:flex;align-items:flex-start;gap:var(--s-3);margin-bottom:var(--s-6)}
.form__check input[type="checkbox"]{
  width:22px;height:22px;margin-top:1px;flex-shrink:0;
  accent-color:var(--c-pool);cursor:pointer;border-radius:var(--r-sm);
}
.form__check label{font-size:var(--fs-sm);color:var(--c-ink-500);cursor:pointer;line-height:var(--lh-normal)}
.form__check label a{color:var(--c-pool);text-decoration:underline;font-weight:700}
.form__honeypot{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.form__feedback{
  padding:var(--s-4) var(--s-5);border-radius:var(--r-lg);
  font-size:var(--fs-sm);margin-top:var(--s-5);display:none;font-weight:600;
}
.form__feedback--success{display:block;background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(20,194,168,.12));color:var(--c-success);border:1px solid rgba(16,185,129,.3)}
.form__feedback--error{display:block;background:rgba(239,68,68,.08);color:var(--c-danger);border:1px solid rgba(239,68,68,.25)}
@media(max-width:640px){.form-section{padding:var(--s-10) var(--s-6)}}

/* ==========================================================================
   CONTACT INFO
   ========================================================================== */
.contact-info{display:flex;flex-direction:column;gap:var(--s-5)}
.contact-info__item{
  display:flex;align-items:flex-start;gap:var(--s-5);
  padding:var(--s-6);
  background:linear-gradient(165deg,#fff,#eaf5fe);
  border:1px solid rgba(14,90,184,.12);
  border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);
  transition:all .4s var(--ease);
  position:relative;overflow:hidden;
}
.contact-info__item::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--c-pool),var(--c-aqua-500));
  transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease);
}
.contact-info__item:hover{transform:translateY(-4px) translateX(4px);box-shadow:var(--sh-md);border-color:rgba(46,144,240,.3)}
.contact-info__item:hover::before{transform:scaleY(1)}
.contact-info__icon{
  width:56px;height:56px;border-radius:16px;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.55),transparent 55%),
    linear-gradient(145deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  box-shadow:0 10px 24px -6px rgba(14,90,184,.5),inset 0 1px 0 rgba(255,255,255,.45);
  position:relative;overflow:hidden;
}
.contact-info__icon::after{
  content:"";position:absolute;inset:-50%;
  background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.2),transparent 30%);
  animation:rotate 12s linear infinite;
}
.contact-info__icon svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;filter:drop-shadow(0 1px 2px rgba(3,18,37,.4))}
.contact-info__text h4{font-size:var(--fs-sm);margin-bottom:4px;font-weight:800;color:var(--c-ink-900)}
.contact-info__text p{font-size:var(--fs-sm);color:var(--c-ink-500);margin-bottom:0}

/* ==========================================================================
   COOKIE BANNER & SETTINGS
   ========================================================================== */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9000;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(234,245,254,.96));
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-top:1px solid rgba(14,90,184,.15);
  box-shadow:0 -18px 50px rgba(6,32,70,.16);
  padding:var(--s-6);
  transform:translateY(100%);transition:transform .5s var(--ease-out);
}
.cookie-banner::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--c-sky),var(--c-aqua-500),transparent);
}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner__inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;gap:var(--s-6);flex-wrap:wrap}
.cookie-banner__text{flex:1;min-width:280px}
.cookie-banner__text p{font-size:var(--fs-sm);color:var(--c-ink-500);margin-bottom:0}
.cookie-banner__text a{color:var(--c-pool);text-decoration:underline;font-weight:700}
.cookie-banner__actions{display:flex;gap:var(--s-3);align-items:center;flex-wrap:wrap}
.cookie-banner__actions .btn{font-size:var(--fs-xs);padding:11px 20px}
.cookie-banner__btn-accept{
  background:linear-gradient(135deg,var(--c-ocean),var(--c-pool),var(--c-aqua-500));color:var(--c-white);border-color:transparent;
  box-shadow:0 8px 20px -4px rgba(14,90,184,.45);
}
.cookie-banner__btn-accept:hover{color:var(--c-white);transform:translateY(-2px)}
.cookie-banner__btn-reject{background:var(--c-ink-800);color:var(--c-white);border-color:var(--c-ink-800)}
.cookie-banner__btn-reject:hover{background:var(--c-ink-900);color:var(--c-white)}
.cookie-banner__btn-settings{background:transparent;color:var(--c-ink-500);border-color:rgba(14,90,184,.22)}
.cookie-banner__btn-settings:hover{background:rgba(207,232,255,.55);color:var(--c-ocean)}

.cookie-settings{
  position:fixed;inset:0;z-index:9500;
  display:none;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center,rgba(6,32,70,.55),rgba(3,18,37,.8));
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.cookie-settings.is-visible{display:flex;animation:fadeUp .4s var(--ease-out)}
.cookie-settings__dialog{
  background:linear-gradient(165deg,#fff,#eaf5fe);
  border-radius:var(--r-2xl);
  padding:var(--s-14);max-width:520px;width:92%;
  max-height:85vh;overflow-y:auto;
  box-shadow:var(--sh-2xl),inset 0 1px 0 rgba(255,255,255,.9);
  border:1px solid rgba(14,90,184,.18);
  position:relative;
}
.cookie-settings__dialog::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  border-radius:var(--r-2xl) var(--r-2xl) 0 0;
  background:linear-gradient(90deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500),var(--c-cyan));
}
.cookie-settings__dialog h3{margin-bottom:var(--s-6);color:var(--c-ocean)}
.cookie-settings__item{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-5) 0;border-bottom:1px dashed rgba(14,90,184,.18);gap:var(--s-4);
}
.cookie-settings__item:last-of-type{border-bottom:none}
.cookie-settings__item-info h4{font-size:var(--fs-sm);margin-bottom:3px;font-weight:800;color:var(--c-ink-900)}
.cookie-settings__item-info p{font-size:var(--fs-xs);color:var(--c-ink-400);margin-bottom:0}

.toggle{position:relative;width:52px;height:30px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0;position:absolute}
.toggle__slider{
  position:absolute;inset:0;
  background:linear-gradient(145deg,var(--c-ink-200),var(--c-ink-100));
  border-radius:var(--r-full);cursor:pointer;
  transition:all .35s var(--ease);
  box-shadow:inset 0 2px 6px rgba(6,32,70,.12);
}
.toggle__slider::before{
  content:"";position:absolute;width:24px;height:24px;
  left:3px;bottom:3px;
  background:radial-gradient(circle at 30% 30%,#fff,#dce7f2);
  border-radius:50%;transition:transform .4s var(--ease-spring);
  box-shadow:0 2px 8px rgba(6,32,70,.3);
}
.toggle input:checked+.toggle__slider{
  background:linear-gradient(135deg,var(--c-pool),var(--c-aqua-500));
  box-shadow:inset 0 2px 6px rgba(6,32,70,.25),0 0 14px rgba(46,144,240,.4);
}
.toggle input:checked+.toggle__slider::before{transform:translateX(22px)}
.toggle input:disabled+.toggle__slider{opacity:.5;cursor:not-allowed}
.toggle input:focus-visible+.toggle__slider{outline:3px solid var(--c-sky);outline-offset:2px}
.cookie-settings__save{margin-top:var(--s-6);width:100%}

/* ==========================================================================
   SUBPAGE HERO
   ========================================================================== */
.page-hero{
  background:
    radial-gradient(ellipse 900px 550px at 80% 20%,rgba(46,144,240,.18),transparent 60%),
    radial-gradient(ellipse 700px 500px at 10% 80%,rgba(20,194,168,.14),transparent 60%),
    linear-gradient(175deg,#e8f4ff 0%,#d0ecf7 50%,#dff4ef 100%);
  padding:var(--s-24) 0 var(--s-20);
  position:relative;overflow:hidden;
  isolation:isolate;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:var(--pool-tile);background-size:64px 64px;opacity:.4;
  mask-image:radial-gradient(ellipse at 60% 50%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at 60% 50%,#000,transparent 75%);
}
.page-hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:80px;
  background:var(--wave-divider) repeat-x center bottom/100% 80px;
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{font-size:var(--fs-3xl);color:var(--c-ink-900)}
.page-hero p{color:var(--c-ink-500);font-size:var(--fs-md);margin-top:var(--s-4);max-width:720px}
.breadcrumb{
  padding:0 0 var(--s-5);font-size:var(--fs-xs);color:var(--c-ink-400);font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;
}
.breadcrumb a{color:var(--c-pool);text-decoration:none;transition:color .2s var(--ease)}
.breadcrumb a:hover{color:var(--c-ocean)}
.breadcrumb span{margin:0 var(--s-2);color:var(--c-ink-300)}

/* ==========================================================================
   LEGAL PAGES
   ========================================================================== */
.legal{padding:var(--s-16) 0 var(--s-24)}
.legal__content{
  max-width:860px;margin:0 auto;
  background:linear-gradient(165deg,rgba(255,255,255,.98),rgba(234,245,254,.92));
  border:1px solid rgba(14,90,184,.12);
  border-radius:var(--r-2xl);
  padding:var(--s-16) var(--s-14);
  box-shadow:var(--sh-xl),inset 0 1px 0 rgba(255,255,255,.9);
  position:relative;overflow:hidden;
}
.legal__content::before{
  content:"";position:absolute;top:0;left:0;right:0;height:5px;
  background:linear-gradient(90deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500),var(--c-cyan));
}
.legal__content h2{
  font-size:var(--fs-xl);margin:var(--s-12) 0 var(--s-5);color:var(--c-ocean);
  padding-bottom:var(--s-3);
  border-bottom:2px solid rgba(14,90,184,.1);
  position:relative;
}
.legal__content h2::before{
  content:"";position:absolute;bottom:-2px;left:0;width:80px;height:3px;
  background:linear-gradient(90deg,var(--c-pool),var(--c-aqua-500));
  border-radius:var(--r-full);
}
.legal__content h2:first-child{margin-top:0}
.legal__content h3{font-size:var(--fs-lg);margin:var(--s-8) 0 var(--s-3);color:var(--c-ink-800)}
.legal__content p{color:var(--c-ink-500);font-size:var(--fs-sm);line-height:var(--lh-relaxed);margin-bottom:var(--s-4)}
.legal__content ul{list-style:none;padding:0;margin:var(--s-4) 0}
.legal__content ul li{
  position:relative;padding-left:var(--s-8);
  color:var(--c-ink-500);font-size:var(--fs-sm);
  line-height:var(--lh-relaxed);margin-bottom:var(--s-3);
}
.legal__content ul li::before{
  content:"";position:absolute;left:0;top:8px;
  width:12px;height:12px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--c-pool));
  box-shadow:0 2px 8px rgba(46,144,240,.4);
}
.legal__content a{color:var(--c-pool);text-decoration:underline;font-weight:700}
@media(max-width:640px){.legal__content{padding:var(--s-10) var(--s-6)}}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-8);margin-top:var(--s-10)}
@media(max-width:768px){.about-values{grid-template-columns:1fr}}
.about-value{
  text-align:center;padding:var(--s-12) var(--s-6);
  background:linear-gradient(165deg,#fff,#eaf5fe);
  border:1px solid rgba(14,90,184,.12);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-sm);
  transition:all .4s var(--ease);
  position:relative;overflow:hidden;
}
.about-value::before{
  content:"";position:absolute;top:-50%;left:-50%;width:200%;height:100%;
  background:radial-gradient(ellipse at center,rgba(46,144,240,.15),transparent 55%);
  filter:blur(20px);transition:transform .6s var(--ease);
}
.about-value:hover{transform:translateY(-6px);box-shadow:var(--sh-lg);border-color:rgba(46,144,240,.3)}
.about-value:hover::before{transform:translateY(30px)}
.about-value h3{font-size:var(--fs-lg);margin-bottom:var(--s-3);color:var(--c-ocean);position:relative}
.about-value p{font-size:var(--fs-sm);color:var(--c-ink-500);position:relative}

/* ==========================================================================
   SITEMAP
   ========================================================================== */
.sitemap-list{list-style:none;padding:0}
.sitemap-list li{margin-bottom:var(--s-3)}
.sitemap-list a{
  font-size:var(--fs-md);color:var(--c-ocean);text-decoration:none;font-weight:700;
  padding:var(--s-4) var(--s-6);display:inline-flex;align-items:center;gap:var(--s-3);
  border-radius:var(--r-lg);transition:all .35s var(--ease);
  background:linear-gradient(165deg,#fff,#eaf5fe);
  border:1px solid rgba(14,90,184,.12);
  box-shadow:var(--sh-xs);
}
.sitemap-list a::before{
  content:"";width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--c-pool));
  box-shadow:0 0 10px rgba(46,144,240,.5);
}
.sitemap-list a:hover{
  background:linear-gradient(165deg,#fff,#d2f2e8);
  border-color:var(--c-sky);
  transform:translateX(8px);
  box-shadow:var(--sh-md);
}

/* ==========================================================================
   404 PAGE
   ========================================================================== */
.error-page{
  min-height:calc(100vh - var(--header-h));
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  text-align:center;padding:var(--s-10);
  background:
    radial-gradient(ellipse 900px 600px at 50% 40%,rgba(46,144,240,.18),transparent 60%),
    radial-gradient(ellipse 700px 500px at 20% 70%,rgba(20,194,168,.14),transparent 60%),
    linear-gradient(175deg,#e8f4ff,#d0ecf7);
  position:relative;overflow:hidden;
}
.error-page::before{
  content:"";position:absolute;inset:0;
  background-image:var(--pool-tile);background-size:64px 64px;opacity:.35;
}
.error-page > *{position:relative;z-index:1}
.error-page__code{
  font-family:var(--font-display);font-style:italic;
  font-size:13rem;font-weight:900;line-height:1;
  background:linear-gradient(135deg,var(--c-ocean),var(--c-sky),var(--c-aqua-500),var(--c-cyan));
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:-.06em;
  filter:drop-shadow(0 12px 40px rgba(46,144,240,.4));
  animation:shimmer 6s ease-in-out infinite;
}
.error-page h1{font-size:var(--fs-2xl);margin:var(--s-4) 0;color:var(--c-ink-900)}
.error-page p{color:var(--c-ink-500);margin-bottom:var(--s-8);font-size:var(--fs-md)}

/* ==========================================================================
   UTILITIES
   ========================================================================== */
.text-center{text-align:center}
.text-sm{font-size:var(--fs-sm)}
.mt-4{margin-top:var(--s-4)}.mt-8{margin-top:var(--s-8)}
.mb-4{margin-bottom:var(--s-4)}.mb-8{margin-bottom:var(--s-8)}
.mb-section{margin-bottom:var(--s-14)}.mb-section-lg{margin-bottom:var(--s-20)}
.mt-section{margin-top:var(--s-14)}
.btn--full{width:100%;justify-content:center}
.table-wrap{overflow-x:auto;border-radius:var(--r-xl);-webkit-overflow-scrolling:touch}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-8);max-width:980px;margin:0 auto}
@media(max-width:640px){.contact-grid{grid-template-columns:1fr}}
.error-page__actions{display:flex;gap:var(--s-4);justify-content:center;flex-wrap:wrap;margin-top:var(--s-4)}
.footer__bottom--simple{border-top:none;padding-top:0}
.form__error--check{margin-top:calc(var(--s-4) * -1);margin-bottom:var(--s-4)}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media(max-width:768px){
  :root{--fs-5xl:3rem;--fs-4xl:2.5rem;--fs-3xl:2rem;--fs-2xl:1.625rem}
  .section{padding:var(--s-16) 0}
  .section__header{margin-bottom:var(--s-12)}
  .hero{padding:var(--s-24) 0 var(--s-24);min-height:auto}
  .cta-banner{padding:var(--s-16) var(--s-6)}
  .selector{padding:var(--s-8)}
}
@media(max-width:480px){
  .container{padding:0 var(--s-5)}
  .cookie-banner__inner{flex-direction:column;align-items:stretch}
  .cookie-banner__actions{width:100%}
  .cookie-banner__actions .btn{flex:1;justify-content:center}
  .error-page__code{font-size:7rem}
}
