/* ============================================================
   ARDAAS LIMITED — shared design system  (v2, multi-page)
   Palette from brand logo (water "A" + navy).
   ============================================================ */
:root{
  --navy:#0B1340; --navy-2:#111c52; --navy-3:#1a2873;
  --azure:#1E6FE0; --azure-2:#3b86f0;
  --aqua:#3FD8CE; --aqua-2:#6ff0e8; --aqua-deep:#1FB9B0;
  --ivory:#F7F5EF; --ivory-2:#efece2; --paper:#fff;
  --slate:#5A6477; --ink:#0B1340;
  --gold:#C8A04B;                         /* spirits accent */
  --line:rgba(11,19,64,.12); --line-soft:rgba(11,19,64,.07);
  --grad-aqua:linear-gradient(135deg,var(--aqua),var(--azure));
  --grad-navy:linear-gradient(150deg,var(--navy-3),var(--navy));

  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;

  --r:18px; --r-lg:28px; --r-xl:36px; --r-sm:12px;
  --shadow-sm:0 1px 2px rgba(11,19,64,.05),0 8px 22px -14px rgba(11,19,64,.28);
  --shadow:0 1px 2px rgba(11,19,64,.05),0 26px 60px -24px rgba(11,19,64,.4);
  --shadow-lg:0 40px 90px -30px rgba(11,19,64,.5);
  --shadow-aqua:0 24px 60px -22px rgba(31,185,176,.55);

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --maxw:1280px;
  --pad:clamp(20px,5vw,72px);
  --section:clamp(54px,7.6vw,108px);     /* tightened vertical rhythm */

  --z-bar:1000; --z-cursor:9999; --z-pre:10000; --z-nav:900; --z-menu:880; --z-modal:9500;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--ivory);color:var(--navy);line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2.5px solid var(--azure);outline-offset:3px;border-radius:6px}
::selection{background:var(--aqua);color:var(--navy)}
body::after{content:"";position:fixed;inset:0;z-index:9997;pointer-events:none;opacity:.028;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.03;letter-spacing:-.018em;color:var(--navy)}
h1{font-size:clamp(2.8rem,7.4vw,6rem)}
h2{font-size:clamp(2.1rem,4.8vw,3.9rem)}
h3{font-size:clamp(1.3rem,2.4vw,2rem);line-height:1.12}
h4{font-size:clamp(1.1rem,1.6vw,1.35rem)}
p{max-width:64ch}
.lead{font-size:clamp(1.05rem,1.5vw,1.32rem);color:var(--slate);line-height:1.62}
.display-italic{font-style:italic;font-weight:500}
.kicker{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--sans);font-size:.78rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--aqua-deep)}
.kicker::before{content:"";width:30px;height:1.5px;background:currentColor;display:inline-block}
.kicker.center{justify-content:center}
.kicker.light{color:var(--aqua)}
.kicker.gold{color:var(--gold)}

/* ---------- layout utils ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.container-wide{max-width:1480px;margin-inline:auto;padding-inline:var(--pad)}
section{position:relative;scroll-margin-top:88px}
.section{padding-block:var(--section)}
.section-t{padding-top:var(--section)}
.section-b{padding-bottom:var(--section)}
.muted{color:var(--slate)}
.center{text-align:center}
.eyebrow-row{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2rem,4vw,3.4rem)}

/* dark section */
.dark{background:var(--grad-navy);color:var(--ivory)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--ivory)}
.dark .lead,.dark p{color:rgba(247,245,239,.78)}
.dark .kicker{color:var(--aqua)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 1.65rem;border-radius:100px;font-weight:600;
  font-size:.97rem;position:relative;white-space:nowrap;will-change:transform;
  transition:transform .4s var(--ease),background .3s,color .3s,box-shadow .3s,border-color .3s}
.btn svg{width:18px;height:18px;transition:transform .4s var(--ease)}
.btn .btn-inner{display:inline-flex;align-items:center;gap:.55rem;transition:transform .4s var(--ease)}
.btn-primary{background:var(--navy);color:var(--ivory);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--navy-2);box-shadow:var(--shadow)}
.btn-primary:hover svg{transform:translate(3px,-3px)}
.btn-aqua{background:var(--grad-aqua);color:#04253b;box-shadow:var(--shadow-aqua)}
.btn-aqua:hover svg{transform:translate(3px,-3px)}
.btn-gold{background:linear-gradient(135deg,#e3c074,var(--gold));color:#2a1e06;box-shadow:0 24px 60px -22px rgba(200,160,75,.6)}
.btn-ghost{background:transparent;color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--navy);background:rgba(11,19,64,.03)}
.dark .btn-ghost{color:var(--ivory);border-color:rgba(247,245,239,.28)}
.dark .btn-ghost:hover{border-color:var(--aqua);background:rgba(255,255,255,.05)}
.btn-light{background:var(--ivory);color:var(--navy)}

/* ---------- scroll progress bar ---------- */
.scrollbar{position:fixed;top:0;left:0;height:3px;width:100%;z-index:var(--z-bar);background:transparent;pointer-events:none}
.scrollbar i{display:block;height:100%;width:0;background:var(--grad-aqua);box-shadow:0 0 12px rgba(63,216,206,.6)}

/* ---------- custom water cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:var(--z-cursor);
  transform:translate(-50%,-50%);opacity:0;transition:opacity .3s}
.cursor-dot{width:7px;height:7px;background:var(--aqua-deep)}
.cursor-ring{width:40px;height:40px;border:1.5px solid rgba(31,185,176,.7);
  background:radial-gradient(circle,rgba(63,216,206,.12),transparent 70%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s,border-color .3s}
.cursor-ring.hover{width:76px;height:76px;background:radial-gradient(circle,rgba(63,216,206,.22),transparent 70%);border-color:var(--aqua)}
.cursor-ring.drag{width:84px;height:84px;border-color:var(--azure);background:radial-gradient(circle,rgba(30,111,224,.2),transparent 70%)}
.cursor-ring .clabel{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--sans);font-size:.6rem;
  font-weight:700;letter-spacing:.08em;color:var(--navy);opacity:0;transition:opacity .25s;text-transform:uppercase}
.cursor-ring.drag .clabel{opacity:1}
@media (hover:hover) and (pointer:fine){body.cursor-on{cursor:none}}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none!important}}

/* ---------- preloader ---------- */
#preloader{position:fixed;inset:0;z-index:var(--z-pre);background:var(--navy);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:1.5rem;transition:opacity .7s var(--ease),visibility .7s}
#preloader.done{opacity:0;visibility:hidden}
#preloader .pl-logo{width:96px;animation:floaty 2.2s ease-in-out infinite;filter:drop-shadow(0 10px 30px rgba(63,216,206,.4))}
#preloader .pl-count{font-family:var(--serif);color:var(--ivory);font-size:1.1rem;letter-spacing:.1em}
#preloader .bar{width:170px;height:2px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
#preloader .bar i{display:block;height:100%;width:0;background:var(--grad-aqua);transition:width .2s linear}
#preloader .pl-name{font-family:var(--sans);color:rgba(247,245,239,.6);letter-spacing:.34em;font-size:.7rem;text-transform:uppercase}
@keyframes floaty{50%{transform:translateY(-10px)}}

/* =========================================================
   NAV  (injected by app.js)
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--pad);transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s,border-color .4s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(247,245,239,.8);backdrop-filter:blur(16px) saturate(1.5);-webkit-backdrop-filter:blur(16px) saturate(1.5);
  padding-block:10px;border-bottom:1px solid var(--line-soft);box-shadow:0 12px 34px -26px rgba(11,19,64,.6)}
/* light nav while over a dark page-hero (subpages) */
body.dark-hero .nav:not(.scrolled) .nav-links a,
body.dark-hero .nav:not(.scrolled) .brand .wm b{color:var(--ivory)}
body.dark-hero .nav:not(.scrolled) .brand .wm span{color:rgba(247,245,239,.65)}
body.dark-hero .nav:not(.scrolled) .nav-links a.active{color:var(--aqua)}
body.dark-hero .nav:not(.scrolled) .burger span{background:var(--ivory)}
body.dark-hero .nav:not(.scrolled) .nav-cta .btn-primary{background:var(--ivory);color:var(--navy)}
/* bigger, bolder brand/logo */
.brand{display:flex;align-items:center;gap:.85rem;z-index:2}
.brand .mark{position:relative;width:56px;height:56px;flex:none;display:grid;place-items:center;transition:width .4s var(--ease),height .4s var(--ease)}
.nav .brand .mark{width:66px;height:66px}
.nav.scrolled .brand .mark{width:56px;height:56px}
.brand .mark img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 3px 10px rgba(31,185,176,.5));position:relative;z-index:2}
.brand .mark::before{content:"";position:absolute;inset:-6px;border-radius:50%;border:1.5px dashed rgba(31,185,176,.45);
  animation:spin 16s linear infinite;opacity:0;transition:opacity .4s}
.brand:hover .mark::before{opacity:1}
.brand .mark::after{content:"";position:absolute;inset:2px;border-radius:50%;background:radial-gradient(circle,rgba(63,216,206,.3),transparent 65%);
  filter:blur(8px);z-index:1;opacity:.8}
@keyframes spin{to{transform:rotate(360deg)}}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:-.01em}
.brand .wm span{font-family:var(--sans);font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--slate);margin-top:4px}

.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{font-size:.93rem;font-weight:500;position:relative;padding:6px 0;color:var(--navy)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--aqua-deep);transition:width .35s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--aqua-deep)}
.nav-cta{display:flex;align-items:center;gap:1rem;z-index:2}
.nav-cta .btn{padding:.7rem 1.3rem;font-size:.9rem}

/* nav hover-image-follow */
.navimg{position:fixed;width:230px;height:150px;border-radius:14px;overflow:hidden;pointer-events:none;z-index:var(--z-nav);
  opacity:0;transform:translate(-50%,-50%) scale(.85);transition:opacity .35s var(--ease),transform .35s var(--ease);box-shadow:var(--shadow)}
.navimg img{width:100%;height:100%;object-fit:cover}
.navimg.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* burger + mobile menu */
.burger{display:none;width:46px;height:46px;border-radius:50%;align-items:center;justify-content:center;z-index:2;position:relative}
.burger span{position:absolute;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:transform .4s var(--ease),opacity .3s}
.burger span:nth-child(1){transform:translateY(-6px)}
.burger span:nth-child(3){transform:translateY(6px)}
body.menu-open .burger span:nth-child(1){transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:rotate(-45deg)}
.menu-overlay{position:fixed;inset:0;z-index:var(--z-menu);background:var(--grad-navy);display:flex;flex-direction:column;
  justify-content:center;padding:max(var(--pad),64px) var(--pad);clip-path:circle(0% at calc(100% - 48px) 40px);
  transition:clip-path .7s var(--ease);visibility:hidden;overflow-y:auto}
body.menu-open .menu-overlay{clip-path:circle(150% at calc(100% - 48px) 40px);visibility:visible}
.menu-overlay a.m-link{font-family:var(--serif);font-size:clamp(1.9rem,8vw,3rem);color:var(--ivory);padding:.18em 0;
  display:flex;align-items:baseline;gap:1rem;opacity:0;transform:translateY(28px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s}
.menu-overlay a.m-link span{font-family:var(--sans);font-size:.8rem;color:var(--aqua);letter-spacing:.1em}
.menu-overlay a.m-link:hover{color:var(--aqua)}
body.menu-open .menu-overlay a.m-link{opacity:1;transform:none}
body.menu-open .menu-overlay a.m-link:nth-child(1){transition-delay:.16s}
body.menu-open .menu-overlay a.m-link:nth-child(2){transition-delay:.22s}
body.menu-open .menu-overlay a.m-link:nth-child(3){transition-delay:.28s}
body.menu-open .menu-overlay a.m-link:nth-child(4){transition-delay:.34s}
body.menu-open .menu-overlay a.m-link:nth-child(5){transition-delay:.40s}
body.menu-open .menu-overlay a.m-link:nth-child(6){transition-delay:.46s}
.menu-foot{margin-top:2.4rem;color:rgba(247,245,239,.6);font-size:.9rem;opacity:0;transition:opacity .5s .55s;display:flex;gap:1.5rem;flex-wrap:wrap}
body.menu-open .menu-foot{opacity:1}

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}
.reveal-d4{transition-delay:.32s}.reveal-d5{transition-delay:.40s}.reveal-d6{transition-delay:.48s}
/* line-by-line text reveal */
.tr{display:inline-block;overflow:hidden;vertical-align:top}
.tr>span{display:inline-block;transform:translateY(110%);transition:transform .9s var(--ease)}
.tr.in>span{transform:none}
.scale-img{clip-path:inset(0 0 0 0);overflow:hidden}
.scale-img img{transform:scale(1.16);transition:transform 1.3s var(--ease)}
.scale-img.in img{transform:scale(1)}

/* =========================================================
   HERO (home)
   ========================================================= */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  padding-top:clamp(110px,15vh,170px);padding-bottom:clamp(40px,6vw,80px)}
#hero3d{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:0;transition:opacity 1.2s ease}
#hero3d.ready{opacity:1}
.hero-fallback{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-fallback .blob{position:absolute;border-radius:50%;filter:blur(90px)}
.hero-fallback .b1{width:520px;height:520px;background:radial-gradient(circle,rgba(63,216,206,.5),transparent 70%);top:-120px;right:-60px;animation:drift 16s ease-in-out infinite}
.hero-fallback .b2{width:460px;height:460px;background:radial-gradient(circle,rgba(30,111,224,.36),transparent 70%);bottom:-160px;left:-120px;animation:drift 20s ease-in-out infinite reverse}
@keyframes drift{50%{transform:translate(40px,30px) scale(1.1)}}
.hero-inner{position:relative;z-index:2;width:100%}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{margin:1.1rem 0 0}
.hero h1 .ink-aqua{background:linear-gradient(120deg,var(--azure),var(--aqua-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-style:italic}
.hero .lead{margin:1.5rem 0 2rem;max-width:46ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-meta{margin-top:2rem;display:flex;gap:2rem;flex-wrap:wrap}
.hero-meta .hm{display:flex;flex-direction:column}
.hero-meta .hm b{font-family:var(--serif);font-size:1.9rem;line-height:1}
.hero-meta .hm b .plus{color:var(--aqua-deep)}
.hero-meta .hm small{color:var(--slate);font-size:.82rem;margin-top:.4rem}
/* hero media stack */
.hero-media{position:relative}
.hero-media .frame{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.hero-media .frame img{position:absolute;top:-15%;left:0;width:100%;height:130%;object-fit:cover;will-change:transform}
.hero-media .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(11,19,64,.4))}
.float-card{position:absolute;border-radius:var(--r);padding:.9rem 1.1rem;display:flex;align-items:center;gap:.8rem;
  background:rgba(247,245,239,.86);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow);z-index:3}
.float-card.fc1{left:-26px;bottom:34px;max-width:230px}
.float-card.fc2{right:-20px;top:42px}
.float-card .ico{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;background:var(--grad-aqua);color:#04253b}
.float-card .ico svg{width:22px;height:22px}
.float-card b{font-family:var(--serif);font-size:1rem;display:block}
.float-card small{color:var(--slate);font-size:.78rem;line-height:1.3;display:block}

/* =========================================================
   PAGE HERO (subpages)
   ========================================================= */
.page-hero{position:relative;min-height:clamp(420px,72vh,720px);display:flex;align-items:flex-end;overflow:hidden;color:var(--ivory)}
.page-hero .ph-bg{position:absolute;inset:-10% 0;width:100%;height:120%;object-fit:cover;z-index:0;will-change:transform}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,19,64,.5),rgba(11,19,64,.82));z-index:1}
.page-hero .ph-inner{position:relative;z-index:2;padding-bottom:clamp(2.5rem,6vw,5rem);width:100%}
.page-hero h1{color:var(--ivory);max-width:18ch;margin-top:1rem}
.page-hero .lead{color:rgba(247,245,239,.85);margin-top:1.4rem;max-width:54ch}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.85rem;color:rgba(247,245,239,.7);margin-bottom:.4rem}
.breadcrumb a:hover{color:var(--aqua)}
.breadcrumb .sep{opacity:.5}
.page-hero.spirits::after{background:linear-gradient(180deg,rgba(10,8,4,.5),rgba(10,8,4,.86))}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:rgba(255,255,255,.4)}
.marquee.dark{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.marquee-track{display:flex;width:max-content;animation:scrollx 40s linear infinite}
.marquee.rev .marquee-track{animation-direction:reverse}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:inline-flex;align-items:center;gap:1.1rem;padding:1.05rem 2.1rem;font-family:var(--serif);
  font-size:clamp(1.05rem,1.8vw,1.5rem);white-space:nowrap}
.marquee.dark .marquee-item{color:var(--ivory)}
.marquee-item::before{content:"✦";color:var(--aqua-deep);font-size:.65em}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* =========================================================
   DIVISION CARDS (home) — big image cards
   ========================================================= */
.divisions{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,1.6vw,1.5rem)}
.div-card{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:360px;display:flex;align-items:flex-end;
  color:var(--ivory);box-shadow:var(--shadow-sm);transition:box-shadow .5s var(--ease),transform .5s var(--ease)}
.div-card .dc-bg{position:absolute;inset:0;z-index:0}
.div-card .dc-bg img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.div-card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,19,64,.05) 30%,rgba(11,19,64,.85));transition:background .4s}
.div-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.div-card:hover .dc-bg img{transform:scale(1.07)}
.div-card .dc-body{position:relative;z-index:2;padding:clamp(1.5rem,3vw,2.4rem);width:100%}
.div-card .dc-num{font-family:var(--serif);font-size:.9rem;color:var(--aqua)}
.div-card h3{color:var(--ivory);margin:.5rem 0 .5rem;font-size:clamp(1.5rem,2.6vw,2.1rem)}
.div-card p{color:rgba(247,245,239,.82);font-size:.95rem;max-width:42ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s,margin .4s}
.div-card:hover p,.div-card:focus-within p{max-height:120px;opacity:1;margin-top:.4rem}
.div-card .dc-go{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;font-weight:600;font-size:.92rem;color:var(--aqua)}
.div-card .dc-go svg{width:18px;height:18px;transition:transform .4s var(--ease)}
.div-card:hover .dc-go svg{transform:translate(4px,-4px)}
.div-card.tall{min-height:440px}

/* =========================================================
   CARDS: service / feature (3D tilt)
   ========================================================= */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,1.6vw,1.4rem)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2vw,1.8rem)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,1.4vw,1.2rem)}
.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.card{position:relative;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r);
  padding:1.8rem 1.7rem;overflow:hidden}
.card .spot{position:absolute;inset:0;opacity:0;transition:opacity .4s;pointer-events:none;
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,0%),rgba(63,216,206,.16),transparent 45%)}
.card:hover{box-shadow:var(--shadow);border-color:transparent}
.card:hover .spot{opacity:1}
.card .lz{transform:translateZ(40px)}     /* layer lifted in 3D */
.card-num{font-family:var(--serif);font-size:.95rem;color:var(--aqua-deep);font-weight:600}
.card .c-ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:rgba(63,216,206,.14);color:var(--aqua-deep);margin-bottom:1.1rem}
.card .c-ico svg{width:26px;height:26px}
.card h3{margin:.4rem 0 .55rem;font-size:1.3rem}
.card p{color:var(--slate);font-size:.95rem;line-height:1.55;max-width:36ch}
.card .arrow{margin-top:1.25rem;width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;
  transition:background .35s,color .35s,border-color .35s,transform .35s var(--ease)}
.card .arrow svg{width:17px;height:17px}
.card:hover .arrow{background:var(--navy);color:var(--aqua);border-color:var(--navy);transform:translate(2px,-2px)}
/* cards inside dark sections become glass */
.dark .card{background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.12)}
.dark .card h3{color:var(--ivory)}
.dark .card p{color:rgba(247,245,239,.72)}
.dark .card .card-num{color:var(--aqua)}
.dark .card .arrow{border-color:rgba(255,255,255,.22);color:var(--ivory)}
.dark .card:hover .arrow{background:var(--aqua);color:var(--navy);border-color:var(--aqua)}
.dark .card .c-ico{background:rgba(63,216,206,.18);color:var(--aqua)}

/* =========================================================
   BENTO
   ========================================================= */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.bento>*{border-radius:var(--r-lg);overflow:hidden;position:relative}
.bento .b-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.bento .b-img:hover img{transform:scale(1.06)}
.bento .b-text{background:var(--grad-navy);color:var(--ivory);padding:1.8rem;display:flex;flex-direction:column;justify-content:space-between}
.bento .b-text h3{color:var(--ivory)}
.bento .b-aqua{background:var(--grad-aqua);color:#04253b;padding:1.8rem;display:flex;flex-direction:column;justify-content:space-between}
.bento .span2{grid-column:span 2}.bento .row2{grid-row:span 2}
.b-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(11,19,64,.5))}
.b-cap{position:absolute;z-index:2;bottom:0;left:0;padding:1.4rem;color:var(--ivory);font-family:var(--serif);font-size:1.1rem}

/* =========================================================
   STATS
   ========================================================= */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat .num{font-family:var(--serif);font-size:clamp(2.4rem,4.4vw,3.6rem);line-height:1}
.stat .num .plus{color:var(--aqua-deep)}
.stat .lab{color:var(--slate);font-size:.88rem;margin-top:.6rem;max-width:18ch}
.dark .stat .lab{color:rgba(247,245,239,.7)}

/* =========================================================
   STEPS / TIMELINE
   ========================================================= */
.steps{border-top:1px solid var(--line)}
.dark .steps{border-color:rgba(247,245,239,.14)}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;padding:1.5rem 0;border-bottom:1px solid var(--line);align-items:start;
  transition:padding-left .4s var(--ease)}
.dark .step{border-color:rgba(247,245,239,.14)}
.step:hover{padding-left:12px}
.step .s-num{font-family:var(--serif);color:var(--aqua-deep);font-size:1.15rem;font-weight:600}
.dark .step .s-num{color:var(--aqua)}
.step h4{font-family:var(--serif);font-size:1.3rem;margin-bottom:.35rem}
.step p{color:var(--slate);font-size:.95rem;max-width:48ch}
.dark .step p{color:rgba(247,245,239,.72)}

/* split media block */
.split-media{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split-media .sm-img{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:6/5}
.split-media .sm-img img{position:absolute;top:-15%;left:0;width:100%;height:130%;object-fit:cover;will-change:transform}
.feature-list{display:grid;gap:1rem;margin-top:1.8rem}
.feature-list li{display:flex;gap:.9rem;align-items:flex-start;list-style:none}
.feature-list .tick{width:26px;height:26px;border-radius:50%;flex:none;display:grid;place-items:center;background:rgba(63,216,206,.16);color:var(--aqua-deep)}
.dark .feature-list .tick{background:rgba(63,216,206,.2);color:var(--aqua)}
.feature-list .tick svg{width:15px;height:15px}
.feature-list b{font-weight:600}.feature-list span{color:var(--slate);font-size:.95rem}
.dark .feature-list span{color:rgba(247,245,239,.7)}

/* =========================================================
   PRODUCTS (spirits)
   ========================================================= */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2vw,1.8rem)}
.prod{position:relative;border-radius:var(--r-lg);overflow:hidden;background:#13110d;color:#f0e9da;border:1px solid rgba(200,160,75,.18);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.prod:hover{transform:translateY(-6px);box-shadow:0 40px 80px -30px rgba(0,0,0,.7);border-color:rgba(200,160,75,.45)}
.prod .p-img{aspect-ratio:4/3;overflow:hidden;position:relative}
.prod .p-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.prod:hover .p-img img{transform:scale(1.08)}
.prod .award{position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(10,8,4,.7);backdrop-filter:blur(6px);border:1px solid rgba(200,160,75,.5);color:var(--gold);
  padding:.4rem .7rem;border-radius:100px;font-size:.72rem;font-weight:600;letter-spacing:.03em}
.prod .award svg{width:14px;height:14px}
.prod .p-body{padding:1.6rem}
.prod h3{color:#fff;font-size:1.4rem;margin-bottom:.5rem}
.prod .p-type{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700}
.prod p{color:rgba(240,233,218,.72);font-size:.92rem;margin-top:.6rem}
.prod .notes{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.prod .notes span{font-size:.74rem;padding:.3rem .65rem;border:1px solid rgba(200,160,75,.3);border-radius:100px;color:rgba(240,233,218,.8)}
/* noir theme (spirits) */
.noir{background:radial-gradient(1100px 560px at 72% -12%,#1c1406,#0c0a07);color:#f0e9da}
.noir h1,.noir h2,.noir h3,.noir h4{color:#fff}
.noir p,.noir .lead{color:rgba(240,233,218,.74)}
.noir .kicker{color:var(--gold)}
.noir .feature-list .tick{background:rgba(200,160,75,.18);color:var(--gold)}
.noir .feature-list span{color:rgba(240,233,218,.7)}
.noir .steps,.noir .step{border-color:rgba(200,160,75,.16)}
.noir .step .s-num{color:var(--gold)}.noir .step p{color:rgba(240,233,218,.7)}
.noir .quote-feature blockquote em{color:var(--gold)}
.noir .avatar{background:linear-gradient(135deg,#3a2a0c,var(--gold));color:#1a1303}
.noir .card{background:rgba(255,255,255,.04);border-color:rgba(200,160,75,.18)}
.noir .card h3{color:#fff}.noir .card p{color:rgba(240,233,218,.72)}.noir .card .card-num{color:var(--gold)}
.noir .card .c-ico{background:rgba(200,160,75,.16);color:var(--gold)}
.noir .card .arrow{border-color:rgba(200,160,75,.3);color:#f0e9da}
.noir .card:hover .arrow{background:var(--gold);color:#1a1303;border-color:var(--gold)}
.gold-marquee{background:#0c0a07;border-color:rgba(200,160,75,.18)}
.gold-marquee .marquee-item{color:#f0e9da}.gold-marquee .marquee-item::before{content:"★";color:var(--gold)}

/* =========================================================
   TEAM (about) — monogram cards
   ========================================================= */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.9rem}
.team-card{aspect-ratio:1;border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  background:var(--paper);border:1px solid var(--line-soft);transition:transform .4s var(--ease),box-shadow .4s,background .4s,color .4s}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);background:var(--grad-navy);color:var(--ivory)}
.team-card .mono{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-size:1.4rem;
  font-weight:600;color:var(--ivory);background:var(--grad-aqua);transition:transform .4s var(--ease)}
.team-card:hover .mono{transform:scale(1.08) rotate(-4deg)}
.team-card b{font-family:var(--serif);font-size:1.05rem}
.team-card small{color:var(--slate);font-size:.76rem}
.team-card:hover small{color:rgba(247,245,239,.7)}

/* =========================================================
   QUOTE / TESTIMONIALS
   ========================================================= */
.quote-feature{text-align:center;max-width:1000px;margin-inline:auto}
.quote-feature .qmark{font-family:var(--serif);font-size:6rem;line-height:0;color:var(--aqua);height:36px;display:block}
.quote-feature blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,4vw,3rem);line-height:1.18;margin:1.5rem auto 0;max-width:20ch}
.quote-feature blockquote em{color:var(--azure);font-style:italic}
.avatar{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-weight:600;
  color:var(--ivory);background:var(--grad-navy);font-size:1rem;flex:none}
.quote-cite{display:inline-flex;align-items:center;gap:.85rem;margin-top:1.8rem}
.quote-cite .who{text-align:left}.quote-cite .who b{display:block}.quote-cite .who small{color:var(--slate)}
.dark .quote-cite .who small{color:rgba(247,245,239,.6)}
/* keep white testimonial cards readable inside dark sections */
.dark .testi-card blockquote{color:var(--navy)}
.dark .testi-card .who b{color:var(--navy)}
.dark .testi-card .who small{color:var(--slate)}
.testi-track{display:flex;gap:1.4rem;cursor:grab;user-select:none;padding-bottom:.5rem;overflow-x:hidden}
.testi-track.dragging{cursor:grabbing}
.testi-card{flex:0 0 min(540px,86vw);background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:clamp(1.8rem,3.5vw,2.6rem);box-shadow:var(--shadow-sm)}
.testi-card .stars{color:var(--aqua-deep);letter-spacing:.18em}
.testi-card blockquote{font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.6rem);line-height:1.32;font-weight:500;margin:1rem 0 1.5rem}
.carousel-controls{display:flex;gap:.8rem;margin-top:2rem;align-items:center}
.carousel-controls button{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;
  transition:background .3s,color .3s,border-color .3s}
.carousel-controls button:hover{background:var(--navy);color:var(--aqua);border-color:var(--navy)}
.carousel-controls .hint{margin-left:.6rem;color:var(--slate);font-size:.85rem}
.dark .carousel-controls button{border-color:rgba(247,245,239,.25);color:var(--ivory)}
.dark .carousel-controls .hint{color:rgba(247,245,239,.6)}

/* =========================================================
   ACCORDION
   ========================================================= */
.acc-item{border-bottom:1px solid var(--line)}
.acc-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.4rem 0;text-align:left;
  font-family:var(--serif);font-size:1.2rem;font-weight:600}
.acc-q .pm{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line);flex:none;display:grid;place-items:center;position:relative;transition:background .3s,color .3s}
.acc-q .pm::before,.acc-q .pm::after{content:"";position:absolute;background:currentColor;transition:transform .3s}
.acc-q .pm::before{width:12px;height:2px}.acc-q .pm::after{width:2px;height:12px}
.acc-item.open .acc-q .pm{background:var(--navy);color:var(--aqua)}
.acc-item.open .acc-q .pm::after{transform:scaleY(0)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.acc-a p{color:var(--slate);padding-bottom:1.4rem;max-width:70ch}

/* =========================================================
   CTA
   ========================================================= */
.cta{position:relative;overflow:hidden;text-align:center}
.cta .blob{position:absolute;width:620px;height:620px;border-radius:50%;filter:blur(95px);opacity:.42;z-index:0}
.cta .blob.a{background:radial-gradient(circle,var(--aqua),transparent 70%);top:-220px;left:-120px;animation:drift 18s ease-in-out infinite}
.cta .blob.b{background:radial-gradient(circle,var(--azure),transparent 70%);bottom:-240px;right:-120px;animation:drift 22s ease-in-out infinite reverse}
.cta-inner{position:relative;z-index:2;max-width:780px;margin-inline:auto}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.2rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-info .row{display:flex;gap:1rem;align-items:center;padding:1.1rem 0;border-bottom:1px solid var(--line-soft)}
.contact-info .row .ico{width:46px;height:46px;border-radius:12px;flex:none;display:grid;place-items:center;background:var(--paper);border:1px solid var(--line-soft);color:var(--azure)}
.contact-info .row .ico svg{width:20px;height:20px}
.contact-info .row b{display:block}.contact-info .row a,.contact-info .row span{color:var(--slate);font-size:.95rem}
.form{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-sm)}
.form .field{margin-bottom:1.05rem}
.form label{display:block;font-size:.82rem;font-weight:600;margin-bottom:.45rem}
.form input,.form textarea,.form select{width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;font:inherit;
  font-size:.95rem;background:var(--ivory);color:var(--navy);transition:border-color .3s,box-shadow .3s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 4px rgba(30,111,224,.12)}
.form textarea{resize:vertical;min-height:120px}
.form .btn{width:100%;justify-content:center;margin-top:.3rem}

/* =========================================================
   FOOTER
   ========================================================= */
.wave{display:block;width:100%;height:auto;line-height:0}
.footer{background:var(--grad-navy);color:rgba(247,245,239,.7);padding-top:clamp(3rem,5vw,4.5rem)}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.1fr;gap:2.2rem;padding-bottom:2.6rem;border-bottom:1px solid rgba(247,245,239,.12)}
.footer .brand .wm b{color:var(--ivory)}.footer .brand .wm span{color:var(--aqua)}
.footer-about{margin-top:1.1rem;max-width:32ch;font-size:.93rem;line-height:1.6}
.footer h5{color:var(--ivory);font-family:var(--sans);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.1rem}
.footer ul{list-style:none;display:grid;gap:.7rem}
.footer ul a{font-size:.92rem;transition:color .3s}.footer ul a:hover{color:var(--aqua)}
.footer .f-contact a{color:rgba(247,245,239,.85)}
.footer-note{font-size:.8rem;color:rgba(247,245,239,.45);margin-top:1rem;max-width:34ch;line-height:1.5}
.footer-bot{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:1.5rem 0 2rem;font-size:.85rem}
.footer-bot .socials{display:flex;gap:.7rem}
.footer-bot .socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(247,245,239,.18);display:grid;place-items:center;transition:background .3s,color .3s,border-color .3s}
.footer-bot .socials a:hover{background:var(--aqua);color:var(--navy);border-color:var(--aqua)}
.footer-bot .socials svg{width:17px;height:17px}
.age-badge{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;border:1.5px solid var(--gold);color:var(--gold);font-weight:700;font-size:.75rem}

/* =========================================================
   AGE GATE (spirits)
   ========================================================= */
.agegate{position:fixed;inset:0;z-index:var(--z-modal);background:rgba(8,6,3,.92);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:var(--pad);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.agegate.show{opacity:1;visibility:visible}
.agegate .ag-box{max-width:460px;text-align:center;background:#13110d;border:1px solid rgba(200,160,75,.3);border-radius:var(--r-lg);
  padding:clamp(2rem,5vw,3rem);color:#f0e9da;transform:translateY(20px);transition:transform .5s var(--ease)}
.agegate.show .ag-box{transform:none}
.agegate img{width:70px;margin:0 auto 1.2rem}
.agegate h3{color:#fff;font-size:1.7rem;margin-bottom:.8rem}
.agegate p{color:rgba(240,233,218,.7);font-size:.95rem;margin:0 auto 1.6rem}
.agegate .ag-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.agegate small{display:block;margin-top:1.2rem;color:rgba(240,233,218,.45);font-size:.78rem}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:960px){
  .hero{min-height:auto}
  .hero-grid,.split-media,.contact-grid{grid-template-columns:1fr}
  .hero-media{max-width:460px;margin-inline:auto;width:100%}
  .split-media .sm-img{order:-1;max-width:520px;margin-inline:auto;width:100%}
  .divisions{grid-template-columns:1fr}
  .grid-3,.prod-grid{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}
  .nav-links{display:none}
  .nav-cta .btn:not(.always){display:none}
  .burger{display:flex}
  #hero3d{opacity:.5!important}
}
@media (max-width:620px){
  body{font-size:16px}
  .grid-3,.grid-2,.grid-4,.prod-grid{grid-template-columns:1fr}
  .bento{grid-template-columns:1fr;grid-auto-rows:180px}
  .bento .span2{grid-column:auto}
  .footer-grid{grid-template-columns:1fr;gap:1.8rem}
  .hero-meta{gap:1.4rem}
  .float-card.fc2{display:none}
  .float-card.fc1{left:50%;transform:translateX(-50%);bottom:-22px}
  .hero-media .frame{aspect-ratio:5/4}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.tr>span{opacity:1!important;transform:none!important}
  .scale-img img{transform:none!important}
  .marquee-track{animation:none}
  .cursor-dot,.cursor-ring{display:none!important}
  #preloader{display:none!important}
  #hero3d{display:none!important}
}
