/* lighting.life — production stylesheet (faithful to design handoff) */
:root{
  --accent:#e7a338;
  --accent-rgb:231,163,56;
  --accent-ink:#a96a12;
  --ink:#1c1a17;
  --panel-dark:#211f1c;
  --display:'Helvetica Neue',Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:#fff;}
body{color:var(--ink);font-family:'Archivo',sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
::selection{background:#e7a338;color:#1c1a17;}
input,textarea,button{border-radius:0;-webkit-appearance:none;appearance:none;font-family:inherit;}
img{max-width:100%;}
[hidden]{display:none !important;}
picture{display:contents;}

/* width-matched fallback so the Anton headline never reflows/clips during font load */
@font-face{font-family:'AntonFB';src:local('Arial Narrow Bold'),local('Arial Narrow'),local('Arial');size-adjust:84%;ascent-override:90%;descent-override:20%;line-gap-override:0%;}

@keyframes llUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:translateY(0);}}
@keyframes llFade{from{opacity:0;}to{opacity:1;}}
@keyframes llBlink{0%,49%{opacity:1;}50%,100%{opacity:0;}}
@keyframes tileIn{from{opacity:0;transform:translateY(20px) scale(.985);}to{opacity:1;transform:translateY(0) scale(1);}}

/* atmosphere */
.atmo-glow{position:fixed;inset:0;pointer-events:none;z-index:1;background:radial-gradient(120% 70% at 50% -10%, rgba(var(--accent-rgb),0.07), transparent 55%);}
.atmo-noise{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.035;mix-blend-mode:multiply;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="140" height="140"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency="0.85" numOctaves="2"/></filter><rect width="100%25" height="100%25" filter="url(%23n)"/></svg>');}
.page{position:relative;z-index:2;min-height:100vh;}

.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--accent);color:#1c1a17;padding:10px 18px;font-family:'Space Mono',monospace;font-size:12px;text-transform:uppercase;letter-spacing:0.16em;text-decoration:none;}
.skip-link:focus{left:0;}
:focus-visible{outline:2px solid var(--accent-ink);outline-offset:2px;}

/* ===================== HERO ===================== */
.hero{padding:clamp(32px,6vh,72px) clamp(18px,5vw,72px) clamp(32px,6vh,72px);}
.hero-c{position:relative;max-width:1560px;margin:0 auto;display:block;}
.hero-media{width:70%;aspect-ratio:16/9;background:#0e0d0b;overflow:hidden;animation:llFade 1.2s both;position:relative;}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-card{position:absolute;right:0;top:6%;bottom:6%;width:46%;background:#eaeaea;overflow:visible;container-type:inline-size;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(16px,1.8vw,32px);box-shadow:0 30px 70px rgba(0,0,0,0.12);animation:llUp 1s .2s both;}
.hero-card h1{margin:0;font-family:'Anton','AntonFB','Arial Narrow',sans-serif;font-weight:400;font-size:clamp(40px,22cqw,168px);line-height:0.92;letter-spacing:0.01em;text-transform:uppercase;color:#333333;}
.hero-card h1 span{display:block;}
.hero-card h1 span + span{margin-top:8px;}
.hero-tagline{margin:clamp(20px,2.4vw,34px) 0 0;max-width:360px;font-weight:600;font-size:clamp(12px,1.15vw,16px);letter-spacing:0.045em;line-height:1.5;text-transform:uppercase;color:#4a4742;}

/* ===================== LATEST WORK ===================== */
.work{padding:0 clamp(18px,5vw,72px) clamp(56px,9vh,110px);scroll-margin-top:74px;}
.work-head{text-align:left;margin-bottom:clamp(26px,4vh,38px);}
.tw-h{margin:0;font-family:var(--display);font-weight:700;font-size:clamp(28px,3.3vw,48px);line-height:1;letter-spacing:-0.01em;text-transform:uppercase;color:#26231f;min-height:1em;}
.caret{display:inline-block;width:0.055em;height:0.82em;background:var(--accent);margin-left:0.07em;vertical-align:-0.04em;animation:llBlink 1s step-end infinite;}
.caret-sm{width:0.05em;height:0.78em;margin-left:0.06em;vertical-align:-0.03em;}

.filters{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:clamp(18px,2.6vh,26px);}
.filter{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;padding:12px 26px;cursor:pointer;transition:all .25s;font-weight:400;border:1px solid #1c1a17;background:#1c1a17;color:#d6d1c7;}
.filter.is-active{font-weight:700;border-color:var(--accent);background:var(--accent);color:#1c1a17;}

.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(max(150px, calc((100% - 30px) / 6)),1fr));grid-auto-rows:150px;gap:6px;grid-auto-flow:dense;}
.tile{display:block;width:100%;height:100%;padding:0;margin:0;border:none;cursor:pointer;position:relative;overflow:hidden;background:#16140f;}
.tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease, filter .5s ease;}
.tile:hover img,.tile:focus-visible img{transform:scale(1.08);filter:grayscale(1);}
.s2x2{grid-column:span 2;grid-row:span 2;}
.s1x2{grid-row:span 2;}
.s2x1{grid-column:span 2;}
.tile-sound{cursor:default;}
.tile-sound iframe{width:100%;height:100%;border:0;display:block;background:#16140f;}
@supports (animation-timeline: view()){
  .tile{animation:tileIn linear both;animation-timeline:view();animation-range:entry 0% entry 55%;}
}
.play-badge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.play-badge > span{width:44px;height:44px;border-radius:50%;background:rgba(231,163,56,0.95);display:flex;align-items:center;justify-content:center;color:#1c1a17;font-size:15px;padding-left:3px;}
.play-badge-sm > span{width:38px;height:38px;font-size:13px;}

.more-wrap{display:flex;justify-content:center;margin-top:30px;}
.more{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:#1c1a17;background:transparent;border:1px solid rgba(0,0,0,0.25);padding:14px 40px;cursor:pointer;transition:all .2s;}
.more:hover{border-color:var(--accent-ink);color:var(--accent-ink);}

/* ===================== GET IN TOUCH ===================== */
.touch{margin-top:-45px;padding:clamp(10px,1.5vh,22px) clamp(18px,5vw,72px) 21px;}
.touch .tw-h{margin:0 0 clamp(26px,4vh,46px);}
.gt-grid{max-width:1480px;display:grid;grid-template-columns:0.92fr 1.08fr;gap:0;align-items:stretch;box-shadow:0 26px 70px rgba(0,0,0,0.12);}

.gt-left{background:#211f1c;display:flex;flex-direction:column;}
.cv-banner{position:relative;min-height:clamp(210px,27vh,310px);overflow:hidden;display:flex;align-items:center;justify-content:center;text-decoration:none;}
.cv-bg{position:absolute;left:0;right:0;top:-90px;bottom:-90px;background-size:cover;background-position:center 30%;will-change:transform;}
.cv-shade{position:absolute;inset:0;background:linear-gradient(180deg, rgba(15,13,11,0.12), rgba(15,13,11,0.22));}
.cv-btn{position:relative;z-index:1;font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:#1c1a17;background:#fff;padding:14px 34px;transition:background .2s ease;}
.cv-banner:hover .cv-btn,.cv-banner:focus-visible .cv-btn{background:var(--accent);}

.ig-head{display:flex;align-items:center;gap:13px;padding:clamp(20px,2vw,26px) clamp(20px,2.2vw,30px) clamp(16px,1.6vw,20px);}
.ig-ring{width:46px;height:46px;border-radius:50%;padding:2px;background:conic-gradient(from 215deg, #f9ce34, var(--accent), #d8612e, #c13584, #f9ce34);flex:none;display:block;}
.ig-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;object-position:center 22%;border:2px solid #211f1c;display:block;}
.ig-id{line-height:1.25;min-width:0;}
.ig-handle{font-weight:700;font-size:15px;color:#f3f0ea;}
.ig-sub{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:#8d877d;}
.ig-follow{margin-left:auto;font-family:'Space Mono',monospace;font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:#1c1a17;background:var(--accent);padding:9px 16px;text-decoration:none;white-space:nowrap;}
.ig-follow:hover{filter:brightness(1.06);}

.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:0 3px 3px;}
.ig-tile{position:relative;padding:0;margin:0;border:none;cursor:pointer;aspect-ratio:1/1;overflow:hidden;background:#16140f;display:block;}
.ig-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.ig-tile:hover img,.ig-tile:focus-visible img{transform:scale(1.07);}
.ig-shade{position:absolute;inset:0;background:rgba(28,26,23,0);transition:background .3s ease;}
.ig-tile:hover .ig-shade,.ig-tile:focus-visible .ig-shade{background:rgba(28,26,23,0.34);}
.ig-badge-carousel{position:absolute;top:7px;right:7px;width:15px;height:15px;pointer-events:none;}
.ig-badge-carousel span:first-child{position:absolute;top:0;right:0;width:11px;height:11px;border:1.6px solid #fff;border-radius:3px;}
.ig-badge-carousel span:last-child{position:absolute;bottom:0;left:0;width:11px;height:11px;border:1.6px solid #fff;border-radius:3px;background:#211f1c;}

.gt-right{background:#e9e9e9;display:flex;flex-direction:column;}
.form-wrap{flex:1;padding:clamp(26px,3vw,52px);display:flex;flex-direction:column;gap:clamp(16px,1.8vw,22px);}
.sent-panel{height:100%;min-height:380px;display:flex;flex-direction:column;justify-content:center;gap:10px;}
.sent-title{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.2vw,42px);text-transform:uppercase;color:#26231f;}
.sent-panel p{margin:0;color:#57524a;font-size:15px;line-height:1.6;}
#contact-form{display:flex;flex-direction:column;gap:clamp(18px,2vw,24px);}
.gt-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2vw,24px);}
#contact-form label{display:flex;flex-direction:column;gap:9px;}
#contact-form label > span{font-weight:700;font-size:16px;color:#2c2a27;}
#contact-form label em{font-style:normal;color:var(--accent-ink);}
#contact-form input,#contact-form textarea{background:#fff;border:none;box-shadow:0 1px 2px rgba(0,0,0,0.06);padding:16px 17px;color:#1c1a17;font-size:15px;outline:none;}
#contact-form input:focus,#contact-form textarea:focus{box-shadow:0 0 0 2px var(--accent);}
#contact-form textarea{resize:vertical;min-height:170px;}
.hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;opacity:0;}
.send{width:100%;font-family:'Space Mono',monospace;font-size:13px;letter-spacing:0.24em;text-transform:uppercase;color:#f3f0ea;background:#1c1a17;border:none;padding:19px;cursor:pointer;font-weight:700;transition:background .2s ease;}
.send:hover{background:var(--accent-ink);color:#fff;}
.send[disabled]{opacity:.6;cursor:wait;}
.form-error{margin:0;font-size:13px;color:var(--accent-ink);}
.form-error a{color:var(--accent-ink);}

.contact-strip{min-height:clamp(92px,10vw,140px);background:#211f1c;padding:clamp(18px,2vw,26px) clamp(24px,2.4vw,34px);display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;}
.cs-email{display:flex;flex-direction:column;gap:6px;}
.cs-label{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:#8d877d;}
.cs-addr{font-weight:600;font-size:clamp(16px,1.5vw,21px);color:var(--accent);text-decoration:none;white-space:nowrap;}
.cs-addr:hover{text-decoration:underline;}
.cs-links{display:flex;gap:9px;flex-wrap:wrap;margin-left:auto;}
.cs-links a{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:#d6d1c7;padding:9px 15px;text-decoration:none;border:1px solid rgba(255,255,255,0.2);}
.cs-links a:hover{border-color:var(--accent);color:#fff;}

/* ===================== FOOTER ===================== */
.footer{padding:34px clamp(18px,5vw,72px);border-top:1px solid rgba(0,0,0,0.08);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;}
.f-brand{display:flex;align-items:center;gap:11px;}
.f-brand img{width:20px;height:20px;}
.f-brand span{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.12em;color:#9a948a;}
.f-links{display:flex;gap:20px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;}
.f-links a{color:#6b655c;text-decoration:none;}
.f-links a:hover{color:#1c1a17;}

/* ===================== LIGHTBOX ===================== */
.lb{position:fixed;inset:0;z-index:80;background:rgba(255,255,255,0.97);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,56px);animation:llFade .25s both;}
.lb-scrim{position:absolute;inset:0;z-index:0;cursor:zoom-out;}
.lb-close{position:absolute;top:20px;right:24px;z-index:3;background:none;border:none;color:#1c1a17;font-size:34px;cursor:pointer;line-height:1;font-family:'Archivo',sans-serif;}
.lb-close:hover{color:#000;}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:#fff;border:1px solid #dcd7ce;color:#1c1a17;width:48px;height:48px;cursor:pointer;font-size:20px;}
.lb-prev{left:clamp(8px,2vw,28px);}
.lb-next{right:clamp(8px,2vw,28px);}
.lb-prev:hover,.lb-next:hover{background:var(--accent);border-color:var(--accent);}
.lb-fig{position:relative;z-index:2;margin:0;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:14px;}
.lb-media img{max-width:92vw;max-height:78vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,0.24);display:block;}
.lb-media video{max-width:92vw;max-height:78vh;background:#000;box-shadow:0 30px 80px rgba(0,0,0,0.28);display:block;}
.lb-sound{width:min(720px,92vw);background:#0e0d0b;box-shadow:0 30px 80px rgba(0,0,0,0.28);}
.lb-sound img{width:100%;max-height:46vh;object-fit:cover;display:block;}
.lb-sound iframe{display:block;border:0;width:100%;height:166px;}
.lb-cap{display:flex;align-items:center;gap:14px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:#1c1a17;}
.lb-chip{color:#1c1a17;background:var(--accent);padding:3px 9px;}

/* ===================== RESPONSIVE ===================== */
@media (max-width:900px){
  .hero-c{display:block;}
  .hero-media{width:100%;aspect-ratio:16/10;}
  .hero-card{position:static;width:auto;margin:-58px 12px 0;top:auto;bottom:auto;padding:34px 26px;}
  .gt-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .gal-grid{grid-template-columns:repeat(2,1fr);}
  .gt-row{grid-template-columns:1fr;}
}

/* ===================== REDUCED MOTION ===================== */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important;}
  .caret{display:none;}
}

/* ---- generated from content/items.json ---- */
.hero-media img{object-position:40% 38%;}
.cv-bg{background-image:url('/assets/img/202107-15a3895-1-scaled-1080.jpg');}
