/* ============================================================
   META LASER SYSTEMS — premium build, v2
   Design language: industrial signage. Black + warm cream +
   brand cyan + safety amber. No rounded corners except where
   functional. No gradients. No bouncy animation. Real equipment,
   real numbers, no decoration that doesn't earn its space.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0a0a0a;
  --surface:#131313;
  --surface-2:#1a1a1a;
  --text:#f0ebe2;
  --text-dim:#a59f93;
  --text-muted:#6b665d;
  --border:#262626;
  --border-dim:#1c1c1c;
  --accent:#2bb8e0;
  --accent-dim:#1a8aa8;
  --signal:#ffb800;
  --signal-dim:#b88300;
  --danger:#ff3b30;
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:'ss01','cv11'}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:0;background:0}

/* type system */
.display{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:-0.005em;line-height:0.92;text-transform:uppercase}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.18em;color:var(--accent);text-transform:uppercase;font-weight:500}
.label-mono{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--text-muted);text-transform:uppercase;font-weight:500}
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
@media(max-width:640px){.wrap{padding:0 20px}}

/* status bar */
.status-bar{background:#000;border-bottom:1px solid var(--border-dim);padding:8px 0;overflow:hidden;position:relative}
.status-bar::before{content:"";position:absolute;left:0;top:0;bottom:0;width:80px;background:linear-gradient(90deg,#000,transparent);z-index:2;pointer-events:none}
.status-bar::after{content:"";position:absolute;right:0;top:0;bottom:0;width:80px;background:linear-gradient(-90deg,#000,transparent);z-index:2;pointer-events:none}
.status-track{display:flex;gap:60px;animation:scroll 38s linear infinite;white-space:nowrap;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted);font-weight:500;width:max-content}
.status-track span{display:inline-flex;align-items:center;gap:14px}
.status-track .dot{display:inline-block;width:6px;height:6px;background:var(--signal);box-shadow:0 0 8px var(--signal)}
.status-track .live{color:var(--signal)}
.status-track .city{color:var(--text-dim)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(10,10,10,0.94);backdrop-filter:blur(16px) saturate(120%);border-bottom:1px solid var(--border-dim)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.brand-mark{width:46px;height:46px;display:block;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(43,184,224,0.18))}
.brand-text strong{font-family:'Inter',sans-serif;font-size:13px;font-weight:800;letter-spacing:0.08em;display:block;line-height:1.15}
.brand-text small{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text-muted);letter-spacing:0.15em;text-transform:uppercase;display:block;margin-top:2px}
nav ul{list-style:none;display:flex;gap:30px;align-items:center}
nav a{font-size:13px;font-weight:500;color:var(--text-dim);transition:color .15s}
nav a:hover{color:var(--text)}
nav a.active{color:var(--text)}
.header-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.tel-mono{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-dim);letter-spacing:0.02em;display:flex;align-items:center;gap:8px}
.tel-mono::before{content:"";width:7px;height:7px;background:var(--signal);box-shadow:0 0 6px var(--signal);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
@media(max-width:980px){nav ul{display:none}.header-cta{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;font-family:'Inter',sans-serif;font-size:13px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;border:1px solid transparent;transition:all .18s;cursor:pointer;line-height:1}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{background:#56cef0;transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--text);border-color:var(--border)}
.btn-secondary:hover{border-color:var(--text);background:rgba(240,235,226,0.04)}
.btn-signal{background:var(--signal);color:#000}
.btn-signal:hover{background:#ffc944}
.btn .arrow{transition:transform .18s}
.btn:hover .arrow{transform:translateX(3px)}

/* hero */
.hero{padding:80px 0 100px;position:relative;overflow:hidden;border-bottom:1px solid var(--border-dim)}
.hero::before{content:"";position:absolute;top:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse 80% 70% at 100% 0%,rgba(43,184,224,0.06),transparent 70%);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0.4}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:80px;align-items:center;position:relative;z-index:1}
.hero-copy .eyebrow{margin-bottom:28px;display:flex;align-items:center;gap:14px}
.hero-copy .eyebrow::before{content:"";width:44px;height:1px;background:var(--accent)}
.hero h1{font-family:'Anton',sans-serif;font-size:clamp(56px,7.5vw,108px);line-height:0.88;letter-spacing:-0.005em;text-transform:uppercase;color:var(--text);margin-bottom:36px;font-weight:400}
.hero h1 .accent{color:var(--accent)}
.hero h1 .signal{color:var(--signal)}
.hero-lead{font-size:18px;line-height:1.6;color:var(--text-dim);max-width:560px;margin-bottom:36px;font-weight:400}
.hero-lead strong{color:var(--text);font-weight:600}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero-foot{display:flex;gap:32px;border-top:1px solid var(--border-dim);padding-top:24px}
.hero-foot-item{display:flex;flex-direction:column;gap:6px}
.hero-foot-item .label-mono{color:var(--accent)}
.hero-foot-item .val{font-family:'Anton',sans-serif;font-size:24px;letter-spacing:0.005em;line-height:1;color:var(--text)}

/* compact hero — interior pages (about, whs, faq) */
.hero.compact{padding:64px 0 56px;border-bottom:1px solid var(--border-dim)}
.hero.compact::before,.hero.compact::after{display:none}
.hero.compact h1{font-size:clamp(44px,5.5vw,76px);margin-bottom:24px}
.hero.compact .hero-lead{max-width:760px;margin-bottom:0;font-size:17px}
.hero.compact .container,.hero.compact .wrap{position:relative;z-index:1}

/* hero media */
.hero-media{position:relative}
.hero-media-frame{position:relative;border:1px solid var(--border);background:var(--surface);padding:20px}
.hero-media-frame::before{content:"";position:absolute;top:-1px;left:-1px;width:24px;height:24px;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.hero-media-frame::after{content:"";position:absolute;bottom:-1px;right:-1px;width:24px;height:24px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.hero-media-frame img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:contrast(1.02) saturate(0.95)}
.hero-media-meta{display:flex;justify-content:space-between;padding-top:16px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-muted)}
.hero-media-meta b{color:var(--accent);font-weight:500}

/* spec plate */
.spec-plate{position:absolute;bottom:42px;left:-32px;background:#000;border:1px solid var(--accent);padding:18px 22px;min-width:240px;box-shadow:0 24px 48px -16px rgba(0,0,0,0.6)}
.spec-plate .plate-head{display:flex;justify-content:space-between;align-items:center;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.spec-plate .plate-head .live-dot{display:flex;align-items:center;gap:6px;color:var(--signal)}
.spec-plate .plate-head .live-dot::before{content:"";width:6px;height:6px;background:var(--signal);box-shadow:0 0 6px var(--signal);animation:pulse 2s infinite}
.spec-plate h3{font-family:'Anton',sans-serif;font-size:28px;letter-spacing:0.01em;color:var(--text);margin-bottom:8px;line-height:1;text-transform:uppercase}
.spec-plate .specs{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-dim);line-height:1.7;letter-spacing:0.02em}

@media(max-width:960px){
  .hero{padding:48px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero h1{font-size:clamp(52px,11vw,80px)}
  .spec-plate{left:auto;right:0;bottom:0;transform:translateY(50%)}
}
@media(max-width:560px){
  .hero-foot{flex-wrap:wrap;gap:20px}
  .spec-plate{position:static;transform:none;margin-top:20px;min-width:0}
}

/* section */
.section{padding:96px 0;border-bottom:1px solid var(--border-dim)}
.section.tight{padding:64px 0}
.section-head{margin-bottom:56px;display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap}
.section-head.center{justify-content:center;text-align:center;flex-direction:column;align-items:center}
.section-head .eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.section-head .eyebrow::before{content:"";width:32px;height:1px;background:var(--accent)}
.section-head h2{font-family:'Anton',sans-serif;font-size:clamp(40px,5vw,68px);letter-spacing:0.005em;text-transform:uppercase;color:var(--text);line-height:0.95;max-width:780px;font-weight:400}
.section-head h2 .accent{color:var(--accent)}
.section-head .head-aside{max-width:380px;color:var(--text-dim);font-size:15px;line-height:1.6}

/* equipment cards */
.equip-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.equip-card{background:var(--surface);padding:36px;position:relative;display:flex;flex-direction:column;gap:26px}
.equip-head{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch}
.equip-meta{display:flex;flex-direction:column}
.equip-meta .equip-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.equip-meta .equip-tag::before{content:"●";color:var(--signal);font-size:8px}
.equip-card h3{font-family:'Anton',sans-serif;font-size:42px;letter-spacing:0.005em;text-transform:uppercase;color:var(--text);line-height:0.95;margin-bottom:14px;font-weight:400}
.equip-card p{font-size:14px;color:var(--text-dim);line-height:1.6;margin-bottom:0}
.equip-card .spec-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-dim);border:1px solid var(--border-dim);margin:0}
.equip-card .spec-list .spec{background:var(--bg);padding:11px 14px;display:flex;flex-direction:column;gap:5px}
.equip-card .spec-list dt{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.16em;color:var(--text-muted);text-transform:uppercase;margin:0}
.equip-card .spec-list dd{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--text);font-weight:500;letter-spacing:0.02em;margin:0;line-height:1.35}
.equip-card .equip-cta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);align-self:flex-end}
.equip-card .equip-cta:hover{color:#56cef0}
.equip-card .equip-img{background:#000;border:1px solid var(--border-dim);position:relative;overflow:hidden;min-height:260px}
.equip-card .equip-img img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}
.equip-card .equip-img::after{content:"DOC-001";position:absolute;top:8px;right:8px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.18em;color:var(--text-muted);background:rgba(0,0,0,0.7);padding:3px 6px}
.equip-card:nth-child(2) .equip-img::after{content:"DOC-002"}

/* equipment dossier plates — used on /about/. Each plate: portrait photo on the left, dossier column on the right. */
.equip-plates{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border)}
.equip-plate{background:var(--surface);padding:40px;display:grid;grid-template-columns:1fr 1.3fr;gap:40px;align-items:start}
.equip-plate-img{background:#000;border:1px solid var(--border-dim);position:relative;overflow:hidden;aspect-ratio:3/4}
.equip-plate-img img{width:100%;height:100%;object-fit:cover;object-position:center 35%;display:block}
.equip-plate-dossier{display:flex;flex-direction:column}
.equip-plate-head{display:flex;justify-content:space-between;align-items:baseline;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;gap:24px;flex-wrap:wrap}
.equip-plate-head b{color:var(--accent);font-weight:500}
.equip-plate h3{font-family:'Anton',sans-serif;font-size:38px;letter-spacing:0.005em;text-transform:uppercase;color:var(--text);line-height:0.95;margin-bottom:16px;font-weight:400}
.equip-plate p{font-size:14px;color:var(--text-dim);line-height:1.65;margin-bottom:22px}
.equip-plate-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border-dim);border:1px solid var(--border-dim);margin-bottom:22px}
.equip-plate-specs dt{background:var(--bg);padding:9px 12px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.16em;color:var(--text-muted);text-transform:uppercase}
.equip-plate-specs dd{background:var(--bg);padding:9px 12px;font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text);font-weight:500;letter-spacing:0.02em}
.equip-plate-evidence{margin:0 0 22px;background:#000;border:1px solid var(--border-dim);padding:10px;display:grid;grid-template-columns:96px 1fr;gap:14px;align-items:center}
.equip-plate-evidence img{width:96px;height:128px;object-fit:cover;object-position:center 25%;display:block;border:1px solid var(--border-dim)}
.equip-plate-evidence figcaption{display:flex;flex-direction:column;gap:6px;min-width:0}
.evidence-tag{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--signal)}
.evidence-line{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text);letter-spacing:0.02em;line-height:1.5}
.equip-plate-cta{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);align-self:flex-start;margin-top:auto}
.equip-plate-cta:hover{color:#56cef0}

@media(max-width:980px){.equip-grid{grid-template-columns:1fr}.equip-head{grid-template-columns:1fr}.equip-card .spec-list{grid-template-columns:repeat(2,1fr)}.equip-plate{grid-template-columns:1fr;padding:28px;gap:28px}}
@media(max-width:520px){.equip-card .spec-list{grid-template-columns:1fr 1fr}}

/* workshop cards */
.workshops{background:#0d0d0d}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.work-card{background:var(--surface);padding:36px;display:flex;flex-direction:column;gap:18px;transition:background .18s;position:relative;overflow:hidden;min-height:380px}
.work-card::before{content:"";position:absolute;top:0;left:0;width:0;height:2px;background:var(--accent);transition:width .25s}
.work-card:hover::before{width:100%}
.work-card .work-num{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;color:var(--text-muted);text-transform:uppercase}
.work-card h3{font-family:'Anton',sans-serif;font-size:32px;letter-spacing:0.005em;color:var(--text);line-height:0.95;text-transform:uppercase;font-weight:400}
.work-card p{font-size:14px;color:var(--text-dim);line-height:1.65}
.work-card .work-cta{margin-top:auto;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:8px;padding-top:18px;border-top:1px solid var(--border)}
.work-card .work-cta .arrow{transition:transform .18s}
.work-card:hover .work-cta .arrow{transform:translateX(4px)}
@media(max-width:980px){.work-grid{grid-template-columns:1fr}}

/* launch terms signboard */
.foundation{background:#000;position:relative;overflow:hidden}
.foundation::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent,transparent 12px,rgba(255,184,0,0.018) 12px,rgba(255,184,0,0.018) 13px);pointer-events:none}
.signboard{border:2px solid var(--signal);padding:48px;background:#0a0a0a;position:relative;display:grid;grid-template-columns:1fr 1px 1.4fr;gap:48px;align-items:start}
.signboard::before{content:"";position:absolute;top:-2px;left:-2px;width:36px;height:36px;border-top:4px solid var(--signal);border-left:4px solid var(--signal)}
.signboard::after{content:"";position:absolute;bottom:-2px;right:-2px;width:36px;height:36px;border-bottom:4px solid var(--signal);border-right:4px solid var(--signal)}
.signboard-rule{background:var(--signal);opacity:0.3}
.signboard-head .sign-stamp{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--signal);margin-bottom:18px;display:inline-flex;align-items:center;gap:10px;padding:6px 12px;border:1px solid var(--signal-dim)}
.signboard-head h2{font-family:'Anton',sans-serif;font-size:clamp(44px,5.2vw,72px);text-transform:uppercase;color:var(--signal);line-height:0.92;letter-spacing:0.005em;font-weight:400;margin-bottom:18px}
.signboard-head p{color:var(--text-dim);font-size:15px;line-height:1.6}
.signboard-body{font-size:15px;color:var(--text);line-height:1.7}
.signboard-list{list-style:none;margin:0 0 28px;counter-reset:item}
.signboard-list li{padding:14px 0;border-top:1px solid var(--border);display:grid;grid-template-columns:24px 1fr;gap:14px}
.signboard-list li:last-child{border-bottom:1px solid var(--border)}
.signboard-list li::before{content:counter(item,decimal-leading-zero);counter-increment:item;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--signal);font-weight:700;letter-spacing:0.05em;padding-top:1px}
.signboard-list strong{color:var(--text);font-weight:700;display:block;margin-bottom:3px}
.signboard-list em{color:var(--text-dim);font-style:normal;font-size:14px;line-height:1.55}
.signboard-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.signboard-cta .tel-big{font-family:'Anton',sans-serif;font-size:28px;letter-spacing:0.01em;color:var(--signal);line-height:1;padding:14px 0}
@media(max-width:880px){.signboard{grid-template-columns:1fr;gap:32px;padding:32px}.signboard-rule{display:none}}

/* demo doc */
.demo-doc{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:start}
.demo-doc.demo-doc--solo{grid-template-columns:1fr;max-width:820px}
.demo-doc-meta{border-top:1px solid var(--border);padding-top:24px}
.doc-id{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px}
.doc-id b{color:var(--accent);font-weight:500}
.demo-doc h2{font-family:'Anton',sans-serif;font-size:clamp(42px,5vw,68px);line-height:0.92;letter-spacing:0.005em;text-transform:uppercase;color:var(--text);margin-bottom:24px;font-weight:400}
.demo-doc h2 .accent{color:var(--accent)}
.demo-doc-body p{color:var(--text-dim);line-height:1.7;font-size:15px;margin-bottom:18px}
.demo-doc-body strong{color:var(--text);font-weight:600}
.demo-data{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin:28px 0}
.demo-data div{background:var(--bg);padding:14px 16px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.04em;color:var(--text)}
.demo-data div small{display:block;font-size:9px;letter-spacing:0.2em;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px;font-weight:500}
.demo-doc-img{position:relative;border:1px solid var(--border);background:var(--surface);padding:12px}
.demo-doc-img img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 30%;filter:contrast(1.05);display:block}
.demo-doc-img .img-foot{display:flex;justify-content:space-between;padding-top:10px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted)}
@media(max-width:880px){.demo-doc{grid-template-columns:1fr}}

/* sectors */
.sectors{background:#0d0d0d}
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.sector-card{background:var(--surface);padding:32px;display:flex;flex-direction:column;gap:14px;min-height:200px}
.sector-card .label-mono{color:var(--text-muted)}
.sector-card h3{font-family:'Inter',sans-serif;font-size:20px;font-weight:700;color:var(--text);letter-spacing:-0.01em;line-height:1.25}
.sector-card p{font-size:13px;color:var(--text-dim);line-height:1.6}
.sector-card a{margin-top:auto;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent)}
@media(max-width:880px){.sectors-grid{grid-template-columns:1fr}}

/* final CTA */
.final{background:#000;padding:120px 0;text-align:center;border-top:1px solid var(--accent);border-bottom:1px solid var(--accent);position:relative;overflow:hidden}
.final::before,.final::after{content:"";position:absolute;left:50%;transform:translateX(-50%);width:600px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0.6}
.final::before{top:-1px}
.final::after{bottom:-1px}
.final .eyebrow{justify-content:center;display:flex;align-items:center;gap:14px;margin-bottom:24px}
.final .eyebrow::before,.final .eyebrow::after{content:"";width:32px;height:1px;background:var(--accent)}
.final h2{font-family:'Anton',sans-serif;font-size:clamp(56px,8vw,128px);line-height:0.9;letter-spacing:0.005em;text-transform:uppercase;color:var(--text);margin-bottom:28px;font-weight:400}
.final h2 .accent{color:var(--accent)}
.final .lead{color:var(--text-dim);font-size:17px;max-width:640px;margin:0 auto 48px;line-height:1.55}
.final-tel{font-family:'Anton',sans-serif;font-size:clamp(40px,5vw,80px);color:var(--signal);letter-spacing:0.02em;line-height:1;display:inline-block;padding:8px 4px;margin-bottom:32px;transition:color .15s}
.final-tel:hover{color:#ffc944}
.final-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* footer */
footer{background:#000;padding:56px 0 32px;border-top:1px solid var(--border-dim)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{font-size:13px;color:var(--text-dim);line-height:1.6;max-width:320px;margin-bottom:14px}
.foot-brand .foot-pillars{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent)}
.foot-col h4{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--text-muted);margin-bottom:18px}
.foot-col a{display:block;padding:5px 0;font-size:13px;color:var(--text-dim);transition:color .15s}
.foot-col a:hover{color:var(--accent)}
.foot-meta{border-top:1px solid var(--border-dim);padding-top:24px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* mobile sticky cta */
.sticky-cta{display:none}
@media(max-width:980px){
  .sticky-cta{display:flex;position:fixed;bottom:0;left:0;right:0;background:#000;border-top:1px solid var(--accent);padding:10px 14px;gap:10px;z-index:60}
  .sticky-cta .btn{flex:1;justify-content:center;padding:14px 12px;font-size:11px}
  body{padding-bottom:72px}
}

/* fade-in */
.section,.hero{opacity:1}
.fade{opacity:0;transform:translateY(16px);transition:opacity .6s,transform .6s}
.fade.visible{opacity:1;transform:none}

/* ============================================================
   ARTICLE / LONG-FORM (about, whs)
   ============================================================ */
.article{display:grid;grid-template-columns:240px minmax(0,1fr);gap:80px;align-items:start;max-width:1100px;margin:0 auto}
.article-toc{position:sticky;top:96px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.14em;text-transform:uppercase}
.article-toc h4{color:var(--accent);margin-bottom:18px;font-weight:500;font-size:10px;letter-spacing:0.2em;padding-bottom:10px;border-bottom:1px solid var(--border)}
.article-toc a{display:block;color:var(--text-muted);padding:9px 0;border-bottom:1px solid var(--border-dim);transition:color .15s}
.article-toc a:hover{color:var(--text)}
.article-body{font-size:16px;line-height:1.75;color:var(--text-dim)}
.article-body h2{font-family:'Anton',sans-serif;font-size:clamp(32px,3.5vw,48px);text-transform:uppercase;color:var(--text);line-height:0.95;letter-spacing:0.005em;margin:64px 0 24px;padding-top:36px;border-top:1px solid var(--border);font-weight:400}
.article-body h2:first-child{margin-top:0;padding-top:0;border-top:0}
.article-body h3{font-family:'Inter',sans-serif;font-size:20px;font-weight:700;color:var(--text);letter-spacing:-0.01em;margin:32px 0 12px;line-height:1.3}
.article-body p{margin-bottom:18px}
.article-body p strong{color:var(--text);font-weight:600}
.article-body ul,.article-body ol{margin:18px 0 28px 24px;padding:0}
.article-body li{margin-bottom:8px;padding-left:6px}
.article-body li::marker{color:var(--accent)}
.article-body .callout{border-left:2px solid var(--accent);background:rgba(43,184,224,0.04);padding:20px 28px;margin:32px 0;font-size:15px;color:var(--text)}
.article-body .callout.signal{border-color:var(--signal);background:rgba(255,184,0,0.04)}
.article-body .spec-table{width:100%;border:1px solid var(--border);background:var(--surface);margin:28px 0;font-family:'JetBrains Mono',monospace;font-size:12px;border-collapse:collapse}
.article-body .spec-table th,.article-body .spec-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-dim);vertical-align:top}
.article-body .spec-table th{color:var(--accent);font-weight:500;letter-spacing:0.14em;text-transform:uppercase;font-size:10px;width:35%}
.article-body .spec-table td{color:var(--text)}
.article-body .spec-table tr:last-child th,.article-body .spec-table tr:last-child td{border-bottom:0}
@media(max-width:880px){
  .article{grid-template-columns:1fr;gap:40px}
  .article-toc{position:static}
}

/* ============================================================
   FAQ — accordion using <details>
   ============================================================ */
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--border);max-width:880px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item summary{list-style:none;padding:24px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;transition:color .15s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary h3{font-family:'Inter',sans-serif;font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.01em;line-height:1.4;margin:0}
.faq-item summary .faq-toggle{flex-shrink:0;width:32px;height:32px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:16px;color:var(--accent);transition:all .18s}
.faq-item[open] summary .faq-toggle{background:var(--accent);color:#000;border-color:var(--accent);transform:rotate(45deg)}
.faq-item .faq-answer{padding:0 60px 28px 0;font-size:15px;color:var(--text-dim);line-height:1.7}
.faq-item .faq-answer p{margin-bottom:14px}
.faq-item .faq-answer p:last-child{margin-bottom:0}
.faq-item .faq-answer strong{color:var(--text);font-weight:600}
.faq-item .faq-answer ul{margin:14px 0 14px 22px}
.faq-item .faq-answer li{margin-bottom:6px}
.faq-group-head{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent);padding:32px 0 12px;border-bottom:1px solid var(--border);max-width:880px;margin:36px auto 0}
.faq-group-head:first-of-type{margin-top:0;padding-top:0}

/* ============================================================
   GALLERY (our-work)
   ============================================================ */
.gallery-grid{display:grid;grid-template-columns:1fr;gap:36px}
.gallery-item{background:var(--surface);border:1px solid var(--border);padding:28px}
.gallery-item-head{display:flex;justify-content:space-between;align-items:baseline;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;gap:24px;flex-wrap:wrap}
.gallery-item-head b{color:var(--accent);font-weight:500}
.gallery-item h3{font-family:'Inter',sans-serif;font-size:22px;font-weight:700;color:var(--text);letter-spacing:-0.01em;line-height:1.3;margin-bottom:8px}
.gallery-item .gallery-meta{font-size:14px;color:var(--text-dim);line-height:1.6;margin-bottom:20px;max-width:760px}
.gallery-pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gallery-pair figure{margin:0}
.gallery-pair img{width:100%;height:auto;display:block;border:1px solid var(--border-dim)}
.gallery-pair figcaption{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--text-muted);padding-top:8px}
.gallery-pending{background:#000;border:1px dashed var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:28px 20px;min-height:240px;aspect-ratio:auto}
.gallery-pending .pending-eyebrow{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--signal);font-weight:500}
.gallery-pending .pending-msg{font-family:'JetBrains Mono',monospace;font-size:11px;line-height:1.55;color:var(--text-muted);letter-spacing:0.02em;max-width:240px;margin:0}
.gallery-single img{width:100%;height:auto;display:block;border:1px solid var(--border-dim)}
.gallery-spec{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);margin-top:18px}
.gallery-spec div{background:var(--bg);padding:10px 14px;font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text)}
.gallery-spec div small{display:block;font-size:9px;letter-spacing:0.18em;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}
@media(max-width:640px){.gallery-pair{grid-template-columns:1fr}}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-info h3{font-family:'Anton',sans-serif;font-size:32px;color:var(--text);text-transform:uppercase;margin-bottom:20px;font-weight:400;letter-spacing:0.005em}
.contact-info p{color:var(--text-dim);line-height:1.7;margin-bottom:16px}
.contact-info .contact-channels{margin-top:32px;border-top:1px solid var(--border);padding-top:24px;display:flex;flex-direction:column;gap:18px}
.contact-info .channel{display:flex;flex-direction:column;gap:4px}
.contact-info .channel .label-mono{color:var(--accent)}
.contact-info .channel a{font-family:'Anton',sans-serif;font-size:28px;color:var(--text);letter-spacing:0.005em;line-height:1;transition:color .15s}
.contact-info .channel a:hover{color:var(--accent)}
.contact-form-wrap{background:var(--surface);border:1px solid var(--border);padding:36px}
.contact-form{display:flex;flex-direction:column;gap:18px}
.contact-form label{display:flex;flex-direction:column;gap:8px}
.contact-form label > span{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted)}
.contact-form input,.contact-form select,.contact-form textarea{background:#000;border:1px solid var(--border);color:var(--text);padding:14px 16px;font-family:'Inter',sans-serif;font-size:14px;transition:border-color .15s;width:100%}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:0;border-color:var(--accent)}
.contact-form textarea{resize:vertical;min-height:140px;font-family:'Inter',sans-serif}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-form button[type=submit]{margin-top:8px;align-self:flex-start}
.contact-form .hidden-field{display:none}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:40px}.contact-form .form-row{grid-template-columns:1fr}}

/* utility */
.skip-link{position:absolute;left:-9999px;top:0;padding:12px 18px;background:var(--accent);color:#000;font-weight:700;z-index:100}
.skip-link:focus{left:8px;top:8px}
