/* === VIEW TRANSITIONS === */
@view-transition{navigation:auto}
::view-transition-old(root){animation:slideOut .3s cubic-bezier(.16,1,.3,1)}
::view-transition-new(root){animation:slideIn .4s cubic-bezier(.16,1,.3,1) .05s both}
@keyframes slideOut{to{opacity:0;transform:translateY(-20px)}}
@keyframes slideIn{from{opacity:0;transform:translateY(20px)}}

/* === SHARED PROJECT PAGE STYLES === */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Geist','Helvetica Neue',sans-serif;background:#0a0a0e;color:#e8e8e8;overflow-x:hidden;animation:pageIn .6s ease-out both}
@keyframes pageIn{from{opacity:0}to{opacity:1}}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}

.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.8rem 3rem;display:flex;justify-content:space-between;align-items:center;background:rgba(10,10,12,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.nav-logo{font-size:.8rem;font-weight:300;letter-spacing:.25em;text-transform:uppercase;opacity:.65;transition:opacity .3s}
.nav-logo:hover{opacity:1}
.nav-logo span{font-weight:600}
.nav-links{display:flex;gap:2.5rem}
.nav-links a{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;opacity:.55;transition:opacity .4s;min-height:44px;display:inline-flex;align-items:center}
.nav-links a:hover{opacity:1}
a:focus-visible{outline:1px solid rgba(70,130,255,.5);outline-offset:4px;border-radius:2px}

.hero{padding:8rem 3rem 2rem;max-width:900px}
.hero-label{font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:.6rem}
.hero h1{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:400;letter-spacing:.1em;text-transform:uppercase;line-height:1.2}
.hero p{font-size:clamp(.8rem,1.1vw,.95rem);font-weight:300;line-height:1.7;color:rgba(255,255,255,.5);margin-top:1rem;max-width:500px}

.gallery{padding:1.5rem 6rem 4rem;display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.gallery-item{overflow:hidden;border-radius:2px;background:#111}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1);aspect-ratio:4/3}
.gallery-item:hover img{transform:scale(1.03)}
/* wide class disabled — uniform grid */
.gallery-caption{padding:.4rem 0;font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.3)}

.video-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:2px;background:#111}
.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.video-section{padding:1.5rem 6rem 4rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}
/* wide disabled */
.video-caption{padding:.6rem 0;font-size:.5rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.35)}

.section-divider{padding:4rem 3rem 2rem;font-size:.55rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.3)}

.back{display:inline-flex;align-items:center;gap:.5rem;padding:2rem 3rem;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);transition:color .3s}
.back:hover{color:rgba(255,255,255,.8)}
.back:active{transform:translateX(-2px);transition-duration:.1s}
.nav-links a:active{opacity:.7;transition-duration:.1s}
.gallery-item:active img{transform:scale(.98);transition-duration:.15s}
.back svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}

.footer{padding:2rem 3rem;border-top:1px solid rgba(255,255,255,.06);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.2);display:flex;justify-content:space-between}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Video hero — constrained, not full-bleed */
.video-hero{position:relative;width:100%;max-width:700px;margin:1.5rem auto 0;padding:0 3rem}
.video-hero video{width:100%;border-radius:2px;background:#111;aspect-ratio:16/9;object-fit:contain}

/* === LIGHTBOX === */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(5,5,10,.95);display:none;align-items:center;justify-content:center;cursor:zoom-out;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease}
.lightbox.active{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:2px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.lightbox-close{position:absolute;top:2rem;right:2rem;font-size:1.5rem;color:rgba(255,255,255,.5);cursor:pointer;transition:color .3s;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none;font-family:inherit}
.lightbox-close:hover{color:#fff}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:1.2rem;color:rgba(255,255,255,.4);cursor:pointer;transition:color .3s;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:none;border:none}
.lightbox-nav:hover{color:#fff}
.lightbox-prev{left:1.5rem}
.lightbox-next{right:1.5rem}
.gallery-item{cursor:zoom-in}

@media(max-width:768px){
  .nav{padding:1.2rem 1.5rem}.nav-links{gap:1rem}.nav-links a{font-size:.55rem}
  .hero{padding:8rem 1.5rem 3rem}
  .gallery{grid-template-columns:repeat(2,1fr);padding:1rem 1.5rem 3rem;gap:.3rem}
  .video-section{grid-template-columns:repeat(2,1fr);padding:1rem 1.5rem 3rem;gap:.3rem}
  .gallery,.video-section{grid-template-columns:1fr}
  .section-divider{padding:3rem 1.5rem 1.5rem}
  .back{padding:1.5rem}
  .footer{flex-direction:column;gap:.5rem;text-align:center;padding:2rem 1.5rem}
  .video-hero{padding:0 1.5rem}
}
