@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Sora:wght@500;600;700&display=swap');

:root {
  --bg: #090909;
  --bg2: #141311;
  --card: rgba(255,255,255,0.045);
  --line: rgba(255,255,255,0.10);
  --text: #ffffff;
  --muted: #c7c1b8;
  --accent1: #ffffff;
  --accent2: #ffffff;
  --accent3: #ffffff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Plus Jakarta Sans', Inter, system-ui, -apple-system, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1000px 500px at 90% -10%, rgba(255,248,235,.10), transparent 60%),
    radial-gradient(900px 580px at -10% 20%, rgba(222,224,228,.10), transparent 58%),
    linear-gradient(180deg,#070707,#10100f 45%, #090909 100%);
}
.container{width:min(1180px,92%);margin:0 auto}
a{text-decoration:none;color:inherit}

/* reveal-on-scroll animation */
.reveal{
  opacity: 0;
  transform: translateY(18px) scale(.985);
  transition: opacity .55s ease, transform .55s ease;
  will-change: opacity, transform;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0) scale(1);
}
.home-page .hero-panel.reveal{
  transform: translateX(-44px) scale(.985);
}
.home-page .hero-media.reveal{
  transform: translateX(44px) scale(.985);
}
.home-page .hero-panel.reveal.is-visible,
.home-page .hero-media.reveal.is-visible{
  transform: translateX(0) scale(1);
}


/* subtle cursor aura */
.cursor-aura{
  position: fixed;
  width: 26px;
  height: 20px;
  border-radius: 58% 42% 60% 40% / 44% 56% 46% 54%;
  pointer-events: none;
  z-index: 9999;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 35% 35%, rgba(247,211,125,.72), rgba(233,185,90,.34) 45%, rgba(242,223,180,.08) 75%);
  box-shadow: 0 0 18px rgba(232,182,84,.35), 0 0 44px rgba(232,182,84,.2);
  mix-blend-mode: screen;
  opacity: .62;
  filter: blur(.2px);
  animation: auraMorph 2.8s ease-in-out infinite;
  transition: width .18s ease, height .18s ease, opacity .18s ease;
}
.cursor-aura.is-hover{ width: 44px; height: 34px; opacity: .9; }
@keyframes auraMorph {
  0%,100% { border-radius: 58% 42% 60% 40% / 44% 56% 46% 54%; }
  50% { border-radius: 44% 56% 46% 54% / 60% 40% 58% 42%; }
}
@media (prefers-reduced-motion: reduce), (max-width: 900px) {
  .cursor-aura { display: none; }
  .nav .btn { animation: none; }
}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(10,10,10,.62);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:15px 0}
.brand{font-family:'Sora',sans-serif;font-size:1.1rem;letter-spacing:.02em;font-weight:600}
.menu{display:flex;gap:24px;color:#d5cec3;font-weight:500}
.menu a{opacity:.88;transition:.25s}
.menu a:hover{opacity:1;color:#fff}
.nav-toggle{display:none;background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;padding:6px 10px;font-size:18px}
.btn{
  position:relative;
  border:1px solid rgba(255,255,255,.22);
  background: linear-gradient(135deg, rgba(255,255,255,.17), rgba(255,255,255,.05));
  color:#fff;padding:10px 16px;border-radius:12px;font-weight:600;
  box-shadow: 0 8px 24px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.22);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(-1px) scale(1.02); box-shadow:0 12px 30px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.3); border-color: rgba(255,255,255,.35)}

/* global top-right CTA style */
.nav .btn{
  background: linear-gradient(135deg, #f7d37d 0%, #e9b95a 45%, #f2dfb4 100%);
  color: #181512;
  border-color: rgba(255,230,170,.9);
  box-shadow: 0 8px 26px rgba(232,182,84,.42), inset 0 1px 0 rgba(255,255,255,.52);
  animation: ctaRing 2.6s ease-in-out infinite;
}
.nav .btn:hover{
  transform: translateY(-1px) scale(1.06);
  box-shadow: 0 16px 40px rgba(232,182,84,.55), inset 0 1px 0 rgba(255,255,255,.7);
}
@keyframes ctaRing {
  0%, 52%, 100% {
    box-shadow:
      0 8px 26px rgba(232,182,84,.42),
      inset 0 1px 0 rgba(255,255,255,.52),
      0 0 0 0 rgba(245,205,122,0),
      0 0 0 0 rgba(245,205,122,0);
  }
  60% {
    box-shadow:
      0 12px 34px rgba(232,182,84,.5),
      inset 0 1px 0 rgba(255,255,255,.62),
      0 0 0 10px rgba(245,205,122,.18),
      0 0 0 18px rgba(245,205,122,.08);
  }
  72% {
    box-shadow:
      0 8px 26px rgba(232,182,84,.42),
      inset 0 1px 0 rgba(255,255,255,.52),
      0 0 0 18px rgba(245,205,122,0),
      0 0 0 30px rgba(245,205,122,0);
  }
}

.btn-gold-static{
  background: linear-gradient(135deg, #f7d37d 0%, #e9b95a 45%, #f2dfb4 100%);
  color: #181512;
  border-color: rgba(255,230,170,.9);
  box-shadow: 0 8px 22px rgba(232,182,84,.28), inset 0 1px 0 rgba(255,255,255,.52);
  animation: none !important;
}
.btn-gold-static:hover{
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 10px 24px rgba(232,182,84,.34), inset 0 1px 0 rgba(255,255,255,.62);
}

/* scroll attention drop for Request Media Kit (left side attached hinge) */
.home-page .btn-gold-static{
  transform-origin: 8% 52%;
}
.home-page .btn-gold-static.drop-brick{
  animation: hingeDrop .92s cubic-bezier(.24,.92,.22,1.12) 1;
}
@keyframes hingeDrop {
  0%   { transform: rotate(0deg) translateY(0); }
  22%  { transform: rotate(12deg) translateY(1px); }
  48%  { transform: rotate(28deg) translateY(5px); }
  62%  { transform: rotate(18deg) translateY(2px); }
  74%  { transform: rotate(24deg) translateY(4px); }
  100% { transform: rotate(0deg) translateY(0); }
}

/* HERO */
.hero{padding:72px 0 40px;display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:stretch}
.hero-panel{
  border:1px solid var(--line);
  border-radius:24px;
  padding:40px;
  background: linear-gradient(150deg, rgba(255,255,255,.10), rgba(230,222,208,.05) 45%, rgba(255,255,255,.02));
  box-shadow: 0 16px 56px rgba(0,0,0,.46), inset 0 1px 0 rgba(255,255,255,.18);
}
.kicker{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:#ddd6ca}
h1{font-family:'Sora',sans-serif;font-size:clamp(2.05rem,4.4vw,3.4rem);line-height:1.1;margin:.55rem 0 1rem;letter-spacing:-0.01em}
.sub{color:#c8c2b7;line-height:1.75;font-size:1.04rem;max-width:62ch}
.hero-media{
  min-height:340px;border-radius:24px;border:1px solid var(--line);
  background:
    linear-gradient(180deg, transparent 30%, rgba(0,0,0,.45) 100%),
    url('../assets/images/hero-main.jpg') center/cover no-repeat,
    linear-gradient(135deg,#121212,#0b0b0b);
  position:relative;overflow:hidden;
}
.hero-media::after{
  content:'';position:absolute;inset:auto -15% -30% -15%;height:180px;
  background:radial-gradient(closest-side, rgba(255,255,255,.20), transparent 70%);
}

/* shared */
.section{padding:34px 0}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.card{
  grid-column:span 12;
  border:1px solid var(--line);
  border-radius:18px;
  background: linear-gradient(160deg, rgba(255,255,255,.055), rgba(230,226,218,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  padding:22px;
}
h2{font-family:'Sora',sans-serif;font-size:1.55rem;margin:.1rem 0 .9rem;letter-spacing:-0.01em}
.small{color:#c8c2b7;line-height:1.75}
.hero-socials{display:flex;gap:12px;flex-wrap:wrap}
.hero-socials a{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 16px;border-radius:12px;
  border:1px solid rgba(233,185,90,.65);
  color:#fff;font-weight:700;font-size:15px;
  box-shadow: inset 0 1px 0 rgba(255,245,220,.22), 0 8px 18px rgba(0,0,0,.28), 0 0 10px rgba(233,185,90,.18);
  transition: transform .2s ease, filter .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.hero-socials a:hover{transform:translateY(-1px) scale(1.04); filter:brightness(1.05); border-color: rgba(247,211,125,.9)}

.hero-socials .social-btn{
  position: relative;
  isolation: isolate;
}
.hero-socials .social-btn::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:12px;
  background:rgba(10,10,10,.30);
  z-index:-1;
}
.hero-socials .ig{
  background: linear-gradient(135deg,rgba(249,206,52,.45),rgba(238,42,123,.45) 55%,rgba(98,40,215,.4));
  box-shadow: 0 0 0 1px rgba(255,245,220,.2) inset, 0 0 10px rgba(233,185,90,.16);
}
.hero-socials .tt{
  background: linear-gradient(135deg,rgba(20,20,20,.88),rgba(45,45,45,.82),rgba(20,20,20,.88));
  border-color: rgba(233,185,90,.6);
  box-shadow: 0 0 0 1px rgba(255,245,220,.18) inset, 0 0 10px rgba(233,185,90,.14);
}
.hero-socials .yt{
  background: linear-gradient(135deg,rgba(255,46,46,.5),rgba(204,0,0,.5));
  box-shadow: 0 0 0 1px rgba(255,245,220,.16) inset, 0 0 10px rgba(233,185,90,.14);
}
.hero-socials .fb{
  background: linear-gradient(135deg,rgba(24,119,242,.5),rgba(15,91,196,.5));
  box-shadow: 0 0 0 1px rgba(255,245,220,.16) inset, 0 0 10px rgba(233,185,90,.14);
}
.hero-socials .em{
  background: linear-gradient(135deg,rgba(242,215,171,.78),rgba(215,182,132,.74));
  color:#ffffff;
  box-shadow: 0 0 0 1px rgba(255,245,220,.4) inset, 0 0 12px rgba(233,185,90,.2);
}

.stats .card{grid-column:span 3;text-align:left}
.stats h3{margin:0;font-family:'Sora',sans-serif;font-size:2rem;letter-spacing:-.01em}
.stats p{margin:.35rem 0 0;color:#c8c2b7}
.stats-premium .card{
  background:
    radial-gradient(120% 80% at 85% -10%, rgba(255,240,210,.10), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,.08), rgba(205,196,182,.03));
  border-color: rgba(255,255,255,.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16);
}
.stats-premium .aud-k{
  display:block;
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#c8c2b7;
  margin-bottom:6px;
}

.two-col .left{grid-column:span 7}
.two-col .right{grid-column:span 5}
.list{margin:0;padding-left:18px;color:#c8c2b7;line-height:1.9}

/* timeline card */
.how-card{background:linear-gradient(165deg, rgba(255,255,255,.08), rgba(213,205,194,.04));}
.timeline{margin:8px 0 0;padding:0;list-style:none;position:relative;display:grid;gap:12px}
.timeline::before{content:'';position:absolute;left:19px;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg, rgba(230,230,230,.7), rgba(220,182,112,.45), rgba(230,230,230,.5));}
.timeline li{position:relative;display:grid;grid-template-columns:40px 1fr;gap:12px;align-items:start;padding:6px 0}
.timeline .step{width:40px;height:40px;border-radius:999px;display:grid;place-items:center;font-size:11px;font-weight:800;letter-spacing:.08em;color:#16120d;border:1px solid rgba(255,240,210,.78);background:linear-gradient(145deg,#f4f4f4 0%,#d4d0c8 35%,#d9b676 72%,#f3d9a4 100%);box-shadow:0 6px 14px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.74), 0 0 10px rgba(217,182,118,.2);z-index:2}
.timeline li:nth-child(1) .step{background:linear-gradient(145deg,#f6f6f6 0%,#d8d6d1 45%,#cfc8bb 100%)}
.timeline li:nth-child(2) .step{background:linear-gradient(145deg,#f5f5f3 0%,#d8d2c6 45%,#d5c1a1 100%)}
.timeline li:nth-child(3) .step{background:linear-gradient(145deg,#f4f1ea 0%,#dbc8a5 48%,#d9b676 100%)}
.timeline li:nth-child(4) .step{background:linear-gradient(145deg,#f2e8d8 0%,#dfbd86 50%,#dfad5c 100%)}
.timeline li:nth-child(5) .step{background:linear-gradient(145deg,#f3e1c1 0%,#e1b56f 52%,#de9d3f 100%)}
.timeline h4{margin:2px 0 4px;font-family:'Sora',sans-serif;font-size:1rem;letter-spacing:-.01em}
.timeline p{margin:0;color:#c8c2b7;font-size:.92rem;line-height:1.6}

.tags{display:flex;flex-wrap:wrap;gap:9px}
.tag{padding:9px 12px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(232,224,210,.07);font-size:.86rem}

/* Available block upgrade */
.available-card{
  background:
    radial-gradient(120% 80% at 85% -10%, rgba(255,240,210,.10), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,.08), rgba(205,196,182,.03));
}
.available-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.avail-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.15);
}
.avail-item strong{font-size:.9rem; font-weight:700; letter-spacing:.01em}
.avail-dot{
  width:9px;height:9px;border-radius:999px;
  background: radial-gradient(circle, #f8ddb0 0%, #d8aa5d 70%);
  box-shadow: 0 0 8px rgba(216,170,93,.45);
  flex:0 0 auto;
}

.work-grid .item{grid-column:span 4;min-height:220px;display:flex;flex-direction:column;justify-content:end;position:relative;overflow:hidden}
.work-grid .item::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.72) 100%)}
.work-grid .item > *{position:relative;z-index:1}
.work-grid .item.photo-card img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover}
.work-grid .item:nth-child(1).photo-card img{object-position:center 18%}
.work-grid .item:nth-child(2).photo-card img{object-position:center 8%}
.work-grid .item:nth-child(3).photo-card img{object-position:center 22%}

/* case study single layout */
.case-block{padding:24px;overflow:hidden}
.case-shell{position:relative;overflow:hidden}
.case-big-next{
  position:absolute;
  right:18px;
  top:20px;
  width:54px;
  height:54px;
  border-radius:14px;
  border:1px solid rgba(233,185,90,.65);
  background:linear-gradient(145deg, rgba(255,255,255,.08), rgba(233,185,90,.18));
  color:#f2dfb4;
  font-size:26px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.25);
}
.case-big-next:hover{transform:translateY(-1px) scale(1.03)}
.case-panels{position:relative;overflow:hidden}
.case-panel{width:100%}
.case-panel[hidden]{display:none !important}
.single-case{display:grid;grid-template-columns:1fr;gap:14px;align-items:center;max-width:760px;margin:0 auto}
.case-name{
  margin:0 0 8px;
  font-size:1.22rem;
  text-align:center;
  color:#f2dfb4;
  letter-spacing:.02em;
  text-shadow:0 0 10px rgba(233,185,90,.2);
}
.case-video-center{display:flex;justify-content:center;overflow:hidden;flex:0 0 auto}
.case-trio{
  display:flex;
  gap:10px;
  overflow-x:auto;
  overflow-y:hidden;
  padding:4px 2px 8px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(233,185,90,.45) rgba(255,255,255,.08);
}
.case-trio::-webkit-scrollbar{height:7px}
.case-trio::-webkit-scrollbar-track{background:rgba(255,255,255,.08);border-radius:999px}
.case-trio::-webkit-scrollbar-thumb{background:rgba(233,185,90,.45);border-radius:999px}
.iphone-frame{
  width:170px;
  height:346px;
  border-radius:28px;
  padding:7px;
  background:linear-gradient(165deg,#111,#242424 45%,#111);
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 10px 20px rgba(0,0,0,.4), 0 0 0 1px rgba(233,185,90,.16) inset;
  position:relative;
  overflow:hidden;
}
.iphone-notch{
  position:absolute;
  top:5px;
  left:50%;
  transform:translateX(-50%);
  width:62px;
  height:12px;
  border-radius:0 0 9px 9px;
  background:#0a0a0a;
  z-index:2;
}
.iphone-frame video{width:100% !important;height:100% !important;display:block;object-fit:cover;border-radius:20px;background:#000;max-width:100%;max-height:100%}
.case-meta{border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:14px;background:linear-gradient(160deg, rgba(255,255,255,.09), rgba(205,196,182,.04))}
.case-overview{
  border-color: rgba(233,185,90,.35);
  box-shadow: 0 10px 24px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.16);
}
.case-title{
  margin:0 0 8px;
  font-family:'Sora',sans-serif;
  font-size:1.45rem;
  letter-spacing:-.01em;
}
.case-lead{
  margin:0 0 12px;
  color:#e3ddd2;
  font-size:1.02rem;
  line-height:1.6;
}
.case-kpis{
  display:grid;
  grid-template-columns: repeat(2,minmax(0,1fr));
  gap:10px;
}
.kpi{
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:10px;
  background:rgba(255,255,255,.03);
}
.kpi span{display:block;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:#c8c2b7;margin-bottom:4px}
.kpi strong{font-family:'Sora',sans-serif;font-size:1rem}
.case-stat{margin-bottom:10px}
.case-stat span{display:block;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:#c8c2b7}
.case-stat strong{font-family:'Sora',sans-serif;font-size:1rem}

.work-grid .item:nth-child(1){background:linear-gradient(120deg,#111317,#0d0e12)}
.work-grid .item:nth-child(2){background:linear-gradient(120deg,#121212,#0d0d0d)}
.work-grid .item:nth-child(3){background:linear-gradient(120deg,#161616,#0f0f0f)}
.item .label{color:#d0d4e8;font-size:.9rem}
.sample-open{
  margin-top:10px;
  align-self:flex-start;
  border:1px solid rgba(233,185,90,.6);
  background:rgba(12,12,12,.65);
  color:#f2dfb4;
  font-weight:700;
  border-radius:10px;
  padding:8px 12px;
  cursor:pointer;
}
.sample-open:hover{background:rgba(233,185,90,.16)}

.clickable-card{
  border-color: rgba(233,185,90,.35);
  box-shadow: 0 0 0 1px rgba(233,185,90,.18) inset, 0 0 14px rgba(233,185,90,.2);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.clickable-card::after{
  content:'Click to view samples';
  position:absolute;
  right:12px;
  top:12px;
  font-size:.65rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#f2dfb4;
  background:rgba(10,10,10,.55);
  border:1px solid rgba(233,185,90,.45);
  border-radius:999px;
  padding:5px 8px;
  z-index:2;
}
.clickable-card:hover{
  transform: translateY(-2px);
  border-color: rgba(233,185,90,.62);
  box-shadow: 0 0 0 1px rgba(233,185,90,.26) inset, 0 0 20px rgba(233,185,90,.3);
}

.samples-modal[hidden]{display:none}
.samples-modal{position:fixed;inset:0;z-index:120}
.samples-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(2px)}
.samples-panel{
  position:relative;
  width:min(860px,92vw);
  max-height:84vh;
  overflow:auto;
  margin:6vh auto 0;
  background:linear-gradient(160deg, rgba(25,25,25,.96), rgba(13,13,13,.96));
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  padding:18px;
}
.samples-close{position:absolute;top:10px;right:12px;background:transparent;border:0;color:#fff;font-size:30px;cursor:pointer}
.samples-body{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}
.samples-body video,.samples-body a.sample-link,.samples-body .sample-photo-card{width:100%;border-radius:10px;border:1px solid rgba(255,255,255,.16);display:block;background:#000;color:#f2dfb4;padding:14px;text-align:center}
.samples-body video{height:300px;object-fit:cover}
.samples-body .sample-photo-card{
  padding:8px;
  background:linear-gradient(165deg, rgba(255,255,255,.06), rgba(205,196,182,.03));
  border-color:rgba(233,185,90,.35);
}
.samples-body img.sample-image{
  width:100%;
  height:240px;
  object-fit:cover;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.16);
  display:block;
}
.samples-body a.sample-link{
  width:auto;
  justify-self:start;
  align-self:start;
  padding:10px 14px;
  background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(233,185,90,.18));
  border:1px solid rgba(233,185,90,.65);
  font-weight:700;
  text-decoration:none;
  box-shadow: 0 8px 18px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.2);
}
.samples-body a.sample-link:hover{background:rgba(233,185,90,.2)}

.footer{margin-top:40px;border-top:1px solid rgba(255,255,255,.1);padding:28px 0 46px;color:#c8c2b7}
.page-head{padding:50px 0 16px}

.photo-card{padding:0;overflow:hidden}
.photo-card img{display:block;width:100%;height:100%;object-fit:cover;filter:contrast(1.02) saturate(.95)}
.photo-card.tall{min-height:420px}
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.photo-strip .card{padding:0;overflow:hidden;min-height:260px}
.photo-strip img{width:100%;height:100%;object-fit:cover;display:block}

/* seamless background-photo block */
.ambient-photo{
  position:relative;
  min-height:260px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
  background:
    radial-gradient(120% 120% at 10% 15%, rgba(255,255,255,.15), transparent 45%),
    linear-gradient(180deg, rgba(8,8,8,.15) 0%, rgba(8,8,8,.72) 78%),
    var(--bg) center 28% / cover no-repeat;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 16px 50px rgba(0,0,0,.35);
}
.ambient-photo::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(9,9,9,.55) 0%, rgba(9,9,9,.15) 52%, rgba(9,9,9,.55) 100%);
  pointer-events:none;
}
.ambient-photo__overlay{
  position:relative;
  z-index:2;
  padding:28px;
  max-width:560px;
}

.topic-photo{
  position: relative;
  overflow: hidden;
}
.topic-photo::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(10,10,10,.62), rgba(10,10,10,.78)),
    var(--topic-bg) center 28% / cover no-repeat;
  opacity:.35;
  filter: saturate(.85) contrast(1.02);
  pointer-events:none;
}
.topic-photo > *{position:relative; z-index:1}

/* audience breakdown card */
.audience-card{
  background:
    radial-gradient(120% 80% at 85% -10%, rgba(255,240,210,.10), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,.08), rgba(205,196,182,.03));
}
.audience-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:6px;
}
.audience-metric{
  border:1px solid rgba(255,255,255,.14);
  border-radius:12px;
  padding:12px;
  background:linear-gradient(145deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.14);
}
.audience-metric .aud-k{
  display:block;
  font-size:.74rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#c8c2b7;
  margin-bottom:6px;
}
.audience-metric strong{
  font-family:'Sora',sans-serif;
  font-size:1.28rem;
  letter-spacing:-.01em;
}

/* contact page ambient background blend */
.contact-page{
  position: relative;
}
.contact-page::before{
  content:'';
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(58% 68% at 82% 36%, rgba(9,9,9,0) 0%, rgba(9,9,9,.18) 48%, rgba(9,9,9,.52) 72%, rgba(9,9,9,.86) 100%),
    radial-gradient(40% 34% at 80% 22%, rgba(255,236,210,.08), transparent 70%),
    linear-gradient(180deg, rgba(8,8,8,.24), rgba(8,8,8,.76)),
    url('../assets/images/contact-bg.jpg') right 8% top 20% / 38% auto no-repeat;
  filter: saturate(.7) contrast(1.03) brightness(.95);
}
.contact-page::after{
  content:'';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(9,9,9,.82), rgba(9,9,9,.64) 38%, rgba(9,9,9,.78)),
    radial-gradient(55% 80% at 82% 40%, rgba(0,0,0,0) 48%, rgba(0,0,0,.38) 78%, rgba(0,0,0,.66) 100%);
}
.contact-page .card{
  background: linear-gradient(160deg, rgba(255,255,255,.08), rgba(230,226,218,.035));
}
.contact-page .email-card{
  border-color: rgba(233,185,90,.42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 0 20px rgba(233,185,90,.16);
}
.email-spot{
  margin: 8px 0 10px;
}
.email-spot a{
  font-family:'Sora',sans-serif;
  font-size: clamp(1.1rem, 2.2vw, 1.4rem);
  font-weight: 700;
  color:#fff;
  letter-spacing:.01em;
  text-shadow: 0 0 12px rgba(233,185,90,.22);
  border-bottom: 1px solid rgba(233,185,90,.55);
  padding-bottom: 2px;
}
.contact-socials{margin-top:8px}
.contact-socials a{font-size:14px;padding:9px 14px}

@media (max-width:700px){
  .nav-toggle{display:block}
  .menu{
    display:flex;
    position:absolute;
    top:58px;
    left:2%;
    right:2%;
    padding:12px;
    border:1px solid rgba(255,255,255,.14);
    border-radius:12px;
    background:rgba(10,10,10,.95);
    flex-direction:column;
    gap:10px;
    z-index:60;
    opacity:0;
    transform:translateY(-10px);
    pointer-events:none;
    visibility:hidden;
    transition:opacity .22s ease, transform .22s ease, visibility .22s ease;
  }
  .menu.is-open{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
    visibility:visible;
  }
  .nav-inner{padding:12px 0; position:relative}
  .hero{grid-template-columns:1fr;gap:16px;padding:40px 0 24px}
  .hero-panel{padding:22px}
  .hero-media{min-height:220px}
  h1{font-size:clamp(1.65rem,7vw,2.2rem)}
  .sub{font-size:.98rem;line-height:1.6}
  .stats .card{grid-column:span 6;padding:16px}
  .stats h3{font-size:1.5rem}
  .two-col .left,.two-col .right{grid-column:span 12}
  .available-grid{grid-template-columns:1fr}
  .audience-grid{grid-template-columns:1fr}
  .single-case{grid-template-columns:1fr}
  .case-meta{order:2}
  .case-kpis{grid-template-columns:1fr}
  .iphone-frame{width:140px;height:286px}
  .case-big-next{right:10px;top:10px;width:42px;height:42px;font-size:20px}
  .samples-panel{width:min(94vw,620px);padding:14px}
  .samples-body{grid-template-columns:1fr}
  .samples-body video{height:240px}
  .work-grid .item{grid-column:span 12;min-height:180px}
  .photo-strip{grid-template-columns:1fr}
  .contact-page::before{
    background:
      radial-gradient(68% 62% at 84% 28%, rgba(9,9,9,0) 0%, rgba(9,9,9,.26) 52%, rgba(9,9,9,.62) 82%, rgba(9,9,9,.88) 100%),
      radial-gradient(55% 44% at 82% 22%, rgba(255,236,210,.06), transparent 70%),
      linear-gradient(180deg, rgba(8,8,8,.24), rgba(8,8,8,.8)),
      url('../assets/images/contact-bg.jpg') right -12% top 16% / 70% auto no-repeat;
  }
}

@media (max-width:420px){
  .container{width:min(96%,96%)}
  .btn{padding:9px 12px;font-size:13px}
  .hero-socials a{padding:8px 12px;font-size:13px}
  .stats .card{grid-column:span 12}
  .case-trio{gap:8px}
  .iphone-frame{width:126px;height:258px}
  .case-meta{padding:12px}
}
