/* ══════════════════════════════════════════════════
   TBL DIGITAL — FINAL CSS v4
   Lavender · Violet · Off-white · Near-black
   Native scroll — ZERO lag
══════════════════════════════════════════════════ */

:root {
  --bg:       #f4f2f7;
  --bg2:      #edeaf4;
  --dark:     #0d0d1a;
  --dark2:    #161628;
  --teal:     #6abfad;
  --teal-d:   #3d8f7c;
  --pu-a:     #c9a8e8;
  --pu-b:     #a78bd4;
  --pu-c:     #8b6bc4;
  --pink:     #e8a8c9;
  --slate:    #8bafc4;
  --pill-bg:  rgba(106,191,173,.12);
  --pill-bd:  rgba(106,191,173,.35);
  --pill-tx:  #3d8f7c;
  --grad:     linear-gradient(135deg,#e8a8c9 0%,#c9a8e8 25%,#a78bd4 55%,#8bafc4 80%,#6abfad 100%);
  --e:        cubic-bezier(.16,1,.3,1);
  --e2:       cubic-bezier(.76,0,.24,1);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--dark);
  font-family:'DM Sans',sans-serif; font-weight:300;
  overflow-x:hidden; cursor:none;
  -webkit-font-smoothing:antialiased;
}
img,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font-family:inherit; }

/* ── CURSOR + SPARKLES ─────────────────────── */
#sparkle-canvas {
  position:fixed; inset:0; z-index:9997;
  pointer-events:none; width:100%; height:100%;
}
.tbl-cursor { position:fixed; top:0; left:0; pointer-events:none; z-index:9999; }
.cur-dot {
  width:10px; height:10px; border-radius:50%; background:var(--dark);
  position:absolute; transform:translate(-50%,-50%);
  transition:width .2s var(--e),height .2s var(--e),background .2s;
}
.cur-ring {
  width:42px; height:42px; border-radius:50%;
  border:1.5px solid rgba(13,13,26,.2);
  position:absolute; transform:translate(-50%,-50%);
  transition:width .45s var(--e),height .45s var(--e),border-color .3s;
}
.cur-label {
  position:absolute; transform:translate(-50%,-50%);
  background:var(--dark); color:var(--bg);
  font-family:'Space Mono',monospace; font-size:11px;
  padding:6px 14px; border-radius:100px;
  opacity:0; white-space:nowrap; transition:opacity .25s;
}
.tbl-cursor.hov .cur-dot { width:6px; height:6px; }
.tbl-cursor.hov .cur-ring { width:60px; height:60px; border-color:var(--teal); }
.tbl-cursor.lbl .cur-dot { opacity:0; }
.tbl-cursor.lbl .cur-ring { opacity:0; }
.tbl-cursor.lbl .cur-label { opacity:1; }

/* ── PAGE TRANSITION ─────────────────────────── */
.page-trans { position:fixed; inset:0; z-index:9998; pointer-events:none; }
.pt-bar { position:absolute; inset:0; background:var(--dark); transform:scaleY(0); transform-origin:bottom; will-change:transform; }
.pt-logo {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:'Bebas Neue',sans-serif; font-size:72px; color:var(--bg); opacity:0;
}
.pt-logo span { color:var(--teal); }

/* ── HEADER ──────────────────────────────────── */
.site-header {
  position:fixed; top:0; left:0; right:0; z-index:500;
}
.hdr-inner {
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 48px;
  transition:padding .35s var(--e), background .35s, backdrop-filter .35s, border-color .35s;
}
.site-header.scrolled .hdr-inner {
  padding:13px 48px;
  background:rgba(244,242,247,.92);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(13,13,26,.06);
}
.logo-t { font-family:'Bebas Neue',sans-serif; font-size:28px; letter-spacing:.04em; color:var(--dark); }
.logo-dot { color:var(--teal); }
.nav-list { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-link {
  display:block; padding:7px 15px; font-size:12.5px; letter-spacing:.05em;
  color:rgba(13,13,26,.55); transition:color .2s; position:relative; overflow:hidden;
}
.nav-link::after { content:''; position:absolute; bottom:4px; left:15px; right:15px; height:1px; background:var(--dark); transform:scaleX(0); transform-origin:right; transition:transform .3s var(--e); }
.nav-link:hover { color:var(--dark); }
.nav-link:hover::after { transform:scaleX(1); transform-origin:left; }
.hdr-right { display:flex; align-items:center; gap:14px; }
.hdr-cta {
  display:inline-flex; align-items:center; gap:7px;
  background:var(--dark); color:var(--bg);
  padding:10px 20px; border-radius:100px;
  font-size:12px; letter-spacing:.07em; text-transform:uppercase;
  transition:background .25s;
}
.hdr-cta:hover { background:var(--teal-d); }
.burger { display:none; flex-direction:column; gap:5px; padding:8px; }
.burger span { display:block; width:22px; height:1.5px; background:var(--dark); transition:transform .3s,opacity .3s; }
.burger.active span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.burger.active span:nth-child(2) { opacity:0; }
.mob-menu { position:fixed; inset:0; z-index:490; background:var(--dark); transform:translateY(-100%); transition:transform .55s var(--e); display:flex; align-items:center; justify-content:center; }
.mob-menu.open { transform:translateY(0); }
.mob-nav { display:flex; flex-direction:column; gap:4px; margin-bottom:48px; }
.mob-link { font-family:'Bebas Neue',sans-serif; font-size:clamp(40px,9vw,72px); color:rgba(244,242,247,.15); transition:color .25s,transform .25s; display:block; line-height:1; }
.mob-link:hover { color:var(--bg); transform:translateX(8px); }
.mob-foot { display:flex; flex-direction:column; gap:6px; }
.mob-foot a,.mob-foot span { font-size:14px; color:rgba(244,242,247,.3); }
.mob-foot a:hover { color:var(--bg); }

/* ── LAYOUT ──────────────────────────────────── */
.wrap { max-width:1240px; margin:0 auto; padding:0 48px; }
.eyebrow {
  font-family:'Space Mono',monospace; font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--pill-tx); margin-bottom:18px; display:flex; align-items:center; gap:10px;
}
.eyebrow::before { content:''; display:block; width:18px; height:1px; background:var(--teal); }
.light-ey { color:rgba(244,242,247,.45); }
.light-ey::before { background:rgba(244,242,247,.3); }
.sh { font-family:'Bebas Neue',sans-serif; font-size:clamp(40px,6vw,80px); line-height:.92; color:var(--dark); margin-bottom:22px; }
.sh em { font-style:normal; color:var(--pu-a); }
.sh-light { color:var(--bg); }
.body-t { font-size:16px; line-height:1.75; color:rgba(13,13,26,.6); margin-bottom:22px; }

/* ── BUTTONS ─────────────────────────────────── */
.btn-glow {
  background: rgba(201,168,232,.18) !important;
  border: 1px solid rgba(201,168,232,.5) !important;
  color: #fff !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow:
    0 0 0 0 rgba(201,168,232,0),
    0 8px 32px rgba(0,0,0,.25);
  transition:
    transform .3s cubic-bezier(.16,1,.3,1),
    box-shadow .3s ease,
    background .3s ease,
    border-color .3s ease !important;
}

.btn-glow::before {
  background: linear-gradient(
    135deg,
    rgba(201,168,232,.4),
    rgba(167,139,212,.3)
  ) !important;
}

.btn-glow:hover {
  transform: translateY(-3px) !important;
  box-shadow:
    0 0 0 6px rgba(201,168,232,.1),
    0 16px 48px rgba(0,0,0,.3) !important;
  border-color: rgba(201,168,232,.8) !important;
}
.btn-glow span,.btn-glow svg,.btn-glow { position:relative; z-index:1; }
.btn-glow:hover { transform:translateY(-2px); box-shadow:0 12px 32px rgba(13,13,26,.2); }
.btn-outline-h {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(13,13,26,.2); color:var(--dark);
  padding:13px 26px; border-radius:100px; font-size:13px; letter-spacing:.07em; text-transform:uppercase;
  transition:border-color .25s,background .25s,transform .25s;
}
.btn-outline-h:hover { border-color:var(--dark); background:rgba(13,13,26,.05); transform:translateY(-2px); }
.btn-dark {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--dark); color:var(--bg);
  padding:13px 26px; border-radius:100px; font-size:13px; letter-spacing:.07em; text-transform:uppercase;
  transition:background .25s,transform .25s;
}
.btn-dark:hover { background:var(--teal-d); transform:translateY(-2px); }
.btn-outline-d {
  display:inline-flex; align-items:center; gap:7px;
  border:1px solid rgba(13,13,26,.18); color:var(--dark);
  padding:12px 22px; border-radius:100px; font-size:12px; letter-spacing:.07em; text-transform:uppercase;
  transition:all .25s;
}
.btn-outline-d:hover { border-color:var(--dark); transform:translateY(-2px); }
.btn-teal {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(106,191,173,.15); color:var(--teal);
  border:1px solid rgba(106,191,173,.3);
  padding:12px 24px; border-radius:100px; font-size:12px; letter-spacing:.07em; text-transform:uppercase;
  transition:all .25s;
}
.btn-teal:hover { background:var(--teal); color:#fff; }
.btn-glow-lg {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--bg); color:var(--dark);
  padding:18px 38px; border-radius:100px; font-size:15px; letter-spacing:.05em; text-transform:uppercase;
  transition:transform .3s var(--e),box-shadow .3s;
}
.btn-glow-lg:hover { transform:translateY(-3px); box-shadow:0 20px 48px rgba(244,242,247,.2); }
.btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid rgba(244,242,247,.2); color:rgba(244,242,247,.7);
  padding:17px 30px; border-radius:100px; font-size:14px; letter-spacing:.06em; text-transform:uppercase;
  transition:border-color .25s,color .25s;
}
.btn-ghost:hover { border-color:rgba(244,242,247,.6); color:var(--bg); }

/* ── HERO ────────────────────────────────────── */
.hero {
  height:100vh; min-height:700px; position:relative;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:140px 48px 80px; overflow:hidden;
}
#hero-gl { position:absolute; inset:0; z-index:0; pointer-events:none; }


.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  opacity: .85;
  filter: grayscale(.2) saturate(.65) brightness(.88) hue-rotate(-10deg);
  pointer-events: none;
}

.hero::before {
  content: '';
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  border: 1px solid rgba(201,168,232,.06);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  pointer-events: none;
  animation: ringPulse 8s ease-in-out infinite;
}

@keyframes ringPulse {
  0%, 100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: .6;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.08);
    opacity: 1;
  }
}
/* Floating image collage */
.hero-media-grid { position:absolute; inset:0; z-index:1; pointer-events:none; }
.hmg-item {
  position:absolute; border-radius:16px; background-size:cover; background-position:center;
  opacity:0; transition:opacity .8s var(--e);
}
.hmg-item.loaded { opacity:1; }
.hmg-1 { width:220px; height:300px; top:8%; left:2%; animation:hmgFloat 14s ease-in-out infinite; }
.hmg-2 { width:180px; height:240px; top:12%; right:3%; animation:hmgFloat 11s ease-in-out infinite; animation-delay:-4s; }
.hmg-3 { width:160px; height:210px; bottom:14%; left:5%; animation:hmgFloat 16s ease-in-out infinite; animation-delay:-8s; }
.hmg-4 { width:150px; height:200px; bottom:10%; right:6%; animation:hmgFloat 12s ease-in-out infinite; animation-delay:-2s; }
@keyframes hmgFloat {
  0%,100% { transform:translateY(0) rotate(-1deg) scale(1); }
  33%      { transform:translateY(-18px) rotate(1deg) scale(1.02); }
  66%      { transform:translateY(10px) rotate(-0.5deg) scale(0.98); }
}

/* Gradient mesh */
.hero-mesh { position:absolute; inset:0; z-index:2; pointer-events:none; }
.mesh-1 { position:absolute; width:700px; height:700px; top:-150px; left:-200px; border-radius:50%; background:radial-gradient(circle at 40% 40%,rgba(201,168,232,.38) 0%,transparent 65%); animation:meshPulse 12s ease-in-out infinite; }
.mesh-2 { position:absolute; width:550px; height:550px; top:50px; right:-180px; border-radius:50%; background:radial-gradient(circle at 60% 40%,rgba(106,191,173,.22) 0%,transparent 65%); animation:meshPulse 9s ease-in-out infinite; animation-delay:-4s; }
.mesh-3 { position:absolute; width:400px; height:400px; bottom:-100px; left:25%; border-radius:50%; background:radial-gradient(circle at 50%,rgba(232,168,201,.2) 0%,transparent 65%); animation:meshPulse 15s ease-in-out infinite; animation-delay:-8s; }
@keyframes meshPulse {
  0%,100% { transform:scale(1) translate(0,0); }
  33%      { transform:scale(1.08) translate(20px,-15px); }
  66%      { transform:scale(.94) translate(-15px,20px); }
}

/* Hero content */
.hero-content { position:relative; z-index:3; text-align:center; max-width:1100px; width:100%; }
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: rgba(201,168,232,.1);
  border: 1px solid rgba(201,168,232,.3);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: 10px 24px;
  border-radius: 100px;
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: .22em;
  color: rgba(255,255,255,.75);
  text-transform: uppercase;
  margin-bottom: 52px;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp .8s .2s cubic-bezier(.16,1,.3,1) forwards;
  box-shadow:
    0 0 40px rgba(201,168,232,.15),
    inset 0 1px 0 rgba(255,255,255,.08);
}

.hb-pulse { width:7px; height:7px; border-radius:50%; background:var(--teal); animation:bPulse 2s infinite; }
@keyframes bPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.6)} }

.hero-hl {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(64px, 11vw, 150px);
  line-height: .92;
  letter-spacing: .02em;
  user-select: none;
  margin-bottom: 36px;
  position: relative;
  z-index: 3;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-top: 60px;
}


.hl {
  display:block;
  overflow:hidden;
  color:#ffffff;
}
.hl-1 {
  display: block;
  overflow: hidden;
  color: rgba(255,255,255,.96);
  text-shadow:
    0 0 80px rgba(201,168,232,.6),
    0 4px 32px rgba(0,0,0,.45);
  opacity: 0;
  transform: translateY(90%);
  animation: charUp 1s .3s cubic-bezier(.16,1,.3,1) forwards;
  letter-spacing: -.04em;
}

.hl-grad {
  display: block;
  overflow: hidden;
  background: linear-gradient(
    135deg,
    #e8d4ff 0%,
    #c9a8e8 20%,
    #a78bd4 40%,
    #8b6bc4 60%,
    #c9a8e8 80%,
    #e8d4ff 100%
  );
  background-size: 400% 400%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation:
    lavendorShimmer 4s ease-in-out infinite alternate,
    fadeIn 1s .48s forwards;
  opacity: 0;
  -webkit-text-stroke: 0 transparent;
  filter: drop-shadow(0 0 40px rgba(201,168,232,.55));
}

.hl-3 {
  display: block;
  overflow: hidden;
  color: transparent;
  -webkit-text-stroke: 2px rgba(255,255,255,.88);
  text-shadow: none;
  letter-spacing: -.02em;
  opacity: 0;
  transform: translateY(90%);
  animation: charUp 1s .62s cubic-bezier(.16,1,.3,1) forwards;
  transition: color .4s ease, -webkit-text-stroke .4s ease;
}
.hero-content:hover .hl-3 {
  color: rgba(255,255,255,.08);
  -webkit-text-stroke: 2px rgba(255,255,255,.95);
}

@keyframes charUp { to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn  { to { opacity:1; } }
@keyframes gradAnim { 0%{background-position:0% 50%} 100%{background-position:100% 50%} }
@keyframes lavendorShimmer {
  0% {
    background-position: 0% 50%;
    filter: drop-shadow(0 0 30px rgba(201,168,232,.4));
  }
  50% {
    background-position: 100% 50%;
    filter: drop-shadow(0 0 60px rgba(167,139,212,.7));
  }
  100% {
    background-position: 200% 50%;
    filter: drop-shadow(0 0 40px rgba(201,168,232,.5));
  }
}

#hero-sub {
  font-size: 18px;
  line-height: 1.8;
  color: rgba(255,255,255,.82);
  max-width: 560px;
  margin: 0 auto 42px;
  font-weight: 300;
  letter-spacing: .01em;
  text-shadow: 0 2px 20px rgba(0,0,0,.4);
  opacity: 0;
  transform: translateY(20px);
  animation: fadeUp .9s .75s cubic-bezier(.16,1,.3,1) forwards;
  position: relative;
}

#hero-sub::before {
  content: '';
  display: block;
  width: 48px;
  height: 1.5px;
  background: linear-gradient(90deg, rgba(201,168,232,.8), transparent);
  margin: 0 auto 18px;
  border-radius: 2px;
}

#hero-btns {
  display:flex; align-items:center; gap:14px; justify-content:center; flex-wrap:wrap;
  opacity:0; animation:fadeUp .9s .9s var(--e) forwards;
}
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }

/* Hero stats */
#hero-stats {
  position:relative; z-index:3; display:flex; gap:8px; margin-top:52px; flex-wrap:wrap; justify-content:center;
  opacity:0; animation:fadeUp .9s 1.05s var(--e) forwards;
}
.hs-pill {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 14px 22px;
  border-radius: 100px;
  background: rgba(201,168,232,.08);
  border: 1px solid rgba(201,168,232,.2);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: transform .35s cubic-bezier(.16,1,.3,1), background .3s, box-shadow .3s;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.hs-pill:hover {
  transform: translateY(-6px) scale(1.06);
  background: rgba(201,168,232,.18);
  box-shadow:
    0 16px 32px rgba(0,0,0,.2),
    0 0 0 1px rgba(201,168,232,.3),
    inset 0 1px 0 rgba(255,255,255,.1);
}

.hs-num {
  font-family: 'Space Mono', monospace;
  font-size: 14px;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  line-height: 1;
  letter-spacing: .04em;
}

.hs-lbl {
  font-size: 9px;
  letter-spacing: .1em;
  color: rgba(255,255,255,.4);
  margin-top: 3px;
  text-transform: uppercase;
}
/* Scroll indicator — pure CSS */
.hero-scroll {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  z-index:3; opacity:0; animation:fadeUp .9s 1.3s var(--e) forwards;
}
.hero-scroll span { font-family:'Space Mono',monospace; font-size:9px; letter-spacing:.2em; text-transform:uppercase; opacity:.35; }
.hs-mouse { width:20px; height:30px; border:1.5px solid rgba(13,13,26,.2); border-radius:10px; position:relative; }
.hs-wheel { width:3px; height:6px; background:rgba(13,13,26,.3); border-radius:2px; position:absolute; top:5px; left:50%; transform:translateX(-50%); animation:wheelScroll 2s ease-in-out infinite; }
@keyframes wheelScroll { 0%,100%{opacity:1;transform:translateX(-50%) translateY(0)} 60%{opacity:0;transform:translateX(-50%) translateY(10px)} }

/* ── MARQUEE ─────────────────────────────────── */
.marquee-wrap {
  background: linear-gradient(90deg, #0b0b17 0%, #131326 45%, #191935 100%);
  padding: 28px 0;
  overflow: hidden;
  border-top: 1px solid rgba(201,168,232,.08);
  border-bottom: 1px solid rgba(201,168,232,.08);
}
.mq-track { display:flex; gap:0; white-space:nowrap; animation:mRoll 26s linear infinite; }
.mq-track:hover { animation-play-state:paused; }
.mq-track span {
  display:inline-flex;
  align-items:center;
  gap:18px;
  padding:0 34px;
  font-family:'Bebas Neue',sans-serif;
  font-size:26px;
  letter-spacing:.08em;
  color:rgba(201,168,232,.18);
  transition:color .3s ease, transform .3s ease;
}

.mq-track span:hover {
  color: rgba(255,255,255,.72);
  transform: translateY(-2px);
}
.mq-track i { color:var(--teal); opacity:.7; font-style:normal; font-size:13px; }
@keyframes mRoll { from{transform:translateX(0)} to{transform:translateX(-33.33%)} }


.btn-cta-float {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 30px;
  border-radius: 999px;
  background: rgba(201,168,232,.14);
  border: 1px solid rgba(201,168,232,.28);
  color: #fff;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  backdrop-filter: blur(18px);
  transition: all .35s ease;
  position: relative;
  overflow: hidden;
}

.btn-cta-float::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(201,168,232,.3), rgba(106,191,173,.22));
  opacity: 0;
  transition: opacity .35s ease;
}

.btn-cta-float span {
  position: relative;
  z-index: 2;
}

.btn-cta-float:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
}

.btn-cta-float:hover::before {
  opacity: 1;
}

/* ── SECTIONS ────────────────────────────────── */
.s-intro,.s-industries {
  padding: 180px 0 120px;
  position: relative;
  z-index: 1;
  background: var(--bg);
}
.s-process {
  background: var(--dark);
  padding: 180px 0 140px;
  position: relative;
  z-index: 3;
}
.home-about-premium {
  position: relative;
  padding: 180px 0 140px;
  background: linear-gradient(180deg, #f4f2f7 0%, #efeaf5 100%);
  overflow: hidden;
}

.about-bg-glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  pointer-events: none;
}

.about-glow-1 {
  width: 420px;
  height: 420px;
  background: rgba(201,168,232,.16);
  top: 60px;
  left: -120px;
}

.about-glow-2 {
  width: 380px;
  height: 380px;
  background: rgba(106,191,173,.12);
  bottom: -100px;
  right: -80px;
}

.about-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 80px;
  align-items: center;
}

.about-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(13,13,26,.42);
  margin-bottom: 26px;
}

.about-eyebrow::before {
  content: '';
  width: 28px;
  height: 1px;
  background: var(--pu-a);
}

.about-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(72px, 8vw, 130px);
  line-height: .88;
  letter-spacing: -.04em;
  color: #111;
  margin-bottom: 28px;
}

.about-title span {
  color: var(--pu-a);
}

.about-text {
  max-width: 560px;
  font-size: 20px;
  line-height: 1.9;
  color: rgba(13,13,26,.58);
  margin-bottom: 42px;
}

.about-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 34px;
}

.about-stat-card {
  padding: 24px;
  border-radius: 24px;
  background: rgba(255,255,255,.52);
  border: 1px solid rgba(201,168,232,.16);
  backdrop-filter: blur(18px);
  box-shadow: 0 20px 40px rgba(10,10,30,.05);
}

.about-stat-card strong {
  display: block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 48px;
  line-height: .9;
  color: #111;
  margin-bottom: 8px;
}

.about-stat-card span {
  font-size: 13px;
  color: rgba(13,13,26,.5);
}

.about-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 40px;
}

.about-tags span {
  padding: 10px 18px;
  border-radius: 999px;
  background: rgba(201,168,232,.1);
  border: 1px solid rgba(201,168,232,.18);
  color: #6d5a88;
  font-size: 13px;
  letter-spacing: .04em;
}

.about-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

.btn-outline-light {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 24px;
  border-radius: 999px;
  border: 1px solid rgba(13,13,26,.14);
  color: #111;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: all .3s ease;
}

.btn-outline-light:hover {
  background: #111;
  color: #fff;
  transform: translateY(-3px);
}

.about-video-wrap {
  position: relative;
  height: 720px;
  border-radius: 38px;
  overflow: hidden;
  background: #111;
  box-shadow: 0 40px 80px rgba(10,10,30,.12);
}

.about-video-wrap video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-video-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(13,13,26,.72), rgba(13,13,26,.18)),
    linear-gradient(to right, rgba(201,168,232,.14), transparent);
}

.about-floating-card {
  position: absolute;
  padding: 14px 20px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(20px);
  color: #fff;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.about-card-top {
  top: 28px;
  left: 28px;
}

.about-card-bottom {
  left: 28px;
  bottom: 28px;
  max-width: 320px;
  line-height: 1.7;
}

.about-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 20px;
}

.about-mini-card {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.56);
  border: 1px solid rgba(201,168,232,.16);
  backdrop-filter: blur(18px);
}

.about-mini-card h4 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 28px;
  letter-spacing: .04em;
  color: var(--pu-a);
  margin-bottom: 10px;
}

.about-mini-card p {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(13,13,26,.55);
}

@media (max-width: 1100px) {
  .about-inner {
    grid-template-columns: 1fr;
    gap: 50px;
  }

  .about-video-wrap {
    height: 560px;
  }
}

@media (max-width: 768px) {
  .home-about-premium {
    padding: 110px 0 90px;
  }

  .about-title {
    font-size: clamp(54px, 14vw, 90px);
  }

  .about-text {
    font-size: 17px;
  }

  .about-stats,
  .about-mini-grid {
    grid-template-columns: 1fr;
  }

  .about-video-wrap {
    height: 420px;
    border-radius: 28px;
  }
}
.work-carousel-wrap {
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 22px;
}

.work-slide h3 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(48px, 5vw, 78px);
  line-height: .9;
  letter-spacing: -.03em;
  color: #fff;
  margin-bottom: 16px;
}

.work-slide p {
  font-size: 18px;
  line-height: 1.8;
  color: rgba(255,255,255,.72);
  max-width: 440px;
  margin-bottom: 22px;
}

.work-slide-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--pu-a);
}

.work-carousel-progress {
  width: 100%;
  height: 4px;
  background: rgba(13,13,26,.08);
  border-radius: 999px;
  margin-top: 30px;
  overflow: hidden;
}

.work-carousel-progress-fill {
  width: 25%;
  height: 100%;
  background: linear-gradient(90deg, var(--pu-a), var(--teal));
  border-radius: 999px;
  transition: transform .8s ease;
}

@media (max-width: 991px) {
  .work-carousel-head {
    grid-template-columns: 1fr;
  }

  .work-slide,
  .work-slide.active {
    min-width: 88vw;
    height: 520px;
  }

  .work-slide h3 {
    font-size: 52px;
  }
}
/* Services pin */
.s-services-pin {
  position: relative;
  height: 900vh;
  background: var(--dark);
  z-index: 5;
}
.svc-sticky {
  position:sticky;
  top:0;
  height:100vh;
  display:grid;
  grid-template-columns:360px 1fr;
  background:var(--dark);
  overflow:visible;
  transform:scale(.92);
  transform-origin:center center;
  will-change:transform;
  border-radius:0;
}
.svc-sticky::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 70% 35%, rgba(201,168,232,.14), transparent 40%),
    radial-gradient(circle at 30% 70%, rgba(106,191,173,.10), transparent 35%);
  pointer-events: none;
  z-index: 1;
}

.svc-right::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(13,13,26,.08), rgba(13,13,26,.45));
  z-index: 1;
  pointer-events: none;
}

.svc-left,
.svc-right {
  position:relative;
  z-index:2;
}

.svc-right {
  overflow:hidden;
}

.svc-sticky::before {
  content:'';
  position:absolute;
  inset:0;
  background:var(--dark);
  z-index:0;
}


.site-header {
  transition:
    transform .5s ease,
    opacity .4s ease,
    background .35s ease;
}

body.hide-header-services .site-header {
  transform:translateY(-120%);
  opacity:0;
  pointer-events:none;
}

.hero-active .site-header {
  transform:translateY(-120%);
  opacity:0;
  pointer-events:none;
}
.s-services-pin.in-view .svc-sticky {
  transform:scale(1.02);
}
.svc-left { padding:72px 48px; display:flex; flex-direction:column; justify-content:center; border-right:1px solid rgba(244,242,247,.06); position:relative; z-index:2; }
.svc-left .sh { font-size:clamp(30px,3.5vw,48px); margin-bottom:14px; }
.svc-sub { color:rgba(244,242,247,.4); font-size:14px; line-height:1.7; margin-bottom:24px; }
.svc-prog { margin-top:auto; display:flex; align-items:center; gap:12px; padding-top:36px; }
.svc-bar { flex:1; height:2px; background:rgba(244,242,247,.1); border-radius:2px; overflow:hidden; }
.svc-fill { height:100%; background:var(--teal); border-radius:2px; width:12.5%; transition:width .4s var(--e); }
#svc-ctr { font-family:'Space Mono',monospace; font-size:11px; color:rgba(244,242,247,.3); letter-spacing:.08em; white-space:nowrap; }
.svc-right { position:relative; overflow:hidden; }
.svc-item {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  opacity: 0;
  transform: translateY(180px) scale(.92) rotateX(10deg);
  transition:
    opacity .9s cubic-bezier(.16,1,.3,1),
    transform 1s cubic-bezier(.16,1,.3,1),
    filter .9s ease;
  pointer-events: none;
  filter: blur(12px);
}

.svc-item.active {
  opacity: 1;
  transform: translateY(0) scale(1) rotateX(0deg);
  pointer-events: auto;
  filter: blur(0);
}

.svc-item.exit {
  opacity: 0;
  transform: translateY(-180px) scale(.9) rotateX(-10deg);
  filter: blur(10px);
}

.svc-bg {
  position: absolute;
  inset: -4%;
  background-size: cover;
  background-position: center;
  opacity: .08;
  transform: scale(1.18);
  filter: blur(4px);
  transition:
    transform 1.6s cubic-bezier(.16,1,.3,1),
    opacity 1s ease,
    filter 1.2s ease;
}

.svc-item.active .svc-bg {
  opacity: .22;
  transform: scale(1);
  filter: blur(0);
}

.svc-content {
  position: relative;
  z-index: 3;
  max-width: 720px;
  padding: 80px 90px;
}

.svc-content::before {
  content: '';
  position: absolute;
  top: 30px;
  left: 30px;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(201,168,232,.18) 0%, transparent 70%);
  filter: blur(20px);
  z-index: -1;
}

.svc-icon {
  width: 86px;
  height: 86px;
  border-radius: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,232,.18);
  backdrop-filter: blur(16px);
  font-size: 34px;
  margin-bottom: 26px;
  box-shadow: 0 10px 40px rgba(0,0,0,.18);
  transform: rotate(-6deg);
  transition: transform .4s ease;
}

.svc-item.active .svc-icon {
  transform: rotate(0deg) scale(1.04);
}

.svc-num {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: .24em;
  color: rgba(201,168,232,.45);
  margin-bottom: 18px;
}

.svc-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(72px, 8vw, 120px);
  line-height: .88;
  letter-spacing: -.03em;
color: var(--lavender-main);
  margin-bottom: 26px;
  text-shadow: 0 0 30px rgba(201,168,232,.12);
}
.svc-item h3,
.svc-item .title,
.svc-item .service-title {
  color: var(--lavender-main);
  text-shadow: 0 0 30px rgba(201,168,232,.12);
}

.svc-desc {
  max-width: 540px;
  font-size: 21px;
  line-height: 1.8;
  color: rgba(255,255,255,.68);
  margin-bottom: 34px;
}

.svc-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,168,232,.18);
  color: #fff;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: all .35s ease;
}

.svc-link:hover {
  transform: translateY(-4px);
  background: rgba(201,168,232,.12);
  border-color: rgba(201,168,232,.35);
}


.svc-particles {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}

.svc-particles span {
  position: absolute;
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(201,168,232,.22);
  box-shadow: 0 0 18px rgba(201,168,232,.35);
  animation: floatParticle 16s linear infinite;
}

.svc-particles span:nth-child(1) {
  left: 12%;
  top: 80%;
  animation-duration: 14s;
}

.svc-particles span:nth-child(2) {
  left: 28%;
  top: 95%;
  animation-duration: 18s;
  width: 12px;
  height: 12px;
}

.svc-particles span:nth-child(3) {
  left: 52%;
  top: 88%;
  animation-duration: 20s;
}

.svc-particles span:nth-child(4) {
  left: 74%;
  top: 92%;
  animation-duration: 15s;
}

.svc-particles span:nth-child(5) {
  left: 88%;
  top: 85%;
  animation-duration: 22s;
}

@keyframes floatParticle {
  0% {
    transform: translateY(0) scale(1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  100% {
    transform: translateY(-900px) scale(1.6);
    opacity: 0;
  }
}


.industries-head {
  max-width: 1320px;
  margin: 120px auto 50px;
  padding: 0 40px;
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 60px;
  align-items: end;
  text-align: left;
}

.industries-head .eyebrow {
  display: inline-block;
  margin-bottom: 18px;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(13,13,26,.4);
}

.industries-heading {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(72px, 7vw, 120px);
  line-height: .85;
  letter-spacing: -.03em;
  color: #111;
  margin: 0;
  max-width: 760px;
}

.industries-intro {
  max-width: 560px;
  margin: 0;
  font-size: 24px;
  line-height: 1.8;
  color: rgba(13,13,26,.58);
  padding-bottom: 12px;
}

.industries-player {
  max-width: 1280px;
  margin: 40px auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.industries-main {
  display: grid;
  grid-template-columns: 560px minmax(420px, 1fr);
  gap: 56px;
  align-items: center;
  width: 100%;
}
.industry-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: 42px;
  background: linear-gradient(145deg, #f4f1f7, #ece8f1);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.8),
    0 40px 80px rgba(10,10,30,.08);
  overflow: hidden;
}

.industry-stage::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(201,168,232,.12), transparent 30%),
    radial-gradient(circle at 80% 80%, rgba(106,191,173,.10), transparent 30%);
  pointer-events: none;
}

.industry-disc {
  position: absolute;
  inset: 10%;
  border-radius: 50%;
  overflow: hidden;
  opacity: 0;
  transform: scale(.7) rotate(-16deg);
  transition:
    opacity .9s ease,
    transform 1.1s cubic-bezier(.16,1,.3,1);
  box-shadow:
    inset 0 0 40px rgba(255,255,255,.5),
    0 30px 60px rgba(0,0,0,.12);
}

.industry-disc.active {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.industry-disc img,
.industry-disc video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.industry-disc::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, transparent 0%, transparent 54%, rgba(255,255,255,.85) 58%, rgba(255,255,255,.25) 64%, transparent 68%),
    conic-gradient(
      from 0deg,
      rgba(150,220,255,.35),
      rgba(255,200,255,.45),
      rgba(180,255,220,.35),
      rgba(255,220,140,.35),
      rgba(150,220,255,.35)
    );
  mix-blend-mode: screen;
  pointer-events: none;
  z-index: 2;
}

.industry-disc::after {
  content: '';
  position: absolute;
  width: 18%;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: rgba(255,255,255,.95);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  box-shadow:
    0 0 0 8px rgba(0,0,0,.08),
    inset 0 0 12px rgba(0,0,0,.08);
  z-index: 3;
}

.industry-reflection {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 15%,
    rgba(255,255,255,.45) 40%,
    transparent 55%
  );
  transform: translateX(-140%);
  animation: discShine 4.5s linear infinite;
  z-index: 4;
}

.industry-selector {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 50px;
}

.industry-copy {
  max-width: 100%;
  padding-right: 30px;
}

.industry-desc {
  font-size: 24px;
  line-height: 1.65;
  color: rgba(13,13,26,.62);
  margin-bottom: 42px;
  max-width: 780px;
}

.industry-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(160px, 1fr));
  gap: 22px;
  margin-top: 10px;
  max-width: 820px;
}

.industry-stat {
  padding: 28px 24px;
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(255,255,255,.75), rgba(255,255,255,.45));
  border: 1px solid rgba(201,168,232,.18);
  backdrop-filter: blur(18px);
  box-shadow:
    0 18px 40px rgba(10,10,30,.06),
    inset 0 1px 0 rgba(255,255,255,.7);
  transition: all .35s ease;
}

.industry-stat:hover {
  transform: translateY(-8px);
  box-shadow:
    0 24px 50px rgba(10,10,30,.10),
    inset 0 1px 0 rgba(255,255,255,.8);
}

.industry-index {
  display: block;
  font-size: 14px;
  letter-spacing: .22em;
  color: rgba(13,13,26,.35);
  margin-bottom: 18px;
}

.industry-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(72px, 7vw, 120px);
  line-height: .88;
  letter-spacing: -.03em;
  margin-bottom: 20px;
  color: var(--lavender-main);
  text-shadow: 0 0 35px rgba(201,168,232,.15);

}

.industry-stat strong {
  display: block;
  font-family: 'Bebas Neue', sans-serif;
  font-size: 56px;
  line-height: .9;
  color: #111;
  margin-bottom: 12px;
}
.industry-stat span {
  display: block;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(13,13,26,.5);
}

@media (max-width: 991px) {
  .industries-head {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }

  .industries-heading {
    max-width: 100%;
    font-size: clamp(56px, 12vw, 90px);
  }

  .industries-intro {
    max-width: 100%;
    margin: 0 auto;
    padding-bottom: 0;
  }
}


:root {
  --lavender-main: #c9a8e8;
}
/* Industries */
.ind-pills { display:flex; flex-wrap:wrap; gap:10px; margin:24px 0 44px; }
.ind-pill { display:flex; align-items:center; gap:9px; padding:12px 22px; border-radius:100px; border:1px solid rgba(13,13,26,.1); background:#fff; font-size:13px; font-weight:300; transition:all .3s var(--e); cursor:default; }
.ind-pill:hover { background:var(--dark); color:var(--bg); border-color:var(--dark); transform:scale(1.04); }
.ind-showcase { display:grid; grid-template-columns:2fr 1fr; gap:16px; }
.ind-sc-col { display:flex; flex-direction:column; gap:16px; }
.ind-sc-img { border-radius:18px; background-size:cover; background-position:center; position:relative; overflow:hidden; }
.ind-sc-big { height:400px; }
.ind-sc-col .ind-sc-img { flex:1; min-height:180px; }
.ind-sc-label { position:absolute; bottom:16px; left:16px; background:rgba(13,13,26,.7); backdrop-filter:blur(8px); color:#fff; padding:10px 16px; border-radius:10px; }
.ind-sc-label strong { display:block; font-size:14px; font-weight:500; }
.ind-sc-label span { font-size:11px; opacity:.6; }

/* Process */
.proc-row { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid rgba(244,242,247,.08); }
.proc-step { padding:44px 28px 38px; border-right:1px solid rgba(244,242,247,.08); position:relative; overflow:hidden; transition:background .35s; }
.proc-step:last-child { border-right:none; }
.proc-step::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--teal); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--e); }
.proc-step:hover { background:rgba(244,242,247,.02); }
.proc-step:hover::before { transform:scaleX(1); }
.ps-n { font-family:'Space Mono',monospace; font-size:11px; letter-spacing:.15em; color:var(--teal); margin-bottom:24px; }
.proc-step h3 { font-family:'Bebas Neue',sans-serif; font-size:26px; color:var(--bg); margin-bottom:12px; }
.proc-step p { font-size:14px; line-height:1.7; color:rgba(244,242,247,.4); }

/* CTA */
.s-cta { background:var(--dark); padding:160px 48px; text-align:center; position:relative; overflow:hidden; }
#cta-gl { position:absolute; inset:0; pointer-events:none; z-index:0; }
.cta-bg-img { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0.04; z-index:0; }
.cta-orbs { position:absolute; inset:0; pointer-events:none; z-index:0; }
.co { position:absolute; border-radius:50%; }
.co-1 { width:600px; height:600px; top:-200px; left:-150px; background:radial-gradient(circle,rgba(201,168,232,.12) 0%,transparent 65%); animation:meshPulse 14s ease-in-out infinite; }
.co-2 { width:500px; height:500px; bottom:-150px; right:-100px; background:radial-gradient(circle,rgba(106,191,173,.09) 0%,transparent 65%); animation:meshPulse 11s ease-in-out infinite; animation-delay:-5s; }
.co-3 { width:350px; height:350px; top:40%; left:55%; background:radial-gradient(circle,rgba(232,168,201,.08) 0%,transparent 65%); animation:meshPulse 18s ease-in-out infinite; animation-delay:-9s; }
.cta-inner { position:relative; z-index:1; }
.cta-h { font-family:'Bebas Neue',sans-serif; font-size:clamp(54px,10vw,136px); line-height:.88; color:var(--bg); margin-bottom:24px; }
.grad-t { background:var(--grad); background-size:300% 300%; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:gradAnim 5s ease-in-out infinite alternate; }
.cta-sub { font-size:17px; color:rgba(244,242,247,.45); max-width:400px; margin:0 auto 44px; line-height:1.7; }
.cta-btns { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:24px; }
.cta-email { font-family:'Space Mono',monospace; font-size:13px; letter-spacing:.06em; color:rgba(244,242,247,.2); transition:color .25s; display:block; margin:0 auto; }
.cta-email:hover { color:var(--teal); }

/* ── SCROLL REVEAL BASE ──────────────────────── */
.reveal-h { overflow:hidden; }
.reveal-h .line-mask { display:block; overflow:hidden; line-height:.96; padding-bottom:.05em; }
.reveal-h .line-inner { display:block; transform:translateY(106%); transition:transform 1s var(--e); }
.reveal-h.in .line-inner { transform:translateY(0); }

.reveal-p { opacity:0; transform:translateY(32px); transition:opacity .8s var(--e),transform .8s var(--e); transition-delay:var(--d,0s); }
.reveal-p.in { opacity:1; transform:translateY(0); }

#site-footer {
  position: relative;
  background: #070711;
  overflow: hidden;
  padding: 70px 0 24px;
  color: rgba(255,255,255,.72);
}

#site-footer::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(201,168,232,.10), transparent 35%),
    radial-gradient(circle at 85% 80%, rgba(106,191,173,.06), transparent 35%);
  pointer-events: none;
}

.footer-wrap {
  position: relative;
  z-index: 2;
  width: min(1320px, calc(100% - 64px));
  margin: 0 auto;
}

.footer-top {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 80px;
  align-items: start;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.ft-brand {
  max-width: 280px;
}

.ft-logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 52px;
  line-height: .9;
  color: #fff;
  letter-spacing: -.02em;
}

.ft-logo span {
  color: var(--pu-a);
}

.ft-tag {
  margin-top: 10px;
  margin-bottom: 22px;
  color: rgba(255,255,255,.5);
  font-size: 15px;
  line-height: 1.6;
  max-width: 220px;
}

.ft-socials {
  display: flex;
  gap: 10px;
}

.ft-soc {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.58);
  transition: all .3s ease;
}

.ft-soc:hover {
  color: #fff;
  border-color: rgba(201,168,232,.28);
  background: rgba(201,168,232,.12);
  transform: translateY(-3px);
}

.ft-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 50px;
}

.ft-col h4 {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--pu-a);
  margin-bottom: 18px;
}

.ft-col a {
  display: block;
  margin-bottom: 10px;
  color: rgba(255,255,255,.5);
  font-size: 14px;
  line-height: 1.6;
  transition: all .3s ease;
}

.ft-col a:hover {
  color: #fff;
  transform: translateX(4px);
}

.ft-marquee {
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 18px 0;
  margin: 28px 0 20px;
  overflow: hidden;
}

.ftm-track {
  display: flex;
  width: max-content;
  animation: footerMarquee 30s linear infinite;
}

.ftm-track span {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 22px;
  letter-spacing: .08em;
  color: rgba(201,168,232,.14);
  margin-right: 26px;
  white-space: nowrap;
}

.ftm-track em {
  color: rgba(106,191,173,.35);
  font-style: normal;
  margin-left: 10px;
}

.ft-bottom {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  color: rgba(255,255,255,.35);
  font-size: 13px;
}

@keyframes footerMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
/* ── PAGE HERO (inner pages) ─────────────────── */
.page-hero { padding:180px 0 100px; position:relative; overflow:hidden; background:var(--bg); }
.ph-bg-text { position:absolute; bottom:-20px; left:48px; font-family:'Bebas Neue',sans-serif; font-size:clamp(120px,20vw,280px); color:rgba(13,13,26,.04); pointer-events:none; user-select:none; white-space:nowrap; }
.page-hero-title { font-family:'Bebas Neue',sans-serif; font-size:clamp(60px,9vw,120px); line-height:.88; color:var(--dark); margin-bottom:18px; }
#hero-sub {
  font-size: 22px;
  line-height: 1.75;
  color: rgba(255,255,255,.88);
  max-width: 760px;
  margin: 0 auto 42px;
  font-weight: 400;
  text-shadow: 0 4px 24px rgba(0,0,0,.28);
}
/* ── PORTFOLIO ───────────────────────────────── */
.portfolio-filter-section { padding:28px 0; border-bottom:1px solid rgba(13,13,26,.06); }
.pf-bar { display:flex; gap:7px; flex-wrap:wrap; }
.pf-btn { padding:8px 18px; border-radius:100px; border:1px solid rgba(13,13,26,.12); font-size:12px; color:rgba(13,13,26,.5); background:transparent; transition:all .22s; cursor:pointer; }
.pf-btn:hover,.pf-btn.active { background:var(--dark); color:var(--bg); border-color:var(--dark); }
.portfolio-masonry { display:grid; grid-template-columns:repeat(12,1fr); gap:18px; padding:0 48px; max-width:1440px; margin:0 auto; }
.pf-item { border-radius:18px; overflow:hidden; }
.pf-item--hero { grid-column:span 12; }
.pf-item--half { grid-column:span 6; }
.pf-item--third { grid-column:span 4; }
.pf-link { display:block; }
.pf-img { position:relative; overflow:hidden; border-radius:14px; aspect-ratio:16/9; }
.pf-item--hero .pf-img { aspect-ratio:21/8; }
.pf-item--third .pf-img { aspect-ratio:4/3; }
.pf-img img { width:100%; height:100%; object-fit:cover; transition:transform .65s var(--e); }
.pf-placeholder { width:100%; height:100%; }
.pf-item:hover .pf-img img { transform:scale(1.05); }
.pf-hover-overlay { position:absolute; inset:0; background:rgba(13,13,26,.5); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .35s; }
.pf-item:hover .pf-hover-overlay { opacity:1; }
.pf-view-cta { font-family:'Space Mono',monospace; font-size:12px; letter-spacing:.1em; color:#fff; border:1px solid rgba(255,255,255,.3); padding:9px 20px; border-radius:100px; transform:translateY(7px); transition:transform .35s var(--e); }
.pf-item:hover .pf-view-cta { transform:translateY(0); }
.pf-meta { padding:14px 4px 6px; }
.pf-meta-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.pf-tag { font-family:'Space Mono',monospace; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:rgba(13,13,26,.4); }
.pf-year { font-size:11px; color:rgba(13,13,26,.3); }
.pf-title { font-family:'Bebas Neue',sans-serif; font-size:22px; color:var(--dark); margin-bottom:3px; }
.pf-client { font-size:13px; color:rgba(13,13,26,.45); margin-bottom:5px; }
.pf-result { display:inline-block; font-family:'Space Mono',monospace; font-size:11px; color:var(--teal-d); background:var(--pill-bg); border:1px solid var(--pill-bd); padding:3px 9px; border-radius:100px; }
.cta-strip { background:var(--bg2); }
.cs-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:20px; }
.cs-inner h2 { font-family:'Bebas Neue',sans-serif; font-size:clamp(32px,5vw,64px); color:var(--dark); }

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1100px) {
  .intro-g { grid-template-columns:1fr; gap:44px; }
  .svc-sticky { grid-template-columns:300px 1fr; }
  .footer-top { grid-template-columns:1fr; gap:44px; }
  .ind-showcase { grid-template-columns:1fr 1fr; }
  .ind-sc-big { height:300px; }
}
@media(max-width:900px) {
  .wrap { padding:0 24px; }
  .s-intro,.s-work,.s-industries { padding:80px 0; }
  .hdr-inner { padding:18px 24px; }
  .site-header.scrolled .hdr-inner { padding:12px 24px; }
  .primary-nav { display:none; }
  .burger { display:flex; }


  .s-services-pin { height:auto; }
  .svc-sticky { position:relative; height:auto; grid-template-columns:1fr; }
  .svc-left { padding:48px 24px; border-right:none; border-bottom:1px solid rgba(244,242,247,.06); }
  .svc-right { position:relative; min-height:360px; }
  .proc-row { grid-template-columns:repeat(2,1fr); }
  .portfolio-masonry { grid-template-columns:1fr; padding:0 24px; }
  .pf-item--hero,.pf-item--half,.pf-item--third { grid-column:span 1; }
  .s-cta { padding:100px 24px; }
  .footer-links-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { padding:0 24px; }
  .hero { padding:120px 24px 70px; }
  .hmg-1,.hmg-2,.hmg-3,.hmg-4,.hmg-5 { display:none; }
  .ind-showcase { grid-template-columns:1fr; }
}
@media(max-width:640px) {
  .hero-hl { font-size:clamp(56px,19vw,100px); }
  #hero-stats { gap:5px; }
  .hs-pill { padding:10px 14px; }
  .cta-btns { flex-direction:column; align-items:center; }
  .proc-row { grid-template-columns:1fr; }
  .footer-links-grid { grid-template-columns:1fr 1fr; }
}

/* ══════════════════════════════════════════════════
   FEATURED WORK v2 — iOS-style immersive carousel
══════════════════════════════════════════════════ */

.s-work-v2 {
  padding: 160px 0 100px;
  background: var(--bg);
  position: relative;
  overflow: hidden;
}

/* ── Ambient glow behind section ── */
.s-work-v2::before {
  content: '';
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(201,168,232,.12) 0%, transparent 65%);
  top: -200px;
  right: -200px;
  pointer-events: none;
}

/* ── Section header ── */
.sw2-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: flex-end;
  margin-bottom: 56px;
}

.sw2-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(60px, 7vw, 100px);
  line-height: .88;
  letter-spacing: -.03em;
  color: var(--dark);
  margin: 0;
}

.sw2-title em {
  font-style: normal;
  background: var(--grad);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradAnim 5s ease-in-out infinite alternate;
}

.sw2-right {
  padding-bottom: 8px;
}

.sw2-right p {
  font-size: 17px;
  line-height: 1.75;
  color: rgba(13,13,26,.52);
  margin-bottom: 24px;
  max-width: 400px;
}

/* ── Outer shell clips the track ── */
.sw2-carousel-outer {
  position: relative;
  padding: 0 60px;
  overflow: hidden;
}

/* ── Track ── */
.sw2-track {
  display: flex;
  gap: 22px;
  transition: transform .75s cubic-bezier(.22,1,.36,1);
  will-change: transform;
  cursor: grab;
  user-select: none;
}

.sw2-track.is-dragging {
  cursor: grabbing;
  transition: none;
}

/* ══════════════════════
   CARD
══════════════════════ */
.sw2-card {
  position: relative;
  flex-shrink: 0;
  width: 380px;
  height: 520px;
  border-radius: 28px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  background: #111;

  /* Subtle default scale */
  transform: scale(.97) translateY(6px);
  opacity: .88;
  transition:
    transform .55s cubic-bezier(.22,1,.36,1),
    opacity .5s ease,
    box-shadow .5s ease;
}

.sw2-card.is-active {
  transform: scale(1) translateY(0);
  opacity: 1;
  box-shadow:
    0 40px 80px rgba(0,0,0,.18),
    0 0 0 1px rgba(255,255,255,.08);
}

.sw2-card:hover {
  transform: scale(1.025) translateY(-8px) !important;
  opacity: 1 !important;
  box-shadow:
    0 50px 90px rgba(0,0,0,.22),
    0 0 0 1px rgba(255,255,255,.10);
}

/* ── Media ── */
.sw2-media {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.sw2-media img,
.sw2-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.22,1,.36,1);
}

.sw2-card:hover .sw2-media img,
.sw2-card:hover .sw2-media video {
  transform: scale(1.06);
}

/* Iridescent shine sweep */
.sw2-media-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 20%,
    rgba(255,255,255,.18) 48%,
    transparent 60%
  );
  transform: translateX(-120%);
  transition: transform 0s;
  z-index: 2;
  pointer-events: none;
}

.sw2-card:hover .sw2-media-shine {
  transform: translateX(120%);
  transition: transform .8s ease;
}

/* ── Gradient overlays ── */
.sw2-overlay-top {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 45%;
  background: linear-gradient(to bottom, rgba(0,0,0,.42), transparent);
  z-index: 3;
  pointer-events: none;
}

.sw2-overlay-bot {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 75%;
  background: linear-gradient(
    to top,
    rgba(0,0,0,.85) 0%,
    rgba(0,0,0,.5) 40%,
    transparent 100%
  );
  z-index: 3;
  pointer-events: none;
}

/* Accent colour tint at bottom */
.sw2-overlay-bot::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, var(--accent, #c9a8e8) 0%, transparent 55%);
  opacity: .18;
  transition: opacity .45s ease;
}

.sw2-card:hover .sw2-overlay-bot::after {
  opacity: .28;
}

/* ── Top tag ── */
.sw2-tag {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 5;
  padding: 8px 15px;
  border-radius: 999px;
  background: rgba(255,255,255,.15);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: 'Space Mono', monospace;
}

/* ── Stat badge (top-right) ── */
.sw2-stat-badge {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 5;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--accent, #c9a8e8);
  color: #fff;
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .05em;
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  transform: translateY(-2px);
  transition: transform .35s ease;
}

.sw2-card:hover .sw2-stat-badge {
  transform: translateY(-5px) scale(1.04);
}

/* ── Bottom content ── */
.sw2-content {
  position: relative;
  z-index: 5;
  padding: 28px 26px 26px;
}

.sw2-client {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent, #c9a8e8);
  margin-bottom: 8px;
}

.sw2-card-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 38px;
  line-height: .9;
  letter-spacing: -.02em;
  color: #fff;
  margin-bottom: 10px;
}

.sw2-card-desc {
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255,255,255,.68);
  margin-bottom: 18px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.sw2-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--accent, #c9a8e8);
  font-family: 'Space Mono', monospace;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .35s ease, transform .35s ease;
}

.sw2-card:hover .sw2-cta {
  opacity: 1;
  transform: translateY(0);
}

/* ── Arrow buttons ── */
.sw2-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(13,13,26,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--dark);
  box-shadow: 0 8px 28px rgba(0,0,0,.14);
  transition: all .3s ease;
  cursor: pointer;
}

.sw2-arrow:hover {
  background: var(--dark);
  color: #fff;
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 12px 36px rgba(0,0,0,.2);
}

.sw2-prev { left: 0; }
.sw2-next { right: 0; }

/* ── Dots ── */
.sw2-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 40px;
}

.sw2-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(13,13,26,.15);
  border: none;
  cursor: pointer;
  transition: all .35s ease;
}

.sw2-dot.active {
  width: 28px;
  border-radius: 999px;
  background: var(--dark);
}

/* ── Progress bar ── */
.sw2-progress-wrap {
  max-width: 320px;
  margin: 18px auto 0;
  height: 2px;
  background: rgba(13,13,26,.08);
  border-radius: 999px;
  overflow: hidden;
}

.sw2-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--pu-a), var(--teal));
  border-radius: 999px;
  width: 0%;
  transition: width .75s ease;
}

/* ── Responsive ── */
@media (max-width: 900px) {
  .sw2-head {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .sw2-carousel-outer {
    padding: 0 20px;
  }

  .sw2-card {
    width: 300px;
    height: 440px;
  }

  .sw2-arrow {
    width: 40px;
    height: 40px;
  }
}

@media (max-width: 640px) {
  .s-work-v2 {
    padding: 100px 0 70px;
  }

  .sw2-card {
    width: 78vw;
    height: 420px;
  }

  .sw2-card-title {
    font-size: 30px;
  }
}


/* ── Restaurant CTA button in header ── */
.hdr-restaurant-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  border-radius: 100px;
  border: 1px solid rgba(201,168,232,.35);
  background: rgba(201,168,232,.08);
  color: rgba(13,13,26,.75);
  font-size: 12px;
  letter-spacing: .04em;
  transition: all .3s var(--e);
  backdrop-filter: blur(10px);
  white-space: nowrap;
}

.hdr-restaurant-btn:hover {
  background: rgba(201,168,232,.22);
  border-color: var(--pu-a);
  color: var(--dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201,168,232,.2);
}

.hdr-rest-icon {
  font-size: 14px;
  line-height: 1;
}

.hdr-rest-text {
  position: relative;
}

.hdr-rest-text::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--pu-a);
  transition: width .3s var(--e);
}

.hdr-restaurant-btn:hover .hdr-rest-text::after {
  width: 100%;
}

/* Scrolled state */
.site-header.scrolled .hdr-restaurant-btn {
  border-color: rgba(13,13,26,.12);
  background: rgba(255,255,255,.6);
}

@media (max-width: 1100px) {
  .hdr-restaurant-btn { display: none; }
}


/* ══════════════════════════════════════════════════
   GLOBAL PAGE FIX — Container + Inner Page Heroes
══════════════════════════════════════════════════ */

/* Ensure container never bleeds */
.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 48px;
  width: 100%;
}

/* Section pad global */
.section-pad {
  padding: 100px 0;
}

/* ── Inner page hero base (dark version) ── */
.page-hero {
  position: relative;
  padding: 180px 0 110px;
  overflow: hidden;
}

/* Services & About hero — force dark */
.page-hero--services,
.page-hero--about {
  background: var(--dark) !important;
}

.page-hero--services .page-hero-title,
.page-hero--about .page-hero-title {
  color: var(--bg) !important;
  font-size: clamp(64px, 9vw, 130px);
  line-height: .88;
  letter-spacing: -.02em;
  margin-bottom: 18px;
}

.page-hero--services .page-hero-sub,
.page-hero--about .page-hero-sub {
  color: rgba(244,242,247,.52) !important;
  font-size: 18px;
  line-height: 1.8;
  max-width: 520px;
}

.page-hero--services .section-eyebrow {
  color: rgba(201,168,232,.6) !important;
}

.page-hero--services .section-eyebrow::before,
.page-hero--about .section-eyebrow::before {
  background: rgba(201,168,232,.45) !important;
}

.page-hero--services .ph-bg-text,
.page-hero--about .ph-bg-text {
  color: rgba(201,168,232,.05) !important;
}

/* Subtle radial glow on dark heroes */
.page-hero--services::after,
.page-hero--about::after {
  content: '';
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  top: -200px;
  right: -150px;
  background: radial-gradient(circle, rgba(201,168,232,.14), transparent 65%);
  pointer-events: none;
  z-index: 0;
  animation: meshPulse 14s ease-in-out infinite;
}

/* Grid line overlay on dark heroes */
.page-hero--services::before,
.page-hero--about::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(201,168,232,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,232,.04) 1px, transparent 1px);
  background-size: 72px 72px;
  z-index: 0;
  pointer-events: none;
}

.page-hero .container {
  position: relative;
  z-index: 2;
}

/* ── About page mission grid ── */
.am-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

.am-left .section-heading {
  font-size: clamp(44px, 5.5vw, 80px);
  line-height: .9;
}

.am-left .section-heading em {
  font-style: normal;
  color: var(--pu-a);
}

.body-text-large {
  font-size: 20px;
  line-height: 1.85;
  color: rgba(13,13,26,.62);
  margin-bottom: 18px;
}

.body-text {
  font-size: 15px;
  line-height: 1.85;
  color: rgba(13,13,26,.52);
}

/* ── Values grid ── */
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}

.value-card {
  padding: 36px 30px;
  border-radius: 24px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(201,168,232,.14);
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 36px rgba(10,10,30,.05);
  transition: transform .35s var(--e), box-shadow .35s;
  position: relative;
  overflow: hidden;
}

.value-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--pu-a);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--e);
}

.value-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgba(10,10,30,.1);
}

.value-card:hover::before {
  transform: scaleX(1);
}

.vc-icon {
  font-size: 26px;
  margin-bottom: 18px;
  display: block;
  transition: transform .3s var(--e);
}

.value-card:hover .vc-icon {
  transform: scale(1.2) rotate(10deg);
}

.value-card h3 {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 24px;
  letter-spacing: .04em;
  color: var(--dark);
  margin-bottom: 10px;
  transition: color .25s;
}

.value-card:hover h3 { color: var(--pu-b); }

.value-card p {
  font-size: 13px;
  line-height: 1.8;
  color: rgba(13,13,26,.52);
}

/* ── Stats row ── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2px;
}

.stat-card {
  padding: 44px 20px;
  text-align: center;
  border-right: 1px solid rgba(13,13,26,.06);
  transition: background .3s;
}

.stat-card:last-child { border-right: none; }
.stat-card:hover { background: rgba(201,168,232,.04); }

.sc-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(36px, 4vw, 60px);
  line-height: .9;
  color: var(--dark);
  margin-bottom: 8px;
  display: block;
}

.sc-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(13,13,26,.38);
}

/* ── Industries list ── */
.ai-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  margin-top: 44px;
}

.ai-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 12px;
  border: 1px solid rgba(244,242,247,.06);
  transition: all .3s var(--e);
  cursor: default;
}

.ai-item:hover {
  background: rgba(244,242,247,.04);
  border-color: rgba(201,168,232,.2);
  transform: translateX(6px);
}

.ai-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--teal);
  flex-shrink: 0;
}

.ai-item span:nth-child(2) {
  flex: 1;
  font-size: 15px;
  color: rgba(244,242,247,.72);
  transition: color .25s;
}

.ai-item:hover span:nth-child(2) { color: rgba(244,242,247,.95); }

.ai-arrow {
  color: rgba(244,242,247,.2);
  font-size: 16px;
  transition: all .3s var(--e);
}

.ai-item:hover .ai-arrow {
  color: var(--teal);
  transform: translateX(4px);
}

/* ── CTA Section (shared) ── */
.cta-section {
  position: relative;
  background: var(--dark);
  padding: 160px 48px;
  text-align: center;
  overflow: hidden;
}

.cta-noise {
  position: absolute;
  inset: 0;
  opacity: .03;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  pointer-events: none;
}

.cta-inner {
  position: relative;
  z-index: 2;
}

.cta-heading {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(64px, 10vw, 130px);
  line-height: .88;
  color: var(--bg);
  margin-bottom: 22px;
}

.cta-gradient {
  background: var(--grad);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradAnim 5s ease-in-out infinite alternate;
}

.cta-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

.btn-cta-large {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 18px 38px;
  border-radius: 100px;
  background: var(--bg);
  color: var(--dark);
  font-size: 14px;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: transform .3s var(--e), box-shadow .3s;
}

.btn-cta-large:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 50px rgba(244,242,247,.2);
}

.btn-ghost-light {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(244,242,247,.22);
  color: rgba(244,242,247,.72);
  padding: 17px 30px;
  border-radius: 100px;
  font-size: 13px;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: all .25s;
}

.btn-ghost-light:hover {
  border-color: rgba(244,242,247,.6);
  color: var(--bg);
}

/* ── Contact page ── */
.page-contact {
  background: var(--bg);
}

.contact-hero {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 80px;
  align-items: start;
  min-height: 100vh;
  padding: 160px 72px 100px;
  max-width: 1440px;
  margin: 0 auto;
}

.contact-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(64px, 8vw, 120px);
  line-height: .88;
  letter-spacing: -.02em;
  color: var(--dark);
  margin-bottom: 20px;
}

.contact-sub {
  font-size: 17px;
  line-height: 1.8;
  color: rgba(13,13,26,.55);
  max-width: 400px;
  margin-bottom: 44px;
}

.contact-details {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.cd-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(13,13,26,.06);
}

.cd-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(13,13,26,.35);
}

.cd-item a, .cd-item span {
  font-size: 16px;
  color: var(--dark);
  transition: color .25s;
}

.cd-item a:hover { color: var(--pu-b); }

/* Contact form */
.contact-form {
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(201,168,232,.14);
  border-radius: 28px;
  padding: 44px;
  backdrop-filter: blur(20px);
  box-shadow: 0 24px 80px rgba(10,10,30,.08);
}

.cf-row { margin-bottom: 20px; }

.cf-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.cf-group {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.cf-group label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(13,13,26,.5);
}

.cf-group input,
.cf-group select,
.cf-group textarea {
  width: 100%;
  padding: 13px 18px;
  border: 1.5px solid rgba(13,13,26,.1);
  border-radius: 12px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  background: rgba(255,255,255,.8);
  color: var(--dark);
  transition: border-color .25s, box-shadow .25s;
  outline: none;
}

.cf-group input:focus,
.cf-group select:focus,
.cf-group textarea:focus {
  border-color: var(--pu-a);
  box-shadow: 0 0 0 3px rgba(201,168,232,.15);
}

.cf-group textarea {
  resize: vertical;
  min-height: 120px;
}

/* Checkboxes */
.cf-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.cf-check {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 100px;
  border: 1.5px solid rgba(13,13,26,.1);
  cursor: pointer;
  transition: all .25s;
  font-size: 13px;
  color: rgba(13,13,26,.6);
}

.cf-check input {
  width: 14px !important;
  height: 14px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  box-shadow: none !important;
  accent-color: var(--pu-a);
}

.cf-check:hover,
.cf-check:has(input:checked) {
  border-color: var(--pu-a);
  background: rgba(201,168,232,.08);
  color: var(--dark);
}

/* Submit button */
.btn-submit {
  width: 100%;
  padding: 16px 24px;
  border-radius: 14px;
  border: none;
  background: var(--dark);
  color: var(--bg);
  font-size: 14px;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
  transition: all .35s var(--e);
  position: relative;
  overflow: hidden;
}

.btn-submit::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--pu-b);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .45s var(--e);
}

.btn-submit:hover::before { transform: scaleX(1); }
.btn-submit span { position: relative; z-index: 1; }

.btn-submit.loading {
  pointer-events: none;
  opacity: .7;
}

.cf-success {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 22px;
  border-radius: 14px;
  background: rgba(106,191,173,.1);
  border: 1px solid rgba(106,191,173,.3);
  color: var(--teal-d);
  font-size: 15px;
  font-weight: 500;
  margin-top: 16px;
}

/* ── Services detail section ── */
.services-detail-section .container {
  max-width: 1280px;
}

/* ── Section eyebrow global ── */
.section-eyebrow {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(13,13,26,.38);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.section-eyebrow::before {
  content: '';
  width: 22px;
  height: 1px;
  background: var(--pu-a);
  opacity: .6;
  flex-shrink: 0;
}

.section-eyebrow.light {
  color: rgba(244,242,247,.42);
}

.section-eyebrow.light::before {
  background: rgba(244,242,247,.3);
}

/* ── Section heading global ── */
.section-heading {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(44px, 6vw, 88px);
  line-height: .9;
  letter-spacing: -.02em;
  color: var(--dark);
  margin-bottom: 22px;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .am-grid { grid-template-columns: 1fr; gap: 48px; }
  .stats-row { grid-template-columns: repeat(3, 1fr); }
  .stat-card:nth-child(3) { border-right: none; }
  .values-grid { grid-template-columns: repeat(2, 1fr); }
  .ai-list { grid-template-columns: 1fr; }
  .contact-hero { grid-template-columns: 1fr; gap: 50px; padding: 140px 48px 80px; }
}

@media (max-width: 768px) {
  .container { padding: 0 24px; }
  .section-pad { padding: 70px 0; }
  .page-hero { padding: 130px 0 80px; }
  .page-hero-title { font-size: clamp(52px, 14vw, 90px) !important; }
  .values-grid { grid-template-columns: 1fr; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .stat-card:nth-child(2) { border-right: none; }
  .cf-row-2 { grid-template-columns: 1fr; }
  .contact-hero { padding: 130px 24px 70px; }
  .contact-form { padding: 28px 24px; }
  .cta-section { padding: 100px 24px; }
  .am-grid { gap: 36px; }
  .sdr-inner { gap: 32px; }
}

@media (max-width: 640px) {
  .stats-row { grid-template-columns: 1fr 1fr; }
  .about-industries .container { padding: 0 20px; }
}


/* ══════════════════════════════════════════════════
   OPACITY FIX — About, Services, Contact pages
   Force all content visible — animations are bonus only
══════════════════════════════════════════════════ */

/* ── Kill any reveal animations on inner pages ── */
.page-about .reveal-p,
.page-about .reveal-h,
.page-about .reveal-h .line-inner,
.page-about [data-animate],
.page-services .reveal-p,
.page-services .reveal-h,
.page-services .reveal-h .line-inner,
.page-services [data-animate],
.page-contact .reveal-p,
.page-contact .reveal-h,
.page-contact [data-animate],
.page-restaurants .reveal-p,
.page-restaurants .reveal-h,
.page-restaurants [data-animate] {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* ── Force all about page sections fully visible ── */
.page-about section,
.page-about .am-grid,
.page-about .am-left,
.page-about .am-right,
.page-about .values-grid,
.page-about .value-card,
.page-about .stats-row,
.page-about .stat-card,
.page-about .ai-list,
.page-about .ai-item,
.page-about .ab-timeline,
.page-about .ab-tl-item,
.page-about .ab-ms-card,
.page-about .ab-hero-pills,
.page-about .ab-pill,
.page-about .cta-inner,
.page-about p,
.page-about h1,
.page-about h2,
.page-about h3 {
  opacity: 1 !important;
}

/* ── Force all services page sections fully visible ── */
.page-services section,
.page-services .sdr-inner,
.page-services .sdr-left,
.page-services .sdr-right,
.page-services .sdr-title,
.page-services .sdr-desc,
.page-services .sdr-icon,
.page-services .sdr-feature-card,
.page-services .sdr-list,
.page-services .sdr-list li,
.page-services .service-detail-row,
.page-services .cta-inner,
.page-services p,
.page-services h1,
.page-services h2 {
  opacity: 1 !important;
}

/* ── Keep animations but start from visible ── */
.page-about .ab-tl-item,
.page-about .value-card,
.page-about .ab-ind-item {
  opacity: 1 !important;
  transform: none !important;
}

/* ── Services rows — visible by default, animate IN not out ── */
.service-detail-row .sdr-left,
.service-detail-row .sdr-right {
  opacity: 1 !important;
  transform: none !important;
}

/* Re-enable the hover/active state animations only */
.service-detail-row .sdr-left,
.service-detail-row .sdr-right {
  transition: transform .35s var(--e), box-shadow .35s !important;
}

/* ── Contact page ── */
.page-contact .contact-hero,
.page-contact .ch-left,
.page-contact .ch-right,
.page-contact .contact-form,
.page-contact .cf-group,
.page-contact h1,
.page-contact p {
  opacity: 1 !important;
  transform: none !important;
}

/* ── Restaurants page ── */
.page-restaurants section,
.page-restaurants .rest-journey-inner,
.page-restaurants .rest-phase,
.page-restaurants .rest-work-grid,
.page-restaurants .rest-work-item,
.page-restaurants .rest-why-card,
.page-restaurants .rest-svc-card,
.page-restaurants p,
.page-restaurants h1,
.page-restaurants h2,
.page-restaurants h3 {
  opacity: 1 !important;
}

/* But keep the why-card scroll animation working */
.page-restaurants .rest-why-card {
  opacity: 1 !important;
  transform: none !important;
  transition: transform .35s var(--e), box-shadow .35s, background .3s !important;
}

/* ── GSAP ScrollTrigger conflict fix ── */
/* Prevent GSAP from setting opacity:0 on these pages */
.page-about *,
.page-services *,
.page-contact *,
.page-restaurants * {
  will-change: auto;
}

/* ── The split-text lines — force visible ── */
.page-about .split-text .line-inner,
.page-services .split-text .line-inner,
.page-contact .split-text .line-inner {
  transform: translateY(0) !important;
  opacity: 1 !important;
}

/* ══════════════════════════════════════════════════
   GREEN HOVER SYSTEM — Veiled Vista #a8c8a8 / sage
══════════════════════════════════════════════════ */
:root {
  --green:    #a8c8a0;   /* Veiled Vista sage */
  --green-d:  #7aaa70;   /* deeper press */
  --green-glow: rgba(168,200,160,.25);
}

/* ── NAV LINKS — green on hover ── */
.nav-link::after {
  background: var(--green) !important;
}

.nav-link:hover {
  color: var(--dark) !important;
}

/* Scrolled header — same green */
.site-header.scrolled .nav-link:hover {
  color: var(--dark) !important;
}

/* Mobile nav links */
.mob-link:hover {
  color: var(--green) !important;
}

/* ── HERO BUTTONS SWAP + GREEN ── */

/* "See Our Work" / "Our Story" → now OUTLINE style */
.hero-btns .btn-glow,
.about-actions .btn-dark,
.ab-cta-btn {
  background: transparent !important;
  border: 1.5px solid rgba(13,13,26,.25) !important;
  color: rgba(255,255,255,.85) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.hero-btns .btn-glow::before,
.about-actions .btn-dark::before,
.ab-cta-btn::before {
  display: none !important;
}

.hero-btns .btn-glow:hover,
.about-actions .btn-dark:hover,
.ab-cta-btn:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 32px var(--green-glow) !important;
}

/* "Start a Project" / "Let's Talk" → now DARK FILLED style */
.hero-btns .btn-outline-h,
.about-actions .btn-outline-light,
.hdr-cta {
  background: var(--dark) !important;
  border: 1.5px solid var(--dark) !important;
  color: var(--bg) !important;
}

.hero-btns .btn-outline-h:hover,
.about-actions .btn-outline-light:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 32px var(--green-glow) !important;
}

/* Header CTA green hover */
.hdr-cta:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 8px 24px var(--green-glow) !important;
}

/* ── SERVICES SECTION BUTTONS ── */

/* "All Services" teal button → sage green */
.btn-teal {
  background: rgba(168,200,160,.12) !important;
  color: var(--green-d) !important;
  border: 1px solid rgba(168,200,160,.35) !important;
}

.btn-teal:hover {
  background: var(--green) !important;
  color: #1a2e1a !important;
  border-color: var(--green) !important;
  box-shadow: 0 10px 28px var(--green-glow) !important;
}

/* "Let's Talk" float btn in services */
.btn-cta-float {
  background: rgba(168,200,160,.1) !important;
  border: 1px solid rgba(168,200,160,.3) !important;
  color: rgba(255,255,255,.85) !important;
}

.btn-cta-float::before {
  background: linear-gradient(90deg, rgba(168,200,160,.35), rgba(120,170,110,.3)) !important;
}

.btn-cta-float:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 14px 36px var(--green-glow) !important;
}

/* ── SVC LINK inside service cards ── */
.svc-link:hover {
  background: rgba(168,200,160,.14) !important;
  border-color: rgba(168,200,160,.4) !important;
  color: var(--green) !important;
}

/* ── ALL btn-primary, btn-dark, btn-outline-d green hover ── */
.btn-primary:hover,
.btn-dark:hover {
  background: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 12px 32px var(--green-glow) !important;
}

.btn-outline-d:hover {
  border-color: var(--green) !important;
  color: var(--green-d) !important;
  background: rgba(168,200,160,.06) !important;
}

/* ── CTA large buttons ── */
.btn-cta-large:hover {
  background: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 20px 50px var(--green-glow) !important;
}

.btn-ghost:hover,
.btn-ghost-light:hover {
  border-color: var(--green) !important;
  color: var(--green) !important;
  background: rgba(168,200,160,.06) !important;
}

/* ── Portfolio explore / start project buttons ── */
.pf-hero-actions .btn-glow:hover,
.pf-cta-right .btn-glow-lg:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 16px 48px var(--green-glow) !important;
}

/* ── Restaurant page buttons ── */
.rest-hero-actions .btn-glow:hover,
.rest-cta-btns .btn-glow-lg:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
  box-shadow: 0 16px 48px var(--green-glow) !important;
}

/* ── Case study nav + back buttons ── */
.cs-back-btn:hover {
  color: var(--green) !important;
}

.cs-nav-btn:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
}

.cs-nav-btn:hover .cs-nav-dir,
.cs-nav-btn:hover .cs-nav-name {
  color: #1a2e1a !important;
}

/* ── Filter buttons on portfolio ── */
.pf-filter-btn.active,
.pf-filter-btn:hover {
  background: var(--green) !important;
  border-color: var(--green) !important;
  color: #1a2e1a !important;
}

.pf-filter-btn::before {
  background: var(--green) !important;
}

/* ── Footer links ── */
.ft-col a:hover {
  color: var(--green) !important;
}

.ft-soc:hover {
  border-color: rgba(168,200,160,.3) !important;
  background: rgba(168,200,160,.1) !important;
  color: var(--green) !important;
}

/* ── Industry thumb active ── */
.industry-thumb.active .thumb-disc {
  border: 2px solid var(--green) !important;
  box-shadow: 0 0 0 4px rgba(168,200,160,.2) !important;
}

/* ── Teal variables update ── */
.eyebrow::before { background: var(--green) !important; }

/* ── Contact form focus ── */
.cf-group input:focus,
.cf-group select:focus,
.cf-group textarea:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 3px rgba(168,200,160,.15) !important;
}

.cf-check:hover,
.cf-check:has(input:checked) {
  border-color: var(--green) !important;
  background: rgba(168,200,160,.08) !important;
}

/* ── Submit button ── */
.btn-submit::before {
  background: var(--green) !important;
}

.btn-submit:hover {
  color: #1a2e1a !important;
}

/* ── Result/pill badges keep accent color ── */
/* (these use --accent from each card, leave alone) */

/* ── Marquee gem color ── */
.mq-track i,
.ab-mq-track i,
.rest-mq-track i,
.ftm-track em {
  color: var(--green) !important;
}

/* ── Scroll indicator dot ── */
.hb-pulse,
.ab-eyebrow-pulse,
.rest-eyebrow-pulse,
.pf-eyebrow-dot {
  background: var(--green) !important;
}

/* ── Timeline dot ── */
.ab-tl-dot {
  background: var(--green) !important;
  box-shadow: 0 0 0 1px rgba(168,200,160,.4), 0 0 18px rgba(168,200,160,.3) !important;
}

/* ── Portfolio result pills ── */
.pf-result {
  color: var(--green-d) !important;
  background: rgba(168,200,160,.1) !important;
  border-color: rgba(168,200,160,.3) !important;
}

/* ── Services page list checkmark ── */
.sdr-list li::before {
  color: var(--green) !important;
}

/* Value card top border */
.value-card::before,
.ab-val-card::before {
  background: var(--green) !important;
}

/* ── Smooth transitions on all buttons ── */
.btn-glow, .btn-outline-h, .btn-dark, .btn-teal,
.btn-cta-large, .btn-ghost, .btn-ghost-light,
.btn-outline-d, .btn-cta-float, .btn-glow-lg,
.hdr-cta, .btn-primary, .btn-submit,
.ab-cta-btn, .svc-link, .rest-hero-actions a {
  transition: background .3s var(--e), border-color .3s var(--e),
              color .3s var(--e), transform .3s var(--e),
              box-shadow .3s var(--e) !important;
}


/* ══════════════════════════════════════════════════
   TBL DIGITAL — MOBILE RESPONSIVE SYSTEM
   Complete mobile overhaul for all pages
   Add at very bottom of main.css
══════════════════════════════════════════════════ */

/* ════════════════════════════════
   BREAKPOINT: 1200px — Large tablets
════════════════════════════════ */
@media (max-width: 1200px) {
  .wrap, .container { padding: 0 36px; }

  /* Hero */
  .hero-hl { font-size: clamp(56px, 9vw, 110px); }
  .hero { padding: 120px 36px 70px; }

  /* About section homepage */
  .about-inner { gap: 48px; }
  .about-title { font-size: clamp(60px, 8vw, 100px); }

  /* Services pin */
  .svc-content { padding: 60px 60px; }
  .svc-title { font-size: clamp(56px, 7vw, 100px); }

  /* Industries */
  .industries-head { padding: 0 36px; gap: 40px; }
  .industries-main { grid-template-columns: 460px 1fr; gap: 40px; }

  /* Portfolio */
  .pf-masonry { padding: 0 36px; }
  .pf-item--third { grid-column: span 6; }

  /* SW2 carousel */
  .sw2-card { width: 340px; height: 480px; }
  .sw2-carousel-outer { padding: 0 40px; }

  /* Footer */
  .footer-top { gap: 50px; }
  .ft-links { gap: 30px; }
}

/* ════════════════════════════════
   BREAKPOINT: 1024px — Tablets landscape
════════════════════════════════ */
@media (max-width: 1024px) {
  /* ── HEADER ── */
  .hdr-inner { padding: 16px 28px; }
  .site-header.scrolled .hdr-inner { padding: 12px 28px; }
  .primary-nav { display: none; }
  .burger { display: flex; }
  .hdr-restaurant-btn { display: none; }

  /* ── HERO ── */
  .hero { padding: 110px 28px 60px; min-height: 100svh; }
  .hero-hl { font-size: clamp(52px, 11vw, 100px); }
  #hero-sub { font-size: 16px; max-width: 480px; }
  .hero-media-grid { display: none; }
  #hero-stats { gap: 6px; margin-top: 36px; }
  .hs-pill { padding: 12px 16px; }
  .hs-num { font-size: 13px; }

  /* ── ABOUT HOME ── */
  .about-inner { grid-template-columns: 1fr; gap: 40px; }
  .about-video-wrap { height: 420px; }
  .about-mini-grid { grid-template-columns: repeat(3,1fr); }
  .about-stats { grid-template-columns: repeat(3,1fr); }

  /* ── SERVICES PIN ── */
  .s-services-pin { height: auto; }
  .svc-sticky {
    position: relative;
    height: auto;
    grid-template-columns: 1fr;
    transform: none !important;
  }
  .svc-left {
    padding: 52px 28px 32px;
    border-right: none;
    border-bottom: 1px solid rgba(244,242,247,.07);
  }
  .svc-right {
    position: relative;
    min-height: 420px;
    overflow: hidden;
  }
  .svc-item {
    position: relative;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    pointer-events: auto !important;
    display: none;
  }
  .svc-item.active { display: flex; }
  .svc-content { padding: 40px 28px; }
  .svc-title { font-size: clamp(44px, 8vw, 80px); }
  .svc-desc { font-size: 17px; }
  .svc-prog { display: none; }

  /* ── INDUSTRIES ── */
  .industries-head {
    grid-template-columns: 1fr;
    gap: 16px;
    text-align: center;
    margin: 80px auto 40px;
    padding: 0 28px;
  }
  .industries-heading { font-size: clamp(52px, 10vw, 80px); }
  .industries-intro { margin: 0 auto; font-size: 18px; }
  .industries-main { grid-template-columns: 1fr; gap: 32px; }
  .industry-stage { max-width: 400px; margin: 0 auto; }
  .industry-copy { padding-right: 0; }
  .industry-title { font-size: clamp(52px, 10vw, 80px); }
  .industry-meta { grid-template-columns: repeat(3,1fr); gap: 14px; }
  .industry-selector { gap: 16px; margin-top: 32px; }

  /* ── FEATURED WORK ── */
  .sw2-head { grid-template-columns: 1fr; gap: 18px; margin-bottom: 36px; }
  .sw2-title { font-size: clamp(48px, 8vw, 72px); }
  .sw2-card { width: 300px; height: 440px; }
  .sw2-carousel-outer { padding: 0 24px; }
  .sw2-arrow { width: 42px; height: 42px; }

  /* ── CTA ── */
  .s-cta { padding: 100px 28px; }
  .cta-h { font-size: clamp(52px, 10vw, 100px); }
  .cta-btns { flex-direction: column; align-items: center; gap: 10px; }

  /* ── PORTFOLIO PAGE ── */
  .pf-hero-section { padding: 120px 28px 80px; }
  .pf-hero-title { font-size: clamp(52px, 10vw, 100px); }
  .pf-masonry { padding: 0 28px; gap: 14px; }
  .pf-item--hero  { grid-column: span 12; }
  .pf-item--half  { grid-column: span 12; }
  .pf-item--third { grid-column: span 12; }
  .pf-cta-inner { grid-template-columns: 1fr; gap: 32px; }
  .pf-cta-section { padding: 80px 28px; }

  /* ── CASE STUDY ── */
  .cs-hero-content { padding: 0 28px; }
  .cs-hero-stats-bar { padding: 20px 28px; flex-wrap: wrap; }
  .cs-stat-pill { min-width: 100px; flex: 1 1 100px; }
  .cs-overview { padding: 70px 28px; }
  .cs-overview-inner { grid-template-columns: 1fr; gap: 40px; }
  .cs-results-section { padding: 80px 28px; }
  .cs-stats-grid { grid-template-columns: repeat(2,1fr); }
  .cs-body-sections { padding: 70px 28px; }
  .cs-gallery-section { padding: 60px 0; }
  .cs-gallery-grid { padding: 0 28px; grid-template-columns: repeat(2,1fr); }
  .cs-reel-section,
  .cs-site-section,
  .cs-testimonial-section { padding: 70px 28px; }
  .cs-nav-section { padding: 50px 28px; }
  .cs-nav-inner { grid-template-columns: 1fr 1fr; gap: 12px; }
  .cs-nav-all { display: none; }
  .cs-site-iframe-container { height: 500px; }

  /* ── ABOUT PAGE ── */
  .ab-hero-pills { justify-content: flex-start; }
  .ab-fs-1, .ab-fs-2, .ab-fs-3 { display: none; }
  .about-mission { padding: 80px 0; }
  .ab-mission-inner { padding: 0 28px; grid-template-columns: 1fr; gap: 40px; }
  .ab-mission-deco { display: none; }
  .ab-mission-stats { grid-template-columns: repeat(3,1fr); }
  .ab-timeline-section { padding: 80px 0; }
  .ab-timeline-inner { padding: 0 28px; }
  .ab-timeline::before { left: 56px; }
  .ab-tl-item { grid-template-columns: 56px 28px 1fr; gap: 0 16px; }
  .ab-values-section { padding: 80px 0; }
  .ab-values-inner { padding: 0 28px; }
  .ab-values-grid { grid-template-columns: repeat(2,1fr); }
  .ab-stats-section { padding: 70px 0; }
  .ab-stats-inner {
    padding: 0 28px;
    grid-template-columns: repeat(3,1fr);
  }
  .ab-stat-card:nth-child(3) { border-right: none; }
  .ab-ind-inner { padding: 0 28px; grid-template-columns: 1fr; gap: 40px; }
  .ab-cta-section { padding: 100px 28px; }

  /* ── SERVICES PAGE ── */
  .page-services .page-hero { padding: 140px 0 80px; }
  .service-detail-row { padding: 70px 0; }
  .sdr-inner { grid-template-columns: 1fr; gap: 32px; }
  .sdr-reverse .sdr-inner { direction: ltr; }
  .sdr-title { font-size: clamp(36px, 7vw, 60px); }
  .sdr-desc { max-width: 100%; }
  .sdr-feature-card { padding: 28px; }

  /* ── RESTAURANTS PAGE ── */
  .rest-hero { padding: 120px 28px 80px; }
  .rest-hero-title { font-size: clamp(56px, 10vw, 110px); }
  .rest-hero-media .rest-hero-img { display: none; }
  .rest-journey { padding: 80px 0; }
  .rest-journey-inner { padding: 0 28px; }
  .rest-phase-list { grid-template-columns: 1fr; }
  .rest-work-section { padding: 80px 0; }
  .rest-work-inner { padding: 0 28px; }
  .rest-work-grid { grid-template-columns: 1fr; }
  .rest-wi--hero, .rest-wi--half, .rest-wi--third { grid-column: span 1; }
  .rest-why-section { padding: 80px 0; }
  .rest-why-inner { padding: 0 28px; }
  .rest-why-grid { grid-template-columns: repeat(2,1fr); }
  .rest-services-section { padding: 80px 0; }
  .rest-services-inner { padding: 0 28px; }
  .rest-svc-grid { grid-template-columns: repeat(2,1fr); }
  .rest-cta-section { padding: 100px 28px; }

  /* ── FOOTER ── */
  .footer-top { grid-template-columns: 1fr; gap: 36px; }
  .ft-links { grid-template-columns: repeat(3,1fr); gap: 24px; }
  .footer-wrap { padding: 0 28px; }
}

/* ════════════════════════════════
   BREAKPOINT: 768px — Tablets portrait / large phones
════════════════════════════════ */
@media (max-width: 768px) {
  /* ── BASE ── */
  .wrap, .container { padding: 0 20px; }
  .section-pad { padding: 60px 0; }
  html { font-size: 15px; }

  /* ── HEADER ── */
  .hdr-inner { padding: 14px 20px; }
  .site-header.scrolled .hdr-inner { padding: 10px 20px; }
  .logo-t { font-size: 24px; }

  /* ── MOBILE MENU ── */
  .mob-link { font-size: clamp(36px, 10vw, 60px); }
  .mob-nav { gap: 2px; }

  /* ── HERO ── */
  .hero { padding: 100px 20px 60px; }
  .hero-hl { font-size: clamp(48px, 14vw, 80px); }
  .hl-1, .hl-3 { letter-spacing: -.02em; }
  #hero-sub { font-size: 15px; max-width: 100%; }
  #hero-btns {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
  }
  #hero-btns a { justify-content: center; text-align: center; }
  #hero-stats { flex-wrap: wrap; gap: 6px; justify-content: center; }
  .hs-pill { padding: 10px 14px; flex: 1; min-width: 120px; }
  .hero-badge { font-size: 9px; letter-spacing: .14em; padding: 8px 16px; }
  .hero-scroll { display: none; }

  /* ── MARQUEE ── */
  .mq-track span { font-size: 20px; padding: 0 22px; }
  .ab-mq-track span, .rest-mq-track span { font-size: 18px; padding: 0 20px; }

  /* ── ABOUT HOME ── */
  .home-about-premium { padding: 80px 0 60px; }
  .about-inner { padding: 0 20px; }
  .about-title { font-size: clamp(52px, 14vw, 80px); }
  .about-text { font-size: 16px; }
  .about-stats { grid-template-columns: repeat(3,1fr); gap: 10px; }
  .about-stat-card { padding: 18px 12px; }
  .about-stat-card strong { font-size: 36px; }
  .about-tags { gap: 8px; }
  .about-actions { flex-direction: column; gap: 10px; }
  .about-actions a { text-align: center; justify-content: center; }
  .about-video-wrap { height: 320px; border-radius: 22px; }
  .about-mini-grid { grid-template-columns: 1fr; gap: 10px; }
  .about-mini-card { padding: 16px; }

  /* ── SERVICES HOME ── */
  .svc-content { padding: 32px 20px; }
  .svc-title { font-size: clamp(40px, 11vw, 72px); }
  .svc-desc { font-size: 15px; }
  .svc-icon { width: 64px; height: 64px; font-size: 26px; border-radius: 20px; }
  .svc-left .sh { font-size: clamp(26px, 6vw, 40px); }
  .svc-sub { font-size: 13px; }

  /* ── INDUSTRIES HOME ── */
  .industries-head { padding: 0 20px; margin: 60px auto 32px; }
  .industries-heading { font-size: clamp(44px, 12vw, 70px); }
  .industries-intro { font-size: 16px; }
  .industries-player { padding: 0 20px; }
  .industry-stage { max-width: 300px; border-radius: 28px; }
  .industry-title { font-size: clamp(44px, 11vw, 72px); }
  .industry-desc { font-size: 16px; }
  .industry-meta { grid-template-columns: repeat(3,1fr); gap: 10px; }
  .industry-stat { padding: 18px 14px; border-radius: 18px; }
  .industry-stat strong { font-size: 36px; }

  /* ── FEATURED WORK ── */
  .s-work-v2 { padding: 80px 0 60px; }
  .sw2-head { padding: 0 20px; }
  .sw2-title { font-size: clamp(40px, 10vw, 64px); }
  .sw2-right p { font-size: 15px; }
  .sw2-card { width: 82vw; height: 400px; border-radius: 20px; }
  .sw2-card-title { font-size: 28px; }
  .sw2-card-desc { font-size: 12px; }
  .sw2-tag { font-size: 9px; }
  .sw2-stat-badge { font-size: 9px; }
  .sw2-dots { margin-top: 28px; }
  .sw2-arrow { display: none; }

  /* ── CTA HOME ── */
  .s-cta { padding: 80px 20px; }
  .cta-h { font-size: clamp(48px, 13vw, 80px); }
  .cta-sub { font-size: 15px; }
  .cta-btns { flex-direction: column; align-items: center; gap: 10px; width: 100%; }
  .btn-glow-lg, .btn-ghost { width: 100%; max-width: 320px; justify-content: center; }
  .cta-email { font-size: 12px; }

  /* ── PORTFOLIO PAGE ── */
  .pf-hero-section { padding: 100px 20px 70px; }
  .pf-hero-title { font-size: clamp(46px, 13vw, 80px); }
  .pf-hero-sub { font-size: 15px; }
  .pf-hero-actions { flex-direction: column; align-items: center; gap: 10px; }
  .pf-hero-actions a { width: 100%; max-width: 300px; justify-content: center; }
  .pf-hero-stats { gap: 6px; }
  .pf-hs-pill { padding: 10px 14px; }
  .pf-filter-section { padding: 16px 0; top: 60px; }
  .pf-filter-bar { padding: 0 20px; gap: 6px; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .pf-filter-bar::-webkit-scrollbar { display: none; }
  .pf-filter-btn { white-space: nowrap; flex-shrink: 0; padding: 7px 14px; font-size: 11px; }
  .pf-grid-section { padding: 40px 0 60px; }
  .pf-masonry { padding: 0 20px; gap: 12px; grid-template-columns: 1fr; }
  .pf-item--hero, .pf-item--half, .pf-item--third { grid-column: span 1; }
  .pf-item--hero .pf-img { aspect-ratio: 16/9; }
  .pf-item-title { font-size: 20px; }
  .pf-cta-section { padding: 60px 20px; }
  .pf-cta-inner { grid-template-columns: 1fr; gap: 24px; }
  .pf-cta-title { font-size: clamp(44px, 12vw, 70px); }

  /* ── CASE STUDY ── */
  .cs-hero { min-height: 70vh; }
  .cs-hero-content { padding: 0 20px; max-width: 100%; }
  .cs-hero-title { font-size: clamp(44px, 11vw, 80px); }
  .cs-hero-tagline { font-size: 16px; }
  .cs-hero-stats-bar { padding: 16px 20px; gap: 8px; }
  .cs-stat-pill { padding: 12px 14px; min-width: 80px; }
  .cs-stat-pill strong { font-size: 22px; }
  .cs-stat-pill span { font-size: 9px; }
  .cs-overview { padding: 60px 20px; }
  .cs-narrative-block p { font-size: 16px; }
  .cs-results-section { padding: 60px 20px; }
  .cs-section-title { font-size: clamp(40px, 10vw, 72px); }
  .cs-stats-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .cs-stat-card { padding: 28px 20px; border-radius: 18px; }
  .cs-stat-value { font-size: clamp(40px, 9vw, 64px); }
  .cs-body-sections { padding: 60px 20px; }
  .cs-body-block { grid-template-columns: 1fr; gap: 8px; }
  .cs-body-num { padding: 0; }
  .cs-body-content h3 { font-size: 28px; }
  .cs-body-content p { font-size: 15px; }
  .cs-gallery-section { padding: 50px 0; }
  .cs-gallery-grid { padding: 0 20px; grid-template-columns: 1fr 1fr; gap: 10px; }
  .cs-reel-section { padding: 60px 20px; }
  .cs-reel-wrap { border-radius: 16px; }
  .cs-site-section { padding: 60px 20px; }
  .cs-site-title { font-size: clamp(36px, 9vw, 60px); }
  .cs-site-iframe-container { height: 360px; }
  .cs-testimonial-section { padding: 60px 20px; }
  .cs-quote-mark { font-size: 100px; }
  .cs-quote-text { font-size: clamp(18px, 4vw, 26px); }
  .cs-nav-section { padding: 40px 20px; }
  .cs-nav-inner { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cs-nav-btn { padding: 18px 16px; border-radius: 12px; }
  .cs-nav-name { font-size: 16px; }

  /* ── ABOUT PAGE ── */
  .ab-hero-section,
  .page-hero--about { padding: 100px 20px 70px; }
  .page-about .page-hero-title { font-size: clamp(56px, 14vw, 90px) !important; }
  .ab-hero-pills { gap: 6px; }
  .ab-pill { font-size: 10px; padding: 6px 12px; }
  .about-mission .container { padding: 0 20px; }
  .am-grid { grid-template-columns: 1fr; gap: 32px; }
  .ab-ms-card strong { font-size: 28px; }
  .ab-ms-card { padding: 16px 14px; }
  .ab-timeline-section { padding: 60px 0; }
  .ab-timeline-section .container { padding: 0 20px; }
  .ab-timeline::before { left: 46px; }
  .ab-tl-item { grid-template-columns: 46px 22px 1fr; gap: 0 12px; padding-bottom: 32px; }
  .ab-tl-content h3 { font-size: 20px; }
  .ab-tl-content p { font-size: 13px; }
  .about-values { padding: 60px 0 !important; }
  .about-values .container { padding: 0 20px; }
  .values-grid { grid-template-columns: 1fr; gap: 12px; }
  .value-card { padding: 28px 24px; }
  .about-stats .container { padding: 0 20px; }
  .stats-row { grid-template-columns: repeat(3,1fr); gap: 1px; }
  .stat-card { padding: 32px 12px; }
  .sc-num { font-size: clamp(28px, 6vw, 48px); }
  .about-industries .container { padding: 0 20px; }
  .ai-list { grid-template-columns: 1fr; }
  .ai-item { padding: 14px 16px; }
  .cta-section { padding: 80px 20px; }
  .cta-heading { font-size: clamp(48px, 13vw, 80px); }
  .cta-actions { flex-direction: column; align-items: center; gap: 10px; }
  .btn-cta-large { width: 100%; max-width: 300px; justify-content: center; }
  .btn-ghost-light { width: 100%; max-width: 300px; justify-content: center; }

  /* ── SERVICES PAGE ── */
  .page-services .page-hero { padding: 110px 0 70px; }
  .page-services .page-hero-title { font-size: clamp(52px, 14vw, 90px) !important; }
  .service-detail-row { padding: 56px 0; }
  .service-detail-row .container { padding: 0 20px; }
  .sdr-inner { grid-template-columns: 1fr; gap: 24px; }
  .sdr-title { font-size: clamp(36px, 9vw, 60px); }
  .sdr-icon { width: 60px; height: 60px; font-size: 24px; border-radius: 16px; }
  .sdr-desc { font-size: 15px; }
  .sdr-feature-card { padding: 24px 20px; border-radius: 18px; }
  .sdr-list li { font-size: 13px; }

  /* ── RESTAURANTS PAGE ── */
  .rest-hero { padding: 100px 20px 70px; }
  .rest-hero-title { font-size: clamp(48px, 13vw, 90px); }
  .rest-hero-sub { font-size: 15px; }
  .rest-hero-actions { flex-direction: column; align-items: center; gap: 10px; }
  .rest-hero-actions a { width: 100%; max-width: 300px; justify-content: center; }
  .rest-hero-stats { gap: 6px; }
  .rest-hs-pill { padding: 10px 14px; }
  .rest-journey { padding: 60px 0; }
  .rest-journey-inner { padding: 0 20px; }
  .rest-phase-header { gap: 14px; padding: 18px 20px; }
  .rest-phase-num { font-size: 36px; width: 40px; }
  .rest-phase-title { font-size: 24px; }
  .rest-phase-body { padding: 0 20px; }
  .rest-phase.open .rest-phase-body { padding: 0 20px 24px; }
  .rest-phase-list { grid-template-columns: 1fr; gap: 6px; }
  .rest-work-section { padding: 60px 0; }
  .rest-work-inner { padding: 0 20px; }
  .rest-why-section { padding: 60px 0; }
  .rest-why-inner { padding: 0 20px; }
  .rest-why-grid { grid-template-columns: 1fr; gap: 12px; }
  .rest-why-card { padding: 28px 24px; border-radius: 20px; }
  .rest-services-section { padding: 60px 0; }
  .rest-services-inner { padding: 0 20px; }
  .rest-svc-grid { grid-template-columns: 1fr; gap: 10px; }
  .rest-svc-card { padding: 28px 24px; }
  .rest-cta-section { padding: 80px 20px; }
  .rest-cta-title { font-size: clamp(52px, 13vw, 90px); }
  .rest-cta-btns { flex-direction: column; align-items: center; gap: 10px; }
  .rest-cta-btns a { width: 100%; max-width: 300px; justify-content: center; }
  .rest-cta-trust { flex-direction: column; gap: 8px; }
  .rest-section-title { font-size: clamp(44px, 10vw, 72px); }

  /* ── CONTACT PAGE ── */
  .contact-hero {
    grid-template-columns: 1fr;
    padding: 120px 20px 60px;
    gap: 40px;
    min-height: auto;
  }
  .contact-title { font-size: clamp(52px, 14vw, 80px); }
  .contact-sub { font-size: 15px; }
  .contact-form { padding: 28px 20px; border-radius: 20px; }
  .cf-row-2 { grid-template-columns: 1fr; }
  .cf-checkboxes { gap: 6px; }
  .cf-check { font-size: 12px; padding: 7px 12px; }
  .btn-submit { padding: 15px; font-size: 13px; }

  /* ── FOOTER ── */
  .footer-wrap { padding: 0 20px; }
  #site-footer { padding: 60px 0 20px; }
  .footer-top { gap: 32px; }
  .ft-logo { font-size: 40px; }
  .ft-tag { font-size: 14px; }
  .ft-links { grid-template-columns: repeat(2,1fr); gap: 24px 16px; }
  .ft-col h4 { font-size: 10px; margin-bottom: 12px; }
  .ft-col a { font-size: 13px; margin-bottom: 8px; }
  .ft-bottom { flex-direction: column; gap: 10px; font-size: 12px; }
  .ft-socials { gap: 8px; }
  .ft-soc { width: 38px; height: 38px; }
  .ft-marquee { margin: 20px 0 14px; }
  .ftm-track span { font-size: 18px; }
}

/* ════════════════════════════════
   BREAKPOINT: 480px — Small phones
════════════════════════════════ */
@media (max-width: 480px) {
  /* ── HERO ── */
  .hero { padding: 90px 16px 50px; }
  .hero-hl { font-size: clamp(42px, 16vw, 68px); }
  .hero-badge { font-size: 8px; letter-spacing: .12em; padding: 7px 14px; }
  #hero-btns { max-width: 100%; }
  #hero-btns a { padding: 13px 20px; font-size: 12px; }
  .hs-pill { min-width: 100px; }
  .hs-num { font-size: 12px; }

  /* ── ABOUT HOME ── */
  .about-title { font-size: clamp(44px, 16vw, 68px); }
  .about-stat-card strong { font-size: 30px; }
  .about-stats { grid-template-columns: repeat(3,1fr); gap: 8px; }
  .about-video-wrap { height: 260px; border-radius: 18px; }
  .about-mini-grid { gap: 8px; }

  /* ── MARQUEE ── */
  .mq-track span { font-size: 18px; padding: 0 18px; }

  /* ── INDUSTRIES ── */
  .industries-heading { font-size: clamp(38px, 14vw, 60px); }
  .industry-stage { max-width: 260px; }
  .industry-title { font-size: clamp(38px, 13vw, 60px); }
  .industry-meta { grid-template-columns: 1fr; gap: 8px; }
  .industry-stat { padding: 16px; }
  .industry-stat strong { font-size: 32px; }
  .industry-selector { gap: 12px; }
  .industry-thumb { width: 44px; height: 44px; }

  /* ── WORK CAROUSEL ── */
  .sw2-card { width: 88vw; height: 360px; }
  .sw2-card-title { font-size: 24px; }
  .sw2-content { padding: 20px 18px 20px; }
  .sw2-tag, .sw2-stat-badge { font-size: 8px; }

  /* ── SERVICES HOME ── */
  .svc-title { font-size: clamp(36px, 12vw, 60px); }
  .svc-content { padding: 28px 16px; }
  .svc-icon { width: 56px; height: 56px; font-size: 22px; }

  /* ── CTA HOME ── */
  .cta-h { font-size: clamp(44px, 15vw, 72px); }

  /* ── PORTFOLIO ── */
  .pf-hero-title { font-size: clamp(40px, 14vw, 68px); }
  .pf-masonry { padding: 0 16px; gap: 10px; }
  .pf-item-title { font-size: 18px; }
  .pf-cta-title { font-size: clamp(38px, 13vw, 60px); }

  /* ── CASE STUDY ── */
  .cs-hero-title { font-size: clamp(38px, 12vw, 64px); }
  .cs-hero-stats-bar { gap: 6px; }
  .cs-stat-pill { min-width: 70px; }
  .cs-stat-pill strong { font-size: 18px; }
  .cs-gallery-grid { grid-template-columns: 1fr; gap: 8px; }
  .cs-stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cs-stat-card { padding: 22px 16px; }
  .cs-nav-inner { grid-template-columns: 1fr 1fr; gap: 8px; }
  .cs-nav-btn { padding: 14px 12px; }
  .cs-nav-name { font-size: 14px; }

  /* ── ABOUT ── */
  .page-about .page-hero-title { font-size: clamp(48px, 15vw, 76px) !important; }
  .ab-ms-card strong { font-size: 26px; }
  .ab-timeline::before { display: none; }
  .ab-tl-item { grid-template-columns: 48px 1fr; gap: 0 12px; }
  .ab-tl-connector { display: none; }
  .ab-tl-year { font-size: 10px; text-align: left; }
  .values-grid { gap: 10px; }
  .value-card { padding: 24px 18px; }
  .stats-row { grid-template-columns: repeat(2,1fr); }
  .stat-card:nth-child(2) { border-right: none; }

  /* ── SERVICES ── */
  .page-services .page-hero-title { font-size: clamp(44px, 14vw, 72px) !important; }
  .sdr-title { font-size: clamp(32px, 10vw, 52px); }
  .sdr-feature-card { padding: 20px 16px; }
  .sdr-list { gap: 8px; }

  /* ── RESTAURANTS ── */
  .rest-hero-title { font-size: clamp(40px, 14vw, 72px); }
  .rest-section-title { font-size: clamp(38px, 12vw, 60px); }
  .rest-phase-header { gap: 10px; padding: 16px; }
  .rest-phase-title { font-size: 20px; }
  .rest-phase-num { font-size: 30px; width: 34px; }
  .rest-why-card { padding: 24px 18px; }
  .rest-cta-title { font-size: clamp(44px, 14vw, 72px); }

  /* ── CONTACT ── */
  .contact-title { font-size: clamp(44px, 14vw, 72px); }
  .contact-form { padding: 24px 16px; border-radius: 16px; }
  .cf-group input, .cf-group select, .cf-group textarea { padding: 11px 14px; font-size: 14px; }
  .cf-checkboxes { gap: 5px; }

  /* ── FOOTER ── */
  .ft-links { grid-template-columns: 1fr 1fr; gap: 20px 12px; }
  .footer-wrap { padding: 0 16px; }

  /* ── PLUGIN / PORTFOLIO BUILDER ── */
  .tbl-pb-grid-2 { grid-template-columns: 1fr !important; }
  .tbl-pb-gallery-grid { grid-template-columns: repeat(2,1fr); }
}

/* ════════════════════════════════
   BREAKPOINT: 375px — Smallest phones
════════════════════════════════ */
@media (max-width: 375px) {
  .wrap, .container { padding: 0 14px; }

  .hero-hl { font-size: clamp(38px, 17vw, 58px); }
  .hero-badge { display: none; }

  .about-title { font-size: clamp(38px, 17vw, 58px); }
  .about-stats { grid-template-columns: 1fr 1fr 1fr; }
  .about-stat-card strong { font-size: 24px; }
  .about-stat-card span { font-size: 10px; }

  .sw2-card { width: 92vw; height: 320px; }

  .pf-hero-title { font-size: clamp(36px, 16vw, 58px); }

  .cs-hero-title { font-size: clamp(34px, 14vw, 56px); }
  .cs-stats-grid { grid-template-columns: 1fr 1fr; }

  .cta-h, .cta-heading { font-size: clamp(40px, 16vw, 64px); }

  .rest-hero-title { font-size: clamp(36px, 16vw, 60px); }
  .rest-cta-title { font-size: clamp(38px, 16vw, 60px); }

  .contact-title { font-size: clamp(40px, 16vw, 60px); }

  .ab-tl-item { grid-template-columns: 40px 1fr; }
  .page-about .page-hero-title { font-size: clamp(40px, 17vw, 64px) !important; }

  .ft-links { grid-template-columns: 1fr; }
  .ft-bottom { text-align: center; }

  /* Touch targets — minimum 44px */
  .pf-filter-btn { min-height: 36px; }
  .btn-glow, .btn-outline-h, .btn-dark,
  .btn-cta-large, .btn-ghost, .hdr-cta,
  .btn-glow-lg, .btn-ghost-light { min-height: 44px; }
}

/* ════════════════════════════════
   GLOBAL MOBILE UTILITIES
════════════════════════════════ */

/* Prevent horizontal scroll everywhere */
@media (max-width: 1024px) {
  html, body { overflow-x: hidden; max-width: 100vw; }

  /* Cursor — hide on touch */
  .tbl-cursor, #sparkle-canvas { display: none !important; }
  body { cursor: auto !important; }

  /* Three.js canvases — reduce quality on mobile */
  #hero-gl, #cta-gl, #pf-hero-canvas,
  .ab-hero-canvas, .rest-hero-canvas { opacity: .6; }

  /* Page transitions — simplify */
  .page-trans { display: none; }

  /* Floating image grids — hide on mobile (performance) */
  .hmg-item { display: none; }

  /* Mesh parallax — disable */
  .mesh-1, .mesh-2, .mesh-3 { animation: none; }

  /* Hero ring pulse — simplify */
  .hero::before { display: none; }

  /* All cards — remove 3D perspective tilt */
  [data-tilt] { transform: none !important; }

  /* Smooth scrolling keep */
  html { scroll-behavior: smooth; }

  /* Magnetic buttons — disable */
  .btn-glow, .btn-glow-lg, .hdr-cta {
    transform: none !important;
  }

  /* Fix any overflow from absolute positioned elements */
  .pf-bg-word, .ab-bg-word, .rest-bg-word, .ph-bg-text {
    overflow: hidden;
    max-width: 100vw;
  }

  /* Service pin section — mobile stack */
  .s-services-pin { height: auto !important; }

  /* About floating cards */
  .ab-fc, .ab-hero-float-stat { display: none; }

  /* Restaurant hero images */
  .rest-img-1, .rest-img-2, .rest-img-3, .rest-img-4 { display: none; }

  /* Homepage about floating cards */
  .about-floating-card { display: none; }

  /* Scroll indicators */
  .pf-hero-scroll, .ab-hero-scroll,
  .rest-hero-scroll { opacity: .6; }

  /* Work carousel — ensure full width track */
  .sw2-track { padding-right: 20px; }

  /* Gallery grid */
  .cs-gallery-grid { grid-template-columns: 1fr 1fr; }

  /* Fix industries player */
  .industries-player { padding: 0 20px; }

  /* Contact form grid */
  .cf-row-2 { grid-template-columns: 1fr; }

  /* Footer marquee */
  .ftm-track span { font-size: 16px; }

  /* Nav links — ensure clickable size */
  .mob-link { padding: 8px 0; display: block; }

  /* Lightbox arrows on mobile */
  .cs-lb-prev { left: 8px; }
  .cs-lb-next { right: 8px; }
  .cs-lightbox-arrow { width: 44px; height: 44px; font-size: 22px; }

  /* Fix sticky filter bar z-index on mobile */
  .pf-filter-section { top: 58px; z-index: 90; }
}

/* ════════════════════════════════
   TOUCH — Hover state improvements
════════════════════════════════ */
@media (hover: none) {
  /* Remove hover transforms on touch devices */
  .pf-item:hover .pf-item-img { transform: none; }
  .pf-item:hover .pf-item-overlay { opacity: 0; }
  .sw2-card:hover { transform: scale(.97) translateY(6px) !important; }
  .rest-why-card:hover,
  .ab-val-card:hover,
  .value-card:hover { transform: none !important; }
  .sdr-feature-card:hover { transform: none; }
  .ab-ms-card:hover { transform: none; }
  .industry-stat:hover { transform: none; }
  .hs-pill:hover { transform: none; }

  /* But keep tap feedback */
  .pf-item:active .pf-item-overlay { opacity: 1; }
  .sw2-card:active { transform: scale(.95) !important; }
}

.about-actions .btn-dark {
  color: #0d0d1a !important;
}

.about-actions .btn-dark:hover {
  color: #1a2e1a !important;
}

.cf-success[hidden] {
  display: none !important;
}