/* 
    Zapphire Studios — Redesign 2026
    Modern, responsive, dark studio aesthetic
*/

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;500;600;700;800&family=Barlow:wght@300;400;500;600&family=Space+Mono:wght@400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;500;600;700&display=swap');

/* ─── Design Tokens ─────────────────────────────── */
:root {
    --bg:           #111214;
    --bg-surface:   #18191d;
    --bg-card:      #1e1f24;
    --bg-card-alt:  #23252b;
    --border:       rgba(255,255,255,0.07);
    --text:         #f0f0f2;
    --text-muted:   #888c96;
    --text-dim:     #555a63;
    --red:          #c8102e;
    --red-bright:   #e8192f;
    --red-glow:     rgba(200,16,46,0.18);
    --red-border:   rgba(200,16,46,0.35);
    --pink:         #e03c62;
    --pink-light:   #f9e9ed;
    --green:        #29fd53;
    --radius-sm:    6px;
    --radius-md:    12px;
    --radius-lg:    20px;
    --transition:   0.3s cubic-bezier(0.4,0,0.2,1);
    --font-display: 'Barlow Condensed', sans-serif;
    --font-body:    'Barlow', sans-serif;
    --font-mono:    'Space Mono', monospace;
    --shadow-card:  0 4px 24px rgba(0,0,0,0.45);
    --shadow-hover: 0 8px 40px rgba(200,16,46,0.22);
}

/* ─── Base Reset ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── Body & HTML background — elimina líneas negras entre secciones ── */
html,
body,
body#top {
    background-color: var(--bg) !important;
}

/* Los <br> sueltos entre secciones no deben heredar fondos diferentes */
br { display: block; background: transparent; }

/* ─── Scrollbar ──────────────────────────────────── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(to bottom, var(--red), #700010);
    border-radius: 10px;
}
html { scrollbar-color: var(--red) var(--bg); scrollbar-width: thin; }

/* ═══════════════════════════════════════════════════
   SOUND SPECTRUM PRELOADER
══════════════════════════════════════════════════ */
#preloader {
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        radial-gradient(ellipse 34% 24% at 50% 50%, rgba(232,25,47,0.12), transparent 72%),
        linear-gradient(180deg, #050507 0%, #0a0b0e 100%) !important;
    transition: opacity .45s ease, visibility .45s ease;
}

#preloader.is-hiding {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

#preloader.is-hidden {
    display: none !important;
}

#loader.sound-loader {
    position: static;
    width: min(360px, calc(100vw - 4rem));
    height: auto;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.6rem;
}

#loader.sound-loader::before {
    content: none;
}

.sound-loader__bars {
    display: grid;
    grid-template-columns: repeat(15, 4px);
    align-items: center;
    justify-content: center;
    gap: .18rem;
    width: 100%;
    height: 8.8rem;
    padding: .9rem 0;
    position: relative;
    isolation: isolate;
}

.sound-loader__bars::before,
.sound-loader__bars::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    z-index: -1;
    pointer-events: none;
}

.sound-loader__bars::before {
    top: 50%;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
}

.sound-loader__bars::after {
    inset: 18% 8% 12%;
    background: radial-gradient(ellipse at center, rgba(232,25,47,0.16), transparent 68%);
    filter: blur(16px);
}

.sound-loader__bars span {
    display: block;
    justify-self: center;
    width: 4px;
    min-width: 4px;
    height: 24%;
    border-radius: 999px;
    background: linear-gradient(180deg, #ffffff 0%, #ff5364 18%, var(--red-bright) 58%, var(--red) 100%);
    box-shadow:
        0 0 18px rgba(232,25,47,0.3),
        0 0 1px rgba(255,255,255,0.42) inset;
    animation: soundSpectrum 1.24s cubic-bezier(0.42, 0, 0.18, 1) infinite;
    transform-origin: center;
}

.sound-loader__bars span:nth-child(1)  { animation-delay: -0.92s; opacity: .38; }
.sound-loader__bars span:nth-child(2)  { animation-delay: -0.64s; opacity: .48; }
.sound-loader__bars span:nth-child(3)  { animation-delay: -0.28s; opacity: .68; }
.sound-loader__bars span:nth-child(4)  { animation-delay: -0.78s; opacity: .82; }
.sound-loader__bars span:nth-child(5)  { animation-delay: -0.14s; opacity: .94; }
.sound-loader__bars span:nth-child(6)  { animation-delay: -1.04s; }
.sound-loader__bars span:nth-child(7)  { animation-delay: -0.42s; }
.sound-loader__bars span:nth-child(8)  { animation-delay: -1.18s; }
.sound-loader__bars span:nth-child(9)  { animation-delay: -0.34s; }
.sound-loader__bars span:nth-child(10) { animation-delay: -0.86s; }
.sound-loader__bars span:nth-child(11) { animation-delay: -0.2s; opacity: .94; }
.sound-loader__bars span:nth-child(12) { animation-delay: -0.7s; opacity: .82; }
.sound-loader__bars span:nth-child(13) { animation-delay: -0.48s; opacity: .68; }
.sound-loader__bars span:nth-child(14) { animation-delay: -0.82s; opacity: .48; }
.sound-loader__bars span:nth-child(15) { animation-delay: -0.54s; opacity: .38; }

.sound-loader__label {
    color: rgba(255,255,255,0.64);
    font-family: 'Oswald', var(--font-display);
    font-size: 1.18rem;
    font-weight: 500;
    letter-spacing: .28em;
    line-height: 1;
    text-transform: uppercase;
}

@keyframes soundSpectrum {
    0%, 100% {
        height: 18%;
        filter: brightness(.82);
    }

    22% {
        height: 68%;
        filter: brightness(1.08);
    }

    44% {
        height: 36%;
    }

    66% {
        height: 88%;
        filter: brightness(1.18);
    }

    84% {
        height: 28%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .sound-loader__bars span {
        animation: none;
    }

    .sound-loader__bars span:nth-child(3n + 1) { height: 34%; }
    .sound-loader__bars span:nth-child(3n + 2) { height: 72%; }
    .sound-loader__bars span:nth-child(3n)     { height: 52%; }
}

@media (max-width: 480px) {
    .sound-loader__bars {
        gap: .16rem;
        height: 7.6rem;
    }

    .sound-loader__label {
        font-size: 1.05rem;
        letter-spacing: .22em;
    }
}

/* ═══════════════════════════════════════════════════
   SERVICES SECTION
══════════════════════════════════════════════════ */
.services-zapphires {
    background: var(--bg);
    padding: 7rem 1.5rem 5rem;
    position: relative;
    overflow: hidden;
}

/* Decorative background grain */
.services-zapphires::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(ellipse 60% 40% at 50% 0%, rgba(200,16,46,0.08) 0%, transparent 70%);
    pointer-events: none;
}

/* Section wrapper — replaces old .wrapper */
.wrapper {
    max-width: 1140px;
    width: 100%;
    margin: 0 auto;
    text-align: center;
    font-family: var(--font-display);
    background: transparent;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 1rem;
}

.wrapper h1,
.wrapper .section-heading {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(3.2rem, 5vw, 5.2rem) !important;
    line-height: .95;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--text);
    position: relative;
    display: inline-block;
    padding-bottom: 1.8rem;
    margin-bottom: 0;
    text-shadow: 0 14px 36px rgba(0,0,0,0.45);
    text-wrap: balance;
}

.wrapper .section-heading::before {
    width: min(180px, 46%);
    height: 1px;
    margin-left: 0;
    left: 50%;
    bottom: .55rem;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(232,25,47,0.75), transparent);
    opacity: .9;
}

.wrapper h1::after,
.wrapper .section-heading::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 72px;
    height: 4px;
    background: linear-gradient(90deg, #ff3449, var(--red), #ff3449);
    border-radius: 999px;
    box-shadow: 0 0 18px rgba(200,16,46,0.42);
}

/* Services grid */
.content-box_wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    width: 100%;
    margin: 3.5rem auto 0;
    padding: 0 1rem;
}

/* Service cards */
.card_wrapper {
    position: relative;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 2.5rem 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: .8rem;
    transition: var(--transition);
    overflow: hidden;
    cursor: default;
}

/* Glow shimmer on top edge */
.card_wrapper::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--red), transparent);
    opacity: 0;
    transition: var(--transition);
}

.card_wrapper::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, var(--red-glow), transparent 70%);
    opacity: 0;
    transition: var(--transition);
    pointer-events: none;
}

.card_wrapper:hover {
    border-color: var(--red-border);
    transform: translateY(-5px);
    box-shadow: var(--shadow-hover);
    background: var(--bg-card-alt);
}

.card_wrapper:hover::before { opacity: 1; }
.card_wrapper:hover::after  { opacity: 1; }

/* Icons */
.card_wrapper i {
    font-size: 7rem;
    color: var(--red-bright);
    transition: var(--transition);
    position: relative;
    z-index: 1;
}

.card_wrapper:hover i {
    color: #fff;
    filter: drop-shadow(0 0 10px var(--red-bright));
}

.card_wrapper h2 {
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--text);
    position: relative;
    z-index: 1;
}

.card_wrapper p {
    font-family: var(--font-body);
    font-size: 1.4rem;
    line-height: 1.65;
    color: var(--text-muted);
    position: relative;
    z-index: 1;
    transition: var(--transition);
}

.card_wrapper:hover p { color: #bbbfc9; }

/* ═══════════════════════════════════════════════════
   PORTFOLIO / WORKS SECTION
══════════════════════════════════════════════════ */
.portfolio-zapphire {
    background: #0d0e11;
    padding: 6.5rem 4rem 7rem;
    position: relative;
    overflow: hidden;
}

.portfolio-zapphire::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.025), transparent 22%),
        radial-gradient(ellipse 68% 48% at 82% 10%, rgba(200,16,46,0.13), transparent 72%);
    opacity: .9;
    pointer-events: none;
}

.portfolio-shell {
    width: 100%;
    max-width: 1190px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.portfolio-header {
    display: grid;
    justify-items: center;
    gap: 1.2rem;
    text-align: center;
    margin-bottom: 2.6rem;
    padding-bottom: 2rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.portfolio-header-copy {
    display: grid;
    justify-items: center;
    gap: .9rem;
}

.portfolio-header-copy p {
    max-width: 620px;
    margin: 0 auto;
    font-family: var(--font-body);
    font-size: 1.2rem;
    line-height: 1.7;
    color: rgba(240,240,242,0.66);
}

.portfolio-alt.section-heading {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: clamp(3.2rem, 5vw, 5.2rem) !important;
    line-height: .95;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--text);
    position: relative;
    display: inline-block;
    padding-top: 0;
    padding-bottom: 1.8rem;
    margin-bottom: 0;
    text-shadow: 0 14px 36px rgba(0,0,0,0.45);
    text-wrap: balance;
}

.portfolio-alt.section-heading::before {
    width: min(180px, 46%);
    height: 1px;
    margin-left: 0;
    left: 50%;
    bottom: .55rem;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(232,25,47,0.75), transparent);
    opacity: .9;
}

.portfolio-alt.section-heading::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 72px;
    height: 4px;
    background: linear-gradient(90deg, #ff3449, var(--red), #ff3449);
    border-radius: 999px;
    box-shadow: 0 0 18px rgba(200,16,46,0.42);
}

/* Section heading variants */
.section-heading3 {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 5.6rem;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--text);
    position: relative;
    line-height: .95;
    display: inline-block;
    margin: 0;
}

.section-heading3::before {
    display: none;
}

.section-heading3--centerbottom3 {
    text-align: center;
    display: block;
    padding-top: 0;
    padding-bottom: 1.4rem;
}

.section-heading3--centerbottom3::before {
    left: 50%;
    transform: translateX(-50%);
    top: auto;
    bottom: 0;
}

/* Portfolio grid */
.portfolio-container {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    width: 100%;
    margin: 0 auto;
    padding: 0;
}

/* Portfolio cards */
.portfolio-container .portfolio-box {
    position: relative;
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: var(--radius-sm);
    overflow: hidden;
    aspect-ratio: 16 / 10.5;
    background: #15161a;
    box-shadow: 0 20px 60px rgba(0,0,0,0.28);
    cursor: pointer;
    isolation: isolate;
    transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.portfolio-container .portfolio-box--featured {
    grid-column: span 2;
    grid-row: span 2;
    aspect-ratio: auto;
    min-height: 520px;
}

.portfolio-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s cubic-bezier(0.4,0,0.2,1);
    display: block;
}

.portfolio-box:hover img {
    transform: scale(1.05);
}

.portfolio-box:hover {
    border-color: rgba(200,16,46,0.36);
    box-shadow: 0 26px 80px rgba(0,0,0,0.38);
    transform: translateY(-4px);
}

/* Hover overlay */
.portfolio-box .portfolio-layer {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(5,6,8,0.96) 0%,
        rgba(5,6,8,0.68) 50%,
        rgba(5,6,8,0.18) 100%
    );
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding: 1.35rem;
    transform: translateY(0);
    transition: background var(--transition);
}

.portfolio-box--featured .portfolio-layer {
    padding: 2rem;
    background: linear-gradient(
        to top,
        rgba(5,6,8,0.98) 0%,
        rgba(5,6,8,0.62) 47%,
        rgba(5,6,8,0.05) 100%
    );
}

.portfolio-kicker {
    display: inline-flex;
    margin-bottom: .7rem;
    padding: .35rem .65rem;
    border: 1px solid rgba(200,16,46,0.34);
    border-radius: var(--radius-sm);
    background: rgba(200,16,46,0.16);
    color: #fff;
    font-family: var(--font-mono);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .14em;
    line-height: 1;
    text-transform: uppercase;
}

.portfolio-layer h4 {
    font-family: var(--font-display);
    max-width: 92%;
    font-size: 2.1rem;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1;
    color: #fff;
    margin-bottom: .3rem;
}

.portfolio-box--featured .portfolio-layer h4 {
    max-width: 620px;
    font-size: 5.2rem;
}

.portfolio-layer p {
    font-family: var(--font-body);
    font-size: .98rem;
    color: rgba(255,255,255,0.75);
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: .9rem;
}

.portfolio-box--featured .portfolio-layer p {
    font-size: 1.12rem;
    margin-bottom: 1.2rem;
}

/* Play button inside portfolio */
.portfolio-layer a,
.play-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.3);
    color: #fff;
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .65rem 1rem;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: var(--transition);
    backdrop-filter: blur(4px);
    text-decoration: none;
}

.portfolio-layer a:hover,
.play-btn:hover {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
    transform: translateY(-2px);
}

.portfolio-layer a i { font-size: 1.4rem; color: #fff; }

/* ═══════════════════════════════════════════════════
   LOCALIZATION PIPELINE
══════════════════════════════════════════════════ */
.pipeline-zapphire {
    background:
        linear-gradient(180deg, var(--bg) 0%, #0d0e11 100%);
    padding: 1.5rem 4rem 3.5rem;
    position: relative;
    overflow: hidden;
}

.pipeline-zapphire::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 64% 44% at 18% 0%, rgba(200,16,46,0.08), transparent 70%),
        linear-gradient(90deg, rgba(255,255,255,0.018), transparent 42%, rgba(255,255,255,0.012));
    pointer-events: none;
}

.pipeline-shell {
    width: 100%;
    max-width: 1190px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.pipeline-header {
    max-width: 760px;
    margin-bottom: 3rem;
}

.pipeline-eyebrow {
    display: inline-block;
    margin-bottom: 1.4rem;
    color: var(--pill-text);
    background: var(--pill-bg);
    border: 1px solid rgba(200,16,46,0.22);
    border-radius: 100px;
    padding: .35rem 1.1rem;
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    pointer-events: none;
}

.pipeline-header h2 {
    margin: 0;
    color: #fff;
    font-family: var(--font-display);
    font-size: clamp(4.8rem, 8vw, 7.8rem);
    font-weight: 800;
    line-height: .95;
    letter-spacing: 0;
}

.pipeline-header h2 span {
    color: var(--red-bright);
}

.pipeline-header p {
    max-width: 760px;
    margin: 2.2rem 0 0;
    color: rgba(240,240,242,0.58);
    font-family: var(--font-body);
    font-size: 1.2rem;
    line-height: 1.7;
}

.pipeline-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-sm);
    background: rgba(17,18,20,0.72);
    overflow: hidden;
}

.pipeline-item {
    min-height: 238px;
    padding: 2.2rem 2rem;
    border-right: 1px solid rgba(255,255,255,0.08);
    border-bottom: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.012);
    transition: background var(--transition), transform var(--transition), border-color var(--transition);
}

.pipeline-item:nth-child(3n) {
    border-right: 0;
}

.pipeline-item:nth-last-child(-n + 3) {
    border-bottom: 0;
}

.pipeline-item--featured {
    border-left: 3px solid var(--red-bright);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.018)),
        rgba(30,31,36,0.82);
}

.pipeline-item span {
    display: block;
    margin-bottom: 1.05rem;
    color: var(--red-bright);
    font-family: var(--font-mono);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.pipeline-item h3 {
    max-width: 330px;
    margin: 0 0 .95rem;
    color: #fff;
    font-family: var(--font-display);
    font-size: 2.2rem;
    font-weight: 700;
    line-height: .98;
    letter-spacing: 0;
}

.pipeline-item p {
    max-width: 360px;
    margin: 0;
    color: rgba(240,240,242,0.62);
    font-family: var(--font-body);
    font-size: 1.05rem;
    line-height: 1.55;
}

.pipeline-item:hover {
    background: rgba(255,255,255,0.04);
    border-color: rgba(200,16,46,0.28);
    transform: translateY(-2px);
}

/* ═══════════════════════════════════════════════════
   SECTION TITLE (generic utility)
═════════════════════════════════════════════════ */ 
.section-title-zapphire {
    width: 100%;
    text-align: center;
    margin-bottom: 3.5rem;
}

.section-title-zapphire h2 span { color: var(--red); }

.row-zapphire { display: flex; flex-wrap: wrap; }

img { max-width: 100%; vertical-align: middle; }

/* ─── Icon size utilities ─── */
.bx-equalizer,
.bx-joystick,
.bx-edit-alt,
.bx-user-voice,
.bx-notepad,
.bx-slideshow {
    font-size: 3.4rem;
}

/* ═══════════════════════════════════════════════════
   GOOGLE DRIVE MODAL — Premium Player
══════════════════════════════════════════════════ */

/* Overlay */
.gdrive-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.92);
    backdrop-filter: blur(12px) saturate(0.6);
    -webkit-backdrop-filter: blur(12px) saturate(0.6);
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    animation: modalOverlayIn .25s ease forwards;
}

.gdrive-modal[style*="block"] {
    display: flex !important;
}

@keyframes modalOverlayIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Container */
.gdrive-modal-content {
    position: relative;
    width: min(92vw, 900px);
    background: #13141a;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow:
        0 0 0 1px rgba(200,16,46,0.15),
        0 32px 80px rgba(0,0,0,0.85),
        0 0 60px rgba(200,16,46,0.08);
    overflow: hidden;
    animation: modalContentIn .3s cubic-bezier(0.34,1.2,0.64,1) forwards;
}

@keyframes modalContentIn {
    from { opacity: 0; transform: scale(0.93) translateY(20px); }
    to   { opacity: 1; transform: scale(1)    translateY(0);    }
}

/* ── Header bar ─────────────────────────────────── */
.gdrive-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.2rem 1rem 1.4rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.02);
    gap: 1rem;
}

.gdrive-modal-meta {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    min-width: 0;
}

.gdrive-modal-title {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.gdrive-modal-subtitle {
    font-family: var(--font-body);
    font-size: 1rem;
    letter-spacing: .09em;
    text-transform: uppercase;
    color: var(--text-muted);
}

/* Red accent dot before title */
.gdrive-modal-meta::before {
    display: none; /* handled via JS badge */
}

/* Studio badge */
.gdrive-modal-badge {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .32rem .85rem;
    border-radius: 100px;
    background: rgba(200,16,46,0.12);
    border: 1px solid rgba(200,16,46,0.28);
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--red-bright);
    white-space: nowrap;
    flex-shrink: 0;
}

.gdrive-modal-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--red-bright);
    box-shadow: 0 0 6px var(--red-bright);
    animation: pulseDot 1.8s ease-in-out infinite;
}

@keyframes pulseDot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: .5; transform: scale(.7); }
}

/* Close button */
.gdrive-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    color: var(--text-muted);
    font-size: 1.2rem;
    cursor: pointer;
    line-height: 1;
    transition: background .2s, color .2s, border-color .2s;
    flex-shrink: 0;
    user-select: none;
}

.gdrive-close:hover {
    background: rgba(200,16,46,0.15);
    border-color: rgba(200,16,46,0.4);
    color: #fff;
}

/* ── Video area ─────────────────────────────────── */
.gdrive-video-wrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #0a0a0c;
}

.gdrive-video-wrapper iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

/* ── Footer bar ─────────────────────────────────── */
.gdrive-modal-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1.4rem;
    border-top: 1px solid rgba(255,255,255,0.05);
    background: rgba(0,0,0,0.3);
    gap: 1rem;
}

.gdrive-modal-footer-brand {
    font-family: var(--font-display);
    font-size: 1.2rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--text-dim);
}

.gdrive-modal-footer-brand span {
    color: var(--red);
}

.gdrive-modal-footer-hint {
    font-family: var(--font-body);
    font-size: 1.2rem;
    color: var(--text-dim);
    letter-spacing: .04em;
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 600px) {
    .gdrive-modal { padding: .75rem; }
    .gdrive-modal-header { padding: .8rem 1rem; }
    .gdrive-modal-title  { font-size: 1.05rem; }
    .gdrive-modal-badge  { display: none; }
    .gdrive-modal-footer { flex-direction: column; gap: .3rem; text-align: center; }
}

/* ═══════════════════════════════════════════════════
   SECTION TRANSITIONS & SYMMETRY
   Unifica paddings, elimina cortes bruscos y agrega
   gradientes de fade entre secciones adyacentes.
══════════════════════════════════════════════════ */

/* ── Token de espaciado uniforme ── */
:root {
    --section-pad-v: 9rem;   /* padding vertical de cada sección */
    --section-pad-v-sm: 5rem; /* versión mobile */
}

/* ── About ──────────────────────────────────────── */
.s-about {
    padding-top: var(--section-pad-v) !important;
    padding-bottom: var(--section-pad-v) !important;
    background-color: var(--pink-light) !important;
    position: relative;
}

/* ── Services ───────────────────────────────────── */
.services-zapphires {
    padding-top: 3.5rem !important;
    padding-bottom: 3rem !important;
    position: relative;
}

/* ── Portfolio / Latest Projects ───────────────── */
.portfolio-zapphire {
    padding-top: 3rem !important;
    padding-bottom: var(--section-pad-v) !important;
    position: relative;
}

/* Cancela los pseudo-elementos previos para evitar artefactos */
.portfolio-zapphire::before,
.portfolio-zapphire::after,
.services-zapphires::after {
    display: none;
}

/* ── CTA / Discord ──────────────────────────────── */
.s-cta {
    background: linear-gradient(180deg, var(--bg) 0%, #090a0c 100%) !important;
    padding: 6rem 1.5rem !important;
    position: relative;
    overflow: hidden;
}

.s-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(88,101,242,0.16), transparent 38%),
        radial-gradient(ellipse 55% 42% at 88% 20%, rgba(200,16,46,0.16), transparent 72%);
    opacity: .8;
    pointer-events: none;
    z-index: 0;
}

.s-cta::after,
.s-contact::after { display: none; }

.discord-shell {
    width: min(1120px, 100%);
    margin: 0 auto;
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 3rem;
    align-items: center;
    padding: 3.2rem;
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: var(--radius-md);
    background: rgba(16,17,21,0.88);
    box-shadow: 0 24px 80px rgba(0,0,0,0.42);
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    margin-bottom: 1.2rem;
    font-family: var(--font-mono);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .16em;
    line-height: 1.4;
    text-transform: uppercase;
    color: var(--red-bright);
}

.eyebrow::before {
    content: '';
    width: 28px;
    height: 1px;
    background: currentColor;
}

.discord-copy h2,
.contact-intro h2,
.footer-cta h2 {
    margin: 0;
    font-family: var(--font-display);
    font-weight: 700;
    line-height: .95;
    letter-spacing: 0;
    color: var(--text);
}

.discord-copy h2 {
    max-width: 680px;
    font-size: 8.8rem;
}

.discord-copy p,
.contact-intro p,
.contact-card p,
.footer-tagline {
    font-family: var(--font-body);
    line-height: 1.7;
    color: rgba(240,240,242,0.68);
}

.discord-copy p {
    max-width: 610px;
    margin: 1.4rem 0 0;
    font-size: 1.35rem;
}

.discord-actions {
    display: grid;
    gap: 1rem;
    justify-items: end;
}

.discord-button,
.contact-button,
.footer-cta-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .8rem;
    min-height: 48px;
    padding: 0 1.6rem;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: var(--radius-sm);
    background: var(--red);
    color: #fff !important;
    font-family: var(--font-display);
    font-size: 1.18rem;
    font-weight: 700;
    letter-spacing: .08em;
    line-height: 1;
    text-transform: uppercase;
    text-decoration: none;
    transition: transform var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.discord-button {
    min-width: 220px;
    background: #5865f2;
    box-shadow: 0 16px 44px rgba(88,101,242,0.24);
}

.discord-button:hover,
.contact-button:hover,
.footer-cta-button:hover {
    transform: translateY(-3px);
    background: var(--red-bright);
    border-color: rgba(255,255,255,0.2);
    box-shadow: var(--shadow-hover);
}

.discord-note {
    max-width: 210px;
    font-family: var(--font-mono);
    font-size: .9rem;
    line-height: 1.6;
    text-align: right;
    color: var(--text-muted);
}

/* ── Contact ────────────────────────────────────── */
.s-contact {
    background: #090a0c !important;
    padding: 7rem 1.5rem !important;
    position: relative;
    overflow: hidden;
}

.s-contact::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, transparent, rgba(200,16,46,0.06)),
        radial-gradient(ellipse 70% 45% at 12% 15%, rgba(255,255,255,0.035), transparent 72%);
    opacity: .55;
    pointer-events: none;
    z-index: 0;
}

.contact-shell {
    width: min(1120px, 100%);
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.contact-intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.3rem;
    justify-items: center;
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 3rem;
    text-align: center;
}

.contact-intro h2 {
    max-width: 820px;
    font-size: 8.4rem;
}

.contact-intro p {
    max-width: 620px;
    margin: 0;
    font-size: 1.3rem;
}

.contact-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr);
    gap: 1rem;
}

.contact-card {
    min-width: 0;
    padding: 2rem;
    border: 1px solid rgba(255,255,255,0.09);
    border-radius: var(--radius-md);
    background: rgba(24,25,29,0.9);
}

.contact-card--primary {
    background:
        linear-gradient(135deg, rgba(200,16,46,0.18), transparent 52%),
        rgba(24,25,29,0.92);
}

.contact-card-label {
    display: block;
    margin-bottom: 1rem;
    font-family: var(--font-mono);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.contact-email {
    display: inline-block;
    max-width: 100%;
    margin: 0 0 1.4rem !important;
    border-bottom: 1px solid rgba(255,255,255,0.16) !important;
    color: #fff !important;
    font-family: var(--font-display) !important;
    font-size: 5.2rem !important;
    font-weight: 700 !important;
    line-height: 1.05 !important;
    overflow-wrap: anywhere;
    text-decoration: none;
}

.contact-email:hover {
    color: var(--red-bright) !important;
    border-color: var(--red-bright) !important;
}

.contact-card p {
    max-width: 680px;
    margin: 0 0 2rem;
    font-size: 1.12rem;
}

.contact-social-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: .75rem;
}

.contact-social-list li {
    padding: 0;
}

.contact-social-list li::before {
    display: none !important;
}

.contact-social-list a {
    display: flex;
    align-items: center;
    gap: .85rem;
    min-height: 46px;
    padding: .75rem .85rem;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,0.025);
    color: var(--text) !important;
    font-family: var(--font-body);
    font-size: 1.05rem;
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), transform var(--transition), color var(--transition);
}

.contact-social-list i {
    width: 1.2rem;
    color: var(--red-bright);
    text-align: center;
}

.contact-social-list a:hover {
    background: rgba(255,255,255,0.055);
    border-color: rgba(200,16,46,0.38);
    color: #fff !important;
    transform: translateX(4px);
}

.contact-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: grid;
    place-items: center;
    padding: 1.5rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--transition), visibility var(--transition);
}

.contact-modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.contact-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.72);
    backdrop-filter: blur(10px);
}

.contact-modal__dialog {
    position: relative;
    width: min(620px, 100%);
    max-height: min(88vh, 760px);
    overflow-y: auto;
    padding: 2.25rem;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: var(--radius-md);
    background:
        linear-gradient(135deg, rgba(200,16,46,0.14), transparent 48%),
        #121317;
    box-shadow: 0 24px 80px rgba(0,0,0,0.48);
    transform: translateY(18px) scale(.98);
    transition: transform var(--transition);
}

.contact-modal.is-open .contact-modal__dialog {
    transform: translateY(0) scale(1);
}

.contact-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 50%;
    background: rgba(255,255,255,0.04);
    color: #fff;
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.contact-modal__close:hover {
    background: rgba(255,255,255,0.08);
    border-color: rgba(200,16,46,0.55);
    color: var(--red-bright);
}

.contact-modal__dialog h2 {
    margin: 0 3rem 1.75rem 0;
    color: #fff;
    font-family: var(--font-display);
    font-size: 4.2rem;
    line-height: 1;
}

.contact-form {
    display: grid;
    gap: 1rem;
}

.contact-form__row {
    display: grid;
    gap: .45rem;
}

.contact-form label {
    margin: 0;
    color: var(--text-muted);
    font-family: var(--font-mono);
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    margin: 0;
    padding: 1.08rem 1.15rem;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,0.075);
    color: #ffffff !important;
    caret-color: var(--red-bright);
    font-family: var(--font-body);
    font-size: 1.32rem;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 0;
    text-shadow: 0 1px 0 rgba(0,0,0,0.3);
    -webkit-text-fill-color: #ffffff;
}

.contact-form textarea {
    min-height: 160px;
    resize: vertical;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
    color: rgba(255,255,255,0.52);
    -webkit-text-fill-color: rgba(255,255,255,0.52);
}

.contact-form input:focus,
.contact-form textarea:focus {
    background: rgba(255,255,255,0.1);
    color: #ffffff !important;
    border-color: rgba(200,16,46,0.62);
    box-shadow: 0 0 0 3px rgba(200,16,46,0.15);
    -webkit-text-fill-color: #ffffff;
}

.contact-form__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .7rem;
    min-height: 52px;
    margin-top: .35rem;
    border: 0;
    border-radius: 999px;
    background: var(--red);
    color: #fff;
    font-family: var(--font-mono);
    font-size: .86rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background var(--transition), transform var(--transition);
}

.contact-form__submit:hover {
    background: var(--red-bright);
    transform: translateY(-2px);
}

/* ── Footer ─────────────────────────────────────── */
footer,
.site-footer {
    background: #050506 !important;
    padding: 0 !important;
    border-top: 1px solid rgba(255,255,255,0.06) !important;
    font-family: var(--font-body);
}

.footer-inner {
    width: 100%;
    margin: 0 auto;
    padding: 4.5rem 4rem 2rem !important;
}

.footer-cta {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1.4rem;
    max-width: 760px;
    margin: 0 auto;
    padding-bottom: 3.2rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    text-align: center;
}

.footer-cta h2 {
    max-width: 720px;
    font-size: 4.8rem;
}

.footer-main {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) auto minmax(220px, 1fr);
    gap: 3rem;
    align-items: start;
    padding: 3.2rem 0;
}

.footer-brand {
    min-width: 0;
}

.footer-logo img {
    display: block;
    width: 50px;
    height: auto;
    margin-bottom: 1.4rem;
    opacity: .94;
    transition: opacity var(--transition), transform var(--transition);
}

.footer-logo:hover img {
    opacity: 1;
    transform: translateY(-2px);
}

.footer-tagline {
    max-width: 280px;
    margin: 0 0 1.4rem;
    font-size: .98rem;
}

.footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem;
}

.footer-social a,
.footer-go-top {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,0.03);
    color: var(--text-muted) !important;
    text-decoration: none;
    transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
}

.footer-social a:hover,
.footer-go-top:hover {
    background: rgba(200,16,46,0.14);
    border-color: rgba(200,16,46,0.42);
    color: #fff !important;
    transform: translateY(-3px);
}

.footer-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: .2rem;
    justify-self: center;
    min-width: 0;
}

.footer-nav-col {
    display: contents;
}

.footer-nav-label {
    display: none;
}

.footer-nav-col ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: .2rem;
}

.footer-nav-col li {
    padding: 0;
}

.footer-nav-col a {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 1rem;
    color: rgba(240,240,242,0.62) !important;
    font-family: var(--font-display) !important;
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-decoration: none;
    transition: color var(--transition), transform var(--transition);
}

.footer-nav-col a:hover {
    color: #fff !important;
    transform: translateY(-2px);
}

.footer-connect {
    display: grid;
    gap: 1rem;
    justify-items: end;
    min-width: 0;
}

.footer-email {
    color: rgba(240,240,242,0.68) !important;
    font-family: var(--font-display) !important;
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: .08em;
    line-height: 1.4;
    overflow-wrap: anywhere;
    text-align: right;
    text-decoration: none;
    transition: color var(--transition);
}

.footer-email:hover {
    color: #fff !important;
}

.footer-bottom {
    display: flex;
    align-items: center;
    gap: 1.25rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(255,255,255,0.08);
}

.footer-copy,
.footer-credit {
    font-size: .92rem;
    line-height: 1.5;
    color: rgba(240,240,242,0.46);
}

.footer-credit {
    margin-left: auto;
}

.footer-credit a {
    color: rgba(240,240,242,0.72) !important;
    text-decoration: none;
}

.footer-credit a:hover {
    color: var(--red-bright) !important;
}

.footer-go-top {
    flex: 0 0 40px;
}

/* ── Footer / Contact / Discord responsive ── */
@media (max-width: 900px) {
    .discord-shell,
    .contact-intro,
    .contact-panel,
    .footer-main {
        grid-template-columns: 1fr;
    }

    .discord-actions {
        justify-items: start;
    }

    .discord-note {
        max-width: none;
        text-align: left;
    }

    .footer-cta-button {
        width: max-content;
    }

    .footer-inner {
        padding-left: 3rem !important;
        padding-right: 3rem !important;
    }

    .footer-main,
    .footer-brand,
    .footer-connect {
        justify-items: start;
        text-align: left;
    }

    .footer-nav {
        justify-self: stretch;
        min-width: 0;
    }

    .footer-email {
        text-align: left;
    }

    .discord-copy h2,
    .contact-intro h2 {
        font-size: 6rem;
    }

    .contact-email {
        font-size: 4rem !important;
    }

    .footer-cta h2 {
        font-size: 4rem;
    }
}

@media (max-width: 620px) {
    .s-cta,
    .s-contact {
        padding: 4.5rem 1rem !important;
    }

    .discord-shell,
    .contact-card {
        padding: 1.5rem;
    }

    .discord-copy h2,
    .contact-intro h2 {
        font-size: 3.4rem;
    }

    .contact-email {
        font-size: 2.5rem !important;
    }

    .contact-modal {
        padding: 1rem;
    }

    .contact-modal__dialog {
        padding: 1.5rem;
    }

    .contact-modal__dialog h2 {
        margin-right: 2.5rem;
        font-size: 3rem;
    }

    .footer-cta h2 {
        font-size: 3rem;
    }

    .discord-button,
    .contact-button,
    .footer-cta-button {
        width: 100%;
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .footer-inner {
        padding: 4rem 2rem 1.5rem !important;
    }

    .footer-nav {
        grid-template-columns: 1fr;
    }

    .footer-bottom {
        align-items: flex-start;
        flex-direction: column;
    }

    .footer-credit {
        margin-left: 0;
    }

    .footer-go-top {
        align-self: flex-end;
        margin-top: -3.2rem;
    }
}

/* ═══════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .content-box_wrapper { grid-template-columns: repeat(2, 1fr); }
    .portfolio-container { grid-template-columns: repeat(2, 1fr); }
    .pipeline-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .pipeline-item,
    .pipeline-item:nth-child(3n),
    .pipeline-item:nth-last-child(-n + 3) {
        border-right: 1px solid rgba(255,255,255,0.08);
        border-bottom: 1px solid rgba(255,255,255,0.08);
    }
    .pipeline-item:nth-child(2n) { border-right: 0; }
    .pipeline-item:nth-last-child(-n + 2) { border-bottom: 0; }
}

@media (max-width: 700px) {
    :root { --section-pad-v: var(--section-pad-v-sm); }
    .services-zapphires { padding: var(--section-pad-v-sm) 1rem !important; }
    .content-box_wrapper { grid-template-columns: 1fr; max-width: 420px; }
    .pipeline-zapphire { padding: 2.5rem 1rem var(--section-pad-v-sm) !important; }
    .pipeline-header { margin: 0 auto 2.4rem; max-width: 420px; }
    .pipeline-eyebrow { font-size: 1rem; letter-spacing: .16em; }
    .pipeline-header h2 { font-size: 4.2rem; }
    .pipeline-header p { margin-top: 1.6rem; font-size: 1.05rem; line-height: 1.6; }
    .pipeline-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
    .pipeline-item,
    .pipeline-item:nth-child(2n),
    .pipeline-item:nth-child(3n),
    .pipeline-item:nth-last-child(-n + 2),
    .pipeline-item:nth-last-child(-n + 3) {
        min-height: auto;
        padding: 2rem 1.5rem;
        border-right: 0;
        border-bottom: 1px solid rgba(255,255,255,0.08);
    }
    .pipeline-item:last-child { border-bottom: 0; }
    .portfolio-zapphire  { padding: var(--section-pad-v-sm) 1rem !important; }
    .portfolio-container { grid-template-columns: 1fr; max-width: 420px; }
    .card_wrapper        { padding: 2rem 1.5rem; }
}

@media (max-width: 400px) {
    .portfolio-container { max-width: 100%; }
    .pipeline-grid { max-width: 100%; }
    .content-box_wrapper { max-width: 100%; }
}

/* ═══════════════════════════════════════════════════
   LEGAL PAGES
══════════════════════════════════════════════════ */
.legal-page {
    background: var(--bg);
    color: var(--text);
    scroll-behavior: smooth;
}

html:has(body.legal-page) {
    scroll-behavior: smooth;
}

.legal-main {
    background:
        radial-gradient(ellipse 70% 42% at 16% 0%, rgba(200,16,46,0.16), transparent 72%),
        linear-gradient(180deg, #0d0e11 0%, var(--bg) 36%, #0d0e11 100%);
    min-height: 100vh;
}

.legal-shell {
    width: min(1120px, calc(100% - 4rem));
    margin: 0 auto;
}

.legal-hero {
    padding: 16rem 0 7rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    position: relative;
    overflow: hidden;
}

.legal-hero::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--red), var(--red-bright), transparent);
    opacity: .55;
}

.legal-kicker {
    display: inline-block;
    margin-bottom: 1.5rem;
    color: var(--pill-text);
    background: var(--pill-bg);
    border: 1px solid rgba(200,16,46,0.22);
    border-radius: 100px;
    padding: .35rem 1.1rem;
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.legal-hero h1 {
    max-width: 820px;
    margin: 0;
    color: #fff;
    font-family: var(--font-display);
    font-size: clamp(5.4rem, 9vw, 10rem);
    font-weight: 800;
    line-height: .9;
    letter-spacing: 0;
}

.legal-hero h1 span {
    color: var(--red-bright);
}

.legal-hero p {
    max-width: 760px;
    margin: 2.4rem 0 0;
    color: rgba(240,240,242,0.64);
    font-family: var(--font-body);
    font-size: 1.7rem;
    line-height: 1.7;
}

.legal-meta {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-top: 3rem;
    color: rgba(255,255,255,0.52);
    font-family: var(--font-mono);
    font-size: 1.1rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.legal-meta a {
    color: var(--red-bright);
    text-decoration: none;
}

.legal-content-section {
    padding: 6rem 0 7rem;
}

.legal-layout {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 4.5rem;
    align-items: start;
}

.legal-sidebar {
    position: sticky;
    top: 9rem;
    display: flex;
    flex-direction: column;
    gap: .35rem;
    padding: 1.5rem;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-sm);
    background: rgba(17,18,20,0.72);
}

.legal-sidebar span {
    margin-bottom: .8rem;
    color: rgba(255,255,255,0.46);
    font-family: var(--font-mono);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: .16em;
    text-transform: uppercase;
}

.legal-sidebar a {
    color: rgba(255,255,255,0.7);
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-decoration: none;
    transition: color var(--transition), transform var(--transition);
}

.legal-sidebar a:hover {
    color: var(--red-bright);
    transform: translateX(4px);
}

.legal-document {
    padding: 3.2rem;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: var(--radius-sm);
    background: rgba(17,18,20,0.76);
    box-shadow: 0 24px 90px rgba(0,0,0,0.34);
}

.legal-notice {
    margin-bottom: 3rem;
    padding: 1.4rem 1.6rem;
    border-left: 3px solid var(--red-bright);
    background: rgba(255,255,255,0.04);
    color: rgba(240,240,242,0.68);
    font-family: var(--font-body);
    font-size: 1.55rem;
    line-height: 1.7;
}

.legal-notice strong {
    color: #fff;
}

.legal-document section {
    padding: 0 0 3rem;
    margin: 0 0 3rem;
    border-bottom: 1px solid rgba(255,255,255,0.08);
    scroll-margin-top: 10rem;
}

.legal-document section:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
    border-bottom: 0;
}

.legal-document h2 {
    margin: 0 0 1.2rem;
    color: #fff;
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 3.4vw, 3.8rem);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
}

.legal-document p {
    margin: 0 0 1.25rem;
    color: rgba(240,240,242,0.66);
    font-family: var(--font-body);
    font-size: 1.65rem;
    line-height: 1.82;
}

.legal-document p:last-child {
    margin-bottom: 0;
}

.legal-document a {
    color: var(--red-bright);
    text-decoration: none;
}

.legal-document a:hover {
    color: #fff;
}

@media (max-width: 900px) {
    .legal-layout {
        grid-template-columns: 1fr;
        gap: 2.4rem;
    }

    .legal-sidebar {
        position: static;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .legal-sidebar span {
        grid-column: 1 / -1;
    }
}

@media (max-width: 700px) {
    .legal-shell {
        width: min(100% - 2rem, 430px);
    }

    .legal-hero {
        padding: 11rem 0 4.5rem;
    }

    .legal-hero h1 {
        font-size: 5rem;
    }

    .legal-hero p {
        font-size: 1.45rem;
    }

    .legal-content-section {
        padding: 3rem 0 4rem;
    }

    .legal-sidebar {
        grid-template-columns: 1fr;
    }

    .legal-document {
        padding: 2rem 1.4rem;
    }

    .legal-document p,
    .legal-notice {
        font-size: 1.5rem;
    }

    .legal-sidebar a {
        font-size: 1.6rem;
    }
}


/* ═══════════════════════════════════════════════════
   REDESIGN v2 — Header · About Us · Mission & Vision
══════════════════════════════════════════════════ */

/* ─── Tokens adicionales ─────────────────────────── */
:root {
    --header-h:      72px;
    --header-border: rgba(255,255,255,0.06);
    --about-bg:      #0e0f11;
    --mv-bg:         #111214;
    --pill-bg:       rgba(200,16,46,0.12);
    --pill-text:     #e8192f;
}


/* ═══════════════════════════════════════════════════
   HEADER — Rediseño completo
══════════════════════════════════════════════════ */

/* ── Contenedor ─────────────────────────────────── */
.s-header {
    height: var(--header-h) !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    z-index: 200 !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 4rem !important;
    gap: 0;

    /* Empieza transparente */
    background: transparent !important;
    border-bottom: 1px solid transparent !important;
    transition:
        background   0.45s cubic-bezier(0.4,0,0.2,1),
        border-color 0.45s cubic-bezier(0.4,0,0.2,1),
        box-shadow   0.45s cubic-bezier(0.4,0,0.2,1);
}

/* Sticky: fondo oscuro con blur */
.s-header.sticky {
    background: rgba(8,8,10,0.82) !important;
    border-bottom-color: rgba(255,255,255,0.055) !important;
    box-shadow: 0 2px 40px rgba(0,0,0,0.6), 0 1px 0 rgba(200,16,46,0.12) !important;
    backdrop-filter: blur(20px) saturate(1.4);
    -webkit-backdrop-filter: blur(20px) saturate(1.4);
}

/* Línea roja inferior animada al hacer scroll — pseudo del header */
.s-header::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--red) 40%, var(--red-bright) 60%, transparent);
    transition: width 0.6s cubic-bezier(0.4,0,0.2,1);
    pointer-events: none;
}

.s-header.sticky::after {
    width: 100%;
}

/* ── Logo ────────────────────────────────────────── */
.s-header .header-logo {
    position: static !important;
    transform: none !important;
    top: auto !important;
    left: auto !important;
    margin: 0 !important;
    flex-shrink: 0;
}

.s-header .header-logo a {
    display: flex;
    align-items: center;
}

.s-header .header-logo img {
    width: 50px;
    height: auto;
    display: block;
    transition: opacity 0.2s ease, filter 0.2s ease;
    filter: brightness(1);
}

.s-header .header-logo a:hover img {
    opacity: 0.85;
    filter: brightness(1.1);
}

/* ── Nav wrap (centro) ───────────────────────────── */
.s-header .header-nav-wrap {
    position: absolute !important;
    left: 50% !important;
    top: 0 !important;
    transform: translateX(-50%) !important;
    flex: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 100%;
    width: auto !important;
    background: transparent !important;
}

/* ── Nav principal ───────────────────────────────── */
.header-main-nav {
    display: flex !important;
    align-items: center;
    gap: 0 !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 100%;
}

.header-main-nav li {
    margin: 0 !important;
    padding: 0 !important;
    height: 100%;
    display: flex !important;
    align-items: center;
}

.header-main-nav li a {
    display: flex !important;
    align-items: center;
    height: 100%;
    padding: 0 2rem !important;
    font-family: var(--font-display) !important;
    font-size: 1.2rem !important;
    font-weight: 600 !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,0.48) !important;
    line-height: 1 !important;
    position: relative;
    transition: color 0.22s ease;
    text-decoration: none !important;
}

/* Punto activo debajo del link */
.header-main-nav li a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) scaleX(0);
    width: calc(100% - 4rem);
    height: 2px;
    background: linear-gradient(90deg, var(--red), var(--red-bright));
    border-radius: 2px 2px 0 0;
    transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
    transform-origin: center bottom;
}

.header-main-nav li a:hover {
    color: #fff !important;
}

.header-main-nav li a:hover::before,
.header-main-nav .current a::before {
    transform: translateX(-50%) scaleX(1);
}

.header-main-nav .current a {
    color: #fff !important;
}

/* ── Divider vertical entre nav y social ─────────── */
.s-header > .header-social {
    position: static !important;
    margin-left: auto !important;
    top: auto !important;
    right: auto !important;
    display: flex !important;
    align-items: center;
    gap: 2px;
    list-style: none !important;
    flex-shrink: 0;
    padding-left: 2.4rem;
    border-left: 1px solid rgba(255,255,255,0.08);
}

.s-header > .header-social li {
    margin: 0 !important;
}

.s-header > .header-social li a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: 1px solid transparent;
    color: rgba(255,255,255,0.38) !important;
    font-size: 1.65rem;
    line-height: 1 !important;
    text-decoration: none !important;
    transition: color 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.s-header > .header-social li a:hover {
    color: #fff !important;
    background: rgba(200,16,46,0.13);
    border-color: rgba(200,16,46,0.25);
}

/* ── Hamburguesa (mobile) ────────────────────────── */
.header-menu-toggle {
    display: none;
    position: absolute !important;
    right: 2.4rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 40px;
    height: 40px;
    border-radius: 8px;
    border: 1px solid rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.7) !important;
    transition: background 0.2s, border-color 0.2s;
    z-index: 10;
}

.header-menu-toggle:hover {
    background: rgba(200,16,46,0.1) !important;
    border-color: rgba(200,16,46,0.3) !important;
    color: #fff !important;
}

/* ── Responsive ──────────────────────────────────── */

/* Pantallas medianas: ocultar social */
@media screen and (max-width: 1100px) {
    .s-header > .header-social { display: none !important; }
    .s-header { padding: 0 3rem !important; }
}

/* Mobile: menú drawer */
@media screen and (max-width: 800px) {
    .s-header {
        padding: 0 2rem !important;
        background: rgba(8,8,10,0.96) !important;
        border-bottom-color: rgba(255,255,255,0.055) !important;
    }

    .s-header::after { display: none; }

    .header-menu-toggle { display: flex !important; align-items: center; justify-content: center; }

    /* Nav como drawer de pantalla completa */
    .s-header .header-nav-wrap {
        display: none !important;
        position: fixed !important;
        top: var(--header-h) !important;
        left: 0 !important;
        right: 0 !important;
        transform: none !important;
        width: 100% !important;
        bottom: 0 !important;
        height: auto !important;
        background: rgba(8,8,10,0.98) !important;
        flex-direction: column !important;
        justify-content: flex-start !important;
        align-items: stretch !important;
        padding: 2.4rem 2.8rem 4rem !important;
        border-top: 1px solid rgba(255,255,255,0.05) !important;
        backdrop-filter: blur(24px);
        overflow-y: auto;
        gap: 3.2rem;
    }

    .header-main-nav {
        flex-direction: column !important;
        height: auto !important;
        gap: 0 !important;
        width: 100%;
    }

    .header-main-nav li {
        height: auto !important;
        width: 100%;
        border-bottom: 1px solid rgba(255,255,255,0.05);
    }

    .header-main-nav li:first-child {
        border-top: 1px solid rgba(255,255,255,0.05);
    }

    .header-main-nav li a {
        height: auto !important;
        padding: 1.8rem 0 !important;
        font-size: 1.6rem !important;
        letter-spacing: .1em !important;
        color: rgba(255,255,255,0.6) !important;
        width: 100%;
        justify-content: space-between;
    }

    /* Flecha decorativa en cada ítem del drawer */
    .header-main-nav li a::after {
        content: '→';
        font-size: 1.2rem;
        color: var(--red);
        opacity: 0;
        transform: translateX(-6px);
        transition: opacity 0.2s, transform 0.2s;
    }

    .header-main-nav li a::before { display: none !important; }

    .header-main-nav li a:hover::after,
    .header-main-nav .current a::after {
        opacity: 1;
        transform: translateX(0);
    }

    .header-main-nav .current a {
        color: #fff !important;
    }

    /* Social en el drawer */
    .s-header .header-nav-wrap .header-social,
    .s-header > .header-social {
        display: flex !important;
        position: static !important;
        border-left: none !important;
        padding-left: 0 !important;
        gap: .6rem !important;
        flex-wrap: wrap;
    }

    .s-header > .header-social { display: none !important; }
}


/* ═══════════════════════════════════════════════════
   ABOUT US
══════════════════════════════════════════════════ */

.s-about {
    background:
        linear-gradient(180deg, #0d0e10 0%, var(--about-bg) 42%, var(--mv-bg) 100%) !important;
    padding-top: 7rem !important;
    padding-bottom: 0 !important;
    position: relative;
    overflow: hidden;
}

/* Línea superior sutil */
.s-about::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(
        to right,
        transparent,
        rgba(200,16,46,0.3) 30%,
        rgba(200,16,46,0.3) 70%,
        transparent
    );
    pointer-events: none;
}

/* Brillo decorativo */
.s-about::after {
    content: '';
    position: absolute;
    top: -180px;
    right: -220px;
    width: 720px;
    height: 720px;
    background:
        radial-gradient(circle, rgba(200,16,46,0.12) 0%, transparent 62%);
    pointer-events: none;
    z-index: 0;
}

.about-me {
    width: min(1120px, calc(100% - 3rem));
    margin: 0 auto;
    padding-bottom: 6rem;
    position: relative;
    z-index: 1;
}

.s-about .heading-block {
    max-width: 760px;
    margin: 0 auto 3.4rem;
    position: relative;
    z-index: 1;
    text-align: center;
}

/* Pill "WHO WE ARE" sobre el título */
.s-about .heading-block::before {
    content: 'WHO WE ARE';
    display: inline-block;
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--pill-text);
    background: var(--pill-bg);
    border: 1px solid rgba(200,16,46,0.22);
    border-radius: 100px;
    padding: .35rem 1.1rem;
    margin-bottom: 1.4rem;
    pointer-events: none;
}

/* Título principal */
.s-about .section-heading {
    font-family: var(--font-display) !important;
    font-size: clamp(4rem, 6vw, 6.4rem) !important;
    font-weight: 800 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    color: var(--text) !important;
    line-height: .95 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 1.8rem !important;
    position: relative;
    text-shadow: 0 16px 42px rgba(0,0,0,0.5);
}

.s-about .section-heading::before {
    display: block !important;
    width: min(180px, 46%);
    height: 1px;
    margin-left: 0;
    left: 50%;
    bottom: .55rem;
    top: auto;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(232,25,47,0.75), transparent);
    opacity: .9;
}

.s-about .section-heading::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 72px;
    height: 4px;
    background: linear-gradient(90deg, #ff3449, var(--red), #ff3449);
    border-radius: 999px;
    box-shadow: 0 0 18px rgba(200,16,46,0.42);
}

/* Contenido */
.about-me__content {
    max-width: 1120px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.about-me__text {
    columns: auto !important;
    column-count: auto !important;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
    gap: 3.2rem;
    align-items: start;
    padding: 3rem;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.055), rgba(255,255,255,0.015)),
        rgba(18,19,23,0.72);
    box-shadow: 0 24px 70px rgba(0,0,0,0.3);
}

/* Lead con barra lateral roja */
.s-about p.lead {
    grid-column: 1;
    font-family: var(--font-display) !important;
    font-size: clamp(2.5rem, 3vw, 3.4rem) !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
    color: var(--text) !important;
    margin-bottom: 1.6rem !important;
    letter-spacing: .02em;
    padding-left: 1.8rem;
    border-left: 4px solid var(--red);
}

/* Párrafo normal */
.s-about .about-me__text p:not(.lead) {
    grid-column: 1;
    font-family: var(--font-body);
    font-size: 1.55rem;
    line-height: 1.75;
    color: rgba(240,240,242,0.68);
    margin-bottom: 0;
    max-width: 680px;
}

/* Stat strip */
.about-stat-strip {
    grid-column: 2;
    grid-row: 1 / span 2;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.about-stat {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 1.1rem;
    min-height: 86px;
    padding: 1.2rem 1.35rem;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    background: rgba(255,255,255,0.035);
    transition: border-color var(--transition), background var(--transition), transform var(--transition);
}

.about-stat:hover {
    border-color: rgba(200,16,46,0.28);
    background: rgba(200,16,46,0.075);
    transform: translateY(-2px);
}

.about-stat__number {
    font-family: var(--font-display);
    min-width: 82px;
    font-size: 4.4rem;
    font-weight: 800;
    line-height: 1;
    color: var(--text);
    letter-spacing: .02em;
}

.about-stat__number span {
    color: var(--red);
}

.about-stat__label {
    font-family: var(--font-body);
    font-size: 1.18rem;
    color: rgba(240,240,242,0.62);
    letter-spacing: .06em;
    text-transform: uppercase;
}


/* ═══════════════════════════════════════════════════
   MISSION & VISION
══════════════════════════════════════════════════ */

.about-experience {
    background:
        linear-gradient(180deg, rgba(255,255,255,0.025), transparent 28%),
        var(--mv-bg);
    padding: 5rem 1.5rem 3.5rem;
    border-top: 1px solid var(--border);
    position: relative;
    z-index: 1;
}

/* Pill "OUR PURPOSE" */
.about-experience .heading-block::before {
    content: 'OUR PURPOSE';
    display: inline-block;
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--pill-text);
    background: var(--pill-bg);
    border: 1px solid rgba(200,16,46,0.22);
    border-radius: 100px;
    padding: .35rem 1.1rem;
    margin-bottom: 1.4rem;
    pointer-events: none;
}

.about-experience .heading-block {
    max-width: 760px;
    margin: 0 auto 3.2rem;
    text-align: center;
}

.about-experience .section-heading {
    font-family: var(--font-display) !important;
    font-size: clamp(3.8rem, 5vw, 5.8rem) !important;
    font-weight: 800 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    color: var(--text) !important;
    line-height: .98 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 1.7rem !important;
    position: relative;
    text-shadow: 0 16px 42px rgba(0,0,0,0.5);
}

.about-experience .section-heading::before {
    display: block !important;
    width: min(180px, 46%);
    height: 1px;
    margin-left: 0;
    left: 50%;
    bottom: .55rem;
    top: auto;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(232,25,47,0.75), transparent);
    opacity: .9;
}

.about-experience .section-heading::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 72px;
    height: 4px;
    background: linear-gradient(90deg, #ff3449, var(--red), #ff3449);
    border-radius: 999px;
    box-shadow: 0 0 18px rgba(200,16,46,0.42);
}

/* Grid de columnas */
.about-experience__timeline {
    gap: 2.4rem;
    align-items: stretch;
}

/* Ocultar elementos originales del timeline */
.timeline__icon-wrap { display: none !important; }
.timeline__bullet    { display: none !important; }

/* Tarjeta */
.timeline {
    background:
        linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
        var(--bg-card);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;
    padding: 0 !important;
    overflow: hidden;
    transition: box-shadow 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
    box-shadow: 0 18px 55px rgba(0,0,0,0.24);
}

.timeline:hover {
    border-color: rgba(200,16,46,0.34);
    box-shadow: 0 24px 70px rgba(0,0,0,0.34), 0 0 36px rgba(200,16,46,0.08);
    transform: translateY(-3px);
}

.timeline__block {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 0;
}

/* Cabecera de la tarjeta */
.timeline__header {
    padding: 2.4rem 2.6rem 2.2rem !important;
    position: relative;
    border-bottom: 1px solid var(--border);
    background:
        linear-gradient(90deg, rgba(200,16,46,0.13), transparent 68%),
        rgba(255,255,255,0.025);
}

/* Badge decorativo (cuadrado con la letra) */
.timeline__header::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 2.4rem;
    transform: translateY(-50%);
    width: 50px;
    height: 50px;
    border-radius: 10px;
    border: 1px solid rgba(200,16,46,0.28);
    background: rgba(200,16,46,0.12);
    pointer-events: none;
}

.column:first-child .timeline__header::before,
.column:last-child  .timeline__header::before {
    position: absolute;
    right: calc(2.4rem + 12px);
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--red);
    z-index: 1;
    letter-spacing: 0;
}

.column:first-child .timeline__header::before { content: 'M'; }
.column:last-child  .timeline__header::before { content: 'V'; }

/* Título */
.timeline__header .item-title {
    font-family: var(--font-display) !important;
    font-size: 2.8rem !important;
    font-weight: 700 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase;
    color: var(--text) !important;
    margin: 0 !important;
    line-height: 1.1;
    padding-right: 5rem;
}

/* Descripción */
.timeline__desc {
    padding: 2.4rem 2.6rem !important;
    flex: 1;
}

.timeline__desc p {
    font-family: var(--font-body) !important;
    font-size: 1.48rem !important;
    line-height: 1.78 !important;
    color: rgba(240,240,242,0.66) !important;
    margin-bottom: 0 !important;
}

/* ── Grid M&V: dos columnas lado a lado ─────────── */
.about-experience__timeline.row {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 2.4rem !important;
    align-items: stretch;
    max-width: 1120px;
    margin: 0 auto;
}

.about-experience__timeline .column.large-half {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    width: auto !important;
    float: none !important;
}

/* ── Responsive About + M&V ─────────────────────── */
@media screen and (max-width: 700px) {
    .s-about { padding-top: 5rem !important; }
    .about-me { width: min(100% - 2rem, 1120px); padding-bottom: 4rem; }
    .about-me__text {
        grid-template-columns: 1fr;
        padding: 2rem;
        gap: 2.2rem;
    }

    .about-stat-strip   { gap: .85rem; }
    .about-stat-strip {
        grid-column: 1;
        grid-row: auto;
    }
    .about-stat__number { font-size: 3.6rem; }

    .about-experience__timeline.row       { flex-wrap: wrap !important; }
    .about-experience__timeline .column.large-half { flex: 1 1 100% !important; }

    .timeline__header { padding: 2rem 2rem 1.6rem !important; }
    .timeline__desc   { padding: 2rem 2rem !important; }
    .timeline__header .item-title { font-size: 2.4rem !important; }
}


/* ═══════════════════════════════════════════════════
   INTRO — Rediseño completo
══════════════════════════════════════════════════ */

/* ── Contenedor ─────────────────────────────────── */
.s-intro {
    width: 100% !important;
    height: 100vh !important;
    min-height: 700px !important;
    max-height: none !important;
    background: #050608 !important;
    position: relative !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
}

/* ── Video de fondo ──────────────────────────────── */
.intro-media {
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    opacity: var(--intro-fade, 1);
    transform: scale(calc(1 + ((1 - var(--intro-fade, 1)) * .035)));
    transition: opacity .18s linear, transform .18s linear;
    pointer-events: none;
}

.intro-video {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: center !important;
    filter: saturate(.78) contrast(1.08) brightness(.58);
}

/* ── Imagen fallback + overlays ──────────────────── */
.intro-pic {
    position: absolute !important;
    inset: 0 !important;
    top: 0 !important; left: 0 !important;
    right: 0 !important; bottom: 0 !important;
    width: 100% !important;
    background-color: #07090d !important;
    background-image: url(../img/iStock-1426350273.jpg) !important;
    background-size: cover !important;
    background-position: center 30% !important;
    background-repeat: no-repeat !important;
    z-index: 1 !important;
    opacity: calc(.2 + (var(--intro-fade, 1) * .26));
    transition: opacity .18s linear;
    pointer-events: none;
}

.intro-pic::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        110deg,
        rgba(5,6,8,0.98) 0%,
        rgba(5,6,8,0.88) 34%,
        rgba(10,11,15,0.62) 58%,
        rgba(10,11,15,0.36) 100%
    ) !important;
    z-index: 1;
}

.intro-pic::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to top, #050608 0%, rgba(5,6,8,0) 28%),
        radial-gradient(circle at 78% 32%, rgba(200,16,46,0.22), transparent 28%),
        linear-gradient(90deg, rgba(255,255,255,0.035) 0 1px, transparent 1px 100%);
    background-size: auto, auto, 18rem 18rem;
    z-index: 2;
}

/* ── Grid de puntos ──────────────────────────────── */
.intro-grid {
    position: absolute !important;
    inset: 0 !important;
    background-image: url(../img/pattern-dot-grid.svg) !important;
    background-size: 28px 28px !important;
    opacity: calc(var(--intro-fade, 1) * .045) !important;
    z-index: 2 !important;
    pointer-events: none;
}

/* ── Línea vertical estructural izquierda ────────── */
.s-intro::before {
    content: '';
    position: absolute;
    left: 7rem;
    top: 0; bottom: 0;
    width: 1px;
    background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(200,16,46,0.22) 25%,
        rgba(200,16,46,0.22) 75%,
        transparent 100%
    );
    z-index: 3;
    pointer-events: none;
}

/* ── "Z" decorativo de fondo ─────────────────────── */
.s-intro::after {
    content: 'Z';
    position: absolute;
    right: -4vw;
    top: 50%;
    transform: translateY(-50%);
    font-family: var(--font-display);
    font-size: 52vw;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.05em;
    color: rgba(255,255,255,0.016);
    z-index: 1;
    pointer-events: none;
    user-select: none;
}

/* ── Contenido ───────────────────────────────────── */
.intro-content {
    position: relative !important;
    z-index: 10 !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 9rem 0 10rem !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    align-items: flex-start !important;
    padding-bottom: 13.5rem !important;
    opacity: calc(.2 + (var(--intro-fade, 1) * .8));
    transform: translateY(calc((1 - var(--intro-fade, 1)) * -26px));
    transition: opacity .16s linear, transform .16s linear;
}

/* ── Bloque de texto ─────────────────────────────── */
.intro-text {
    transform: none !important;
    position: static !important;
    z-index: 2;
    max-width: 980px;
}

/* Eyebrow */
.intro-text h3 {
    font-family: var(--font-display) !important;
    font-size: 1.15rem !important;
    font-weight: 700 !important;
    letter-spacing: .32em !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,0.42) !important;
    margin: 0 0 2.8rem 0 !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 1.4rem !important;
}

.intro-text h3::before {
    content: '' !important;
    display: block !important;
    width: 6px !important;
    height: 6px !important;
    border-radius: 50% !important;
    background: var(--red) !important;
    flex-shrink: 0 !important;
}

/* Headline principal */
.intro-text h1 {
    font-family: var(--font-display) !important;
    font-size: clamp(5.8rem, 8.4vw, 11.8rem) !important;
    font-weight: 850 !important;
    line-height: .92 !important;
    letter-spacing: 0 !important;
    color: #ffffff !important;
    margin: 0 0 4.2rem 0 !important;
    text-transform: uppercase !important;
}

/* Línea en outline italic */
.intro-text h1 .outline {
    font-style: italic;
    color: transparent !important;
    -webkit-text-stroke: 1.5px rgba(255,255,255,0.58);
    text-shadow: 0 0 28px rgba(200,16,46,0.12);
    display: block;
}

/* Fila inferior: tagline + CTAs */
.intro-bottom {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    width: 100%;
    gap: 4rem;
}

.intro-tagline {
    font-family: var(--font-body);
    font-size: 1.65rem;
    font-weight: 300;
    line-height: 1.65;
    color: rgba(255,255,255,0.52);
    max-width: 460px;
}

.intro-tagline strong {
    font-weight: 400;
    color: rgba(255,255,255,0.82);
    display: block;
    margin-bottom: .4rem;
}

.intro-brand-mark {
    font-family: 'Oswald', var(--font-display);
    font-size: 1.9rem;
    font-weight: 700 !important;
    letter-spacing: .16em;
    line-height: 1;
}

.intro-brand-mark span {
    color: var(--red-bright);
}

/* CTAs */
.intro-ctas {
    display: flex;
    align-items: center;
    gap: 2rem;
    flex-shrink: 0;
    flex-wrap: wrap;
}

.intro-btn-primary {
    display: inline-flex;
    align-items: center;
    gap: .8rem;
    background: var(--red);
    color: #fff !important;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 1.2rem 2.8rem;
    border-radius: 4px;
    text-decoration: none !important;
    transition: background 0.22s ease, transform 0.22s ease;
    white-space: nowrap;
    box-shadow: 0 18px 42px rgba(200,16,46,0.26);
}

.intro-btn-primary:hover {
    background: var(--red-bright) !important;
    transform: translateY(-2px);
    color: #fff !important;
}

.intro-btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    background: transparent;
    color: rgba(255,255,255,0.55) !important;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: 0 0 .4rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    text-decoration: none !important;
    transition: color 0.2s ease, border-color 0.2s ease;
    white-space: nowrap;
}

.intro-btn-secondary svg { transition: transform 0.2s ease; }

.intro-btn-secondary:hover {
    color: #fff !important;
    border-color: rgba(255,255,255,0.5);
}

.intro-btn-secondary:hover svg { transform: translateX(4px); }

.intro-trust {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 3.2rem;
}

.intro-trust span {
    display: inline-flex;
    align-items: center;
    min-height: 3.2rem;
    padding: .7rem 1.15rem;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.045);
    color: rgba(255,255,255,0.58);
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 650;
    letter-spacing: .1em;
    text-transform: uppercase;
    backdrop-filter: blur(12px);
}

/* ── Stats bar pegada al borde inferior ──────────── */
.intro-stats-bar {
    position: absolute !important;
    bottom: 0; left: 0; right: 0;
    z-index: 10;
    display: flex;
    border-top: 1px solid rgba(255,255,255,0.075);
    background: linear-gradient(90deg, rgba(5,6,8,0.84), rgba(18,20,25,0.56));
    backdrop-filter: blur(18px);
    opacity: calc(.35 + (var(--intro-fade, 1) * .65));
}

.intro-stat {
    flex: 1;
    padding: 2rem 0 2rem 10rem;
    border-right: 1px solid rgba(255,255,255,0.075);
    display: flex;
    flex-direction: column;
    gap: .3rem;
}

.intro-stat:last-child { border-right: none; }

.intro-stat__n {
    font-family: var(--font-display);
    font-size: 2.8rem;
    font-weight: 800;
    color: #fff;
    line-height: 1;
    letter-spacing: .02em;
}

.intro-stat__n em {
    color: var(--red);
    font-style: normal;
}

.intro-stat__l {
    font-family: var(--font-body);
    font-size: 1.15rem;
    font-weight: 300;
    color: rgba(255,255,255,0.44);
    letter-spacing: .06em;
    text-transform: uppercase;
}

/* ── Scroll hint vertical derecho ────────────────── */
.intro-scroll {
    position: absolute !important;
    right: 3.6rem !important;
    top: 50% !important;
    bottom: auto !important;
    left: auto !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1.4rem !important;
}

.intro-scroll a {
    writing-mode: vertical-rl !important;
    font-family: var(--font-display) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: .22em !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,0.2) !important;
    text-decoration: none !important;
    padding-right: 0 !important;
    transition: color 0.2s ease !important;
    display: block !important;
}

.intro-scroll a::before { content: none !important; }

.intro-scroll a::after {
    content: '' !important;
    display: block !important;
    width: 1px !important;
    height: 56px !important;
    background: linear-gradient(to bottom, rgba(200,16,46,0.7), transparent) !important;
    margin: 1.2rem auto 0 !important;
    position: static !important;
    top: auto !important; right: auto !important;
    animation: scrollPulse 2.2s ease-in-out infinite !important;
}

.intro-scroll a:hover { color: rgba(255,255,255,0.5) !important; }

@keyframes scrollPulse {
    0%, 100% { opacity: 1; transform: scaleY(1); }
    50%       { opacity: 0.3; transform: scaleY(0.55); }
}

/* ═══════════════════════════════════════════════════
   INTRO — Variantes de concepto

   Cambiar en index.html:
   intro--cinematic  = premium, cinematografico, empresarial
   intro--studio     = cabina/control room, mas tecnico audiovisual
   intro--minimal    = marca limpia, editorial y sobria
   intro--premium-studio = minimal premium + detalles de estudio
══════════════════════════════════════════════════ */

.intro--cinematic .intro-content {
    padding: 0 9rem 13.5rem 10rem !important;
}

.intro--cinematic .intro-text {
    max-width: 980px;
}

.intro--cinematic .intro-text h1 {
    max-width: 920px;
}

.intro--cinematic .intro-pic::before {
    background:
        linear-gradient(105deg, rgba(5,6,8,0.98) 0%, rgba(5,6,8,0.86) 42%, rgba(10,11,15,0.42) 100%) !important;
}

.intro--cinematic .intro-trust span {
    border-color: rgba(255,255,255,0.13);
}

.intro--studio .intro-content {
    padding: 0 8rem 13rem 8rem !important;
}

.intro--studio .intro-text {
    max-width: 760px;
    padding: 3.6rem 3.8rem 3.2rem;
    border-left: 2px solid rgba(200,16,46,0.78);
    background:
        linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.025)),
        rgba(8,10,14,0.54);
    box-shadow: 0 28px 90px rgba(0,0,0,0.36);
    backdrop-filter: blur(18px);
}

.intro--studio .intro-text h3 {
    color: rgba(255,255,255,0.6) !important;
    letter-spacing: .24em !important;
}

.intro--studio .intro-text h3::after {
    content: 'LIVE SESSION';
    margin-left: auto;
    padding: .45rem .8rem;
    border: 1px solid rgba(200,16,46,0.42);
    color: var(--red-bright);
    font-size: .9rem;
    letter-spacing: .16em;
}

.intro--studio .intro-text h1 {
    font-size: clamp(5.2rem, 7vw, 9.6rem) !important;
    margin-bottom: 3.2rem !important;
}

.intro--studio .intro-bottom {
    align-items: flex-start;
    flex-direction: column;
    gap: 2.6rem;
}

.intro--studio .intro-tagline {
    max-width: 560px;
}

.intro--studio .intro-trust {
    margin-top: 2.6rem;
}

.intro--studio .intro-trust span {
    background: rgba(200,16,46,0.1);
    border-color: rgba(200,16,46,0.28);
    color: rgba(255,255,255,0.7);
}

.intro--studio .intro-pic::before {
    background:
        linear-gradient(90deg, rgba(5,6,8,0.96) 0%, rgba(5,6,8,0.72) 52%, rgba(5,6,8,0.22) 100%),
        repeating-linear-gradient(90deg, rgba(255,255,255,0.06) 0 1px, transparent 1px 14rem) !important;
}

.intro--studio .intro-stats-bar {
    background: rgba(7,9,13,0.86);
}

.intro--minimal {
    justify-content: center !important;
}

.intro--minimal .intro-content {
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    padding: 7rem 3rem 11rem !important;
}

.intro--minimal .intro-text {
    max-width: 930px;
}

.intro--minimal .intro-text h3 {
    justify-content: center !important;
    margin-bottom: 2.4rem !important;
}

.intro--minimal .intro-text h1 {
    font-size: clamp(5.2rem, 8vw, 10.8rem) !important;
    margin-bottom: 3.6rem !important;
}

.intro--minimal .intro-bottom {
    align-items: center;
    flex-direction: column;
    gap: 2.8rem;
}

.intro--minimal .intro-tagline {
    max-width: 620px;
    margin: 0 auto;
}

.intro--minimal .intro-ctas {
    justify-content: center;
}

.intro--minimal .intro-trust {
    justify-content: center;
    margin-top: 3rem;
}

.intro--minimal .intro-pic {
    opacity: calc(.12 + (var(--intro-fade, 1) * .2));
}

.intro--minimal .intro-pic::before {
    background:
        linear-gradient(to bottom, rgba(5,6,8,0.92), rgba(5,6,8,0.72)),
        radial-gradient(circle at center, rgba(200,16,46,0.18), transparent 38%) !important;
}

.intro--minimal .intro-stats-bar {
    max-width: 1120px;
    left: 50%;
    right: auto;
    bottom: 2.2rem;
    width: calc(100% - 4rem);
    transform: translateX(-50%);
    border: 1px solid rgba(255,255,255,0.08);
}

.intro--minimal .intro-stat {
    padding-left: 3.2rem;
}

.intro--premium-studio {
    justify-content: center !important;
}

.intro--premium-studio .intro-content {
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    padding: 12rem 4rem 5rem !important;
}

.intro--premium-studio .intro-text {
    max-width: 980px;
}

.intro--premium-studio .intro-text h3 {
    justify-content: center !important;
    margin-bottom: 2.4rem !important;
    color: rgba(255,255,255,0.58) !important;
}

.intro--premium-studio .intro-text h3::after {
    content: 'STUDIO SESSION';
    display: inline-flex;
    align-items: center;
    min-height: 2.4rem;
    margin-left: .3rem;
    padding: .35rem .85rem;
    border: 1px solid rgba(200,16,46,0.45);
    background: rgba(200,16,46,0.12);
    color: var(--red-bright);
    font-size: .9rem;
    font-weight: 800;
    letter-spacing: .16em;
}

.intro--premium-studio .intro-text h1 {
    max-width: 930px;
    margin-left: auto !important;
    margin-right: auto !important;
    margin-bottom: 3.6rem !important;
    font-size: clamp(5.4rem, 8.2vw, 11rem) !important;
}

.intro--premium-studio .intro-text h1 .outline {
    -webkit-text-stroke: 1.25px rgba(255,255,255,0.66);
    text-shadow: 0 0 34px rgba(200,16,46,0.18);
}

.intro--premium-studio .intro-bottom {
    align-items: center;
    flex-direction: column;
    gap: 2.8rem;
}

.intro--premium-studio .intro-tagline {
    max-width: 650px;
    margin: 0 auto;
    color: rgba(255,255,255,0.58);
}

.intro--premium-studio .intro-ctas {
    justify-content: center;
}

.intro--premium-studio .intro-btn-primary {
    background: #fff;
    color: #08090d !important;
    box-shadow: 0 20px 55px rgba(255,255,255,0.16);
}

.intro--premium-studio .intro-btn-primary:hover {
    background: var(--red-bright) !important;
    color: #fff !important;
}

.intro--premium-studio .intro-trust {
    justify-content: center;
    margin-top: 3rem;
}

.intro--premium-studio .intro-trust span {
    position: relative;
    border-color: rgba(200,16,46,0.28);
    background: rgba(8,10,14,0.5);
    color: rgba(255,255,255,0.68);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}

.intro--premium-studio .intro-trust span::before {
    content: '';
    width: 6px;
    height: 6px;
    margin-right: .75rem;
    border-radius: 50%;
    background: var(--red-bright);
    box-shadow: 0 0 12px rgba(232,25,47,0.7);
}

.intro--premium-studio .intro-media {
    opacity: calc(var(--intro-fade, 1) * .88);
}

.intro--premium-studio .intro-video {
    filter: saturate(.72) contrast(1.12) brightness(.48);
}

.intro--premium-studio .intro-pic {
    opacity: calc(.12 + (var(--intro-fade, 1) * .22));
}

.intro--premium-studio .intro-pic::before {
    background:
        linear-gradient(to bottom, rgba(5,6,8,0.88), rgba(5,6,8,0.68)),
        radial-gradient(circle at 50% 42%, rgba(200,16,46,0.2), transparent 34%),
        linear-gradient(90deg, rgba(5,6,8,0.72), rgba(5,6,8,0.22), rgba(5,6,8,0.72)) !important;
}

.intro--premium-studio .intro-grid {
    opacity: calc(var(--intro-fade, 1) * .07) !important;
}

.intro--premium-studio .intro-stats-bar {
    max-width: 1120px;
    left: 50%;
    right: auto;
    bottom: 2.2rem;
    width: calc(100% - 4rem);
    transform: translateX(-50%);
    border: 1px solid rgba(255,255,255,0.09);
    background: rgba(7,9,13,0.68);
    box-shadow: 0 24px 70px rgba(0,0,0,0.28);
}

.intro--premium-studio .intro-stat {
    padding-left: 3rem;
}

/* ── Responsive ──────────────────────────────────── */
@media screen and (max-width: 1200px) {
    .intro-content  { padding: 0 6rem 12rem 7rem !important; }
    .intro-stat     { padding-left: 7rem; }
    .s-intro::before { left: 4.5rem; }

    .intro--studio .intro-content { padding: 0 5rem 13rem 5rem !important; }
    .intro--minimal .intro-stat { padding-left: 2.4rem; }
    .intro--premium-studio .intro-stat { padding-left: 2.4rem; }
}

@media screen and (max-width: 900px) {
    .s-intro::before { display: none; }
    .intro-scroll   { display: none !important; }
    .intro-content  { padding: 0 3rem 14rem 3rem !important; }
    .intro-stat     { padding-left: 3rem; }
    .intro-bottom   { flex-direction: column; align-items: flex-start; gap: 2.4rem; }
    .intro-media    { opacity: calc(var(--intro-fade, 1) * .72); }

    .intro-pic::before {
        background: linear-gradient(
            to bottom,
            rgba(5,6,8,0.96) 0%,
            rgba(5,6,8,0.78) 60%,
            rgba(5,6,8,0.64) 100%
        ) !important;
    }

    .intro--studio .intro-text {
        padding: 2.8rem 2.6rem;
    }

    .intro--studio .intro-text h3::after {
        display: none;
    }

    .intro--minimal .intro-content {
        text-align: left !important;
        align-items: flex-start !important;
        padding: 0 3rem 16rem 3rem !important;
    }

    .intro--minimal .intro-text h3,
    .intro--minimal .intro-trust,
    .intro--minimal .intro-ctas {
        justify-content: flex-start !important;
    }

    .intro--minimal .intro-bottom {
        align-items: flex-start;
    }

    .intro--minimal .intro-stats-bar {
        bottom: 0;
        width: 100%;
        border-left: none;
        border-right: none;
    }

    .intro--premium-studio .intro-content {
        text-align: left !important;
        align-items: flex-start !important;
        padding: 10rem 3rem 6rem 3rem !important;
    }

    .intro--premium-studio .intro-text h3,
    .intro--premium-studio .intro-trust,
    .intro--premium-studio .intro-ctas {
        justify-content: flex-start !important;
    }

    .intro--premium-studio .intro-text h3::after {
        display: none;
    }

    .intro--premium-studio .intro-text h1 {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .intro--premium-studio .intro-bottom {
        align-items: flex-start;
    }

    .intro--premium-studio .intro-stats-bar {
        bottom: 0;
        width: 100%;
        border-left: none;
        border-right: none;
    }
}

@media screen and (max-width: 600px) {
    .intro-content { padding: 0 2rem 16rem 2rem !important; }
    .intro-stat    { padding-left: 2rem; }

    .intro-text h1 {
        font-size: clamp(4.8rem, 13vw, 7.2rem) !important;
    }

    .intro-trust {
        gap: .7rem;
        margin-top: 2.4rem;
    }

    .intro-trust span {
        font-size: .9rem;
        min-height: 2.8rem;
        padding: .55rem .85rem;
    }

    .intro-stats-bar { flex-wrap: wrap; }
    .intro-stat {
        flex: 1 1 50%;
        border-bottom: 1px solid rgba(255,255,255,0.055);
    }

    .intro--studio .intro-content,
    .intro--minimal .intro-content,
    .intro--premium-studio .intro-content {
        padding: 9rem 2rem 6rem 2rem !important;
    }

    .intro--studio .intro-text {
        padding: 0;
        border-left: none;
        background: transparent;
        box-shadow: none;
        backdrop-filter: none;
    }

    .intro--minimal .intro-stats-bar {
        width: 100%;
    }

    .intro--minimal .intro-stat {
        padding-left: 2rem;
    }

    .intro--premium-studio .intro-stats-bar {
        width: 100%;
    }

    .intro--premium-studio .intro-stat {
        padding-left: 2rem;
    }
}

/* ═══════════════════════════════════════════════════
   TYPOGRAPHY BALANCE PASS
══════════════════════════════════════════════════ */
body#top {
    font-family: var(--font-body);
    text-rendering: optimizeLegibility;
}

.header-main-nav a,
.header-social a,
.eyebrow,
.pipeline-eyebrow,
.portfolio-kicker,
.intro-text h3,
.intro-text h3::after,
.intro-trust span,
.about-stat__label,
.footer-nav-label,
.footer-nav a,
.footer-copy,
.footer-credit,
.portfolio-layer p,
.play-btn,
.footer-cta-button,
.contact-button {
    letter-spacing: .08em !important;
}

.header-main-nav a,
.header-main-nav li a,
.footer-nav a {
    font-size: 1.35rem !important;
    line-height: 1.4 !important;
}

.intro-text h3 {
    font-size: 1.25rem !important;
    line-height: 1.35 !important;
    letter-spacing: .16em !important;
}

.intro-text h3::after {
    font-size: 1rem !important;
    line-height: 1 !important;
    letter-spacing: .08em !important;
}

.intro-text h1,
.intro--minimal .intro-text h1,
.intro--premium-studio .intro-text h1,
.intro--studio .intro-text h1 {
    font-size: clamp(5.8rem, 7.2vw, 9.6rem) !important;
    line-height: .96 !important;
}

.intro-text p,
.intro-copy,
.intro-subtitle {
    font-size: 1.65rem !important;
    line-height: 1.65 !important;
}

.intro-brand-mark {
    font-size: 1.7rem !important;
    letter-spacing: .1em !important;
}

.intro-trust span {
    font-size: 1.1rem !important;
    line-height: 1.2 !important;
}

.wrapper .section-heading,
.s-about .section-heading,
.about-experience .section-heading,
.portfolio-alt.section-heading,
.section-heading3 {
    font-size: clamp(3.8rem, 4.6vw, 5.6rem) !important;
    line-height: 1 !important;
    letter-spacing: .04em !important;
}

.s-about p.lead {
    font-size: clamp(2.3rem, 2.4vw, 3rem) !important;
    line-height: 1.35 !important;
    letter-spacing: 0 !important;
}

.s-about .about-me__text p:not(.lead),
.about-experience .timeline__desc p,
.card_wrapper p,
.pipeline-header p,
.pipeline-item p,
.portfolio-header-copy p,
.contact-intro p,
.contact-card p {
    font-size: 1.55rem !important;
    line-height: 1.7 !important;
}
.footer-tagline{
    font-size: 1.2rem !important;
    line-height: 1.7 !important;
}

.about-stat__number {
    font-size: 3.8rem !important;
    line-height: 1 !important;
}

.about-stat__label {
    font-size: 1.25rem !important;
    line-height: 1.4 !important;
}

.timeline__header .item-title {
    font-size: 2.45rem !important;
    line-height: 1.15 !important;
    letter-spacing: .02em !important;
}

.card_wrapper h3,
.card_wrapper h4,
.content-box_wrapper h3,
.content-box_wrapper h4 {
    font-size: 2.45rem !important;
    line-height: 1.1 !important;
    letter-spacing: .02em !important;
}

.pipeline-header h2 {
    font-size: clamp(4.2rem, 5.7vw, 6.4rem) !important;
    line-height: 1 !important;
}

.pipeline-item h3 {
    font-size: 2.15rem !important;
    line-height: 1.12 !important;
}

.pipeline-item span {
    font-size: 1rem !important;
    letter-spacing: .1em !important;
}

.portfolio-box--featured .portfolio-layer h4 {
    font-size: clamp(3.4rem, 4.2vw, 4.6rem) !important;
    line-height: 1.02 !important;
}

.portfolio-layer h4 {
    font-size: 2.2rem !important;
    line-height: 1.05 !important;
}

.portfolio-layer p,
.portfolio-box--featured .portfolio-layer p {
    font-size: 1.15rem !important;
    line-height: 1.35 !important;
}

.portfolio-layer a,
.play-btn,
.contact-button,
.footer-cta-button {
    font-size: 1.15rem !important;
    line-height: 1.2 !important;
}

.contact-intro h2 {
    font-size: clamp(4.2rem, 5.8vw, 6.8rem) !important;
    line-height: 1 !important;
}

.footer-cta h2 {
    font-size: clamp(3.2rem, 3.6vw, 4.2rem) !important;
    line-height: 1.05 !important;
}

@media screen and (max-width: 900px) {
    .intro-text h1,
    .intro--minimal .intro-text h1,
    .intro--premium-studio .intro-text h1,
    .intro--studio .intro-text h1 {
        font-size: clamp(5rem, 10vw, 7.4rem) !important;
    }

    .pipeline-header h2,
    .contact-intro h2 {
        font-size: clamp(3.8rem, 8vw, 5.6rem) !important;
    }
}

@media screen and (max-width: 600px) {
    .header-main-nav a,
    .header-main-nav li a,
    .footer-nav a {
        font-size: 1.55rem !important;
    }

    .intro-text h1,
    .intro--minimal .intro-text h1,
    .intro--premium-studio .intro-text h1,
    .intro--studio .intro-text h1 {
        font-size: clamp(4.4rem, 11.5vw, 6.2rem) !important;
        line-height: 1 !important;
    }

    .wrapper .section-heading,
    .s-about .section-heading,
    .about-experience .section-heading,
    .portfolio-alt.section-heading,
    .section-heading3 {
        font-size: clamp(3.3rem, 9vw, 4.4rem) !important;
    }

    .s-about .about-me__text p:not(.lead),
    .about-experience .timeline__desc p,
    .card_wrapper p,
    .pipeline-header p,
    .pipeline-item p,
    .portfolio-header-copy p,
    .contact-intro p,
    .contact-card p,
    .footer-tagline {
        font-size: 1.48rem !important;
    }
}
