/* =========================================================
   Laylosh — minimalist creative-agency redesign
   Inspired by Cunnet's structural language; brand stays pink.
   ========================================================= */

:root {
    --pink: #FF66C4;
    --pink-ink: #D93BA4;
    --ink: #101014;
    --ink-2: #3A3A42;
    --muted: #7A7A82;
    --line: #E8E8EC;
    --bg: #FAFAFA;
    --bg-2: #F1F1F3;
    --white: #FFFFFF;

    --font-head: 'Garet', 'Inter', system-ui, -apple-system, sans-serif;
    --font-body: 'Open Sauce Sans', 'Inter', system-ui, -apple-system, sans-serif;

    --radius-pill: 999px;
    --radius-card: 18px;
    --radius-img: 14px;

    --shadow-soft: 0 2px 14px rgba(16, 16, 20, .06);
    --shadow-hover: 0 10px 40px rgba(16, 16, 20, .10);

    --ease-out: cubic-bezier(.22, 1, .36, 1);
    --ease-in-out: cubic-bezier(.65, 0, .35, 1);

    --container: 1320px;
    --gutter: clamp(1.25rem, 3vw, 2.25rem);
    --section-y: clamp(4rem, 9vw, 8rem);
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font-family: var(--font-body);
    font-size: 17px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

h1, h2, h3, h4, h5 {
    font-family: var(--font-head);
    font-weight: 900;
    line-height: 1.02;
    letter-spacing: -0.03em;
    margin: 0 0 .6em;
    color: var(--ink);
}
h1 { font-size: clamp(2.8rem, 8vw, 7.5rem); }
h2 { font-size: clamp(2rem, 5vw, 4.25rem); }
h3 { font-size: clamp(1.5rem, 2.5vw, 2.2rem); }
h4 { font-size: 1.25rem; letter-spacing: -0.01em; }
p  { margin: 0 0 1rem; }
p.lede { font-size: clamp(1.05rem, 1.4vw, 1.3rem); color: var(--ink-2); max-width: 58ch; }
em { font-style: italic; color: var(--pink); font-weight: 400; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: var(--section-y) 0; }
.section--tight { padding: clamp(2.5rem, 5vw, 4.5rem) 0; }
.section--dark { background: #120616; color: var(--white); position: relative; overflow: hidden; isolation: isolate; }
.section--dark > .container { position: relative; z-index: 2; }
.section--dark__bg {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 60% 50% at 15% 20%, rgba(255,51,187,.35), transparent 60%),
        radial-gradient(ellipse 55% 45% at 85% 80%, rgba(176,133,255,.28), transparent 60%),
        radial-gradient(ellipse 45% 40% at 70% 15%, rgba(70,227,247,.18), transparent 60%),
        linear-gradient(135deg, #1A0826 0%, #120616 60%, #1A0826 100%);
    background-size: 160% 160%, 180% 180%, 140% 140%, 100% 100%;
    animation: darkBgShift 18s ease-in-out infinite alternate;
}
.section--dark__bg::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, #000 40%, transparent 100%);
    -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, #000 40%, transparent 100%);
    opacity: .6;
}
@keyframes darkBgShift {
    0%   { background-position: 0% 0%, 100% 100%, 50% 0%, 0 0; }
    100% { background-position: 100% 50%, 0% 30%, 30% 90%, 0 0; }
}
@media (prefers-reduced-motion: reduce) {
    .section--dark__bg { animation: none; }
}
.section--dark h1, .section--dark h2, .section--dark h3 { color: var(--white); }
.section--dark p, .section--dark .lede { color: rgba(255,255,255,.72); }
.section--dark em { color: var(--pink); }

.section-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 2rem; margin-bottom: clamp(2rem, 4vw, 3.5rem); flex-wrap: wrap;
}
.section-head > div:first-child { max-width: 780px; }
.eyebrow {
    display: inline-flex; align-items: center; gap: .55rem;
    font-family: var(--font-body);
    font-size: .82rem; letter-spacing: .14em;
    text-transform: uppercase; font-weight: 600;
    color: var(--ink-2); margin-bottom: 1rem;
}
.eyebrow::before { content: ''; width: 28px; height: 2px; background: var(--pink); }
.section--dark .eyebrow { color: rgba(255,255,255,.65); }

/* Header */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(250,250,250,.86);
    backdrop-filter: saturate(1.4) blur(12px);
    -webkit-backdrop-filter: saturate(1.4) blur(12px);
    border-bottom: 1px solid var(--line);
}
.site-header__row { display: flex; align-items: center; justify-content: space-between; padding: 1rem 0; }
.wordmark { font-family: var(--font-head); font-weight: 900; font-size: 1.6rem; letter-spacing: -0.04em; color: var(--pink); }
.wordmark:hover { color: var(--pink-ink); }
.primary-nav { display: flex; align-items: center; gap: .25rem; }
.primary-nav a {
    padding: .55rem 1rem; border-radius: var(--radius-pill);
    font-weight: 500; font-size: .98rem; color: var(--ink);
    transition: background .2s var(--ease-out), color .2s var(--ease-out);
}
.primary-nav a:hover, .primary-nav a[aria-current="page"] { background: var(--ink); color: var(--white); }
.header-cta { display: inline-flex; }
.nav-toggle {
    display: none; width: 44px; height: 44px; border-radius: var(--radius-pill);
    background: var(--ink); color: var(--white);
    align-items: center; justify-content: center;
}
.nav-toggle svg { width: 20px; height: 20px; }

@media (max-width: 860px) {
    .primary-nav {
        position: fixed; inset: 72px 0 auto 0;
        flex-direction: column; align-items: stretch;
        background: var(--white);
        padding: 1rem var(--gutter) 2rem;
        border-bottom: 1px solid var(--line);
        transform: translateY(-120%);
        transition: transform .35s var(--ease-out);
        gap: .25rem;
    }
    .primary-nav.is-open { transform: translateY(0); }
    .primary-nav a { padding: .9rem 1rem; font-size: 1.1rem; }
    .nav-toggle { display: inline-flex; }
    .header-cta { display: none; }
}

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: .55rem;
    padding: .85rem 1.5rem; border-radius: var(--radius-pill);
    background: var(--ink); color: var(--white);
    font-weight: 600; font-size: .98rem;
    transition: transform .25s var(--ease-out), background .2s var(--ease-out), color .2s var(--ease-out), box-shadow .25s var(--ease-out);
}
.btn:hover { background: var(--pink); color: var(--ink); transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.btn--pink { background: var(--pink); color: var(--ink); }
.btn--pink:hover { background: var(--ink); color: var(--white); }
.btn--ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--white); }
.section--dark .btn--ghost { color: var(--white); border-color: rgba(255,255,255,.35); }
.section--dark .btn--ghost:hover { background: var(--pink); color: var(--ink); border-color: var(--pink); }
.btn--lg { padding: 1.1rem 1.9rem; font-size: 1.05rem; }
.btn .btn__arrow { display: inline-block; transition: transform .25s var(--ease-out); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* Hero */
.hero { padding: clamp(3rem, 6vw, 5rem) 0 clamp(2rem, 4vw, 3rem); position: relative; overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: 1fr; gap: clamp(2rem, 4vw, 3rem); align-items: end; }
.hero__label {
    font-size: .88rem; letter-spacing: .2em; text-transform: uppercase;
    color: var(--ink-2); font-weight: 600; margin-bottom: 1.25rem;
    display: flex; align-items: center; gap: .75rem;
}
.hero__label::before {
    content: ''; width: 10px; height: 10px; border-radius: 50%; background: var(--pink);
    animation: pulse 2.2s var(--ease-in-out) infinite;
}
.hero__title {
    font-size: clamp(3rem, 10vw, 9.5rem); line-height: .94;
    letter-spacing: -0.045em; margin: 0;
}
.hero__title .line { display: block; }
.hero__title .pink { color: var(--pink); }
.hero__meta {
    display: grid; grid-template-columns: 1fr; gap: 2rem;
    margin-top: clamp(2rem, 4vw, 3rem);
    padding-top: 1.75rem; border-top: 1px solid var(--line);
}
.hero__meta p { margin: 0; color: var(--ink-2); max-width: 52ch; }
.hero__actions { display: flex; gap: .75rem; flex-wrap: wrap; }
@media (min-width: 860px) {
    .hero__meta { grid-template-columns: 1fr auto; align-items: center; }
}
.hero__showreel {
    margin-top: clamp(3rem, 5vw, 4.5rem);
    border-radius: var(--radius-card);
    overflow: hidden; aspect-ratio: 21 / 9;
    background: var(--ink); position: relative;
    box-shadow: var(--shadow-soft);
}
.hero__showreel .ai-img { width: 100%; height: 100%; object-fit: cover; }
.hero__showreel__tag {
    position: absolute; top: 1.25rem; left: 1.25rem;
    background: rgba(16,16,20,.65); color: var(--white);
    padding: .45rem .85rem; border-radius: var(--radius-pill);
    font-size: .78rem; letter-spacing: .1em; text-transform: uppercase;
    backdrop-filter: blur(6px); font-weight: 600;
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1);} 50%{opacity:.55;transform:scale(.8);} }

/* Marquee */
.marquee { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 1.25rem 0; overflow: hidden; background: var(--bg); }
.marquee__track { display: flex; gap: 3rem; white-space: nowrap; animation: marquee 36s linear infinite; width: max-content; }
.marquee__item {
    font-family: var(--font-head); font-weight: 900;
    font-size: clamp(1.5rem, 2.5vw, 2.2rem); letter-spacing: -0.03em;
    color: var(--ink); display: inline-flex; align-items: center; gap: 3rem;
}
.marquee__item::after { content: '✦'; color: var(--pink); font-size: 1.2rem; }
.marquee--dark { background: var(--ink); border-color: rgba(255,255,255,.08); }
.marquee--dark .marquee__item { color: var(--white); }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* Intro */
.intro-grid { display: grid; grid-template-columns: 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
@media (min-width: 960px) { .intro-grid { grid-template-columns: 1fr 1.2fr; } }
.intro-grid .big-claim {
    font-family: var(--font-head); font-weight: 900;
    font-size: clamp(2rem, 3.5vw, 3.4rem); line-height: 1.05;
    letter-spacing: -0.03em; margin: 0 0 1.25rem;
}
.intro-grid .big-claim em { color: var(--pink); font-style: italic; font-weight: 400; }
.stat-row { margin-top: 2.5rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; padding-top: 1.75rem; border-top: 1px solid var(--line); }
.stat-row__item .n {
    font-family: var(--font-head); font-weight: 900;
    font-size: clamp(1.8rem, 3vw, 2.6rem); letter-spacing: -0.03em;
    color: var(--pink); display: block;
}
.stat-row__item .l { font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2); font-weight: 600; }

/* Services grid (home) */
.services-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 720px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }
.service-card {
    background: var(--white); border-radius: var(--radius-card);
    padding: 1.75rem; border: 1px solid var(--line);
    position: relative; overflow: hidden;
    transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out), border-color .25s var(--ease-out);
    display: flex; flex-direction: column; min-height: 280px;
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); border-color: transparent; }
.service-card .num { font-family: var(--font-head); font-weight: 900; font-size: 1rem; color: var(--muted); margin-bottom: 1.25rem; }
.service-card h3 { margin: 0 0 .5rem; font-size: 1.35rem; line-height: 1.1; }
.service-card p { color: var(--ink-2); font-size: .98rem; margin: 0; }
.service-card__tag { position: absolute; top: 1.5rem; right: 1.5rem; font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; color: var(--pink); font-weight: 700; }
.service-card__arrow {
    margin-top: auto; padding-top: 1.5rem; font-size: 1.4rem; color: var(--ink);
    transition: transform .25s var(--ease-out), color .25s var(--ease-out);
}
.service-card:hover .service-card__arrow { transform: translateX(6px); color: var(--pink); }
.service-card--featured {
    background: var(--ink); color: var(--white); border-color: var(--ink);
    grid-column: 1 / -1; min-height: 320px;
    display: grid; grid-template-columns: 1fr; gap: 1.5rem; padding: 2.25rem;
}
@media (min-width: 860px) { .service-card--featured { grid-template-columns: 1.4fr 1fr; align-items: center; padding: 3rem; } }
.service-card--featured h3 { color: var(--white); font-size: clamp(1.8rem, 3vw, 2.8rem); }
.service-card--featured p { color: rgba(255,255,255,.75); }
.service-card--featured .num { color: var(--pink); }
.service-card--featured .service-card__tag { color: var(--pink); }
.service-card--featured .service-card__media { aspect-ratio: 4 / 3; border-radius: var(--radius-img); overflow: hidden; background: #1E1E22; }
.service-card--featured .service-card__media svg,
.service-card--featured .service-card__media img { width: 100%; height: 100%; display: block; object-fit: cover; }

/* Work tiles */
.work-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 720px) { .work-grid { grid-template-columns: repeat(2, 1fr); } }
.work-tile { position: relative; border-radius: var(--radius-card); overflow: hidden; background: var(--bg-2); aspect-ratio: 4 / 5; display: block; isolation: isolate; }
.work-tile--wide { aspect-ratio: 16 / 10; }
@media (min-width: 720px) { .work-tile--wide { grid-column: span 2; } }
.work-tile .ai-img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease-out); }
.work-tile:hover .ai-img { transform: scale(1.04); }
.work-tile__meta { position: absolute; left: 1.25rem; bottom: 1.25rem; right: 1.25rem; display: flex; align-items: center; justify-content: space-between; color: var(--white); z-index: 2; }
.work-tile::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(16,16,20,.55) 0%, rgba(16,16,20,0) 45%); z-index: 1; pointer-events: none; }
.work-tile__title { font-family: var(--font-head); font-weight: 900; font-size: 1.15rem; letter-spacing: -0.01em; }
.work-tile__tag { background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3); backdrop-filter: blur(10px); padding: .4rem .8rem; border-radius: var(--radius-pill); font-size: .75rem; text-transform: uppercase; letter-spacing: .08em; font-weight: 600; }

/* Process */
.process-list { display: grid; grid-template-columns: 1fr; gap: 0; border-top: 1px solid rgba(255,255,255,.12); }
.process-step {
    padding: 2rem 0; border-bottom: 1px solid rgba(255,255,255,.12);
    display: grid; grid-template-columns: 1fr; gap: 1rem; align-items: start;
    transition: padding .4s var(--ease-out);
}
@media (min-width: 860px) { .process-step { grid-template-columns: 120px 1fr 2fr; gap: 2rem; padding: 2.5rem 0; } }
.process-step:hover { padding-left: 1rem; padding-right: 1rem; background: rgba(255,255,255,.02); }
.process-step .n { font-family: var(--font-head); font-weight: 900; font-size: 1.5rem; color: var(--pink); }
.process-step h3 { margin: 0; font-size: clamp(1.4rem, 2.3vw, 1.9rem); color: var(--white); }
.process-step p { margin: 0; color: rgba(255,255,255,.7); max-width: 60ch; }

/* Testimonials */
.testimonials { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 860px) { .testimonials { grid-template-columns: repeat(2, 1fr); } }
.testimonial {
    background: var(--white); border: 1px solid var(--line);
    border-radius: var(--radius-card); padding: 2rem; position: relative;
    transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
}
.testimonial:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.testimonial__quote { font-family: var(--font-head); font-weight: 700; font-size: clamp(1.15rem, 1.5vw, 1.35rem); line-height: 1.3; letter-spacing: -0.015em; color: var(--ink); margin: 0 0 1.5rem; }
.testimonial__mark { font-family: var(--font-head); color: var(--pink); font-size: 2.5rem; line-height: 0; display: block; margin-bottom: 1.25rem; }
.testimonial__who { display: flex; align-items: center; gap: .85rem; padding-top: 1.25rem; border-top: 1px solid var(--line); }
.testimonial__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--pink); display: flex; align-items: center; justify-content: center; color: var(--ink); font-family: var(--font-head); font-weight: 900; font-size: 1rem; }
.testimonial__name { font-weight: 600; font-size: .95rem; }
.testimonial__role { font-size: .85rem; color: var(--muted); }

/* CTA band */
.cta-band { padding: clamp(2.5rem, 5vw, 4.5rem) 0; text-align: center; background: #0F0512; color: var(--white); position: relative; overflow: hidden; isolation: isolate; }
.cta-band > .container { position: relative; z-index: 2; }
.cta-band__bg {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background:
        conic-gradient(from 140deg at 30% 40%, rgba(255,51,187,.45), rgba(176,133,255,.35), rgba(255,177,153,.3), rgba(70,227,247,.25), rgba(255,51,187,.45)),
        #0F0512;
    filter: blur(60px) saturate(1.1);
    animation: ctaSpin 22s linear infinite;
}
.cta-band__bg::before {
    content: ''; position: absolute; inset: -10%;
    background:
        radial-gradient(circle at 20% 80%, rgba(255,51,187,.45), transparent 45%),
        radial-gradient(circle at 80% 20%, rgba(70,227,247,.35), transparent 45%);
    mix-blend-mode: screen;
    animation: ctaFloat 14s ease-in-out infinite alternate;
}
.cta-band__bg::after {
    content: ''; position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 75% 60% at 50% 50%, #000 30%, transparent 100%);
    -webkit-mask-image: radial-gradient(ellipse 75% 60% at 50% 50%, #000 30%, transparent 100%);
    opacity: .45;
}
@keyframes ctaSpin  { to { transform: rotate(360deg); } }
@keyframes ctaFloat { from { transform: translate(-2%, -1%); } to { transform: translate(2%, 2%); } }
@media (prefers-reduced-motion: reduce) {
    .cta-band__bg, .cta-band__bg::before { animation: none; }
}
.cta-band h2 {
    font-size: clamp(1.6rem, 3.6vw, 3.25rem);
    line-height: 1.12;
    color: var(--white);
    margin: 0 auto 1.5rem;
    max-width: 24ch;
    text-wrap: balance;
}
.cta-band h2 em { color: var(--pink); }
.cta-band p { color: rgba(255,255,255,.72); max-width: 52ch; margin: 0 auto 2rem; font-size: 1.1rem; }

/* FAQ */
.faq-list { border-top: 1px solid var(--line); max-width: 880px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.5rem 0; cursor: pointer; list-style: none;
    font-family: var(--font-head); font-weight: 700; font-size: clamp(1.1rem, 1.4vw, 1.4rem);
    letter-spacing: -0.015em; color: var(--ink);
    transition: color .2s var(--ease-out);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-size: 1.5rem; color: var(--pink); transition: transform .3s var(--ease-out); }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item[open] summary { color: var(--pink); }
.faq-item p { padding: 0 0 1.5rem; color: var(--ink-2); margin: 0; max-width: 65ch; }

/* Page hero (inner pages) */
.page-hero { padding: clamp(4rem, 7vw, 6rem) 0 clamp(3rem, 5vw, 4rem); border-bottom: 1px solid var(--line); }
.page-hero h1 { font-size: clamp(2.5rem, 7vw, 6rem); margin: 0 0 1.25rem; }
.page-hero h1 em { color: var(--pink); }
.page-hero p.lede { max-width: 64ch; }

/* Feed */
.feed .section-head--split { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 2rem; }
.section-num { display: inline-block; font-size: .78rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-bottom: .75rem; }
.feed-tabs { display: inline-flex; gap: .25rem; padding: .35rem; background: var(--bg-2); border-radius: var(--radius-pill); margin: 0 0 2rem; }
.feed-tab { padding: .55rem 1.3rem; border-radius: var(--radius-pill); font-weight: 600; font-size: .95rem; color: var(--ink-2); transition: background .2s var(--ease-out), color .2s var(--ease-out); }
.feed-tab.is-active { background: var(--ink); color: var(--white); }
.feed-panel.is-hidden { display: none; }

.embed-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; justify-items: center; }
.embed-tile { position: relative; width: 100%; max-width: 380px; border-radius: var(--radius-card); background: #000; overflow: hidden; border: 1px solid var(--line); box-shadow: var(--shadow-soft); transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.embed-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.embed-clip { position: relative; width: 100%; aspect-ratio: 9 / 16; overflow: hidden; background: #000; }
.embed-clip iframe { position: absolute; left: 0; right: 0; top: -58px; width: 100%; height: calc(100% + 58px + 360px); border: 0; display: block; }
.embed-tile__overlay { position: absolute; inset: 0; z-index: 2; background: transparent; }
.embed-fallback { display: flex; flex-direction: column; align-items: center; justify-content: center; aspect-ratio: 9/16; width: 100%; color: var(--white); background: var(--ink); padding: 1.25rem; text-align: center; gap: .75rem; position: relative; }
.embed-fallback img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; opacity: .75; }
.embed-fallback span { position: relative; z-index: 2; font-weight: 600; }

.tt-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.25rem; justify-items: center; }
.tt-tile { width: 100%; max-width: 380px; }
.tt-poster { position: relative; display: flex; flex-direction: column; justify-content: flex-end; aspect-ratio: 9/16; border-radius: var(--radius-card); overflow: hidden; background: var(--ink); color: var(--white); padding: 1.25rem; border: 1px solid var(--line); transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.tt-poster:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.tt-poster img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .75; }
.tt-poster__play { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 64px; height: 64px; border-radius: 50%; background: var(--pink); color: var(--ink); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; z-index: 2; }
.tt-poster__label { position: relative; z-index: 2; background: rgba(0,0,0,.5); padding: .5rem .9rem; border-radius: var(--radius-pill); font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; align-self: flex-start; backdrop-filter: blur(8px); }
.feed-cta { margin-top: 2.5rem; text-align: center; display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }
.feed-more { margin-top: 2rem; text-align: center; display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.feed-more__count { margin: 0; color: var(--ink-2); font-size: .9rem; }

/* ===== Blog index ===== */
.blog-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 720px)  { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }
.blog-card {
    display: flex; flex-direction: column;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    overflow: hidden;
    color: var(--ink);
    transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out), border-color .35s var(--ease-out);
}
.blog-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); border-color: var(--pink); }
.blog-card__cover { aspect-ratio: 16 / 10; overflow: hidden; background: var(--bg-2); }
.blog-card__cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease-out); }
.blog-card:hover .blog-card__cover img { transform: scale(1.05); }
.blog-card__cover--empty { width: 100%; height: 100%; background: linear-gradient(135deg, #FF33BB 0%, #B085FF 100%); }
.blog-card__body { padding: 1.25rem 1.35rem 1.5rem; display: flex; flex-direction: column; gap: .6rem; flex: 1; }
.blog-card__cat {
    align-self: flex-start;
    font-family: var(--font-head); font-weight: 700; font-size: .7rem; letter-spacing: .12em;
    text-transform: uppercase; color: var(--pink);
}
.blog-card h3 { margin: 0; font-size: 1.25rem; letter-spacing: -0.01em; line-height: 1.2; }
.blog-card p  { margin: 0; color: var(--ink-2); font-size: .95rem; line-height: 1.5;
    display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card__meta { margin-top: auto; display: flex; justify-content: space-between; align-items: center; padding-top: .75rem; font-size: .85rem; color: var(--ink-2); border-top: 1px dashed var(--line); }
.blog-card__arrow { color: var(--pink); font-weight: 700; }

/* ===== Blog post page ===== */
.blog-post { position: relative; overflow: hidden; isolation: isolate; padding-top: clamp(4rem, 8vw, 7rem); }
.blog-post__bg {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 55% 45% at 15% 10%, rgba(255,51,187,.14), transparent 60%),
        radial-gradient(ellipse 50% 40% at 90% 90%, rgba(176,133,255,.12), transparent 60%);
    animation: darkBgShift 22s ease-in-out infinite alternate;
}
.blog-post__container { position: relative; z-index: 1; max-width: 760px; }
.blog-post__crumbs { margin-bottom: 1.5rem; font-size: .9rem; }
.blog-post__crumbs a { color: var(--pink); text-decoration: none; font-weight: 600; }
.blog-post__crumbs a:hover { text-decoration: underline; }
.blog-post__head h1 { font-size: clamp(2.25rem, 5.5vw, 4rem); margin: .25rem 0 1rem; line-height: 1.05; letter-spacing: -0.02em; }
.blog-post__head h1 em { color: var(--pink); font-style: italic; font-weight: 400; }
.blog-post__head .lede { max-width: 62ch; }
.blog-post__meta { color: var(--ink-2); font-size: .9rem; margin: .75rem 0 0; }
.blog-post__cover { margin: 2.5rem 0; border-radius: var(--radius-card); overflow: hidden; aspect-ratio: 16/9; background: var(--bg-2); }
.blog-post__cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-post__body { font-size: 1.1rem; line-height: 1.7; color: var(--ink); }
.blog-post__body p { margin: 0 0 1.25rem; }
.blog-post__body ul { padding-left: 1.25rem; margin: 0 0 1.5rem; }
.blog-post__body li { margin-bottom: .5rem; }
.blog-post__body strong { color: var(--pink); font-weight: 800; }

/* ===== Inside the lab (About) ===== */
.inside-lab__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.25rem;
}
@media (min-width: 860px)  { .inside-lab__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .inside-lab__grid { grid-template-columns: repeat(3, 1fr); } }
.inside-card {
    position: relative;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--radius-card);
    padding: 1.75rem;
    color: var(--white);
    overflow: hidden;
    isolation: isolate;
    transition: transform .35s var(--ease-out), border-color .35s var(--ease-out), background .35s var(--ease-out);
}
.inside-card::before {
    content: ''; position: absolute; inset: -2px;
    background: conic-gradient(from 0deg, transparent 0deg, rgba(255,51,187,.9) 40deg, transparent 90deg);
    opacity: 0; transition: opacity .35s var(--ease-out);
    z-index: -1;
    animation: insideSpin 8s linear infinite;
}
.inside-card:hover { transform: translateY(-4px); background: rgba(255,255,255,.07); border-color: rgba(255,51,187,.4); }
.inside-card:hover::before { opacity: .45; }
@keyframes insideSpin { to { transform: rotate(360deg); } }
.inside-card { min-height: 100%; }
.inside-card__kicker {
    display: inline-block;
    font-family: var(--font-head); font-weight: 700; font-size: .7rem; letter-spacing: .12em;
    text-transform: uppercase; color: var(--pink);
    margin-bottom: .75rem;
}
.inside-card h3 { margin: 0 0 .75rem; font-size: clamp(1.5rem, 2.5vw, 2rem); color: var(--white); }
.inside-card p  { margin: 0; color: rgba(255,255,255,.75); }
.inside-card .hl { color: var(--pink); font-weight: 700; font-family: var(--font-head); }
.inside-card__list { list-style: none; padding: 0; margin: 1.25rem 0 0; display: grid; gap: .65rem; }
.inside-card__list li { display: grid; grid-template-columns: 60px 1fr; gap: 1rem; align-items: baseline; padding: .6rem 0; border-top: 1px dashed rgba(255,255,255,.15); color: rgba(255,255,255,.8); }
.inside-card__list li span { font-family: var(--font-head); font-weight: 900; color: var(--pink); font-size: .95rem; }
.inside-card__swatches { display: flex; gap: .5rem; margin-top: 1.25rem; }
.inside-card__swatches span {
    width: 36px; height: 36px; border-radius: 50%;
    box-shadow: inset 0 0 0 2px rgba(255,255,255,.1);
    animation: swatchBounce 3s var(--ease-out) infinite;
}
.inside-card__swatches span:nth-child(2) { animation-delay: .2s; }
.inside-card__swatches span:nth-child(3) { animation-delay: .4s; }
.inside-card__swatches span:nth-child(4) { animation-delay: .6s; }
@keyframes swatchBounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
.inside-card__pipeline { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; margin-top: 1.25rem; font-size: .85rem; }
.inside-card__pipeline span {
    padding: .35rem .75rem;
    border-radius: var(--radius-pill);
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.15);
    font-weight: 600;
}
.inside-card__pipeline em { color: var(--pink); font-style: normal; font-weight: 900; }
@media (prefers-reduced-motion: reduce) {
    .inside-card::before, .inside-card__swatches span { animation: none; }
}

/* ===== Skills grid ===== */
.skills-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}
@media (min-width: 720px)  { .skills-grid { grid-template-columns: repeat(2, 1fr); gap: 1.25rem; } }
@media (min-width: 1100px) { .skills-grid { grid-template-columns: repeat(3, 1fr); } }
.skill-card {
    display: grid;
    grid-template-columns: 88px 1fr;
    gap: 1.25rem;
    align-items: start;
    background: var(--white);
    border: 1px solid var(--line);
    border-radius: var(--radius-card);
    padding: 1.25rem;
    transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out), border-color .35s var(--ease-out);
}
.skill-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); border-color: var(--pink); }
.skill-card__logo {
    width: 88px; height: 88px;
    border-radius: 20px;
    display: flex; align-items: center; justify-content: center;
    color: var(--white);
    box-shadow: 0 6px 18px rgba(16,16,20,.12), inset 0 0 0 1px rgba(255,255,255,.12);
    overflow: hidden;
    position: relative;
}
.skill-card__logo::after {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.35), transparent 55%);
    pointer-events: none;
}
.skill-card__mark {
    font-family: var(--font-head);
    font-weight: 900;
    font-size: 2rem;
    letter-spacing: -0.04em;
    line-height: 1;
    text-shadow: 0 1px 0 rgba(0,0,0,.1);
    position: relative; z-index: 1;
}
.skill-card__mark--emoji { font-family: inherit; font-size: 2.4rem; text-shadow: none; }
.skill-card__body h3 { margin: .25rem 0 .4rem; font-size: 1.25rem; letter-spacing: -0.01em; }
.skill-card__body p  { margin: 0; color: var(--ink-2); font-size: .95rem; line-height: 1.5; }
.skill-card__cat {
    display: inline-block;
    font-family: var(--font-head); font-weight: 700;
    font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
    color: var(--pink);
}

/* ===== Media filter chips ===== */
.media-filters { display: flex; gap: .6rem; flex-wrap: wrap; margin: 0 0 1.75rem; }
.media-filter {
    appearance: none; border: 1px solid var(--line); background: var(--white); color: var(--ink);
    padding: .55rem 1.1rem; border-radius: var(--radius-pill);
    font: inherit; font-weight: 600; font-size: .9rem; letter-spacing: .02em;
    cursor: pointer;
    transition: background .2s var(--ease-out), color .2s var(--ease-out), border-color .2s var(--ease-out), transform .2s var(--ease-out);
}
.media-filter:hover { border-color: var(--pink); color: var(--pink); }
.media-filter.is-active { background: var(--pink); border-color: var(--pink); color: var(--ink); }
.media-tile.is-hidden { display: none; }

/* ===== Works hero ===== */
.works-hero { position: relative; overflow: hidden; isolation: isolate; padding-top: clamp(4rem, 10vw, 8rem); }
.works-hero > .container { position: relative; z-index: 2; }
.works-hero__bg {
    position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(ellipse 50% 40% at 10% 20%, rgba(255,51,187,.22), transparent 60%),
        radial-gradient(ellipse 45% 35% at 90% 80%, rgba(176,133,255,.2), transparent 60%);
    animation: darkBgShift 20s ease-in-out infinite alternate;
}
.works-hero__grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 960px) { .works-hero__grid { grid-template-columns: 1.1fr 1fr; gap: 4rem; align-items: end; } }

/* ===== Mixed media grid (photos + IG + TT) ===== */
.media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1.25rem;
}
.media-tile {
    position: relative; display: block;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-card);
    overflow: hidden;
    background: var(--ink);
    border: 1px solid var(--line);
    cursor: pointer;
    padding: 0;
    color: var(--white);
    font: inherit; text-align: left;
    isolation: isolate;
    transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
}
.media-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.media-tile__cover {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .7s var(--ease-out), filter .35s var(--ease-out);
}
.media-tile:hover .media-tile__cover { transform: scale(1.06); filter: brightness(.85); }
.media-tile__cover--empty { background: linear-gradient(135deg, #1B1B22 0%, #101014 100%); }
.media-tile::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(16,16,20,.65) 0%, rgba(16,16,20,0) 55%);
    z-index: 1; pointer-events: none;
}
.media-tile__badge {
    position: absolute; top: .85rem; left: .85rem; z-index: 2;
    background: rgba(16,16,20,.6); color: var(--white);
    padding: .35rem .7rem; border-radius: var(--radius-pill);
    font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 700;
    backdrop-filter: blur(8px);
}
.media-tile__badge--ph { background: rgba(255,255,255,.9); color: var(--ink); }
.media-tile__badge--ig { background: var(--pink); color: var(--ink); }
.media-tile__badge--tt { background: rgba(16,16,20,.75); }
.media-tile__play {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%) scale(.9);
    width: 60px; height: 60px; border-radius: 50%;
    background: var(--pink); color: var(--ink);
    display: flex; align-items: center; justify-content: center;
    z-index: 2;
    transition: transform .35s var(--ease-out);
    box-shadow: 0 6px 20px rgba(16,16,20,.35);
}
.media-tile:hover .media-tile__play { transform: translate(-50%, -50%) scale(1.05); }
.media-tile__play svg { margin-left: 3px; }
.media-tile__title {
    position: absolute; left: .85rem; right: .85rem; bottom: .85rem;
    z-index: 2;
    font-family: var(--font-head); font-weight: 900;
    font-size: .95rem; letter-spacing: -0.01em; color: var(--white);
    line-height: 1.2;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ===== Reel modal ===== */
.reel-modal {
    position: fixed; inset: 0; z-index: 200;
    display: flex; align-items: center; justify-content: center;
    padding: 1rem;
    animation: reelFade .25s var(--ease-out);
}
.reel-modal[hidden] { display: none !important; }
@keyframes reelFade { from { opacity: 0; } to { opacity: 1; } }
.reel-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(16,16,20,.82);
    backdrop-filter: blur(8px);
    border: 0; padding: 0;
    cursor: pointer;
}
.reel-modal__dialog {
    position: relative; z-index: 1;
    width: 100%; max-width: 440px;
    background: var(--ink); color: var(--white);
    border-radius: var(--radius-card);
    overflow: hidden;
    display: flex; flex-direction: column;
    max-height: 92vh;
    animation: reelPop .3s var(--ease-out);
}
@keyframes reelPop { from { transform: scale(.94); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.reel-modal__head {
    display: flex; align-items: center; justify-content: space-between;
    padding: .85rem 1rem;
    border-bottom: 1px solid rgba(255,255,255,.1);
    gap: 1rem;
}
.reel-modal__head strong { font-family: var(--font-head); font-weight: 900; font-size: 1rem; letter-spacing: -0.01em; }
.reel-modal__actions { display: flex; align-items: center; gap: .5rem; }
.reel-modal__link { font-size: .85rem; color: var(--pink); font-weight: 600; }
.reel-modal__link:hover { text-decoration: underline; }
.reel-modal__close {
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(255,255,255,.1); color: var(--white);
    font-size: 1.3rem; line-height: 1;
}
.reel-modal__close:hover { background: var(--pink); color: var(--ink); }
.reel-modal__frame {
    position: relative; width: 100%;
    aspect-ratio: 9 / 16;
    background: #000;
    overflow: hidden;
}
.reel-modal__frame iframe {
    position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
}
/* IG embed adds chrome we don't want — clip it */
.reel-modal__frame--ig iframe {
    top: -58px;
    height: calc(100% + 58px + 360px);
}
/* Photo mode: wider dialog, natural image ratio */
.reel-modal__dialog--photo { max-width: min(1100px, 96vw); }
.reel-modal__frame--photo {
    aspect-ratio: auto;
    background: #000;
    max-height: calc(92vh - 64px);
    display: flex; align-items: center; justify-content: center;
}
.reel-modal__frame--photo img {
    display: block;
    max-width: 100%;
    max-height: calc(92vh - 64px);
    width: auto; height: auto;
    object-fit: contain;
}


/* Services list */
.services-list { display: grid; grid-template-columns: 1fr; gap: 0; }
.service-row { display: grid; grid-template-columns: 1fr; gap: 1.25rem; padding: 2rem 0; border-top: 1px solid var(--line); transition: padding .3s var(--ease-out); }
@media (min-width: 860px) { .service-row { grid-template-columns: 80px 1.3fr 2fr; gap: 2rem; align-items: start; padding: 2.5rem 0; } }
.service-row:hover { padding-left: 1rem; padding-right: 1rem; background: var(--bg-2); }
.service-row .n { font-family: var(--font-head); font-weight: 900; font-size: 1.25rem; color: var(--pink); }
.service-row h3 { margin: 0; font-size: clamp(1.5rem, 2.5vw, 2.2rem); }
.service-row .lead { margin: 0 0 .75rem; font-weight: 500; font-size: 1.05rem; }
.service-row p { margin: 0; color: var(--ink-2); max-width: 62ch; }

/* Editorial service list */
.svc-list { list-style: none; padding: 0; margin: 0; }
.svc-item {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem 2.5rem;
    padding: 2.5rem 0;
    border-top: 1px solid var(--line);
    transition: background .3s var(--ease-out);
}
.svc-item:last-child { border-bottom: 1px solid var(--line); }
.svc-item:hover { background: linear-gradient(90deg, rgba(255,51,187,.04), transparent 70%); }
@media (min-width: 860px) {
    .svc-item { grid-template-columns: 140px 1fr; padding: 3rem 0; }
}
.svc-item__num {
    font-family: var(--font-head); font-weight: 900;
    font-size: clamp(2.5rem, 5vw, 4rem);
    line-height: .9; color: var(--pink);
    letter-spacing: -0.04em;
}
.svc-item__main { max-width: 68ch; }
.svc-item__head { display: flex; align-items: baseline; gap: .85rem; flex-wrap: wrap; margin-bottom: .4rem; }
.svc-item__head h3 { margin: 0; font-size: clamp(1.5rem, 2.8vw, 2.25rem); line-height: 1.1; }
.svc-item__tag {
    font-family: var(--font-head); font-weight: 900;
    font-size: .7rem; letter-spacing: .1em; text-transform: uppercase;
    color: var(--pink); border: 1.5px solid var(--pink);
    padding: .2rem .55rem; border-radius: 4px;
}
.svc-item__lead { margin: 0 0 1rem; font-weight: 600; color: var(--ink); font-size: 1.1rem; }
.svc-item__body { margin: 0 0 1.25rem; color: var(--ink-2); }
.svc-item__points { list-style: none; padding: 0; margin: 0 0 1.5rem; display: grid; gap: .5rem; }
.svc-item__points li { position: relative; padding-left: 1.4rem; color: var(--ink-2); }
.svc-item__points li::before {
    content: "→"; position: absolute; left: 0; top: 0;
    color: var(--pink); font-weight: 900; font-family: var(--font-head);
}
.svc-item__delivers {
    margin: 0; padding-top: 1rem; border-top: 1px dashed var(--line);
    color: var(--ink-2); font-size: .92rem; display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
}
.svc-item__delivers-label {
    font-family: var(--font-head); font-weight: 900; font-size: .7rem;
    letter-spacing: .12em; text-transform: uppercase; color: var(--ink);
    margin-right: .5rem;
}
.svc-item__delivers-item { color: var(--ink); font-weight: 600; }
.svc-item__sep { color: var(--pink); font-weight: 900; }
@media (prefers-reduced-motion: reduce) {
    .svc-item, .svc-item:hover { transition: none; background: none; }
}

/* Values */
.values-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 720px) { .values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .values-grid { grid-template-columns: repeat(4, 1fr); } }
.value-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--radius-card); padding: 1.75rem; transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.value-card .num { font-family: var(--font-head); font-weight: 900; color: var(--pink); font-size: 1rem; margin-bottom: 1.25rem; }
.value-card h4 { margin: 0 0 .5rem; font-size: 1.2rem; }
.value-card p { margin: 0; color: var(--ink-2); font-size: .95rem; }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 960px) { .contact-grid { grid-template-columns: 1fr 1.3fr; gap: 4rem; } }
.contact-aside h3 { font-size: 1.5rem; }
.contact-aside ul { list-style: none; padding: 0; margin: 0 0 2rem; display: grid; gap: .75rem; }
.contact-aside a { border-bottom: 1px solid var(--line); padding-bottom: .25rem; }
.contact-aside a:hover { color: var(--pink); border-color: var(--pink); }

.form-field { margin: 0 0 1.25rem; }
.form-field label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .4rem; }
.form-field input, .form-field textarea {
    width: 100%; padding: .85rem 1rem;
    border: 1.5px solid var(--line); border-radius: 14px;
    background: var(--white); font: inherit; color: var(--ink);
    transition: border-color .2s var(--ease-out);
}
.form-field input:focus, .form-field textarea:focus { outline: none; border-color: var(--pink); }
.form-field textarea { min-height: 150px; resize: vertical; }
.form-honey { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.form-success, .form-error { padding: 1rem 1.25rem; border-radius: 14px; font-weight: 500; margin-bottom: 1.5rem; }
.form-success { background: #E8FCEF; color: #0A6B2E; border: 1px solid #BEEBD0; }
.form-error   { background: #FFE8EF; color: #A30F3C; border: 1px solid #FFC5D6; }

/* Footer */
.site-footer { background: var(--ink); color: var(--white); padding: clamp(2rem, 4vw, 3rem) 0 1.25rem; }
.site-footer a { color: rgba(255,255,255,.8); }
.site-footer a:hover { color: var(--pink); }
.footer-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.footer-brand { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }
.footer-wordmark {
    font-family: var(--font-head); font-weight: 900;
    font-size: clamp(2.25rem, 6vw, 4.5rem);
    color: transparent;
    -webkit-text-stroke: 1.5px rgba(255,255,255,.35);
    letter-spacing: -0.045em; line-height: .9;
    margin: 0;
    transition: color .45s var(--ease-out), -webkit-text-stroke-color .45s var(--ease-out);
    cursor: default;
}
.footer-wordmark:hover { color: var(--pink); -webkit-text-stroke-color: var(--pink); }
.footer-wordmark em { color: var(--pink); font-style: normal; }
.footer-socials { display: flex; gap: 1rem; }
.footer-social { display: inline-flex; align-items: center; justify-content: center; color: rgba(255,255,255,.8); }
.footer-social svg { transition: transform .3s var(--ease-out); }
.footer-social:hover { color: var(--pink); }
.footer-social:hover svg { transform: scale(1.15); }
.footer-links {
    display: grid;
    grid-template-columns: repeat(3, minmax(120px, auto));
    gap: 1rem 3rem;
    align-items: center;
    justify-items: start;
    margin-top: .5rem;
}
.footer-links a {
    font-family: var(--font-body); font-weight: 400; font-size: 1rem;
    text-decoration: none; color: rgba(255,255,255,.78);
    transition: color .25s var(--ease-out);
}
.footer-links a:hover { color: var(--pink); }
.footer-legal {
    margin-top: 2rem; padding-top: 1.25rem;
    border-top: 1px solid rgba(255,255,255,.12);
    display: flex; justify-content: space-between; flex-wrap: wrap;
    gap: .5rem 1rem; color: rgba(255,255,255,.55); font-size: .85rem;
}
@media (max-width: 700px) {
    .footer-row { flex-direction: column; align-items: flex-start; }
    .footer-links { grid-template-columns: repeat(3, auto); gap: .85rem 1.5rem; }
}

/* Scroll progress */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 2px; z-index: 100; background: transparent; pointer-events: none; }
.scroll-progress__bar { height: 100%; width: 0; background: var(--pink); transition: width .1s linear; }

/* Reveal */
[data-reveal] { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal][data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal][data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal][data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal][data-reveal-delay="4"] { transition-delay: .32s; }

/* AI placeholder */
.ai-img, .slot-img { display: block; width: 100%; height: 100%; object-fit: cover; background: var(--bg-2); transition: transform .9s var(--ease-out); }
.hero__showreel:hover .slot-img,
.service-card:hover .slot-img { transform: scale(1.03); }

/* Utility */
.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; }

/* ===== Hover motion & color play ===== */

/* Hero title: letters lift on hover */
.hero__title .line {
    transition: color .4s var(--ease-out), transform .5s var(--ease-out);
    cursor: default;
}
.hero__title .line:hover { color: var(--pink); transform: translateX(10px); }

/* Section titles — sweep to pink on hover */
.section-head h2,
.page-hero h1,
.cta-band h2,
.big-claim {
    transition: color .45s var(--ease-out), letter-spacing .45s var(--ease-out);
    cursor: default;
}
.section-head h2:hover,
.page-hero h1:hover,
.cta-band h2:hover,
.big-claim:hover { color: var(--pink); letter-spacing: -0.04em; }
.section--dark .section-head h2:hover,
.cta-band h2:hover { color: var(--pink); }

/* Marquee items: pink + scale on hover */
.marquee__item { transition: color .3s var(--ease-out), transform .3s var(--ease-out); cursor: default; }
.marquee__item:hover { color: var(--pink); transform: scale(1.06); }
.marquee:hover .marquee__track { animation-play-state: paused; }

/* Service card hover: title shifts pink and lifts */
.service-card h3 { transition: color .3s var(--ease-out), transform .35s var(--ease-out); }
.service-card:hover h3 { color: var(--pink); transform: translateX(4px); }
.service-card--featured:hover h3 { color: var(--pink); }

/* Value cards: number grows + pink accent underline */
.value-card { position: relative; overflow: hidden; }
.value-card::after {
    content: ''; position: absolute; left: 0; bottom: 0; height: 3px;
    width: 0; background: var(--pink);
    transition: width .5s var(--ease-out);
}
.value-card:hover::after { width: 100%; }
.value-card .num { transition: transform .35s var(--ease-out), font-size .35s var(--ease-out); display: inline-block; }
.value-card:hover .num { transform: scale(1.2) translateX(4px); }
.value-card:hover h4 { color: var(--pink); transition: color .3s var(--ease-out); }

/* Testimonials — pink mark rotates, quote tilts a hair */
.testimonial__mark { transition: transform .4s var(--ease-out); }
.testimonial:hover .testimonial__mark { transform: rotate(-8deg) scale(1.15); }
.testimonial__quote { transition: color .35s var(--ease-out); }
.testimonial:hover .testimonial__quote { color: var(--pink-ink); }

/* Process steps — number scales, title shifts */
.process-step .n { transition: transform .35s var(--ease-out), color .35s var(--ease-out); display: inline-block; }
.process-step:hover .n { transform: translateX(6px) scale(1.1); }
.process-step h3 { transition: color .35s var(--ease-out); }
.process-step:hover h3 { color: var(--pink); }

/* FAQ items — number indicator */
.faq-item summary:hover { color: var(--pink); letter-spacing: -0.02em; }

/* Wordmark in header — gradient wipe on hover */
.wordmark {
    background-image: linear-gradient(120deg, var(--pink) 0%, var(--pink) 50%, var(--pink-ink) 50%, var(--pink-ink) 100%);
    background-size: 200% 100%;
    background-position: 0% 0%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: background-position .5s var(--ease-out), transform .3s var(--ease-out);
}
.wordmark:hover { background-position: -100% 0%; transform: rotate(-2deg); }

/* Primary nav — underline sweep */
.primary-nav a { position: relative; }
.primary-nav a::after {
    content: ''; position: absolute;
    left: 1rem; right: 1rem; bottom: .35rem;
    height: 2px; background: var(--pink);
    transform: scaleX(0); transform-origin: left;
    transition: transform .3s var(--ease-out);
}
.primary-nav a:hover::after { transform: scaleX(1); }
.primary-nav a[aria-current="page"]::after { display: none; }

/* Contact form focus glow */
.form-field input:focus,
.form-field textarea:focus {
    box-shadow: 0 0 0 4px rgba(255, 102, 196, .15);
}

/* Contact aside links — slide arrow */
.contact-aside a { position: relative; display: inline-block; transition: padding-right .3s var(--ease-out); }
.contact-aside a:hover { padding-right: 1.5rem; }
.contact-aside a::after {
    content: '→'; position: absolute; right: 0; top: 0;
    opacity: 0; transform: translateX(-6px);
    transition: opacity .25s var(--ease-out), transform .25s var(--ease-out);
    color: var(--pink);
}
.contact-aside a:hover::after { opacity: 1; transform: translateX(0); }

/* Work tile meta slide */
.work-tile__title { transition: transform .35s var(--ease-out); }
.work-tile:hover .work-tile__title { transform: translateX(6px); color: var(--pink); }

/* Button tiny shimmer */
.btn { position: relative; overflow: hidden; }
.btn::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.25) 50%, transparent 100%);
    transform: translateX(-120%); transition: transform .7s var(--ease-out);
    pointer-events: none;
}
.btn:hover::before { transform: translateX(120%); }

/* Eyebrow bar grow */
.eyebrow::before { transition: width .35s var(--ease-out); }
.section-head:hover .eyebrow::before,
.page-hero:hover .eyebrow::before { width: 60px; }

/* Footer link hover — slide */
.site-footer ul a { display: inline-block; transition: transform .3s var(--ease-out), color .25s var(--ease-out); }
.site-footer ul a:hover { transform: translateX(6px); }

/* Hero showreel tag pulse */
.hero__showreel__tag { transition: background .3s var(--ease-out); }
.hero__showreel:hover .hero__showreel__tag { background: var(--pink); color: var(--ink); }
.hero__showreel .ai-img { transition: transform .9s var(--ease-out); }
.hero__showreel:hover .ai-img { transform: scale(1.03); }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
    .marquee__track { animation: none; }
    [data-reveal] { opacity: 1; transform: none; }
}
