@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --bg:#ffffff;
  --ink:#0a0a0a;
  --muted:rgba(10,10,10,.72);
  --muted2:rgba(10,10,10,.52);
  --accent:#0a0a0a;
  --accent2:#333333;
  --panelBorder:rgba(10,10,10,.12);
  --panelBg:rgba(255,255,255,.60);
  --shadow:rgba(10,10,10,.08);
  --headerStart:rgba(255,255,255,.90);
  --headerEnd:rgba(255,255,255,.65);
  --headerBorder:rgba(10,10,10,.10);
  --gridLine:rgba(10,10,10,.08);
  --serif: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --sans: 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --radius: 0px;
}

:root[data-theme="dark"]{
  --bg:#060608;
  --ink:#f5f5f5;
  --muted:rgba(245,245,245,.72);
  --muted2:rgba(245,245,245,.52);
  --accent:#f5f5f5;
  --accent2:#cccccc;
  --panelBorder:rgba(255,255,255,.10);
  --panelBg:rgba(255,255,255,.04);
  --shadow:rgba(0,0,0,.28);
  --headerStart:rgba(6,6,8,.88);
  --headerEnd:rgba(6,6,8,.25);
  --headerBorder:rgba(255,255,255,.08);
  --gridLine:rgba(255,255,255,.06);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Editorial grid background pattern */
body::before{
  content:'';
  position:fixed; inset:0;
  z-index:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent calc(25vh - 1px),
      var(--gridLine) calc(25vh - 1px),
      var(--gridLine) 25vh
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent calc(25vw - 1px),
      var(--gridLine) calc(25vw - 1px),
      var(--gridLine) 25vw
    );
}

a{color:inherit; text-decoration:none}
button{font:inherit}

#webgl{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:1; pointer-events:none;
}

.vignette{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 520px at 50% 18%, rgba(0,0,0,.0), rgba(0,0,0,.08)),
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.06));
}

.grain{
  position:fixed; inset:0; z-index:2; pointer-events:none;
  opacity:.03; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.62'/%3E%3C/svg%3E");
}

header{
  position:fixed; left:0; right:0; top:0; z-index:50;
  padding:16px 18px;
  background: linear-gradient(180deg, var(--headerStart), var(--headerEnd));
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--headerBorder);
}

.topbar{
  width:min(1180px,100%); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}

.brand{display:flex; align-items:center; gap:10px; font-weight:860; letter-spacing:.3px; text-transform:uppercase; font-size:14px;}
.sig{
  height:34px;
  width:auto;
  display:block;
}

nav{display:flex; align-items:center; gap:18px; color:var(--muted2); font-weight:650; font-size:12px; letter-spacing:.18px; text-transform:uppercase;}
nav a{opacity:.9; transition: opacity .15s ease}
nav a:hover{opacity:1; color:var(--ink)}
@media (max-width: 920px){ nav{display:none} }

/* Mobile menu button — hidden on desktop, shown on mobile */
.menuToggle{display:none; position:relative; z-index:91;}
@media (max-width: 920px){ .menuToggle{display:inline-flex} }

.right{display:flex; align-items:center; gap:14px}
.lang{display:flex; gap:10px; align-items:center; color:var(--muted2); font-weight:720; font-size:12px}
.lang a{opacity:.75}
.lang a.active{opacity:1; color:var(--ink)}

.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:0; font-weight:700;
  border:1px solid var(--panelBorder);
  background: transparent;
  box-shadow: none;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
  white-space:nowrap;
  cursor:pointer;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}
.btn:hover{transform:translateY(-1px); border-color:var(--ink); background: rgba(10,10,10,.04)}

.iconBtn{
  border:1px solid var(--panelBorder);
  background: transparent;
  padding:10px 12px;
  border-radius:0;
  cursor:pointer;
  color:var(--ink);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  transition: border-color .15s ease;
}
.iconBtn:hover{border-color:var(--ink)}

.rail{
  position:fixed; left:18px; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; gap:14px; z-index:40;
  color:var(--muted2); font-weight:900; letter-spacing:.14px; font-size:12px;
}
.rail a{
  display:flex; align-items:center; gap:10px;
  padding:10px 10px; border-radius:0;
  border:1px solid var(--panelBorder);
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(10px);
}
.rail .num{width:26px; text-align:right; color:var(--muted2)}
.rail a.active{border-color:var(--ink); background: rgba(10,10,10,.04)}
.rail a.active .num{color:var(--ink)}
@media (max-width: 980px){ .rail{display:none} }

main{position:relative; z-index:5}
.wrap{width:min(1180px,100%); margin:0 auto; padding:96px 18px 70px}
section.panel{min-height:100vh; padding:74px 0 42px; display:flex; align-items:center;}

.panel + .panel{
  border-top:1px solid var(--panelBorder);
  position:relative;
}
.panel + .panel::before{
  content:'';
  position:absolute;
  top:0; left:50%;
  transform:translate(-50%, -50%) rotate(45deg);
  width:8px; height:8px;
  border:1px solid var(--panelBorder);
  background:var(--bg);
}

.grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:0;
  align-items:stretch;
}
.grid > div{
  padding:28px;
  border-right:1px solid var(--gridLine);
  border-bottom:1px solid var(--gridLine);
}
.grid > div:last-child{
  border-right:none;
}
@media (max-width: 980px){
  .grid{grid-template-columns:1fr}
  .grid > div{border-right:none}
}

#about .grid{
  column-gap:0;
  row-gap:0;
  align-items:center;
}

.kicker{
  font-family:var(--sans);
  letter-spacing:.2em;
  color:var(--muted);
  font-size:11px;
  margin-bottom:14px;
  font-weight:700;
  text-transform:uppercase;
}
.h1{
  font-family:var(--serif);
  font-size: clamp(44px, 5.4vw, 72px);
  line-height: 0.95;
  letter-spacing:-0.02em;
  margin:0 0 14px;
  font-weight:800;
  text-transform:uppercase;
}
.subhead{max-width: 62ch; color:var(--muted); font-size:16.5px; line-height:1.68; margin:0 0 18px;}
.subhead.soft{color:var(--muted2)}

.metaRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:0;
  border:1px solid var(--panelBorder);
  background: transparent;
  color:var(--muted); font-weight:600; font-size:12px;
  letter-spacing:.05em; text-transform:uppercase;
}
.dot{
  width:0; height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-bottom:7px solid var(--ink);
  background:none;
  border-radius:0;
  transform:none;
}

.chapter{
  display:flex; align-items:center; gap:12px;
  color:var(--muted2); font-weight:900;
  letter-spacing:.25em; font-size:11px; text-transform:uppercase;
}
.bar{width:44px; height:1px; background:var(--panelBorder)}
h2{margin:10px 0 10px; font-family:var(--serif); font-size:30px; letter-spacing:-.25px; font-weight:700;}

.cards{display:grid; grid-template-columns:repeat(12,1fr); gap:14px; margin-top:18px;}
.card{
  grid-column: span 6;
  padding:16px 16px 15px;
  border-radius:0;
  border:1px solid var(--panelBorder);
  border-left:2px solid var(--ink);
  background: var(--panelBg);
  backdrop-filter: blur(6px);
  box-shadow: none;
  position:relative;
  overflow:hidden;
}
.card h3{margin:0 0 8px; font-size:14px; letter-spacing:.15px; font-weight:700;}
.card p{margin:0; color:var(--muted2); line-height:1.55; font-size:13.5px}
@media (max-width: 980px){ .card{grid-column: span 12} }

.serviceListCard{
  grid-column: span 12;
  border-left:2px solid var(--ink);
}

.serviceListScroll{
  max-height: 220px;
  overflow-y: auto;
  margin-top: 8px;
  padding-right: 6px;
  border-radius: 0;
}

.serviceListScroll ul{
  margin: 0;
  padding: 0 0 0 18px;
  display: grid;
  gap: 8px;
}

.serviceListScroll li{
  color: var(--muted2);
  line-height: 1.45;
  font-size: 13.5px;
}

.serviceListScroll::-webkit-scrollbar{
  width: 8px;
}

.serviceListScroll::-webkit-scrollbar-thumb{
  background: rgba(10,10,10,.20);
  border-radius: 0;
}

.gallery{display:grid; grid-template-columns: 1fr; gap:14px; margin-top:18px;}
.gItem{
  grid-column: span 12;
  border-radius:0;
  border:1px solid var(--panelBorder);
  background: var(--panelBg);
  overflow:hidden;
  position:relative;
  min-height: 320px;
  box-shadow: none;
  cursor: pointer;
  touch-action: manipulation;
  transition: transform .22s ease, border-color .22s ease;
}
@media (max-width: 980px){ .gItem{min-height: 260px} }

.gItem:hover,
.gItem:focus-visible{
  transform: translateY(-2px);
  border-color: var(--ink);
}

.gItem.active{
  border-color: var(--ink);
}

.galleryControls{
  margin-top: 12px;
  display:flex;
  align-items:center;
  gap:10px;
}

.caseCounter{
  font-size: 12px;
  font-weight: 800;
  color: var(--muted2);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.caseStudyFocus{
  margin-top: 16px;
  padding: 16px;
  border-radius: 0;
  border: 1px solid var(--panelBorder);
  border-left: 2px solid var(--ink);
  background: var(--panelBg);
}

.focusKicker{
  margin: 0 0 8px;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--muted2);
  font-weight: 800;
}

.caseStudyFocus h3{
  margin: 0 0 10px;
  font-family: var(--serif);
  font-size: clamp(20px, 2.6vw, 28px);
}

.gItem .label{
  position:absolute; left:14px; bottom:12px; right:14px;
  display:flex; justify-content:space-between; align-items:flex-end; gap:10px;
  pointer-events:none;
  z-index:2;
  background:rgba(255,255,255,.88);
  border:1px solid var(--panelBorder);
  border-radius:0;
  padding:10px 12px;
  backdrop-filter: blur(2px);
}
.gItem .label b{
  font-family:var(--serif);
  font-size:18px;
  letter-spacing:-.1px;
  color:var(--ink);
}
.gItem .label span{color:var(--muted2); font-size:12px; font-weight:800}

.gItem .layer{position:absolute; inset:0; background-size:cover; background-position:center; z-index:1;}
.gItem .layer.segment{opacity:0; will-change: transform, opacity;}

.lightbox{
  position: fixed;
  inset: 0;
  z-index: 120;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(5, 5, 8, 0.85);
  backdrop-filter: blur(8px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease;
}

.lightbox.open{
  opacity: 1;
  pointer-events: auto;
}

.lightboxImage{
  width: min(1080px, 95vw);
  max-height: 88vh;
  border-radius: 0;
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 12px 40px rgba(0,0,0,.45);
  object-fit: contain;
}

.lightboxClose{
  position: absolute;
  top: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255,255,255,.32);
  border-radius: 0;
  background: rgba(0,0,0,.28);
  color: #fff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
}

.lightboxClose:hover{
  border-color: rgba(255,255,255,.68);
}

body.lightbox-open{
  overflow: hidden;
}

.formWrap{
  margin-top:18px;
  border-radius:0;
  border:1px solid var(--panelBorder);
  overflow:hidden;
  background: var(--panelBg);
}

#contact .contactGrid{
  width:min(1600px, calc(100vw - 36px));
  margin:0 auto;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  align-items:start;
  gap:0;
}

#contact .contactIntro{
  position:sticky;
  top:108px;
}

#contact .contactFormCol,
#contact .formWrap{
  width:100%;
  max-width:none;
}

#contact .contactFormFrame{
  display:block;
  width:100%;
  min-height:980px;
  height:78vh;
  max-height:1240px;
  border:0;
}

@media (max-width: 980px){
  #contact .contactGrid{
    grid-template-columns:1fr;
    gap:0;
  }

  #contact .contactIntro{
    position:static;
  }

  #contact .contactFormFrame{
    min-height:880px;
    height:76vh;
  }
}

footer{padding:56px 0 42px; color:var(--muted2); font-size:13px;}
.footRow{display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; border-top:1px solid var(--panelBorder); padding-top:16px;}

.menuOpen header{z-index:90}
#menuOverlay{
  position:fixed; inset:0; z-index:80;
  display:none;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(14px);
}
:root[data-theme="dark"] #menuOverlay{
  background: rgba(6,6,8,.94);
}
#menuOverlay.open{display:flex; align-items:center; justify-content:center}
.menuInner{width:min(980px,100%); margin:0 auto; padding:110px 18px 40px;}
.menuGrid{display:grid; grid-template-columns: 1.2fr .8fr; gap:18px;}
@media (max-width: 980px){ .menuGrid{grid-template-columns:1fr} }
.menuTitle{font-family:var(--serif); font-size: clamp(34px, 4.2vw, 56px); line-height: 0.98; margin:0 0 14px; text-transform:uppercase; font-weight:800;}
.menuList{display:flex; flex-direction:column; gap:12px; margin-top:18px;}
.menuLink{padding:14px 16px; border-radius:0; border:1px solid var(--panelBorder); background:transparent; font-weight:700; color:var(--ink); font-size:18px; text-align:left; text-decoration:none; text-transform:uppercase; letter-spacing:.3px;}
.menuLink:hover{border-color:var(--ink); background:var(--panelBg)}

/* Dark theme overrides */
:root[data-theme="dark"] .vignette{
  background:
    radial-gradient(900px 520px at 50% 18%, rgba(0,0,0,.0), rgba(0,0,0,.35)),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.45));
}

:root[data-theme="dark"] .grain{
  opacity:.08;
  mix-blend-mode:overlay;
}

:root[data-theme="dark"] .serviceListScroll::-webkit-scrollbar-thumb{
  background: rgba(245,245,245,.20);
}

:root[data-theme="dark"] .gItem .label{
  background:rgba(6,6,8,.80);
  border-color:rgba(255,255,255,.10);
}
:root[data-theme="dark"] .gItem .label b{
  color:var(--ink);
  text-shadow:none;
}

:root[data-theme="dark"] .btn:hover{
  background:rgba(245,245,245,.06);
}

:root[data-theme="dark"] .rail a{
  background:rgba(6,6,8,.70);
}

/* Keep rooks subtle so text stays readable */
:root:not([data-theme="dark"]) #webgl{
  opacity:.40;
}
:root[data-theme="dark"] #webgl{
  opacity:.45;
}

/* Make inline links readable */
.subhead a{
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  text-decoration-color: var(--panelBorder);
}
.subhead a:hover{
  text-decoration-color: var(--ink);
}

/* Rate Card PDF link */
#rate-card a[href$=".pdf"]{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:0;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  border:1px solid var(--panelBorder);
  background: transparent;
  transition: transform .15s ease, border-color .15s ease;
  white-space:nowrap;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}

#rate-card a[href$=".pdf"]::after{
  content:"↗";
  opacity:.72;
  font-weight:900;
  transform: translateY(-1px);
}

#rate-card a[href$=".pdf"]:hover{
  transform: translateY(-1px);
  border-color: var(--ink);
}

#rate-card a[href$=".pdf"]:focus-visible{
  outline: 2px solid var(--ink);
  outline-offset: 3px;
}

footer a[href$=".pdf"]{
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  text-decoration-color: var(--panelBorder);
}
footer a[href$=".pdf"]:hover{
  text-decoration-color: var(--ink);
}

code{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 0;
  border: 1px solid var(--panelBorder);
  background: rgba(10,10,10,.03);
}
:root[data-theme="dark"] code{
  background: rgba(255,255,255,.06);
}
