/* =========================================================
   CherryMocha Invest — Premium dark fintech landing
   Palette: cherry #C2342E · mocha #7B5B47 · bronze/gold #E8B872 · blush #F1D6D0
   Korea convention: 상승=빨강(red) · 하락=파랑(blue)
   ========================================================= */

:root{
    --espresso:#19100e;
    --espresso-2:#241512;
    --espresso-3:#2e1a16;
    --cherry:#C2342E;
    --cherry-deep:#8f201d;
    --cherry-bright:#e0463d;
    --mocha:#7B5B47;
    --bronze:#C79A6B;
    --gold:#E8B872;
    --blush:#F1D6D0;
    --cream:#F7EBE5;
    --ivory:#FCF6F3;
    --ink:#241210;
    --ink-soft:#6e5249;
    --line-dark:rgba(231,184,114,.16);
    --line-light:rgba(123,91,71,.16);
    --up:#FF6B5C;
    --down:#6FA0FF;

    --serif:"Noto Serif KR", serif;
    --sans:"Noto Sans KR", sans-serif;
    --mono:"Space Grotesk", "Noto Sans KR", monospace;

    --maxw:1200px;
    --radius:20px;
    --shadow:0 40px 80px -36px rgba(0,0,0,.6);
    --dock-h:96px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
    font-family:var(--sans);
    color:var(--ink);
    background:var(--espresso);
    line-height:1.62;
    overflow-x:hidden;
    width:100%;
    max-width:100%;
    padding-bottom:var(--dock-h);
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
strong,b{font-weight:700}
::selection{background:var(--cherry);color:#fff}

/* fine film grain over everything */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");}

/* ---------- shared accents ---------- */
.grad{background:linear-gradient(100deg,var(--gold),var(--cherry-bright) 55%,var(--gold));
    -webkit-background-clip:text;background-clip:text;color:transparent;
    background-size:200% auto;animation:shine 6s linear infinite;}
.grad-ink{background:linear-gradient(100deg,var(--cherry),var(--mocha));
    -webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic;}
@keyframes shine{to{background-position:200% center}}

.dot{width:8px;height:8px;border-radius:50%;background:var(--up);display:inline-block;flex:none;
    box-shadow:0 0 0 0 rgba(255,107,92,.6);animation:dotPulse 1.7s infinite;}
@keyframes dotPulse{70%{box-shadow:0 0 0 7px rgba(255,107,92,0)}100%{box-shadow:0 0 0 0 rgba(255,107,92,0)}}

.is-up{color:var(--up)!important}
.is-down{color:var(--down)!important}

.kicker{display:inline-flex;align-items:center;gap:.55em;
    font-family:var(--mono);font-size:.76rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
    color:var(--cherry);padding:.5em 1em;border:1px solid var(--line-light);border-radius:100px;
    background:rgba(255,255,255,.5);}
.kicker--light{color:var(--gold);border-color:var(--line-dark);background:rgba(231,184,114,.06)}

.section-title{font-family:var(--serif);font-weight:700;line-height:1.22;letter-spacing:-.015em;
    font-size:clamp(1.8rem,4vw,3rem);margin:.55em 0;color:var(--ink);word-break:keep-all}
.section-title--light{color:var(--cream)}
.section-sub{color:var(--ink-soft);font-size:1.03rem;max-width:48ch}
.section-head{text-align:center;max-width:780px;margin:0 auto 3.4rem}
.section-head .section-sub{margin:0 auto}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
    font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1.2;
    padding:.95em 1.6em;border:none;border-radius:100px;cursor:pointer;
    transition:transform .28s cubic-bezier(.2,.8,.2,1),box-shadow .28s,background .28s;text-align:center;}
.btn-icon{width:1.6em;height:1.6em;object-fit:contain;border-radius:7px;flex:none}
.btn i{font-size:.95em}

.btn--primary{color:#fff;
    background:linear-gradient(135deg,var(--cherry-bright),var(--cherry) 52%,var(--cherry-deep));
    box-shadow:0 16px 30px -14px rgba(194,52,46,.8),inset 0 1px 0 rgba(255,255,255,.22);}
.btn--primary::after{content:"";position:absolute;inset:0;border-radius:inherit;
    background:linear-gradient(135deg,rgba(255,255,255,.4),transparent 45%);opacity:0;transition:opacity .28s}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 24px 40px -16px rgba(194,52,46,.9)}
.btn--primary:hover::after{opacity:1}
.btn--primary:active{transform:translateY(-1px)}

.btn--glow{position:relative}
.btn--glow::before{content:"";position:absolute;inset:-2px;border-radius:inherit;z-index:-1;
    background:linear-gradient(135deg,var(--gold),var(--cherry-bright),var(--gold));
    background-size:200% auto;filter:blur(11px);opacity:.55;animation:shine 5s linear infinite;}

.btn--ghost{color:#fff;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.22);font-weight:600;
    backdrop-filter:blur(6px);}
.btn--ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}

.btn--xl{font-size:1.18rem;padding:1.15em 2.3em}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}

/* =========================================================
   TICKER
   ========================================================= */
.ticker{position:sticky;top:0;z-index:40;display:flex;align-items:stretch;height:44px;overflow:hidden;
    background:#120a09;border-bottom:1px solid var(--line-dark);}
.ticker__label{flex:none;display:flex;align-items:center;gap:.5em;white-space:nowrap;
    font-family:var(--mono);font-weight:700;font-size:.72rem;letter-spacing:.16em;color:#fff;
    padding:0 1.1em;background:linear-gradient(135deg,var(--cherry),var(--cherry-deep));}
.ticker__viewport{flex:1;overflow:hidden;position:relative;display:flex;align-items:center;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);}
.ticker__track{display:flex;gap:2.4rem;white-space:nowrap;padding-left:2rem;will-change:transform;
    animation:marquee 48s linear infinite;}
.ticker:hover .ticker__track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.tick{display:inline-flex;align-items:center;gap:.55em;font-size:.82rem;font-family:var(--mono)}
.tick__name{font-family:var(--sans);font-weight:500;color:var(--blush)}
.tick__px{color:#e9ddd7}
.tick__chg{font-weight:700}
.tick__chg.up{color:var(--up)}
.tick__chg.down{color:var(--down)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;overflow:clip;color:#fff;
    background:radial-gradient(120% 90% at 80% 0%,#33191400,#160c0a),var(--espresso);
    padding:clamp(3rem,7vw,6rem) 0 4.5rem;}
.hero__aurora{position:absolute;inset:0;z-index:0;pointer-events:none;filter:blur(60px);opacity:.85;
    background:
      radial-gradient(38% 40% at 22% 28%, rgba(194,52,46,.55), transparent 60%),
      radial-gradient(34% 38% at 78% 22%, rgba(231,184,114,.32), transparent 60%),
      radial-gradient(46% 50% at 65% 78%, rgba(123,91,71,.45), transparent 60%),
      radial-gradient(40% 44% at 30% 80%, rgba(143,32,29,.4), transparent 60%);
    animation:aurora 18s ease-in-out infinite alternate;}
@keyframes aurora{
    0%{transform:translate3d(0,0,0) scale(1)}
    50%{transform:translate3d(2%,-2%,0) scale(1.08)}
    100%{transform:translate3d(-2%,1%,0) scale(1.04)}
}
.hero__grid-lines{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
    background-image:
      linear-gradient(rgba(231,184,114,.06) 1px,transparent 1px),
      linear-gradient(90deg,rgba(231,184,114,.06) 1px,transparent 1px);
    background-size:54px 54px;
    -webkit-mask-image:radial-gradient(80% 80% at 50% 40%,#000,transparent 75%);
    mask-image:radial-gradient(80% 80% at 50% 40%,#000,transparent 75%);}

.hero__inner{position:relative;z-index:2;width:min(92%,var(--maxw));margin:0 auto;
    display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center;}

.eyebrow{display:inline-flex;align-items:center;gap:.6em;font-size:.82rem;font-weight:500;color:var(--blush);
    padding:.5em 1em;border:1px solid var(--line-dark);border-radius:100px;
    background:rgba(231,184,114,.06);backdrop-filter:blur(6px);margin-bottom:1.5rem;}

.hero__title{font-family:var(--serif);font-weight:900;letter-spacing:-.025em;
    font-size:clamp(2.7rem,6vw,4.9rem);line-height:1.04;margin-bottom:1.4rem;
    text-shadow:0 10px 40px rgba(0,0,0,.5);}
.hero__lead{font-size:clamp(1rem,1.5vw,1.16rem);color:rgba(255,255,255,.82);max-width:44ch;margin-bottom:2rem}
.hero__lead strong{color:#fff;background:linear-gradient(transparent 60%,rgba(194,52,46,.55) 0);padding:0 .1em}

.hero__cta-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2.2rem}

.hero__trust{display:flex;align-items:center;gap:.8em;font-size:.92rem;color:rgba(255,255,255,.78)}
.hero__trust b{font-family:var(--mono);color:var(--gold)}
.avatars{display:flex}
.avatars span{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
    font-family:var(--serif);font-weight:700;font-size:.78rem;color:#fff;margin-left:-9px;
    border:2px solid var(--espresso);background:linear-gradient(135deg,var(--mocha),var(--cherry-deep));}
.avatars span:first-child{margin-left:0;background:linear-gradient(135deg,var(--gold),var(--bronze));color:var(--ink)}

/* hero stage: bull + cards */
.hero__stage{position:relative;min-height:440px;display:flex;align-items:center;justify-content:center}
.hero__glow{position:absolute;width:78%;aspect-ratio:1;border-radius:50%;z-index:0;
    background:radial-gradient(circle,rgba(224,70,61,.55),rgba(231,184,114,.18) 45%,transparent 70%);
    filter:blur(20px);animation:glowPulse 4.5s ease-in-out infinite;}
@keyframes glowPulse{50%{transform:scale(1.12);opacity:.85}}
.hero__bull{position:relative;z-index:1;width:108%;max-width:none;
    filter:drop-shadow(0 30px 50px rgba(0,0,0,.6));animation:floaty 6s ease-in-out infinite;}
@keyframes floaty{50%{transform:translateY(-14px)}}

.quote-card{position:absolute;left:-4%;bottom:2%;z-index:3;width:min(270px,72%);
    background:rgba(28,16,14,.66);backdrop-filter:blur(16px);
    border:1px solid var(--line-dark);border-radius:18px;padding:1.1rem 1.2rem;
    box-shadow:var(--shadow);animation:floaty 6s ease-in-out infinite .6s;}
.quote-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.quote-card__name{display:inline-flex;align-items:center;gap:.45em;font-weight:700;font-size:.86rem;color:var(--blush)}
.quote-card__tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:rgba(255,255,255,.6);
    border:1px solid var(--line-dark);border-radius:100px;padding:.15em .6em}
.quote-card__value{font-family:var(--mono);font-weight:700;font-size:2rem;line-height:1;color:#fff;letter-spacing:-.01em}
.quote-card__delta{font-family:var(--mono);font-weight:700;font-size:.92rem;margin-top:.35rem}
.quote-card__delta.is-up{color:var(--up)!important}
.quote-card__spark{width:100%;height:54px;margin-top:.5rem;display:block}

.float-chip{position:absolute;z-index:3;display:flex;flex-direction:column;gap:.1em;
    background:rgba(28,16,14,.7);backdrop-filter:blur(12px);border:1px solid var(--line-dark);
    border-radius:14px;padding:.6rem .85rem;box-shadow:0 18px 36px -18px rgba(0,0,0,.7);}
.float-chip span{font-size:.68rem;color:rgba(255,255,255,.62)}
.float-chip b{font-family:var(--mono);font-size:1rem}
.float-chip--a{top:4%;right:-2%;animation:floaty 5.5s ease-in-out infinite .2s}
.float-chip--b{top:40%;right:-6%;animation:floaty 6.5s ease-in-out infinite 1s}

.hero__scrollhint{position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);z-index:2;
    display:flex;flex-direction:column;align-items:center;gap:.3em;
    font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;color:rgba(255,255,255,.55)}
.hero__scrollhint i{animation:bob 1.8s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(6px)}}

/* =========================================================
   PULSE BAND (animated candlestick + stats)
   ========================================================= */
.pulse{position:relative;overflow:hidden;background:var(--espresso-2);
    border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);padding:3.2rem 0}
.pulse__chart{position:absolute;inset:0;z-index:0;opacity:.9}
.pulse__chart svg{width:100%;height:100%}
.pulse__overlay{position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,rgba(36,21,18,.4),rgba(36,21,18,.86))}
.pulse__stats{position:relative;z-index:2;width:min(92%,var(--maxw));margin:0 auto;
    display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.pstat{text-align:center;padding:.5rem;border-right:1px solid var(--line-dark)}
.pstat:last-child{border-right:none}
.pstat__num{font-family:var(--mono);font-weight:700;font-size:clamp(2rem,3.6vw,2.9rem);line-height:1;
    color:var(--gold)}
.pstat:nth-child(1) .pstat__num,.pstat:nth-child(3) .pstat__num{color:var(--up)}
.pstat__label{font-size:.84rem;color:rgba(255,255,255,.72);margin-top:.5rem}

/* candle animation */
.candle{transform:scaleY(0);transform-box:fill-box;transform-origin:bottom;
    animation:growCandle .7s cubic-bezier(.2,.8,.2,1) forwards}

@keyframes growCandle{to{transform:scaleY(1)}}

/* =========================================================
   WHY / FEATURES (light)
   ========================================================= */
.why{position:relative;z-index:2;background:var(--ivory);
    border-radius:34px 34px 0 0;margin-top:-1px;
    width:100%;padding:5.5rem max(4vw,calc((100% - var(--maxw))/2))}
.why__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.3rem}
.feature{position:relative;grid-column:span 2;background:#fff;border:1px solid var(--line-light);border-radius:var(--radius);
    padding:2.1rem 1.9rem;overflow:hidden;
    box-shadow:0 18px 40px -28px rgba(123,57,40,.5);
    transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s}
.feature--lg{grid-column:span 3}
.feature::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;
    background:linear-gradient(90deg,var(--cherry),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .4s}
.feature:hover{transform:translateY(-7px);box-shadow:0 34px 60px -30px rgba(123,57,40,.6);border-color:rgba(194,52,46,.3)}
.feature:hover::before{transform:scaleX(1)}
.feature__icon{width:56px;height:56px;border-radius:15px;display:grid;place-items:center;font-size:1.35rem;color:#fff;
    margin-bottom:1.1rem;background:linear-gradient(135deg,var(--cherry-bright),var(--cherry-deep));
    box-shadow:0 12px 24px -10px rgba(194,52,46,.7)}
.feature--lg .feature__icon{background:linear-gradient(135deg,var(--gold),var(--bronze));color:var(--ink);
    box-shadow:0 12px 24px -10px rgba(199,154,107,.7)}
.feature__body h3{font-family:var(--serif);font-weight:700;font-size:1.24rem;margin-bottom:.5rem;color:var(--ink)}
.feature__body p{color:var(--ink-soft);font-size:.95rem}
.feature__body strong{color:var(--cherry)}
.feature__no{position:absolute;top:1.1rem;right:1.5rem;font-family:var(--mono);font-weight:700;font-size:2.5rem;
    line-height:1;color:transparent;-webkit-text-stroke:1.4px var(--blush);opacity:.9}

/* =========================================================
   SPLIT MODULES (light)
   ========================================================= */
.split{background:var(--ivory);width:100%;
    padding:4.5rem max(4vw,calc((100% - var(--maxw))/2));
    display:grid;grid-template-columns:1fr 1fr;gap:3.4rem;align-items:center}
.split--img-right{background:var(--cream)}
.split__media{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;
    box-shadow:0 40px 70px -34px rgba(60,20,12,.55);border:1px solid var(--line-light)}
.split__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s ease}
.split__media:hover img{transform:scale(1.06)}
.split__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(25,16,14,.4))}
.split--img-right .split__media{order:2}
.split__tag{position:absolute;top:1.1rem;left:1.1rem;z-index:2;display:inline-flex;align-items:center;gap:.5em;
    background:rgba(25,16,14,.72);backdrop-filter:blur(8px);color:#fff;padding:.5em .95em;border-radius:100px;
    font-family:var(--mono);font-size:.74rem;font-weight:600;border:1px solid var(--line-dark)}
.split__tag--up{background:rgba(194,52,46,.85)}
.split__text .section-title{margin-top:.55rem}
.split__text>p{color:var(--ink-soft);margin:.4rem 0 1.4rem;font-size:1.02rem}

.ticklist{list-style:none;margin:0 0 1.8rem;display:flex;flex-direction:column;gap:.75rem}
.ticklist li{display:flex;align-items:flex-start;gap:.7em;font-size:.97rem;color:var(--ink)}
.ticklist i{color:var(--cherry);margin-top:.18em;font-size:1.05em}

/* =========================================================
   REPORTS (dark)
   ========================================================= */
.reports{background:radial-gradient(120% 90% at 15% 10%,#3a201a,#19100e);position:relative;overflow:hidden}
.reports::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;
    background:radial-gradient(40% 50% at 85% 30%,rgba(231,184,114,.18),transparent 60%)}
.reports__inner{position:relative;z-index:1;width:min(92%,var(--maxw));margin:0 auto;
    padding:5.2rem 0;display:grid;grid-template-columns:1fr 1fr;gap:3.4rem;align-items:center}
.reports__media{position:relative;border-radius:var(--radius);overflow:hidden;
    box-shadow:var(--shadow);border:1px solid var(--line-dark)}
.reports__media img{width:100%;height:100%;object-fit:cover}
.reports__badge{position:absolute;bottom:1.2rem;right:1.2rem;z-index:2;width:120px;height:120px;border-radius:50%;
    display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;
    background:radial-gradient(circle at 35% 30%,var(--cherry-bright),var(--cherry-deep));
    border:3px solid rgba(255,255,255,.85);box-shadow:0 18px 34px -12px rgba(0,0,0,.7);transform:rotate(-8deg)}
.reports__badge-num{font-family:var(--mono);font-weight:700;font-size:2.3rem;line-height:1}
.reports__badge-num small{font-size:1.1rem;vertical-align:super}
.reports__badge-txt{font-size:.64rem;letter-spacing:.04em;margin-top:.2em;line-height:1.2}
.giftlist{display:flex;flex-direction:column;gap:.8rem;margin:1.5rem 0 1.9rem}
.gift{display:flex;align-items:center;gap:.9em;color:var(--cream);
    background:rgba(255,255,255,.04);border:1px solid var(--line-dark);border-radius:14px;padding:.85em 1.1em;
    transition:transform .28s,border-color .28s,background .28s}
.gift:hover{transform:translateX(6px);border-color:rgba(231,184,114,.45);background:rgba(255,255,255,.07)}
.gift i{flex:none;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;
    color:var(--ink);background:linear-gradient(135deg,var(--gold),var(--bronze));font-size:1rem}
.gift span{font-size:.96rem}
.gift b{color:var(--gold)}

/* =========================================================
   FINAL CTA (dark + skyline)
   ========================================================= */
.final{position:relative;overflow:hidden;color:#fff;text-align:center;padding:6.5rem 0}
.final__bg{position:absolute;inset:0;z-index:0}
.final__bg img{width:100%;height:100%;object-fit:cover}
.final::before{content:"";position:absolute;inset:0;z-index:1;
    background:linear-gradient(180deg,rgba(25,16,14,.86),rgba(143,32,29,.82))}
.final__inner{position:relative;z-index:2;width:min(92%,800px);margin:0 auto;
    display:flex;flex-direction:column;align-items:center;gap:1.2rem}
.final__title{font-family:var(--serif);font-weight:900;line-height:1.18;letter-spacing:-.02em;
    font-size:clamp(2rem,4.8vw,3.5rem);text-shadow:0 6px 30px rgba(0,0,0,.5)}
.final__sub{color:rgba(255,255,255,.86);max-width:52ch;font-size:1.05rem}
.final__inner .btn{margin-top:.9rem}
.final__fine{font-size:.85rem;color:rgba(255,255,255,.74);display:inline-flex;align-items:center;gap:.5em}
.final__fine i{color:var(--gold)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:#120a09;color:rgba(255,255,255,.74);padding:3rem 1rem 2.5rem;text-align:center;
    display:flex;flex-direction:column;align-items:center;gap:1.2rem;border-top:1px solid var(--line-dark)}
.footer__logo{font-family:var(--serif);font-weight:700;font-size:1.45rem;color:#fff;letter-spacing:.02em}
.footer__brand p{font-size:.88rem;color:rgba(255,255,255,.55);margin-top:.4rem}
.footer__links{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem}
.footer__link{background:none;border:none;color:rgba(255,255,255,.8);cursor:pointer;font-family:var(--sans);
    font-size:.9rem;padding:.4em .9em;border-radius:100px;transition:background .2s,color .2s}
.footer__link:hover{background:rgba(231,184,114,.12);color:var(--gold)}
.footer__link:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.footer__legal{font-size:.76rem;color:rgba(255,255,255,.42);max-width:60ch}

/* =========================================================
   FIXED DOCK
   ========================================================= */
.dock{position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;justify-content:center;
    padding:.85rem 1rem calc(.85rem + env(safe-area-inset-bottom,0));pointer-events:none;
    background:linear-gradient(180deg,rgba(18,10,9,0),rgba(18,10,9,.55) 45%,rgba(18,10,9,.9))}
.dock__btn{pointer-events:auto;width:min(580px,100%);justify-content:center;gap:.7em;
    padding:.8em 1.4em;animation:dockPop .6s cubic-bezier(.2,.8,.2,1) both}
@keyframes dockPop{from{transform:translateY(130%)}to{transform:translateY(0)}}
.dock__btn-text{display:flex;flex-direction:column;align-items:center;text-align:center;line-height:1.22}
.dock__btn-main{font-size:1rem;font-weight:700}
.dock__btn-sub{font-size:.72rem;font-weight:500;opacity:.9;font-family:var(--mono)}
.dock__btn-arrow{font-size:.9em;transition:transform .25s}
.dock__btn:hover .dock__btn-arrow{transform:translateX(4px)}

/* =========================================================
   MODAL
   ========================================================= */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.2rem}
.modal[hidden]{display:none}
.modal__overlay{position:absolute;inset:0;background:rgba(18,10,9,.66);backdrop-filter:blur(5px);animation:fade .25s ease}
.modal__panel{position:relative;z-index:2;width:min(620px,100%);max-height:86vh;overflow-y:auto;
    background:var(--ivory);border-radius:20px;padding:2.5rem 2rem 2rem;
    box-shadow:var(--shadow);border:1px solid var(--line-light);animation:rise .32s cubic-bezier(.2,.8,.2,1)}
@keyframes fade{from{opacity:0}}
@keyframes rise{from{opacity:0;transform:translateY(22px)}}
.modal__close{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border-radius:50%;
    border:1px solid var(--line-light);background:#fff;color:var(--ink);cursor:pointer;font-size:1rem;
    display:grid;place-items:center;transition:background .2s,transform .25s,color .2s}
.modal__close:hover{background:var(--cherry);color:#fff;transform:rotate(90deg)}
.modal__title{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--cherry);margin-bottom:1.1rem;padding-right:2.5rem}
.modal__content{color:var(--ink-soft);font-size:.95rem}
.modal__content h4{font-family:var(--serif);color:var(--ink);font-size:1.02rem;margin:1.2rem 0 .35rem}
.modal__content p{margin-bottom:.5rem}
.modal__content strong{color:var(--cherry)}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:960px){
    .hero__inner{grid-template-columns:1fr;gap:1rem}
    .hero__stage{min-height:340px;margin-top:1rem}
    .hero__bull{width:78%}
    .quote-card{left:0}
    .why__grid{grid-template-columns:repeat(2,1fr);gap:1.1rem}
    .feature,.feature--lg{grid-column:span 1}
    .feature--lg:last-child{grid-column:span 2}
}
@media (max-width:680px){
    :root{--dock-h:96px}
    /* ---- compact hero ---- */
    .hero{padding:1.6rem 0 2rem}
    .eyebrow{margin-bottom:1rem;font-size:.74rem;padding:.4em .85em}
    .hero__title{font-size:clamp(2.1rem,8.6vw,2.9rem);line-height:1.08;margin-bottom:.9rem}
    .hero__lead{font-size:.97rem;margin-bottom:1.3rem;max-width:none}
    .hero__cta-row{flex-direction:column;align-items:stretch;gap:.7rem;margin-bottom:1.3rem}
    .hero__cta-row .btn{width:100%}
    .hero__trust{font-size:.86rem}
    /* bull must be clearly visible: flow, centered, card below */
    .hero__stage{min-height:auto;flex-direction:column;margin-top:.4rem}
    .hero__glow{width:64%}
    .hero__bull{width:66%;animation-duration:5.5s}
    .quote-card{position:relative;left:auto;bottom:auto;margin:-1.4rem auto 0;width:min(300px,90%);
        animation:none}
    .float-chip{display:none}
    .hero__scrollhint{display:none}

    /* ---- compact pulse ---- */
    .pulse{padding:2.2rem 0}
    .pulse__stats{grid-template-columns:1fr 1fr;gap:1.4rem 1rem}
    .pstat:nth-child(2n){border-right:none}

    /* ---- compact sections ---- */
    .section-head{margin-bottom:2.2rem}
    .why{padding:3rem 5.5vw;border-radius:24px 24px 0 0}
    .why__grid{grid-template-columns:1fr;gap:.9rem}
    .feature,.feature--lg,.feature--lg:last-child{grid-column:span 1}
    .feature{padding:1.6rem 1.5rem}
    .feature__icon{width:48px;height:48px;font-size:1.15rem;margin-bottom:.85rem}
    .feature__no{font-size:2rem;top:1rem;right:1.2rem}
    .split{grid-template-columns:1fr;gap:1.5rem;padding:3rem 5.5vw}
    .split--img-right .split__media{order:0}
    .split__media{aspect-ratio:16/11}
    .ticklist{margin-bottom:1.4rem;gap:.6rem}
    .reports__inner{grid-template-columns:1fr;gap:1.6rem;padding:3rem 0}
    .reports__badge{width:96px;height:96px}
    .reports__badge-num{font-size:1.9rem}
    .giftlist{margin:1.2rem 0 1.5rem;gap:.6rem}
    .final{padding:4rem 0}

    .btn{font-size:.95rem}
    .dock__btn-main{font-size:.88rem}
    .dock__btn-arrow{display:none}
    .ticker__label{padding:0 .7em;font-size:.66rem}
}
@media (max-width:380px){
    .hero__bull{width:74%}
    .dock__btn-main{font-size:.8rem}
}

@media (prefers-reduced-motion:reduce){
    *{animation-duration:.001ms!important;animation-iteration-count:1!important;
        transition-duration:.001ms!important;scroll-behavior:auto!important}
    .reveal{opacity:1;transform:none}
    .candle{transform:scaleY(1)}
}
