:root{
  --bg-base:#0A0A0B; --bg-elevated:#121215; --bg-stripe:#161619;
  --text-primary:#F5F6F8; --text-muted:#A6A8AD; --border-line:#26272B;
  --accent:#3D5AFE; --accent-hover:#5A72FF; --accent-glow:rgba(61,90,254,0.35);
  --max:1200px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{max-width:100%;overflow-x:hidden}
body{
  margin:0;background:var(--bg-base);color:var(--text-primary);
  font-family:'Inter',system-ui,sans-serif;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-wrap:break-word;
}
img,svg,video,iframe{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;font-weight:800;line-height:1.05;margin:0;text-transform:uppercase;letter-spacing:.04em}
.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:2px}

.eyebrow{font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.35em;
  font-size:.72rem;font-weight:700;color:var(--accent);text-align:center;margin:0 0 1rem}
.eyebrow.left{text-align:left}

/* Buttons */
.btn{display:inline-block;font-family:'Archivo',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.15em;font-size:.82rem;padding:.95rem 2rem;border-radius:4px;cursor:pointer;
  border:1px solid transparent;transition:transform .2s,background .2s,box-shadow .2s}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 30px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text-primary);border-color:var(--border-line)}
.btn-ghost:hover{border-color:var(--accent);color:#fff}
.btn.full{width:100%;text-align:center;border:none}

/* Header */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s,backdrop-filter .3s,padding .3s;
  padding:1.1rem 0;background:linear-gradient(180deg,rgba(10,10,11,.85),transparent)}
.hdr.scrolled{background:rgba(10,10,11,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-line);padding:.7rem 0}
.hdr-inner{max-width:var(--max);margin:0 auto;padding:0 1.2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo img{height:34px}
.nav{display:flex;align-items:center;gap:1.4rem}
.nav-link{font-family:'Archivo',sans-serif;font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.12em;color:var(--text-muted);transition:color .2s;position:relative;padding:.3rem 0}
.nav-link:hover,.nav-link.active{color:var(--text-primary)}
.nav-link.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent)}
.nav-cta{font-family:'Archivo',sans-serif;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;background:var(--accent);color:#fff;padding:.6rem 1.4rem;border-radius:4px;transition:background .2s}
.nav-cta:hover{background:var(--accent-hover)}
.burger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;padding:8px;flex-direction:column;justify-content:space-between}
.burger span{display:block;height:2px;background:var(--text-primary);border-radius:2px;transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

@media(max-width:1080px){
  .burger{display:flex}
  .nav{position:fixed;top:0;right:0;height:100vh;width:min(82%,340px);background:var(--bg-elevated);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:1.6rem;padding:2rem;
    transform:translateX(100%);transition:transform .35s ease;border-left:1px solid var(--border-line);z-index:120}
  .nav.open{transform:translateX(0)}
  .nav-link{font-size:.95rem}
  .nav-cta{font-size:.85rem;padding:.8rem 1.6rem}
}

/* Hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at center,rgba(10,10,11,.35),rgba(10,10,11,.82)),linear-gradient(180deg,rgba(10,10,11,.6),rgba(10,10,11,.3) 40%,rgba(10,10,11,.95))}
.hero-content{position:relative;z-index:2;padding:5rem 1.2rem;max-width:780px}
.hero-logo{width:min(78vw,540px);margin:0 auto 1.6rem;filter:drop-shadow(0 4px 30px rgba(0,0,0,.6))}
.hero-tag{font-size:clamp(1.4rem,4.5vw,2.6rem);letter-spacing:.12em;margin-bottom:.9rem;text-shadow:0 2px 20px rgba(0,0,0,.6)}
.hero-sub{font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.3em;font-size:.78rem;color:var(--text-muted);margin:0 0 2.2rem}
.hero-stats{position:absolute;bottom:0;left:0;right:0;z-index:2;display:flex;justify-content:center;flex-wrap:wrap;gap:1.4rem 2.6rem;
  padding:1.1rem;background:linear-gradient(180deg,transparent,rgba(10,10,11,.9));border-top:1px solid rgba(255,255,255,.06)}
.hero-stats span{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em}
.hero-stats strong{color:var(--accent);font-family:'Archivo',sans-serif;margin-right:.4rem}

/* Intro */
.intro{max-width:760px;margin:0 auto;padding:6rem 1.2rem;text-align:center}
.intro-lead{font-size:clamp(1.1rem,2.6vw,1.5rem);color:var(--text-primary);margin:0 0 2rem;line-height:1.45}

/* Services stripes */
.stripe{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch;
  border-top:1px solid var(--border-line)}
.stripe-media{overflow:hidden;min-height:420px}
.stripe-media img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.stripe:hover .stripe-media img{transform:scale(1.04)}
.stripe-text{padding:clamp(2rem,5vw,4.5rem);display:flex;flex-direction:column;justify-content:center;background:var(--bg-base)}
.stripe.reverse .stripe-media{order:2}
.stripe.reverse .stripe-text{order:1}
.num{font-family:'Archivo',sans-serif;font-size:.85rem;font-weight:700;color:var(--accent);letter-spacing:.2em;margin-bottom:.8rem}
.stripe-text h2{font-size:clamp(1.6rem,3.6vw,2.3rem);margin-bottom:1rem}
.stripe-text .sub{font-style:italic;color:var(--text-primary);font-size:1.02rem;margin:0 0 1rem;font-family:'Inter'}
.stripe-text p{color:var(--text-muted);margin:0}
.stripe-text .sub+p{margin-top:0}

/* Story */
.story{padding:6rem 1.2rem;background:var(--bg-stripe)}
.story-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.story-collage{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);gap:.9rem;min-width:0}
.story-collage img{border-radius:8px;width:100%;height:100%;object-fit:cover;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.story-collage .c1{grid-row:1/3}
.story-collage .c4{grid-row:span 1}
.story-text h2{font-size:clamp(1.6rem,3.4vw,2.3rem);margin-bottom:1.4rem}
.story-text p{color:var(--text-muted);margin:0 0 1rem}
.story-text .signoff{color:var(--text-primary);font-weight:600;font-style:italic}

/* Banner */
.banner{position:relative;min-height:60vh;display:flex;overflow:hidden}
.banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.banner-overlay{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:1.6rem;padding:5rem 1.2rem;background:linear-gradient(180deg,rgba(10,10,11,.55),rgba(10,10,11,.75))}
.banner-overlay h2{font-size:clamp(1.8rem,5vw,3.2rem)}

/* Section heads */
.sec-head{text-align:center;max-width:760px;margin:0 auto 3rem}
.sec-head h2{font-size:clamp(1.8rem,4vw,2.7rem);margin-bottom:.8rem}
.sec-head h3{font-size:clamp(1.3rem,3vw,1.9rem);margin-bottom:.6rem}
.sec-head p{color:var(--text-muted);margin:0}
.sec-head.sub{margin-top:4rem}

/* Gallery */
.gallery{padding:6rem 1.2rem;max-width:var(--max);margin:0 auto}
.cat-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.cat{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.cat img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) brightness(.45);transition:transform .5s,filter .5s}
.cat span{position:relative;z-index:2;font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  font-size:1.2rem;text-align:center;padding:0 1rem}
.cat:hover img{transform:scale(1.06);filter:grayscale(0) brightness(.6)}
.cat::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent,rgba(61,90,254,.18))}

.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}
.tile{position:relative;border-radius:10px;overflow:hidden;margin:0;aspect-ratio:1/1;background:var(--bg-elevated)}
.tile.big{grid-column:span 2;grid-row:span 2}
.tile.wide{grid-column:span 2}
.tile img,.tile video{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.tile:hover img,.tile:hover video{transform:scale(1.05)}
.tile figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem;display:flex;flex-direction:column;gap:.2rem;
  background:linear-gradient(180deg,transparent,rgba(10,10,11,.92))}
.tile figcaption strong{font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:.85rem}
.tile figcaption span{font-size:.72rem;color:var(--text-muted)}

/* Indoor/Outdoor */
.inout{padding:6rem 1.2rem;background:var(--bg-stripe)}
.inout-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.io-card{background:var(--bg-elevated);border:1px solid var(--border-line);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}
.io-card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.io-body{padding:1.8rem}
.io-body h3{font-size:1.4rem;margin-bottom:.8rem}
.io-body p{color:var(--text-muted);margin:0 0 1.2rem}
.link-arrow{font-family:'Archivo',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--accent)}
.link-arrow:hover{color:var(--accent-hover)}

/* Brands */
.brands{padding:6rem 0;text-align:center}
.brands .sec-head{padding:0 1.2rem}
.brands-copy{font-size:.95rem}
.marquee{margin-top:3rem;overflow:hidden;position:relative;display:flex;gap:0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:3.2rem;padding-right:3.2rem;animation:scroll 42s linear infinite;flex-shrink:0}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:34px;width:auto;opacity:.78;filter:brightness(0) invert(1);transition:opacity .3s}
.marquee-track img.chip{filter:none;background:#fff;padding:6px 8px;border-radius:4px;height:42px}
.marquee-track img:hover{opacity:1}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-100%)}}

/* Present */
.present{padding:6rem 1.2rem}
.present-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:center}
.present-text h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1.2rem}
.present-text p{color:var(--text-muted);margin:0 0 1.8rem}
.present-media img{border-radius:12px;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.5)}

/* Serve */
.serve{padding:6rem 1.2rem;background:var(--bg-stripe)}
.serve-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:center}
.serve-media img{border-radius:12px;width:100%;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.serve-text h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1.6rem}
.serve-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1.4rem}
.serve-list li{position:relative;padding-left:1.2rem;color:var(--text-muted);font-size:.92rem}
.serve-list li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;background:var(--accent);border-radius:50%}

/* FAQ */
.faq{padding:6rem 1.2rem;max-width:820px;margin:0 auto}
.acc-item{border-bottom:1px solid var(--border-line)}
.acc-q{width:100%;background:none;border:none;color:var(--text-primary);font-family:'Archivo',sans-serif;
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;text-align:left;
  padding:1.4rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer}
.acc-ic{position:relative;flex-shrink:0;width:18px;height:18px}
.acc-ic::before,.acc-ic::after{content:"";position:absolute;background:var(--accent);transition:transform .3s}
.acc-ic::before{top:8px;left:0;width:18px;height:2px}
.acc-ic::after{top:0;left:8px;width:2px;height:18px}
.acc-q[aria-expanded="true"] .acc-ic::after{transform:scaleY(0)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.acc-a p,.acc-a ul{margin:0 0 1.4rem;color:var(--text-muted)}
.acc-a ul{padding-left:1.2rem}
.acc-a li{margin-bottom:.4rem}

/* Contact */
.contact{padding:6rem 1.2rem;background:var(--bg-stripe)}
.contact-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:3.5rem;align-items:start}
.contact-info h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:1.2rem}
.contact-info p{color:var(--text-muted);margin:0 0 .8rem}
.contact-list{list-style:none;padding:0;margin:1.8rem 0}
.contact-list li{display:flex;align-items:center;gap:.9rem;margin-bottom:1rem}
.contact-list img{width:20px;height:20px;filter:brightness(0) invert(1) opacity(.8)}
.contact-list a:hover{color:var(--accent)}
.map-card{display:flex;border:1px solid var(--border-line);border-radius:12px;overflow:hidden;background:var(--bg-elevated)}
.map-deco{width:90px;flex-shrink:0;background:
  radial-gradient(circle at 50% 60%,var(--accent) 0 5px,transparent 6px),
  linear-gradient(135deg,#101427,#1b2240);position:relative}
.map-deco::after{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(0deg,transparent 0 12px,rgba(255,255,255,.05) 12px 13px),
  repeating-linear-gradient(90deg,transparent 0 12px,rgba(255,255,255,.05) 12px 13px)}
.map-body{padding:1.2rem;display:flex;flex-direction:column;gap:.35rem}
.map-body strong{font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.04em;font-size:.85rem}
.map-body span{color:var(--text-muted);font-size:.85rem}

.contact-form{background:var(--bg-elevated);border:1px solid var(--border-line);border-radius:14px;padding:2rem}
.row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;margin-bottom:1rem;min-width:0}
.field label{font-family:'Archivo',sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;color:var(--text-muted);margin-bottom:.4rem}
.field input,.field select,.field textarea{background:var(--bg-base);border:1px solid var(--border-line);border-radius:6px;
  color:var(--text-primary);padding:.75rem .9rem;font-family:inherit;font-size:.95rem;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.field textarea{resize:vertical}
.err{color:#ff7a7a;font-size:.72rem;margin-top:.3rem;min-height:1em}
.form-msg{margin:1rem 0 0;font-size:.9rem;text-align:center}
.form-msg.ok{color:#6ee7a8}
.form-msg.bad{color:#ff7a7a}

/* Footer */
.ftr{background:var(--bg-base);border-top:1px solid var(--border-line);padding:4rem 1.2rem 2rem}
.ftr-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:2.5rem}
.ftr-brand img{height:36px;margin-bottom:1rem}
.ftr-brand p{color:var(--text-muted);font-size:.88rem;max-width:240px}
.ftr-col h4{font-size:.78rem;letter-spacing:.18em;margin-bottom:1.2rem;color:var(--text-primary)}
.ftr-col a{display:block;color:var(--text-muted);font-size:.9rem;margin-bottom:.7rem;transition:color .2s}
.ftr-col a:hover{color:var(--accent)}
.socials{display:flex;gap:.6rem;margin-top:1rem}
.socials a{width:36px;height:36px;border:1px solid var(--border-line);border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:.72rem;text-transform:uppercase;color:var(--text-muted);margin:0}
.socials a:hover{border-color:var(--accent);color:var(--accent)}
.ftr-legal{max-width:var(--max);margin:3rem auto 0;padding-top:1.5rem;border-top:1px solid var(--border-line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:var(--text-muted);font-size:.78rem}
.ftr-legal a:hover{color:var(--accent)}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
  .stripe{grid-template-columns:1fr}
  .stripe-media{min-height:260px;order:1 !important}
  .stripe-text{order:2 !important}
  .story-grid,.present-grid,.serve-grid,.contact-grid,.inout-grid{grid-template-columns:1fr;gap:2.2rem}
  .present-media{order:-1}
  .serve-media{order:-1}
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile.big,.tile.wide{grid-column:span 2;grid-row:auto}
  .tile.big{aspect-ratio:16/10}
  .ftr-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .cat-tiles{grid-template-columns:1fr;max-width:340px;margin:0 auto}
  .cat{aspect-ratio:16/9}
  .bento{grid-template-columns:1fr}
  .tile,.tile.big,.tile.wide{grid-column:span 1;aspect-ratio:16/11}
  .row{grid-template-columns:1fr}
  .serve-list{grid-template-columns:1fr}
  .ftr-grid{grid-template-columns:1fr}
  .ftr-legal{flex-direction:column}
  .hero-stats{gap:.5rem 1.4rem;font-size:.7rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}