/* ========== SLD · Service pages + big service grid ========== */

/* ====== HOME: Big service cards (4 grandes) ====== */
.create__grid--big{grid-template-columns:repeat(2,1fr);gap:16px}
.bigtool{
  position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  border-radius:28px;overflow:hidden;aspect-ratio:4/3;
  background:#0f0f0f;border:1px solid rgba(255,255,255,.06);
  transition:transform .45s var(--ease),border-color .3s,box-shadow .3s;isolation:isolate;
}
.bigtool video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:saturate(1.15) brightness(.65);transition:filter .5s var(--ease),transform .7s}
.bigtool:hover{transform:translateY(-8px);border-color:var(--pink);box-shadow:0 40px 80px rgba(255,30,190,.25)}
.bigtool:hover video{filter:saturate(1.3) brightness(.9);transform:scale(1.04)}
.bigtool::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg, rgba(10,10,10,.15) 0%, rgba(10,10,10,.3) 40%, rgba(10,10,10,.95) 100%);pointer-events:none}
.bigtool__body{position:relative;z-index:2;padding:36px 34px}
.bigtool__num{font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--pink);display:block;margin-bottom:14px}
.bigtool__body h3{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(36px,4.5vw,60px);font-weight:800;letter-spacing:-.04em;line-height:.95;color:#fff}
.bigtool__body p{margin-top:12px;opacity:.82;font-size:15px;line-height:1.5;max-width:520px}
.bigtool__cta{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:10px 16px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);font-size:13px;font-weight:700;backdrop-filter:blur(6px);transition:all .3s var(--ease)}
.bigtool:hover .bigtool__cta{background:var(--yellow);color:#0a0a0a;border-color:var(--yellow)}
.bigtool:hover .bigtool__cta .arrow{color:#0a0a0a}

@media (max-width:820px){
  .create__grid--big{grid-template-columns:1fr;gap:12px}
  .bigtool{aspect-ratio:4/3}
  .bigtool__body{padding:24px 22px}
}

/* ====== SERVICE PAGES ====== */
.svc-hero{position:relative;min-height:72svh;padding:140px 28px 80px;display:flex;align-items:center;justify-content:flex-start;overflow:hidden;isolation:isolate}
.svc-hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:saturate(1.1) brightness(.55)}
.svc-hero__scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg, rgba(10,10,10,.3) 0%, rgba(10,10,10,.1) 30%, rgba(10,10,10,.8) 90%),
  radial-gradient(800px 500px at 15% 80%, rgba(255,30,190,.45), transparent 60%),
  radial-gradient(700px 400px at 85% 20%, rgba(245,222,116,.18), transparent 60%);
}
.svc-hero__grain{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.15;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.5' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size:180px;
}
.svc-hero__inner{position:relative;z-index:3;max-width:1480px;margin:0 auto;width:100%}
.svc-crumbs{display:flex;gap:8px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.7;font-weight:700;margin-bottom:20px}
.svc-crumbs a{transition:color .2s}
.svc-crumbs a:hover{color:var(--yellow)}
.svc-crumbs span{opacity:.5}

.svc-hero h1{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(68px,13vw,200px);letter-spacing:-.055em;line-height:.86;
  display:flex;flex-direction:column;
}
.svc-hero h1 .line{overflow:hidden;display:block}
.svc-hero h1 .line-inner{
  display:inline-block;
  background-image:linear-gradient(92deg,#FF1EBE 0%,#F5DE74 25%,#fff 50%,#FF4FD1 75%,#FF1EBE 100%);
  background-size:300% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:colorCycle 7s ease-in-out infinite;
  transform:translateY(110%);opacity:0;
  transition:transform 1s var(--ease-out),opacity 1s;transition-delay:.2s;
}
.svc-hero h1 .line-inner.is-in{transform:translateY(0);opacity:1}
.svc-hero h1 .line:nth-child(2) .line-inner{animation-delay:-1.5s;transition-delay:.4s}

.svc-hero__lead{margin-top:24px;font-size:19px;opacity:.9;line-height:1.55;max-width:640px}
.svc-hero__lead em{color:var(--yellow);font-size:1.05em}
.svc-hero__actions{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap}

.svc-hero__tags{margin-top:26px;display:flex;gap:8px;flex-wrap:wrap}
.svc-tag{padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);font-size:12px;font-weight:600;letter-spacing:.02em;backdrop-filter:blur(6px)}

/* SUB-SERVICES GRID */
.subs{max-width:1480px;margin:100px auto 0;padding:0 28px}
.subs__head{margin-bottom:40px;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.subs__head h2{font-size:clamp(48px,7vw,108px);font-weight:800;letter-spacing:-.04em;line-height:.9;margin-top:12px}
.subs__head p.muted{font-size:14px;max-width:420px;margin-top:10px;line-height:1.5}

.subs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sub{
  position:relative;border-radius:22px;overflow:hidden;
  background:linear-gradient(160deg,#141414,#0a0a0a);
  border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;
  transition:transform .4s var(--ease),border-color .3s;
  isolation:isolate;
}
.sub:hover{transform:translateY(-8px);border-color:var(--pink)}
.sub__img{position:relative;aspect-ratio:4/3;background-size:cover;background-position:center;overflow:hidden;transition:transform .5s var(--ease)}
.sub__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.7))}
.sub:hover .sub__img{transform:scale(1.05)}
.sub__num{position:absolute;top:14px;left:14px;z-index:2;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);font-size:10px;font-weight:800;letter-spacing:.22em;padding:5px 10px;border-radius:8px;color:#fff}
.sub__arrow{position:absolute;top:14px;right:14px;z-index:2;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;transition:all .3s var(--ease)}
.sub:hover .sub__arrow{background:var(--yellow);color:#0a0a0a;transform:rotate(-45deg) scale(1.1)}
.sub__body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:10px}
.sub__body h3{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.05}
.sub__body p{opacity:.72;font-size:14px;line-height:1.5}
.sub__tags{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;padding:0}
.sub__tags li{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:6px;background:rgba(255,30,190,.12);color:var(--pink);border:1px solid rgba(255,30,190,.2)}

/* FEATURES ROW (optional "why us" section) */
.features{max-width:1480px;margin:100px auto 0;padding:0 28px}
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.feat{background:linear-gradient(160deg,#141414,#0a0a0a);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:26px 22px;position:relative;overflow:hidden;transition:transform .3s var(--ease),border-color .3s}
.feat::before{content:"";position:absolute;top:-60px;right:-60px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(245,222,116,.3),transparent 70%);filter:blur(20px);opacity:.5;transition:opacity .3s}
.feat:hover{transform:translateY(-4px);border-color:var(--yellow)}
.feat:hover::before{opacity:1}
.feat__icon{font-size:30px;line-height:1}
.feat h4{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:700;margin-top:14px;letter-spacing:-.02em;line-height:1.1;position:relative;z-index:1}
.feat p{opacity:.7;font-size:13px;line-height:1.5;margin-top:8px;position:relative;z-index:1}

/* RESPONSIVE */
@media (max-width:1100px){
  .subs__grid{grid-template-columns:repeat(2,1fr)}
  .features__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){
  .svc-hero{padding:120px 20px 70px;min-height:auto}
  .svc-hero h1{font-size:clamp(52px,15vw,110px)}
  .svc-hero__lead{font-size:16px}
  .svc-hero__actions{flex-direction:column;align-items:stretch}
  .svc-hero__actions .btn{justify-content:center}
  .subs{padding:0 16px;margin-top:60px}
  .subs__head{margin-bottom:26px}
  .subs__head h2{font-size:clamp(40px,10vw,70px)}
  .subs__grid{grid-template-columns:1fr;gap:12px}
  .sub__body h3{font-size:21px}
  .features{padding:0 16px;margin-top:60px}
  .features__grid{grid-template-columns:1fr;gap:10px}
}

/* ========== SUB AS BUTTON (click-to-modal) ========== */
.sub--btn{border:0;background:none;color:inherit;font:inherit;text-align:left;cursor:pointer;padding:0;width:100%}

/* ========== CASE STUDY MODAL ========== */
.case{
  position:fixed;inset:0;z-index:9998;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .45s var(--ease),visibility .45s;
}
.case.is-open{opacity:1;visibility:visible;pointer-events:auto}

.case__backdrop{
  position:absolute;inset:0;
  background:radial-gradient(1000px 600px at 50% 30%,rgba(245,222,116,.18),rgba(10,10,10,.92) 60%),rgba(10,10,10,.96);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

.case__panel{
  position:absolute;inset:0;overflow-y:auto;
  padding:80px 28px 120px;
  transform:translateY(30px);
  transition:transform .55s var(--ease-out);
}
.case.is-open .case__panel{transform:translateY(0)}

.case__x{
  position:fixed;top:20px;right:20px;z-index:10;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:transform .3s var(--ease),background .3s;
}
.case__x:hover{background:var(--yellow);color:#0a0a0a;transform:rotate(90deg)}

.case__hero{
  position:relative;max-width:1100px;margin:30px auto 60px;
  aspect-ratio:16/9;border-radius:22px;overflow:hidden;
  box-shadow:
    0 80px 140px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.08),
    0 0 0 6px rgba(245,222,116,.05);
}
.case__hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.22));
  z-index:1;
}
.case__hero img{width:100%;height:100%;object-fit:cover;display:block}
.case__hero-tag{
  position:absolute;bottom:22px;left:22px;z-index:2;
  background:rgba(10,10,10,.72);backdrop-filter:blur(14px);
  color:#fff;padding:10px 16px;border-radius:999px;
  font-size:11px;letter-spacing:.22em;font-weight:700;
  border:1px solid rgba(255,255,255,.14);
}

.case__body{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.3fr;gap:60px;
  align-items:start;padding-bottom:60px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.case__head .eyebrow{margin-bottom:14px}
.case__head h2{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(42px,6vw,84px);line-height:.92;letter-spacing:-.04em;
  color:#fff;
}
.case__copy p{font-size:17px;line-height:1.6;opacity:.88;margin-bottom:22px}
.case__tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0 0 28px}
.case__tags li{
  font-size:11px;text-transform:uppercase;letter-spacing:.18em;font-weight:700;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
}
.case__ctas{display:flex;gap:12px;flex-wrap:wrap}

.case__gallery{max-width:1400px;margin:60px auto 0}
.case__gallery .eyebrow{margin-bottom:22px;opacity:.7}
.case__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
@media (max-width:1200px){.case__grid{grid-template-columns:repeat(3,1fr)}}
.case__tile{
  position:relative;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  margin:0;transition:transform .4s var(--ease),border-color .3s;
}
.case__tile:hover{transform:translateY(-4px);border-color:var(--yellow)}
.case__tile img{width:100%;height:100%;object-fit:cover;display:block}
.case__tile figcaption{
  position:absolute;inset:auto 0 0 0;padding:14px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);
  color:#fff;font-weight:600;
}
.case__tile figcaption span{color:var(--yellow);margin-right:6px}
.case__tile.is-wip{
  background:
    radial-gradient(600px 320px at 30% 80%, rgba(245,222,116,.14), transparent 60%),
    linear-gradient(135deg,#151313 0%,#0c0a09 100%);
  display:flex;align-items:flex-end;justify-content:flex-start;
  overflow:hidden;cursor:pointer;
}
.case__tile.is-wip::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(245,222,116,.09) 50%,transparent 70%);
  background-size:220% 100%;background-position:-120% 0;
  animation:shimmer 3.4s ease-in-out infinite;pointer-events:none;
}
@keyframes shimmer{0%{background-position:-120% 0}100%{background-position:220% 0}}
.case__tile.is-wip::after{
  content:"IN QUEUE";
  position:absolute;top:14px;left:14px;
  font-size:9px;letter-spacing:.26em;font-weight:700;
  padding:5px 10px;border-radius:999px;
  background:rgba(245,222,116,.16);color:var(--yellow);
  border:1px solid rgba(245,222,116,.3);
  z-index:2;
}
.case__tile-wip-cap{
  position:absolute;inset:auto 22px 22px 22px;z-index:2;
  display:flex;flex-direction:column;gap:8px;text-align:left;
  pointer-events:none;
}
.case__tile-wip-title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(20px,2.2vw,26px);letter-spacing:-.02em;
  color:#fff;line-height:1.05;
  transition:color .3s;
}
.case__tile.is-wip:hover .case__tile-wip-title{color:var(--yellow)}
.case__tile-wip-style{
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:600;line-height:1.4;
}
.case__tile-cta{
  position:absolute;top:14px;right:14px;z-index:3;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  padding:6px 12px;border-radius:999px;
  background:rgba(245,222,116,.95);color:#0a0a0a;
  opacity:0;transform:translateY(-6px);transition:opacity .3s,transform .3s;
}
.case__tile.is-wip:hover .case__tile-cta{opacity:1;transform:translateY(0)}
.case__tile.is-wip:hover{border-color:rgba(245,222,116,.5)}

/* ========== LIGHTBOX INFO MODE ========== */
.case__lb-image{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.case__lb-info{
  display:none;flex-direction:column;align-items:center;justify-content:center;
  max-width:640px;width:100%;text-align:center;color:#fff;
  padding:40px 32px;
}
.case__lb-info-status{
  font-size:10px;letter-spacing:.3em;font-weight:800;
  padding:7px 14px;border-radius:999px;
  background:rgba(245,222,116,.16);color:var(--yellow);
  border:1px solid rgba(245,222,116,.35);
  margin-bottom:34px;
}
.case__lb-info-title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(44px,6vw,80px);line-height:.98;letter-spacing:-.03em;
  margin-bottom:16px;color:#fff;
  background:linear-gradient(180deg,#fff 40%,var(--yellow));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.case__lb-info-style{
  font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:600;margin-bottom:34px;
}
.case__lb-info-detail{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%;margin-bottom:34px;
}
.case__lb-info-detail > div{
  padding:16px 14px;border-radius:14px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  text-align:left;
}
.case__lb-info-detail span{
  display:block;font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  font-weight:700;color:rgba(255,255,255,.5);margin-bottom:6px;
}
.case__lb-info-detail strong{
  display:block;font-size:13px;font-weight:600;color:#fff;line-height:1.4;
}
.case__lb-info-cta .btn{padding:14px 28px}
.case__note{
  margin-top:26px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  opacity:.45;text-align:center;
}

@media (max-width:900px){
  .case__panel{padding:70px 16px 80px}
  .case__hero{aspect-ratio:16/9;border-radius:18px;margin-bottom:28px}
  .case__body{grid-template-columns:1fr;gap:28px;padding-bottom:40px}
  .case__grid{grid-template-columns:1fr;gap:12px}
  .case__x{top:14px;right:14px;width:42px;height:42px}
  .case__ctas{flex-direction:column;align-items:stretch}
  .case__ctas .btn{justify-content:center}
}

/* ========== VIDEO PLAYER (videoclips) ========== */
.vplayer{padding:0 28px;margin-top:100px;max-width:1500px;margin-left:auto;margin-right:auto}
.vplayer__stage{
  position:relative;width:100%;aspect-ratio:16/9;
  border-radius:26px;overflow:hidden;margin-top:40px;
  box-shadow:0 80px 140px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06);
  background:#0a0a0a;
}
.vplayer__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity .35s var(--ease-out);
}
.vplayer__scrim{
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg,transparent 30%,rgba(0,0,0,.55) 75%,rgba(0,0,0,.92) 100%),
    linear-gradient(90deg,rgba(0,0,0,.55) 0%,transparent 40%);
}
.vplayer__sound{
  position:absolute;top:22px;right:22px;z-index:3;
  width:46px;height:46px;border-radius:50%;
  background:rgba(10,10,10,.55);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.18);color:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .25s,transform .25s,border-color .25s;
}
.vplayer__sound:hover{background:var(--yellow);color:#0a0a0a;border-color:var(--yellow);transform:scale(1.08)}
.vplayer__meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:50px 48px 44px;max-width:820px;
  transition:opacity .35s var(--ease-out),transform .35s var(--ease-out);
}
.vplayer__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:800;
  color:var(--yellow);margin-bottom:18px;
}
.vplayer__eyebrow::before{
  content:"";width:8px;height:8px;border-radius:50%;background:#ff3b3b;
  box-shadow:0 0 10px rgba(255,59,59,.7);
  animation:recDot 1.4s ease-in-out infinite;
}
@keyframes recDot{0%,100%{opacity:1}50%{opacity:.35}}
.vplayer__title{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(36px,5vw,72px);line-height:.98;letter-spacing:-.03em;
  color:#fff;margin-bottom:16px;
}
.vplayer__desc{
  font-size:clamp(14px,1.2vw,17px);line-height:1.5;
  color:rgba(255,255,255,.82);max-width:620px;margin-bottom:22px;
}
.vplayer__tags{
  list-style:none;padding:0;margin:0 0 26px;display:flex;flex-wrap:wrap;gap:8px;
}
.vplayer__tags li{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  padding:7px 12px;border-radius:999px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  color:#fff;backdrop-filter:blur(8px);
}
.vplayer__actions{display:flex;gap:12px;flex-wrap:wrap}
.vplayer__actions .btn{padding:14px 22px}

.vplayer__tabs{
  display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-top:18px;
}
.vtab{
  position:relative;display:flex;flex-direction:column;align-items:flex-start;
  gap:6px;padding:18px 18px 22px;border-radius:16px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  color:#fff;cursor:pointer;text-align:left;overflow:hidden;
  transition:background .3s var(--ease),border-color .3s,transform .3s;
}
.vtab:hover{background:rgba(245,222,116,.06);border-color:rgba(245,222,116,.25);transform:translateY(-3px)}
.vtab.is-active{
  background:linear-gradient(180deg,rgba(245,222,116,.14),rgba(245,222,116,.02));
  border-color:var(--yellow);
}
.vtab__num{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:13px;
  letter-spacing:.08em;color:var(--yellow);opacity:.7;
  font-variant-numeric:tabular-nums;
}
.vtab.is-active .vtab__num{opacity:1}
.vtab__name{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(14px,1.2vw,18px);letter-spacing:-.01em;
  color:#fff;line-height:1.1;
}
.vtab__bar{
  position:absolute;left:0;right:0;bottom:0;height:3px;
  background:var(--yellow);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease-out);
}
.vtab.is-active .vtab__bar{transform:scaleX(1)}

.vplayer__note{
  margin-top:22px;text-align:center;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  color:rgba(255,255,255,.35);
}

@media (max-width:900px){
  .vplayer{padding:0 16px;margin-top:60px}
  .vplayer__stage{aspect-ratio:4/5;border-radius:18px}
  .vplayer__meta{padding:26px 22px}
  .vplayer__title{font-size:clamp(28px,6vw,44px)}
  .vplayer__tabs{grid-template-columns:repeat(3,1fr);gap:8px}
  .vtab{padding:14px 12px}
  .vtab__name{font-size:12px}
  .vplayer__sound{top:14px;right:14px;width:40px;height:40px}
}

/* ========== HERO SCROLL INDICATOR ========== */
.svc-hero__scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  z-index:4;display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:#fff;opacity:.7;text-decoration:none;
  transition:opacity .3s;
}
.svc-hero__scroll:hover{opacity:1}
.svc-hero__scroll-line{
  width:1px;height:40px;background:rgba(255,255,255,.3);position:relative;overflow:hidden;
}
.svc-hero__scroll-line::after{
  content:"";position:absolute;top:-40px;left:0;right:0;height:40px;
  background:linear-gradient(180deg,transparent,var(--yellow));
  animation:scrollLine 1.8s var(--ease-out) infinite;
}
@keyframes scrollLine{0%{top:-40px}100%{top:40px}}

/* ========== STATS STRIP ========== */
.stats-strip{
  padding:70px 28px;margin-top:0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg,rgba(245,222,116,.03),transparent);
}
.stats-strip__inner{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
}
.stat{text-align:left;position:relative;padding-left:18px}
.stat::before{
  content:"";position:absolute;left:0;top:10px;bottom:10px;width:2px;
  background:linear-gradient(180deg,var(--yellow),transparent);
}
.stat__num{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:clamp(44px,5.5vw,78px);line-height:.95;
  letter-spacing:-.04em;color:#fff;font-variant-numeric:tabular-nums;
}
.stat__label{
  margin-top:8px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  font-weight:600;opacity:.65;
}

/* ========== SUB LIVE PULSE ========== */
.sub__pulse{
  position:absolute;top:14px;right:14px;z-index:3;
  font-size:10px;letter-spacing:.24em;font-weight:800;
  padding:5px 10px;border-radius:999px;
  background:rgba(245,222,116,.95);color:#0a0a0a;
  display:inline-flex;align-items:center;gap:6px;
}
.sub__pulse::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:#0a0a0a;animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.sub__img{position:relative}

/* ========== PROCESS TIMELINE ========== */
.process-tl{padding:0 28px;margin-top:120px;max-width:1400px;margin-left:auto;margin-right:auto}
.process-tl__line{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;margin-top:40px;
}
.process-tl__line::before{
  content:"";position:absolute;top:34px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(245,222,116,.4) 20%,rgba(245,222,116,.4) 80%,transparent);
  z-index:0;
}
.process-tl__step{
  position:relative;padding:0 18px 0 0;z-index:1;
}
.process-tl__step:not(:last-child){border-right:1px dashed rgba(255,255,255,.08)}
.process-tl__num{
  width:68px;height:68px;border-radius:50%;
  background:#0a0a0a;border:1px solid rgba(245,222,116,.4);
  display:flex;align-items:center;justify-content:center;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:22px;
  color:var(--yellow);letter-spacing:.02em;margin-bottom:22px;
  transition:transform .4s var(--ease),background .3s,color .3s;
}
.process-tl__step:hover .process-tl__num{
  background:var(--yellow);color:#0a0a0a;transform:scale(1.08) rotate(-6deg);
}
.process-tl__step h4{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:22px;letter-spacing:-.02em;margin-bottom:10px;color:#fff;
}
.process-tl__step p{font-size:14px;line-height:1.55;opacity:.75;margin-bottom:14px}
.process-tl__time{
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  padding:4px 10px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:var(--yellow);
}

/* ========== PILLARS (APPROACH) ========== */
.pillars{padding:0 28px;margin-top:120px;max-width:1400px;margin-left:auto;margin-right:auto}
.pillars__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:40px;
}
.pillar{
  position:relative;padding:36px 30px;border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.06);
  transition:transform .4s var(--ease),border-color .3s,background .3s;
  cursor:default;overflow:hidden;
}
.pillar::before{
  content:"";position:absolute;inset:0;opacity:0;transition:opacity .4s;
  background:radial-gradient(400px 220px at 20% 0%,rgba(245,222,116,.12),transparent 60%);
}
.pillar:hover{transform:translateY(-6px);border-color:rgba(245,222,116,.4)}
.pillar:hover::before{opacity:1}
.pillar__num{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:38px;color:var(--yellow);line-height:1;margin-bottom:18px;
  letter-spacing:.02em;
}
.pillar h3{
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(24px,2.2vw,30px);letter-spacing:-.02em;line-height:1.1;
  color:#fff;margin-bottom:14px;
}
.pillar p{font-size:15px;line-height:1.6;opacity:.82;margin-bottom:22px}
.pillar p em{color:var(--yellow);font-size:1.04em}
.pillar__arrow{
  font-size:28px;opacity:.3;transition:transform .3s var(--ease),opacity .3s,color .3s;
}
.pillar:hover .pillar__arrow{opacity:1;color:var(--yellow);transform:translateX(8px)}

/* ========== BRANDS MARQUEE ========== */
.brands-mq{padding:60px 0;margin-top:100px;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.brands-mq .eyebrow{justify-content:center;text-align:center;margin-bottom:20px}
.brands-mq__track{overflow:hidden;width:100%;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.brands-mq__row{
  display:flex;gap:40px;align-items:center;white-space:nowrap;
  animation:brandsMarquee 40s linear infinite;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:clamp(28px,3.5vw,54px);letter-spacing:-.02em;
  color:rgba(255,255,255,.15);
}
.brands-mq__row span{display:inline-block}
.brands-mq__row span:nth-child(odd){color:rgba(255,255,255,.3)}
.brands-mq__row span:nth-child(2n){color:rgba(245,222,116,.35);font-size:.5em}
@keyframes brandsMarquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ========== CASE MODAL TOP BAR (counter + nav + close) ========== */
.case__topbar{
  position:fixed;top:0;left:0;right:0;z-index:20;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 22px;
  background:linear-gradient(180deg,rgba(10,10,10,.75),rgba(10,10,10,0));
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  pointer-events:none;opacity:0;transition:opacity .3s;
}
.case.is-open .case__topbar{opacity:1;pointer-events:auto}
.case__counter{
  display:flex;align-items:center;gap:8px;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  font-size:13px;letter-spacing:.14em;color:#fff;
}
.case__counter-current,.case__counter-sep,.case__counter-total{display:none}
.case__counter-label{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.26em;font-weight:700;color:#fff;opacity:.88;
}
.case__counter-label::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--yellow);box-shadow:0 0 10px rgba(245,222,116,.7);
}
.case__nav-buttons{display:flex;gap:8px}
.case__nav-btn{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .3s,transform .3s,border-color .3s;
}
.case__nav-btn:hover{background:var(--yellow);color:#0a0a0a;border-color:var(--yellow)}
.case__nav-btn:hover svg{transform:scale(1.15)}
.case__nav-btn svg{transition:transform .3s var(--ease-out)}
.case__nav-btn--close:hover{background:#fff;color:#0a0a0a;transform:rotate(90deg)}
.case__nav-btn[disabled]{opacity:.3;cursor:not-allowed;pointer-events:none}

/* ========== KEN BURNS HERO ========== */
.case__hero--kb{position:relative;overflow:hidden}
.case__hero--kb img{
  transform:scale(1.02);
  animation:kenburns 22s ease-in-out infinite alternate;
  transition:opacity .3s;
}
@keyframes kenburns{
  0%{transform:scale(1) translate(0,0)}
  100%{transform:scale(1.05) translate(-.6%,-.8%)}
}

/* ========== PANEL FADE ON CASE CHANGE ========== */
.case__panel{opacity:0;transition:opacity .4s var(--ease)}
.case__panel.is-ready{opacity:1}

/* ========== STAGGER ANIMATION TILES ========== */
.case__tile{
  opacity:0;transform:translateY(18px);
  animation:tileIn .55s var(--ease-out) forwards;
  animation-delay:calc(var(--i,0) * 50ms + 100ms);
}
@keyframes tileIn{
  to{opacity:1;transform:translateY(0)}
}

/* ========== CLICKABLE TILE (is-click) ========== */
.case__tile.is-click{cursor:pointer}
.case__tile.is-click:hover img{transform:scale(1.05)}
.case__tile.is-click img{transition:transform .6s var(--ease-out)}
.case__tile-zoom{
  position:absolute;top:12px;right:12px;z-index:2;
  width:34px;height:34px;border-radius:50%;
  background:rgba(10,10,10,.6);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;font-size:15px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(-6px);
  transition:opacity .3s,transform .3s;
}
.case__tile.is-click:hover .case__tile-zoom{opacity:1;transform:translateY(0)}

/* ========== JUMP TO NEXT CASE ========== */
.case__jump{
  max-width:1400px;margin:80px auto 0;
  padding-top:40px;border-top:1px solid rgba(255,255,255,.08);
}
.case__jump .eyebrow{margin-bottom:14px;opacity:.6}
.case__jump-btn{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:30px 36px;
  background:linear-gradient(180deg,rgba(245,222,116,.06),rgba(255,255,255,.02));
  border:1px solid rgba(245,222,116,.18);border-radius:24px;
  color:#fff;cursor:pointer;text-align:left;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;
  transition:transform .4s var(--ease),background .3s,border-color .3s;
}
.case__jump-btn:hover{
  transform:translateY(-4px);border-color:var(--yellow);
  background:linear-gradient(180deg,rgba(245,222,116,.14),rgba(245,222,116,.04));
}
.case__jump-label{
  font-size:clamp(18px,2.2vw,28px);letter-spacing:-.02em;
  line-height:1.1;
}
.case__jump-arrow{
  font-size:38px;color:var(--yellow);line-height:1;
  transition:transform .35s var(--ease-out);
}
.case__jump-btn:hover .case__jump-arrow{transform:translateX(14px)}

/* ========== LIGHTBOX ========== */
.case__lightbox{
  position:fixed;inset:0;z-index:30;
  background:rgba(5,5,7,.96);backdrop-filter:blur(20px);
  opacity:0;visibility:hidden;pointer-events:none;
  display:flex;align-items:center;justify-content:center;
  padding:70px 40px 80px;
  transition:opacity .35s var(--ease),visibility .35s;
}
.case__lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.case__lightbox img{
  max-width:100%;max-height:100%;object-fit:contain;
  border-radius:14px;box-shadow:0 40px 120px rgba(0,0,0,.6);
  transform:scale(.94);transition:transform .45s var(--ease-out);
}
.case__lightbox.is-open img{transform:scale(1)}
.case__lb-close{
  position:fixed;top:20px;right:20px;z-index:2;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(10px);transition:transform .3s,background .3s;
}
.case__lb-close:hover{background:var(--yellow);color:#0a0a0a;transform:rotate(90deg)}
.case__lb-caption{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  padding:10px 20px;border-radius:999px;
  background:rgba(10,10,10,.7);backdrop-filter:blur(10px);
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  color:#fff;border:1px solid rgba(255,255,255,.1);
  max-width:80%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* ========== MOBILE RESPONSIVE FOR NEW SECTIONS ========== */
@media (max-width:900px){
  .stats-strip{padding:40px 18px}
  .stats-strip__inner{grid-template-columns:repeat(2,1fr);gap:28px 20px}
  .process-tl{padding:0 18px;margin-top:80px}
  .process-tl__line{grid-template-columns:1fr;gap:30px;margin-top:28px}
  .process-tl__line::before{display:none}
  .process-tl__step{padding:22px 18px;border-right:0!important;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.02)}
  .pillars{padding:0 18px;margin-top:80px}
  .pillars__grid{grid-template-columns:1fr;gap:10px;margin-top:28px}
  .pillar{padding:28px 22px}
  .brands-mq{padding:40px 0;margin-top:70px}
  .svc-hero__scroll{bottom:18px}

  /* Case modal mobile */
  .case__topbar{padding:12px 14px}
  .case__counter-label{display:none}
  .case__nav-btn{width:40px;height:40px}
  .case__jump-btn{padding:22px 22px;flex-direction:column;gap:14px;align-items:flex-start}
  .case__jump-arrow{font-size:30px}
  .case__lightbox{padding:60px 18px 70px}
  .case__lb-close{top:14px;right:14px;width:42px;height:42px}
  .case__lb-caption{bottom:14px;font-size:11px;letter-spacing:.1em}
  .case__lb-info{padding:20px 14px}
  .case__lb-info-detail{grid-template-columns:1fr;gap:10px}
  .case__hero{margin:14px auto 34px;border-radius:16px}
  .case__tile-outline-num{font-size:clamp(80px,18vw,120px)}
  .case__tile-wip-title{font-size:13px}
  .case__tile-wip-style{font-size:9px}
}

/* ========== SVC-SHOW · single big video + full paragraph ========== */
.svc-show{
  padding:0 28px;margin-top:100px;
  max-width:1500px;margin-left:auto;margin-right:auto;
}
.svc-show__head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:30px;flex-wrap:wrap;margin-bottom:34px;
}
.svc-show__head h2{
  font-size:clamp(48px,7vw,108px);font-weight:800;
  letter-spacing:-.04em;line-height:.9;margin-top:12px;
}
.svc-show__head p.muted{
  font-size:14px;max-width:460px;margin-top:10px;
  line-height:1.5;opacity:.7;
}

/* Big video area — same size as old vplayer stage (kept BIG per user req) */
.svc-show__stage{
  position:relative;width:100%;aspect-ratio:16/9;
  border-radius:26px;overflow:hidden;
  box-shadow:0 80px 140px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.06);
  background:#0a0a0a;isolation:isolate;
}
.svc-show__video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.svc-show__scrim{
  position:absolute;inset:0;pointer-events:none;z-index:1;
  background:
    linear-gradient(180deg,transparent 50%,rgba(0,0,0,.55) 85%,rgba(0,0,0,.92) 100%),
    linear-gradient(90deg,rgba(0,0,0,.35) 0%,transparent 45%);
}
.svc-show__sound{
  position:absolute;top:22px;right:22px;z-index:3;
  width:46px;height:46px;border-radius:50%;
  background:rgba(10,10,10,.55);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.18);color:#fff;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .25s,transform .25s,border-color .25s;
}
.svc-show__sound:hover{background:var(--yellow);color:#0a0a0a;border-color:var(--yellow);transform:scale(1.08)}
.svc-show__badge{
  position:absolute;left:22px;bottom:22px;z-index:3;
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:800;
  color:var(--yellow);
  padding:8px 14px;border-radius:999px;
  background:rgba(10,10,10,.6);backdrop-filter:blur(10px);
  border:1px solid rgba(245,222,116,.25);
}
.svc-show__badge::before{
  content:"";width:7px;height:7px;border-radius:50%;background:#ff3b3b;
  box-shadow:0 0 10px rgba(255,59,59,.7);
  animation:recDot 1.4s ease-in-out infinite;
}

/* Copy block below the video — long paragraph of everything */
.svc-show__copy{
  max-width:980px;margin:56px auto 0;text-align:left;
  padding:0 4px;
}
.svc-show__eyebrow{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:800;
  color:var(--yellow);margin-bottom:18px;
  display:inline-block;padding:8px 14px;border-radius:999px;
  background:rgba(245,222,116,.1);border:1px solid rgba(245,222,116,.22);
}
.svc-show__copy p{
  font-size:clamp(17px,1.5vw,21px);line-height:1.65;
  color:rgba(255,255,255,.9);
  margin-bottom:22px;
}
.svc-show__copy p em{color:var(--yellow);font-style:italic;font-family:'Instrument Serif',serif;font-size:1.08em}
.svc-show__copy strong{color:#fff;font-weight:700}

.svc-show__pills{
  list-style:none;padding:0;margin:30px 0 36px;
  display:flex;flex-wrap:wrap;gap:8px;
}
.svc-show__pills li{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  padding:9px 14px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  color:#fff;
}

.svc-show__ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.svc-show__ctas .btn{padding:14px 24px}

@media (max-width:900px){
  .svc-show{padding:0 16px;margin-top:60px}
  .svc-show__stage{aspect-ratio:4/5;border-radius:18px}
  .svc-show__head{margin-bottom:22px}
  .svc-show__head h2{font-size:clamp(40px,10vw,70px)}
  .svc-show__copy{margin-top:36px}
  .svc-show__copy p{font-size:16px;line-height:1.6}
  .svc-show__sound{top:14px;right:14px;width:40px;height:40px}
  .svc-show__badge{left:14px;bottom:14px;font-size:10px;padding:6px 10px}
}
