/* ============================================================
   ZADID PATHAN — cinematic-futuristic portfolio
   Shared stylesheet
   ============================================================ */
:root{
  --bg:#070708; --bg-soft:#0d0d11;
  --line:rgba(255,255,255,.09);
  --text:#EDEAE4; --muted:#A6A6B4;
  --accent:#7A6CFF;     /* violet */
  --accent2:#3BE6FF;    /* cyan   */
  --accent3:#FF5CA8;    /* pink   */
  --glow:0 0 26px rgba(122,108,255,.45);
  --maxw:1360px;
  --ease:cubic-bezier(.6,0,.15,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;
  overflow-x:hidden;width:100%;
  background:
    radial-gradient(58% 66% at 16% 8%, rgba(140,120,255,.50), transparent 60%),
    radial-gradient(54% 62% at 88% 22%, rgba(59,230,255,.40), transparent 60%),
    radial-gradient(64% 68% at 76% 104%, rgba(255,92,168,.42), transparent 60%),
    radial-gradient(78% 78% at 48% 54%, rgba(120,104,235,.38), transparent 72%),
    linear-gradient(180deg,#26204e 0%,#1b1640 46%,#15112f 100%);
  background-attachment:fixed;
  background-color:#1a1540; /* solid base: guarantees a rich indigo field everywhere */
}
body{
  background:transparent; color:var(--text);
  font-family:'Inter',system-ui,sans-serif; font-weight:300;
  line-height:1.55; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:.04em}
.acc{color:var(--accent2)}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.display{font-family:'Anton',Impact,sans-serif;font-weight:400;text-transform:uppercase;line-height:.86;letter-spacing:.01em}
/* readability over the animated gradient */
.statement p,.sec-head h2,.cta h2,.feat h3,.about-hero h1,.tiles h3,.svc .card h3,.statement .small,.feat .info p,.sec-head .idx,.eyebrow{text-shadow:0 2px 26px rgba(8,6,20,.55)}
.statement .small,.feat .info p{text-shadow:0 1px 18px rgba(8,6,20,.7)}

/* ============================================================
   LIVING BACKGROUND  (aurora + grid + grain)
   ============================================================ */
.bgfx{position:fixed;inset:0;z-index:-1;overflow:hidden;
  background:
    radial-gradient(58% 66% at 16% 8%, rgba(140,120,255,.46), transparent 60%),
    radial-gradient(54% 62% at 88% 22%, rgba(59,230,255,.36), transparent 60%),
    radial-gradient(64% 68% at 76% 104%, rgba(255,92,168,.38), transparent 60%),
    radial-gradient(78% 78% at 48% 54%, rgba(120,104,235,.30), transparent 72%),
    linear-gradient(180deg,#1d1842 0%,#15112f 48%,#100d24 100%);
  background-size:165% 165%;
  animation:auroraMove 30s ease-in-out infinite}
@keyframes auroraMove{
  0%{background-position:0% 28%}
  33%{background-position:100% 66%}
  66%{background-position:52% 100%}
  100%{background-position:0% 28%}
}
.bgfx .blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.85;mix-blend-mode:screen;will-change:transform}
.bgfx .b1{width:52vw;height:52vw;left:-8vw;top:-10vw;background:radial-gradient(circle,var(--accent) 0%,transparent 62%);animation:drift1 24s var(--ease) infinite alternate}
.bgfx .b2{width:50vw;height:50vw;left:26vw;top:24vh;background:radial-gradient(circle,var(--accent2) 0%,transparent 60%);opacity:.55;animation:drift2 30s var(--ease) infinite alternate}
.bgfx .b3{width:48vw;height:48vw;right:-10vw;bottom:-14vw;background:radial-gradient(circle,var(--accent3) 0%,transparent 60%);opacity:.6;animation:drift3 28s var(--ease) infinite alternate}
@keyframes drift1{to{transform:translate(20vw,16vh) scale(1.25)}}
@keyframes drift2{to{transform:translate(-22vw,-12vh) scale(1.2)}}
@keyframes drift3{to{transform:translate(-14vw,-18vh) scale(1.3)}}
/* faint moving grid (site-wide) */
.bgfx::before{content:"";position:absolute;inset:-2px;background-image:
  linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:84px 84px;opacity:.5;
  animation:gridmove 40s linear infinite}
/* edge vignette for depth (subtle) */
.bgfx::after{content:"";position:absolute;inset:0;background:radial-gradient(125% 110% at 50% 40%,transparent 62%,rgba(0,0,0,.32) 100%)}
@keyframes gridmove{to{background-position:84px 84px}}
/* grain on top of everything */
.grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.05;mix-blend-mode:screen;
  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)' opacity='0.6'/></svg>")}

/* ============================================================
   NAV / HUD
   ============================================================ */
.hud-read{position:fixed;z-index:8000;font-size:10px;letter-spacing:.08em;color:#fff;opacity:.55;mix-blend-mode:difference;pointer-events:none;text-transform:uppercase}
.hud-read.bl{left:clamp(20px,4vw,48px);bottom:22px}
.hud-read.br{right:clamp(20px,4vw,48px);bottom:22px}
nav{position:fixed;top:0;left:0;right:0;z-index:9000;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,4vw,48px);transition:background .4s,backdrop-filter .4s,padding .4s}
nav.solid{background:rgba(7,7,8,.6);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding-top:12px;padding-bottom:12px}
nav .logo{font-family:'Anton';font-size:19px;letter-spacing:.06em;text-transform:uppercase;z-index:10}
nav .links{display:flex;gap:30px;font-size:12px;text-transform:uppercase}
nav .links a{position:relative;opacity:.8;transition:opacity .3s}
nav .links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--accent2);transition:width .35s var(--ease)}
nav .links a:hover,nav .links a.active{opacity:1}
nav .links a:hover::after,nav .links a.active::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:40px;padding:11px 22px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;transition:.3s var(--ease);font-family:'JetBrains Mono',monospace}
.btn:hover{border-color:var(--accent);box-shadow:var(--glow);color:#fff;transform:translateY(-1px)}
.btn.solid{background:var(--accent);border-color:var(--accent);color:#0a0a0c}
.btn.solid:hover{background:var(--accent2);border-color:var(--accent2);box-shadow:0 0 30px rgba(59,230,255,.5)}
.burger{display:none;flex-direction:column;gap:5px;z-index:10;cursor:pointer;background:none;border:0}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}
.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-open .burger span:nth-child(2){opacity:0}
.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:820px){
  nav .links,nav>.btn{display:none}
  .burger{display:flex}
}
/* mobile overlay */
.overlay{position:fixed;inset:0;z-index:8900;background:rgba(6,6,8,.96);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:0 8vw;
  transform:translateY(-100%);transition:transform .6s var(--ease);visibility:hidden}
.menu-open .overlay{transform:none;visibility:visible}
.overlay a{font-family:'Anton';font-size:clamp(38px,12vw,72px);text-transform:uppercase;line-height:1.05;opacity:.9}
.overlay a span{color:var(--accent2);font-family:'JetBrains Mono';font-size:13px;margin-right:14px;vertical-align:middle}
.overlay .meta{font-family:'JetBrains Mono';font-size:11px;color:var(--muted);margin-top:40px;text-transform:uppercase}

/* ============================================================
   LOADER
   ============================================================ */
#loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .8s,visibility .8s}
#loader.done{opacity:0;visibility:hidden}
#loader .lname{font-family:'Anton';font-size:clamp(46px,10vw,120px);text-transform:uppercase}
#loader .bar{width:min(60vw,240px);height:2px;background:var(--line);overflow:hidden;position:relative}
#loader .bar i{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));box-shadow:var(--glow);animation:load 1.7s var(--ease) forwards}
#loader .pct{font-size:11px;color:var(--muted);text-transform:uppercase}
@keyframes load{to{width:100%}}

/* page transition curtain (CSS auto-lifts on load; JS only handles leaving) */
#curtain{position:fixed;inset:0;z-index:9500;background:#0a0817;transform:scaleY(0);transform-origin:bottom;pointer-events:none}
#curtain.in{transform-origin:top;animation:curtainUp .6s var(--ease) forwards}
#curtain.leave{transform-origin:bottom;transform:scaleY(1);transition:transform .45s var(--ease)}
@keyframes curtainUp{from{transform:scaleY(1)}to{transform:scaleY(0)}}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero .bg{position:absolute;inset:-7% 0;background-position:center;background-size:cover;transform:scale(1.07);will-change:transform}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,7,8,.5),rgba(7,7,8,.05) 34%,rgba(7,7,8,.9))}
.hero .inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,48px) clamp(40px,8vh,90px)}
.hero .tag{font-size:clamp(10px,1.4vw,13px);text-transform:uppercase;color:var(--accent2);margin-bottom:14px}
.hero h1{font-size:clamp(54px,13vw,210px)}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln i{display:block;font-style:normal;transform:translateY(110%)}
.hero .meta{display:flex;flex-wrap:wrap;gap:clamp(14px,3vw,30px);margin-top:22px;font-size:11px;text-transform:uppercase;color:var(--muted)}
.scrollcue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:10px;text-transform:uppercase;color:#fff;opacity:.7}
.scrollcue .l{width:1px;height:34px;background:linear-gradient(var(--accent2),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ============================================================
   SECTION SHELL
   ============================================================ */
section{position:relative}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:clamp(60px,9vh,110px) 0 28px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.sec-head h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(26px,4.4vw,58px);line-height:.9}
.sec-head .idx{font-size:11px;color:var(--muted);text-transform:uppercase}
.eyebrow{font-size:11px;text-transform:uppercase;color:var(--accent2);letter-spacing:.12em}

/* marquee statement */
.marquee{padding:clamp(50px,8vh,90px) 0;overflow:hidden;white-space:nowrap;border-bottom:1px solid var(--line)}
.marquee .run{display:inline-block;animation:run 28s linear infinite}
.marquee span{font-family:'Anton';text-transform:uppercase;font-size:clamp(34px,7vw,104px);opacity:.16;padding:0 .35em}
.marquee span.hi{opacity:1;-webkit-text-stroke:1px var(--accent2);color:transparent}
@keyframes run{to{transform:translateX(-50%)}}

/* statement block */
.statement{padding:clamp(60px,14vh,160px) 0;border-bottom:1px solid var(--line)}
.statement p{font-family:'Anton';text-transform:uppercase;font-size:clamp(26px,5vw,72px);line-height:1.04;max-width:20ch}
.statement .w{display:inline-block;opacity:.13;transition:opacity .5s var(--ease)}
.statement .w.on{opacity:1}
.statement .small{font-family:'Inter';text-transform:none;font-size:clamp(13px,1.5vw,15px);color:var(--muted);max-width:50ch;line-height:1.8;margin-top:34px}

/* ============================================================
   FEATURED ROWS  (cinematic alternating)
   ============================================================ */
.feat .row{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;min-height:clamp(420px,78vh,820px);border-bottom:1px solid var(--line)}
.feat .media{position:relative;overflow:hidden;min-height:300px}
.feat .media img{position:absolute;inset:-8% 0;width:100%;height:116%;object-fit:cover;will-change:transform;transition:transform 1.2s var(--ease)}
.feat .media .mask{position:absolute;inset:0;background:var(--bg);transform-origin:bottom;transition:transform 1.1s var(--ease)}
.feat .row.in .media .mask{transform:scaleY(0)}
.feat .media:hover img{transform:scale(1.05) translateY(-2%)}
.feat .media .tagline{position:absolute;left:18px;bottom:16px;z-index:2;font-size:10px;text-transform:uppercase;color:#fff;opacity:.85;mix-blend-mode:difference}
.feat .info{display:flex;flex-direction:column;justify-content:center;padding:clamp(28px,5vw,72px)}
.feat .row:nth-child(even){direction:rtl}
.feat .row:nth-child(even) .info{direction:ltr}
.feat .num{font-size:12px;color:var(--accent2);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}
.feat h3{font-family:'Anton';text-transform:uppercase;font-size:clamp(32px,5.2vw,80px);line-height:.9;opacity:0;transform:translateY(26px);transition:.8s .12s var(--ease)}
.feat .info p{color:var(--muted);font-size:clamp(13px,1.4vw,15px);line-height:1.75;max-width:36ch;margin:18px 0 28px;opacity:0;transform:translateY(20px);transition:.8s .26s var(--ease)}
.feat .info .btn{align-self:flex-start;opacity:0;transform:translateY(16px);transition:.8s .4s var(--ease)}
.feat .row.in h3,.feat .row.in .info p,.feat .row.in .info .btn{opacity:1;transform:none}
@media(max-width:820px){
  .feat .row{grid-template-columns:1fr}
  .feat .row:nth-child(even){direction:ltr}
  .feat .media{height:58vh}
  .feat .info{padding:32px 24px 56px}
}

/* ============================================================
   HORIZONTAL SCROLL GALLERY
   ============================================================ */
.hscroll{padding:clamp(40px,7vh,90px) 0}
.hscroll .rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:8px clamp(20px,4vw,48px) 26px;scrollbar-width:none}
.hscroll .rail::-webkit-scrollbar{display:none}
.hscroll .card{position:relative;flex:0 0 auto;width:clamp(260px,42vw,520px);aspect-ratio:4/5;border-radius:3px;overflow:hidden;scroll-snap-align:start}
.hscroll .card img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);filter:saturate(.95)}
.hscroll .card:hover img{transform:scale(1.06)}
.hscroll .card .cap{position:absolute;left:16px;bottom:14px;z-index:2;font-size:11px;text-transform:uppercase;color:#fff;text-shadow:0 2px 12px #000}
.hscroll .card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.55))}
.hscroll .hint{font-size:11px;color:var(--muted);text-transform:uppercase;padding:0 clamp(20px,4vw,48px);margin-top:8px}
/* carousel arrows */
.rail-wrap{position:relative}
.rail-arrow{position:absolute;top:calc(50% - 13px);transform:translateY(-50%);z-index:6;
  width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(12,9,26,.6);backdrop-filter:blur(10px);border:1px solid var(--line);color:#fff;
  font-family:'JetBrains Mono',monospace;font-size:22px;line-height:1;cursor:pointer;transition:.3s var(--ease)}
.rail-arrow:hover{border-color:var(--accent);box-shadow:var(--glow);background:rgba(12,9,26,.9);transform:translateY(-50%) scale(1.06)}
.rail-arrow:active{transform:translateY(-50%) scale(.96)}
.rail-arrow.prev{left:clamp(8px,2vw,26px)}
.rail-arrow.next{right:clamp(8px,2vw,26px)}
.rail-arrow[disabled]{opacity:.25;pointer-events:none}
@media(max-width:560px){.rail-arrow{width:42px;height:42px;font-size:18px}}

/* ============================================================
   MASONRY GALLERY (gallery pages)
   ============================================================ */
.masonry{columns:3 300px;column-gap:16px;padding:clamp(30px,5vh,60px) 0}
.masonry .cell{break-inside:avoid;margin:0 0 16px;position:relative;overflow:hidden;border-radius:3px;cursor:pointer;background:var(--bg-soft)}
.masonry .cell img{width:100%;height:auto;transition:transform .9s var(--ease),filter .6s;filter:saturate(.9) brightness(.92)}
.masonry .cell:hover img{transform:scale(1.05);filter:saturate(1) brightness(1)}
.masonry .cell::after{content:"↗";position:absolute;top:12px;right:14px;font-size:14px;color:#fff;opacity:0;transition:.4s;mix-blend-mode:difference}
.masonry .cell:hover::after{opacity:.9}
.masonry .cell.tall{} /* natural */
@media(max-width:560px){.masonry{columns:2 150px;column-gap:10px}.masonry .cell{margin-bottom:10px}}

/* full-bleed feature break inside gallery */
.bleed{position:relative;height:clamp(60vh,80vh,90vh);overflow:hidden;margin:clamp(20px,5vh,50px) 0;border-radius:3px}
.bleed img{width:100%;height:100%;object-fit:cover;will-change:transform}
.bleed .ov{position:absolute;inset:0;display:flex;align-items:flex-end;padding:clamp(24px,5vw,60px);background:linear-gradient(transparent 50%,rgba(0,0,0,.6))}
.bleed .ov h3{font-family:'Anton';text-transform:uppercase;font-size:clamp(30px,6vw,90px);line-height:.9}

/* ============================================================
   WORK INDEX TILES
   ============================================================ */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr));gap:14px;padding:clamp(30px,5vh,60px) 0}
.tile{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:3px;display:flex;align-items:flex-end}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s;filter:saturate(.85) brightness(.7)}
.tile:hover img{transform:scale(1.07);filter:saturate(1) brightness(.9)}
.tile .t{position:relative;z-index:2;padding:clamp(20px,3vw,40px)}
.tile .t .n{font-size:11px;color:var(--accent2);text-transform:uppercase;letter-spacing:.12em}
.tile .t h3{font-family:'Anton';text-transform:uppercase;font-size:clamp(26px,3.6vw,52px);line-height:.92;margin-top:8px}
.tile .t .c{font-size:12px;color:var(--muted);text-transform:uppercase;margin-top:6px}
.tile::after{content:"";position:absolute;inset:0;border:1px solid transparent;transition:.4s}
.tile:hover::after{border-color:var(--accent);box-shadow:inset var(--glow)}

/* ============================================================
   STATS
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .cell{padding:clamp(40px,7vh,72px) 16px;border-left:1px solid var(--line);text-align:center}
.stats .cell:first-child{border-left:none}
.stats .n{font-family:'Anton';font-size:clamp(38px,6vw,86px);line-height:1;background:linear-gradient(120deg,#fff,var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.stats .l{font-size:11px;text-transform:uppercase;color:var(--muted);margin-top:12px}
@media(max-width:640px){.stats{grid-template-columns:1fr 1fr}.stats .cell:nth-child(3){border-left:none}}

/* marquee image strip */
.strip{padding:clamp(50px,10vh,120px) 0;overflow:hidden}
.strip .label{text-align:center;font-size:11px;text-transform:uppercase;color:var(--muted);margin-bottom:40px}
.strip .track{display:flex;gap:20px;width:max-content;animation:run 40s linear infinite}
.strip:hover .track{animation-play-state:paused}
.strip img{height:clamp(220px,34vh,360px);width:auto;border-radius:3px;object-fit:cover;filter:saturate(.92)}

/* ============================================================
   CTA + FOOTER
   ============================================================ */
.cta{text-align:center;padding:clamp(110px,22vh,260px) 0 clamp(80px,16vh,200px)}
.cta h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(42px,9vw,156px);line-height:.88}
.cta h2 .g{background:linear-gradient(120deg,var(--accent2),var(--accent3));-webkit-background-clip:text;background-clip:text;color:transparent;display:block}
.cta .btn{margin-top:42px}
.cta .em{font-size:13px;color:var(--muted);margin-top:24px}
footer{border-top:1px solid var(--line);padding:26px clamp(20px,4vw,48px);display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:11px;text-transform:uppercase;color:var(--muted)}
footer .socials{display:flex;gap:22px}
footer a:hover{color:var(--accent2)}

/* about */
.about-hero{padding:clamp(120px,20vh,220px) 0 clamp(40px,8vh,80px)}
.about-hero h1{font-family:'Anton';text-transform:uppercase;font-size:clamp(44px,9vw,140px);line-height:.86}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,64px);align-items:center;padding:clamp(30px,6vh,70px) 0;border-top:1px solid var(--line)}
.about-grid .portrait{aspect-ratio:4/5;overflow:hidden;border-radius:3px}
.about-grid .portrait img{width:100%;height:100%;object-fit:cover}
.about-grid p{color:var(--muted);font-size:clamp(14px,1.6vw,17px);line-height:1.85;margin-bottom:20px}
.about-grid p strong{color:var(--text);font-weight:400}
@media(max-width:760px){.about-grid{grid-template-columns:1fr}}

/* services */
.svc{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:14px;padding:clamp(30px,5vh,60px) 0}
.svc .card{border:1px solid var(--line);border-radius:4px;padding:clamp(24px,3vw,40px);background:rgba(255,255,255,.015);transition:.4s var(--ease)}
.svc .card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--glow)}
.svc .card .n{font-size:11px;color:var(--accent2);text-transform:uppercase}
.svc .card h3{font-family:'Anton';text-transform:uppercase;font-size:clamp(24px,3vw,38px);margin:12px 0}
.svc .card .price{font-family:'JetBrains Mono';font-size:13px;color:var(--text);margin-bottom:14px}
.svc .card ul{list-style:none;color:var(--muted);font-size:13px;line-height:2}
.svc .card ul li::before{content:"— ";color:var(--accent2)}

/* ============================================================
   LIGHTBOX
   ============================================================ */
#lb{position:fixed;inset:0;z-index:9700;background:rgba(5,5,7,.95);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;padding:5vh 4vw}
#lb.open{display:flex}
#lb img{max-width:92vw;max-height:88vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6);animation:lbin .4s var(--ease)}
@keyframes lbin{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
#lb .x,#lb .nav{position:absolute;color:#fff;font-family:'JetBrains Mono';cursor:pointer;user-select:none;opacity:.7;transition:.3s}
#lb .x:hover,#lb .nav:hover{opacity:1;color:var(--accent2)}
#lb .x{top:24px;right:30px;font-size:22px}
#lb .nav{top:50%;transform:translateY(-50%);font-size:34px;padding:20px}
#lb .prev{left:10px}#lb .next{right:10px}
#lb .count{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:'JetBrains Mono';font-size:12px;color:var(--muted)}

/* ============================================================
   MOTION / FILMS
   ============================================================ */
.motion-banner{position:relative;height:clamp(48vh,68vh,78vh);overflow:hidden;margin:clamp(40px,8vh,90px) 0}
.motion-banner video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.motion-banner .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;gap:14px;padding:0 clamp(20px,6vw,90px);background:linear-gradient(90deg,rgba(7,6,15,.78),rgba(7,6,15,.25) 60%,transparent)}
.motion-banner h2{font-family:'Anton';text-transform:uppercase;font-size:clamp(36px,7vw,104px);line-height:.9;max-width:16ch}
.motion-banner p{color:#cfcdd8;max-width:40ch;font-size:clamp(13px,1.5vw,16px);line-height:1.7}

.films{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr));gap:16px;padding:clamp(30px,5vh,60px) 0}
.film{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--bg-soft);cursor:pointer;transition:.4s var(--ease)}
.film:hover{border-color:var(--accent);box-shadow:var(--glow);transform:translateY(-4px)}
.film.feature{grid-column:1/-1}
.film .pf{position:relative;aspect-ratio:16/9;overflow:hidden}
.film.feature .pf{aspect-ratio:21/8}
.film .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .5s;filter:saturate(.92) brightness(.78)}
.film:hover .poster{transform:scale(1.05);filter:saturate(1) brightness(.9)}
.film .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}
.film .play b{width:66px;height:66px;border-radius:50%;background:rgba(10,8,23,.5);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;padding-left:4px;transition:.3s var(--ease)}
.film:hover .play b{border-color:var(--accent2);box-shadow:0 0 26px rgba(59,230,255,.45);transform:scale(1.1)}
.film .dur{position:absolute;right:12px;bottom:12px;z-index:2;font-family:'JetBrains Mono';font-size:11px;color:#fff;background:rgba(0,0,0,.5);padding:3px 8px;border-radius:20px}
.film .meta2{padding:16px 18px 20px}
.film .meta2 .n{font-size:11px;color:var(--accent2);text-transform:uppercase;letter-spacing:.1em}
.film .meta2 h3{font-family:'Anton';text-transform:uppercase;font-size:clamp(20px,2.4vw,32px);line-height:.95;margin-top:8px}
.film .meta2 .d{font-size:12.5px;color:var(--muted);margin-top:6px;line-height:1.6}

/* film poster strip (home teaser) */
.film-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-top:8px}
.film-strip a{position:relative;aspect-ratio:4/3;border-radius:3px;overflow:hidden}
.film-strip img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) brightness(.7);transition:.5s var(--ease)}
.film-strip a:hover img{filter:saturate(1) brightness(.95);transform:scale(1.05)}
.film-strip .lab{position:absolute;left:12px;bottom:10px;z-index:2;font-family:'JetBrains Mono';font-size:10px;text-transform:uppercase;color:#fff;text-shadow:0 1px 8px #000}
.film-strip a::after{content:"▶";position:absolute;top:10px;right:12px;font-size:11px;color:#fff;opacity:.85}
@media(max-width:680px){.film-strip{grid-template-columns:1fr 1fr}}

/* video lightbox */
#vlb{position:fixed;inset:0;z-index:9700;background:rgba(4,4,8,.97);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:4vh 4vw}
#vlb.open{display:flex}
#vlb video{max-width:94vw;max-height:88vh;background:#000;box-shadow:0 30px 90px rgba(0,0,0,.7);border-radius:3px}
#vlb iframe.ytplay{width:min(94vw,1280px);aspect-ratio:16/9;max-height:88vh;border:0;background:#000;box-shadow:0 30px 90px rgba(0,0,0,.7);border-radius:3px}
#vlb .x{position:absolute;top:22px;right:30px;color:#fff;font-family:'JetBrains Mono';font-size:20px;cursor:pointer;opacity:.8;z-index:2}
#vlb .x:hover{opacity:1;color:var(--accent2)}
#vlb .cap{position:absolute;left:30px;bottom:24px;font-family:'JetBrains Mono';font-size:12px;color:var(--muted)}

/* ============================================================
   REVEAL UTILITIES
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  .reveal,.feat h3,.feat .info p,.feat .info .btn{opacity:1!important;transform:none!important}
  .feat .row .media .mask{transform:scaleY(0)}
  .bgfx .blob{animation:none}
}

/* ============================================================
   About — social icon row
   ============================================================ */
.about-socials{display:flex;gap:14px;margin-top:26px;flex-wrap:wrap}
.about-socials a{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);border-radius:50%;color:var(--text);transition:.3s var(--ease)}
.about-socials a svg{width:19px;height:19px;display:block}
.about-socials a:hover{border-color:var(--accent);color:#fff;box-shadow:var(--glow);transform:translateY(-2px)}

/* ============================================================
   Contact modal — popup of all socials
   ============================================================ */
.cmodal{position:fixed;inset:0;z-index:9800;display:none;align-items:center;justify-content:center;padding:6vh 5vw;background:rgba(5,5,7,.82);backdrop-filter:blur(8px)}
.cmodal.open{display:flex}
.cmodal-card{position:relative;width:min(440px,100%);background:linear-gradient(180deg,var(--bg-soft),var(--bg));border:1px solid var(--line);border-radius:20px;padding:clamp(28px,4vw,40px);box-shadow:0 30px 90px rgba(0,0,0,.6);animation:lbin .4s var(--ease)}
.cmodal-card .cmodal-x{position:absolute;top:18px;right:20px;background:none;border:none;color:var(--muted);font-family:'JetBrains Mono',monospace;font-size:12px;cursor:pointer;transition:.3s}
.cmodal-card .cmodal-x:hover{color:var(--accent2)}
.cmodal-eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent2)}
.cmodal-card h3{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(28px,5vw,40px);line-height:1;margin:12px 0 8px}
.cmodal-card p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:22px}
.cmodal-links{display:flex;flex-direction:column;gap:12px}
.cmodal-links a{display:flex;align-items:center;gap:14px;padding:13px 16px;border:1px solid var(--line);border-radius:12px;color:var(--text);transition:.3s var(--ease)}
.cmodal-links a:hover{border-color:var(--accent);background:rgba(122,108,255,.08);transform:translateX(3px)}
.cmodal-links a svg{width:20px;height:20px;flex:0 0 20px;color:var(--accent2)}
.cmodal-links .cl-txt{display:flex;flex-direction:column;line-height:1.3}
.cmodal-links .cl-txt b{font-weight:500;font-size:14px}
.cmodal-links .cl-txt span{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted)}

/* ============================================================
   Films — featured YouTube embed (responsive 16:9)
   ============================================================ */
.yt-feature{margin-top:clamp(34px,6vw,60px)}
.yt-feature .yt-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.yt-feature .yt-head .lab{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent2)}
.yt-feature .yt-head h2{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:clamp(26px,4.6vw,54px);line-height:1}
.yt-frame{position:relative;width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#000;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.yt-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.yt-feature .yt-sub{margin-top:14px;color:var(--muted);font-size:14px;line-height:1.7;max-width:60ch}
