/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
    --bg: #0a0a0a;
    --bg-alt: #0f0f0f;
    --surface: #161616;
    --text: #e5e5e5;
    --text-dim: #5a5a5a;
    --accent: #d4d4d4;
    --accent-soft: rgba(212,212,212,0.08);
    --white: #ffffff;
    --font-display: 'Syne', system-ui, sans-serif;
    --font-body: 'Inter', system-ui, sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --ease-smooth: cubic-bezier(0.25, 1, 0.5, 1);
    --letterbox: 24px;
}

/* ============================================
   RESET
   ============================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
button{background:none;border:none;color:inherit;cursor:pointer;font-family:inherit}
em{font-style:normal;font-weight:600;color:var(--white);font-family:var(--font-display)}
::selection{background:var(--white);color:var(--bg)}

/* ============================================
   PRELOADER
   ============================================ */
.preloader{
    position:fixed;inset:0;z-index:10000;background:var(--bg);
    display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;
    transition:opacity .8s var(--ease),visibility .8s;
}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader-bar{
    width:120px;height:1px;background:var(--surface);position:relative;overflow:hidden;
}
.preloader-bar::after{
    content:'';position:absolute;inset:0;background:var(--accent);
    transform-origin:left;animation:preload-bar 1.6s var(--ease) infinite;
}
@keyframes preload-bar{0%{transform:scaleX(0)}50%{transform:scaleX(1)}100%{transform:scaleX(0);transform-origin:right}}
.preloader-counter{
    font-family:var(--font-mono);font-size:.75rem;color:var(--text-dim);letter-spacing:.2em;
}



/* ============================================
   LETTERBOX BARS (cinematic)
   ============================================ */
.letterbox{
    position:fixed;left:0;right:0;background:var(--bg);z-index:9900;
    pointer-events:none;height:50vh; /* Start closed */
    transition:height 1.5s cubic-bezier(0.8, 0, 0.1, 1);
}
body.loaded .letterbox{height:var(--letterbox)}
.letterbox--top{top:0}
.letterbox--bottom{bottom:0}

/* Cursor: removed per user feedback */



/* ============================================
   HEADER
   ============================================ */
.header{
    position:fixed;top:var(--letterbox);left:0;right:0;z-index:95;
    display:flex;align-items:center;justify-content:space-between;
    padding:20px 40px;
    transition:background .5s,backdrop-filter .5s;
}
.header.scrolled{
    background:rgba(11,11,11,.8);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
.logo{display:flex;align-items:center;gap:6px;z-index:101}
.logo-svg{
    display:block;color:var(--text);transition:color .3s;
}
.logo:hover .logo-svg{color:var(--accent)}

.header-center{position:absolute;left:50%;transform:translateX(-50%)}
.header-timecode{
    font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);
    letter-spacing:.15em;opacity:.5;
}

.nav{display:flex;gap:36px}
.nav-link{
    font-size:.75rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
    color:var(--white);transition:color .3s;position:relative;
}
.nav-link::after{
    content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
    background:var(--accent);transition:width .5s var(--ease);
}
.nav-link:hover{color:rgba(255,255,255,.5)}
.nav-link:hover::after{width:100%}

.menu-btn{display:none;flex-direction:column;gap:5px;padding:8px;z-index:101}
.menu-btn span{display:block;width:24px;height:1.5px;background:var(--text);transition:transform .5s var(--ease),opacity .3s}
.menu-btn.active span:first-child{transform:rotate(45deg) translate(2px,2px)}
.menu-btn.active span:last-child{transform:rotate(-45deg) translate(2px,-2px)}

/* ============================================
   MOBILE MENU
   ============================================ */
.mobile-menu{
    position:fixed;inset:0;z-index:100;background:rgba(11,11,11,.97);
    backdrop-filter:blur(40px);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s;
}
.mobile-menu.active{opacity:1;visibility:visible}
.mobile-menu-nav{display:flex;flex-direction:column;gap:8px;text-align:center}
.mobile-menu-link{
    font-family:var(--font-display);font-size:clamp(2.5rem,8vw,5rem);font-weight:700;
    text-transform:uppercase;letter-spacing:-.02em;
    color:var(--text);transform:translateY(30px);opacity:0;
    transition:transform .6s var(--ease),opacity .6s,color .3s;
}
.mobile-menu.active .mobile-menu-link{transform:translateY(0);opacity:1}
.mobile-menu.active .mobile-menu-link:nth-child(1){transition-delay:.1s}
.mobile-menu.active .mobile-menu-link:nth-child(2){transition-delay:.18s}
.mobile-menu.active .mobile-menu-link:nth-child(3){transition-delay:.26s}
.mobile-menu-link:hover{color:var(--accent)}
.mobile-menu-footer{position:absolute;bottom:48px;text-align:center}
.mobile-menu-label{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim)}

/* ============================================
   HERO
   ============================================ */
.hero{
    min-height:100vh;display:flex;flex-direction:column;
    justify-content:center;position:relative;overflow:hidden;
    padding:calc(var(--letterbox) + 80px) 40px var(--letterbox);
}
.hero-video-container {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
}
.hero-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.6;
}
.hero-video--r2 {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border: none;
}.hero-content--minimal {
    position: relative;
    z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}
.hero-name-minimal {
    font-family: var(--font-display);
    font-size: clamp(1.2rem, 3vw, 2.5rem);
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--white);
    margin-bottom: 8px;
    text-shadow: 0 2px 20px rgba(0,0,0,.6);
}
.hero-tagline-minimal {
    font-size: clamp(.7rem, 1.2vw, .9rem);
    font-weight: 400;
    color: rgba(255,255,255,.75);
    letter-spacing: .2em;
    text-transform: uppercase;
    font-family: var(--font-mono);
    text-shadow: 0 2px 16px rgba(0,0,0,.7);
}

.hero-bottom{
    position:absolute;bottom:calc(var(--letterbox) + 40px);left:40px;right:40px;
    display:flex;justify-content:space-between;align-items:flex-end;
}
.hero-scroll{
    display:flex;align-items:center;gap:12px;
    font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim);
}
.hero-scroll-dot{
    width:6px;height:6px;border-radius:50%;border:1px solid var(--text-dim);
    animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.hero-meta{
    display:flex;align-items:center;gap:12px;
    font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--white);
}
.hero-meta-sep{color:var(--accent);opacity:.5}

/* ============================================
   WORK SECTION
   ============================================ */
.work{
    padding:160px 40px 80px;max-width:1400px;margin:0 auto;
}
.work-header{margin-bottom:80px}
.section-eyebrow{
    display:flex;align-items:center;gap:12px;
    font-size:.65rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
    color:var(--text-dim);margin-bottom:16px;
}
.section-eyebrow-index{color:var(--accent);font-family:var(--font-mono)}
.section-eyebrow-line{width:24px;height:1px;background:var(--text-dim);opacity:.3}
.work-title{
    font-family:var(--font-display);font-size:clamp(1.2rem, 3vw, 2.5rem);font-weight:700;
    letter-spacing:-.03em;text-transform:uppercase;
}

/* ============================================
   PROJECTS
   ============================================ */
.projects{display:flex;flex-direction:column;gap:24px}

.projects-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.projects-row--three{grid-template-columns:repeat(3,1fr)}

.project{
    display:block;position:relative;border-radius:4px;overflow:hidden;
    cursor:pointer;
}
.project-visual{
    position:relative;overflow:hidden;
    border-radius:4px;
}
.project--full .project-visual{aspect-ratio:21/9}
.project--half .project-visual{aspect-ratio:16/10}
.project--third .project-visual{aspect-ratio:4/3}

.project-img{
    position:absolute;inset:0;
    transition:transform 1.2s var(--ease),filter 1.2s var(--ease);
    will-change:transform;
    filter:grayscale(0%) contrast(1);
}
.project:hover .project-img{transform:scale(1.05);filter:brightness(0.7);}

.project-card-video{
    position:absolute;inset:0;overflow:hidden;
    transition:filter 1.2s var(--ease);
}
.project:hover .project-card-video{filter:brightness(0.7);}
.project-card-video video{
    position:absolute;inset:0;
    width:100%;height:100%;
    object-fit:cover;
    border:none;pointer-events:none;
}
.project-card-video iframe{
    position:absolute;
    top:50%;left:50%;
    aspect-ratio:16/9;
    min-width:100%;
    min-height:100%;
    transform:translate(-50%,-50%);
    border:none;pointer-events:none;
}

/* Overlay gradient */
.project-visual::after{
    content:'';position:absolute;inset:0;z-index:1;
    background:linear-gradient(
        to top,
        rgba(11,11,11,.70) 0%,
        rgba(11,11,11,.69) 1%,
        rgba(11,11,11,.68) 2%,
        rgba(11,11,11,.67) 3%,
        rgba(11,11,11,.66) 4%,
        rgba(11,11,11,.65) 5%,
        rgba(11,11,11,.63) 6%,
        rgba(11,11,11,.62) 7%,
        rgba(11,11,11,.61) 8%,
        rgba(11,11,11,.60) 9%,
        rgba(11,11,11,.58) 10%,
        rgba(11,11,11,.57) 11%,
        rgba(11,11,11,.56) 12%,
        rgba(11,11,11,.55) 13%,
        rgba(11,11,11,.53) 14%,
        rgba(11,11,11,.52) 15%,
        rgba(11,11,11,.51) 16%,
        rgba(11,11,11,.49) 17%,
        rgba(11,11,11,.48) 18%,
        rgba(11,11,11,.47) 19%,
        rgba(11,11,11,.46) 20%,
        rgba(11,11,11,.44) 21%,
        rgba(11,11,11,.43) 22%,
        rgba(11,11,11,.42) 23%,
        rgba(11,11,11,.41) 24%,
        rgba(11,11,11,.40) 25%,
        rgba(11,11,11,.38) 26%,
        rgba(11,11,11,.37) 27%,
        rgba(11,11,11,.36) 28%,
        rgba(11,11,11,.35) 29%,
        rgba(11,11,11,.34) 30%,
        rgba(11,11,11,.32) 32%,
        rgba(11,11,11,.30) 34%,
        rgba(11,11,11,.28) 36%,
        rgba(11,11,11,.27) 38%,
        rgba(11,11,11,.25) 40%,
        rgba(11,11,11,.23) 42%,
        rgba(11,11,11,.21) 44%,
        rgba(11,11,11,.20) 46%,
        rgba(11,11,11,.18) 48%,
        rgba(11,11,11,.16) 50%,
        rgba(11,11,11,.15) 52%,
        rgba(11,11,11,.13) 54%,
        rgba(11,11,11,.12) 56%,
        rgba(11,11,11,.10) 58%,
        rgba(11,11,11,.09) 60%,
        rgba(11,11,11,.08) 62%,
        rgba(11,11,11,.07) 64%,
        rgba(11,11,11,.06) 66%,
        rgba(11,11,11,.05) 68%,
        rgba(11,11,11,.04) 70%,
        rgba(11,11,11,.04) 72%,
        rgba(11,11,11,.03) 74%,
        rgba(11,11,11,.02) 76%,
        rgba(11,11,11,.02) 78%,
        rgba(11,11,11,.02) 80%,
        rgba(11,11,11,.01) 82%,
        rgba(11,11,11,.01) 84%,
        rgba(11,11,11,.01) 86%,
        rgba(11,11,11,.00) 90%,
        transparent 100%
    );
    transition:opacity .5s;
}
.project:hover .project-visual::after{
    background:linear-gradient(
        to top,
        rgba(11,11,11,.85) 0%,
        rgba(11,11,11,.84) 1%,
        rgba(11,11,11,.83) 2%,
        rgba(11,11,11,.82) 3%,
        rgba(11,11,11,.80) 4%,
        rgba(11,11,11,.79) 5%,
        rgba(11,11,11,.78) 6%,
        rgba(11,11,11,.76) 7%,
        rgba(11,11,11,.75) 8%,
        rgba(11,11,11,.73) 9%,
        rgba(11,11,11,.72) 10%,
        rgba(11,11,11,.70) 11%,
        rgba(11,11,11,.69) 12%,
        rgba(11,11,11,.67) 13%,
        rgba(11,11,11,.66) 14%,
        rgba(11,11,11,.64) 15%,
        rgba(11,11,11,.62) 16%,
        rgba(11,11,11,.61) 17%,
        rgba(11,11,11,.59) 18%,
        rgba(11,11,11,.57) 19%,
        rgba(11,11,11,.56) 20%,
        rgba(11,11,11,.54) 21%,
        rgba(11,11,11,.52) 22%,
        rgba(11,11,11,.51) 23%,
        rgba(11,11,11,.49) 24%,
        rgba(11,11,11,.47) 25%,
        rgba(11,11,11,.46) 26%,
        rgba(11,11,11,.44) 27%,
        rgba(11,11,11,.42) 28%,
        rgba(11,11,11,.41) 29%,
        rgba(11,11,11,.39) 30%,
        rgba(11,11,11,.37) 32%,
        rgba(11,11,11,.35) 34%,
        rgba(11,11,11,.33) 36%,
        rgba(11,11,11,.31) 38%,
        rgba(11,11,11,.29) 40%,
        rgba(11,11,11,.27) 42%,
        rgba(11,11,11,.25) 44%,
        rgba(11,11,11,.23) 46%,
        rgba(11,11,11,.21) 48%,
        rgba(11,11,11,.19) 50%,
        rgba(11,11,11,.18) 52%,
        rgba(11,11,11,.16) 54%,
        rgba(11,11,11,.14) 56%,
        rgba(11,11,11,.13) 58%,
        rgba(11,11,11,.11) 60%,
        rgba(11,11,11,.10) 62%,
        rgba(11,11,11,.08) 64%,
        rgba(11,11,11,.07) 66%,
        rgba(11,11,11,.06) 68%,
        rgba(11,11,11,.05) 70%,
        rgba(11,11,11,.04) 72%,
        rgba(11,11,11,.04) 74%,
        rgba(11,11,11,.03) 76%,
        rgba(11,11,11,.02) 78%,
        rgba(11,11,11,.02) 80%,
        rgba(11,11,11,.01) 82%,
        rgba(11,11,11,.01) 85%,
        rgba(11,11,11,.00) 90%,
        transparent 100%
    );
}

/* Film strip metadata */
.project-film-strip{
    position:absolute;top:16px;left:16px;z-index:2;
    display:flex;gap:16px;
    font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;
    color:var(--text);opacity:0;transform:translateY(-8px);
    transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.project:hover .project-film-strip{opacity:.5;transform:translateY(0)}

/* Project meta */
.project-meta{
    display:flex;align-items:center;gap:12px;
    padding:20px 4px 8px;position:relative;z-index:2;
}
.project-category{
    font-size:.6rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;
    color:var(--accent);
}
.project-name{
    font-family:var(--font-display);font-size:clamp(1rem,1.8vw,1.4rem);font-weight:600;
    flex:1;text-transform:uppercase;letter-spacing:-.01em;
}
.project-arrow{
    font-size:1.2rem;color:var(--text-dim);
    transition:transform .4s var(--ease),color .3s;
}
.project:hover .project-arrow{transform:translate(3px,-3px);color:var(--accent)}

/* ============================================
   ABOUT — minimal industrial
   ============================================ */
.about{
    padding:80px 40px 160px;position:relative;overflow:hidden;
}
.about::before{
    content:'';position:absolute;left:0;right:0;top:0;height:1px;
    background:linear-gradient(to right,transparent,var(--text-dim),transparent);opacity:.1;
}
.about-inner{max-width:1200px;margin:0 auto}
.about-headline{
    font-family:var(--font-display);font-size:clamp(1rem,1.8vw,1.4rem);font-weight:700;
    line-height:1.3;letter-spacing:-.02em;margin-top:48px;
    max-width:800px;text-transform:uppercase;
}
.about-footer{
    display:flex;align-items:center;gap:16px;margin-top:48px;
    padding-top:32px;border-top:1px solid rgba(255,255,255,.06);
}
.about-detail{
    font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);
}
.about-sep{
    color:var(--text-dim);opacity:.3;font-size:.7rem;
}
.about-email{
    color:var(--text-dim);text-decoration:none;transition:color .3s var(--ease);
}
.about-email:hover{color:var(--white);}

/* ============================================
   CONTACT
   ============================================ */
.contact{
    padding:60px 40px;text-align:center;position:relative;
}
.contact::before{
    content:'';position:absolute;left:0;right:0;top:0;height:1px;
    background:linear-gradient(to right,transparent,var(--text-dim),transparent);opacity:.1;
}
.contact-inner{max-width:800px;margin:0 auto}
.contact .section-eyebrow{justify-content:center}

.contact-headline{
    font-family:var(--font-display);font-size:clamp(1.2rem, 3vw, 2.5rem);font-weight:700;
    line-height:1.1;margin:24px 0 28px;letter-spacing:-.03em;text-transform:uppercase;
}
.contact-cta{
    display:inline-flex;align-items:center;gap:12px;
    font-size:clamp(.75rem,1.1vw,0.95rem);font-weight:300;
    color:var(--text-dim);letter-spacing:.05em;
    padding:12px 22px;border:1px solid rgba(255,255,255,.12);
    border-radius:4px;
    transition:all .5s var(--ease);
    margin-bottom:48px;
}
.about-inner .contact-cta{
    display:flex;margin:48px auto 0;width:fit-content;
}
.contact-cta:hover{
    color:var(--white);border-color:rgba(255,255,255,.4);
    background:rgba(255,255,255,.04);transform:translateY(-3px);
    box-shadow:0 12px 40px rgba(0,0,0,.2);
}
.contact-cta-arrow{
    font-size:1.3rem;transition:transform .3s var(--ease);
}
.contact-cta:hover .contact-cta-arrow{transform:translate(3px,-3px)}

.contact-links{display:flex;justify-content:center;gap:32px}
.contact-link{
    font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--text-dim);position:relative;transition:color .3s;
}
.contact-link::after{
    content:'';position:absolute;bottom:-3px;left:0;width:0;height:1px;
    background:var(--accent);transition:width .5s var(--ease);
}
.contact-link:hover{color:var(--text)}
.contact-link:hover::after{width:100%}

/* ============================================
   FOOTER
   ============================================ */
.footer{
    padding:28px 40px;border-top:1px solid rgba(255,255,255,.04);
}
.footer-inner{
    max-width:1400px;margin:0 auto;
    display:flex;align-items:center;justify-content:space-between;
}
.footer-logo{
    font-family:var(--font-display);font-size:.9rem;color:var(--text-dim);font-weight:700;
    display:flex;align-items:center;gap:4px;text-transform:uppercase;letter-spacing:.05em;
}

.footer-copy{font-size:.65rem;color:var(--text-dim);letter-spacing:.1em}
.footer-top{
    font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--text-dim);transition:color .3s;
}
.footer-top:hover{color:var(--accent)}

/* ============================================
   REVEAL ANIMATIONS (Blur/Focus effect)
   ============================================ */
.reveal{
    opacity:0;transform:translateY(32px);filter:blur(8px);
    transition:opacity 1.2s var(--ease),transform 1.2s var(--ease),filter 1.2s var(--ease);
}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}

/* Stagger in rows */
.projects-row .reveal:nth-child(2){transition-delay:.12s}
.projects-row--three .reveal:nth-child(2){transition-delay:.1s}
.projects-row--three .reveal:nth-child(3){transition-delay:.2s}

/* ============================================
   RESPONSIVE: TABLET
   ============================================ */
@media(max-width:1024px){
    :root{--letterbox:16px}
    .header{padding:16px 28px}
    .nav{display:none}
    .menu-btn{display:flex}
    .header-center{display:none}
    .hero{padding-left:28px;padding-right:28px}
    .hero-bottom{left:28px;right:28px}
    .work{padding:120px 28px 60px}
    .about{padding:60px 28px 120px}
    .about-footer{flex-wrap:wrap}
    .contact{padding:120px 28px}
    .footer{padding:20px 28px}
    .projects-row--three{grid-template-columns:1fr 1fr}
}

/* ============================================
   RESPONSIVE: MOBILE
   ============================================ */
@media(max-width:640px){
    :root{--letterbox:10px}
    .header{padding:12px 20px}
    .hero{padding-left:20px;padding-right:20px}
    .hero-name-line span{font-size:clamp(2rem,10vw,3.5rem)}
    .hero-bottom{left:20px;right:20px;flex-direction:column;align-items:flex-start;gap:12px}
    .hero-meta{display:none}
    .work{padding:80px 20px 40px}
    .work-header{margin-bottom:48px}
    .projects{gap:16px}
    .projects-row{grid-template-columns:1fr;gap:16px}
    .projects-row--three{grid-template-columns:1fr}
    .project--full .project-visual{aspect-ratio:21/9}
    .project--half .project-visual{aspect-ratio:21/9}
    .project--third .project-visual{aspect-ratio:21/9}
    .project-film-strip{display:none}
    .about{padding:40px 20px 80px}
    .about-footer{flex-wrap:wrap;gap:12px}
    .contact{padding:80px 20px}
    .contact-cta{padding:16px 24px}
    .contact-links{gap:20px}
    .footer{padding:16px 20px}
    .footer-inner{flex-direction:column;gap:10px;text-align:center}
}

@view-transition { navigation: auto; }
::view-transition-old(root) { animation: 180ms ease-out both vt-out; }
::view-transition-new(root) { animation: 280ms ease-in  both vt-in;  }
@keyframes vt-out { to   { opacity: 0; } }
@keyframes vt-in  { from { opacity: 0; } }
