:root {
  --ink: #050505;
  --surface: #111111;
  --paper: #050505;
  --white: #ffffff;
  --muted: #d1d1d1;
  --acid: #c5f82a;
  --gold-soft: #d6fa66;
  --violet: #c5f82a;
  --line: rgba(18,18,16,.12);
  /* Light theme tokens — "lime-kissed stone", tied to the accent (not cream) */
  --paper-100: #f0f1ea;   /* cool light stone, faint green cast */
  --paper-200: #e5e8dc;   /* deeper stone for alternating surfaces */
  --ink-900: #14150f;     /* near-black, warm-green cast to harmonize with lime */
  --ink-600: #50544a;     /* muted olive-grey body text on light */
  --hair: rgba(20,21,15,.13);   /* hairline borders on light */
  --hair-soft: rgba(20,21,15,.06);
  --acid-ink: #6d28d9;    /* electric violet — label/text accent on light */
  --violet-bright: #a78bfa;/* electric violet — label/text accent on dark */
  --serif: "DM Serif Display", Georgia, serif;
  --sans: "Manrope", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--white); font-family: var(--sans); font-size: 16px; line-height: 1.6; overflow-x: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
::selection { background: var(--acid); color: var(--ink); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; left: 1rem; top: -5rem; z-index: 200; background: var(--acid); padding: .75rem 1rem; transition: top .2s; }
.skip-link:focus { top: 1rem; }
.icon-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }

.social-rail { position: fixed; z-index: 95; left: 0; top: 50%; transform: translateY(-50%); display: flex; flex-direction: column; border: 1px solid rgba(197,248,42,.34); border-left: 0; background: rgba(5,5,5,.92); color: var(--white); backdrop-filter: blur(14px); }
.social-rail-label { padding: .9rem .45rem; color: var(--acid); font-size: .58rem; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; writing-mode: vertical-rl; transform: rotate(180deg); }
.social-rail a, .footer-social a { display: grid; place-items: center; width: 46px; height: 46px; color: inherit; border-top: 1px solid rgba(197,248,42,.18); transition: all .25s ease; }
.social-rail a:hover { color: var(--ink); background: var(--acid); }
.social-rail svg, .footer-social svg { width: 19px; height: 19px; fill: currentColor; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.social-rail svg use[href="#icon-instagram"], .social-rail svg use[href="#icon-x"], .social-rail svg use[href="#icon-tiktok"], .social-rail svg use[href="#icon-soundcloud"], .social-rail svg use[href="#icon-whatsapp"], .footer-social svg use[href="#icon-instagram"], .footer-social svg use[href="#icon-x"], .footer-social svg use[href="#icon-tiktok"], .footer-social svg use[href="#icon-soundcloud"], .footer-social svg use[href="#icon-whatsapp"] { fill: none; }
.whatsapp-bubble { position: fixed; z-index: 96; right: 1.5rem; bottom: 1.5rem; display: flex; align-items: center; gap: .8rem; min-height: 58px; padding: .65rem 1.1rem .65rem .85rem; border: 1px solid var(--gold-soft); border-radius: 99px; color: #000; background: var(--acid); box-shadow: 0 14px 40px rgba(0,0,0,.38); text-decoration: none; transition: all .25s ease; }
.whatsapp-bubble::before { content: ""; position: absolute; inset: -6px; z-index: -1; border: 1px solid rgba(197,248,42,.42); border-radius: inherit; animation: whatsappPulse 2.3s ease-out infinite; }
.whatsapp-bubble:hover { transform: translateY(-4px); background: var(--gold-soft); box-shadow: 0 18px 46px rgba(197,248,42,.24); }
.whatsapp-bubble svg { width: 27px; height: 27px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.whatsapp-bubble span { display: flex; flex-direction: column; font-size: .72rem; font-weight: 800; line-height: 1.35; text-transform: uppercase; letter-spacing: .08em; }
.whatsapp-bubble small { font-size: .56rem; font-weight: 600; opacity: .65; }
@keyframes whatsappPulse { from { opacity: .75; transform: scale(.94); } to { opacity: 0; transform: scale(1.16); } }

.site-header { position: fixed; inset: 0 0 auto; z-index: 100; height: 86px; padding: 0 clamp(1.2rem, 4vw, 4rem); display: flex; align-items: center; justify-content: space-between; color: var(--white); border-bottom: 1px solid rgba(197,248,42,.26); background: rgba(5,5,5,.28); backdrop-filter: blur(8px); transition: all .25s ease; }
.site-header.scrolled { height: 72px; background: rgba(5,5,5,.94); backdrop-filter: blur(16px); border-bottom-color: rgba(197,248,42,.42); }
.brand { display: inline-flex; align-items: center; gap: .7rem; color: inherit; font-weight: 700; letter-spacing: -.04em; text-decoration: none; font-size: 1.08rem; }
.brand-mark { width: 2.1em; height: auto; flex: none; }
.brand-lockup { display: flex; flex-direction: column; gap: .26em; line-height: 1; }
.brand-name { letter-spacing: .05em; }
.brand-x { color: var(--acid); }
.brand-tag { display: inline-flex; align-items: center; font-size: .55rem; font-weight: 600; letter-spacing: .17em; text-transform: uppercase; color: rgba(255,255,255,.52); }
.brand-tag::before { content: ""; width: 14px; height: 1px; margin-right: 7px; background: var(--acid); }
.brand-bars { height: 24px; display: flex; align-items: flex-end; gap: 2px; }
.brand-bars i { display: block; width: 3px; background: var(--acid); }
.brand-bars i:nth-child(1) { height: 10px; }.brand-bars i:nth-child(2) { height: 21px; }.brand-bars i:nth-child(3) { height: 14px; }.brand-bars i:nth-child(4) { height: 24px; }
.site-nav { display: flex; gap: clamp(1.2rem, 3vw, 3rem); align-items: center; }
.site-nav a { color: inherit; text-decoration: none; font-size: .77rem; text-transform: uppercase; letter-spacing: .13em; font-weight: 600; transition: all .25s ease; }
.site-nav a:hover { color: var(--acid); }
.site-nav a:not(.nav-cta) { position: relative; }
.site-nav a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -.35rem; height: 1px; background: currentColor; transition: right .25s; }
.site-nav a:hover::after { right: 0; }
.nav-cta { border: 1px solid var(--acid); border-radius: 99px; padding: .75rem 1.15rem; color: var(--acid); transition: all .25s ease; }
.nav-cta:hover { background: var(--acid); border-color: var(--acid); color: #000 !important; box-shadow: 0 8px 22px rgba(197,248,42,.2); }
.menu-toggle { display: none; }

.hero { position: relative; min-height: 100svh; overflow: hidden; background: var(--ink); color: var(--white); display: flex; align-items: flex-end; padding: 10rem clamp(1.2rem, 5vw, 5.5rem) 7vh; }
.hero-media { position: absolute; inset: 0; overflow: hidden; background: var(--ink); }
.hero-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.60) 60%, rgba(197,248,42,.08) 100%), linear-gradient(0deg, rgba(0,0,0,.58), transparent 46%); }
.hero-media img { position: absolute; inset: 0 0 0 auto; width: 58%; height: 100%; object-fit: cover; object-position: center 32%; filter: saturate(.8) contrast(1.06) brightness(.9); animation: heroZoom 14s ease-out both; }
.hero-noise { position: absolute; inset: -80px; opacity: .72; pointer-events: none; background-image: radial-gradient(rgba(197,248,42,.08) 1px, transparent 1px); background-size: 32px 32px; animation: goldFloat 12s infinite linear; }
@keyframes goldFloat { from { background-position: 0 0; } to { background-position: 120px -80px; } }
@keyframes heroZoom { from { transform: scale(1.08); } to { transform: scale(1.01); } }
.hero-content { position: relative; z-index: 2; width: min(880px, 66%); }
.eyebrow, .kicker, .mini-label { margin: 0 0 1.25rem; text-transform: uppercase; letter-spacing: .2em; font-size: .7rem; font-weight: 700; }
.eyebrow { color: var(--violet-bright); }
.kicker { color: var(--violet-bright); }
h1, h2, blockquote { font-family: var(--serif); font-weight: 400; letter-spacing: -.035em; line-height: .9; }
h1 { margin: 0; font-size: clamp(4rem, 8.7vw, 9rem); max-width: 1100px; }
h1 em, h2 em, blockquote em { font-weight: 400; color: var(--acid); }
.hero h1 em { font-style: italic; color: var(--acid); text-shadow: 0 0 20px rgba(197,248,42,.25); }
.hero-copy { max-width: 620px; margin: 2rem 0 0; font-size: clamp(1rem, 1.5vw, 1.25rem); color: rgba(255,255,255,.77); }
.hero-actions { display: flex; gap: 2rem; align-items: center; margin-top: 2.5rem; }
.button { min-height: 54px; display: inline-flex; align-items: center; justify-content: space-between; gap: 2.5rem; padding: .95rem 1.35rem; border: 0; border-radius: 2px; text-decoration: none; text-transform: uppercase; font-size: .72rem; letter-spacing: .13em; font-weight: 700; cursor: pointer; transition: all .25s ease; }
.button-primary { color: #000; background: var(--acid); }
.button-primary:hover { background: var(--gold-soft); transform: translateY(-2px); box-shadow: 0 10px 25px rgba(197,248,42,.3); }
.text-link { color: var(--white); font-size: .76rem; text-transform: uppercase; letter-spacing: .14em; text-underline-offset: .5rem; }
.text-link:hover, .direct-contact a:hover, .whatsapp-link:hover { color: var(--acid); }
.hero-stamp { position: absolute; z-index: 2; right: 5vw; bottom: 8vh; width: 130px; height: 130px; display: grid; place-items: center; }
.hero-stamp svg { position: absolute; inset: 0; animation: spin 18s linear infinite; }
.hero-stamp text { fill: var(--white); font-family: var(--sans); font-size: 8px; letter-spacing: 2.4px; }
.hero-stamp > span { color: var(--acid); font-family: var(--serif); font-size: 2.1rem; }
@keyframes spin { to { transform: rotate(360deg); } }
.sound-line { position: absolute; z-index: 2; right: 5vw; top: 29%; display: flex; align-items: center; gap: 4px; height: 45px; }
.sound-line i { width: 2px; height: 8px; background: var(--acid); animation: equalize 1s ease-in-out infinite alternate; }
.sound-line i:nth-child(3n) { animation-delay: -.4s; }.sound-line i:nth-child(2n) { animation-delay: -.7s; }.sound-line i:nth-child(5n) { animation-delay: -.2s; }
@keyframes equalize { to { height: 42px; } }

.proof-strip { display: grid; grid-template-columns: repeat(3, 1fr); color: var(--white); background: #0c0e08; border-top: 1px solid rgba(197,248,42,.18); border-bottom: 1px solid rgba(197,248,42,.18); }
.proof-strip > div { min-height: 150px; display: flex; align-items: center; gap: 1rem; padding: 2rem clamp(1.2rem, 4vw, 4rem); border-right: 1px solid rgba(255,255,255,.09); }
.proof-strip > div:last-child { border-right: 0; }
.proof-strip strong { color: var(--acid); font-family: var(--serif); font-size: clamp(2.4rem, 4vw, 4.5rem); font-weight: 400; line-height: 1; }
.proof-strip span { max-width: 130px; color: var(--violet-bright); text-transform: uppercase; font-size: .68rem; line-height: 1.4; letter-spacing: .13em; font-weight: 700; }

.clients { padding: clamp(4rem, 7vw, 7rem) clamp(1.2rem, 5vw, 5.5rem) 0; color: var(--white); background: #080808; border-top: 1px solid var(--line); }
.clients-heading { display: flex; align-items: end; justify-content: space-between; gap: 3rem; padding-bottom: 2rem; }
.clients-heading .kicker { margin: 0; color: var(--acid); }
.clients-heading h2 { max-width: 670px; margin: 0; font-family: var(--serif); font-size: clamp(2.4rem, 4.5vw, 5rem); font-weight: 400; line-height: .98; letter-spacing: -.035em; text-align: right; }
.client-logos { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid rgba(197,248,42,.28); box-shadow: 0 22px 70px rgba(0,0,0,.34); }
.client-logo { min-width: 0; height: 150px; display: flex; align-items: center; justify-content: center; gap: .7rem; padding: 2rem clamp(1rem, 2.5vw, 2.5rem); border-right: 1px solid rgba(197,248,42,.2); border-bottom: 1px solid rgba(197,248,42,.2); background: #fff; transition: all .25s ease; }
.client-logo:nth-child(4n) { border-right: 0; }
.client-logo:nth-last-child(-n+4) { border-bottom: 0; }
.client-logo:hover { position: relative; z-index: 1; transform: translateY(-4px); background: #fffdf4; box-shadow: 0 12px 30px rgba(197,248,42,.12); }
.client-logo img { width: 100%; max-width: 170px; max-height: 58px; object-fit: contain; }
.client-logo.standard-bank { background: #0033a1; }
.client-logo.standard-bank:hover { background: #00277d; }
.client-logo.absa img { max-width: 66px; max-height: 66px; }
.client-logo.discovery img { width: 46px; height: 46px; object-fit: cover; object-position: center; border-radius: 50%; }
.client-logo.discovery { color: #111; }
.client-logo.discovery strong { font-family: Arial, sans-serif; font-size: 1.15rem; letter-spacing: -.04em; }
.client-logo.dark-logo { background: #171717; }
.client-logo.dark-logo:hover { background: #292929; }
.client-logo.news-cafe img { max-width: 155px; }
.client-logo.emperors-palace img { max-width: 100px; max-height: 78px; }
.client-wordmark { display: flex; flex-direction: column; align-items: center; color: #102f5c; line-height: 1; }
.client-wordmark strong { font-family: Georgia, serif; font-size: 1.65rem; letter-spacing: .08em; }
.client-wordmark span { margin-top: .42rem; font-size: .55rem; text-transform: uppercase; letter-spacing: .18em; }
.clients-note { margin: 0; padding: 1rem 0; color: rgba(255,255,255,.48); font-size: .62rem; text-transform: uppercase; letter-spacing: .13em; text-align: right; }

.section-pad { padding: clamp(5rem, 10vw, 10rem) clamp(1.2rem, 5vw, 5.5rem); }
.section-index { font-size: .66rem; text-transform: uppercase; letter-spacing: .18em; font-weight: 700; opacity: .55; }
.intro { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr); grid-template-areas: "index index" "copy image"; column-gap: clamp(3rem, 6vw, 7rem); row-gap: clamp(2rem, 3vw, 3rem); align-items: start; color: var(--white); background-color: var(--ink); background-image: radial-gradient(rgba(197,248,42,.045) 1px, transparent 1px); background-size: 34px 34px; }
.intro > .section-index { grid-area: index; padding-bottom: 1.25rem; border-bottom: 1px solid var(--line); }
.intro-copy { grid-area: copy; max-width: 780px; }
.intro-copy h2, .section-heading h2, .contact h2 { margin: 0; font-size: clamp(3.7rem, 7vw, 7.5rem); }
.intro-copy h2 em, .section-heading h2 em, .contact h2 em { color: var(--acid); }
.intro-copy > p:last-child { margin: 2.5rem 0 0; max-width: 670px; color: var(--muted); font-size: clamp(1rem, 1.4vw, 1.22rem); }
.intro-image { grid-area: image; width: 100%; max-width: 440px; margin: 3rem 0 0; justify-self: start; }
.intro-image img { width: 100%; height: clamp(340px, 30vw, 400px); object-fit: cover; object-position: center 15%; filter: saturate(.76) contrast(1.08); border: 1px solid rgba(197,248,42,.34); box-shadow: 0 24px 55px rgba(0,0,0,.42); }
.intro-image figcaption { margin-top: .75rem; color: rgba(255,255,255,.58); font-size: .68rem; text-transform: uppercase; letter-spacing: .14em; }

.services { color: var(--white); background-color: var(--surface); background-image: radial-gradient(rgba(197,248,42,.045) 1px, transparent 1px); background-size: 34px 34px; }
.section-heading { display: grid; grid-template-columns: .6fr 2.6fr; gap: 2rem; margin-bottom: clamp(4rem, 8vw, 8rem); }
.section-heading h2 { color: var(--white); }
.section-heading h2 em { color: var(--acid); }
.service-list { border-top: 1px solid rgba(197,248,42,.28); }
.service-card { position: relative; display: grid; grid-template-columns: .6fr 2fr .3fr; gap: 2rem; align-items: center; min-height: 180px; padding: 2rem 0; border-bottom: 1px solid rgba(197,248,42,.22); transition: all .25s ease; }
.card-cover { position: absolute; inset: 0; z-index: 2; border: 0; }
.card-cover:focus-visible { outline-offset: -4px; }
.service-card:not(.featured):hover { padding-left: 1.5rem; padding-right: 1.5rem; background: rgba(197,248,42,.045); }
.service-icon { transition: transform .25s ease, color .25s ease; }
.service-number { font-size: .67rem; text-transform: uppercase; letter-spacing: .16em; color: var(--acid); }
.service-card h3 { margin: 0; font-family: var(--serif); font-size: clamp(2.4rem, 4.5vw, 5rem); font-weight: 400; line-height: 1; }
.service-card p { max-width: 630px; color: var(--muted); }
.service-icon { justify-self: end; font-size: 2.5rem; color: var(--acid); }
.service-card.featured { margin-top: 1.5rem; padding: 2.5rem 2rem; border: 1px solid var(--gold-soft); color: #000; background: linear-gradient(135deg, var(--gold-soft), var(--acid)); box-shadow: 0 20px 55px rgba(197,248,42,.14); }
.service-card.featured .service-number, .service-card.featured .service-icon { color: var(--ink); }
.service-card.featured p { color: rgba(11,11,11,.7); }
.service-card.featured .mini-label { margin-bottom: 1rem; }

.manifesto { min-height: 850px; display: grid; grid-template-columns: 1fr 1fr; background: linear-gradient(135deg, #0e140a 0%, var(--surface) 42%, #080808 100%); color: var(--white); border-top: 1px solid rgba(197,248,42,.22); border-bottom: 1px solid rgba(197,248,42,.22); }
.manifesto-image { min-height: 650px; overflow: hidden; }
.manifesto-image img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.72) contrast(1.12) sepia(.08); transition: transform .8s, filter .8s; }
.manifesto:hover .manifesto-image img { transform: scale(1.025); }
.manifesto-copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(3rem, 7vw, 8rem); }
.manifesto-copy .kicker { color: var(--violet-bright); }
blockquote { margin: 1rem 0 4rem; font-size: clamp(3rem, 5vw, 5.5rem); }
blockquote em { color: var(--acid); text-shadow: 0 0 20px rgba(197,248,42,.16); }
.manifesto ul { list-style: none; padding: 0; margin: 0; border-top: 1px solid rgba(255,255,255,.2); }
.manifesto li { display: flex; gap: 2rem; padding: 1rem 0; border-bottom: 1px solid rgba(255,255,255,.2); font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; }
.manifesto li span { color: var(--acid); }

.gallery { color: var(--white); background: #080808; }
.gallery .section-heading h2 { color: var(--white); }
.gallery .section-heading h2 em { color: var(--acid); }
.gallery-grid { display: grid; grid-template-columns: repeat(12, 1fr); grid-auto-rows: minmax(160px, 16vw); gap: 1rem; }
.gallery-item { position: relative; grid-column: span 4; grid-row: span 2; border: 1px solid rgba(197,248,42,.18); padding: 0; background: var(--ink); overflow: hidden; cursor: zoom-in; text-align: left; transition: border-color .25s, box-shadow .25s; }
.gallery-item.wide { grid-column: span 8; }
.gallery-item.tall { grid-row: span 3; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.72) contrast(1.05); transition: transform .7s cubic-bezier(.2,.8,.2,1), filter .4s; }
.gallery-item:hover { border-color: rgba(197,248,42,.7); box-shadow: 0 18px 45px rgba(0,0,0,.42); }
.gallery-item:hover img { transform: scale(1.045); filter: saturate(.95) contrast(1.06); }
.gallery-item span { position: absolute; left: 1rem; bottom: 1rem; color: var(--acid); border: 1px solid rgba(197,248,42,.3); background: rgba(5,5,5,.78); backdrop-filter: blur(7px); padding: .5rem .65rem; font-size: .62rem; text-transform: uppercase; letter-spacing: .13em; }
.gallery-quality-note { max-width: 620px; margin: 2rem 0 0 auto; color: rgba(255,255,255,.54); font-size: .75rem; text-transform: uppercase; letter-spacing: .13em; text-align: right; }

.process { color: var(--white); background: linear-gradient(135deg, #0e140a 0%, #080808 58%, #111111 100%); }
.process .section-heading h2 { color: var(--white); }
.process .section-heading h2 em { color: var(--acid); }
.process-steps { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid rgba(197,248,42,.38); border-bottom: 1px solid rgba(197,248,42,.38); }
.process-steps li { min-height: 290px; padding: 2rem; border-right: 1px solid rgba(197,248,42,.28); transition: background .25s ease; }
.process-steps li:hover { background: rgba(197,248,42,.045); }
.process-steps li:last-child { border-right: 0; }
.process-steps span { display: block; color: var(--acid); font-size: .7rem; font-weight: 700; }
.process-steps h3 { margin: 4rem 0 1rem; font-family: var(--serif); font-size: 3rem; font-weight: 400; }
.process-steps p { max-width: 360px; color: var(--muted); }

.contact { display: grid; grid-template-columns: 1fr .9fr; gap: clamp(3rem, 9vw, 10rem); color: var(--white); background-color: var(--ink); background-image: radial-gradient(rgba(197,248,42,.045) 1px, transparent 1px); background-size: 34px 34px; border-top: 1px solid var(--line); }
.contact .section-index { margin-bottom: 7rem; }
.contact .kicker { color: var(--acid); }
.contact h2 em { color: var(--acid); }
.contact-intro > p:not(.kicker) { max-width: 540px; color: var(--muted); }
.direct-contact { display: flex; flex-direction: column; align-items: flex-start; gap: .3rem; margin-top: 3rem; }
.direct-contact a { color: var(--white); text-underline-offset: .3rem; }
.contact-form { align-self: end; }
.contact-form label { display: block; margin-bottom: 1.6rem; }
.contact-form label > span { display: block; margin-bottom: .5rem; font-size: .67rem; text-transform: uppercase; letter-spacing: .15em; color: rgba(197,248,42,.72); }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 0; border-bottom: 1px solid rgba(197,248,42,.32); border-radius: 0; padding: .7rem 0; color: var(--white); background: transparent; outline: 0; transition: border-color .25s, box-shadow .25s; }
.contact-form select { color-scheme: dark; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--acid); box-shadow: 0 8px 18px -16px rgba(197,248,42,.75); }
.contact-form textarea { resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-note { margin: .75rem 0 0; font-size: .66rem; color: rgba(255,255,255,.42); }

.site-footer { padding: 5rem clamp(1.2rem, 5vw, 5.5rem) 2rem; color: var(--white); background: var(--surface); border-top: 1px solid rgba(197,248,42,.52); }
.footer-main { display: grid; grid-template-columns: minmax(240px, 1.6fr) repeat(4, minmax(130px, 1fr)); gap: clamp(2rem, 4vw, 5rem); padding-bottom: 4rem; }
.footer-brand-column { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 1.6rem; }
.footer-brand-column .brand-large { max-width: 100%; font-size: clamp(1.35rem, 1.6vw, 1.75rem); white-space: nowrap; }
.site-footer .brand-x { color: var(--acid); opacity: 1; }
.brand-large .brand-tag { font-size: .6rem; }
.footer-brand-column p { max-width: 360px; margin: 0; color: var(--muted); }
.footer-column { display: flex; flex-direction: column; align-items: flex-start; gap: .55rem; }
.footer-column h3 { margin: .35rem 0 1rem; color: var(--violet-bright); font-size: .65rem; text-transform: uppercase; letter-spacing: .18em; }
.footer-column a { color: var(--muted); font-size: .78rem; text-decoration: none; text-underline-offset: .3rem; transition: color .25s ease; }
.footer-column a:hover { color: var(--acid); }
.footer-contact address { margin-top: .7rem; font-style: normal; font-size: .75rem; line-height: 1.7; opacity: .68; }
.footer-social-row { display: flex; align-items: center; justify-content: space-between; gap: 2rem; padding: 1.5rem 0; border-top: 1px solid rgba(197,248,42,.28); }
.footer-social-row > span { font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; }
.footer-top { display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: end; gap: 3rem; padding-bottom: 5rem; }
.brand-large { font-size: clamp(1.5rem, 3vw, 3rem); }
.footer-top p { max-width: 450px; margin: 0; }
.whatsapp-link { justify-self: end; text-transform: uppercase; font-size: .72rem; letter-spacing: .13em; font-weight: 700; text-underline-offset: .5rem; }
.footer-connect { justify-self: end; display: flex; flex-direction: column; align-items: flex-end; gap: 1.5rem; }
.footer-social { display: flex; border: 1px solid rgba(197,248,42,.34); }
.footer-social a { width: 42px; height: 42px; border-top: 0; border-right: 1px solid rgba(197,248,42,.26); }
.footer-social a:last-child { border-right: 0; }
.footer-social a:hover { background: var(--acid); color: #000; transform: translateY(-3px); }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 1.5rem; border-top: 1px solid rgba(197,248,42,.28); color: rgba(255,255,255,.62); font-size: .67rem; text-transform: uppercase; letter-spacing: .12em; }
.footer-bottom a { transition: color .25s ease; }
.footer-bottom a:hover { color: var(--acid); }
.footer-credit span { display: inline-block; margin: 0 .12rem; font-size: .85rem; }
.footer-credit .credit-heart { color: var(--acid); line-height: 0; }
.footer-credit .credit-heart svg { width: 1em; height: 1em; vertical-align: -.14em; }

.lightbox { width: min(92vw, 1200px); max-height: 90vh; padding: 0; border: 1px solid rgba(197,248,42,.42); background: var(--ink); overflow: visible; box-shadow: 0 30px 100px rgba(0,0,0,.62); }
.lightbox::backdrop { background: rgba(0,0,0,.88); backdrop-filter: blur(8px); }
.lightbox img { width: 100%; max-height: 86vh; object-fit: contain; }
.lightbox button { position: absolute; right: 0; top: -3rem; width: 2.5rem; height: 2.5rem; border: 1px solid rgba(255,255,255,.6); border-radius: 50%; color: var(--white); background: transparent; cursor: pointer; font-size: 1.4rem; }

a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 2px solid var(--acid); outline-offset: 4px; }

.reveal { opacity: 0; transform: translateY(32px); transition: opacity .75s ease, transform .75s cubic-bezier(.2,.75,.25,1); }
.reveal.in-view { opacity: 1; transform: none; }

@media (max-width: 1120px) {
  .footer-main { grid-template-columns: repeat(3, 1fr); }
  .footer-brand-column { grid-column: 1/-1; }
  .footer-brand-column .brand-large { font-size: 1.75rem; }
}

@media (max-width: 900px) {
  .site-header { height: 72px; }
  .menu-toggle { display: block; width: 42px; height: 42px; padding: 12px 8px; border: 0; background: transparent; }
  .menu-toggle span:not(.sr-only) { display: block; height: 1px; background: currentColor; margin: 5px 0; transition: transform .25s; }
  .menu-toggle[aria-expanded="true"] span:first-child { transform: translateY(3px) rotate(45deg); }
  .menu-toggle[aria-expanded="true"] span:nth-child(2) { transform: translateY(-3px) rotate(-45deg); }
  .site-nav { position: fixed; inset: 72px 0 auto; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 1rem 1.2rem 2rem; background: rgba(5,5,5,.98); border-bottom: 1px solid rgba(197,248,42,.34); }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 1rem 0; border-bottom: 1px solid rgba(197,248,42,.18); }
  .nav-cta { border: 0; border-bottom: 0 !important; border-radius: 0; color: var(--acid) !important; }
  .hero { min-height: 900px; padding-bottom: 5rem; }
  .hero-media::after { background: linear-gradient(0deg, var(--ink) 12%, rgba(5,5,5,.9) 38%, rgba(197,248,42,.06) 100%); }
  .hero-media img { width: 100%; height: 72%; object-position: center 28%; }
  .hero-content { width: 100%; }
  .hero-stamp { display: none; }
  .sound-line { right: 1.2rem; top: 7rem; }
  .proof-strip { grid-template-columns: 1fr; }
  .proof-strip > div { min-height: 110px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.09); }
  .proof-strip > div:last-child { border-bottom: 0; }
  .clients-heading { align-items: flex-start; flex-direction: column; }
  .clients-heading h2 { text-align: left; }
  .client-logos { grid-template-columns: repeat(2, 1fr); }
  .client-logo { border-bottom: 1px solid var(--line); }
  .client-logo:nth-child(4n) { border-right: 1px solid var(--line); }
  .client-logo:nth-last-child(-n+4) { border-bottom: 1px solid var(--line); }
  .client-logo:nth-child(2n) { border-right: 0; }
  .client-logo:nth-last-child(-n+2) { border-bottom: 0; }
  .intro { grid-template-columns: 1fr; grid-template-areas: "index" "copy" "image"; row-gap: 2rem; }
  .intro-image { max-width: none; margin-top: 1rem; justify-self: stretch; }
  .intro-image img { height: min(84vw, 500px); }
  .section-heading { grid-template-columns: 1fr; }
  .service-card { grid-template-columns: .4fr 2fr .2fr; }
  .manifesto { grid-template-columns: 1fr; }
  .manifesto-image { min-height: 560px; }
  .gallery-grid { grid-auto-rows: minmax(150px, 34vw); }
  .gallery-item, .gallery-item.wide { grid-column: span 6; }
  .process-steps { grid-template-columns: 1fr; }
  .process-steps li { min-height: 230px; border-right: 0; border-bottom: 1px solid rgba(197,248,42,.28); }
  .process-steps li:last-child { border-bottom: 0; }
  .process-steps h3 { margin-top: 2rem; }
  .contact { grid-template-columns: 1fr; }
  .contact .section-index { margin-bottom: 4rem; }
  .footer-top { grid-template-columns: 1fr; align-items: start; }
  .footer-main { grid-template-columns: repeat(2, 1fr); }
  .footer-brand-column { grid-column: 1/-1; }
  .whatsapp-link { justify-self: start; }
  .footer-connect { justify-self: start; align-items: flex-start; }
}

@media (max-width: 600px) {
  h1 { font-size: clamp(3.4rem, 17vw, 5rem); }
  .hero { min-height: 820px; }
  .social-rail { display: none; }
  .social-rail-label { display: none; }
  .social-rail a { width: 42px; height: 42px; border-top: 1px solid rgba(255,255,255,.16); border-right: 0; }
  .social-rail a:first-of-type { border-top: 0; }
  .whatsapp-bubble { right: 1rem; bottom: 1rem; width: 58px; height: 58px; min-height: 58px; padding: 0; justify-content: center; }
  .whatsapp-bubble span { display: none; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 1.4rem; }
  .intro-copy h2, .section-heading h2, .contact h2 { font-size: clamp(3.2rem, 15vw, 4.8rem); }
  .service-card { grid-template-columns: 1fr auto; gap: 1rem; padding: 2rem 0; }
  .service-card .service-number { grid-column: 1/-1; }
  .service-card h3 { font-size: 2.8rem; }
  .manifesto-image { min-height: 450px; }
  .manifesto-copy { padding: 4rem 1.2rem; }
  blockquote { font-size: 3.1rem; }
  .gallery-grid { display: block; }
  .gallery-item { width: 100%; height: 310px; margin-bottom: .8rem; }
  .gallery-item.tall { height: 430px; }
  .gallery-quality-note { text-align: left; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .footer-bottom { flex-direction: column; gap: .8rem; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-brand-column { grid-column: auto; }
  .footer-social-row { align-items: flex-start; flex-direction: column; }
  .footer-social { flex-wrap: wrap; }
  .client-logo { height: 120px; padding: 1.5rem; }
  .client-logos { grid-template-columns: 1fr; }
  .client-logo, .client-logo:nth-child(2n), .client-logo:nth-child(4n) { border-right: 0; border-bottom: 1px solid var(--line); }
  .client-logo:nth-last-child(-n+2) { border-bottom: 1px solid var(--line); }
  .client-logo:last-child { border-bottom: 0; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

/* ============================================================
   LIGHT THEME — body sections below the hero
   Dark hero + dark footer act as bookends; everything between
   is a warm "paper" palette. Bright lime stays for fills;
   --acid-ink is the accessible deep-lime for text on light.
   ============================================================ */

/* CLIENTS */
.clients { color: var(--ink-900); background: var(--paper-100); border-top: 1px solid var(--hair); }
.clients-heading .kicker { color: var(--acid-ink); }
.client-logos { border: 1px solid var(--hair); box-shadow: 0 24px 60px rgba(18,18,16,.10); }
.client-logo { border-right: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.client-logo:hover { box-shadow: 0 12px 30px rgba(18,18,16,.12); }
.clients-note { color: rgba(18,18,16,.5); }

/* Light-section labels use the deep violet (bright violet is too light on stone) */
.intro .kicker, .services .kicker, .process .kicker, .contact .kicker, .clients-heading .kicker { color: var(--acid-ink); }

/* INTRO */
.intro { color: var(--ink-900); background-color: var(--paper-100); background-image: radial-gradient(rgba(18,18,16,.05) 1px, transparent 1px); }
.intro-copy h2 em { color: var(--acid-ink); }
.intro-copy > p:last-child { color: var(--ink-600); }
.intro-image img { border: 1px solid var(--hair); box-shadow: 0 24px 55px rgba(18,18,16,.16); }
.intro-image figcaption { color: rgba(18,18,16,.55); }

/* SERVICES */
.services { color: var(--ink-900); background-color: var(--paper-200); background-image: radial-gradient(rgba(18,18,16,.05) 1px, transparent 1px); }
.section-heading h2 { color: var(--ink-900); }
.section-heading h2 em { color: var(--acid-ink); }
.service-list { border-top: 1px solid var(--hair); }
.service-card { border-bottom: 1px solid var(--hair); }
/* branded row hover: lime energy bar + faint violet wash + icon slide */
.service-card:not(.featured):hover { background: rgba(109,40,217,.045); box-shadow: inset 4px 0 0 var(--acid); padding-left: 1.75rem; }
.service-card:not(.featured):hover .service-icon { transform: translateX(8px); }
/* signature card lifts toward you instead of staying inert */
.service-card.featured:hover { transform: translateY(-4px); box-shadow: 0 28px 64px rgba(197,248,42,.30); }
.service-number { color: var(--acid-ink); }
.service-card p { color: var(--ink-600); }
.service-icon { color: var(--acid-ink); }
/* featured card keeps its bright lime fill + black text as a pop */
.service-card.featured { color: #000; border-color: var(--gold-soft); }
.service-card.featured .service-number, .service-card.featured .service-icon { color: var(--ink); }

/* MANIFESTO + GALLERY stay DARK on purpose — the "stage" panels:
   the manifesto is the emotional thesis, and photos glow against dark. */

/* PROCESS */
.process { color: var(--ink-900); background: linear-gradient(135deg, var(--paper-200) 0%, var(--paper-100) 58%, var(--paper-200) 100%); }
.process .section-heading h2 { color: var(--ink-900); }
.process .section-heading h2 em { color: var(--acid-ink); }
.process-steps { border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.process-steps li { border-right: 1px solid var(--hair); }
.process-steps li:hover { background: rgba(18,18,16,.03); }
.process-steps span { color: var(--acid-ink); }
.process-steps p { color: var(--ink-600); }

/* CONTACT */
.contact { color: var(--ink-900); background-color: var(--paper-100); background-image: radial-gradient(rgba(18,18,16,.05) 1px, transparent 1px); border-top: 1px solid var(--hair); }
.contact .kicker { color: var(--acid-ink); }
.contact h2 em { color: var(--acid-ink); }
.contact-intro > p:not(.kicker) { color: var(--ink-600); }
.direct-contact a { color: var(--ink-900); }
.direct-contact a:hover, .text-link:hover { color: var(--acid-ink); }
.contact-form label > span { color: var(--acid-ink); }
.contact-form input, .contact-form select, .contact-form textarea { color: var(--ink-900); border-bottom: 1px solid var(--hair); }
.contact-form select { color-scheme: light; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--acid-ink); box-shadow: 0 8px 18px -16px rgba(18,18,16,.6); }
.form-note { color: rgba(18,18,16,.5); }
/* brief violet pulse when a service card pre-fills the event type */
@keyframes fieldPreset { from { box-shadow: 0 7px 18px -10px rgba(109,40,217,.95); } to { box-shadow: 0 7px 18px -10px rgba(109,40,217,0); } }
.field-preset select { animation: fieldPreset 1.5s ease-out; border-bottom-color: var(--acid-ink); }

/* Mobile light-section borders (override the responsive lime hairlines) */
@media (max-width: 900px) {
  .process-steps li { border-bottom: 1px solid var(--hair); }
}

/* ============================================================
   CONTACT — the conversion moment.
   Elevated form card on a warm, glowing light surface.
   ============================================================ */
.contact {
  align-items: start;
  background-color: #f4f3ee;
  background-image:
    radial-gradient(120% 90% at 100% 0%, rgba(197,248,42,.12), transparent 55%),
    radial-gradient(90% 80% at 0% 100%, rgba(109,40,217,.08), transparent 55%),
    radial-gradient(rgba(18,18,16,.045) 1px, transparent 1px);
  background-size: 100% 100%, 100% 100%, 34px 34px;
}
.contact .section-index { margin-bottom: 2.25rem; }

.contact-assurance { list-style: none; padding: 0; margin: 2.5rem 0 0; display: grid; gap: 1rem; }
.contact-assurance li { display: flex; align-items: center; gap: .85rem; font-size: .92rem; line-height: 1.4; color: var(--ink-600); }
.contact-assurance li strong { color: var(--ink-900); font-weight: 600; }
.contact-assurance .tick { flex: none; display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: var(--acid); color: var(--ink-900); font-size: .78rem; font-weight: 700; }

.contact-form {
  align-self: start;
  background: #ffffff;
  border: 1px solid var(--hair);
  border-top: 3px solid var(--acid);
  border-radius: 16px;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  box-shadow: 0 32px 70px -34px rgba(20,21,15,.42), 0 4px 14px -10px rgba(20,21,15,.18);
}
.contact-form label { margin-bottom: 1.15rem; }
.contact-form label > span { color: var(--acid-ink); margin-bottom: .55rem; }

.contact-form input,
.contact-form select,
.contact-form textarea {
  border: 1px solid rgba(20,21,15,.16);
  border-radius: 10px;
  background: #f7f7f2;
  padding: .8rem 1rem;
  min-height: 52px;
  color: var(--ink-900);
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.contact-form textarea { min-height: 112px; }
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: rgba(20,21,15,.42); }
.contact-form input:hover,
.contact-form select:hover,
.contact-form textarea:hover { border-color: rgba(20,21,15,.32); }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  border-color: var(--acid-ink);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(109,40,217,.16);
}

.contact-form .button-primary {
  width: 100%;
  justify-content: center;
  gap: .6rem;
  min-height: 58px;
  margin-top: .5rem;
}
.contact-form .form-note { color: rgba(20,21,15,.5); text-align: center; }

/* field pre-fill pulse — matches the new focus ring */
@keyframes fieldPreset { from { box-shadow: 0 0 0 3px rgba(109,40,217,.45); } to { box-shadow: 0 0 0 3px rgba(109,40,217,0); } }
.field-preset select { animation: fieldPreset 1.6s ease-out; border-color: var(--acid-ink); }

/* ============================================================
   SERVICE CARDS — black cards floating on the light section.
   Lime returns as the title/number colour; Signature stays lime.
   ============================================================ */
.service-list { border-top: 0; display: grid; gap: 1rem; }
.service-card { position: relative; min-height: 0; align-items: center;
  background: #14150f; color: var(--white);
  border: 1px solid rgba(255,255,255,.09); border-radius: 16px;
  padding: clamp(1.6rem,3vw,2.3rem) clamp(1.6rem,3vw,2.5rem);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease, background .25s ease; }
.service-card .service-number { color: var(--acid); }
.service-card h3 { color: var(--white); }
.service-card p { color: var(--muted); }
.service-card .service-icon { color: var(--violet-bright); }
.service-card:not(.featured):hover { transform: translateY(-4px); background: #181910;
  border-color: rgba(197,248,42,.5); box-shadow: 0 24px 52px -26px rgba(0,0,0,.75);
  padding-left: clamp(1.6rem,3vw,2.5rem); }
.service-card:not(.featured):hover .service-icon { transform: translateX(8px); color: var(--acid); }
/* Signature card keeps its bright lime fill and detonates against the dark ones */
.service-card.featured { margin-top: .25rem; border-radius: 16px; border-color: var(--gold-soft); }
.service-card.featured .service-number, .service-card.featured .service-icon { color: var(--ink); }
.service-card.featured h3 { color: var(--ink); }
.service-card.featured p { color: rgba(5,5,5,.8); }
.service-card.featured:hover { transform: translateY(-4px); box-shadow: 0 28px 64px -22px rgba(197,248,42,.55); }

/* ============================================================
   PROCESS — connected journey: linked cards, numbered nodes,
   ghosted numerals, a DJ-flavoured icon per step, hover lift.
   ============================================================ */
.process-steps { position: relative; display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; border: 0; }
.process-steps li { position: relative; min-height: 0; padding: 2.25rem 2rem;
  background: #fff; border: 1px solid var(--hair); border-radius: 16px;
  box-shadow: 0 18px 44px -28px rgba(20,21,15,.42); overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.process-steps li:hover { transform: translateY(-6px); border-color: rgba(20,21,15,.22);
  box-shadow: 0 28px 58px -26px rgba(20,21,15,.5); background: #fff; }
.process-steps .step-num { position: absolute; top: .2rem; right: 1.1rem; z-index: 0;
  font-family: var(--serif); font-size: 5.5rem; line-height: 1; font-weight: 400;
  color: rgba(109,40,217,.08); pointer-events: none; }
.process-steps .step-node { position: relative; z-index: 1; display: grid; place-items: center;
  width: 52px; height: 52px; margin: 0 0 1.4rem; border-radius: 50%;
  background: #fff; border: 2px solid var(--acid); color: var(--acid-ink); }
.process-steps .step-icon { width: 23px; height: 23px; }
.process-steps h3 { position: relative; z-index: 1; margin: 0 0 .55rem;
  font-family: var(--serif); font-size: 2rem; font-weight: 400; color: var(--ink-900); }
.process-steps p { position: relative; z-index: 1; max-width: 340px; color: var(--ink-600); }
/* connector line bridging cards at node height (desktop) */
.process-steps li:not(:last-child)::after { content: ""; position: absolute; top: 62px; right: -2rem;
  width: 2rem; height: 2px; z-index: 2; background: linear-gradient(90deg, var(--acid), rgba(197,248,42,.2)); }

@media (max-width: 900px) {
  .process-steps { grid-template-columns: 1fr; }
  .process-steps li:not(:last-child)::after { display: none; }
}

/* ============================================================
   LIGHT-BODY VERTICAL FLOW
   One continuous warm ramp: pure white at the top, easing into
   a soft warm taupe toward the footer. Each light section hands
   its bottom colour to the next one's top, so seams disappear.
   (The dark manifesto + gallery interrupt, then it resumes.)
   ============================================================ */
.intro {
  background-color: #ffffff;
  background-image:
    radial-gradient(rgba(18,18,16,.045) 1px, transparent 1px),
    linear-gradient(180deg, #ffffff 0%, #f6f4ef 100%);
  background-size: 34px 34px, 100% 100%;
}
.services {
  background-color: #f6f4ef;
  background-image:
    radial-gradient(rgba(18,18,16,.05) 1px, transparent 1px),
    linear-gradient(180deg, #f6f4ef 0%, #efebe3 100%);
  background-size: 34px 34px, 100% 100%;
}
.process {
  background: linear-gradient(180deg, #efebe3 0%, #e9e4db 100%);
}
.contact {
  background-color: #e9e4db;
  background-image:
    radial-gradient(120% 90% at 100% 0%, rgba(197,248,42,.14), transparent 55%),
    radial-gradient(90% 80% at 0% 100%, rgba(109,40,217,.09), transparent 55%),
    radial-gradient(rgba(18,18,16,.05) 1px, transparent 1px),
    linear-gradient(180deg, #e9e4db 0%, #e4dfd5 100%);
  background-size: 100% 100%, 100% 100%, 34px 34px, 100% 100%;
}
.clients {
  background: linear-gradient(180deg, #e4dfd5 0%, #ded8ce 100%);
}
