:root{
  --ink:#0e1419; --ink2:#141c24; --panel:#18222c; --panel2:#1d2935;
  --steel:#8aa0b2; --steel-d:#5d7184; --azur:#2e9bd6; --azur-soft:#5fc0ef; --azur-deep:#1c6fa0;
  --chrome:#cdd9e3; --white:#eef4f9; --dim:#9fb1c0; --line:rgba(138,160,178,.22);
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--ink);color:var(--white);
  font-family:'Inter',system-ui,sans-serif;font-weight:400;line-height:1.65;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.head{font-family:'Barlow Condensed','Inter',sans-serif;text-transform:uppercase;letter-spacing:.01em}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:22px}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(14,20,25,.9);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--maxw);margin-inline:auto;padding-inline:18px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:38px;height:38px;border:2px solid var(--azur);display:grid;place-items:center;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.5rem;color:var(--azur-soft);background:rgba(46,155,214,.08)}
.brand b{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:1.3rem;letter-spacing:.05em;text-transform:uppercase;color:var(--white);line-height:1}
.brand small{display:block;font-size:.55rem;letter-spacing:.34em;text-transform:uppercase;color:var(--steel);margin-top:3px}
.nav{display:none}
.nav a{font-family:'Barlow Condensed',sans-serif;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);padding:6px 2px;position:relative;transition:color .22s}
.nav a:hover,.nav a[aria-current=page]{color:var(--azur-soft)}
.nav a[aria-current=page]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--azur)}
.hdr-cta{font-family:'Barlow Condensed',sans-serif;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;
  background:var(--azur);color:#04121b;font-weight:600;padding:9px 17px;border-radius:4px;white-space:nowrap;transition:.2s}
.hdr-cta:hover{background:var(--azur-soft)}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--azur-soft);transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mnav{display:none;flex-direction:column;background:var(--ink2);border-bottom:1px solid var(--line)}
.mnav.open{display:flex}
.mnav a{padding:14px 26px;border-top:1px solid rgba(138,160,178,.12);font-family:'Barlow Condensed',sans-serif;font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase;color:var(--dim)}
.mnav a[aria-current=page]{color:var(--azur-soft)}

/* hero */
.hero{position:relative;min-height:86vh;display:flex;align-items:flex-end;border-bottom:1px solid var(--line);overflow:hidden}
.hero .bg{position:absolute;inset:0}
.hero .bg img{width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,20,25,.55),rgba(14,20,25,.82) 60%,var(--ink))}
.hero-in{position:relative;padding:40px 22px 56px;width:100%;max-width:var(--maxw);margin-inline:auto}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--azur-soft);border:1px solid var(--line);border-radius:999px;padding:7px 14px;background:rgba(46,155,214,.07)}
.badge i{display:none}
.hero h1{font-family:'Barlow Condensed',sans-serif;font-weight:600;text-transform:uppercase;line-height:.98;
  font-size:clamp(2.8rem,12vw,5.6rem);letter-spacing:.01em;margin-top:18px}
.hero h1 span{color:var(--azur-soft);display:block}
.hero .sub{color:var(--chrome);max-width:46ch;margin-top:18px;font-size:1.05rem}
.hero .phone-xl{display:inline-flex;align-items:baseline;gap:10px;margin-top:8px;
  font-family:'Barlow Condensed',sans-serif;font-size:2rem;color:var(--white);letter-spacing:.02em}
.hero .phone-xl small{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--steel)}

/* buttons */
.btns{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:54px;padding:0 28px;
  font-family:'Barlow Condensed',sans-serif;font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;border-radius:5px;transition:.22s}
.btn-azur{background:var(--azur);color:#04121b}
.btn-azur:hover{background:var(--azur-soft);transform:translateY(-2px)}
.btn-line{border:1.5px solid var(--steel-d);color:var(--chrome)}
.btn-line:hover{border-color:var(--azur);color:var(--azur-soft)}

/* sections */
section{padding:64px 0}
.kicker{font-family:'Barlow Condensed',sans-serif;font-size:.95rem;letter-spacing:.22em;text-transform:uppercase;color:var(--azur);display:flex;align-items:center;gap:12px}
.kicker::before{content:"";width:6px;height:6px;transform:rotate(45deg);background:var(--azur)}
.kicker.ctr{justify-content:center}
h2.sec{font-family:'Barlow Condensed',sans-serif;font-weight:600;text-transform:uppercase;line-height:1;
  font-size:clamp(2rem,8vw,3.4rem);margin-top:12px}
.sec-head{max-width:60ch}
.sec-head.ctr{margin-inline:auto;text-align:center}
.sec-head.ctr .kicker{justify-content:center}
.lead{color:var(--dim);font-size:1.02rem;margin-top:14px;max-width:60ch}

/* service cards */
.cards{display:grid;gap:16px;margin-top:34px}
.svc{position:relative;border:1px solid var(--line);background:var(--panel);overflow:hidden;display:flex;flex-direction:column}
.svc .ph{aspect-ratio:16/10;overflow:hidden}
.svc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.svc:hover .ph img{transform:scale(1.06)}
.svc .bd{padding:20px 20px 24px;flex:1;display:flex;flex-direction:column}
.svc .n{font-family:'Barlow Condensed',sans-serif;font-size:.8rem;letter-spacing:.2em;color:var(--azur);text-transform:uppercase}
.svc h3{font-family:'Barlow Condensed',sans-serif;font-weight:600;text-transform:uppercase;font-size:1.55rem;margin-top:4px;color:var(--white)}
.svc p{color:var(--dim);font-size:.92rem;margin-top:8px}
.svc .go{margin-top:auto;padding-top:14px;font-family:'Barlow Condensed',sans-serif;font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;color:var(--azur-soft);display:inline-flex;gap:8px;align-items:center}

/* list of prestations */
.prest{display:grid;gap:11px;margin-top:30px;list-style:none}
.prest li{display:flex;gap:14px;align-items:flex-start;border:1px solid var(--line);background:var(--panel);padding:16px 18px}
.prest li .chk{flex:none;width:22px;height:22px;border:1.5px solid var(--azur);border-radius:50%;display:grid;place-items:center;margin-top:1px}
.prest li .chk::after{content:"";width:8px;height:4px;border-left:2px solid var(--azur-soft);border-bottom:2px solid var(--azur-soft);transform:rotate(-45deg) translateY(-1px)}
.prest li b{font-weight:500;color:var(--white)}
.prest li span.d{color:var(--dim);font-size:.92rem}

/* split */
.split{display:grid;gap:26px;align-items:center}
.split .ph{border:1px solid var(--line);overflow:hidden}
.split .ph img{width:100%;aspect-ratio:4/3;object-fit:cover}
.split h2{font-family:'Barlow Condensed',sans-serif;font-weight:600;text-transform:uppercase;font-size:clamp(2rem,7vw,3rem);line-height:1}

/* stats band */
.band{background:linear-gradient(rgba(14,20,25,.86),rgba(14,20,25,.92)),url('img/water.jpg') center/cover;border-block:1px solid var(--line)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.stats .s{background:var(--ink);padding:26px 18px;text-align:center}
.stats .s b{display:block;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:2.6rem;color:var(--azur-soft);line-height:1}
.stats .s span{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-top:6px;display:block}

/* zones */
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.chips span{font-size:.82rem;color:var(--chrome);border:1px solid var(--line);border-radius:4px;padding:7px 13px;background:var(--panel)}

/* contact */
.info-grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:26px}
.info-grid .cell{background:var(--ink2);padding:22px}
.info-grid .k{font-family:'Barlow Condensed',sans-serif;font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--azur)}
.info-grid .v{font-size:1.15rem;color:var(--white);margin-top:6px;font-weight:500}
.info-grid .v a:hover{color:var(--azur-soft)}
.hours{display:grid;gap:8px;margin-top:18px;list-style:none}
.hours li{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:9px 0;color:var(--chrome);font-size:.95rem}
.hours li b{color:var(--white);font-weight:500}
.hours li .u{color:#3ad07a;font-weight:500}

/* footer */
.ft{border-top:1px solid var(--line);background:var(--ink2);padding:46px 0 30px}
.ft-in{display:grid;gap:26px}
.ft p{color:var(--dim);font-size:.88rem;max-width:36ch;margin-top:14px}
.ft h5{font-family:'Barlow Condensed',sans-serif;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--azur);margin-bottom:12px}
.ft a.fl{display:block;color:var(--dim);font-size:.92rem;padding:3px 0}
.ft a.fl:hover{color:var(--azur-soft)}
.ft .legal{border-top:1px solid var(--line);margin-top:28px;padding-top:16px;font-size:.72rem;color:rgba(159,177,192,.5);display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between}

@media(min-width:760px){
  section{padding:88px 0}
  .nav{display:flex;gap:22px}
  .burger,.mnav{display:none!important}
  .hero{align-items:center}
  .btns{flex-direction:row}
  .cards{grid-template-columns:repeat(3,1fr)}
  .split{grid-template-columns:1fr 1fr;gap:48px}
  .split.rev .ph{order:2}
  .stats{grid-template-columns:repeat(4,1fr)}
  .info-grid{grid-template-columns:repeat(3,1fr)}
  .ft-in{grid-template-columns:1.7fr 1fr 1fr;gap:38px}
}

/* animation pass (reveal base states) */
.js-anim .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}
/* ---- Animation pass (CSS-sober tier): hero rise + slow scale, reveals gated by .js-anim ---- */
@media(prefers-reduced-motion:no-preference){
  .js-anim .hero .bg img{animation:heroScale 1.4s cubic-bezier(.16,1,.3,1) both}
  .js-anim .hero-in>*{animation:heroRise .8s cubic-bezier(.16,1,.3,1) both}
  .js-anim .hero-in>*:nth-child(1){animation-delay:.12s}
  .js-anim .hero-in>*:nth-child(2){animation-delay:.22s}
  .js-anim .hero-in>*:nth-child(3){animation-delay:.32s}
  .js-anim .hero-in>*:nth-child(4){animation-delay:.42s}
  @keyframes heroScale{from{transform:scale(1.12);filter:brightness(.82)}to{transform:scale(1.06);filter:brightness(1)}}
  @keyframes heroRise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
}
