:root {
    --orange: #ff5702;
    --orange-2: #ff8a3d;
    --purple: #2c1a54;
    --purple-2: #4a3782;
    --pink: #ec4899;
    --peach: #ffd0a8;
    --lavender: #d4a8ff;
    --cream: #fff4e8;
    --ink: #2c1a54;
    --ink-deep: #1a0f3d;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: 'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--ink);
    background: var(--cream);
    overflow-x: hidden;
}

.display-bricolage {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.03em;
}

/* ─── BACKGROUND BLOBS ─── */
.blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.55;
    pointer-events: none;
    z-index: 0;
}
.blob.b-orange   { background: var(--orange); }
.blob.b-pink     { background: var(--pink); }
.blob.b-purple   { background: var(--purple-2); }
.blob.b-peach    { background: var(--peach); }
.blob.b-lavender { background: var(--lavender); }

@keyframes blobFloat {
    0%, 100% { transform: translate(0,0) scale(1); }
    33%      { transform: translate(40px,-30px) scale(1.08); }
    66%      { transform: translate(-30px,40px) scale(0.95); }
}
.blob-anim    { animation: blobFloat 14s ease-in-out infinite; }
.blob-anim.b2 { animation-duration: 18s; animation-delay: -4s; }
.blob-anim.b3 { animation-duration: 22s; animation-delay: -8s; }

/* ─── PROMO BAR ─── */
.promo-bar {
    background: var(--ink);
    color: var(--cream);
    padding: 8px 0;
    font-size: 0.85rem;
    font-weight: 500;
    text-align: center;
}
.promo-bar .accent { color: var(--orange-2); font-weight: 700; }
.promo-bar .pulse-dot {
    display: inline-block; width: 8px; height: 8px; border-radius: 50%;
    background: var(--orange); margin-right: 8px;
    animation: pulseDot 1.5s infinite;
}
@keyframes pulseDot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.5; transform: scale(1.3); }
}

/* ─── NAVBAR ─── */
.nav-bakatt {
    background: rgba(255,244,232,0.85);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(44,26,84,0.06);
}
.nav-bakatt .navbar-brand-text {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800; font-size: 1.5rem; letter-spacing: 2px;
    color: var(--ink);
}
.nav-bakatt .nav-link { color: var(--ink); font-weight: 600; }
.nav-bakatt .nav-link:hover { color: var(--orange); }

/* ─── BUTTONS ─── */
.btn-pill {
    border-radius: 999px;
    padding: 0.85rem 1.8rem;
    font-weight: 700;
    border: none;
    transition: all 0.25s ease;
    display: inline-flex; align-items: center; gap: 0.5rem;
}
.btn-orange {
    background: var(--orange); color: #fff;
    box-shadow: 0 10px 24px rgba(255,87,2,0.35), inset 0 -3px 0 rgba(0,0,0,0.12);
}
.btn-orange:hover {
    background: #ff6b1f; color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(255,87,2,0.45), inset 0 -3px 0 rgba(0,0,0,0.12);
}
.btn-ink {
    background: var(--ink); color: var(--cream);
}
.btn-ink:hover { background: var(--ink-deep); color: #fff; transform: translateY(-2px); }
.btn-ghost {
    background: transparent; color: var(--ink);
    border: 2px solid var(--ink);
}
.btn-ghost:hover { background: var(--ink); color: var(--cream); }

/* ─── SECTIONS ─── */
section { position: relative; padding: 5.5rem 0; z-index: 1; }
@media (max-width: 768px) { section { padding: 4rem 0; } }

.section-eyebrow {
    display: inline-block;
    background: var(--ink); color: var(--orange-2);
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.section-eyebrow.peach { background: var(--peach); color: var(--ink); }

/* ─── HERO ─── */
.hero { padding: 4rem 0 7rem; }
.hero h1 { font-size: clamp(3rem, 8vw, 6rem); }
.hero h1 .stroke {
    -webkit-text-stroke: 2px var(--ink);
    color: transparent;
}
.hero-sticker {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--peach);
    border: 2px solid var(--ink);
    padding: 0.4rem 1rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.9rem;
    transform: rotate(-3deg);
    box-shadow: 4px 4px 0 var(--ink);
    color: var(--ink);
}
.hero-meta { color: var(--ink); opacity: 0.7; font-size: 1.1rem; max-width: 520px; line-height: 1.55; }
.hero-trio { display: flex; align-items: center; }
.hero-trio .tile {
    width: 56px; height: 56px; border-radius: 50%;
    border: 3px solid var(--cream);
    margin-left: -16px;
    background-size: cover; background-position: center;
    box-shadow: 0 4px 12px rgba(44,26,84,0.18);
}
.hero-trio .tile:first-child { margin-left: 0; }
.hero-trio .t1 { background: linear-gradient(135deg, var(--orange), var(--pink)); }
.hero-trio .t2 { background: linear-gradient(135deg, var(--purple), var(--purple-2)); }
.hero-trio .t3 { background: linear-gradient(135deg, var(--peach), var(--orange)); }
.hero-trio .t4 { background: linear-gradient(135deg, var(--pink), var(--lavender)); }
.hero-trio .more {
    background: var(--ink); color: var(--peach);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 0.85rem;
}

/* ─── PHONE MOCK ─── */
.phone {
    background: linear-gradient(180deg, #1a1a1a 0%, var(--ink) 100%);
    border-radius: 44px;
    padding: 12px;
    box-shadow:
            0 30px 60px rgba(44,26,84,0.4),
            0 8px 16px rgba(0,0,0,0.18),
            0 0 0 8px rgba(255,138,61,0.18);
    position: relative;
    transform: rotate(-4deg);
    transition: transform 0.4s ease;
}
.phone:hover { transform: rotate(-2deg) scale(1.02); }
.phone::before {
    content: '';
    position: absolute;
    top: 22px; left: 50%;
    transform: translateX(-50%);
    width: 110px; height: 28px;
    background: #000;
    border-radius: 999px;
    z-index: 2;
}
.phone-screen {
    background: linear-gradient(135deg, var(--peach) 0%, #ffb6c1 50%, var(--lavender) 100%);
    border-radius: 32px;
    overflow: hidden;
    min-height: 560px;
    display: flex; flex-direction: column;
    padding: 60px 16px 16px;
    position: relative;
}
.ps-stories { display: flex; gap: 10px; margin-bottom: 16px; }
.ps-story {
    width: 56px; height: 56px; border-radius: 50%;
    background: rgba(255,255,255,0.5);
    border: 2.5px solid var(--orange);
    display: flex; align-items: center; justify-content: center;
    color: var(--ink); font-weight: 700;
}
.ps-story.muted { border-color: #d1d5db; }
.ps-welcome { font-weight: 800; font-size: 22px; color: var(--purple); margin-bottom: 14px; }
.ps-card {
    background: #fff; border-radius: 18px; padding: 12px;
    box-shadow: 0 6px 16px rgba(0,0,0,0.06);
    margin-bottom: 12px;
}
.ps-card .pc-h { font-weight: 700; font-size: 13px; color: var(--purple); }
.ps-thumbs { display: flex; gap: 6px; margin-top: 8px; }
.ps-thumbs > div { flex: 1; aspect-ratio: 9/14; border-radius: 10px; }
.ps-thumbs > div:nth-child(1) { background: linear-gradient(160deg, var(--orange), var(--pink)); }
.ps-thumbs > div:nth-child(2) { background: linear-gradient(160deg, var(--purple-2), var(--lavender)); }
.ps-thumbs > div:nth-child(3) { background: linear-gradient(160deg, var(--peach), var(--orange)); }

/* ─── MARQUEE ─── */
.marquee {
    background: var(--ink);
    color: var(--cream);
    padding: 1.2rem 0;
    overflow: hidden;
    white-space: nowrap;
}
.marquee-track {
    display: inline-flex;
    gap: 3rem;
    animation: marquee 28s linear infinite;
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    font-size: 1.6rem;
    letter-spacing: 0.02em;
}
.marquee-track i { color: var(--orange-2); margin-right: 8px; }
@keyframes marquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

/* ─── BENTO GRID ─── */
.bento {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: 180px;
    gap: 18px;
}
@media (max-width: 768px) {
    .bento { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
}
.bento-cell {
    background: #fff;
    border-radius: 24px;
    padding: 1.5rem;
    border: 1.5px solid rgba(44,26,84,0.08);
    position: relative;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: all 0.25s ease;
}
.bento-cell:hover {
    transform: translateY(-3px);
    border-color: var(--orange);
    box-shadow: 0 12px 28px rgba(44,26,84,0.08);
}
.bento-cell .bc-icon {
    width: 48px; height: 48px; border-radius: 14px;
    background: var(--cream); color: var(--orange);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    margin-bottom: auto;
}
.bento-cell h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    font-size: 1.4rem;
    margin: 0.5rem 0 0.4rem;
    color: var(--ink);
}
.bento-cell p { color: rgba(44,26,84,0.7); margin: 0; font-size: 0.95rem; line-height: 1.5; }

/* Variantes */
.bento-cell.dark   { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.bento-cell.dark p { color: rgba(255,244,232,0.85); }
.bento-cell.dark h3{ color: var(--cream); }
.bento-cell.dark .bc-icon { background: rgba(255,138,61,0.18); color: var(--orange-2); }

.bento-cell.peach { background: var(--peach); border-color: var(--peach); }
.bento-cell.peach .bc-icon { background: var(--ink); color: var(--peach); }
.bento-cell.peach h3 { color: var(--ink); }
.bento-cell.peach p { color: rgba(44,26,84,0.75); }

.bento-cell.orange { background: var(--orange); color: #fff; border-color: var(--orange); }
.bento-cell.orange p { color: rgba(255,255,255,0.92); }
.bento-cell.orange h3 { color: #fff; }
.bento-cell.orange .bc-icon { background: rgba(255,255,255,0.18); color: #fff; }

.bento-cell.pink { background: linear-gradient(135deg, var(--pink), var(--orange)); color: #fff; border-color: var(--pink); }
.bento-cell.pink p { color: rgba(255,255,255,0.92); }
.bento-cell.pink h3 { color: #fff; }
.bento-cell.pink .bc-icon { background: rgba(255,255,255,0.18); color: #fff; }

.span-2 { grid-column: span 2; }
.span-3 { grid-column: span 3; }
.span-4 { grid-column: span 4; }
.row-2  { grid-row: span 2; }
@media (max-width: 768px) {
    .span-2, .span-3, .span-4 { grid-column: span 2; }
    .row-2 { grid-row: span 1; }
}

.bento-quote {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    font-size: 1.6rem;
    line-height: 1.15;
}

/* ─── TALENTS PILLS ─── */
.talent-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: #fff;
    color: var(--ink);
    font-weight: 700;
    padding: 0.6rem 1.1rem;
    border-radius: 999px;
    font-size: 0.95rem;
    border: 1.5px solid rgba(44,26,84,0.1);
    margin: 0.3rem;
    transition: all 0.2s ease;
    cursor: default;
}
.talent-pill:hover {
    background: var(--orange); color: #fff;
    transform: translateY(-2px) rotate(-1deg);
    border-color: var(--orange);
}
.talent-pill.featured { background: var(--orange); color: #fff; border-color: var(--orange); }
.talent-pill.featured:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }

/* ─── STATS ─── */
.stat-card { text-align: center; padding: 1.5rem; }
.stat-num {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-size: clamp(3rem, 6vw, 5rem);
    font-weight: 800;
    color: var(--orange);
    line-height: 1;
}
.stat-label { font-weight: 600; color: var(--ink); margin-top: 0.5rem; }

/* ─── SCREENS ─── */
.screens-section { background: var(--ink); color: var(--cream); }
.screens-section .section-eyebrow { background: var(--peach); color: var(--ink); }
.screens-section h2.display-bricolage { color: var(--cream); }
.screen-mockup {
    border-radius: 28px;
    background: #1a1a1a;
    padding: 8px;
    box-shadow: 0 18px 40px rgba(0,0,0,0.5);
    transition: transform 0.3s ease;
}
.screen-mockup:hover { transform: translateY(-6px); }
.screen-content {
    border-radius: 22px; min-height: 360px;
    display: flex; align-items: flex-end; justify-content: center;
    color: #fff; padding: 1.5rem;
    position: relative; overflow: hidden;
}
.screen-1 { background: linear-gradient(160deg, var(--peach), var(--lavender)); color: var(--purple); }
.screen-2 { background: linear-gradient(160deg, var(--purple), var(--orange)); }
.screen-3 { background: linear-gradient(160deg, var(--purple-2), var(--pink)); }

/* ─── TESTIMONIALS MARQUEE ─── */
.testi-marquee { background: var(--cream); padding: 3.5rem 0; overflow: hidden; }
.testi-track {
    display: inline-flex;
    gap: 1.2rem;
    animation: marquee 50s linear infinite;
}
.testi-card {
    background: #fff;
    padding: 1.5rem;
    border-radius: 20px;
    min-width: 320px;
    border: 1.5px solid rgba(44,26,84,0.08);
    box-shadow: 0 6px 18px rgba(44,26,84,0.06);
}
.testi-card .quote {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    font-size: 1.15rem;
    line-height: 1.3;
    margin-bottom: 1rem;
    color: var(--ink);
}
.testi-card .who { display: flex; align-items: center; gap: 12px; }
.testi-card .av {
    width: 40px; height: 40px; border-radius: 50%;
    background: linear-gradient(135deg, var(--orange), var(--pink));
}
.testi-card .av.av2 { background: linear-gradient(135deg, var(--purple), var(--peach)); }
.testi-card .av.av3 { background: linear-gradient(135deg, var(--peach), var(--orange)); }
.testi-card .av.av4 { background: linear-gradient(135deg, var(--pink), var(--purple-2)); }
.testi-card .av.av5 { background: linear-gradient(135deg, var(--orange), var(--purple)); }
.testi-card .meta { font-size: 0.85rem; }
.testi-card .meta strong { display: block; color: var(--ink); }
.testi-card .meta span { color: rgba(44,26,84,0.6); }

/* ─── BIG CTA + FORM ─── */
.cta-section { background: var(--ink); color: var(--cream); position: relative; overflow: hidden; }
.cta-section h2 { color: var(--cream); }
.cta-section .section-eyebrow { background: var(--peach); color: var(--ink); }

.signup-card {
    background: var(--cream);
    color: var(--ink);
    border-radius: 28px;
    padding: 2.5rem;
    position: relative;
}
@media (max-width: 768px) { .signup-card { padding: 1.8rem; } }
.signup-card h3 {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800;
    font-size: 1.8rem;
}
.form-label { font-weight: 700; color: var(--ink); font-size: 0.9rem; }
.form-control, .form-select {
    border: 2px solid rgba(44,26,84,0.15);
    border-radius: 14px;
    padding: 0.75rem 1rem;
    font-size: 1rem;
    font-weight: 500;
    background: #fff;
    color: var(--ink);
}
.form-control:focus, .form-select:focus {
    border-color: var(--orange);
    box-shadow: 0 0 0 4px rgba(255,87,2,0.18);
}
.form-success {
    display: none;
    background: linear-gradient(135deg, var(--orange) 0%, var(--pink) 100%);
    color: #fff;
    border-radius: 18px;
    padding: 2rem;
    text-align: center;
}
.form-success.is-visible { display: block; }
.form-success i { font-size: 3rem; }
.form-error {
    display: none;
    background: #fee2e2;
    color: #991b1b;
    border-radius: 12px;
    padding: 1rem;
    margin-top: 1rem;
    font-weight: 600;
    font-size: 0.9rem;
}
.form-error.is-visible { display: block; }

.perk-list { list-style: none; padding: 0; margin: 0; }
.perk-list li {
    display: flex; align-items: flex-start; gap: 0.75rem;
    margin-bottom: 0.85rem;
    color: var(--cream);
    font-weight: 500;
    font-size: 1.02rem;
}
.perk-list li i { color: var(--orange-2); font-size: 1.3rem; margin-top: 1px; flex-shrink: 0; }
.perk-list li strong { color: #fff; }

/* ─── FOOTER ─── */
footer {
    background: var(--cream);
    color: var(--ink);
    padding: 2.5rem 0 1.8rem;
    border-top: 2px solid rgba(44,26,84,0.08);
}
.footer-brand {
    font-family: 'Bricolage Grotesque', sans-serif;
    font-weight: 800; font-size: 1.6rem; letter-spacing: 2px;
    color: var(--ink);
}
footer a { color: var(--ink); text-decoration: none; }
footer a:hover { color: var(--orange); }

/* ─── REVEAL ─── */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }

.anchor-offset { scroll-margin-top: 120px; }