/* ============================================================
   TSK — THE STELLAR KRAFT
   Ultra-luxury architectural experience — design system
   ============================================================ */

:root{
  /* palette */
  --black:#070709;
  --graphite:#0d0d11;
  --panel:#14141a;
  --panel-2:#1b1b22;
  --grey:#2a2a31;
  --line:rgba(233,231,224,.16);
  --line-soft:rgba(255,255,255,.08);
  /* refined warm-white accent palette (no yellow) */
  --gold:#d9d2c4;
  --gold-bright:#f3eee3;
  --gold-deep:#8b8579;
  --champagne:#ece6da;
  --silver:#c9ccd2;
  --white:#f4f1ea;
  --muted:#9b958a;
  --muted-2:#6f6a62;
  /* warm beige surface (for sea-view / ceiling imagery) */
  --beige:#e9e1d1;
  --beige-2:#ded4c0;
  --ink:#1c1813;

  /* type */
  --serif:'Cormorant Garamond', 'Didot', 'Times New Roman', serif;
  --sans:'Jost','Helvetica Neue', Arial, sans-serif;

  /* motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-2:cubic-bezier(.7,0,.2,1);
  --slow:1.2s;

  --maxw:1560px;
  --gutter:clamp(20px,5vw,90px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-y:scroll;scrollbar-gutter:stable}
body{
  background:var(--black);
  color:var(--white);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body.lock{overflow:hidden;height:100vh}
::selection{background:var(--gold);color:var(--black)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}

/* scrollbar */
::-webkit-scrollbar{width:9px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:#23232a;border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-deep)}

/* ---------- typography ---------- */
.display{font-family:var(--serif);font-weight:300;line-height:1.02;letter-spacing:0}
h1,h2,h3{font-family:var(--serif);font-weight:300;letter-spacing:0;line-height:1.04}
.kicker{
  font-family:var(--sans);font-weight:400;
  font-size:clamp(10px,.78vw,12.5px);letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);
}
.kicker.dim{color:var(--muted)}
.serif-it{font-family:var(--serif);font-style:italic}
.lead{font-size:clamp(15px,1.25vw,18px);color:var(--silver);font-weight:300;line-height:1.7}
.fade-text{color:var(--muted)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.section{padding-block:clamp(80px,11vw,170px)}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}

/* ============================================================
   LOADER
   ============================================================ */
#loader{
  position:fixed;inset:0;z-index:9000;background:var(--black);
  display:flex;align-items:center;justify-content:center;text-align:center;
}
#loader .l-line{
  position:absolute;font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,3.6vw,52px);line-height:1.25;color:var(--white);
  opacity:0;letter-spacing:0;max-width:min(860px,82vw);padding-inline:24px;
}
#loader .l-final{color:var(--gold-bright)}
#loader .l-mono{
  position:absolute;bottom:46px;left:0;right:0;text-align:center;
  font-family:var(--sans);font-size:11px;letter-spacing:.5em;color:var(--muted-2);
  text-transform:uppercase;opacity:0;
}
.l-prog{position:absolute;left:0;bottom:0;height:2px;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright))}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{position:fixed;top:0;left:0;width:7px;height:7px;border-radius:50%;background:var(--gold-bright);
  pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference}
.cursor-ring{position:fixed;top:0;left:0;width:38px;height:38px;border:1px solid rgba(201,168,106,.5);
  border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s}
.cursor-ring.grow{width:74px;height:74px;background:rgba(201,168,106,.07);border-color:var(--gold)}
.cursor-ring.grow::after{content:attr(data-label);position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright)}
@media (hover:none){.cursor,.cursor-ring{display:none}}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gutter);
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s;
  border-bottom:1px solid transparent;
}
header.nav.solid{background:rgba(7,7,9,.72);backdrop-filter:blur(16px);padding-block:15px;border-bottom-color:var(--line-soft)}
.brand{display:flex;align-items:center;gap:13px;z-index:1100}
.brand .mark{width:34px;height:34px}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-family:var(--serif);font-size:23px;font-weight:500;letter-spacing:.16em;color:var(--white)}
.brand .bt span{font-size:8.5px;letter-spacing:.36em;color:var(--gold);text-transform:uppercase;margin-top:3px}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--silver);position:relative;padding:4px 0;transition:color .4s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .45s var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{border:1px solid var(--line);padding:11px 22px;border-radius:40px;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-bright);transition:all .45s var(--ease)}
.nav-cta:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.burger{display:none;flex-direction:column;gap:6px;z-index:1100;width:30px}
.burger span{height:1.5px;background:var(--white);transition:.4s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* mobile menu */
.menu-overlay{position:fixed;inset:0;z-index:1050;background:var(--black);display:flex;flex-direction:column;
  justify-content:center;padding:0 var(--gutter);transform:translateY(-100%);visibility:hidden;
  transition:transform .7s var(--ease),visibility 0s .7s}
.menu-overlay.open{transform:translateY(0);visibility:visible;transition:transform .7s var(--ease),visibility 0s 0s}
.menu-overlay a{font-family:var(--serif);font-size:clamp(34px,8vw,64px);color:var(--white);padding:9px 0;
  display:block;opacity:.85;transition:.4s;border-bottom:1px solid var(--line-soft)}
.menu-overlay a:hover{color:var(--gold);padding-left:14px}
.menu-foot{margin-top:46px;display:flex;gap:28px;flex-wrap:wrap;color:var(--muted);font-size:12px;letter-spacing:.1em}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:14px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--white);padding:17px 34px;border:1px solid var(--line);border-radius:44px;position:relative;
  overflow:hidden;transition:color .5s var(--ease);background:transparent}
.btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .55s var(--ease);z-index:-1}
.btn:hover{color:var(--black);border-color:var(--gold)}
.btn:hover::before{transform:translateY(0)}
.btn .ar{transition:transform .5s var(--ease)}
.btn:hover .ar{transform:translateX(5px)}
.btn.gold{background:var(--gold);color:var(--black);border-color:var(--gold)}
.btn.gold::before{background:var(--gold-bright)}
.link-arrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);transition:gap .4s}
.link-arrow:hover{gap:18px;color:var(--gold-bright)}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{height:100vh;min-height:640px;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.hero video,.hero .hero-fallback{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(7,7,9,.62) 0%,rgba(7,7,9,.18) 26%,rgba(7,7,9,.5) 64%,rgba(7,7,9,.97) 100%),
  linear-gradient(75deg,rgba(7,7,9,.62) 0%,rgba(7,7,9,.15) 42%,transparent 65%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,8vh,110px)}
.hero h1{font-size:clamp(46px,9vw,160px);letter-spacing:0}
.hero h1 .it{font-style:italic;color:var(--gold-bright)}
.hero .sub{max-width:560px;margin-top:26px;color:var(--silver);font-size:clamp(14px,1.3vw,18px)}
.hero-meta{position:absolute;z-index:2;bottom:clamp(48px,8vh,110px);right:var(--gutter);text-align:right;display:none}
.scroll-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;
  align-items:center;gap:10px;color:var(--muted);font-size:10px;letter-spacing:.3em;text-transform:uppercase}
.scroll-cue .bar{width:1px;height:50px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.scroll-cue .bar::after{content:'';position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-bright);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{top:-50%}100%{top:100%}}

/* ============================================================
   REVEAL ANIMATIONS (set by JS / CSS fallback)
   ============================================================ */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.12s}.reveal-d2{transition-delay:.24s}.reveal-d3{transition-delay:.36s}.reveal-d4{transition-delay:.48s}
.line-mask{overflow:hidden;display:block}
.line-mask>span{display:block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
.line-mask.in>span{transform:none}
.char-rise{opacity:0;transform:translateY(40px) rotate(3deg)}

/* ============================================================
   SPLIT / EDITORIAL BLOCKS
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,110px);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.bignum{font-family:var(--serif);font-size:clamp(60px,9vw,150px);color:var(--panel-2);line-height:.8;
  -webkit-text-stroke:1px var(--gold-deep);color:transparent}
.h-xl{font-size:clamp(38px,6vw,92px)}
.h-lg{font-size:clamp(30px,4.4vw,68px)}
.h-md{font-size:clamp(24px,3vw,42px)}
.home-statement{font-size:clamp(34px,4.4vw,74px);line-height:1.08;max-width:980px;margin-inline:auto}
.statement-wrap{max-width:1180px;margin-inline:auto}
.founder-statement{max-width:980px;margin-inline:auto}
.founder-statement h2{font-size:clamp(32px,4.2vw,68px);line-height:1.1}
.media-frame{position:relative;overflow:hidden;border-radius:3px}
.media-frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.media-frame:hover img{transform:scale(1.05)}
.media-tall{aspect-ratio:4/5}
.media-wide{aspect-ratio:16/10}

/* marquee */
.marquee{overflow:hidden;white-space:nowrap;border-block:1px solid var(--line-soft);padding-block:30px}
.marquee .track{display:inline-flex;gap:60px;animation:scrollx 38s linear infinite;will-change:transform}
.marquee span{font-family:var(--serif);font-size:clamp(28px,4vw,64px);color:var(--panel-2);
  -webkit-text-stroke:.6px var(--gold-deep);font-style:italic}
.marquee .dot{color:var(--gold)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============================================================
   WHAT WE CREATE / DIVISION CARDS
   ============================================================ */
.divisions{display:grid;gap:14px}
.div-card{position:relative;height:clamp(360px,52vw,560px);overflow:hidden;border-radius:3px;display:flex;align-items:flex-end;cursor:pointer}
.div-card video,.div-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform 1.6s var(--ease)}
.div-card::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(7,7,9,.15),rgba(7,7,9,.9))}
.div-card:hover video,.div-card:hover img{transform:scale(1.06)}
.div-card .dc-in{position:relative;z-index:2;padding:clamp(26px,3vw,52px);width:100%}
.div-card .dc-in h3{font-size:clamp(30px,3.6vw,60px);margin:10px 0 6px}
.div-card .dc-tag{color:var(--silver);max-width:38ch;opacity:0;transform:translateY(16px);transition:.6s var(--ease)}
.div-card:hover .dc-tag{opacity:1;transform:none}
.div-card .dc-n{position:absolute;top:clamp(22px,3vw,44px);right:clamp(22px,3vw,44px);z-index:2;font-family:var(--serif);
  font-size:18px;color:var(--gold);border:1px solid var(--line);width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center}
@media(min-width:900px){.divisions.three{grid-template-columns:repeat(3,1fr)}.divisions.three .div-card{height:clamp(440px,40vw,640px)}}
@media(min-width:1100px){.divisions.three:has(.div-card:nth-child(4)){grid-template-columns:repeat(4,1fr)}}

/* ============================================================
   PRODUCT GRID + CARDS
   ============================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,26px)}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cat-grid{grid-template-columns:1fr}}
.pcard{position:relative;display:block;overflow:hidden;background:var(--graphite);border-radius:3px;cursor:pointer}
.pcard .pc-media{position:relative;overflow:hidden;aspect-ratio:3/4}
.pcard .pc-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s var(--ease),filter 1.2s;filter:saturate(.92)}
.pcard:hover .pc-media img{transform:scale(1.08);filter:saturate(1.05)}
.pcard .pc-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(7,7,9,.85));opacity:.7;transition:opacity .6s}
.pcard:hover .pc-media::after{opacity:.95}
.pc-body{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(18px,1.8vw,28px);width:100%}
.pc-code{font-size:10.5px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}
.pc-name{font-family:var(--serif);font-size:clamp(21px,1.9vw,30px);margin-top:7px;line-height:1}
.pc-tag{color:var(--muted);font-size:12.5px;margin-top:7px;max-width:30ch;opacity:0;max-height:0;transition:.55s var(--ease)}
.pcard:hover .pc-tag{opacity:1;max-height:60px}
.pc-explore{position:absolute;top:18px;right:18px;z-index:2;display:flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-bright);
  opacity:0;transform:translateX(-8px);transition:.5s var(--ease)}
.pcard:hover .pc-explore{opacity:1;transform:none}
.pc-shine{position:absolute;inset:0;z-index:1;background:linear-gradient(115deg,transparent 40%,rgba(233,220,192,.13) 50%,transparent 60%);
  transform:translateX(-100%);transition:transform .9s var(--ease)}
.pcard:hover .pc-shine{transform:translateX(100%)}

/* filter bar */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.filter{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);padding:9px 20px;border:1px solid var(--line-soft);border-radius:30px;transition:.4s}
.filter:hover{color:var(--white);border-color:var(--line)}
.filter.active{background:var(--gold);color:var(--black);border-color:var(--gold)}

/* ============================================================
   PAGE HEADER (subpages)
   ============================================================ */
.phead{padding-top:clamp(140px,18vh,230px);padding-bottom:clamp(40px,6vw,90px);position:relative;overflow:hidden}
.phead .pbg{position:absolute;inset:0;z-index:-1;opacity:.32}
.phead .pbg img{width:100%;height:100%;object-fit:cover}
.phead::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(7,7,9,.6),var(--black))}
.phead h1{font-size:clamp(44px,8vw,128px);margin-top:18px}
.phead .psub{max-width:60ch;margin-top:22px;color:var(--silver)}

/* breadcrumb */
.crumb{display:flex;gap:12px;align-items:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.crumb a:hover{color:var(--gold)}
.crumb .sep{color:var(--gold-deep)}

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.p-hero{height:100vh;min-height:600px;position:relative;overflow:hidden;display:flex;align-items:center}
.p-hero .ph-img{position:absolute;inset:0;z-index:0}
.p-hero .ph-img img{width:100%;height:100%;object-fit:cover;transition:filter 1s var(--ease),transform 6s ease-out}
.p-hero::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(7,7,9,.82),rgba(7,7,9,.2) 60%,rgba(7,7,9,.5))}
.p-hero .wrap{position:relative;z-index:2;width:100%}
.p-hero h1{font-size:clamp(44px,7.5vw,120px);margin:12px 0}
.float{animation:float 7s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.psec{padding-block:clamp(64px,9vw,130px)}
.psec-h{display:flex;align-items:baseline;gap:18px;margin-bottom:48px}
.psec-h .n{font-family:var(--serif);font-size:18px;color:var(--gold);-webkit-text-stroke:0}
.psec-h h2{font-size:clamp(28px,3.6vw,54px)}

/* gallery */
.pgallery{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;grid-auto-rows:minmax(120px,auto)}
.pgallery .g{overflow:hidden;border-radius:2px}
.pgallery .g img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.pgallery .g:hover img{transform:scale(1.06)}
.g.big{grid-column:span 7;grid-row:span 2}
.g.tall{grid-column:span 5;grid-row:span 2}
.g.wide{grid-column:span 5}
.g.sq{grid-column:span 5}
@media(max-width:760px){.pgallery{grid-template-columns:1fr}.g.big,.g.tall,.g.wide,.g.sq{grid-column:span 1;grid-row:auto;aspect-ratio:4/3}}

/* selectors (material/finish) */
.selector{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center}
.swatches{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.swatch{display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer}
.swatch .dot{width:54px;height:54px;border-radius:50%;border:1px solid var(--line-soft);position:relative;transition:.4s var(--ease)}
.swatch .dot::after{content:'';position:absolute;inset:-6px;border:1px solid transparent;border-radius:50%;transition:.4s}
.swatch.active .dot::after{border-color:var(--gold)}
.swatch span{font-size:10px;letter-spacing:.1em;color:var(--muted);text-align:center;max-width:80px;transition:.4s}
.swatch.active span{color:var(--gold-bright)}
.sel-preview{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/5}
.sel-preview img{width:100%;height:100%;object-fit:cover;transition:filter 1s var(--ease)}
.sel-readout{font-family:var(--serif);font-size:clamp(26px,3vw,44px);margin-top:6px}

/* engineering diagram */
.eng-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,70px);align-items:center}
.eng-svg{width:100%;height:auto;background:var(--graphite);border:1px solid var(--line-soft);border-radius:4px}
.eng-list{list-style:none;display:grid;gap:2px}
.eng-list li{display:flex;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid var(--line-soft)}
.eng-list li b{font-weight:400;color:var(--white)}
.eng-list li span{color:var(--muted);text-align:right}

/* video sections */
.pvideo{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:16/9;background:var(--graphite)}
.pvideo video{width:100%;height:100%;object-fit:cover}
.pvideo .vlabel{position:absolute;left:26px;bottom:24px;z-index:2;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-bright)}
.pvideo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(7,7,9,.7))}

/* specs */
.spectable{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(30px,6vw,90px)}
@media(max-width:700px){.spectable{grid-template-columns:1fr}}
.spectable .row{display:flex;justify-content:space-between;gap:20px;padding:18px 0;border-bottom:1px solid var(--line-soft)}
.spectable .row b{font-weight:400;color:var(--silver);font-size:13px;letter-spacing:.04em}
.spectable .row span{color:var(--white);font-family:var(--serif);font-size:18px}

/* downloads */
.downloads{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:820px){.downloads{grid-template-columns:repeat(2,1fr)}}
.dl{border:1px solid var(--line-soft);border-radius:4px;padding:26px 22px;transition:.5s var(--ease);position:relative;overflow:hidden}
.dl:hover{border-color:var(--gold);background:var(--graphite)}
.dl .dl-ic{color:var(--gold);margin-bottom:18px}
.dl b{display:block;font-family:var(--serif);font-size:21px;font-weight:400}
.dl small{color:var(--muted);font-size:11.5px;letter-spacing:.08em}

/* similar carousel */
.carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:18px;scrollbar-width:none}
.carousel::-webkit-scrollbar{display:none}
.carousel .pcard{min-width:min(360px,72vw);scroll-snap-align:start}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi{position:relative;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center}
.testi .t-item{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;transform:translateY(30px) scale(.98);transition:.9s var(--ease);padding-inline:var(--gutter)}
.testi .t-item.show{opacity:1;transform:none}
.t-quote{font-family:var(--serif);font-size:clamp(24px,3.4vw,50px);line-height:1.28;max-width:20ch;font-style:italic;font-weight:300}
.t-card{max-width:880px;margin-inline:auto;background:rgba(255,255,255,.035);border:1px solid var(--line-soft);
  backdrop-filter:blur(14px);border-radius:6px;padding:clamp(36px,5vw,72px)}
.t-by{margin-top:30px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.t-role{color:var(--muted);font-size:12px;margin-top:6px;letter-spacing:.05em}
.t-nav{display:flex;gap:10px;justify-content:center;margin-top:42px}
.t-dot{width:30px;height:2px;background:var(--grey);cursor:pointer;transition:.4s}
.t-dot.active{background:var(--gold)}

/* ============================================================
   STATS / GLOBAL
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:44px}}
.stat .num{font-family:var(--serif);font-size:clamp(46px,6vw,92px);color:var(--gold-bright);line-height:1}
.stat .lab{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.globe-wrap{position:relative;display:flex;justify-content:center}
.city-list{columns:2;gap:40px;color:var(--silver)}
.city-list li{list-style:none;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14px;letter-spacing:.05em;display:flex;justify-content:space-between}
.city-list li i{font-style:normal;color:var(--muted);font-size:11px}

/* ============================================================
   FORM
   ============================================================ */
.form{display:grid;grid-template-columns:1fr 1fr;gap:26px 34px}
.form .full{grid-column:1/-1}
@media(max-width:720px){.form{grid-template-columns:1fr}}
.field{position:relative}
.field label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:11px}
.field input,.field select,.field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line-soft);
  color:var(--white);font-family:var(--sans);font-size:16px;font-weight:300;padding:10px 0;transition:border-color .5s}
.field textarea{resize:vertical;min-height:90px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-bottom-color:var(--gold)}
.field select option{background:var(--graphite)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.upload{border:1px dashed var(--line);border-radius:5px;padding:24px;text-align:center;color:var(--muted);
  cursor:pointer;transition:.4s;font-size:13px;letter-spacing:.05em}
.upload:hover{border-color:var(--gold);color:var(--gold-bright)}

/* ============================================================
   FOOTER
   ============================================================ */
footer.foot{background:var(--graphite);border-top:1px solid var(--line-soft);padding-top:clamp(64px,8vw,120px);position:relative;overflow:hidden}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:50px}
@media(max-width:860px){.foot-top{grid-template-columns:1fr;gap:48px}}
.foot h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.foot-links a{display:block;color:var(--silver);padding:8px 0;font-size:14px;transition:.4s;border-bottom:1px solid transparent}
.foot-links a:hover{color:var(--gold);padding-left:8px}
.foot-cta h3{font-size:clamp(30px,4.4vw,62px);max-width:14ch;line-height:1.04}
.foot-bottom{margin-top:clamp(50px,7vw,90px);padding:30px 0;border-top:1px solid var(--line-soft);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;color:var(--muted-2);font-size:11.5px;letter-spacing:.12em}
.foot-mono{font-family:var(--serif);font-size:clamp(80px,20vw,280px);line-height:.7;color:transparent;
  -webkit-text-stroke:1px rgba(201,168,106,.13);text-align:center;margin-top:40px;letter-spacing:.05em;user-select:none}

/* ============================================================
   PAGE TRANSITION
   ============================================================ */
#pt{position:fixed;inset:0;z-index:8000;background:var(--black);transform:translateY(100%);pointer-events:none;
  display:flex;align-items:center;justify-content:center}
#pt .pt-mark{font-family:var(--serif);font-size:60px;color:var(--gold);opacity:0;letter-spacing:.2em}

/* canvases */
.bg-canvas{position:absolute;inset:0;z-index:0;width:100%;height:100%}

/* experience room */
#xp-canvas{position:fixed;inset:0;z-index:0}
.xp-ui{position:fixed;z-index:5;pointer-events:none}
.xp-title{left:var(--gutter);bottom:48px;max-width:46vw}
.xp-title h2{font-size:clamp(30px,5vw,72px)}
.xp-hint{right:var(--gutter);bottom:54px;text-align:right;color:var(--muted);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.xp-tabs{top:clamp(86px,11vh,120px);left:50%;transform:translateX(-50%);display:flex;flex-direction:row;align-items:center;gap:clamp(20px,3vw,40px);pointer-events:auto}
.xp-tab{font-family:var(--serif);font-size:clamp(15px,1.5vw,21px);color:var(--muted);cursor:pointer;transition:.4s;letter-spacing:.04em;position:relative;padding-bottom:9px;white-space:nowrap}
.xp-tab.active,.xp-tab:hover{color:var(--gold-bright)}
.xp-tab.active::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold-bright)}
@media(max-width:640px){.xp-tabs{gap:16px;top:78px}.xp-title{max-width:88vw}.xp-hint{display:none}}

/* utility */
.center{text-align:center}
.mt-s{margin-top:18px}.mt-m{margin-top:32px}.mt-l{margin-top:60px}
.maxw-60{max-width:60ch}.maxw-50{max-width:50ch}.mx-auto{margin-inline:auto}
.gold-rule{width:60px;height:1px;background:var(--gold);margin:26px 0}
.center .gold-rule{margin-inline:auto}
.tag-row{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--silver);border:1px solid var(--line-soft);padding:7px 15px;border-radius:30px}
.noscroll{overflow:hidden}
.hide{display:none!important}

/* ============================================================
   BEIGE SURFACE — for sea-view / warm ceiling imagery
   ============================================================ */
.sec-beige{background:var(--beige);color:var(--ink)}
.sec-beige .kicker{color:#8a7d63}
.sec-beige h1,.sec-beige h2,.sec-beige h3{color:var(--ink)}
.sec-beige .lead{color:#4b4438}
.sec-beige .fade-text{color:#6a6151}
.sec-beige .bignum{color:transparent;-webkit-text-stroke:1px #b6a888}
.sec-beige .gold-rule{background:#b6a888}
.sec-beige .chip{color:#5b5343;border-color:rgba(28,24,19,.18)}
.sec-beige .btn{color:var(--ink);border-color:rgba(28,24,19,.28)}
.sec-beige .btn::before{background:var(--ink)}
.sec-beige .btn:hover{color:var(--beige)}
.sec-beige .link-arrow{color:#6a5d44}
.sec-beige .link-arrow:hover{color:var(--ink)}
.seaview-frame{background:var(--beige);padding:clamp(16px,2.2vw,40px);border-radius:4px}
.seaview-frame img{border-radius:2px}

/* brand wordmark only */
.brand .bt b{letter-spacing:.22em}
.cursor,.cursor-ring{display:none!important}

/* ============================================================
   LUXURY FOOTER
   ============================================================ */
.lfoot{position:relative;overflow:hidden;background:#0A0A0A;border-top:1px solid var(--line-soft);
  padding:clamp(70px,9vw,130px) 0 0;isolation:isolate}
.lfoot .wrap{position:relative;z-index:2}
.lf-amb{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.8}
.lf-amb .blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.45;will-change:transform}
.lf-amb .blob1{width:46vw;height:46vw;left:-12%;top:-18%;background:radial-gradient(circle,rgba(86,92,120,.40),transparent 64%);animation:lfDrift1 24s ease-in-out infinite}
.lf-amb .blob2{width:40vw;height:40vw;right:-8%;bottom:-18%;background:radial-gradient(circle,rgba(168,146,104,.24),transparent 64%);animation:lfDrift2 30s ease-in-out infinite}
.lf-amb .blob3{width:30vw;height:30vw;left:42%;top:40%;background:radial-gradient(circle,rgba(120,124,140,.16),transparent 66%);animation:lfDrift1 36s ease-in-out infinite reverse}
@keyframes lfDrift1{0%,100%{transform:translate(-8%,0) scale(1)}50%{transform:translate(18%,-12%) scale(1.08)}}
@keyframes lfDrift2{0%,100%{transform:translate(8%,8%) scale(1)}50%{transform:translate(-14%,-6%) scale(1.1)}}
.lf-glow{position:absolute;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:1;opacity:0;
  transform:translate(-50%,-50%);transition:opacity .6s ease;mix-blend-mode:screen;
  background:radial-gradient(circle,rgba(236,230,218,.10),rgba(236,230,218,.03) 40%,transparent 62%)}
.lfoot::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:linear-gradient(180deg,transparent,rgba(255,255,255,.015));}

.lf-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.15fr;gap:clamp(34px,4vw,70px)}
@media(max-width:980px){.lf-grid{grid-template-columns:1fr 1fr;gap:46px}}
@media(max-width:560px){.lf-grid{grid-template-columns:1fr;gap:42px}}
.lf-col h5{font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:24px;font-weight:400}
.lf-brandmark{font-family:var(--serif);font-size:clamp(44px,5vw,62px);font-weight:500;letter-spacing:.18em;color:#fff;display:inline-block;position:relative;line-height:1}
.lf-brandmark::after{content:'';position:absolute;left:-18%;top:50%;width:140%;height:160%;transform:translateY(-50%);z-index:-1;
  background:radial-gradient(ellipse,rgba(236,230,218,.16),transparent 60%);opacity:.7;transition:opacity .6s}
.lf-brandmark:hover::after{opacity:1}
.lf-studio{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--champagne);margin-top:14px}
.lf-desc{color:var(--silver);margin-top:20px;max-width:34ch;font-size:14px;line-height:1.7}
.lf-tag{color:var(--muted);margin-top:14px;font-style:italic;font-family:var(--serif);font-size:19px}
.lf-link{display:block;width:fit-content;color:var(--silver);padding:8px 0;font-size:14px;position:relative;letter-spacing:.02em;
  transition:transform .4s var(--ease),color .4s}
.lf-link::after{content:'';position:absolute;left:0;bottom:4px;height:1px;width:0;background:linear-gradient(90deg,#fff,rgba(255,255,255,.25));transition:width .5s var(--ease)}
.lf-link:hover{transform:translateY(-2px);color:#fff}
.lf-link:hover::after{width:100%}
.lf-socials{display:flex;flex-wrap:wrap;gap:11px;margin-bottom:26px}
.lf-soc{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.04);border:1px solid var(--line-soft);backdrop-filter:blur(8px);color:var(--silver);
  transition:transform .45s var(--ease),color .45s,background .45s,box-shadow .45s,border-color .45s}
.lf-soc svg{width:17px;height:17px}
.lf-soc:hover{transform:translateY(-5px);color:#fff;background:rgba(255,255,255,.10);border-color:rgba(236,230,218,.4);box-shadow:0 12px 34px rgba(236,230,218,.16)}
.lf-contact a{display:block;color:var(--silver);font-size:13.5px;padding:5px 0;transition:color .4s}
.lf-contact a:hover{color:#fff}
.lf-legal{display:flex;flex-wrap:wrap;gap:12px 32px;padding:30px 0;margin-top:clamp(46px,6vw,86px);border-top:1px solid var(--line-soft)}
.lf-legal a{font-size:12px;letter-spacing:.08em;color:var(--muted);position:relative;transition:color .4s,opacity .4s}
.lf-legal a::after{content:'';position:absolute;left:0;bottom:-3px;height:1px;width:0;background:var(--champagne);transition:width .45s var(--ease)}
.lf-legal a:hover{color:var(--champagne)}
.lf-legal a:hover::after{width:100%}
.lf-mono{font-family:var(--serif);font-size:clamp(90px,22vw,250px);line-height:.7;color:transparent;
  -webkit-text-stroke:1px rgba(236,230,218,.08);text-align:center;margin-top:24px;letter-spacing:.06em;user-select:none}
.lf-bottom{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;padding:26px 0;
  border-top:1px solid var(--line-soft);color:var(--muted-2);font-size:11px;letter-spacing:.16em}
.lf-bottom .c{text-align:center;color:var(--muted);font-style:italic;font-family:var(--serif);font-size:14px;letter-spacing:.05em}
.lf-bottom .r{text-align:right}
@media(max-width:760px){.lf-bottom{grid-template-columns:1fr;text-align:center;gap:10px}.lf-bottom .r{text-align:center}}
@media(prefers-reduced-motion:reduce){.lf-amb .blob{animation:none}}

/* responsive nav */
@media(max-width:1024px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
}
@media(max-width:760px){
  .split{grid-template-columns:1fr}
  .split.rev{direction:ltr}
  .selector,.eng-grid,.foot-cta{grid-template-columns:1fr!important}
  .selector,.eng-grid{display:block}
  .sel-preview{margin-top:30px;max-width:420px}
  .stats{margin-top:10px}
}

/* ============================================================
   TRUSTED BY — client logo wall
   ============================================================ */
#trusted .logo-wall{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:4px;overflow:hidden}
.trust-cat{margin-bottom:clamp(30px,3.5vw,56px)}
.trust-cat h4{text-align:center;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;font-weight:400}
.logo-chip{position:relative;display:flex;align-items:center;justify-content:center;min-height:120px;background:var(--black);padding:22px;transition:background .3s var(--ease)}
.logo-chip img{height:40px;width:auto;max-width:82%;object-fit:contain;filter:brightness(0) invert(1) opacity(.6);transition:filter .3s var(--ease),transform .3s var(--ease)}
.logo-chip:hover{background:var(--graphite)}
.logo-chip:hover img{filter:none;opacity:1;transform:scale(1.07)}
.logo-chip .logo-text{display:none;font-family:var(--serif);font-size:clamp(15px,1.3vw,19px);letter-spacing:.02em;color:#86837c;text-align:center;line-height:1.2;transition:color .3s var(--ease),transform .3s var(--ease)}
.logo-chip.noimg .logo-text{display:block}
.logo-chip.noimg:hover .logo-text{color:var(--white);transform:scale(1.06)}
@media(max-width:900px){#trusted .logo-wall{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){#trusted .logo-wall{grid-template-columns:repeat(2,1fr)}.logo-chip{min-height:100px;padding:16px}}

/* ============================================================
   v3 FIXES — footer cleanup + trusted-by no-empty-cells
   ============================================================ */
.lf-mono,.foot-mono,.lf-glow{display:none!important}
.lfoot{padding-bottom:0}
.lf-bottom{grid-template-columns:1fr auto 1.2fr}
.lf-bottom .r{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:0}
.lf-bottom .r a{color:var(--muted-2);transition:color .4s}
.lf-bottom .r a:hover{color:var(--champagne)}
.lf-bottom .r i{color:var(--gold-deep);font-style:normal;padding:0 7px}
@media(max-width:760px){.lf-bottom .r{justify-content:center}}
/* footer columns slightly tighter / more luxury */
.lf-link{padding:6px 0;font-size:13.5px}
.lf-col h5{margin-bottom:18px}

/* Trusted-by: centered flex, uniform chips, NO empty cells, always-visible wordmark */
#trusted .logo-wall{display:flex!important;flex-wrap:wrap;justify-content:center;gap:10px;background:none!important;border:none!important;border-radius:0!important;overflow:visible!important}
#trusted .logo-chip{flex:0 1 calc(20% - 10px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:11px;border:1px solid var(--line-soft);border-radius:4px;min-height:122px;padding:18px 14px;background:var(--graphite);transition:background .3s var(--ease)}
#trusted .logo-chip .logo-img{display:block;height:38px;width:auto;max-width:80%;object-fit:contain;filter:grayscale(1) brightness(1.9) contrast(.9) opacity(.72);transition:filter .35s var(--ease),transform .35s var(--ease)}
#trusted .logo-chip:hover .logo-img{filter:grayscale(0) brightness(1) contrast(1) opacity(1);transform:scale(1.06)}
#trusted .logo-chip .logo-text{display:block;font-family:var(--serif);font-size:12.5px;letter-spacing:.02em;color:#8f8c84;text-align:center;line-height:1.15;transition:color .3s var(--ease)}
#trusted .logo-chip:hover{background:#14141a}
#trusted .logo-chip:hover .logo-text{color:var(--white)}
#trusted .logo-chip.noimg .logo-text{font-size:clamp(14px,1.2vw,17px)}
@media(max-width:900px){#trusted .logo-chip{flex:0 1 calc(33.333% - 10px)}}
@media(max-width:560px){#trusted .logo-chip{flex:0 1 calc(50% - 10px);min-height:104px}}

/* ============================================================
   ATELIER TEAM
   ============================================================ */
#teamGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,30px);max-width:980px;margin-inline:auto}
#cofounderGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(20px,2.4vw,40px);max-width:1060px;margin-inline:auto}
@media(max-width:720px){#cofounderGrid{grid-template-columns:1fr;max-width:360px}}
.lead-card .team-photo{aspect-ratio:4/5}
.lead-card .team-name{font-size:clamp(19px,1.7vw,25px)}
.team-ph{display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#1b1b20,#0e0e11)}
.team-ph span{font-family:var(--serif);font-size:30px;letter-spacing:.24em;color:var(--muted);opacity:.45}
.team-card{text-align:center}
.team-photo{position:relative;overflow:hidden;border-radius:4px;aspect-ratio:3/4;background:var(--graphite);border:1px solid var(--line-soft)}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(.45) brightness(.96);transition:transform 1.2s var(--ease),filter .6s var(--ease)}
.team-card:hover .team-photo img{transform:scale(1.05);filter:grayscale(0) brightness(1.03)}
.team-name{font-size:clamp(17px,1.5vw,22px);margin-top:14px;line-height:1.1}
.team-role{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:6px}
