
:root{
  --bg:#0b0b0b;
  --surface:#121212;
  --surface-2:#171717;
  --text:#f5f5f5;
  --muted:#c9c9c9;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.22);
  --accent:#ffffff;
  --band:#efefef;
  --shadow:0 22px 50px rgba(0,0,0,.22);
  --radius:22px;
  --radius-sm:14px;
  --container:min(1180px, calc(100% - 2rem));
  --header-h:78px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{margin:0 0 1rem;color:var(--muted)}
h1,h2,h3{line-height:1.1;margin:0 0 1rem;color:var(--text)}
h1{font-size:clamp(2.5rem, 5vw, 4.8rem);letter-spacing:-.04em}
h2{font-size:clamp(1.75rem, 3vw, 3rem);letter-spacing:-.03em}
h3{font-size:1.2rem}
.container{width:var(--container);margin-inline:auto}
.skip-link{
  position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:.75rem 1rem;z-index:100
}
.skip-link:focus{left:1rem;top:1rem}
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(11,11,11,.72);
  border-bottom:1px solid var(--line);
}
.nav-shell{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:var(--header-h);
}
.brand{display:inline-flex;align-items:center;gap:.8rem;font-size:1rem}
.brand strong{font-weight:700}
.brand-mark{
  width:2.35rem;height:2.35rem;border:1px solid var(--line-strong);border-radius:999px;
  display:grid;place-items:center;font-size:.9rem;font-weight:700;letter-spacing:.08em
}
.brand-text{display:flex;gap:.25rem;flex-wrap:wrap}
.site-nav{display:flex;align-items:center;gap:1.25rem}
.site-nav a{color:#ededed}
.site-nav a:hover{color:#fff}
.nav-toggle{
  display:none;background:none;border:0;padding:.25rem;cursor:pointer
}
.nav-toggle span{
  display:block;width:1.5rem;height:2px;background:#fff;margin:.28rem 0;border-radius:2px
}
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  border:1px solid #fff;color:#000;background:#fff;padding:.95rem 1.2rem;border-radius:999px;
  font-weight:700;transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  box-shadow:var(--shadow)
}
.button:hover{transform:translateY(-2px)}
.button-secondary,.button-sm{
  background:transparent;color:#fff;border-color:var(--line-strong);box-shadow:none
}
.button-secondary:hover,.button-sm:hover{background:#fff;color:#000}
.button-row{display:flex;gap:1rem;flex-wrap:wrap}
.eyebrow{
  color:#d9d9d9;text-transform:uppercase;letter-spacing:.2em;font-size:.8rem;margin-bottom:1rem
}
.hero{
  position:relative;min-height:calc(100svh - var(--header-h));display:grid;align-items:end;overflow:hidden
}
.hero-media{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.95)
}
.hero-overlay{
  position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,.82) 10%, rgba(0,0,0,.25) 55%, rgba(0,0,0,.08) 100%)
}
.hero-content{
  position:relative;z-index:1;padding:6rem 0 5rem;max-width:760px
}
.hero-copy{font-size:1.08rem;max-width:650px;color:#e6e6e6}
.page-hero{
  padding:7rem 0 3rem;background:
  linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)),
  radial-gradient(circle at top left, rgba(255,255,255,.06), transparent 35%);
  border-bottom:1px solid var(--line)
}
.page-hero-short{padding-bottom:2rem}
.page-hero-services,.page-hero-portfolio,.page-hero-contact{
  background:
  linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)),
  radial-gradient(circle at top right, rgba(255,255,255,.06), transparent 35%)
}
.section{padding:5rem 0}
.section-dark{background:var(--surface)}
.section-band{background:var(--band);color:#111}
.section-band h2,.section-band h3{color:#111}
.section-band p,.section-band li{color:#353535}
.intro-grid,.two-col,.split-callout,.contact-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center
}
.section-heading{max-width:680px;margin-bottom:2rem}
.featured-grid{
  display:grid;gap:1rem;grid-template-columns:1.15fr 1fr 1fr;
  grid-auto-rows:minmax(220px, 1fr)
}
.feature-card{
  position:relative;overflow:hidden;border-radius:var(--radius);min-height:220px;background:#000;
  border:1px solid var(--line)
}
.feature-card img{
  width:100%;height:100%;object-fit:cover;transition:transform .45s ease, opacity .45s ease;opacity:.88
}
.feature-card span{
  position:absolute;left:1rem;bottom:1rem;right:1rem;padding:.9rem 1rem;
  border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.45);border-radius:999px;font-weight:700;
  backdrop-filter:blur(10px)
}
.feature-card:hover img{transform:scale(1.04);opacity:1}
.feature-tall{grid-row:span 2}
.cards-three,.service-grid,.faq-grid{
  display:grid;gap:1rem
}
.cards-three{grid-template-columns:repeat(3, minmax(0,1fr))}
.service-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
.faq-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
.info-card,.service-card,.faq-item,.contact-note{
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.35rem
}
.section-band .info-card,.section-band .service-card,.section-band .faq-item,.section-band .contact-note{
  background:#fff;border-color:rgba(0,0,0,.08)
}
.cta-panel{
  border:1px solid var(--line);border-radius:calc(var(--radius) + 4px);
  padding:1.3rem 1.4rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01))
}
.check-list{margin:0;padding-left:1.1rem}
.check-list li{margin:.55rem 0}
.stacked-image img{
  border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)
}
.filter-bar{
  display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.4rem
}
.filter-button{
  background:transparent;border:1px solid var(--line-strong);color:#fff;padding:.65rem .95rem;border-radius:999px;cursor:pointer
}
.filter-button.is-active,.filter-button:hover{background:#fff;color:#000;border-color:#fff}
.gallery-grid{
  display:grid;gap:1rem;grid-template-columns:repeat(3, minmax(0,1fr))
}
.gallery-card{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--surface)
}
.gallery-button{
  width:100%;padding:0;border:0;background:none;color:inherit;text-align:left;cursor:pointer
}
.gallery-button img{width:100%;aspect-ratio:1.2/1;object-fit:cover}
.gallery-meta{display:block;padding:1rem}
.gallery-meta strong{display:block;font-size:1.03rem;margin-bottom:.35rem}
.gallery-meta small{color:var(--muted);display:block;font-size:.95rem;line-height:1.5}
.lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:80;padding:2rem;display:grid;place-items:center
}
.lightbox[hidden]{display:none}
.lightbox-inner{
  width:min(1100px, 100%);display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;align-items:start
}
.lightbox-image{
  width:100%;max-height:78svh;object-fit:contain;background:#000;border-radius:var(--radius)
}
.lightbox-copy{padding:1rem}
.lightbox-close{
  position:absolute;top:1rem;right:1rem;width:3rem;height:3rem;border-radius:999px;border:1px solid var(--line-strong);
  background:rgba(255,255,255,.07);color:#fff;font-size:2rem;cursor:pointer
}
.contact-form{
  display:grid;gap:1rem;background:var(--surface-2);padding:1.4rem;border:1px solid var(--line);border-radius:var(--radius)
}
label{display:grid;gap:.45rem;font-weight:600}
input,select,textarea{
  width:100%;padding:.9rem 1rem;border-radius:14px;border:1px solid var(--line-strong);
  background:#0f0f0f;color:#fff;font:inherit
}
textarea{resize:vertical}
.form-help{font-size:.95rem}
.site-footer{padding-top:2rem;border-top:1px solid var(--line);background:#080808}
.footer-grid{
  display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:1.5rem;padding:2rem 0
}
.footer-brand{font-size:1.15rem;font-weight:800;margin-bottom:.75rem}
.footer-bottom{padding:0 0 2rem;color:#b6b6b6}
.hidden{display:none !important}
@media (max-width: 980px){
  .featured-grid,.cards-three,.service-grid,.faq-grid,.gallery-grid,.intro-grid,.two-col,.split-callout,.contact-grid,.footer-grid,.lightbox-inner{
    grid-template-columns:1fr
  }
  .feature-tall{grid-row:span 1}
  .cta-panel{align-items:flex-start;flex-direction:column}
}
@media (max-width: 760px){
  .site-nav{
    position:absolute;top:calc(100% + 1px);right:1rem;left:1rem;background:rgba(15,15,15,.98);border:1px solid var(--line);
    border-radius:20px;padding:1rem;display:none;flex-direction:column;align-items:stretch
  }
  .site-nav.is-open{display:flex}
  .nav-toggle{display:block}
  .hero-content{padding:5rem 0 4rem}
  .section{padding:4rem 0}
}


.area-pills{
  list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.65rem
}
.area-pills li{
  padding:.7rem .95rem;border:1px solid rgba(0,0,0,.12);border-radius:999px;background:rgba(255,255,255,.9);color:#222
}
