/* ============================================
   FOURTH STUDIO — STYLESHEET v3 (PREMIUM)
   ============================================ */
@import 'variables.css';

/* Always light — prevent OS dark mode */
:root{color-scheme:light only}
html{color-scheme:light only}
/* Samsung Browser + all others: prevent dark mode rewriting */
:root{
  forced-color-adjust:none;
  -webkit-forced-color-adjust:none;
}
@media(prefers-color-scheme:dark){
  html{
    color-scheme:light only;
    filter:none!important;
    -webkit-filter:none!important;
    forced-color-adjust:none;
    -webkit-forced-color-adjust:none;
  }
  body{
    background:#070707!important;
    color:#ede8e4!important;
    filter:none!important;
    -webkit-filter:none!important;
  }
  *{
    filter:none!important;
    -webkit-filter:none!important;
    forced-color-adjust:none;
    -webkit-forced-color-adjust:none;
  }
  .nav-logo img,.footer-logo img{
    filter:brightness(0) invert(1)!important;
    -webkit-filter:brightness(0) invert(1)!important;
  }
  .ht-red,.st-red,.red,.proj-cat,.meta-label,.srv-num,.booking-title em,.mono-label.red{color:#be1318!important}
  .hero-bg{background:radial-gradient(ellipse 70% 85% at 85% 50%,#8b0000 0%,#3a0000 28%,#0a0000 58%,#070707 100%)!important}
  .event-banner{background:#be1318!important}
  .b-submit,.hero-cta{background:#be1318!important}
  .nav-logo-text{color:#ede8e4!important}
}


/* ---- RESET & BASE ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--black);color:var(--white);
  font-family:var(--font-body);font-weight:300;
  font-size:16px;line-height:1.5;overflow-x:hidden;cursor:auto;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block;width:100%;height:100%;object-fit:cover}
ul{list-style:none}
button,select,input,textarea{cursor:auto;font-family:var(--font-body)}
em{font-style:normal}

/* GRAIN */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.26;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.07'/%3E%3C/svg%3E");
}

/* default OS cursor */
.cursor-ring{
  position:fixed;
  width:36px;height:36px;
  border:1.5px solid rgba(255,255,255,.55);
  border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .45s cubic-bezier(.16,1,.3,1),height .45s cubic-bezier(.16,1,.3,1),border-color .3s,opacity .3s,border-radius .3s;
  mix-blend-mode:difference;
}



/* MONO LABEL */
.mono-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--white-dim)}
.mono-label.red{color:var(--red)}

/* ============================================
   NAV
   ============================================ */
.nav{
  position:fixed;top:0;left:0;right:0;height:72px;z-index:500;
  background:transparent;border-bottom:1px solid transparent;
  padding:0 clamp(32px,4vw,80px);
  transition:background .6s ease,border-color .6s ease,backdrop-filter .6s ease;
}
.nav.solid{
  background:rgba(7,7,7,.95);
  border-bottom:1px solid rgba(240,236,232,.07);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
}
.nav.solid::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(190,19,24,.35) 30%,rgba(190,19,24,.35) 70%,transparent);
}
.nav-inner{height:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;width:100%}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:20px;filter:brightness(0) invert(1);display:block;transition:opacity .25s}
.nav-logo:hover img{opacity:.7}
.nav-logo-text,.footer-logo-text{font-family:var(--font-display);font-size:.9rem;letter-spacing:.08em;color:var(--white);display:none}
.nav-logo-img,.nav-logo picture,.nav-logo picture img{display:block;height:20px;filter:brightness(0) invert(1)}
.nav-links{display:flex;gap:clamp(28px,3.5vw,56px);align-items:center;justify-content:center;list-style:none}
.nav-links li{position:relative}
.nav-links li a{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(240,236,232,.4);transition:color .25s;display:block;padding-bottom:2px;
}
.nav-links li a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;
  background:var(--red);transition:width .3s var(--ease);
}
.nav-links li a:hover{color:var(--white)}
.nav-links li a:hover::after{width:100%}
.nav-cta-btn{
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--red);border:1px solid var(--red);padding:10px 24px;
  position:relative;overflow:hidden;transition:color .3s;white-space:nowrap;
}
.nav-cta-btn::before{
  content:'';position:absolute;inset:0;background:var(--red);
  transform:translateX(-100%);transition:transform .35s var(--ease);z-index:0;
}
.nav-cta-btn:hover{color:var(--white)}
.nav-cta-btn:hover::before{transform:translateX(0)}
/* wrap text so it sits above the fill */
.nav-cta-btn{display:inline-block}
.hamburger{
  display:none;flex-direction:column;gap:6px;
  background:none;border:none;padding:4px;z-index:600;position:relative;margin-left:auto;
}
.hamburger span{display:block;width:24px;height:1px;background:var(--white);transition:all .35s var(--ease)}

/* ============================================
   HERO
   ============================================ */
.hero{position:relative;width:100vw;height:100vh;min-height:700px;overflow:hidden;display:flex;flex-direction:column}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:2;pointer-events:none}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 70% 85% at 85% 50%,#8b0000 0%,#3a0000 28%,#0a0000 58%,#070707 100%),
    radial-gradient(ellipse 40% 60% at 12% 80%,rgba(70,0,0,.25) 0%,transparent 60%);
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,.18) 0px,rgba(0,0,0,.18) 1px,transparent 1px,transparent 4px);
  pointer-events:none;
}
.hero-media{position:absolute;inset:0;z-index:1}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to top,rgba(7,7,7,1) 0%,rgba(7,7,7,.55) 35%,rgba(7,7,7,.05) 65%,rgba(7,7,7,.2) 100%),
    radial-gradient(ellipse at 50% 110%,rgba(7,7,7,.8) 0%,transparent 60%);
}
.hero-title-wrap{position:absolute;bottom:clamp(160px,22vh,220px);left:var(--pad);z-index:4}
.hero-title{
  font-family:var(--font-display);font-size:clamp(72px,10.5vw,168px);
  line-height:.88;letter-spacing:-.01em;display:flex;flex-direction:column;
}
.ht-l1{color:var(--white);display:block;animation:heroWord .9s var(--ease) .1s both}
.ht-l2{display:block;animation:heroWord .9s var(--ease) .28s both}
.ht-l3{display:block;animation:heroWord .9s var(--ease) .44s both}
.ht-red{color:var(--red)}
@keyframes heroWord{
  from{opacity:0;transform:translateY(44px) skewY(1.5deg)}
  to{opacity:1;transform:translateY(0) skewY(0)}
}
.hero-sub-wrap{
  position:absolute;bottom:clamp(60px,9vh,90px);left:var(--pad);z-index:4;
  animation:heroWord .9s var(--ease) .6s both;
}
.hero-sub{
  font-size:clamp(1rem,1.3vw,1.25rem);font-weight:300;
  color:rgba(240,236,232,.55);line-height:1.75;letter-spacing:.03em;max-width:420px;
}
.hero-cta{
  position:absolute;bottom:clamp(60px,9vh,88px);right:var(--pad);z-index:4;
  display:flex;align-items:center;gap:16px;
  background:var(--red);color:var(--white);padding:18px 40px;
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  overflow:hidden;white-space:nowrap;
  animation:heroWord .9s var(--ease) .7s both;
  transition:gap .35s var(--ease),box-shadow .35s,background .25s;
}
.hero-cta::before{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transition:left .55s ease;
}
.hero-cta:hover::before{left:150%}
.hero-cta:hover{gap:26px;box-shadow:0 0 40px rgba(190,19,24,.5),0 4px 20px rgba(0,0,0,.4);background:var(--red-hot)}
.cta-arrow{font-family:sans-serif;font-size:1rem;transition:transform .3s var(--ease)}
.hero-cta:hover .cta-arrow{transform:translateX(4px)}
.hero-scroll{
  position:absolute;bottom:clamp(32px,5vh,52px);left:50%;transform:translateX(-50%);
  z-index:4;display:flex;flex-direction:column;align-items:center;gap:12px;
  opacity:0;animation:fadeIn 1s var(--ease) 1.2s forwards;
  transition:opacity .7s ease,transform .7s ease;
}
.scroll-line{
  width:1px;height:68px;
  background:linear-gradient(to bottom,rgba(240,236,232,.6),transparent);
  animation:scrollDrop 2.4s ease-in-out infinite;
}
@keyframes scrollDrop{
  0%{transform:scaleY(0);transform-origin:top;opacity:1}
  48%{transform:scaleY(1);transform-origin:top;opacity:1}
  49%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom;opacity:0}
}
.scroll-word{
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.35em;text-transform:uppercase;
  color:rgba(240,236,232,.38);animation:scrollTextPulse 2.4s ease-in-out infinite;
}
@keyframes scrollTextPulse{0%,100%{opacity:.38}50%{opacity:.65}}
.hero-dot{
  position:absolute;right:var(--pad);top:50%;width:5px;height:5px;
  background:var(--white);border-radius:50%;z-index:4;opacity:.35;
  animation:dotPulse 3s ease-in-out infinite;
}
@keyframes dotPulse{0%,100%{opacity:.35;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============================================
   MARQUEE
   ============================================ */
.marquee-bar{
  background:var(--black);
  border-top:1px solid var(--red-dim);border-bottom:1px solid var(--red-dim);
  padding:14px 0;overflow:hidden;position:relative;
}
.marquee-bar::before,.marquee-bar::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.marquee-bar::before{left:0;background:linear-gradient(to right,var(--black),transparent)}
.marquee-bar::after{right:0;background:linear-gradient(to left,var(--black),transparent)}
.marquee-inner{display:flex}
.m-set{
  display:flex;align-items:center;gap:52px;white-space:nowrap;flex-shrink:0;
  padding-right:52px;will-change:transform;animation:ticker 36s linear infinite;
}
.m-set span{
  font-family:var(--font-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(240,236,232,.45);flex-shrink:0;
}
.m-set i{font-style:normal;color:var(--red);font-size:.4rem;flex-shrink:0;line-height:1}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

/* ============================================
   PROJECTS
   ============================================ */
.projects{padding:clamp(60px,8vh,100px) 0 0}
.projects-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);max-width:var(--max);margin:0 auto;margin-bottom:32px;
}
.projects-heading{
  font-family:var(--font-display);font-size:clamp(1.1rem,1.8vw,1.6rem);
  letter-spacing:.06em;text-transform:uppercase;color:var(--white);
}
.link-arrow{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--white-dim);display:flex;align-items:center;gap:8px;
  transition:color .25s,gap .3s var(--ease);
}
.link-arrow-bold{
  font-family:var(--font-display);font-size:clamp(.85rem,1.2vw,1.1rem);
  letter-spacing:.08em;color:var(--red);
}
.link-arrow-bold:hover{color:var(--white)}
.link-arrow:hover{color:var(--white)}
.link-arrow span{transition:transform .3s var(--ease)}
.link-arrow:hover span{transform:translateX(5px)}

.proj-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:3px;
}
.proj-item{
  position:relative;overflow:hidden;background:var(--black2);
  grid-column:span 6;aspect-ratio:4/3;cursor:auto;
  display:block;text-decoration:none;color:inherit;
}
/* Large(7) + Small(5) = 12 cols, height locked by the small card's aspect ratio */
.proj-large{grid-column:span 7;aspect-ratio:unset;align-self:stretch}
.proj-small{grid-column:span 5;aspect-ratio:4/3}
.proj-wide{grid-column:span 12;aspect-ratio:21/8}

.proj-img{position:absolute;inset:0;transition:transform .85s var(--ease)}
.proj-item:hover .proj-img{transform:scale(1.06)}

.proj-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#120101,#0d0d0d);
  display:flex;align-items:center;justify-content:center;
}
.proj-ph-icon{font-size:3rem;opacity:.06;color:var(--red)}

.proj-scan{
  position:absolute;inset:0;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,.14) 0px,rgba(0,0,0,.14) 1px,transparent 1px,transparent 4px);
  pointer-events:none;z-index:1;opacity:.7;transition:opacity .4s;
}
.proj-item:hover .proj-scan{opacity:.3}

/* Red left bar */
.proj-item::before{
  content:'';position:absolute;left:0;top:0;width:3px;height:0;
  background:linear-gradient(to bottom,var(--red-hot),var(--red));
  z-index:4;transition:height .55s var(--ease);
  box-shadow:0 0 14px rgba(190,19,24,.6);
}
.proj-item:hover::before{height:100%}

/* Info overlay */
.proj-info{
  position:absolute;inset:0;z-index:3;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(16px,2.5vw,32px);
  background:linear-gradient(to top,rgba(7,7,7,.98) 0%,rgba(7,7,7,.72) 40%,rgba(7,7,7,.08) 75%,transparent 100%);
  opacity:0;transform:translateY(8px);
  transition:opacity .45s var(--ease),transform .45s var(--ease);
}
.proj-item:hover .proj-info{opacity:1;transform:translateY(0)}
.proj-name{
  font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,2.6rem);
  letter-spacing:.04em;line-height:1;
}
.proj-cat{
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);margin-bottom:10px;display:block;
}
.proj-cta{
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(240,236,232,.4);margin-top:14px;display:flex;align-items:center;gap:6px;
  transition:color .2s,gap .3s var(--ease);
}
.proj-item:hover .proj-cta{color:rgba(240,236,232,.75);gap:10px}
.proj-item::after{
  content:attr(data-cat);position:absolute;bottom:16px;left:18px;z-index:2;
  font-family:var(--font-mono);font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(240,236,232,.2);transition:opacity .3s;
}
.proj-item:hover::after{opacity:0}

/* ============================================
   STATEMENT
   ============================================ */
.statement{
  padding:clamp(80px,12vh,140px) var(--pad);
  max-width:1440px;margin:0 auto;width:100%;
  border-bottom:1px solid var(--white-rule);
}
.statement-text{
  font-family:var(--font-display);
  font-size:clamp(2.8rem,6.5vw,7.5rem);
  line-height:.92;letter-spacing:.01em;
  margin-bottom:clamp(60px,8vh,100px);
}
.st-white{color:var(--white)}
.st-red{color:var(--red)}
.st-outline{-webkit-text-stroke:1.5px rgba(240,236,232,.2);color:transparent}
.statement-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;width:100%}
.st-stat{
  padding:clamp(32px,5vh,56px) var(--pad);
  border-right:1px solid var(--white-rule);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
  transition:background .4s;
}
.st-stat::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(190,19,24,.05),transparent 60%);
  opacity:0;transition:opacity .4s;
}
.st-stat:hover::before{opacity:1}
.st-stat:last-child{border-right:none}
.st-divider{display:none}
.st-num{
  display:block;font-family:var(--font-display);
  font-size:clamp(4rem,9vw,10rem);color:var(--red);
  line-height:.9;margin-bottom:14px;letter-spacing:-.01em;
  transition:transform .4s var(--ease);
}
.st-stat:hover .st-num{transform:translateX(6px)}
.st-stat .mono-label{font-size:.65rem;letter-spacing:.25em}

/* ============================================
   SERVICES
   ============================================ */
.services-section{padding:clamp(80px,10vh,120px) var(--pad);max-width:var(--max);margin:0 auto}
.srv-header{
  display:flex;align-items:baseline;gap:32px;
  margin-bottom:clamp(40px,6vh,64px);
  border-bottom:1px solid var(--white-rule);padding-bottom:24px;
}
.srv-title{font-family:var(--font-display);font-size:clamp(3rem,6vw,6rem);letter-spacing:.04em;line-height:1}
.srv-list{border-top:1px solid var(--white-rule)}
.srv-item{
  display:grid;grid-template-columns:280px 1fr auto;
  align-items:center;gap:40px;
  padding:clamp(24px,3.5vh,36px) 0;
  border-bottom:1px solid rgba(240,236,232,.06);
  position:relative;
  transition:padding-left .35s var(--ease);
}
.srv-item::before{
  content:'';position:absolute;left:0;bottom:-1px;width:0;height:1px;
  background:linear-gradient(to right,var(--red),var(--red-hot));
  transition:width .55s var(--ease);
}
.srv-item:hover::before{width:100%}
.srv-item:hover{padding-left:12px}
.srv-left{display:flex;align-items:baseline;gap:20px}
.srv-num{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.2em;color:var(--red)}
.srv-name{
  font-family:var(--font-display);font-size:clamp(1.6rem,2.5vw,2.4rem);
  letter-spacing:.04em;transition:color .25s;text-transform:uppercase;
}
.srv-item:hover .srv-name{color:rgba(240,236,232,.9)}
.srv-desc{color:rgba(240,236,232,.45);font-size:.95rem;letter-spacing:.02em;max-width:420px;line-height:1.65}
.srv-tag{
  border:1px solid rgba(240,236,232,.1);padding:7px 16px;
  font-family:var(--font-mono);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(240,236,232,.3);white-space:nowrap;
  transition:border-color .3s,color .3s,background .3s;
}
.srv-item:hover .srv-tag{border-color:var(--red);color:var(--red);background:rgba(190,19,24,.06)}

/* ============================================
   WHY WORK WITH US
   ============================================ */
.why-section{
  border-top:1px solid var(--white-rule);border-bottom:1px solid var(--white-rule);
  padding:clamp(80px,12vh,140px) var(--pad);position:relative;overflow:hidden;
}
.why-section::before{
  content:'';position:absolute;top:0;right:-200px;width:600px;height:600px;
  background:radial-gradient(circle,rgba(190,19,24,.055) 0%,transparent 70%);pointer-events:none;
}
.why-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(48px,6vw,120px);
  align-items:start;position:relative;z-index:1;
}
.why-title{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,5.5rem);line-height:.88;letter-spacing:.01em;color:var(--white)}
.why-title-outline{-webkit-text-stroke:1.5px rgba(240,236,232,.22);color:transparent;display:block}
.why-body{
  font-size:clamp(.98rem,1.2vw,1.15rem);font-weight:300;
  color:rgba(240,236,232,.55);line-height:1.78;letter-spacing:.02em;margin-bottom:26px;
}
.why-body strong{color:var(--white);font-weight:600}
.why-body em{font-style:italic;color:rgba(240,236,232,.8)}

/* ============================================
   BOOKING
   ============================================ */
.booking-section{
  position:relative;overflow:hidden;
  padding:clamp(80px,12vh,140px) var(--pad);
  background:var(--black2);border-top:1px solid var(--white-rule);
}
.booking-section::before{
  content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);
  width:800px;height:400px;
  background:radial-gradient(ellipse at 50% 0%,rgba(190,19,24,.07) 0%,transparent 70%);
  pointer-events:none;
}
.booking-bg-text{
  position:absolute;right:-0.05em;top:50%;transform:translateY(-50%);
  font-family:var(--font-display);font-size:clamp(200px,28vw,420px);
  line-height:1;letter-spacing:.05em;color:rgba(190,19,24,.03);
  pointer-events:none;user-select:none;white-space:nowrap;
}
.booking-wrap{
  display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(40px,6vw,100px);
  max-width:var(--max);margin:0 auto;position:relative;z-index:1;
}
.booking-title{font-family:var(--font-display);font-size:clamp(4rem,7vw,8rem);letter-spacing:.02em;line-height:.88;margin:16px 0 24px}
.booking-title em{color:var(--red)}
.booking-sub{color:var(--white-dim);font-size:1rem;letter-spacing:.02em;line-height:1.7;margin-bottom:40px}
.booking-contact{display:flex;flex-direction:column;gap:0}
.b-contact-link{
  display:flex;align-items:center;gap:16px;
  padding:16px 0;border-bottom:1px solid rgba(240,236,232,.07);
  transition:border-color .25s,padding-left .3s var(--ease);
}
.b-contact-link:hover{border-color:rgba(190,19,24,.4);padding-left:10px}
.b-contact-link .mono-label{color:var(--red);font-size:.75rem;flex-shrink:0;min-width:20px;text-align:center}
.b-contact-link span:last-child{font-size:1rem;letter-spacing:.02em;color:var(--white)}
.b-form{display:flex;flex-direction:column;gap:22px}
.b-row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.b-field{display:flex;flex-direction:column;gap:8px}
.b-field .mono-label{color:var(--red)}
.b-form input,.b-form select,.b-form textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(240,236,232,.1);
  color:var(--white);padding:13px 0;
  font-family:var(--font-body);font-size:1rem;font-weight:300;letter-spacing:.02em;
  outline:none;width:100%;appearance:none;border-radius:0;transition:border-color .25s;
}
.b-form input::placeholder,.b-form textarea::placeholder{color:rgba(240,236,232,.18)}
.b-form input:focus,.b-form select:focus,.b-form textarea:focus{border-bottom-color:var(--red)}
.b-form select{color:rgba(240,236,232,.45)}
.b-form select option{background:var(--black2);color:var(--white)}
.b-form textarea{resize:vertical;min-height:110px}
.b-submit{
  background:var(--red);border:none;color:var(--white);padding:18px 40px;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:center;gap:16px;width:100%;margin-top:4px;
  position:relative;overflow:hidden;
  transition:gap .35s var(--ease),background .25s,box-shadow .35s;
}
.b-submit::before{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  transition:left .55s ease;
}
.b-submit:hover::before{left:150%}
.b-submit:hover{background:var(--red-hot);gap:24px;box-shadow:0 0 36px rgba(190,19,24,.4)}
.sub-arrow{font-family:sans-serif;font-size:1rem;transition:transform .3s var(--ease)}
.b-submit:hover .sub-arrow{transform:translateX(4px)}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--black);border-top:1px solid var(--white-rule);
  padding:clamp(32px,5vh,56px) var(--pad);position:relative;
}
.site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(190,19,24,.3) 30%,rgba(190,19,24,.3) 70%,transparent);
}
.footer-top{
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  max-width:var(--max);margin:0 auto;
  padding-bottom:clamp(20px,3vh,36px);border-bottom:1px solid var(--white-faint);
  margin-bottom:clamp(16px,2vh,28px);
}
.footer-logo img{height:24px;filter:brightness(0) invert(1);transition:opacity .25s}
.footer-logo:hover img{opacity:.65}
.footer-nav{display:flex;gap:32px}
.footer-nav a{
  font-family:var(--font-mono);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(240,236,232,.3);position:relative;transition:color .25s;
}
.footer-nav a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;
  background:var(--red);transition:width .3s var(--ease);
}
.footer-nav a:hover{color:var(--white)}
.footer-nav a:hover::after{width:100%}
.footer-social{display:flex;gap:10px}
.footer-social a{
  width:36px;height:36px;border:1px solid rgba(240,236,232,.1);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:rgba(240,236,232,.35);
  transition:border-color .25s,color .25s,transform .3s var(--ease),box-shadow .3s;
}
.footer-social a:hover{
  border-color:var(--red);color:var(--red);
  transform:translateY(-3px);box-shadow:0 4px 16px rgba(190,19,24,.25);
}
.footer-bottom{display:flex;justify-content:space-between;max-width:var(--max);margin:0 auto}
.footer-bottom span{
  font-family:var(--font-mono);font-size:.55rem;letter-spacing:.15em;
  text-transform:uppercase;color:rgba(240,236,232,.18);
}

/* ============================================
   REVEAL ANIMATIONS — staggered scroll-driven
   ============================================ */
@keyframes fadeUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity .85s cubic-bezier(.16,1,.3,1), transform .85s cubic-bezier(.16,1,.3,1);
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.22s}
.reveal-d3{transition-delay:.38s}
/* Project cards: never hidden — images must always show */
.proj-item{opacity:1!important;transform:none!important}

/* ============================================
   RESPONSIVE — TABLET  ≤ 1100px
   ============================================ */
@media(max-width:1100px){
  .srv-item{grid-template-columns:180px 1fr auto}
  .booking-wrap{grid-template-columns:1fr}
  .booking-bg-text{font-size:clamp(120px,18vw,260px)}
}

/* ============================================
   RESPONSIVE — TABLET  ≤ 900px
   ============================================ */
@media(max-width:900px){
  /* Projects */
  .proj-item{grid-column:span 12!important;aspect-ratio:16/9}
  .proj-wide{aspect-ratio:16/9}
  .proj-large,.proj-small{aspect-ratio:16/9;align-self:auto}

  /* Services */
  .srv-item{grid-template-columns:1fr;gap:16px;padding:clamp(20px,3vh,28px) 0}
  .srv-left{align-items:center;gap:16px}
  .srv-tag{align-self:flex-start}

  /* Why */
  .why-inner{grid-template-columns:1fr;gap:40px}
}

/* ============================================
   RESPONSIVE — MOBILE  ≤ 768px
   ============================================ */
@media(max-width:768px){

  /* ---- NAV ---- */
  .nav{height:60px;padding:0 20px}
  .nav-inner{grid-template-columns:1fr auto auto;gap:12px}
  .nav-links{
    display:none;
    position:fixed;inset:0;top:60px;
    background:rgba(7,7,7,.98);
    backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;align-items:center;
    gap:40px;z-index:499;
    padding-bottom:80px;
  }
  .nav-links.open{display:flex}
  .nav-links li a{
    font-family:var(--font-display);
    font-size:clamp(1.8rem,8vw,3rem);
    letter-spacing:.04em;
    color:rgba(240,236,232,.5);
    transition:color .2s;
  }
  .nav-links li a:hover{color:var(--white)}
  .nav-links li a::after{display:none}
  .nav-cta-btn{display:none}
  .hamburger{display:flex;margin-left:8px}

  /* ---- CURSOR — hide custom cursor on touch devices ---- */
  *{cursor:auto!important}
  a,button,.back-btn,.b-submit{cursor:pointer!important}
  .nav-logo-text{display:none!important}
  .nav-logo picture,.nav-logo picture img,.nav-logo-img{display:block!important;height:16px!important;filter:brightness(0) invert(1)!important}

  /* ---- NAV mobile ---- */
  .nav{height:56px;padding:0 20px}
  .nav-logo img{height:16px!important}

  /* ---- HERO mobile — stack everything from bottom ---- */
  .hero{min-height:100svh}

  /* CTA button — fixed at very bottom */
  .hero-cta{
    bottom:20px;
    right:20px;left:20px;
    width:calc(100% - 40px);
    justify-content:center;
    padding:14px 20px;
    font-size:.6rem;
    box-sizing:border-box;
    position:absolute;
  }

  /* Sub copy — sits above CTA */
  .hero-sub-wrap{
    bottom:88px;
    left:20px;right:20px;
    position:absolute;
  }
  .hero-sub{
    font-size:clamp(.8rem,3.2vw,.95rem);
    max-width:100%;
    line-height:1.55;
    display:none; /* hide sub-copy on mobile to prevent clipping */
  }

  /* Title — sits above sub-copy */
  .hero-title-wrap{
    bottom:100px;
    left:20px;right:20px;
    position:absolute;
  }
  .hero-title{
    font-size:clamp(32px,9.5vw,52px);
    line-height:.9;
  }

  .hero-scroll{bottom:auto;top:auto;display:none}
  .hero-dot{display:none}

  /* ---- MARQUEE ---- */
  .marquee-bar{padding:12px 0}
  .m-set span{font-size:.6rem;letter-spacing:.16em}
  .m-set{gap:36px}

  /* ---- PROJECTS ---- */
  .projects{padding:clamp(40px,6vh,64px) 0 0}
  .projects-header{
    padding:0 20px;
    margin-bottom:20px;
    flex-wrap:wrap;gap:10px;
  }
  .projects-heading{font-size:1rem}
  .link-arrow-bold{font-size:.9rem}
  .proj-grid{gap:2px}
  .proj-item{
    aspect-ratio:4/3!important;
  }
  .proj-name{font-size:clamp(1.2rem,5vw,1.8rem)}
  .proj-cat{font-size:.52rem}
  /* Always show info on mobile — no hover */
  .proj-info{
    opacity:1!important;
    transform:none!important;
    background:linear-gradient(to top,rgba(7,7,7,.95) 0%,rgba(7,7,7,.6) 50%,transparent 100%);
  }

  /* ---- STATEMENT ---- */
  .statement{padding:clamp(48px,7vh,80px) 20px}
  .statement-text{
    font-size:clamp(2rem,9vw,3.5rem);
    margin-bottom:clamp(36px,5vh,56px);
  }
  .statement-stats{grid-template-columns:1fr}
  .st-stat{
    border-right:none;
    border-bottom:1px solid var(--white-rule);
    padding:clamp(24px,4vh,36px) 20px;
  }
  .st-stat:last-child{border-bottom:none}
  .st-num{font-size:clamp(3rem,16vw,5.5rem)}

  /* ---- SERVICES ---- */
  .services-section{padding:clamp(48px,7vh,80px) 20px}
  .srv-header{flex-direction:column;gap:12px;padding-bottom:20px}
  .srv-title{font-size:clamp(2rem,10vw,3.5rem)}
  .srv-item{
    grid-template-columns:1fr;
    gap:10px;
    padding:20px 0;
  }
  .srv-left{flex-direction:row;align-items:center;gap:14px}
  .srv-name{font-size:clamp(1.4rem,6vw,2rem)}
  .srv-desc{font-size:.9rem;max-width:100%}
  .srv-tag{font-size:.5rem;padding:5px 12px}

  /* ---- WHY WORK WITH US ---- */
  .why-section{padding:clamp(48px,7vh,80px) 20px}
  .why-inner{gap:32px}
  .why-title{font-size:clamp(1.8rem,8vw,3.2rem)}
  .why-body{font-size:.95rem}

  /* ---- BOOKING ---- */
  .booking-section{padding:clamp(48px,7vh,80px) 20px}
  .booking-bg-text{font-size:clamp(80px,28vw,160px);right:0}
  .booking-wrap{grid-template-columns:1fr;gap:40px}
  .booking-title{font-size:clamp(3rem,14vw,5rem)}
  .booking-sub{font-size:.9rem}
  .b-row{grid-template-columns:1fr;gap:0}
  .b-form{gap:16px}
  .b-contact-link span:last-child{font-size:.9rem}
  .b-submit{padding:16px 24px;font-size:.65rem}

  /* ---- FOOTER ---- */
  .site-footer{padding:clamp(28px,5vh,44px) 20px}
  .footer-top{
    flex-direction:column;
    align-items:flex-start;
    gap:24px;
    padding-bottom:24px;
  }
  .footer-nav{
    flex-wrap:wrap;gap:12px 24px;
  }
  .footer-nav a{font-size:.55rem}
  .footer-bottom span{font-size:.5rem}
}

/* ============================================
   RESPONSIVE — SMALL MOBILE  ≤ 420px
   ============================================ */
@media(max-width:420px){
  .hero-title{font-size:clamp(40px,12vw,64px)}
  .statement-text{font-size:clamp(1.6rem,8.5vw,2.8rem)}
  .booking-title{font-size:clamp(2.5rem,13vw,4rem)}
  .why-title{font-size:clamp(1.6rem,8vw,2.8rem)}
}
