/* =============================================
   OMNIX — Tech Minimalist · Clean Build
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --black:  #050505;
  --white:  #ffffff;
  --purple: #7A00FF;
  --p10:    rgba(122,0,255,.10);
  --p20:    rgba(122,0,255,.20);
  --p40:    rgba(122,0,255,.40);
  --p60:    rgba(122,0,255,.60);
  --glow:   0 0 40px rgba(122,0,255,.35);
  --muted:  rgba(255,255,255,.50);
  --border: rgba(255,255,255,.06);
  --glass:  rgba(255,255,255,.025);
  --max:    1440px;
  --font:   'Inter', system-ui, sans-serif;
  --ease:   cubic-bezier(.16,1,.3,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
}

/* ─── Reset ─── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { background:var(--black); -webkit-font-smoothing:antialiased; }
html.lenis,html.lenis body { height:auto; }
.lenis.lenis-smooth { scroll-behavior:auto !important; }
body { overflow-x:hidden; background:var(--black); color:var(--white); font-family:var(--font); font-size:1rem; line-height:1.65; cursor:none; }
body::-webkit-scrollbar { display:none; }
a { color:inherit; text-decoration:none; cursor:none; }
img,video { display:block; max-width:100%; }
button { font:inherit; border:none; background:none; color:inherit; cursor:none; }
::selection { color:var(--white); background:var(--purple); }

/* ─── Typography — Inter only ─── */
h1,h2,h3,h4 { font-family:var(--font); font-weight:600; letter-spacing:-0.03em; line-height:1.15; }
h1 { font-size:3.5rem; }
h2 { font-size:2.5rem; }
h3 { font-size:1.5rem; }
h4 { font-size:1.1rem; font-weight:600; }
p  { font-size:1rem; line-height:1.7; color:rgba(255,255,255,.60); }

/* ─── Noise Grain ─── */
.noise {
  position:fixed; inset:-50%; z-index:9500;
  width:200%; height:200%; pointer-events:none; opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain .4s steps(3) infinite;
}
@keyframes grain {
  0%  { transform:translate(0,0); }
  33% { transform:translate(-3%,-3%); }
  66% { transform:translate(3%,1%); }
}

/* ─── Preloader ─── */
.preloader {
  position:fixed; inset:0; z-index:10000;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.8rem;
  background:var(--black);
  transition:opacity .9s ease, visibility .9s ease;
}
.preloader.done { opacity:0; visibility:hidden; pointer-events:none; }
.preloader-num { font-size:clamp(5rem,14vw,12rem); font-weight:800; letter-spacing:-0.05em; line-height:.9; }
.preloader-bar { width:clamp(160px,28vw,300px); height:1px; background:rgba(255,255,255,.08); overflow:hidden; }
.preloader-fill { height:100%; width:0; background:var(--purple); box-shadow:var(--glow); transition:width .1s linear; }
.preloader-label { font-size:.6rem; font-weight:700; letter-spacing:.25em; text-transform:uppercase; color:var(--muted); }

/* ─── Cursor ─── */
.cur-dot  { position:fixed; z-index:9999; width:8px; height:8px; border-radius:50%; background:var(--purple); pointer-events:none; transform:translate(-50%,-50%); box-shadow:0 0 14px rgba(122,0,255,.65); transition:width .3s var(--ease),height .3s var(--ease),background .3s ease; }
.cur-ring { position:fixed; z-index:9998; width:44px; height:44px; border-radius:50%; border:1.5px solid rgba(122,0,255,.45); pointer-events:none; transform:translate(-50%,-50%); transition:width .45s var(--spring),height .45s var(--spring),border-color .3s ease; }
.cur-glow { position:fixed; z-index:9990; width:260px; height:260px; border-radius:50%; pointer-events:none; background:radial-gradient(circle,rgba(122,0,255,.22),transparent 70%); filter:blur(28px); mix-blend-mode:screen; opacity:.45; transform:translate(-50%,-50%); }
.cur-dot.hov { width:52px; height:52px; background:rgba(122,0,255,.08); box-shadow:0 0 30px rgba(122,0,255,.2); }
.cur-ring.hov { width:52px; height:52px; border-color:var(--purple); opacity:.35; }

/* ─── Header ─── */
.hdr {
  position:absolute; top:0; left:0; right:0; z-index:120;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:20px;
  padding:20px clamp(20px,4vw,68px);
  background:transparent;
}

.logo { width:clamp(56px,5vw,90px); }
.logo img { width:100%; filter:drop-shadow(0 0 14px rgba(122,0,255,.18)); transition:filter .4s ease; }
.logo:hover img { filter:drop-shadow(0 0 28px rgba(122,0,255,.5)); }

.nav { display:flex; align-items:center; justify-content:center; gap:clamp(16px,3vw,44px); font-size:.68rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; }
.nav a { opacity:.45; transition:opacity .3s ease; position:relative; }
.nav a::after { content:''; position:absolute; left:0; right:0; bottom:-4px; height:1px; background:var(--purple); transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.nav a:hover { opacity:1; }
.nav a:hover::after { transform:scaleX(1); transform-origin:left; }

/* ─── Button ─── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  height:46px; padding:0 22px;
  border:1px solid rgba(255,255,255,.08); border-radius:999px;
  background:rgba(255,255,255,.03); backdrop-filter:blur(12px);
  font-size:.68rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  transition:all .4s var(--ease);
}
.btn:hover { border-color:var(--p60); background:var(--p10); box-shadow:var(--glow); transform:scale(1.04); }
.btn .arrow { width:12px; height:8px; background:currentColor; clip-path:polygon(0 42%,70% 42%,52% 0,100% 50%,52% 100%,70% 58%,0 58%); transition:transform .3s var(--ease); }
.btn:hover .arrow { transform:translateX(3px); }
.btn-cta { justify-self:end; }

/* ─── Shell / Label / Section ─── */
.shell { width:min(var(--max), calc(100% - clamp(40px,8vw,140px))); margin:0 auto; }
.sec   { padding:clamp(80px,10vw,160px) 0; }
.label {
  display:inline-block; margin-bottom:14px;
  font-size:.65rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:var(--purple); opacity:.7;
}

/* ─── Hero ─── */
.hero {
  position:relative; height:100vh; height:100svh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; isolation:isolate;
  padding:clamp(100px,10vw,180px) clamp(20px,5vw,80px) clamp(44px,5vw,76px);
}
.hero-vid-wrap { position:absolute; inset:0; z-index:-3; overflow:hidden; }
.hero-vid { width:100%; height:100%; object-fit:cover; opacity:.45; filter:saturate(.5) contrast(1.3) brightness(.35); transform:scale(1.04); }
.hero-mask { position:absolute; inset:0; background:radial-gradient(ellipse 65% 65% at 50% 45%,transparent 0%,var(--black) 100%); }
.hero-ov   { position:absolute; inset:0; z-index:-2; background:radial-gradient(circle at 55% 35%,rgba(122,0,255,.15),transparent 45%),linear-gradient(180deg,rgba(5,5,5,.1) 0%,rgba(5,5,5,.04) 40%,rgba(5,5,5,.98) 100%); }

.hero-inner { text-align:center; position:relative; z-index:1; max-width:860px; }
.hero-tag {
  display:inline-flex; align-items:center; gap:10px;
  margin-bottom:clamp(14px,2vw,24px);
  font-size:.62rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(122,0,255,.8);
}
.hero-tag::before,.hero-tag::after { content:''; width:24px; height:1px; background:var(--purple); }
.hero-title {
  font-size:clamp(3rem,10vw,7rem);
  font-weight:800; letter-spacing:-0.04em; line-height:.95;
  margin-bottom:clamp(12px,2vw,22px);
}
.hero-slogan {
  font-size:clamp(1rem,2vw,1.35rem);
  font-weight:400; color:rgba(255,255,255,.62);
  letter-spacing:0; line-height:1.6;
  max-width:560px; margin:0 auto clamp(24px,3vw,44px);
}
.hero-foot { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }

.scroll-cue { position:absolute; right:clamp(20px,4vw,68px); bottom:34px; display:flex; align-items:center; gap:10px; writing-mode:vertical-rl; color:var(--muted); font-size:.58rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; }
.scroll-cue .bar { width:1px; height:52px; background:rgba(255,255,255,.08); overflow:hidden; }
.scroll-cue .bar::after { content:''; display:block; width:1px; height:16px; background:var(--purple); box-shadow:0 0 6px var(--purple); animation:cue 2s ease-in-out infinite; }
@keyframes cue { 0%{transform:translateY(-20px)} 100%{transform:translateY(58px)} }

/* ─── Stats ─── */
.stats { padding:clamp(28px,4vw,44px) 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:rgba(122,0,255,.015); }
.stats-inner { width:min(var(--max),calc(100% - clamp(40px,8vw,140px))); margin:0 auto; display:flex; justify-content:center; gap:clamp(36px,8vw,110px); flex-wrap:wrap; }
.stat { text-align:center; }
.stat strong { display:block; font-size:clamp(2.5rem,5.5vw,5.5rem); font-weight:800; letter-spacing:-0.04em; line-height:.9; }
.stat strong::before { content:'+'; color:var(--purple); }
.stat span { display:block; margin-top:8px; color:var(--muted); font-size:.62rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; }

/* ─── About ─── */
.about { background:radial-gradient(ellipse at 8% 30%,rgba(122,0,255,.05),transparent 50%),#060606; }
.about-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(28px,6vw,96px); align-items:end; }
.about-copy p { color:rgba(255,255,255,.75); font-size:clamp(1rem,2vw,1.5rem); font-weight:500; line-height:1.5; letter-spacing:-0.01em; }

/* ─── Services Bento ─── */
.services { background:radial-gradient(ellipse at 72% 18%,rgba(122,0,255,.04),transparent 50%),var(--black); }
.sec-head { display:grid; grid-template-columns:.28fr 1fr; gap:clamp(16px,4vw,64px); align-items:start; margin-bottom:clamp(36px,5vw,64px); }

.bento { display:grid; grid-template-columns:1.1fr .9fr 1fr; grid-auto-rows:minmax(200px,auto); gap:10px; }
.card {
  position:relative; min-height:240px; overflow:hidden;
  padding:clamp(20px,2.5vw,32px);
  border:1px solid var(--border); border-radius:16px;
  background:var(--glass); backdrop-filter:blur(16px);
  transition:transform .45s var(--ease), border-color .35s ease, box-shadow .45s ease;
}
.card::before { content:''; position:absolute; inset:0; border-radius:16px; background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(122,0,255,.07),transparent 50%); opacity:0; transition:opacity .35s ease; pointer-events:none; }
.card:hover { border-color:rgba(122,0,255,.4); transform:translateY(-4px); box-shadow:0 0 40px rgba(122,0,255,.1),0 24px 60px rgba(0,0,0,.3); }
.card:hover::before { opacity:1; }
.card > * { position:relative; z-index:1; }
.card .n { color:var(--purple); font-size:.7rem; font-weight:700; letter-spacing:.1em; opacity:.6; }
.card h3 { margin-top:clamp(22px,3vw,40px); font-size:clamp(1.1rem,2vw,1.6rem); font-weight:600; letter-spacing:-0.02em; }
.card p  { margin-top:10px; color:var(--muted); font-size:.88rem; line-height:1.6; }
.c-lg { grid-column:span 2; grid-row:span 2; }
.c-w  { grid-column:span 2; }
.c-t  { grid-row:span 2; }

/* ─── Portfolio Stack ─── */
.work { background:radial-gradient(ellipse at 50% 0%,rgba(122,0,255,.05),transparent 50%),#070707; }
.work-head { margin-bottom:clamp(36px,5vw,64px); }
.stack {
  width:min(1160px,calc(100% - 32px)); margin:0 auto;
  padding-bottom:clamp(60px,8vw,120px);
}
.proj {
  position:sticky; top:96px;
  min-height:min(660px,70vh); margin-bottom:28px;
  overflow:hidden; border:1px solid rgba(255,255,255,.06);
  border-radius:20px; background:#0a0a0a;
  box-shadow:0 32px 90px rgba(0,0,0,.5);
  transform-origin:top center; will-change:transform;
  z-index:1;
}
.proj img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.55; filter:saturate(.65) contrast(1.1) brightness(.5); transition:transform .8s var(--ease), opacity .5s ease; }
.proj:hover img { transform:scale(1.04); opacity:.72; }
.proj::after { content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(to top,rgba(5,5,5,.95),rgba(5,5,5,.15) 50%,transparent),radial-gradient(circle at 12% 85%,rgba(122,0,255,.18),transparent 40%); }
.proj-info { position:absolute; left:0; right:0; bottom:0; z-index:2; padding:clamp(20px,4vw,48px); }
.proj-tags { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.proj-tags span { display:inline-flex; align-items:center; height:24px; padding:0 10px; border:1px solid rgba(255,255,255,.1); border-radius:999px; background:rgba(255,255,255,.04); backdrop-filter:blur(8px); font-size:.58rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; }
.proj-info h3 { font-size:clamp(1.8rem,5vw,5rem); font-weight:700; letter-spacing:-0.03em; }
.proj-info p  { max-width:440px; margin-top:8px; color:var(--muted); font-size:clamp(.8rem,.95vw,.98rem); font-weight:400; }

/* ─── Text Marquee ─── */
.marq { overflow:hidden; padding:clamp(32px,4vw,52px) 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.marq-track { display:flex; width:max-content; gap:clamp(24px,4vw,60px); animation:marquee 28s linear infinite; }
.marq-track span { font-size:clamp(1.4rem,3.5vw,4rem); font-weight:700; letter-spacing:-0.03em; text-transform:uppercase; white-space:nowrap; color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.16); transition:color .3s ease,-webkit-text-stroke-color .3s ease; }
.marq-track span:hover { color:var(--purple); -webkit-text-stroke-color:var(--purple); }
@keyframes marquee { to { transform:translateX(-50%); } }

/* ─── Trust Wall — 80px logos ─── */
.trust { padding:clamp(40px,5vw,68px) 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); overflow:hidden; }
.trust-label { text-align:center; margin-bottom:clamp(22px,3vw,38px); font-size:.6rem; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }
.trust-track { display:flex; width:max-content; gap:0; align-items:center; animation:logoScroll 38s linear infinite; }
.trust-track img {
  height:80px; width:auto; max-width:220px;
  object-fit:contain;
  margin:0 40px;
  opacity:.5; filter:grayscale(1) brightness(2);
  transition:opacity .35s ease, filter .35s ease;
}
.trust-track img:hover { opacity:1; filter:grayscale(0) brightness(1); }
@keyframes logoScroll { to { transform:translateX(-50%); } }

/* ─── Fullscreen Footer Video (OMNIX_FOOTER.webm) ─── */
.footer-showreel,
.vid-fullscreen {
  position:relative !important;
  width:100% !important;
  height:100vh !important;
  overflow:hidden !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  z-index:10 !important;
  margin-top:0 !important;
}

.footer-video-bg,
.vid-fullscreen video {
  position:absolute !important;
  top:0 !important; left:0 !important;
  width:100% !important; height:100% !important;
  object-fit:cover !important;
  opacity:.55;
  filter:brightness(.5) saturate(.65) contrast(1.2);
  z-index:-1 !important;
  pointer-events:none !important;
}

.footer-content,
.footer-main,
.vid-fullscreen-overlay {
  position:relative !important;
  z-index:3 !important;
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:center !important;
  text-align:center !important;
  padding:clamp(20px,5vw,80px);
}

.vid-fs-title {
  font-size:clamp(2rem,6vw,5.5rem);
  font-weight:700; letter-spacing:-0.03em; line-height:1.1;
  color:var(--white);
  margin-bottom:14px;
}

.footer-content p:not(.vid-fs-title),
.vid-fullscreen-overlay p {
  font-size:clamp(.72rem,1.1vw,.95rem);
  font-weight:600; letter-spacing:.26em;
  text-transform:uppercase;
  color:rgba(255,255,255,.50);
}

/* Purple cinematic overlay on footer video */
.footer-vid-overlay {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  pointer-events: none !important;
  background:
    /* Deep purple center glow */
    radial-gradient(ellipse 80% 60% at 50% 50%, rgba(122,0,255,.28), transparent 70%),
    /* Dark vignette edges */
    radial-gradient(ellipse 120% 100% at 50% 50%, transparent 40%, rgba(5,5,5,.75) 100%),
    /* Subtle purple tint across entire frame */
    linear-gradient(135deg, rgba(80,0,180,.15) 0%, rgba(122,0,255,.08) 50%, rgba(40,0,120,.18) 100%);
}


/* ─── Footer ─── */
.footer {
  position:relative; z-index:20;
  background:radial-gradient(ellipse at 50% 20%,rgba(122,0,255,.05),transparent 55%),var(--black);
  padding:clamp(80px,10vw,140px) 0 clamp(40px,5vw,60px);
}
.footer-hero { text-align:center; margin-bottom:clamp(50px,7vw,96px); }
.footer-title {
  font-size:clamp(2.5rem,8vw,9rem);
  font-weight:800; letter-spacing:-0.04em; line-height:.95;
  display:inline-block;
  transition:text-shadow .5s ease, transform .5s var(--ease);
  cursor:pointer;
}
.footer-title:hover { text-shadow:0 0 80px rgba(122,0,255,.5),0 0 160px rgba(122,0,255,.18); transform:scale(1.02); }

.footer-grid {
  width:min(var(--max),calc(100% - clamp(40px,8vw,140px))); margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr 1fr; gap:clamp(24px,4vw,60px);
  padding-top:clamp(28px,4vw,52px); border-top:1px solid rgba(255,255,255,.06);
}
.footer-col h4 { font-size:.7rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; margin-bottom:16px; color:rgba(255,255,255,.65); }
.footer-col a { display:block; margin-bottom:10px; color:var(--muted); font-size:.9rem; font-weight:400; transition:color .3s ease; }
.footer-col a:hover { color:var(--white); }
.footer-col .btn { margin-top:8px; }

.footer-bar {
  width:min(var(--max),calc(100% - clamp(40px,8vw,140px))); margin:clamp(48px,6vw,80px) auto 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
  padding-top:24px; border-top:1px solid rgba(255,255,255,.04);
}
.footer-bar img { width:clamp(48px,4.5vw,72px); filter:drop-shadow(0 0 10px rgba(122,0,255,.14)); }
.footer-bar p { color:rgba(255,255,255,.28); font-size:.62rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; }

/* ─── Reveal Base — opacity set by JS, not CSS (failsafe) ─── */
[data-r],[data-s] { opacity:1; transition:opacity .1s; }
.js-ready [data-r], .js-ready [data-s] { opacity:0; }

/* ─── Video Showcase Grid ─── */
.vid-grid { background:var(--black); }
.vid-grid .shell { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.vid-tile {
  position:relative; aspect-ratio:16/9; overflow:hidden;
  border-radius:16px; border:1px solid var(--border); background:#0a0a0a;
  transition:border-color .35s ease, box-shadow .35s ease;
}
.vid-tile:first-child { grid-column:span 2; aspect-ratio:21/9; }
.vid-tile:hover { border-color:rgba(122,0,255,.28); box-shadow:0 0 36px rgba(122,0,255,.07); }
.vid-tile video { width:100%; height:100%; object-fit:cover; opacity:.6; filter:brightness(.55) contrast(1.1); }
.vid-tile .vid-label { position:absolute; bottom:14px; left:16px; z-index:2; font-size:.6rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }

/* ─── Responsive ─── */
@media (max-width:1020px) {
  body,a,button { cursor:auto; }
  .cur-dot,.cur-ring,.cur-glow { display:none; }
  .hdr { grid-template-columns:1fr auto; }
  .nav { display:none; }
  .about-grid,.sec-head,.footer-grid { grid-template-columns:1fr; }
  .bento { grid-template-columns:1fr 1fr; }
  .c-lg,.c-w,.c-t { grid-column:auto; grid-row:auto; }
  .vid-grid .shell { grid-template-columns:1fr; }
  .vid-tile:first-child { grid-column:auto; aspect-ratio:16/9; }
}
@media (max-width:680px) {
  .btn-cta { display:none; }
  .hero { min-height:100svh; padding-top:100px; align-items:flex-end; text-align:left; }
  .hero-inner { text-align:left; }
  .hero-tag { justify-content:flex-start; }
  h1 { font-size:2.6rem; }
  h2 { font-size:1.9rem; }
  .bento { grid-template-columns:1fr; }
  .proj { top:68px; min-height:460px; border-radius:14px; }
  .footer-grid { grid-template-columns:1fr; }
  .scroll-cue { display:none; }
  .sec { padding:clamp(56px,12vw,100px) 0; }
}
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; }
  [data-r],[data-s] { opacity:1; }
  .preloader { display:none; }
}

/* ─────────────────────────────────────────────
   SHOWREEL CAROUSEL
   ───────────────────────────────────────────── */

.showreel {
  background: radial-gradient(ellipse at 50% 0%, rgba(122,0,255,.06), transparent 55%), #070707;
  overflow: hidden;
}

.showreel-head { margin-bottom: clamp(28px,4vw,48px); }

/* Outer: arrows + scrollable track in a row */
.showreel-outer {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 clamp(20px,5vw,80px);
}

/* Scrollable track */
.showreel-track {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 20px 0 28px;
  flex: 1;
}
.showreel-track::-webkit-scrollbar { display: none; }

/* Individual card */
.sreel-card {
  flex: 0 0 auto;
  width: clamp(200px, 22vw, 280px);
  scroll-snap-align: start;
  cursor: pointer;
}

/* Thumbnail container — portrait 9:16 */
.sreel-thumb {
  position: relative;
  aspect-ratio: 9/16;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.06);
  background: #0e0e0e;
  transition: border-color .35s ease, box-shadow .35s ease;
}

.sreel-card:hover .sreel-thumb {
  border-color: rgba(122,0,255,.45);
  box-shadow: 0 0 32px rgba(122,0,255,.2), 0 20px 50px rgba(0,0,0,.5);
}

.sreel-thumb video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.7) saturate(.8);
  transition: filter .4s ease, transform .5s ease;
}

.sreel-card:hover .sreel-thumb video {
  filter: brightness(.9) saturate(1);
  transform: scale(1.04);
}

/* Dark gradient overlay on thumb */
.sreel-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,5,5,.85) 0%, transparent 50%);
  z-index: 1;
  pointer-events: none;
}

/* Play button */
.sreel-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%) scale(1);
  z-index: 2;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(122,0,255,.85);
  border: 2px solid rgba(255,255,255,.15);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  cursor: pointer;
  transition: transform .3s var(--ease), background .3s ease, box-shadow .3s ease;
}

.sreel-play svg {
  width: 18px;
  height: 18px;
  margin-left: 3px;
}

.sreel-card:hover .sreel-play {
  transform: translate(-50%,-50%) scale(1.12);
  background: var(--purple);
  box-shadow: 0 0 24px rgba(122,0,255,.6);
}

/* Card info below thumb */
.sreel-info {
  padding: 14px 4px 0;
}

.sreel-info h3 {
  font-size: .95rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #fff;
  margin: 0 0 4px;
}

.sreel-info p {
  font-size: .75rem;
  color: rgba(255,255,255,.4);
  margin: 0;
}

/* Arrow buttons */
.sreel-btn {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.6);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color .3s ease, background .3s ease, color .3s ease;
  z-index: 2;
}

.sreel-btn:hover {
  border-color: rgba(122,0,255,.5);
  background: rgba(122,0,255,.12);
  color: #fff;
}

.sreel-prev { margin-right: 12px; }
.sreel-next { margin-left:  12px; }

@media (max-width:680px) {
  .sreel-card { width: clamp(160px,55vw,220px); }
  .sreel-btn  { display: none; }
}



/* ─────────────────────────────────────────────
   SERVICES — SPLIT SCREEN  (3fr left | 2fr right)
   ───────────────────────────────────────────── */

.svc-split {
  background: radial-gradient(ellipse at 72% 18%, rgba(122,0,255,.04), transparent 50%), var(--black);
}

/* Outer 3fr | 2fr grid */
.svc-outer {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 40px;
  align-items: start;
}

/* ── LEFT column ── */
.svc-left { display: flex; flex-direction: column; gap: clamp(32px,4vw,56px); }

.svc-header { display: flex; flex-direction: column; gap: 12px; }

.svc-sub {
  font-size: .95rem;
  line-height: 1.7;
  color: rgba(255,255,255,.45);
  max-width: 520px;
  margin-top: 4px;
}

/* 2×3 cards grid */
.svc-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Individual card — background applied via inline style */
.svc-card {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.05);
  padding: 32px 28px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color .4s ease, box-shadow .4s ease;
  /* bg-image scale lives on a pseudo-element */
  background-size: cover !important;
  background-position: center !important;
}

/* Pseudo-element for the scale hover on background image */
.svc-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: inherit;
  background-size: cover !important;
  background-position: center !important;
  transition: transform .65s cubic-bezier(.16,1,.3,1);
  z-index: 0;
  border-radius: 20px;
}

.svc-card:hover {
  border-color: rgba(122,0,255,.5);
  box-shadow: 0 0 30px rgba(122,0,255,.16), 0 16px 48px rgba(0,0,0,.5);
}

.svc-card:hover::before { transform: scale(1.06); }

/* Purple glow on hover */
.svc-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 20px;
  background: radial-gradient(ellipse at 15% 60%, rgba(122,0,255,.1), transparent 60%);
  opacity: 0;
  transition: opacity .4s ease;
  z-index: 0;
}
.svc-card:hover::after { opacity: 1; }

/* All direct children above pseudo-elements */
.svc-card > * { position: relative; z-index: 1; }

.svc-num {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .2em;
  color: rgba(122,0,255,.8);
}

.svc-card h3 {
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: #fff;
  margin: 0;
}

.svc-card p {
  font-size: .82rem;
  line-height: 1.6;
  color: rgba(255,255,255,.5);
  margin: 0;
}

.svc-arrow {
  display: inline-block;
  font-size: 1rem;
  color: rgba(122,0,255,.55);
  margin-top: 4px;
  transition: transform .3s ease, color .3s ease;
  width: fit-content;
}
.svc-card:hover .svc-arrow { transform: translateX(5px); color: var(--purple); }

/* ── RIGHT column — video ── */
.svc-right {
  position: sticky;
  top: 10vh;
}

.svc-vid-wrap {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
  box-shadow:
    0 0 60px rgba(122,0,255,.18),
    0 40px 100px rgba(0,0,0,.6);
  background: #0a0a0a;
}

.svc-vid-wrap video {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 3/4;
  filter: brightness(.8) saturate(.85);
  transition: filter .5s ease;
}

.svc-vid-wrap:hover video { filter: brightness(.95) saturate(1); }

.svc-vid-tag {
  position: absolute;
  bottom: 16px;
  left: 16px;
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(10px);
  padding: 5px 13px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
}

/* ── Responsive ── */
@media (max-width:1020px) {
  .svc-outer { grid-template-columns: 1fr; }
  .svc-right { position: relative; top: auto; }
  .svc-vid-wrap video { aspect-ratio: 16/9; }
}

@media (max-width:680px) {
  .svc-cards { grid-template-columns: 1fr; }
  .svc-card  { padding: 24px 20px; }
  .svc-card h3 { font-size: .95rem; }
}
