/* =========================================================================
   Dabujii Elevators — site.css
   Industrial-premium: brushed steel, brass accent, control-blue glow.
   ========================================================================= */

:root{
  --brass:#C9A24A; --glow:#2D9CDB; --ink:#0C1116;
  --r:14px; --rs:10px;
  --ease:cubic-bezier(.16,1,.3,1);
  --steel:linear-gradient(120deg,#2a333d 0%,#3c4856 22%,#222a32 23%,#39434f 48%,#20272e 60%,#37414c 80%,#252d35 100%);
  --steel-light:linear-gradient(120deg,#cbd3db 0%,#eef2f6 22%,#c2cbd4 23%,#e6ebf0 48%,#bcc6cf 60%,#e9eef2 80%,#cdd5dd 100%);
}

html[data-theme="dark"]{
  --bg:var(--ink); --surface:#131a22; --surface2:#1a232d; --raised:#1f2935;
  --text:#E7ECF2; --muted:#93A1AE; --line:rgba(255,255,255,.09);
  --line2:rgba(255,255,255,.14); --door:var(--steel); --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --glass:rgba(19,26,34,.72);
}
html[data-theme="light"]{
  --bg:#EAEEF2; --surface:#FFFFFF; --surface2:#F4F7FA; --raised:#FFFFFF;
  --text:#16202B; --muted:#5C6B7A; --line:rgba(12,17,22,.10);
  --line2:rgba(12,17,22,.16); --door:var(--steel-light); --shadow:0 24px 60px -26px rgba(20,40,70,.28);
  --glass:rgba(255,255,255,.78);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:'Inter',system-ui,sans-serif; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  transition:background .5s var(--ease),color .5s var(--ease);
}
h1,h2,h3,h4{font-family:'Sora',sans-serif; line-height:1.1; margin:0; letter-spacing:-.02em}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.ic{display:inline-block; vertical-align:middle}
.wrap{width:min(1180px,92vw); margin-inline:auto}

/* ----------------------------------------------------- shared bits */
.kicker{
  display:inline-flex; align-items:center; gap:.55rem; font-family:'Share Tech Mono',monospace;
  text-transform:uppercase; letter-spacing:.22em; font-size:.72rem; color:var(--brass);
  margin-bottom:1rem;
}
.led{width:8px; height:8px; border-radius:50%; background:var(--glow);
  box-shadow:0 0 10px var(--glow),0 0 2px var(--glow); animation:blink 2.4s infinite}
@keyframes blink{0%,92%,100%{opacity:1}96%{opacity:.25}}

.btn{display:inline-flex; align-items:center; gap:.5rem; padding:.85rem 1.5rem; border-radius:var(--rs);
  font-weight:600; font-size:.95rem; cursor:pointer; border:1px solid transparent;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s,color .3s; will-change:transform}
.btn .arr{transition:transform .3s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-brass{background:linear-gradient(135deg,var(--brass),#a9842f); color:#1a1407;
  box-shadow:0 10px 26px -10px rgba(201,162,74,.6)}
.btn-brass:hover{transform:translateY(-2px); box-shadow:0 16px 34px -10px rgba(201,162,74,.75)}
.btn-ghost{background:transparent; border-color:var(--line2); color:var(--text)}
.btn-ghost:hover{border-color:var(--brass); color:var(--brass); transform:translateY(-2px)}

/* ===================================================================
   PRELOADER — elevator doors part to reveal the page
   =================================================================== */
#preloader{position:fixed; inset:0; z-index:2000; background:var(--ink);
  display:flex; align-items:center; justify-content:center}
#preloader.gone{opacity:0; visibility:hidden; transition:opacity .6s ease .2s,visibility 0s .8s}
.pre-frame{position:relative; width:100%; height:100%; display:flex; align-items:center; justify-content:center}
.pre-doors{position:absolute; inset:0; display:flex}
.pre-door{width:50%; height:100%; background:var(--steel);
  box-shadow:inset 0 0 60px rgba(0,0,0,.6); transition:transform 1s var(--ease) .35s}
.pre-door-l{border-right:1px solid rgba(0,0,0,.5)}
.pre-door-r{border-left:1px solid rgba(255,255,255,.05)}
#preloader.open .pre-door-l{transform:translateX(-100%)}
#preloader.open .pre-door-r{transform:translateX(100%)}
.pre-display{position:absolute; top:8%; left:50%; transform:translateX(-50%); z-index:3;
  font-family:'Share Tech Mono',monospace; font-size:2rem; color:var(--glow);
  background:#06090c; padding:.4rem 1.4rem; border-radius:6px; border:1px solid rgba(255,255,255,.08);
  box-shadow:0 0 24px rgba(45,156,219,.4),inset 0 0 12px rgba(0,0,0,.8); letter-spacing:.1em}
.pre-brand{position:absolute; bottom:9%; left:50%; transform:translateX(-50%); z-index:3;
  color:var(--brass); font-family:'Sora',sans-serif; font-weight:800; letter-spacing:.3em;
  text-transform:uppercase; font-size:1rem; opacity:.9}

/* ===================================================================
   TOPBAR
   =================================================================== */
.topbar{position:fixed; top:0; left:0; right:0; z-index:900; display:flex; align-items:center;
  justify-content:space-between; gap:1rem; padding:.85rem clamp(1rem,4vw,2.4rem);
  background:transparent; transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent}
.topbar.solid{background:var(--glass); backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line); padding-top:.6rem; padding-bottom:.6rem}
.brand{display:flex; align-items:center; gap:.6rem}
.brand-logo{height:40px; width:auto}
.brand-mark{display:grid; place-items:center; width:38px; height:38px; border-radius:9px;
  background:linear-gradient(135deg,var(--brass),#8d6e24); color:#1a1407;
  box-shadow:0 6px 18px -6px rgba(201,162,74,.7)}
.brand-name{font-family:'Sora',sans-serif; font-weight:800; font-size:1.15rem; letter-spacing:-.01em}
.brand-name em{color:var(--brass); font-style:normal; font-weight:500; margin-left:.25rem; opacity:.9}
.brand-name.big{font-size:1.6rem}
.topnav{display:flex; gap:1.6rem}
.topnav a{font-size:.92rem; color:var(--muted); font-weight:500; position:relative; padding:.3rem 0}
.topnav a::after{content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--brass);
  transition:width .3s var(--ease)}
.topnav a:hover{color:var(--text)}
.topnav a:hover::after{width:100%}
.topbar-tools{display:flex; align-items:center; gap:1rem}
.cta-call{display:inline-flex; align-items:center; gap:.5rem; padding:.6rem 1.1rem; border-radius:var(--rs);
  background:linear-gradient(135deg,var(--brass),#a9842f); color:#1a1407; font-weight:600; font-size:.9rem;
  transition:transform .3s var(--ease),box-shadow .3s}
.cta-call:hover{transform:translateY(-2px); box-shadow:0 12px 26px -10px rgba(201,162,74,.7)}
.call-dot{width:8px; height:8px; border-radius:50%; background:#1a1407;
  box-shadow:0 0 0 0 rgba(26,20,7,.5); animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(26,20,7,.5)}70%{box-shadow:0 0 0 8px rgba(26,20,7,0)}100%{box-shadow:0 0 0 0 rgba(26,20,7,0)}}

/* theme toggle */
.ctrl-btn{background:none; border:none; cursor:pointer; padding:0}
.theme-toggle .tg-track{display:block; width:48px; height:26px; border-radius:20px;
  background:var(--surface2); border:1px solid var(--line2); position:relative; transition:background .4s}
.theme-toggle .tg-knob{position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%;
  background:var(--brass); box-shadow:0 0 12px var(--brass); transition:transform .4s var(--ease),background .4s}
html[data-theme="light"] .theme-toggle .tg-knob{transform:translateX(22px); background:var(--glow); box-shadow:0 0 12px var(--glow)}

/* ===================================================================
   FLOOR DISPLAY (seven-seg style)
   =================================================================== */
.floor-display{position:fixed; top:50%; left:clamp(.6rem,2vw,1.4rem); transform:translateY(-50%);
  z-index:850; background:#06090c; border:1px solid rgba(255,255,255,.1); border-radius:10px;
  padding:.6rem .7rem; text-align:center; min-width:62px;
  box-shadow:0 0 24px rgba(45,156,219,.25),inset 0 0 14px rgba(0,0,0,.85); opacity:0;
  transition:opacity .5s .8s}
.floor-display.show{opacity:1}
.fd-dir{display:block; color:var(--glow); font-size:.9rem; line-height:1; margin-bottom:.2rem;
  text-shadow:0 0 8px var(--glow); transition:opacity .3s,transform .3s}
.fd-dir.down{transform:rotate(180deg)}
.fd-num{display:block; font-family:'Share Tech Mono',monospace; font-size:2rem; color:var(--brass);
  text-shadow:0 0 12px rgba(201,162,74,.6); line-height:1}

/* ===================================================================
   ELEVATOR BUTTON PANEL (navigation)
   =================================================================== */
.panel{position:fixed; top:50%; right:clamp(.5rem,2vw,1.4rem); transform:translateY(-50%);
  z-index:850; background:var(--surface); border:1px solid var(--line2); border-radius:18px;
  padding:.7rem .55rem; display:flex; flex-direction:column; gap:.5rem; align-items:center;
  box-shadow:var(--shadow); backdrop-filter:blur(6px)}
.panel-head{color:var(--brass); opacity:.7; padding-bottom:.2rem; border-bottom:1px solid var(--line);
  width:100%; display:grid; place-items:center}
.panel-buttons{display:flex; flex-direction:column; gap:.5rem}
.floor-btn{position:relative; width:40px; height:40px; border-radius:50%; border:1px solid var(--line2);
  background:var(--surface2); color:var(--muted); cursor:pointer; display:grid; place-items:center;
  font-family:'Share Tech Mono',monospace; font-size:.95rem; transition:all .3s var(--ease)}
.floor-btn .fb-num{transition:transform .3s}
.floor-btn .fb-label{position:absolute; right:calc(100% + 12px); top:50%; transform:translateY(-50%) translateX(6px);
  white-space:nowrap; background:var(--surface); border:1px solid var(--line2); padding:.3rem .6rem;
  border-radius:8px; font-family:'Inter',sans-serif; font-size:.78rem; color:var(--text); opacity:0;
  pointer-events:none; transition:opacity .25s,transform .25s; box-shadow:var(--shadow)}
.floor-btn:hover{border-color:var(--brass); color:var(--brass); transform:scale(1.06)}
.floor-btn:hover .fb-label{opacity:1; transform:translateY(-50%) translateX(0)}
.floor-btn.active{background:radial-gradient(circle at 50% 40%,rgba(201,162,74,.35),transparent 70%);
  border-color:var(--brass); color:var(--brass); box-shadow:0 0 16px -2px rgba(201,162,74,.6)}
.panel-foot{border-top:1px solid var(--line); padding-top:.4rem; width:100%; display:grid; place-items:center}
.floor-btn.alarm{border-color:rgba(229,90,90,.5); color:#e25b5b}
.floor-btn.alarm .bell{font-size:.7rem; animation:blink 1.6s infinite}
.floor-btn.alarm:hover{border-color:#e25b5b; box-shadow:0 0 14px -2px rgba(226,91,91,.6)}

/* shaft rails */
.rail{position:fixed; top:0; bottom:0; width:2px; z-index:5; pointer-events:none;
  background:linear-gradient(var(--line2),transparent 40%,var(--line2)); opacity:.4}
.rail-l{left:calc(clamp(.6rem,2vw,1.4rem) + 30px)} .rail-r{right:calc(clamp(.5rem,2vw,1.4rem) + 30px)}
@media (max-width:980px){.rail{display:none}}

/* ===================================================================
   FLOORS / SECTIONS
   =================================================================== */
.floor{position:relative; min-height:100vh; display:flex; align-items:center; padding:7rem 0}
.section.alt{background:
  radial-gradient(1200px 600px at 80% -10%,rgba(45,156,219,.06),transparent 60%),var(--surface)}
.head{max-width:760px; margin-bottom:3rem}
.head h2{font-size:clamp(1.8rem,3.6vw,2.8rem); margin-bottom:.8rem}
.head-lead{color:var(--muted); font-size:1.05rem; max-width:640px}

/* reveal */
.reveal{opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease) var(--d,0ms),transform .8s var(--ease) var(--d,0ms)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none}}

/* ===================================================================
   HERO / LOBBY
   =================================================================== */
.hero{align-items:center; overflow:hidden}
.hero-copy{width:min(720px,92vw); margin-left:clamp(1rem,7vw,5rem); position:relative; z-index:3}
.hero-copy h1{font-size:clamp(2.3rem,5.5vw,4.4rem); font-weight:800; margin-bottom:1.3rem;
  background:linear-gradient(180deg,var(--text),color-mix(in srgb,var(--text) 60%,var(--muted)));
  -webkit-background-clip:text; background-clip:text}
.hero-copy>p{color:var(--muted); font-size:1.12rem; max-width:600px; margin-bottom:2rem}
.hero-actions{display:flex; gap:1rem; flex-wrap:wrap}
.hero-photo{position:absolute; inset:0; z-index:0; background-size:cover; background-position:center;
  opacity:.16; filter:saturate(.8)}
.scroll-hint{position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  font-family:'Share Tech Mono',monospace; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); display:flex; flex-direction:column; align-items:center; gap:.5rem}
.scroll-hint span{width:1px; height:34px; background:linear-gradient(var(--brass),transparent); position:relative; overflow:hidden}
.scroll-hint span::after{content:""; position:absolute; top:-50%; left:0; width:100%; height:50%;
  background:var(--brass); animation:drop 1.8s var(--ease) infinite}
@keyframes drop{0%{top:-50%}100%{top:120%}}

/* animated shaft */
.hero-shaft{position:absolute; right:clamp(2rem,12vw,9rem); top:0; bottom:0; width:160px; z-index:1;
  display:flex; justify-content:center}
@media (max-width:900px){.hero-shaft{opacity:.35; right:1rem; width:90px}}
.hero-shaft::before{content:""; position:absolute; inset:0; border-left:1px solid var(--line2);
  border-right:1px solid var(--line2); background:linear-gradient(var(--surface2),transparent)}
.cable{position:absolute; top:0; left:50%; width:2px; height:100%; background:var(--line2); transform:translateX(-26px)}
.car{position:absolute; left:50%; transform:translateX(-50%); width:118px; height:150px; border-radius:6px;
  background:var(--door); border:1px solid var(--line2); box-shadow:var(--shadow);
  animation:ride 9s var(--ease) infinite; overflow:hidden}
.car-roof{height:10px; background:linear-gradient(#444,#222); border-bottom:1px solid rgba(0,0,0,.4)}
html[data-theme="light"] .car-roof{background:linear-gradient(#aeb7c0,#8b95a0)}
.car-doors{position:relative; height:calc(100% - 10px); display:flex}
.car-door{width:50%; height:100%; background:linear-gradient(120deg,rgba(255,255,255,.06),transparent);
  border:1px solid rgba(0,0,0,.25); animation:cardoor 9s var(--ease) infinite}
.cd-r{animation-direction:reverse}
.car-seam{position:absolute; left:50%; top:0; bottom:0; width:1px; background:rgba(0,0,0,.4); transform:translateX(-.5px)}
.counterweight{position:absolute; left:50%; transform:translateX(28px); width:14px; height:50px;
  background:linear-gradient(#555,#333); border-radius:3px; animation:counter 9s var(--ease) infinite}
.shaft-floor{position:absolute; left:0; right:0; height:1px; background:var(--line2);
  top:calc(11% * var(--i) + 6%); opacity:.5}
@keyframes ride{0%,100%{top:62%}45%{top:8%}50%{top:8%}95%{top:62%}}
@keyframes counter{0%,100%{top:8%}45%{top:60%}50%{top:60%}95%{top:8%}}
@keyframes cardoor{0%,38%{transform:translateX(0)}46%,54%{transform:translateX(var(--o,-50%))}62%,100%{transform:translateX(0)}}
.cd-l{--o:-50%}.cd-r{--o:50%}
@media (prefers-reduced-motion:reduce){.car,.counterweight,.car-door{animation:none}.car{top:30%}}

/* ===================================================================
   SERVICES — landing doors that open on hover/focus
   =================================================================== */
.services{display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:1.4rem}
.svc{position:relative; border-radius:var(--r); background:var(--surface); border:1px solid var(--line);
  overflow:hidden; min-height:280px; transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.svc:hover,.svc:focus-visible{transform:translateY(-6px); border-color:var(--brass); box-shadow:var(--shadow); outline:none}
.svc-doors{position:absolute; inset:0; z-index:2; display:flex; pointer-events:none}
.svc-door{width:50%; height:100%; background:var(--door); border:1px solid rgba(0,0,0,.2);
  transition:transform .7s var(--ease)}
.svc-door.sl{border-right:1px solid rgba(0,0,0,.35)}
.svc-num{position:absolute; top:1rem; left:50%; transform:translateX(-50%); z-index:3;
  font-family:'Share Tech Mono',monospace; color:var(--glow); font-size:.85rem;
  background:#06090c; padding:.2rem .55rem; border-radius:5px; border:1px solid rgba(255,255,255,.1)}
.svc:hover .svc-door.sl,.svc:focus-visible .svc-door.sl{transform:translateX(-100%)}
.svc:hover .svc-door.sr,.svc:focus-visible .svc-door.sr{transform:translateX(100%)}
.svc:hover .svc-num,.svc:focus-visible .svc-num{opacity:0; transition:opacity .2s}
.svc-body{position:relative; z-index:1; padding:1.8rem 1.6rem; height:100%; display:flex; flex-direction:column}
.svc-ic{width:54px; height:54px; border-radius:12px; display:grid; place-items:center; color:var(--brass);
  background:linear-gradient(135deg,rgba(201,162,74,.16),transparent); border:1px solid var(--line2); margin-bottom:1.1rem}
.svc-body h3{font-size:1.2rem; margin-bottom:.7rem}
.svc-body p{color:var(--muted); font-size:.95rem}

/* ===================================================================
   ABOUT — split + control panel card
   =================================================================== */
.split{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center}
@media (max-width:880px){.split{grid-template-columns:1fr}}
.split-copy h2{font-size:clamp(1.7rem,3.4vw,2.6rem); margin-bottom:1.2rem}
.split-copy p{color:var(--muted); margin-bottom:1rem}
.split-copy .btn{margin-top:.6rem}
.panel-card{position:relative; border-radius:var(--r); background:var(--surface); border:1px solid var(--line2);
  padding:1.4rem; box-shadow:var(--shadow); overflow:hidden}
.pc-disp{display:flex; align-items:center; gap:.55rem; font-family:'Share Tech Mono',monospace; font-size:.78rem;
  color:var(--glow); background:#06090c; padding:.5rem .8rem; border-radius:8px; letter-spacing:.18em; margin-bottom:1rem;
  border:1px solid rgba(255,255,255,.08)}
.pc-led{width:8px; height:8px; border-radius:50%; background:#4be38a; box-shadow:0 0 10px #4be38a; animation:blink 2s infinite}
.pc-grid{display:grid; grid-template-columns:1fr 1fr; gap:.7rem}
.pc-cell{display:flex; align-items:center; gap:.6rem; padding:.85rem; border-radius:10px;
  background:var(--surface2); border:1px solid var(--line); color:var(--brass); font-size:.85rem; font-weight:600}
.pc-cell span{color:var(--text)}
.pc-photo{margin-top:1rem; height:160px; border-radius:10px; background-size:cover; background-position:center}

/* ===================================================================
   STORY + FOUNDER + STATS
   =================================================================== */
.story-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:2.4rem; align-items:start; margin-bottom:3.5rem}
@media (max-width:880px){.story-grid{grid-template-columns:1fr}}
.story-text p{color:var(--muted); margin-bottom:1rem; font-size:1.02rem}
.founder{background:var(--surface); border:1px solid var(--line2); border-left:3px solid var(--brass);
  border-radius:var(--r); padding:1.6rem; box-shadow:var(--shadow)}
.founder-tag{display:inline-flex; align-items:center; gap:.5rem; color:var(--brass); font-weight:700;
  font-family:'Sora',sans-serif; margin-bottom:.9rem; font-size:1.05rem}
.founder p{color:var(--muted); font-size:.95rem}

.stats{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden}
.stat{background:var(--surface); padding:2rem 1.4rem; text-align:center}
.stat-num{font-family:'Sora',sans-serif; font-weight:800; font-size:clamp(2.2rem,4vw,3.2rem);
  color:var(--brass); line-height:1; display:flex; justify-content:center; align-items:baseline; gap:.05em}
.stat-prefix,.stat-suffix{font-size:.6em}
.stat-label{color:var(--muted); font-size:.88rem; margin-top:.7rem}

/* ===================================================================
   WHY — feature tiles
   =================================================================== */
.features{display:grid; grid-template-columns:repeat(auto-fit,minmax(255px,1fr)); gap:1.4rem}
.feat{position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:2rem 1.6rem; overflow:hidden; transition:transform .4s var(--ease),border-color .4s}
.feat:hover{transform:translateY(-6px); border-color:var(--brass)}
.feat::before{content:""; position:absolute; left:0; top:0; height:3px; width:0; background:var(--brass); transition:width .5s var(--ease)}
.feat:hover::before{width:100%}
.feat-ic{width:52px; height:52px; border-radius:12px; display:grid; place-items:center; color:var(--glow);
  background:linear-gradient(135deg,rgba(45,156,219,.16),transparent); border:1px solid var(--line2); margin-bottom:1.1rem}
.feat h3{font-size:1.18rem; margin-bottom:.6rem}
.feat p{color:var(--muted); font-size:.92rem}
.feat-no{position:absolute; right:1.1rem; top:.9rem; font-family:'Share Tech Mono',monospace;
  font-size:1.6rem; color:var(--line2); font-weight:700}

/* ===================================================================
   CONTACT + QUOTE
   =================================================================== */
.contact{background:
  radial-gradient(900px 500px at 10% 120%,rgba(201,162,74,.08),transparent 60%),var(--bg)}
.contact-info h2{font-size:clamp(1.7rem,3.4vw,2.5rem); margin-bottom:1.6rem; max-width:520px}
.contact-list{list-style:none; padding:0; margin:0 0 1.6rem; display:flex; flex-direction:column; gap:1.1rem}
.contact-list li{display:flex; gap:.9rem; align-items:flex-start; color:var(--muted)}
.contact-list li .ic{color:var(--brass); flex:none; margin-top:.15rem}
.contact-list a:hover{color:var(--brass)}
.socials{display:flex; gap:.6rem}
.socials a{width:40px; height:40px; border-radius:10px; display:grid; place-items:center;
  border:1px solid var(--line2); color:var(--muted); font-size:.8rem; font-weight:700; transition:all .3s}
.socials a:hover{border-color:var(--brass); color:var(--brass); transform:translateY(-2px)}

.quote-shell{position:relative; border-radius:var(--r); overflow:hidden;
  background:var(--surface); border:1px solid var(--line2); box-shadow:var(--shadow)}
.quote-doors{position:absolute; inset:0; z-index:5; display:flex; pointer-events:none}
.quote-doors span{width:50%; height:100%; background:var(--door); transition:transform 1s var(--ease)}
.quote-shell.open .quote-doors span:first-child{transform:translateX(-100%)}
.quote-shell.open .quote-doors span:last-child{transform:translateX(100%)}
.quote-form{padding:2rem 1.8rem}
.qf-head{margin-bottom:1.4rem; position:relative; padding-left:1.2rem}
.qf-led{position:absolute; left:0; top:.4rem; width:8px; height:8px; border-radius:50%;
  background:#4be38a; box-shadow:0 0 10px #4be38a; animation:blink 2.2s infinite}
.qf-head h3{font-size:1.35rem; margin-bottom:.4rem}
.qf-head p{color:var(--muted); font-size:.92rem}
.qf-grid{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.field{display:flex; flex-direction:column; gap:.4rem}
.field.full{grid-column:1/-1}
.field span{font-size:.82rem; color:var(--muted); font-weight:500}
.field i{color:var(--brass); font-style:normal}
.field input,.field select,.field textarea{width:100%; padding:.8rem .9rem; border-radius:var(--rs);
  background:var(--surface2); border:1px solid var(--line2); color:var(--text); font:inherit; font-size:.93rem;
  transition:border-color .3s,box-shadow .3s}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--brass);
  box-shadow:0 0 0 3px rgba(201,162,74,.18)}
.field.err input,.field.err select{border-color:#e25b5b; box-shadow:0 0 0 3px rgba(226,91,91,.15)}
.hp{position:absolute; left:-9999px; width:1px; height:1px; opacity:0}
.qf-submit{width:100%; justify-content:center; margin-top:1.3rem}
.qf-submit.loading{opacity:.7; pointer-events:none}
.qf-result{margin-top:1rem; font-size:.92rem; text-align:center; min-height:1.2em}
.qf-result.ok{color:#4be38a}.qf-result.bad{color:#e25b5b}

/* ===================================================================
   FOOTER
   =================================================================== */
.site-foot{background:var(--surface); border-top:1px solid var(--line); padding:4rem 0 1.5rem; margin-top:2rem}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:3rem; margin-bottom:2.5rem}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr}}
.foot-brand p{color:var(--muted); margin:1rem 0; max-width:440px; font-size:.95rem}
.foot-contact{display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; color:var(--muted); font-size:.9rem}
.foot-news h4{font-size:1.1rem; margin-bottom:.6rem}
.foot-news p{color:var(--muted); font-size:.9rem; margin-bottom:1rem}
.news-form{display:flex; gap:.6rem; flex-wrap:wrap}
.news-form input{flex:1; min-width:180px; padding:.75rem .9rem; border-radius:var(--rs);
  background:var(--surface2); border:1px solid var(--line2); color:var(--text); font:inherit}
.news-form input:focus{outline:none; border-color:var(--brass)}
.news-msg{flex-basis:100%; font-size:.85rem; color:var(--brass)}
.foot-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:1.5rem;
  border-top:1px solid var(--line); color:var(--muted); font-size:.85rem; flex-wrap:wrap; gap:.6rem}
.foot-loc{display:inline-flex; align-items:center; gap:.4rem}

/* whatsapp float */
.wa-float{position:fixed; bottom:1.4rem; left:1.4rem; z-index:860; width:54px; height:54px; border-radius:50%;
  background:#25D366; color:#fff; display:grid; place-items:center; box-shadow:0 12px 28px -8px rgba(37,211,102,.6);
  transition:transform .3s var(--ease)}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:980px){
  .topnav{display:none}
  .panel{flex-direction:row; top:auto; bottom:1rem; right:50%; transform:translateX(50%);
    padding:.5rem .6rem; border-radius:16px}
  .panel-head,.panel-foot{display:none}
  .panel-buttons{flex-direction:row}
  .floor-btn{width:36px; height:36px}
  .floor-btn .fb-label{display:none}
  .floor-display{top:auto; bottom:5rem; left:50%; transform:translateX(-50%); display:flex; gap:.4rem;
    align-items:center; min-width:0; padding:.4rem .6rem}
  .fd-num{font-size:1.4rem}
  .qf-grid{grid-template-columns:1fr}
  .hero-copy{margin-left:1.2rem}
}
@media (max-width:560px){
  .floor{padding:5.5rem 0}
  .cta-call{display:none}
}
