/* ============================================================================
   LuxuryLifts — public face. "Brass & Rail" identity (extends the app tokens).
   Standalone: landing.html / book.html / login.html link ONLY this file.
   Signature: the page is a lift shaft — a brushed-brass rail tracks your
   scroll, and the hero arrives through parting elevator doors.
   Performance-minded for Pi + iPhone: transforms/opacity only, no WebGL,
   backdrop-blur dropped on small screens, prefers-reduced-motion respected.
   ========================================================================== */

:root{
  --paper:#ECEEF1; --surface:#FBFBFC; --surface2:#E9EBEF;
  --ink:#14161B; --muted:#5C6473;
  --brass:#8A6A24; --brass2:#6E531B;
  --brass-grad:linear-gradient(135deg,#E3C572 0%,#B68F3C 55%,#C7A24A 100%);
  --rail:linear-gradient(180deg,#E7CB78 0%,#B68F3C 100%);
  --steel:#2f6fb0;
  --border:#DDE0E6; --border2:#C9CFD8;
  /* brushed-steel lift doors */
  --metal:linear-gradient(100deg,#cfd3da 0%,#eef1f5 16%,#c2c7d0 36%,#e9ecf1 58%,#cbd0d8 80%,#eef1f5 100%);
  --shadow:0 1px 2px rgba(16,24,40,.06),0 10px 30px rgba(16,24,40,.10);
  --shadow-lg:0 30px 70px rgba(16,24,40,.22);
  --r:18px; --r-lg:26px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  --display:'Space Grotesk','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:76px;}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  font-feature-settings:"tnum" 1,"ss01" 1;line-height:1.55;overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
:focus-visible{outline:3px solid rgba(138,106,36,.45);outline-offset:2px;border-radius:6px;}

/* ambient backdrop: brass light + faint blueprint grid (static, cheap) */
/* layer 1 — brand glow + fine grain (richer, static) */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(rgba(20,22,27,.045) 1px, transparent 1.5px) 0 0 / 7px 7px,
    radial-gradient(1220px 640px at 82% -12%, rgba(199,162,74,.30), transparent 60%),
    radial-gradient(940px 540px at -8% 6%, rgba(47,111,176,.13), transparent 56%),
    radial-gradient(960px 720px at 50% 116%, rgba(199,162,74,.11), transparent 60%),
    var(--paper);
}
/* layer 2 — the lift-shaft motif: brushed-brass guide rails (with a metallic
   highlight) + faint horizontal "passing-floor" ticks, masked so the centre of
   the page stays clean. The floor ticks drift slowly upward on desktop only. */
/* ── per-page ANIMATED lift backdrop (.pagefx) ───────────────────────────────
   Faint lift cabins ride up & down shafts, colour-themed per page. Built only
   from translateY + linear-gradient + box-shadow + radial mask — all render on
   mobile (no 3D transforms / conic / repeating-radial). */
body.pg-home, body.pg-dw, body.pg-cfg{--fx:#9c7a2c; --fxc:#C7A24A;}   /* brass */
body.pg-contract{--fx:#2f6fb0; --fxc:#4f93dd;}                        /* blueprint blue */
body.pg-form, body.pg-auth{--fx:#6e7785; --fxc:#9aa3b1;}              /* steel */
.pagefx{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden;
  -webkit-mask-image:radial-gradient(145% 120% at 50% 34%, #000 50%, transparent 96%);
          mask-image:radial-gradient(145% 120% at 50% 34%, #000 50%, transparent 96%);}
.fx-shaft{position:absolute;top:-12%;height:124%;width:2px;
  background:linear-gradient(180deg, transparent, var(--fx) 16%, var(--fx) 84%, transparent);
  opacity:.12;}
.fx-cabin{position:absolute;left:-13px;width:28px;height:38px;border-radius:5px;
  background:linear-gradient(180deg, var(--fxc), var(--fx));
  box-shadow:0 10px 20px rgba(16,24,40,.14), inset 0 0 0 1px rgba(255,255,255,.4);
  opacity:.4;will-change:transform;}
.fx-cabin::before{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:54%;height:3px;border-radius:2px;background:rgba(255,251,240,.65);}
.fx-cabin::after{content:"";position:absolute;left:6px;right:6px;bottom:7px;height:5px;border-radius:2px;
  background:rgba(255,255,255,.22);}
@media(max-width:560px){ .fx-cabin{width:24px;height:32px;left:-11px;} }
@keyframes shaftDrift{
  from{background-position:0 0, 0 0, 0 0;}
  to{  background-position:0 0, 0 0, 0 -132px;}
}

/* ── buttons ──────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5em;font-family:var(--display);
  font-weight:600;font-size:15px;line-height:1;padding:13px 24px;border-radius:999px;
  border:1px solid transparent;cursor:pointer;white-space:nowrap;
  transition:transform .16s ease,box-shadow .26s ease,border-color .2s,color .2s,background .2s;
}
.btn-brass{
  background:var(--brass-grad);color:#241a06;
  box-shadow:0 7px 20px rgba(160,123,40,.36),inset 0 1px 0 rgba(255,255,255,.55);
}
.btn-brass:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(160,123,40,.46),inset 0 1px 0 rgba(255,255,255,.65);}
.btn-ghost{background:transparent;border-color:var(--border2);color:var(--ink);}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--brass);color:var(--brass2);}
.btn-dark{background:#14161B;color:#F2E6C6;}
.btn-dark:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn-lg{padding:17px 32px;font-size:17px;}
.btn-block{width:100%;justify-content:center;}

/* ── top nav ──────────────────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;
  padding:14px clamp(16px,4vw,48px);
  background:rgba(252,252,253,.74);border-bottom:1px solid var(--border);
  backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);
}
.nav-brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.01em;}
.nav-brand img{height:42px;width:auto;filter:drop-shadow(0 2px 5px rgba(16,24,40,.18));}
.nav-brand .mk{color:var(--brass2);}
@media(max-width:560px){.nav-brand{font-size:18px;}.nav-brand img{height:36px;}}
.nav-spacer{flex:1;}
.nav .btn{padding:10px 18px;font-size:14px;}
.nav-link{font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--ink);padding:8px 6px;
  position:relative;transition:color .2s;}
.nav-link::after{content:"";position:absolute;left:6px;right:6px;bottom:2px;height:2px;border-radius:2px;
  background:var(--rail);transform:scaleX(0);transform-origin:left;transition:transform .25s ease;}
.nav-link:hover{color:var(--brass2);}
.nav-link:hover::after{transform:scaleX(1);}
.nav-hide{display:inline-flex;}
@media(max-width:860px){.nav-link.nav-hide{display:none;}}
@media(max-width:560px){
  .nav-hide{display:none;}
  .nav{gap:8px 10px;padding:10px 14px;flex-wrap:wrap;justify-content:space-between;}  /* never clip the button */
  .nav-spacer{display:none;}
  .nav .btn{padding:9px 13px;font-size:12.5px;white-space:nowrap;}
  .nav-brand{font-size:16px;gap:9px;min-width:0;}
  .nav-brand img{height:30px;}
}
html,body{overflow-x:hidden;}
img{max-width:100%;}

/* ── hero / lift shaft ────────────────────────────────────────────────────── */
.hero{position:relative;min-height:calc(100svh - 60px);display:flex;align-items:center;overflow:hidden;}
.hero-inner{
  position:relative;z-index:8;width:100%;max-width:1180px;margin:0 auto;
  padding:clamp(28px,7vh,90px) clamp(20px,5vw,72px);
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,418px);
  gap:clamp(28px,5vw,60px);align-items:center;
}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;gap:26px;}}
/* hero photo — the page's thesis, revealed as the doors part */
.hero-photo{margin:0;position:relative;border-radius:22px;overflow:hidden;
  border:1px solid rgba(255,255,255,.45);box-shadow:var(--shadow-lg);}
.hero-photo img{width:100%;height:clamp(380px,54vh,560px);object-fit:cover;display:block;}
.hero-photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 13px;
  font-family:var(--display);font-weight:600;font-size:13px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(16,18,24,.82));}
@media(max-width:900px){.hero-photo img{height:clamp(200px,30vh,290px);}}
@media(max-width:760px){.cfg-real img{max-height:240px;}}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;font-size:12px;color:var(--brass2);margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--rail);border-radius:2px;}
.hero h1{
  font-family:var(--display);font-weight:700;font-size:clamp(40px,7.4vw,84px);line-height:1.0;
  letter-spacing:-.025em;margin:0 0 .34em;max-width:15ch;
}
.hero h1 .brass{
  background:var(--brass-grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.lead{font-size:clamp(17px,2.1vw,21px);color:var(--muted);max-width:48ch;margin:0 0 30px;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-meta{margin-top:32px;display:flex;flex-wrap:wrap;gap:0;color:var(--muted);font-size:13.5px;}
.hero-meta span{padding:2px 22px;}
.hero-meta span:first-child{padding-left:0;}
.hero-meta span:not(:first-child){border-left:1px solid var(--border2);}
.hero-meta b{color:var(--ink);font-family:var(--display);font-size:21px;display:block;letter-spacing:-.01em;margin-bottom:1px;}
@media(max-width:560px){.hero-meta span{flex:1 0 100%;border-left:none;padding:2px 0;}}

/* floor-indicator panel — the hero's characteristic object */
.indicator{
  display:inline-flex;align-items:center;gap:14px;margin-bottom:26px;padding:11px 16px;border-radius:14px;
  background:#101218;color:#E7CB78;box-shadow:var(--shadow),inset 0 0 0 1px rgba(231,203,120,.18);
}
.indicator .chev{font-size:13px;line-height:.8;animation:rise 1.8s ease-in-out infinite;}
.indicator .seg{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:1px;white-space:nowrap;
  text-shadow:0 0 14px rgba(231,203,120,.55);}
.indicator .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#9c8a5e;}
@keyframes rise{0%,100%{transform:translateY(2px);opacity:.6;}50%{transform:translateY(-2px);opacity:1;}}

/* parting elevator doors (one orchestrated load moment) */
.doors{position:absolute;inset:0;z-index:7;display:flex;pointer-events:none;}
.door{
  position:relative;flex:1 1 50%;background:var(--metal);
  background-size:200% 100%;box-shadow:inset 0 0 80px rgba(20,22,27,.10);
}
.door::before{ /* brushed grooves */
  content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.35) 0 1px,transparent 1px 3px);
}
.door::after{content:"";position:absolute;top:0;bottom:0;width:3px;background:rgba(20,22,27,.22);}
.door.l::after{right:0;}.door.r::after{left:0;}
.door.l{animation:doorL 1.45s cubic-bezier(.72,0,.18,1) .35s forwards;}
.door.r{animation:doorR 1.45s cubic-bezier(.72,0,.18,1) .35s forwards;}
@keyframes doorL{to{transform:translateX(-101%);}}
@keyframes doorR{to{transform:translateX(101%);}}

/* fixed lift-rail scroll indicator (desktop) */
.rail{position:fixed;left:26px;top:0;bottom:0;width:42px;z-index:45;
  display:none;align-items:center;justify-content:center;pointer-events:none;}
@media(min-width:1080px){.rail{display:flex;}}
.rail-track{position:relative;width:4px;height:62vh;border-radius:4px;
  background:linear-gradient(180deg,rgba(182,143,60,.18),rgba(182,143,60,.42));}
.rail-car{position:absolute;left:50%;top:0;width:20px;height:48px;border-radius:7px;
  transform:translate(-50%,0);background:var(--brass-grad);
  box-shadow:0 8px 20px rgba(160,123,40,.5),inset 0 1px 0 rgba(255,255,255,.6);
  transition:top .25s cubic-bezier(.3,.7,.2,1);}
.rail-car::after{content:"";position:absolute;inset:7px 5px;border-radius:3px;background:rgba(20,22,27,.18);}
.floor{position:absolute;left:50%;transform:translate(-50%,-50%);display:flex;align-items:center;gap:9px;}
.floor i{width:9px;height:9px;border-radius:50%;background:var(--surface2);
  border:1.5px solid var(--border2);transition:all .3s;}
.floor b{font-family:var(--display);font-size:12px;color:var(--muted);opacity:0;transform:translateX(-4px);
  transition:all .3s;}
.floor.on i{background:var(--brass-grad);border-color:#B68F3C;box-shadow:0 0 0 4px rgba(182,143,60,.18);}
.floor.on b{opacity:1;transform:none;color:var(--brass2);}

/* ── sections ─────────────────────────────────────────────────────────────── */
.section{max-width:1180px;margin:0 auto;padding:clamp(64px,10vh,124px) clamp(20px,5vw,72px);}
.kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--brass2);}
.kicker::before{content:"";width:24px;height:2px;background:var(--rail);border-radius:2px;}
.section h2{font-family:var(--display);font-weight:700;font-size:clamp(29px,4.6vw,48px);
  letter-spacing:-.025em;margin:.35em 0 .35em;max-width:18ch;}
.section .sub{color:var(--muted);font-size:clamp(16px,1.8vw,18px);max-width:54ch;margin:0 0 44px;}

/* feature cards with 3D tilt */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1100px;}
@media(max-width:900px){.cards{grid-template-columns:1fr;}}
.card{
  position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:30px 26px 28px;box-shadow:var(--shadow);overflow:hidden;
  transform-style:preserve-3d;transition:transform .18s ease,box-shadow .3s ease;will-change:transform;
}
.card::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--rail);}
.card:hover{box-shadow:var(--shadow-lg);}
.card .ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;font-size:25px;
  background:radial-gradient(120% 120% at 30% 25%, rgba(199,162,74,.22), rgba(199,162,74,.08));
  border:1px solid rgba(199,162,74,.4);box-shadow:inset 0 1px 0 rgba(255,255,255,.6),var(--shadow);
  transform:translateZ(46px);}
.card h3{font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:-.01em;margin:18px 0 9px;
  transform:translateZ(28px);}
.card p{color:var(--muted);margin:0 0 14px;transform:translateZ(14px);}
.card ul{margin:0;padding:0;list-style:none;transform:translateZ(10px);}
.card li{display:flex;gap:9px;align-items:flex-start;color:var(--ink);font-size:14.5px;padding:5px 0;}
.card li::before{content:"";flex:none;width:7px;height:7px;margin-top:7px;border-radius:2px;background:var(--brass-grad);}

/* how it works — a real sequence, so numbering carries meaning */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:900px){.steps{grid-template-columns:1fr;}}
.step{position:relative;padding:28px 24px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow);}
.step .n{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.1em;color:var(--brass2);}
.step h3{font-family:var(--display);font-weight:600;font-size:19px;margin:12px 0 7px;}
.step p{color:var(--muted);margin:0;font-size:15px;}
.step::after{content:"";position:absolute;left:24px;right:24px;top:54px;height:1px;
  background:repeating-linear-gradient(90deg,var(--border2) 0 6px,transparent 6px 12px);}

/* CTA band */
.cta-band{position:relative;max-width:1180px;margin:0 auto;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(135deg,#191b22 0%,#24272f 100%);color:#fff;
  padding:clamp(40px,7vw,72px);display:flex;flex-wrap:wrap;gap:28px;align-items:center;justify-content:space-between;}
.cta-band::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--rail);}
.cta-band::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(199,162,74,.28),transparent 70%);pointer-events:none;}
.cta-band h2{font-family:var(--display);font-weight:700;font-size:clamp(26px,3.6vw,40px);letter-spacing:-.02em;margin:0 0 8px;}
.cta-band p{color:#c7cad3;margin:0;max-width:42ch;}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:14px;position:relative;z-index:2;}

/* footer */
.foot{position:relative;max-width:1180px;margin:0 auto;padding:48px clamp(20px,5vw,72px) 60px;border-top:1px solid var(--border);
  display:flex;flex-wrap:wrap;gap:18px 40px;align-items:center;justify-content:space-between;color:var(--muted);font-size:14px;}
.foot::before{content:"";position:absolute;left:clamp(20px,5vw,72px);top:-1px;width:64px;height:3px;background:var(--rail);border-radius:2px;}
.foot .brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:19px;color:var(--ink);}
.foot .brand img{height:38px;width:auto;filter:drop-shadow(0 2px 5px rgba(16,24,40,.16));}
.foot a:hover{color:var(--brass2);}
@media(max-width:560px){.foot{justify-content:center;text-align:center;}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ── auth + booking (shared) ──────────────────────────────────────────────── */
.sheet-page{min-height:100svh;display:grid;place-items:center;padding:clamp(20px,5vw,40px);}
.panel{position:relative;width:min(440px,100%);background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:38px 32px 30px;box-shadow:var(--shadow-lg);overflow:hidden;}
.panel.wide{width:min(560px,100%);}
.panel::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--rail);}
.panel-logo{height:40px;width:auto;margin-bottom:14px;}
.panel-tag{font-family:var(--display);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brass2);margin-bottom:6px;}
.panel h1{font-family:var(--display);font-weight:700;font-size:27px;letter-spacing:-.02em;margin:0 0 4px;}
.panel .hint{color:var(--muted);font-size:14.5px;margin:0 0 22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-family:var(--display);font-weight:500;font-size:13px;letter-spacing:.02em;color:var(--ink);margin-bottom:7px;}
.field input,.field select,.field textarea{
  width:100%;font:inherit;font-size:16px;color:var(--ink);background:#fff;
  border:1px solid var(--border2);border-radius:12px;padding:13px 14px;transition:border-color .2s,box-shadow .2s;
}
.field textarea{min-height:96px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brass);box-shadow:0 0 0 3px rgba(138,106,36,.16);}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:480px){.row2{grid-template-columns:1fr;}}
.remember{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:14px;margin:4px 0 20px;cursor:pointer;}
.remember input{width:17px;height:17px;accent-color:var(--brass);}
.alert{border-radius:12px;padding:11px 14px;font-size:14px;margin-bottom:18px;}
.alert.err{background:rgba(214,59,44,.10);border:1px solid rgba(214,59,44,.32);color:#a02b1f;}
.alert.ok{background:rgba(31,157,87,.10);border:1px solid rgba(31,157,87,.32);color:#15683c;}
.back-home{display:inline-flex;align-items:center;gap:7px;margin-top:20px;color:var(--muted);font-size:13.5px;}
.back-home:hover{color:var(--brass2);}
.honey{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;}
.book-ok{text-align:center;padding:10px 0;}
.book-ok .tick{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:6px auto 16px;
  font-size:30px;background:var(--brass-grad);color:#241a06;box-shadow:0 10px 26px rgba(160,123,40,.4);}

/* ── inside the cabin (CSS-rendered lift interior) ────────────────────────────
   A second signature object: a brushed-steel cabin you can look into, with a
   lit ceiling, a working-looking car panel, mirror back wall and handrail. */
.cabin-wrap{display:grid;grid-template-columns:minmax(0,420px) minmax(0,1fr);
  gap:clamp(30px,5vw,68px);align-items:center;}
@media(max-width:900px){.cabin-wrap{grid-template-columns:1fr;justify-items:center;}}

.cabin{position:relative;width:100%;max-width:420px;border-radius:22px;
  background:linear-gradient(180deg,#2b2f37,#15171c);padding:14px 14px 0;
  box-shadow:var(--shadow-lg),inset 0 0 0 1px rgba(255,255,255,.05);
  transform:perspective(1400px) rotateY(-7deg);transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.cabin:hover{transform:perspective(1400px) rotateY(0deg);}
.cabin-ceiling{display:flex;justify-content:center;gap:30px;padding:9px 0 15px;}
.downlight{width:30px;height:6px;border-radius:6px;background:#fffaf0;
  box-shadow:0 0 24px 7px rgba(255,247,214,.7);}
.cabin-body{position:relative;display:grid;grid-template-columns:88px 1fr;gap:14px;
  background:var(--metal);background-size:200% 100%;border-radius:12px;padding:18px 16px;
  box-shadow:inset 0 0 60px rgba(20,22,27,.12);min-height:296px;}
.cabin-body::before{content:"";position:absolute;inset:0;border-radius:12px;opacity:.4;pointer-events:none;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.28) 0 1px,transparent 1px 4px);}
/* car operating panel */
.cabin-cop{position:relative;z-index:2;align-self:start;
  background:linear-gradient(180deg,#d2d6dd,#aeb4bf);border-radius:11px;padding:12px 10px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 5px 14px rgba(0,0,0,.2);}
.cop-display{background:#0f1116;border-radius:7px;padding:8px 6px;text-align:center;margin-bottom:12px;
  box-shadow:inset 0 0 0 1px rgba(231,203,120,.22);}
.cop-arrow{display:block;color:#E7CB78;font-size:11px;line-height:1;animation:rise 1.8s ease-in-out infinite;}
.cop-floor{display:block;font-family:var(--display);font-weight:700;font-size:27px;color:#E7CB78;
  text-shadow:0 0 12px rgba(231,203,120,.6);letter-spacing:1px;}
.cop-buttons{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
.cop-btn{aspect-ratio:1;display:grid;place-items:center;font-family:var(--display);font-weight:600;
  font-size:12.5px;color:#3a3f48;background:linear-gradient(180deg,#eef1f5,#d3d8e0);border-radius:50%;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 2px 4px rgba(0,0,0,.14);}
.cop-btn.on{color:#241a06;background:var(--brass-grad);
  box-shadow:0 0 0 3px rgba(199,162,74,.32),inset 0 1px 0 rgba(255,255,255,.5);}
.cop-btn.alarm{font-size:11px;}
/* mirrored back wall + handrail */
.cabin-wall{position:relative;z-index:1;border-radius:10px;overflow:hidden;
  background:linear-gradient(120deg,rgba(255,255,255,.5),rgba(206,211,218,.25));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.35);}
.cabin-mirror{position:absolute;inset:14px 16px 42px;border-radius:8px;
  background:linear-gradient(135deg,rgba(233,236,241,.9),rgba(180,190,200,.5) 58%,rgba(233,236,241,.85));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);}
.cabin-mirror::after{content:"";position:absolute;top:-30%;left:-20%;width:46%;height:170%;
  transform:rotate(18deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);}
.cabin-rail{position:absolute;left:14px;right:16px;bottom:24px;height:8px;border-radius:6px;
  background:linear-gradient(180deg,#eef1f5,#b9bfc8);box-shadow:0 3px 6px rgba(0,0,0,.22);}
.cabin-floor{height:18px;margin:0 -14px;border-radius:0 0 22px 22px;
  background:linear-gradient(180deg,#3a3f48,#23262d);box-shadow:inset 0 3px 9px rgba(0,0,0,.42);}

.cabin-copy .malta-pill{display:inline-flex;align-items:center;gap:9px;margin-top:6px;
  font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--brass2);
  background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);padding:9px 15px;border-radius:999px;}
.malta-pill{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;
  font-size:13.5px;color:var(--brass2);background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);
  padding:9px 15px;border-radius:999px;line-height:1.3;}
.malta-pill .dot{flex:none;width:8px;height:8px;border-radius:50%;background:var(--brass-grad);
  box-shadow:0 0 0 4px rgba(199,162,74,.16);}

/* hero scroll cue */
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:9;
  width:26px;height:42px;border:2px solid rgba(110,83,27,.4);border-radius:14px;
  display:grid;justify-items:center;align-content:start;padding-top:7px;}
.scroll-cue span{width:4px;height:8px;border-radius:3px;background:var(--brass2);
  animation:cue 1.6s ease-in-out infinite;}
@keyframes cue{0%{opacity:0;transform:translateY(-2px);}40%{opacity:1;}100%{opacity:0;transform:translateY(11px);}}
@media(max-width:560px){.scroll-cue{display:none;}}

/* staggered reveals so grids cascade in instead of snapping together */
.cards .card:nth-child(2),.steps .step:nth-child(2){transition-delay:.09s;}
.cards .card:nth-child(3),.steps .step:nth-child(3){transition-delay:.18s;}

/* ── motion / mobile guards ───────────────────────────────────────────────── */
@media(max-width:900px){
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--surface);}
  .cabin{transform:none;}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important;}
  .doors{display:none;}
  .reveal{opacity:1;transform:none;}
}

/* ── dumbwaiter microlift section ──────────────────────────────────────────────
   A third signature object: a realistic brushed-stainless dumbwaiter recessed in
   a wall — a half-raised guillotine door reveals the cabin, with a call panel
   beside it. Rendered in 3D (perspective tilt) and links to /dumbwaiter. */
.dw-wrap{display:grid;grid-template-columns:minmax(0,380px) minmax(0,1fr);
  gap:clamp(34px,5vw,72px);align-items:center;}
@media(max-width:900px){.dw-wrap{grid-template-columns:1fr;justify-items:center;}}

/* clickable 3D art → /dumbwaiter */
.dw-art{display:block;text-decoration:none;width:100%;max-width:380px;perspective:1300px;cursor:pointer;}
.dw3d{position:relative;display:flex;align-items:stretch;gap:16px;transform-style:preserve-3d;
  transform:rotateX(4deg) rotateY(-16deg);transition:transform .6s cubic-bezier(.2,.7,.2,1);
  filter:drop-shadow(24px 32px 34px rgba(16,24,40,.34));}
.dw-art:hover .dw3d{transform:rotateX(2deg) rotateY(-7deg);}

/* recessed stainless architrave frame */
.dw3d-frame{position:relative;flex:1;border-radius:10px;padding:14px;
  background:var(--metal);background-size:240% 100%;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75),inset 0 0 0 1px rgba(120,130,145,.55),0 2px 6px rgba(0,0,0,.25);}
.dw3d-frame::before{content:"";position:absolute;inset:0;border-radius:10px;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 1px,transparent 1px 3px);}

/* the dark opening that holds cabin + door */
.dw3d-opening{position:relative;height:300px;border-radius:5px;overflow:hidden;
  background:linear-gradient(180deg,#11141a,#05070b);
  box-shadow:inset 0 0 0 2px rgba(18,22,28,.9),inset 0 14px 30px rgba(0,0,0,.7);}

/* cabin interior */
.dw3d-cabin{position:absolute;inset:0;padding:18px 16px;display:flex;flex-direction:column;
  justify-content:flex-end;gap:18px;}
.dw3d-back{position:absolute;inset:0;
  background:linear-gradient(120deg,#3b4048 0%,#5a616b 30%,#8a919b 50%,#5a616b 70%,#3b4048 100%);
  box-shadow:inset 0 0 44px rgba(0,0,0,.55);}
.dw3d-back::after{content:"";position:absolute;top:-20%;left:10%;width:28%;height:150%;transform:rotate(16deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);}
.dw3d-shelf{position:relative;z-index:1;height:12px;border-radius:3px;
  background:linear-gradient(180deg,#eef1f5,#aab0ba);
  box-shadow:0 5px 8px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.85);}
.dw3d-box{position:absolute;left:16%;bottom:11px;width:46px;height:36px;border-radius:3px;
  background:linear-gradient(180deg,#caa46a,#a97f44);
  box-shadow:0 5px 9px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.3);}
.dw3d-box::after{content:"";position:absolute;left:0;right:0;top:46%;height:2px;background:rgba(0,0,0,.2);}
.dw3d-tray{position:absolute;left:26%;right:26%;bottom:9px;height:8px;border-radius:2px;
  background:linear-gradient(180deg,#e7ecf2,#b7bec8);box-shadow:0 3px 5px rgba(0,0,0,.4);}

/* the half-raised guillotine door */
.dw3d-door{position:absolute;left:0;right:0;top:0;height:42%;background:var(--metal);background-size:240% 100%;
  border-bottom:3px solid #2a2e35;box-shadow:0 9px 18px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.75);}
.dw3d-door::before{content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.16) 0 1px,transparent 1px 3px);}
.dw3d-grip{position:absolute;left:50%;bottom:9px;transform:translateX(-50%);width:46%;height:7px;border-radius:5px;
  background:linear-gradient(180deg,#f2f4f7,#9aa1ab);box-shadow:0 2px 4px rgba(0,0,0,.4);}
.dw3d-lintel{position:absolute;left:0;right:0;top:0;height:9px;background:linear-gradient(180deg,#1a1d23,#0a0c10);}

/* wall-mounted call panel */
.dw3d-cop{position:relative;width:66px;align-self:center;display:grid;gap:9px;justify-items:center;
  background:var(--metal);background-size:240% 100%;border-radius:9px;padding:12px 8px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75),inset 0 0 0 1px rgba(120,130,145,.55),0 2px 6px rgba(0,0,0,.25);}
.dw3d-readout{width:100%;background:#0c0f15;border-radius:5px;padding:6px 0;text-align:center;
  box-shadow:inset 0 0 0 1px rgba(231,203,120,.25),inset 0 2px 6px rgba(0,0,0,.7);}
.dw3d-arrow{display:block;color:#E7CB78;font-size:9px;line-height:1;animation:rise 1.8s ease-in-out infinite;}
.dw3d-num{display:block;font-family:var(--display);font-weight:700;font-size:20px;color:#E7CB78;
  text-shadow:0 0 10px rgba(231,203,120,.7);}
.dw3d-key{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;font-size:11px;color:#3a3f48;
  background:linear-gradient(180deg,#eef1f5,#cdd2da);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 2px 4px rgba(0,0,0,.22);}
.dw3d-key.up{color:#241a06;background:var(--brass-grad);
  box-shadow:0 0 0 3px rgba(199,162,74,.3),inset 0 1px 0 rgba(255,255,255,.5);}

.dw-art-hint{display:block;text-align:center;margin-top:22px;font-family:var(--display);font-weight:600;
  font-size:14px;letter-spacing:.02em;color:var(--brass2);}
.dw-art-hint b{display:inline-block;transition:transform .3s;}
.dw-art:hover .dw-art-hint b{transform:translateX(5px);}

.dw-copy .dw-list{list-style:none;margin:0 0 26px;padding:0;display:grid;gap:11px;}
.dw-copy .dw-list li{position:relative;padding-left:26px;color:var(--ink);font-size:16px;}
.dw-copy .dw-list li::before{content:"";position:absolute;left:0;top:7px;width:13px;height:13px;
  border-radius:50%;background:var(--brass-grad);box-shadow:0 0 0 4px rgba(199,162,74,.14);}
.dw-copy .malta-pill{display:inline-flex;align-items:center;gap:9px;margin-top:18px;
  font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--brass2);
  background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);padding:9px 15px;border-radius:999px;}

@media(max-width:900px){
  .dw-art{max-width:330px;margin:0 auto;}
  .dw3d{transform:none;filter:drop-shadow(0 18px 30px rgba(16,24,40,.26));}
}

/* ── /dumbwaiter dedicated page ───────────────────────────────────────────────── */
.dwp-hero{max-width:1180px;margin:0 auto;padding:clamp(40px,7vh,84px) clamp(20px,5vw,72px) clamp(30px,5vh,56px);
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,440px);gap:clamp(34px,5vw,72px);align-items:center;}
@media(max-width:900px){.dwp-hero{grid-template-columns:1fr;}}
.dwp-hero .dw-art{max-width:440px;justify-self:center;}
.dwp-hero .dw3d-opening{height:360px;}
.dwp-eyebrow{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--brass2);}
.dwp-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(34px,5.6vw,58px);line-height:1.04;
  margin:14px 0 16px;color:var(--ink);}
.dwp-hero .lead{color:var(--muted);font-size:clamp(16px,1.9vw,19px);max-width:52ch;margin:0 0 26px;}
.dwp-models{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 26px;}
.dwp-chip{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--brass2);
  background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);padding:8px 14px;border-radius:999px;}
.dwp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(16px,2.4vw,26px);perspective:1100px;}
.dwp-feat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px 22px;
  box-shadow:var(--shadow);transform-style:preserve-3d;will-change:transform;
  transition:transform .18s ease,box-shadow .3s ease;}
.dwp-feat .ic{transition:transform .18s ease;}
@media(hover:hover) and (pointer:fine){.dwp-feat:hover{box-shadow:var(--shadow-lg);}.dwp-feat:hover .ic{transform:translateZ(30px);}}
.dwp-feat .ic{width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-size:23px;margin-bottom:14px;
  background:radial-gradient(120% 120% at 30% 25%, rgba(199,162,74,.22), rgba(199,162,74,.08));
  border:1px solid rgba(199,162,74,.4);box-shadow:inset 0 1px 0 rgba(255,255,255,.6);}
.dwp-feat h3{font-family:var(--display);font-weight:600;font-size:18px;margin:0 0 7px;color:var(--ink);}
.dwp-feat p{color:var(--muted);font-size:15px;margin:0;}

/* ── interactive Daldoss Microlift configurator popup ──────────────────────────
   Opens from the 3D lift; finish/door/size swaps re-skin the live model; choices
   carry into /quote. Inert until opened, so it costs nothing on first paint. */
.dwc-overlay{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:18px;
  background:rgba(16,18,24,.62);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.dwc-overlay.open{display:flex;}
.dwc-modal{position:relative;width:min(960px,100%);max-height:92vh;overflow:auto;display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,360px);
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);}
@media(max-width:760px){.dwc-modal{grid-template-columns:1fr;}}
.dwc-close{position:absolute;top:12px;right:14px;z-index:5;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--border);background:var(--surface);color:var(--ink);font-size:20px;line-height:1;cursor:pointer;}
.dwc-close:hover{background:var(--surface2);}

/* stage holds the 3D model */
.dwc-stage{position:relative;display:grid;place-items:center;padding:38px 26px 30px;perspective:1300px;
  background:radial-gradient(120% 100% at 50% 0%, #20242c, #11131a);border-radius:var(--r-lg) 0 0 var(--r-lg);}
@media(max-width:760px){.dwc-stage{border-radius:var(--r-lg) var(--r-lg) 0 0;padding:30px 20px 26px;}}
.dwc-cap{position:absolute;left:0;right:0;bottom:13px;text-align:center;font-family:var(--display);
  font-weight:600;font-size:13px;color:#cdd2da;letter-spacing:.02em;}

/* the live model */
.dwc{position:relative;display:flex;gap:16px;transform-style:preserve-3d;--dwc-skin:var(--metal);
  transform:rotateX(4deg) rotateY(-16deg);filter:drop-shadow(20px 28px 30px rgba(0,0,0,.45));}
.dwc-frame{position:relative;width:180px;border-radius:10px;padding:13px;background:var(--dwc-skin);background-size:240% 100%;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),inset 0 0 0 1px rgba(120,130,145,.45),0 2px 6px rgba(0,0,0,.3);
  transition:width .4s ease;}
.dwc.is-metal .dwc-frame::before,.dwc.is-metal .dwc-door::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.16) 0 1px,transparent 1px 3px);}
.dwc-opening{position:relative;height:270px;border-radius:5px;overflow:hidden;
  background:linear-gradient(180deg,#11141a,#05070b);box-shadow:inset 0 0 0 2px rgba(18,22,28,.9),inset 0 14px 30px rgba(0,0,0,.7);
  transition:height .4s ease;}
.dwc-cabin{position:absolute;inset:0;padding:16px 14px;display:flex;flex-direction:column;justify-content:flex-end;gap:16px;}
.dwc-back{position:absolute;inset:0;background:linear-gradient(120deg,#3b4048,#8a919b 50%,#3b4048);box-shadow:inset 0 0 40px rgba(0,0,0,.55);}
.dwc-back::after{content:"";position:absolute;top:-20%;left:10%;width:28%;height:150%;transform:rotate(16deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);}
.dwc-shelf{position:relative;z-index:1;height:12px;border-radius:3px;background:linear-gradient(180deg,#eef1f5,#aab0ba);
  box-shadow:0 5px 8px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.85);}
.dwc-box{position:absolute;left:16%;bottom:11px;width:44px;height:34px;border-radius:3px;background:linear-gradient(180deg,#caa46a,#a97f44);
  box-shadow:0 5px 9px rgba(0,0,0,.5);}
.dwc-tray{position:absolute;left:26%;right:26%;bottom:9px;height:8px;border-radius:2px;background:linear-gradient(180deg,#e7ecf2,#b7bec8);box-shadow:0 3px 5px rgba(0,0,0,.4);}
.dwc-lintel{position:absolute;left:0;right:0;top:0;height:9px;background:linear-gradient(180deg,#1a1d23,#0a0c10);z-index:2;}

/* doors */
.dwc-door{position:absolute;left:0;right:0;top:0;height:42%;background:var(--dwc-skin);background-size:240% 100%;
  border-bottom:3px solid #2a2e35;box-shadow:0 9px 18px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.65);z-index:1;
  transition:transform .55s cubic-bezier(.2,.7,.2,1);}
.dwc-grip{position:absolute;left:50%;bottom:9px;transform:translateX(-50%);width:46%;height:7px;border-radius:5px;
  background:linear-gradient(180deg,#f2f4f7,#9aa1ab);box-shadow:0 2px 4px rgba(0,0,0,.4);}
.dwc--open:not(.dwc--hinged) .dwc-door{transform:translateY(-100%);}
.dwc--hinged .dwc-door{height:100%;transform-origin:left center;border-bottom:none;border-right:3px solid #2a2e35;}
.dwc--hinged .dwc-grip{left:auto;right:8px;bottom:50%;transform:translateY(50%);width:7px;height:34px;}
.dwc--hinged.dwc--open .dwc-door{transform:rotateY(-74deg);}

/* call panel */
/* call station / push-button panel is ALWAYS standard (per Daldoss) — it does
   NOT take the chosen frame/door colour, so it keeps a fixed brushed-steel look. */
.dwc-cop{position:relative;width:58px;align-self:center;display:grid;gap:9px;justify-items:center;
  background:var(--metal);background-size:240% 100%;border-radius:9px;padding:11px 7px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6),inset 0 0 0 1px rgba(120,130,145,.45),0 2px 6px rgba(0,0,0,.3);}
.dwc-readout{width:100%;background:#0c0f15;border-radius:5px;padding:6px 0;text-align:center;box-shadow:inset 0 0 0 1px rgba(231,203,120,.25),inset 0 2px 6px rgba(0,0,0,.7);}
.dwc-arrow{display:block;color:#E7CB78;font-size:9px;line-height:1;animation:rise 1.8s ease-in-out infinite;}
.dwc-num{display:block;font-family:var(--display);font-weight:700;font-size:18px;color:#E7CB78;text-shadow:0 0 10px rgba(231,203,120,.7);}
.dwc-key{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;font-size:10px;color:#3a3f48;
  background:linear-gradient(180deg,#eef1f5,#cdd2da);box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 2px 4px rgba(0,0,0,.22);}
.dwc-key.up{color:#241a06;background:var(--brass-grad);box-shadow:0 0 0 3px rgba(199,162,74,.3),inset 0 1px 0 rgba(255,255,255,.5);}

/* sizes */
.dwc.dwc-s24  .dwc-frame{width:150px;} .dwc.dwc-s24  .dwc-opening{height:200px;}
.dwc.dwc-s50  .dwc-frame{width:180px;} .dwc.dwc-s50  .dwc-opening{height:268px;}
.dwc.dwc-s100 .dwc-frame{width:210px;} .dwc.dwc-s100 .dwc-opening{height:318px;}
.dwc.dwc-s300 .dwc-frame{width:246px;} .dwc.dwc-s300 .dwc-opening{height:366px;}

/* controls */
.dwc-panel{padding:30px 26px 26px;display:flex;flex-direction:column;gap:19px;}
.dwc-title{font-family:var(--display);font-weight:700;font-size:22px;margin:0;color:var(--ink);}
.dwc-psub{color:var(--muted);font-size:14px;margin:-13px 0 0;}
.dwc-group{display:flex;flex-direction:column;gap:9px;}
.dwc-glabel{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--brass2);}
.dwc-swatches{display:flex;flex-wrap:wrap;gap:9px;}
.dwc-sw{width:38px;height:38px;border-radius:10px;border:2px solid var(--border);cursor:pointer;padding:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);transition:transform .15s,border-color .2s,box-shadow .2s;}
.dwc-sw:hover{transform:translateY(-2px);}
.dwc-sw.is-on{border-color:var(--brass);box-shadow:0 0 0 3px rgba(199,162,74,.25);}
.dwc-pick{font-size:13px;color:var(--muted);}
.dwc-seg{display:inline-flex;flex-wrap:wrap;gap:6px;}
.dwc-seg button{font-family:var(--display);font-weight:600;font-size:13px;padding:9px 14px;border-radius:999px;
  border:1px solid var(--border);background:var(--surface);color:var(--ink);cursor:pointer;transition:background .18s,color .18s,border-color .18s;}
.dwc-seg button.is-on{background:var(--brass-grad);color:#241a06;border-color:transparent;}
.dwc-openbtn{align-self:flex-start;font-family:var(--display);font-weight:600;font-size:13px;padding:9px 16px;border-radius:999px;
  border:1px solid var(--border2);background:var(--surface2);color:var(--ink);cursor:pointer;}
.dwc-quote{margin-top:4px;text-align:center;}

/* selection chip carried into the quote page */
.cfg-chip{display:inline-flex;align-items:center;gap:8px;margin:8px 0 16px;font-family:var(--display);font-weight:600;
  font-size:13.5px;color:var(--brass2);background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);padding:9px 15px;border-radius:999px;}
.cfg-chip span{text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--brass);}

/* /configure full page (reuses the .dwc model + .dwc-modal card in normal flow) */
.cfg-page{max-width:1080px;margin:0 auto;padding:clamp(26px,5vh,56px) clamp(20px,5vw,72px) clamp(40px,7vh,80px);}
.cfg-intro{text-align:center;margin:0 auto 30px;max-width:60ch;}
.cfg-intro h1{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,50px);line-height:1.05;margin:12px 0 14px;color:var(--ink);}
.cfg-intro .lead{color:var(--muted);font-size:clamp(16px,1.9vw,18px);margin:0;}
.cfg-page .dwc-modal{margin:0 auto;max-height:none;}
.cfg-page .dwc-panel .back-home{margin-top:4px;}

/* real Daldoss product render (replaces the CSS art on hero + home teaser) */
.dw-photo{display:block;width:auto;max-width:100%;max-height:440px;margin:0 auto;
  background:#fff;border-radius:16px;padding:12px;box-shadow:var(--shadow-lg);}
@media(max-width:900px){.dw-photo{max-height:360px;}}
.cfg-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,280px);gap:clamp(24px,4vw,56px);
  align-items:center;max-width:980px;margin:0 auto 34px;}
.cfg-hero .cfg-intro{text-align:left;margin:0;max-width:none;}
.cfg-real{margin:0;text-align:center;}
.cfg-real img{width:auto;max-height:340px;max-width:100%;background:#fff;border-radius:14px;padding:10px;box-shadow:var(--shadow);}
.cfg-real figcaption{margin-top:8px;font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--muted);}
@media(max-width:760px){.cfg-hero{grid-template-columns:1fr;}.cfg-hero .cfg-intro{text-align:center;}}

/* expanded configurator — 200kg size, RAL colour tray, multi-select options, real-parts strip */
.dwc.dwc-s200 .dwc-frame{width:228px;} .dwc.dwc-s200 .dwc-opening{height:344px;}
.dwc-hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--muted);font-size:11px;}
.dwc-more{align-self:flex-start;margin-top:2px;font-family:var(--display);font-weight:600;font-size:12.5px;
  color:var(--brass2);background:none;border:none;cursor:pointer;padding:2px 0;}
.dwc-more:hover{text-decoration:underline;}
.dwc-tray{display:flex;flex-wrap:wrap;gap:9px;margin-top:4px;}
.dwc-opts{gap:7px;}
.cfg-parts{max-width:1080px;margin:26px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2.5vw,26px);}
.cfg-parts figure{margin:0;background:#fff;border:1px solid var(--border);border-radius:var(--r);
  padding:16px;text-align:center;box-shadow:var(--shadow);}
.cfg-parts img{height:140px;width:auto;max-width:100%;object-fit:contain;}
.cfg-parts figcaption{margin-top:10px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink);}
@media(max-width:620px){.cfg-parts{grid-template-columns:1fr;}.cfg-parts img{height:120px;}}

/* desktop: wider configurator card with the control groups in two columns */
@media(min-width:861px){
  .cfg-page .dwc-modal{width:100%;max-width:1040px;grid-template-columns:minmax(0,390px) minmax(0,1fr);}
  .cfg-page .dwc-panel{display:grid;grid-template-columns:1fr 1fr;column-gap:26px;row-gap:18px;align-content:start;}
  .cfg-page .dwc-panel>.dwc-title,
  .cfg-page .dwc-panel>.dwc-psub,
  .cfg-page .dwc-panel>.dwc-quote,
  .cfg-page .dwc-panel>.back-home{grid-column:1 / -1;}
}

@media(prefers-reduced-motion:reduce){.dwc-door,.dwc-frame,.dwc-opening{transition:none;}}

/* ── /dumbwaiter scroll lift — a cabin rides down the left edge as you scroll and
   its doors open on each new section. Desktop only (slim left margin). ──────── */
/* top:62px so the floor readout ("G") clears the sticky header instead of
   hiding behind it. */
.liftshaft{position:fixed;top:62px;bottom:0;left:0;width:78px;z-index:20;pointer-events:none;display:block;}
/* mobile: slim + translucent left-edge accent (never blocks taps) */
@media(max-width:1079px){
  .liftshaft{width:34px;opacity:.5;}
  .liftshaft .ls-readout{top:10px;padding:3px 6px;border-radius:8px;}
  .liftshaft .ls-arrow{font-size:7px;}
  .liftshaft .ls-floor{font-size:12px;}
  .liftshaft .ls-rail{top:48px;width:4px;}
  .liftshaft .ls-car{top:48px;width:22px;margin-left:-11px;height:84px;}
}
.liftshaft .ls-readout{position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:1px;background:#101218;color:#E7CB78;
  padding:6px 11px;border-radius:10px;box-shadow:var(--shadow),inset 0 0 0 1px rgba(231,203,120,.18);}
.ls-arrow{font-size:9px;line-height:1;animation:rise 1.8s ease-in-out infinite;}
.ls-floor{font-family:var(--display);font-weight:700;font-size:18px;line-height:1;text-shadow:0 0 10px rgba(231,203,120,.6);}
.ls-rail{position:absolute;top:58px;bottom:16px;left:50%;width:6px;transform:translateX(-50%);border-radius:4px;
  background:linear-gradient(180deg,#E7CB78,#B68F3C);opacity:.45;}
.ls-car{position:absolute;left:50%;top:58px;width:54px;margin-left:-27px;height:120px;will-change:transform;}
.ls-cabin{position:relative;width:100%;height:100%;border-radius:8px;overflow:hidden;
  background:linear-gradient(180deg,#2b2f37,#15171c);box-shadow:var(--shadow-lg),inset 0 0 0 1px rgba(255,255,255,.06);}
.ls-interior{position:absolute;inset:6px;border-radius:5px;
  background:linear-gradient(120deg,#3b4048,#8a919b 50%,#3b4048);box-shadow:inset 0 0 18px rgba(0,0,0,.6);}
.ls-interior::after{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:60%;height:4px;border-radius:3px;
  background:rgba(255,250,240,.85);box-shadow:0 0 12px 3px rgba(255,247,214,.6);}
.ls-door{position:absolute;top:0;bottom:0;width:50%;z-index:1;background:var(--metal);background-size:200% 100%;
  box-shadow:inset 0 0 14px rgba(20,22,27,.25);transition:transform .5s cubic-bezier(.2,.7,.2,1);}
.ls-door.l{left:0;border-right:1px solid rgba(20,22,27,.5);}
.ls-door.r{right:0;}
.ls-car.is-open .ls-door.l{transform:translateX(-100%);}
.ls-car.is-open .ls-door.r{transform:translateX(100%);}
@media(prefers-reduced-motion:reduce){.ls-door{transition:none;}}

/* ── maintenance agreement / service contract ─────────────────────────────────
   Card-band pairing the pitch with a dark "brands we service" panel. Reuses the
   brass rail accent + pill so it sits inside the Brass & Rail identity. */
.contract-band{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,360px);
  gap:clamp(28px,4.5vw,58px);align-items:center;overflow:hidden;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:clamp(28px,5vw,54px);box-shadow:var(--shadow-lg);}
.contract-band::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--rail);}
@media(max-width:900px){.contract-band{grid-template-columns:1fr;}}
.contract-copy h2{margin-top:.3em;}
.contract-brands{align-self:stretch;border-radius:var(--r);padding:24px 22px;color:#fff;
  background:linear-gradient(135deg,#191b22 0%,#24272f 100%);box-shadow:var(--shadow);}
.brand-title{display:block;font-family:var(--display);font-weight:600;font-size:13px;
  letter-spacing:.03em;color:#E7CB78;margin-bottom:14px;}
.brand-grid{display:flex;flex-wrap:wrap;gap:8px;}
.brand-chip{font-family:var(--display);font-weight:600;font-size:13px;color:#e7e9ee;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);padding:7px 12px;border-radius:999px;}
.brand-note{color:#c7cad3;font-size:13px;line-height:1.5;margin:14px 0 0;}

/* ── real installations gallery ───────────────────────────────────────────── */
.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:clamp(14px,2.2vw,22px);perspective:1200px;}
.g-item{position:relative;margin:0;border-radius:var(--r);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow);background:var(--surface);
  transform-style:preserve-3d;will-change:transform;transition:transform .2s ease,box-shadow .3s ease;}
.g-item img{width:100%;height:248px;object-fit:cover;display:block;transition:transform .5s ease;transform:translateZ(20px);}
@media(hover:hover) and (pointer:fine){.g-item:hover{box-shadow:var(--shadow-lg);}.g-item:hover img{transform:translateZ(20px) scale(1.06);}}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 13px;
  font-family:var(--display);font-weight:600;font-size:14px;color:#fff;
  background:linear-gradient(180deg,transparent,rgba(16,18,24,.82));}

/* ── real lift photo (replaces the CSS art in the 'finished to last' section) ── */
.cabin-photo{width:100%;max-width:420px;height:auto;border-radius:22px;
  border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-lg);}
@media(max-width:900px){.cabin-photo{max-width:100%;}}

/* ── maintenance-plan cards (/contract) ───────────────────────────────────── */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;}
@media(max-width:900px){.plans{grid-template-columns:1fr;}}
.plan{position:relative;display:flex;flex-direction:column;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-lg);padding:32px 26px 28px;box-shadow:var(--shadow);}
.plan::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--rail);
  border-radius:var(--r-lg) var(--r-lg) 0 0;}
.plan-pop{border-color:var(--brass);box-shadow:var(--shadow-lg);transform:translateY(-6px);}
@media(max-width:900px){.plan-pop{transform:none;}}
.plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);white-space:nowrap;
  background:var(--brass-grad);color:#241a06;font-family:var(--display);font-weight:700;font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:999px;
  box-shadow:0 6px 16px rgba(160,123,40,.4);}
.plan-name{font-family:var(--display);font-weight:700;font-size:20px;color:var(--ink);margin:4px 0 0;}
.plan-visits{font-family:var(--display);font-weight:700;font-size:42px;letter-spacing:-.02em;
  color:var(--ink);line-height:1;margin:12px 0 2px;}
.plan-visits span{font-size:15px;font-weight:600;color:var(--muted);letter-spacing:0;}
.plan-tag{color:var(--muted);font-size:14px;margin:0 0 18px;}
.plan-list{list-style:none;margin:0 0 24px;padding:0;display:grid;gap:10px;flex:1;}
.plan-list li{position:relative;padding-left:26px;font-size:14.5px;color:var(--ink);}
.plan-list li::before{content:"✓";position:absolute;left:0;top:0;font-weight:700;color:var(--brass2);}
.plan .btn{margin-top:auto;}
.plan{transition:transform .2s cubic-bezier(.2,.7,.2,1),box-shadow .3s ease;will-change:transform;}
@media(hover:hover) and (pointer:fine){
  .plan:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
  .plan-pop:hover{transform:translateY(-12px);}
}

/* ── configurator: step-by-step wizard (/configure) ───────────────────────────
   One question at a time; the live 3D model updates as you answer, so the panel
   is a single column even on desktop (overrides the old two-column layout). */
@media(min-width:861px){
  .cfg-page .dwc-panel{display:flex;flex-direction:column;column-gap:0;}
  .cfg-page .dwc-panel>*{grid-column:auto;}
}
.cfg-skip{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;margin-top:18px;}
.cfg-skip-note{color:var(--muted);font-size:13px;max-width:34ch;line-height:1.45;}
.wiz-head{margin-bottom:4px;}
.wiz-prog{height:8px;border-radius:999px;background:var(--surface2);overflow:hidden;border:1px solid var(--border);}
.wiz-bar{display:block;height:100%;width:12.5%;background:var(--brass-grad);border-radius:999px;
  transition:width .45s cubic-bezier(.2,.7,.2,1);box-shadow:inset 0 1px 0 rgba(255,255,255,.5);}
.wiz-meta{margin-top:9px;font-family:var(--display);font-size:13px;color:var(--muted);letter-spacing:.02em;}
.wiz-meta b{color:var(--ink);}
.wiz-step{animation:wizIn .35s cubic-bezier(.2,.7,.2,1);}
@keyframes wizIn{from{opacity:0;transform:translateX(10px);}to{opacity:1;transform:none;}}
.wiz-hint{color:var(--muted);font-size:13.5px;line-height:1.5;margin:12px 0 0;}
.wiz-nav{display:flex;align-items:center;gap:12px;margin-top:22px;}
.wiz-nav .wiz-next{margin-left:auto;}
.wiz-back{align-self:center;}
.wiz-review{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:0;border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;}
.wiz-review li{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:12px 16px;font-size:14.5px;background:var(--surface);}
.wiz-review li:nth-child(odd){background:var(--surface2);}
.wiz-review li span{color:var(--muted);font-family:var(--display);font-weight:600;font-size:12.5px;
  letter-spacing:.04em;text-transform:uppercase;}
.wiz-review li b{color:var(--ink);text-align:right;}
.wiz-daldoss{margin:16px 0 0;font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--brass2);
  background:rgba(199,162,74,.12);border:1px solid rgba(199,162,74,.32);padding:11px 15px;border-radius:12px;}

/* a touch more presence for the live model stage */
.cfg-page .dwc-stage{min-height:420px;}
.dwc-cap{font-size:13px;}

/* finish (frame + doors) takes a real Daldoss texture image OR a flat RAL colour;
   cover keeps the brushed-steel grain crisp instead of stretching it. The call
   panel keeps its own standard steel (set above), so colour never touches it. */
.dwc-frame, .dwc-door{background-size:cover;background-position:center;background-repeat:no-repeat;}
.dwc-sw{background-size:cover !important;background-position:center;}

/* ── contact section + footer contact ─────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1100px;}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;}}
.contact-card{position:relative;display:block;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:28px 26px;box-shadow:var(--shadow);color:inherit;
  transform-style:preserve-3d;will-change:transform;transition:transform .18s ease,box-shadow .3s ease;overflow:hidden;}
.contact-card::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--rail);}
@media(hover:hover) and (pointer:fine){.contact-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);}}
.contact-card .ic{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;font-size:24px;margin-bottom:14px;
  background:radial-gradient(120% 120% at 30% 25%, rgba(199,162,74,.22), rgba(199,162,74,.08));
  border:1px solid rgba(199,162,74,.4);box-shadow:inset 0 1px 0 rgba(255,255,255,.6);}
.contact-card h3{font-family:var(--display);font-weight:600;font-size:18px;margin:0 0 6px;color:var(--ink);}
.contact-card .c-val{margin:0;color:var(--ink);font-size:16px;font-weight:500;word-break:break-word;}
.contact-card .c-act{display:inline-block;margin-top:12px;font-family:var(--display);font-weight:600;font-size:13px;color:var(--brass2);}
.contact-card.wa .ic{background:radial-gradient(120% 120% at 30% 25%, rgba(37,211,102,.24), rgba(37,211,102,.08));
  border-color:rgba(37,211,102,.5);}
.contact-card.wa .c-act{color:#1f9d57;}
.foot-contact{display:flex;flex-direction:column;gap:4px;}
.foot-contact a{color:var(--ink);font-weight:600;}
.foot-contact a:hover{color:var(--brass2);}

/* ── floating menu button + nav popup (form pages without a top nav) ───────── */
.navfab{position:fixed;top:14px;left:14px;z-index:60;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);cursor:pointer;
  background:rgba(252,252,253,.9);border:1px solid var(--border2);border-radius:999px;padding:9px 15px;
  box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:border-color .2s,color .2s,transform .15s;}
.navfab:hover{border-color:var(--brass);color:var(--brass2);transform:translateY(-1px);}
.navpop{position:fixed;inset:0;z-index:70;display:none;align-items:flex-start;justify-content:center;
  padding:66px 18px 18px;background:rgba(16,18,24,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.navpop.open{display:flex;}
.navpop-card{width:min(360px,100%);background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:navpopIn .22s cubic-bezier(.2,.7,.2,1);}
@keyframes navpopIn{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:none;}}
.navpop-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);}
.navpop-head b{font-family:var(--display);font-weight:700;font-size:14px;color:var(--ink);}
.navpop-x{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);
  color:var(--ink);font-size:18px;line-height:1;cursor:pointer;}
.navpop-x:hover{background:var(--surface2);}
.navpop-card a{display:flex;align-items:center;gap:13px;padding:15px 18px;color:var(--ink);text-decoration:none;
  font-family:var(--display);font-weight:600;font-size:16px;border-top:1px solid var(--border);}
.navpop-card a:first-of-type{border-top:none;}
.navpop-card a:hover{background:var(--surface2);color:var(--brass2);}
.navpop-card a .e{font-size:18px;width:24px;text-align:center;}
