/* ============================
   components.css — reusable + scene-specific UI
   Loads after tokens.css
   ============================ */

/* ============================
   PERSISTENT TOP BAR
   ============================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:22px 36px;display:flex;justify-content:space-between;align-items:center;gap:24px;
  background:rgba(250,247,240,0.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid transparent;
  transition:border-color .3s, padding .3s, opacity .4s, transform .4s;
}
.topbar.compact{padding:14px 36px;border-color:rgba(217,209,189,0.5)}
.topbar.hidden-on-welcome{opacity:0;pointer-events:none;transform:translateY(-12px)}
body.welcome-mode{background:#050B16}
.tb-left{display:flex;align-items:center;gap:22px;min-width:0;flex:1}
.tb-logo{
  width:24px;height:24px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #FFE6A0 0%, var(--gold-light) 50%, var(--gold-2) 100%);
  box-shadow:0 1px 6px rgba(200,147,42,0.3);
  flex-shrink:0;cursor:pointer;transition:transform .3s;
}
.tb-logo:hover{transform:scale(1.1)}
.tb-brand{
  font-family:'Anuphan','Inter',sans-serif;
  font-size:0.86rem;font-weight:500;color:var(--ink);
  white-space:nowrap;letter-spacing:-0.005em;
}
.tb-brand em{color:var(--navy);font-style:normal;font-weight:700}
.tb-crumb{
  font-family:var(--font-mono);font-size:0.7rem;
  color:var(--muted);letter-spacing:0.06em;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  text-transform:uppercase;
}
.tb-crumb .sep{color:var(--muted-2);margin:0 10px;opacity:0.6}
.tb-crumb .here{color:var(--navy);font-weight:700}
.tb-right{display:flex;align-items:center;gap:16px}
.tb-back{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:0.7rem;
  color:var(--muted);padding:7px 12px;border-radius:3px;
  letter-spacing:0.08em;text-transform:uppercase;
  transition:color .2s, background .2s;
}
.tb-back:hover{color:var(--navy);background:rgba(217,209,189,0.3)}
.tb-back:active{transform:translateX(-2px)}
.tb-login{
  font-family:var(--font-mono);font-size:0.7rem;
  color:var(--ink);padding:8px 14px;border:1px solid var(--border-2);
  border-radius:3px;letter-spacing:0.08em;text-transform:uppercase;
  transition:all .2s;
}
.tb-login:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

@media(max-width:720px){
  .topbar{padding:14px 18px;gap:10px}
  .tb-brand{display:none}
  .tb-crumb{font-size:0.62rem}
  .tb-back{padding:10px 12px;min-height:40px}
  .tb-login{padding:10px 12px;font-size:0.62rem;min-height:40px}
  .tb-logo{width:30px;height:30px}
}

/* ============================
   SCENES — base layout + reveal animation
   ============================ */
.scene{
  display:none;min-height:100vh;
  padding:120px 56px 80px;
  flex-direction:column;align-items:center;justify-content:center;
  position:relative;z-index:2;
}
.scene.active{display:flex}
@media(max-width:720px){.scene{padding:90px 22px 60px}}

.scene.active .reveal{
  opacity:0;transform:translateY(14px);
  animation:revealUp 700ms cubic-bezier(.2,.7,.3,1) forwards;
}
.scene.active .reveal[data-delay="1"]{animation-delay:80ms}
.scene.active .reveal[data-delay="2"]{animation-delay:180ms}
.scene.active .reveal[data-delay="3"]{animation-delay:320ms}
.scene.active .reveal[data-delay="4"]{animation-delay:480ms}
.scene.active .reveal[data-delay="5"]{animation-delay:640ms}
.scene.active .reveal[data-delay="6"]{animation-delay:800ms}
@keyframes revealUp{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}

.sc-inner{width:100%;max-width:1100px;display:flex;flex-direction:column;align-items:center;gap:28px;text-align:center}
.sc-inner.narrow{max-width:680px}
.sc-inner.wide{max-width:1280px}

/* ============================
   CTA — refined, less buttony
   ============================ */
.cta-row{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;align-items:center;margin-top:8px}
.cta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-display);
  font-size:1rem;font-weight:500;color:var(--ink);
  padding:18px 0;letter-spacing:-0.01em;
  position:relative;transition:color .25s, gap .25s;
}
.cta::after{
  content:'';position:absolute;left:0;right:0;bottom:8px;height:1px;
  background:currentColor;transform:scaleX(0.4);transform-origin:left;
  transition:transform .35s cubic-bezier(.2,.7,.3,1);
}
.cta:hover{color:var(--navy);gap:18px}
.cta:hover::after{transform:scaleX(1)}
.cta .ar{font-family:var(--font-mono);font-weight:400;font-size:1.1em;transition:transform .25s}
.cta:hover .ar{transform:translateX(3px)}
.cta.primary{
  background:var(--ink);color:var(--paper);
  padding:18px 36px;border-radius:3px;letter-spacing:0;
  font-weight:500;
}
.cta.primary::after{display:none}
.cta.primary:hover{background:var(--navy);color:var(--paper)}
.cta.gold{
  background:var(--gold);color:var(--ink);
  padding:18px 36px;border-radius:3px;font-weight:600;
}
.cta.gold::after{display:none}
.cta.gold:hover{background:var(--gold-2);color:var(--paper)}
.cta.ghost{
  font-weight:400;color:var(--muted);font-size:0.9rem;padding:14px 0;
}
.cta.ghost::after{background:var(--muted)}

/* ============================
   SCENE · WELCOME — Split: text-left / slideshow-right
   ============================ */
.welcome{
  display:none;height:100vh;
  background:#050B16;color:var(--paper);
  padding:0;position:relative;overflow:hidden;
}
.welcome.active{
  display:grid;
  grid-template-columns: 1.4fr minmax(400px, 0.9fr);
  animation:scIn 800ms cubic-bezier(.2,.7,.3,1);
}
@keyframes scIn{from{opacity:0}to{opacity:1}}
@media(max-width:900px){
  .welcome{height:auto;min-height:100vh}
  .welcome.active{grid-template-columns:1fr;grid-template-rows:50vh auto}
}

.w-overlay{
  position:relative;
  display:flex;flex-direction:column;
  background:radial-gradient(120% 100% at 75% 0%, #11305A 0%, var(--ink) 55%, #050B16 100%);
  overflow:hidden;
}
.w-overlay::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:0.05;
  background-image:
    linear-gradient(rgba(233,185,73,0.6) 1px, transparent 1px),
    linear-gradient(90deg, rgba(233,185,73,0.6) 1px, transparent 1px);
  background-size:84px 84px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%, black 30%, transparent 100%);
}
.w-overlay::after{
  content:'';position:absolute;top:0;right:-10%;width:70%;height:55%;pointer-events:none;
  background:radial-gradient(ellipse 70% 70% at 100% 0%, rgba(233,185,73,0.18) 0%, transparent 65%);
}
.w-frame{
  position:relative;z-index:2;
  display:grid;grid-template-rows:auto 1fr auto auto auto;
  flex:1;padding:6vh 56px 4vh;row-gap:24px;min-height:0;
}
@media(max-width:1200px){.w-frame{padding:5vh 44px 3.5vh;row-gap:20px}}
@media(max-width:900px){.w-frame{padding:60px 28px 30px;row-gap:18px}}
@media(max-width:520px){.w-frame{padding:50px 22px 26px;row-gap:16px}}

.w-stage{
  position:relative;background:#050B16;
  display:grid;grid-template-rows:1fr auto;
  overflow:hidden;
}

.w-stage-hero{
  position:relative;overflow:hidden;
  perspective:1600px;perspective-origin:50% 50%;
}
.w-slide{
  position:absolute;inset:0;
  opacity:0;transform-style:preserve-3d;
  transform: rotateY(28deg) translateX(8%) translateZ(-180px) scale(1.1);
  transition: opacity 1.5s cubic-bezier(.4,0,.2,1), transform 1.8s cubic-bezier(.4,0,.2,1);
  will-change: transform, opacity;
}
.w-slide.prev{
  opacity:0;
  transform: rotateY(-28deg) translateX(-8%) translateZ(-180px) scale(0.94);
}
.w-slide.active{
  opacity:1;
  transform: rotateY(0) translateX(0) translateZ(0) scale(1);
}
.w-slide img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(0.95) saturate(1.05);
}
.w-slide.active img{
  animation: kenBurns 11s ease-out forwards;
  transform-origin:50% 50%;
}
@keyframes kenBurns{
  from { transform: scale(1.04) translate3d(0,0,0); }
  to   { transform: scale(1.16) translate3d(-1.5%, -1%, 0); }
}
.w-veil{
  position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(to top, rgba(5,11,22,0.78) 0%, transparent 35%);
}

.w-thumbs{
  position:relative;z-index:3;
  display:flex;gap:10px;
  padding:18px 36px 22px;
  background:#050B16;
  border-top:1px solid rgba(244,239,226,0.06);
  overflow-x:auto;
  scrollbar-width:thin;
}
.w-thumbs::-webkit-scrollbar{height:4px}
.w-thumbs::-webkit-scrollbar-thumb{background:rgba(244,239,226,0.15);border-radius:2px}
.w-thumb{
  position:relative;flex:0 0 110px;aspect-ratio:16/10;
  border-radius:3px;overflow:hidden;cursor:pointer;
  background:none;padding:0;font:inherit;text-align:left;
  border:1px solid rgba(244,239,226,0.10);
  opacity:0.5;
  transition:opacity .35s, transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s, border-color .35s;
}
.w-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.w-thumb::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.55) 0%, transparent 60%);
  pointer-events:none;
}
.w-thumb:hover{opacity:0.88;transform:translateY(-3px)}
.w-thumb:focus-visible{outline:2px solid var(--gold-light);outline-offset:2px}
.w-thumb.active{
  opacity:1;
  border-color:rgba(233,185,73,0.85);
  box-shadow:0 6px 18px rgba(0,0,0,0.5), 0 0 0 1px rgba(233,185,73,0.45);
  transform:translateY(-3px);
}
@media(max-width:900px){.w-thumb{flex:0 0 90px}}
.w-thumb-num{
  position:absolute;left:7px;top:5px;z-index:2;
  font-family:var(--font-mono);font-size:0.55rem;font-weight:700;
  letter-spacing:0.14em;color:rgba(244,239,226,0.85);
  text-shadow:0 1px 2px rgba(0,0,0,0.7);
}
.w-thumb.active .w-thumb-num{color:var(--gold-light)}
.w-thumb-type{
  position:absolute;right:6px;bottom:6px;z-index:2;
  font-family:var(--font-mono);font-size:0.5rem;font-weight:700;
  letter-spacing:0.16em;color:#FAF7F0;text-transform:uppercase;
  padding:2px 6px;border-radius:2px;
  background:rgba(0,0,0,0.55);
  text-shadow:0 1px 2px rgba(0,0,0,0.6);
}
.w-thumb-type.t-built{background:rgba(15,46,95,0.85);color:#FAF7F0}
.w-thumb-type.t-3d{background:rgba(155,111,28,0.88);color:#FBF1D8}

@media(max-width:1200px){.w-thumbs{padding:42px 12px 24px 8px;gap:8px}}
@media(max-width:900px){
  .w-thumbs{padding:18px 12px;gap:8px}
  .w-thumbs-label{display:none}
}
.w-side{display:flex;align-items:flex-start;justify-content:flex-start;flex-shrink:0}
.w-eyebrow{
  font-family:var(--font-mono);font-size:0.64rem;font-weight:500;
  letter-spacing:0.2em;color:rgba(244,239,226,0.5);text-transform:uppercase;
  line-height:1.5;
}

.w-main{
  align-self:center;
  display:flex;flex-direction:column;gap:26px;max-width:560px;
}
@media(max-width:900px){.w-main{gap:22px}}

.w-brand-block{display:flex;flex-direction:column;gap:16px;position:relative}

.w-side-bot{
  font-family:var(--font-mono);font-size:0.62rem;
  letter-spacing:0.18em;color:rgba(244,239,226,0.4);text-transform:uppercase;line-height:1.7;
}
.w-side-bot strong{color:rgba(244,239,226,0.7);font-weight:400;letter-spacing:0.14em}

/* Service CTA cards — equal side-by-side */
.w-services{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;
  max-width:560px;list-style:none;padding:0;
}
@media(max-width:520px){.w-services{grid-template-columns:1fr;gap:10px}}
.ws-card{
  position:relative;padding:18px 18px 16px 22px;border-radius:4px;
  display:flex;flex-direction:column;gap:9px;
  background:#0A1628;
  border:1px solid rgba(244,239,226,0.14);
  overflow:hidden;cursor:pointer;
  font:inherit;color:inherit;text-align:left;width:100%;
  transition:transform .3s cubic-bezier(.2,.7,.3,1), border-color .3s, box-shadow .3s, background .3s;
}
.ws-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  transition:width .3s;
}
.ws-card.ws-primary{border-color:rgba(233,185,73,0.45)}
.ws-card.ws-primary::before{background:var(--gold)}
.ws-card.ws-secondary{border-color:rgba(120,160,225,0.42)}
.ws-card.ws-secondary::before{background:#7BA0DC}
.ws-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,0.5);background:#0F2040}
.ws-card:hover::before{width:6px}
.ws-card.ws-primary:hover{border-color:rgba(233,185,73,0.8)}
.ws-card.ws-secondary:hover{border-color:rgba(120,160,225,0.8)}
.ws-card:focus-visible{outline:2px solid var(--gold-light);outline-offset:2px}
.ws-mark{
  align-self:flex-start;
  font-family:var(--font-mono);font-size:0.58rem;font-weight:700;
  letter-spacing:0.2em;padding:4px 10px;border-radius:2px;
  text-transform:uppercase;
}
.ws-card.ws-primary .ws-mark{background:var(--gold);color:#241803}
.ws-card.ws-secondary .ws-mark{background:#A8C3F2;color:#0A1628}
.ws-name{
  font-family:var(--font-display);font-weight:500;
  font-size:1.05rem;color:#FAF7F0;letter-spacing:-0.005em;line-height:1.3;
}
.ws-name em{font-style:italic;font-weight:600}
.ws-card.ws-primary .ws-name em{color:var(--gold-light)}
.ws-card.ws-secondary .ws-name em{color:#C8DCFF}
.ws-detail{
  font-size:0.82rem;color:#FAF7F0;font-weight:300;
  line-height:1.5;opacity:0.92;
}
.ws-go{
  margin-top:6px;padding-top:8px;
  border-top:1px solid rgba(244,239,226,0.1);
  font-family:var(--font-mono);font-size:0.64rem;font-weight:700;
  letter-spacing:0.2em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
  transition:gap .25s, color .25s;
}
.ws-card.ws-primary .ws-go{color:var(--gold-light)}
.ws-card.ws-secondary .ws-go{color:#C8DCFF}
.ws-card:hover .ws-go{gap:14px}

.w-brand{
  font-family:'Anuphan','Inter',sans-serif;
  font-weight:200;font-size:clamp(2.4rem,5vw,4.4rem);
  line-height:1;letter-spacing:-0.045em;color:var(--paper);margin:0;
}
.w-brand em{
  color:var(--gold-light);font-style:italic;font-weight:300;
  letter-spacing:-0.03em;display:block;margin-top:2px;
}
.w-tagline{
  font-family:var(--font-mono);font-weight:500;
  font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--gold-light);margin:0;
}
.w-promise{
  font-family:var(--font-display);
  font-style:italic;font-weight:300;
  font-size:clamp(1rem,1.2vw,1.12rem);
  color:rgba(244,239,226,0.82);max-width:460px;line-height:1.55;letter-spacing:-0.005em;
  margin:0;
}
.w-promise em{color:var(--gold-light);font-style:italic;font-weight:400}

.w-divider{
  height:1px;width:160px;
  background:linear-gradient(90deg, var(--gold) 0%, transparent 100%);
  opacity:0.45;
}

.w-menu{display:flex;flex-direction:column;gap:0;max-width:560px}
.dr-wrap{border-top:1px solid rgba(244,239,226,0.10)}
.dr-wrap:last-child{border-bottom:1px solid rgba(244,239,226,0.10)}
.dr-wrap.open{border-top-color:rgba(233,185,73,0.45)}
.dr-wrap.open + .dr-wrap{border-top-color:rgba(233,185,73,0.45)}

.dr{
  display:grid;grid-template-columns:54px 1fr 28px;align-items:center;gap:20px;
  padding:18px 6px 18px 0;
  cursor:pointer;text-decoration:none;color:inherit;
  transition:padding-left .35s cubic-bezier(.2,.7,.3,1);
  position:relative;font-family:inherit;background:none;border:none;
  text-align:left;width:100%;
}
.dr:hover{padding-left:14px}
.dr-n{
  font-family:var(--font-mono);font-size:0.84rem;font-weight:400;
  color:rgba(233,185,73,0.65);letter-spacing:0.04em;
}
.dr-info{display:flex;flex-direction:column;gap:4px;min-width:0}
.dr-tag{
  font-family:var(--font-mono);font-size:0.58rem;
  letter-spacing:0.18em;color:rgba(244,239,226,0.42);text-transform:uppercase;
}
.dr-title{
  font-family:'Anuphan','Inter',sans-serif;
  font-size:clamp(1.1rem,1.5vw,1.35rem);font-weight:300;
  color:var(--paper);letter-spacing:-0.02em;line-height:1.15;
}
.dr-title em{color:var(--gold-light);font-style:italic;font-weight:400}
.dr-ar{
  font-family:var(--font-mono);font-size:1.05rem;
  color:var(--gold-light);transition:transform .35s cubic-bezier(.2,.7,.3,1);
  text-align:right;
}
.dr:hover .dr-ar{transform:translateY(2px)}
.dr-wrap.open .dr-ar{transform:rotate(180deg)}
.dr:focus-visible{outline:2px solid var(--gold-light);outline-offset:-2px;border-radius:3px;padding-left:14px}
.welcome a:focus-visible,.welcome button:focus-visible{outline-color:var(--gold-light)}

/* Inline login/form panel */
.dr-panel{
  max-height:0;overflow:hidden;opacity:0;
  display:flex;flex-direction:column;gap:10px;
  padding:0 6px 0 60px;
  transition:max-height .45s cubic-bezier(.4,0,.2,1), opacity .35s, padding .45s;
}
.dr-wrap.open .dr-panel{max-height:280px;opacity:1;padding:4px 6px 22px 60px}
.dr-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:520px){.dr-row{grid-template-columns:1fr}}
.dr-blurb{
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:0.88rem;color:rgba(244,239,226,0.78);
  line-height:1.5;letter-spacing:-0.005em;margin:0;
}
.dr-types{display:flex;flex-wrap:wrap;gap:6px;padding-bottom:2px}
.dr-type{
  font-family:'Anuphan','Inter',sans-serif;font-size:0.74rem;font-weight:400;
  letter-spacing:0;text-transform:none;
  padding:6px 11px;border-radius:14px;
  background:rgba(244,239,226,0.04);
  border:1px solid rgba(244,239,226,0.18);
  color:rgba(244,239,226,0.72);
  cursor:pointer;transition:all .2s;
}
.dr-type:hover{color:var(--paper);border-color:rgba(233,185,73,0.45);background:rgba(244,239,226,0.08)}
.dr-type.selected{background:var(--gold);color:#241803;border-color:var(--gold)}
.dr-type:focus-visible{outline:2px solid var(--gold-light);outline-offset:2px}
.dr-field{
  width:100%;padding:11px 13px;
  background:rgba(244,239,226,0.05);
  border:1px solid rgba(244,239,226,0.14);
  border-radius:3px;
  color:var(--paper);font-family:inherit;font-size:0.92rem;letter-spacing:-0.005em;
  transition:border .2s, background .2s;
}
.dr-field::placeholder{color:rgba(244,239,226,0.38)}
.dr-field:focus{outline:none;border-color:var(--gold-light);background:rgba(244,239,226,0.08)}
.dr-actions{
  display:flex;align-items:center;gap:14px;justify-content:space-between;flex-wrap:wrap;
  margin-top:2px;
}
.dr-submit{
  padding:11px 22px;
  background:var(--gold);color:#241803;
  font-family:var(--font-mono);font-size:0.7rem;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  border-radius:3px;border:none;cursor:pointer;
  transition:background .2s, transform .2s;
}
.dr-submit:hover{background:var(--gold-light);transform:translateX(2px)}
.dr-hint{
  font-family:var(--font-mono);font-size:0.58rem;
  letter-spacing:0.12em;text-transform:uppercase;color:rgba(244,239,226,0.45);
}
.dr-hint a{color:var(--gold-light);transition:color .2s}
.dr-hint a:hover{color:var(--paper)}

/* Staff chip — separated, smaller, far away */
.w-staff{display:flex;justify-content:flex-end;margin-top:14px;padding-top:14px}
.dr-chip-wrap{position:relative;max-width:280px}
.dr-chip{
  display:inline-flex;align-items:center;gap:9px;
  padding:7px 14px;border-radius:18px;
  background:rgba(244,239,226,0.04);
  border:1px solid rgba(244,239,226,0.14);
  font-family:var(--font-mono);font-size:0.62rem;font-weight:500;
  letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(244,239,226,0.5);
  cursor:pointer;transition:color .25s, border .25s, background .25s;
}
.dr-chip:hover{color:var(--paper);border-color:rgba(244,239,226,0.32);background:rgba(244,239,226,0.07)}
.dr-chip-wrap.open .dr-chip{
  background:rgba(15,30,55,0.65);color:var(--paper);border-color:rgba(233,185,73,0.35);
}
.dr-chip-arrow{font-size:0.85rem;color:var(--gold-light);transition:transform .3s}
.dr-chip-wrap.open .dr-chip-arrow{transform:rotate(180deg)}
.dr-chip-wrap .dr-panel{
  padding:0;
  position:absolute;right:0;top:calc(100% + 10px);
  width:280px;min-width:240px;
  background:rgba(15,30,55,0.92);backdrop-filter:blur(8px);
  border:1px solid rgba(244,239,226,0.14);border-radius:4px;
  z-index:10;
}
.dr-chip-wrap.open .dr-panel{padding:14px 14px 14px}

/* Bottom rail inside hero pane */
.w-bottom{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;
  padding:30px 40px 30px;
  background:linear-gradient(to top, rgba(5,11,22,0.82) 0%, rgba(5,11,22,0.35) 55%, transparent 100%);
}
.w-counter{
  position:absolute;top:30px;left:40px;z-index:3;
  font-family:var(--font-mono);font-size:0.72rem;font-weight:500;
  letter-spacing:0.16em;color:rgba(244,239,226,0.7);
  display:flex;gap:6px;align-items:baseline;
  padding:6px 14px;border-left:1px solid rgba(233,185,73,0.45);
}
.w-counter-cur{color:var(--gold-light);font-weight:700;font-size:0.92rem}
.w-counter-sep{color:rgba(244,239,226,0.35)}
.w-counter-label{
  margin-left:14px;color:rgba(244,239,226,0.55);font-size:0.62rem;
  letter-spacing:0.22em;text-transform:uppercase;
}
.w-caption{display:flex;flex-direction:column;gap:4px;min-width:0;text-align:left;transition:opacity .35s}
.w-cap-meta{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:0.6rem;
  letter-spacing:0.22em;color:rgba(233,185,73,0.85);text-transform:uppercase;
}
.w-cap-type{
  display:inline-flex;align-items:center;
  padding:2px 7px;font-size:0.5rem;font-weight:700;letter-spacing:0.16em;
  border-radius:2px;color:#FAF7F0;
}
.w-cap-type.t-built{background:rgba(15,46,95,0.92);color:#FAF7F0}
.w-cap-type.t-3d{background:rgba(155,111,28,0.92);color:#FBF1D8}
.w-cap-name{
  font-family:var(--font-display);font-weight:300;
  font-size:1.1rem;color:var(--paper);
  letter-spacing:-0.01em;line-height:1.3;
}
.w-cap-name em{color:var(--gold-light);font-style:italic;font-weight:400;margin-left:6px}

.w-meta-links{
  font-family:var(--font-mono);font-size:0.6rem;
  letter-spacing:0.16em;color:rgba(244,239,226,0.42);text-transform:uppercase;
  text-align:right;line-height:1.7;
}
.w-meta-links a{color:rgba(244,239,226,0.6);transition:color .25s;cursor:pointer;margin:0 3px}
.w-meta-links a:hover{color:var(--gold-light)}

@media(max-width:780px){
  .w-bottom{grid-template-columns:1fr;gap:10px;padding:18px 22px 20px;text-align:center}
  .w-caption{text-align:center}
  .w-meta-links{text-align:left}
}

@media (prefers-reduced-motion: reduce){
  .w-slide{transition:opacity .3s}
  .w-slide.active img{animation:none}
}

/* ============================
   SCENE · WHO — 2 PROMINENT + DISCRETE STAFF
   ============================ */
.who-prominent{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%;max-width:1080px;margin-top:24px;
}
@media(max-width:780px){.who-prominent{grid-template-columns:1fr}}
.door-big{
  position:relative;cursor:pointer;text-align:left;
  padding:44px 40px 36px;border-radius:6px;
  display:flex;flex-direction:column;gap:18px;min-height:360px;
  transition:transform .35s cubic-bezier(.2,.7,.3,1), box-shadow .35s;
  overflow:hidden;
  font-family:inherit;border:none;
}
.door-big.priority{
  background:linear-gradient(135deg, var(--navy) 0%, #143468 50%, var(--ink-2) 100%);
  color:var(--paper);
  box-shadow:var(--shadow-2);
}
.door-big.priority::before{
  content:'';position:absolute;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle, rgba(233,185,73,0.22) 0%, transparent 65%);
  top:-160px;right:-120px;pointer-events:none;
  transition:transform .6s cubic-bezier(.2,.7,.3,1);
}
.door-big.priority::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--gold);
  transition:width .35s cubic-bezier(.2,.7,.3,1);
}
.door-big.priority:hover{transform:translateY(-8px);box-shadow:var(--shadow-3)}
.door-big.priority:hover::before{transform:translate(-30px,30px) scale(1.1)}
.door-big.priority:hover::after{width:3px}
.door-big.priority .door-num-big{color:var(--gold-light);opacity:0.85}
.door-big.priority .door-tag{color:var(--gold-light)}
.door-big.priority .door-title{color:var(--paper)}
.door-big.priority .door-title em{color:var(--gold-light);font-style:italic;font-weight:500}
.door-big.priority .door-sub{color:rgba(244,239,226,0.78)}
.door-big.priority .door-cta{color:var(--gold-light);border-top-color:rgba(233,185,73,0.18)}

.door-big:not(.priority){background:var(--surface);border:1px solid var(--border)}
.door-big:not(.priority)::before{
  content:'';position:absolute;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle, rgba(200,147,42,0.10) 0%, transparent 65%);
  top:-140px;right:-110px;pointer-events:none;opacity:0;
  transition:opacity .4s;
}
.door-big:not(.priority)::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--gold);
  transition:width .35s cubic-bezier(.2,.7,.3,1);
}
.door-big:not(.priority):hover{transform:translateY(-8px);box-shadow:var(--shadow-3);border-color:var(--gold)}
.door-big:not(.priority):hover::before{opacity:1}
.door-big:not(.priority):hover::after{width:3px}
.door-big:not(.priority) .door-num-big{color:var(--paper-3)}
.door-big:not(.priority) .door-tag{color:var(--gold-2)}
.door-big:not(.priority) .door-title{color:var(--ink)}
.door-big:not(.priority) .door-title em{color:var(--navy);font-style:italic;font-weight:500}
.door-big:not(.priority) .door-sub{color:var(--muted)}
.door-big:not(.priority) .door-cta{color:var(--navy);border-top-color:var(--border)}

.door-num-big{
  font-family:var(--font-display);
  font-weight:200;font-size:4.6rem;line-height:0.85;
  letter-spacing:-0.07em;position:relative;z-index:2;
}
.door-tag{
  font-family:var(--font-mono);font-size:0.66rem;
  letter-spacing:0.18em;text-transform:uppercase;font-weight:500;
  display:inline-flex;align-items:center;gap:8px;position:relative;z-index:2;
}
.door-title{
  font-family:var(--font-display);
  font-weight:300;font-size:clamp(1.9rem,2.6vw,2.5rem);
  line-height:1.02;letter-spacing:-0.03em;position:relative;z-index:2;
}
.door-sub{font-size:0.95rem;line-height:1.6;flex:1;position:relative;z-index:2;font-weight:400}
.door-cta{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:0.72rem;
  letter-spacing:0.14em;text-transform:uppercase;font-weight:600;
  padding-top:18px;border-top:1px solid;position:relative;z-index:2;
  transition:gap .25s;
}
.door-big:hover .door-cta{gap:18px}

.staff-discrete{
  display:flex;align-items:center;gap:14px;justify-content:center;
  font-family:var(--font-mono);font-size:0.7rem;
  color:var(--muted);letter-spacing:0.14em;text-transform:uppercase;
}
.staff-discrete a{color:var(--muted);padding:8px 14px;transition:color .25s, background .25s;border-radius:3px}
.staff-discrete a:hover{color:var(--navy);background:rgba(217,209,189,0.35)}
.staff-discrete .dot{width:3px;height:3px;background:var(--muted-2);border-radius:50%;opacity:0.7}

/* ============================
   SCENE · LANE-NEW (workshops grid)
   ============================ */
.intro-block{
  text-align:center;max-width:680px;margin-bottom:64px;
  display:flex;flex-direction:column;gap:20px;align-items:center;
}
.section-label{
  font-family:var(--font-mono);font-size:0.7rem;
  letter-spacing:0.16em;color:var(--gold-2);text-transform:uppercase;
  display:block;margin-bottom:24px;font-weight:500;
}
.workshop-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:14px;width:100%;
}
/* Workshop-card variant lives in main paper scenes — share class but override darks above */
.scene:not(.welcome) .ws-card{
  background:var(--surface);border:1px solid var(--border);border-radius:5px;
  padding:30px 28px;text-align:left;
  display:flex;flex-direction:column;gap:12px;cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s, border-color .25s;
  position:relative;overflow:hidden;min-height:200px;
  font-family:inherit;
  color:var(--ink);
}
.scene:not(.welcome) .ws-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--gold);transform:scaleY(0);transform-origin:top;
  transition:transform .3s;
}
.scene:not(.welcome) .ws-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--border-2)}
.scene:not(.welcome) .ws-card:hover::before{transform:scaleY(1)}
.scene:not(.welcome) .ws-card.disabled{opacity:0.45;cursor:default}
.scene:not(.welcome) .ws-card.disabled:hover{transform:none;box-shadow:none;border-color:var(--border)}
.scene:not(.welcome) .ws-card.disabled:hover::before{transform:scaleY(0)}
.ws-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.ws-letter{
  font-family:var(--font-display);
  font-weight:200;font-size:2.6rem;line-height:1;color:var(--ink);letter-spacing:-0.05em;
}
.ws-pill{
  font-family:var(--font-mono);font-size:0.6rem;
  padding:3px 9px;border-radius:10px;letter-spacing:0.08em;
  text-transform:uppercase;font-weight:500;flex-shrink:0;margin-top:4px;
}
.ws-pill.live{background:var(--gold-soft);color:var(--gold-2)}
.ws-pill.soon{background:var(--paper-2);color:var(--muted-2)}
.scene:not(.welcome) .ws-name{
  font-family:var(--font-display);
  font-weight:500;font-size:1.15rem;letter-spacing:-0.01em;line-height:1.25;color:var(--ink);
}
.scene:not(.welcome) .ws-name em{color:var(--navy);font-style:italic}
.scene:not(.welcome) .ws-desc{font-size:0.85rem;color:var(--muted);line-height:1.55}
.scene:not(.welcome) .ws-go{
  margin-top:auto;font-family:var(--font-mono);font-size:0.66rem;
  color:var(--navy);letter-spacing:0.12em;text-transform:uppercase;font-weight:600;padding-top:6px;
  border-top:none;background:none;
}

/* ============================
   SCENE · WORKSHOP A
   ============================ */
.wsdetail-hero{
  text-align:left;max-width:780px;width:100%;margin-bottom:48px;
  display:flex;flex-direction:column;gap:18px;
}
.wsd-letter-display{
  font-family:var(--font-display);
  font-weight:200;font-size:clamp(7rem,18vw,14rem);
  line-height:0.85;color:var(--gold-2);letter-spacing:-0.07em;margin-bottom:-20px;
}
.wsd-meta{
  display:flex;gap:36px;flex-wrap:wrap;margin-top:24px;padding-top:24px;border-top:1px solid var(--border);
}
.wsd-meta div{display:flex;flex-direction:column;gap:4px}
.wsd-meta-lbl{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase}
.wsd-meta-val{font-family:var(--font-display);font-size:1.1rem;font-weight:500;color:var(--ink);letter-spacing:-0.01em}
.wsd-meta-val em{color:var(--gold-2);font-style:italic}

.wsd-pair{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;width:100%;max-width:1080px;
  text-align:left;align-items:start;
}
@media(max-width:880px){.wsd-pair{grid-template-columns:1fr;gap:36px}}
.wsd-info{display:flex;flex-direction:column;gap:30px}
.wsd-info h4{
  font-family:var(--font-mono);font-size:0.7rem;
  letter-spacing:0.14em;color:var(--gold-2);text-transform:uppercase;
  font-weight:600;margin-bottom:14px;
}
.wsd-info ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.wsd-info ul li{
  padding-left:22px;position:relative;font-size:0.95rem;color:var(--ink-2);line-height:1.55;
}
.wsd-info ul li::before{
  content:'';position:absolute;left:0;top:11px;width:12px;height:1px;background:var(--gold);
}

/* ============================
   FORMS (shared)
   ============================ */
.form-block{
  background:var(--surface);border:1px solid var(--border);border-radius:5px;
  padding:38px 40px;display:flex;flex-direction:column;gap:18px;
}
@media(max-width:680px){.form-block{padding:26px 24px}}
.form-block h3{
  font-family:var(--font-display);
  font-weight:400;font-size:1.4rem;letter-spacing:-0.015em;
  margin-bottom:4px;
}
.form-block h3 em{color:var(--navy);font-style:italic;font-weight:500}
.form-block .form-sub{font-size:0.88rem;color:var(--muted);margin-bottom:14px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.fr{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{
  font-family:var(--font-mono);font-size:0.62rem;
  letter-spacing:0.14em;color:var(--ink-2);text-transform:uppercase;font-weight:600;
}
.fg input,.fg textarea,.fg select{
  width:100%;padding:13px 14px;background:var(--paper);
  border:1px solid var(--border);border-radius:3px;
  font-family:inherit;font-size:0.95rem;color:var(--ink);
  transition:border-color .2s, background .2s, box-shadow .2s;letter-spacing:-0.005em;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
  outline:none;border-color:var(--navy);background:var(--surface);
  box-shadow:0 0 0 3px rgba(15,46,95,0.08);
}
.fg textarea{min-height:96px;resize:vertical;font-family:inherit;line-height:1.55}

/* ============================
   SCENE · LANE-CUSTOMER (login shell)
   ============================ */
.login-shell{
  display:grid;grid-template-columns:1fr 1fr;gap:0;width:100%;max-width:1000px;
  background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;
  box-shadow:var(--shadow-1);
}
@media(max-width:780px){.login-shell{grid-template-columns:1fr}}
.login-side{
  padding:48px 44px;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:space-between;min-height:460px;
  position:relative;overflow:hidden;
}
.login-side::before{
  content:'';position:absolute;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle, rgba(233,185,73,0.18) 0%, transparent 70%);
  top:-120px;right:-120px;
}
.login-side .ls-top{position:relative;z-index:2}
.login-side .ls-eyebrow{
  font-family:var(--font-mono);font-size:0.7rem;
  letter-spacing:0.18em;color:var(--gold-light);text-transform:uppercase;margin-bottom:16px;
}
.login-side h2{
  font-family:var(--font-display);
  font-weight:300;font-size:clamp(1.8rem,3vw,2.4rem);line-height:1.1;letter-spacing:-0.025em;
}
.login-side h2 em{color:var(--gold-light);font-style:italic;font-weight:400}
.login-side .ls-body{margin-top:16px;color:#CBD5E1;font-size:0.95rem;line-height:1.65;max-width:340px}
.login-side .ls-bot{position:relative;z-index:2;font-family:var(--font-mono);font-size:0.66rem;color:rgba(255,255,255,0.4);letter-spacing:0.14em}
.login-form-side{padding:48px 44px;display:flex;flex-direction:column;justify-content:center;gap:18px}
@media(max-width:780px){.login-side,.login-form-side{padding:36px 28px}.login-side{min-height:auto}}
.login-helper{font-size:0.84rem;color:var(--muted);margin-top:8px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.login-helper a{color:var(--navy);font-weight:500}
.login-helper a:hover{text-decoration:underline}

/* ============================
   SCENE · THANKS
   ============================ */
.thanks-check{
  width:90px;height:90px;border-radius:50%;
  background:linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 100%);
  color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-size:2.4rem;font-weight:300;
  box-shadow:0 12px 36px rgba(200,147,42,0.35);
}

/* ============================
   SCENE · STAFF (discrete login)
   ============================ */
.staff-shell{width:100%;max-width:520px;display:flex;flex-direction:column;gap:24px}
.staff-lock{
  width:52px;height:52px;border-radius:50%;
  background:var(--ink-2);color:var(--gold-light);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;
  margin:0 auto 6px;
}
.staff-form{
  background:var(--surface);border:1px solid var(--border);border-radius:5px;
  padding:36px 40px;display:flex;flex-direction:column;gap:16px;
}

/* ============================
   SCENE · PORTFOLIO
   ============================ */
.port-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;width:100%;text-align:left;
}
.pcard{
  background:var(--surface);border:1px solid var(--border);border-radius:5px;overflow:hidden;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.3,1), box-shadow .25s;
}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.pthumb{
  aspect-ratio:4/3;display:flex;align-items:flex-end;padding:18px;color:white;
  font-family:var(--font-display);font-style:italic;font-size:0.95rem;font-weight:300;
  letter-spacing:-0.005em;
}
.pthumb.s1{background:linear-gradient(135deg,#1B3D72 0%, #0F2E5F 100%)}
.pthumb.s2{background:linear-gradient(135deg,#FBF1D8 0%, #C8932A 100%);color:var(--ink)}
.pthumb.s3{background:linear-gradient(135deg,#1E293B 0%, #0A1628 100%)}
.pthumb.s4{background:linear-gradient(135deg,#F4EFE2 0%, #C2B89E 100%);color:var(--ink)}
.pthumb.s5{background:linear-gradient(135deg,#2563EB 0%, #1E40AF 100%)}
.pthumb.s6{background:linear-gradient(135deg,#FAF7F0 0%, #D9D1BD 100%);color:var(--ink)}
.pbody{padding:16px 18px}
.pcat{font-family:var(--font-mono);font-size:0.62rem;letter-spacing:0.14em;color:var(--gold-2);text-transform:uppercase;font-weight:500}
.pname{margin-top:5px;font-size:1.02rem;font-weight:500;letter-spacing:-0.01em;color:var(--ink)}

/* ============================
   SCENE · ABOUT
   ============================ */
.about-quote{
  font-family:var(--font-display);
  font-style:italic;font-weight:300;
  font-size:clamp(1.4rem,2.4vw,1.8rem);
  color:var(--navy);line-height:1.4;
  max-width:720px;letter-spacing:-0.015em;
}
.about-body{font-size:1.05rem;color:var(--ink-2);max-width:680px;line-height:1.75;font-weight:400}
.about-body em{font-style:italic;color:var(--navy);font-weight:500}

/* ============================
   SCENE · CONTACT
   ============================ */
.contact-block{
  display:grid;grid-template-columns:1fr 1fr;gap:0;width:100%;max-width:980px;
  background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;
  box-shadow:var(--shadow-1);
}
@media(max-width:780px){.contact-block{grid-template-columns:1fr}}
.contact-col{padding:40px 44px;text-align:left}
.contact-col:first-child{border-right:1px solid var(--border)}
@media(max-width:780px){.contact-col:first-child{border-right:none;border-bottom:1px solid var(--border)}}
.cb-row{display:grid;grid-template-columns:90px 1fr;gap:16px;padding:14px 0;border-bottom:1px solid var(--border)}
.cb-row:last-child{border:none}
.cb-lbl{font-family:var(--font-mono);font-size:0.66rem;letter-spacing:0.14em;color:var(--gold-2);text-transform:uppercase;padding-top:3px;font-weight:600}
.cb-val{font-size:0.98rem;color:var(--ink);line-height:1.55}
.cb-val a:hover{color:var(--navy);text-decoration:underline}
