/* ============================================================
   OPTON — shared stylesheet
   Edit colors here. Everything below uses these variables.
   ============================================================ */
:root[data-theme="dark"]{
  --bg:#0c0a08;            /* page background */
  --bg-2:#1a1611;          /* cards, tiles */
  --text:#ECE7DC;          /* main text */
  --text-soft:rgba(236,231,220,.62);
  --line:rgba(236,231,220,.16);
  --accent:#cd6f44;        /* rust accent */
}
:root[data-theme="light"]{
  --bg:#EDE6D6;
  --bg-2:#ddd4bf;
  --text:#1a1611;
  --text-soft:rgba(26,22,17,.62);
  --line:rgba(26,22,17,.16);
  --accent:#a8502a;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased;transition:background .15s,color .15s}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---------- header ---------- */
header{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:20px 48px;border-bottom:1px solid var(--line)}
header .logo{height:34px;width:auto;filter:invert(1)}
[data-theme="light"] header .logo{filter:none}
header nav{display:flex;gap:24px;align-items:center;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-soft)}
header nav a{white-space:nowrap}
header nav a:hover, header nav a.is-active{color:var(--text)}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;
  background:none;border:1px solid var(--line);border-radius:50%;color:var(--text-soft);cursor:pointer;
  transition:color .15s,border-color .15s,background .15s}
.theme-toggle:hover{color:var(--text);border-color:var(--text)}
.theme-toggle svg{width:17px;height:17px;display:block}
[data-theme="dark"] .theme-toggle .moon{display:none}
[data-theme="light"] .theme-toggle .sun{display:none}

/* ---------- layout ---------- */
section{padding:80px 48px}
.container{max-width:1200px;margin:0 auto}
.eyebrow{font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:20px}
h1{font-weight:800;font-size:clamp(40px,6vw,84px);line-height:1.02;letter-spacing:-.03em}
h2{font-weight:700;font-size:clamp(28px,3.5vw,44px);letter-spacing:-.02em;margin-bottom:28px}
.lede{font-size:19px;line-height:1.55;color:var(--text-soft);max-width:62ch;margin-top:20px}

/* ---------- hero ---------- */
.hero{padding:110px 48px 90px;border-bottom:1px solid var(--line)}
.hero .container{max-width:1200px}

/* key facts row */
.facts{display:flex;flex-wrap:wrap;gap:40px;margin-top:40px}
.facts div{font-size:14px;color:var(--text-soft)}
.facts b{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text);margin-bottom:5px}

/* ---------- practice cards (homepage) ---------- */
.practice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.pcard{display:flex;flex-direction:column;gap:10px;padding:32px;border:1px solid var(--line);background:var(--bg-2);transition:border-color .15s}
.pcard:hover{border-color:var(--accent)}
.pcard .n{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.1em}
.pcard h3{font-size:26px;font-weight:700;letter-spacing:-.015em}
.pcard p{font-size:15px;line-height:1.5;color:var(--text-soft)}
.pcard .go{margin-top:auto;padding-top:12px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}

/* ---------- works table ---------- */
table.works{width:100%;border-collapse:collapse}
table.works th{text-align:left;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-soft);padding:12px 0;border-bottom:1px solid var(--text)}
table.works td{padding:16px 0;border-bottom:1px solid var(--line);font-size:16px}
table.works td.year{width:90px;color:var(--text-soft)}
table.works td.t{font-weight:700;font-size:19px}
table.works td.studio{color:var(--text-soft);font-size:14px}
table.works td.role{text-align:right;color:var(--text-soft);font-size:14px}
table.works td.fmt{color:var(--text-soft)}
table.works .title-link{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s,color .15s}
table.works .title-link:hover{color:var(--accent);border-bottom-color:var(--accent)}

/* ---------- clients ---------- */
.clients{display:grid;grid-template-columns:repeat(6,1fr);gap:32px;align-items:center}
.clients .c{height:44px;display:flex;align-items:center;justify-content:center}
.clients img{max-width:100%;max-height:100%;object-fit:contain;filter:invert(1);opacity:.78}
[data-theme="light"] .clients img{filter:none;opacity:.85}

/* ---------- contact ---------- */
.contact-box{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:48px;border:1px solid var(--line);background:var(--bg-2)}
.contact-box h2{margin-bottom:12px}
.contact-box p{color:var(--text-soft);line-height:1.55;max-width:44ch}
.contact-list{display:flex;flex-direction:column;gap:14px;font-size:16px}
.contact-list b{display:inline-block;width:90px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-soft)}

/* ---------- footer ---------- */
footer{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:32px 48px;border-top:1px solid var(--line);font-size:13px;color:var(--text-soft);flex-wrap:wrap}
footer .logo{height:22px;width:auto;filter:invert(1);opacity:.8}
[data-theme="light"] footer .logo{filter:none}
footer nav{display:flex;gap:20px;font-size:12px;letter-spacing:.1em;text-transform:uppercase}
footer nav a:hover{color:var(--text)}

/* ---------- practice pages ---------- */
.page-hero{padding:90px 48px 70px;border-bottom:1px solid var(--line)}
.crumbs{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft);margin-bottom:24px}
.crumbs a:hover{color:var(--text)}

/* photo grid — replace each .ph with <img class="photo" src="..."> */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.photo-grid .wide{grid-column:span 2}
.ph{aspect-ratio:4/3;background:var(--bg-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-align:center;padding:16px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-soft)}
.photo{aspect-ratio:4/3;width:100%;object-fit:cover;border:1px solid var(--line)}
.caption{font-size:12px;color:var(--text-soft);margin-top:8px}

/* equipment list */
.gear{display:grid;grid-template-columns:repeat(2,1fr);gap:20px 48px}
.gear .group{padding:24px;border:1px solid var(--line)}
.gear h4{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.gear ul{list-style:none}
.gear li{padding:8px 0;border-bottom:1px solid var(--line);font-size:15px}
.gear li:last-child{border-bottom:0}
.gear li span{color:var(--text-soft);font-size:13px;float:right}

/* simple CTA band */
.cta{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:40px 48px;border:1px solid var(--line);background:var(--bg-2);flex-wrap:wrap}
.cta h3{font-size:26px;font-weight:700;letter-spacing:-.015em}
.btn{display:inline-block;padding:14px 28px;border:1px solid var(--text);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;transition:background .15s,color .15s}
.btn:hover{background:var(--text);color:var(--bg)}

/* ---------- responsive ---------- */
@media (max-width:900px){
  header{flex-direction:column;align-items:center;gap:14px;padding:16px 16px}
  header .logo{height:28px}
  header nav{gap:6px 18px;font-size:11px;flex-wrap:wrap;justify-content:center;row-gap:6px}
  header nav a{padding:6px 2px}
  section{padding:48px 16px}
  .hero,.page-hero{padding:56px 16px 44px}
  .lede{font-size:16px}
  .facts{gap:20px 28px;margin-top:32px}
  .practice-grid{grid-template-columns:1fr}
  .pcard{padding:24px}
  .clients{grid-template-columns:repeat(3,1fr);gap:20px}
  .clients .c{height:36px}
  .contact-box{grid-template-columns:1fr;padding:24px;gap:28px}
  .photo-grid{grid-template-columns:1fr}
  .photo-grid .wide{grid-column:span 1}
  .gear{grid-template-columns:1fr;gap:14px}
  .cta{padding:28px 24px;justify-content:center;text-align:center}
  footer{padding:24px 16px;justify-content:center;text-align:center;gap:16px}

  /* works table → stacked rows on phones */
  table.works thead{display:none}
  table.works, table.works tbody{display:block}
  table.works tr{display:flex;flex-wrap:wrap;gap:2px 14px;padding:16px 0;border-bottom:1px solid var(--line)}
  table.works td{display:block;border:0;padding:0}
  table.works td.t{width:100%;order:-1;font-size:18px}
  table.works td.year{width:auto;font-size:13px}
  table.works td.fmt{font-size:13px}
  table.works td.studio{font-size:13px}
  table.works td.studio:empty{display:none}
  table.works td.role{margin-left:auto;text-align:right;font-size:13px}
}

/* ============================================================
   Staff link (footer)
   ============================================================ */
.staff-link{opacity:.6;transition:opacity .15s,color .15s}
.staff-link:hover{opacity:1;color:var(--accent)}

/* ============================================================
   Gallery (dynamic, any count) + lightbox
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery .gphoto{margin:0}
.gallery .gphoto.wide{grid-column:span 2}
.gphoto-btn{display:block;width:100%;padding:0;border:0;background:none;cursor:zoom-in;overflow:hidden;border-radius:2px}
.gphoto-btn img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line);border-radius:2px;
  transition:transform .35s ease,filter .2s ease}
.gphoto-btn:hover img{transform:scale(1.04);filter:brightness(1.05)}
.gallery figcaption{font-size:12px;color:var(--text-soft);margin-top:8px}

.lightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:32px;
  background:rgba(10,8,6,.92);cursor:zoom-out}
.lightbox.open{display:flex;animation:lbfade .15s ease}
@keyframes lbfade{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:94vw;max-height:90vh;object-fit:contain;border-radius:3px;box-shadow:0 24px 80px rgba(0,0,0,.5)}
.lightbox .lb-close{position:fixed;top:20px;right:26px;background:none;border:0;color:#fff;font-size:40px;line-height:1;cursor:pointer;opacity:.8}
.lightbox .lb-close:hover{opacity:1}

@media (max-width:720px){
  .gallery{grid-template-columns:1fr 1fr;gap:12px}
  .gallery .gphoto.wide{grid-column:span 2}
}
