:root{
    --bg:#ffffff;
    --bg-soft:#f4f9ff;
    --border:#e2ecf7;
    --text:#282828;
    --muted:#5d728c;
    --brand:#2563eb;
    --brand-hover:#1d4ed8;
    --brand-light:#3b82f6;
    --brand-soft:#dbeafe;
    --brand-sky:#38bdf8;
    --accent:#bae6fd;
    --max:1280px;
}
*{
    box-sizing:border-box;
    -webkit-user-select:none;
    user-select:none;
    -webkit-tap-highlight-color:transparent;
}
input, textarea, [contenteditable="true"]{
    -webkit-user-select:text;
    user-select:text;
}
html,body{
    margin:0;padding:0;color:var(--text);
    font-family:'Space Grotesk',system-ui,-apple-system,sans-serif;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
    overflow-x:hidden;
}
html {
    background: #282828;
    scroll-behavior: smooth;
    scroll-padding-top: 90px;
}

body {
    background: #282828;
    min-height: 100%;
    margin: 0;
    padding: 0;
    top: 0;
    left: 0;
    color: var(--text);
    font-family: 'Space Grotesk', system-ui, -apple-system, sans-serif;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit}

.bg-color{
    background: radial-gradient(900px 600px at 80% 10%, rgba(56,189,248,.22), transparent 60%),
        radial-gradient(700px 500px at -10% 30%, rgba(37,99,235,.10), transparent 60%),
        var(--bg-soft);
    position: fixed;
    width: 100%;
    min-height:100vh;
    top: 0;
    left: 0;
    z-index: 0;
}

.bg-grid{
    position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
    background-image:
    linear-gradient(rgba(37,99,235,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.07) 1px, transparent 1px);
    background-size:56px 56px;
    mask-image:radial-gradient(ellipse 80% 60% at 60% 30%, #000 30%, transparent 80%);
}

.wrap{max-width:var(--max);margin:0 auto;padding:0 32px;position:relative;z-index:1}

.header{
    position:fixed;
    /* left:50%; */
    top:-1px;
    /* transform:translateX(-50%); */
    z-index:100;
    pointer-events:none;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
}
.dock-pill{
    position:relative;
    display:inline-flex;
    align-items:center;
    background:#282828;
    color:#282828;
    box-shadow:0 18px 40px -18px rgba(11,29,51,.45),
                0 1px 0 rgba(255,255,255,.04) inset;
    pointer-events:auto;
    margin: auto;
    justify-content: center;
    padding: 10px 18px;
}
@media (min-width:768px){ .dock-pill{transform:scale(1)} }
.dock-wing{
    position:absolute;
    top: -1px;
    width:74px;
    height:58px;
    z-index:-1;
    color:#282828;
    pointer-events:none;
    transform:scaleY(-1);
}
.dock-wing-l{left:-73px}
.dock-wing-r{right:-73px}
.dock-pill .nav-inner{padding:0;gap:18px}
.dock-pill .menu a{color:rgba(255,255,255,.85)}
.dock-pill .menu a:hover{color:#fff;background:rgba(255,255,255,.08)}
.dock-pill .soc{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:#fff}
.dock-pill .soc:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3);box-shadow:0 6px 18px -8px rgba(0,0,0,.6)}
body{padding-top:80px;padding-bottom:0}

.nav-inner{
    display:flex;align-items:center;gap:32px;padding:10px 0;
}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:32px;width:auto}
.menu{display:flex;gap:8px;margin-left:24px}
.menu a{
    padding:9px 14px;border-radius:10px;font-size:15px;font-weight:500;color:var(--text);
    transition:.15s ease;
}
.menu a:hover{background:rgba(37,99,235,.07);color:var(--brand)}
.actions{margin-left:auto;display:flex;gap:10px;align-items:center}
.soc{
    width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
    background:#fff;border:1px solid var(--border);color:var(--brand);
    transition:.15s ease;
}
.soc:hover{transform:translateY(-1px);border-color:var(--brand);box-shadow:0 6px 18px -8px rgba(37,99,235,.5)}
.btn{
    display:inline-flex;align-items:center;gap:8px;
    padding:11px 22px;border-radius:12px;font-weight:600;font-size:15px;
    border:1px solid transparent;cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn-ghost{background:#fff;border-color:var(--border);color:var(--text)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand)}
.btn-primary{
    background:var(--brand);color:#fff;
    box-shadow:0 8px 24px -8px rgba(37,99,235,.55);
}
.btn-primary:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 12px 30px -8px rgba(37,99,235,.7)}
.btn-lg{padding:18px 32px;font-size:16px;border-radius:14px}
.nav-burger{display:none;width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--border);align-items:center;justify-content:center;cursor:pointer;color:var(--text)}

.hero{
    position:relative;padding:40px 0 0;z-index:1;
}
.hero-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;min-height:580px;
}
.kicker{
    font:600 13px/1 'Space Grotesk',sans-serif;letter-spacing:.18em;text-transform:uppercase;
    color:var(--brand);display:inline-block;margin-bottom:18px;
}
.hero h1{
    font-size:clamp(34px, 4.8vw, 64px);font-weight:700;letter-spacing:-.025em;line-height:1.06;
    margin:0 0 32px;color:var(--text);
}
.hero h1 .grad{
    background:linear-gradient(120deg, var(--brand-sky) 0%, var(--brand) 60%, var(--brand-hover) 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}

.hero-right{position:relative;display:grid;place-items:center;min-height:560px;z-index:1}
.char-stage{
    position:relative;width:100%;max-width:680px;aspect-ratio:1/1;margin-bottom:-200px;z-index:1;
    pointer-events:none;
    touch-action:pan-y;
}
.glow{
    position:absolute;inset:8% 8% 4% 8%;border-radius:50%;pointer-events:none;
    background:radial-gradient(circle, rgba(56,189,248,.45), rgba(37,99,235,.18) 45%, transparent 70%);
    filter:blur(20px);
}
.stage-grid{
    position:absolute;inset:0;opacity:.4;pointer-events:none;
    background-image:
    linear-gradient(rgba(37,99,235,.18) 1px, transparent 1px),
    linear-gradient(90deg, rgba(37,99,235,.18) 1px, transparent 1px);
    background-size:48px 48px;
    mask-image:radial-gradient(ellipse 60% 60% at 50% 50%, #000, transparent 80%);
}
#spine-character{position:absolute;inset:0;width:100%;height:100%;z-index:3;transform:translateY(3%)}
#spine-coins{
    position:absolute;inset:-12% -18% -22% -8%;z-index:2;pointer-events:none;
    -webkit-mask-image:radial-gradient(ellipse 70% 65% at 52% 55%, #000 45%, transparent 95%);
    mask-image:radial-gradient(ellipse 70% 65% at 52% 55%, #000 45%, transparent 95%);
    display:none;
}
.stage canvas, #spine-character canvas, #spine-coins canvas{
    position:absolute;inset:0;width:100%!important;height:100%!important;display:block;
}
.spine-player{background:transparent!important;border:0!important}
.spine-player-controls,
.spine-player-controls-wrapper,
.spine-player-button-loading,
.spine-player-loading,
.spine-player-loading-screen,
.spine-player-error,
.spine-player-error-screen,
.spine-player-overlay,
.spine-player .spinner,
.spine-player .spinner-pulse{
    display:none!important;visibility:hidden!important;opacity:0!important;
}

#spine-character canvas, #spine-coins canvas{
    display:block!important;width:100%!important;height:100%!important;
}

.chip{
    position:absolute;z-index:5;background:#fff;border-radius:18px;
    padding:18px 26px;box-shadow:
    0 24px 48px -16px rgba(37,99,235,.30),
    0 4px 12px -4px rgba(15,40,80,.10),
    inset 0 1px 0 rgba(255,255,255,.9);
    border:1px solid rgba(37,99,235,.12);
    min-width:170px;
}
.chip .chip-k{font-size:20px;font-weight:600;color:var(--text);letter-spacing:-.01em}
.chip .chip-v{font-size:14px;color:var(--muted);font-weight:500;margin-top:2px}
.chip-1{top:28%;left:-6%;transform:rotate(-6deg)}
.chip-2{top:56%;right:-4%;transform:rotate(5deg)}
@keyframes floaty1 { 0%,100%{transform:rotate(-6deg) translateY(0)} 50%{transform:rotate(-6deg) translateY(-8px)} }
@keyframes floaty2 { 0%,100%{transform:rotate(5deg) translateY(0)} 50%{transform:rotate(5deg) translateY(-10px)} }
.chip-1{animation:floaty1 4.5s ease-in-out infinite}
.chip-2{animation:floaty2 5.2s ease-in-out infinite .8s}
.stats-section{
    padding:0 0 60px;position:relative;z-index:5;margin-top:0;
}

.features{
    position:relative;
    z-index:1;
    margin-top:-120px;
    padding:200px 0 100px;
    background:#282828;
    color:#fff;
    border-top-left-radius:45px;
    border-top-right-radius:45px;
    border-bottom-right-radius: 25px;
    border-bottom-left-radius: 25px;
}
.features .wrap{position:relative;z-index:1}
.features .kicker{color:var(--brand-sky);margin-bottom:14px}
.features h2{
    font-size:clamp(28px, 3.6vw, 48px);
    font-weight:700;letter-spacing:-.025em;line-height:1.1;
    margin:0 0 16px;color:#fff;
}
.features p.features-lead{
    margin:0 0 48px;font-size:16.5px;line-height:1.6;
    color:rgba(255,255,255,.65);max-width:640px;
}

.blue-bridge{
    position:relative;
    height: 40px;
    z-index: 0;
    top: -12px;
    border-top-left-radius: 45px;
    border-top-right-radius: 45px;
}
.blue-bridge-curve{
    position:absolute;
    left:0;
    right:0;
    bottom: 0px;
    width: 95%;
    height: 30px;
    display:block;
    pointer-events:none;
    margin: auto;
}

.contacts{
    position:relative;
    z-index:1;
    padding:120px 0 100px;
    text-align:center;
    color:var(--text);
    overflow:hidden;
}
.contacts .wrap{position:relative;z-index:1}
.contacts .kicker{color:var(--brand);margin-bottom:14px}
.contacts h2{
    font-size:clamp(28px, 3.6vw, 48px);
    font-weight:700;letter-spacing:-.025em;line-height:1.1;
    margin:0 0 16px;color:var(--text);
}
.contacts p{
    color:var(--muted);
    font-size:17px;line-height:1.55;
    max-width:520px;
    margin:0 auto 32px;
}
.contacts-cta{margin:0 auto}

.contacts-layout{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-areas:
        "info  illustration"
        "cards cards";
    column-gap:60px;
    row-gap:40px;
    align-items:center;
    text-align:left;
    max-width:1140px;
    margin:0 auto;
}

.contacts-info{ grid-area: info; padding-top:8px; }
.contacts-info .kicker{color:var(--brand);margin-bottom:14px}
.contacts-info h2{
    font-size:clamp(36px, 4.6vw, 56px);
    font-weight:700;letter-spacing:-.025em;line-height:1.05;
    margin:0 0 18px;color:var(--text);
}
.contacts-lead{
    font-size:16px;line-height:1.55;
    color:var(--muted);max-width:480px;
    margin:0;
}

.contacts-illustration{
    grid-area: illustration;
    position:relative;
    width:100%;
    max-width:520px;
    aspect-ratio:4/3;
    margin-left:auto;
    border-radius:24px;
    overflow:hidden;
    background:
        radial-gradient(800px 400px at 80% 10%, rgba(56,189,248,.22), transparent 60%),
        radial-gradient(500px 400px at 0% 100%, rgba(37,99,235,.12), transparent 60%),
        linear-gradient(135deg, #eaf3ff 0%, #f8fbff 100%);
    box-shadow:0 24px 60px -24px rgba(37,99,235,.20);
}
.contacts-illustration img{
    display:block;
    width:100%;height:100%;
    object-fit:contain;
    user-select:none;-webkit-user-drag:none;
    pointer-events:none;
}

.cs-items{
    grid-area: cards;
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:14px;
    width:100%;
    margin-top:12px;
}
@media (max-width:980px){
    .contacts-layout{
        grid-template-columns:1fr;
        grid-template-areas:
            "info"
            "illustration"
            "cards";
        row-gap:28px;
        max-width:560px;
        text-align:center;
    }
    .contacts-lead{margin-left:auto;margin-right:auto}
    .contacts-illustration{margin:0 auto;max-width:420px}
    .cs-items{grid-template-columns:1fr;gap:12px}
}

.cp{
    display:flex;
    align-items:center;
    gap:14px;
    padding:12px 16px;
    border-radius:14px;
    background:#fff;
    transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.cp:hover{
    border-color: rgba(37, 99, 235, .3);
    box-shadow: 0 12px 28px -12px rgb(37 99 235 / 7%);
    background: #282828;
    transition: 0.2s;
    span{
        color: #fff;
    }
}
.cp-icon{
    width:44px;height:44px;border-radius:12px;
    display:grid;place-items:center;flex-shrink:0;
    color:#fff;
}
.cp-icon--tg{background:linear-gradient(135deg, #38bdf8, #2563eb)}
.cp-icon--mail{background:linear-gradient(135deg, #34d399, #10b981)}
.cp-icon--dark{background:#282828}
.cp-body{display:flex;flex-direction:column;gap:2px;min-width:0;align-items: flex-start;}
.cp-title{
    font-size:11px;font-weight:600;color:var(--muted);
    text-transform:uppercase;letter-spacing:.06em;
}
.cp-text{
    font-size:15px;font-weight:500;color:var(--text);
    letter-spacing:-.005em;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.contacts-form{
    background:#fff;
    border:1px solid var(--border);
    border-radius:24px;
    padding:32px;
    box-shadow:0 24px 60px -24px rgba(37,99,235,.18);
}
.cf-title{
    margin:0 0 6px;text-align:center;
    font-size:24px;font-weight:700;letter-spacing:-.01em;
    color:var(--text);
}
.cf-sub{
    margin:0 0 24px;text-align:center;
    font-size:14px;color:var(--muted);
}
.cf-field{
    position:relative;
    display:flex;align-items:center;
    margin-bottom:12px;
    background:var(--bg-soft);
    border:1px solid var(--border);
    border-radius:12px;
    transition:border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.cf-field:focus-within{
    border-color:var(--brand);
    background:#fff;
    box-shadow:0 0 0 3px rgba(37,99,235,.12);
}
.cf-field--textarea{align-items:flex-start}
.cf-icon{
    flex-shrink:0;
    width:42px;height:42px;
    display:grid;place-items:center;
    color:#9aa3b8;
}
.cf-field:focus-within .cf-icon{color:var(--brand)}
.cf-field input,
.cf-field textarea{
    flex:1;min-width:0;
    padding:12px 14px 12px 0;
    background:transparent;border:0;outline:0;
    font:500 15px 'Space Grotesk',sans-serif;
    color:var(--text);
    -webkit-user-select:text;user-select:text;
}
.cf-field--textarea textarea{
    padding:14px;
    resize:vertical;min-height:96px;
    font-family:'Space Grotesk',sans-serif;
}
.cf-field--textarea .cf-icon{display:none}
.cf-field input::placeholder,
.cf-field textarea::placeholder{color:#9aa3b8}

.cf-submit{
    width:100%;margin-top:14px;
    padding:14px 22px;
    border:0;border-radius:12px;
    background:var(--brand);color:#fff;
    font:600 15.5px 'Space Grotesk',sans-serif;
    cursor:pointer;
    box-shadow:0 10px 26px -10px rgba(37,99,235,.55);
    transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
}
.cf-submit:hover:not(:disabled){
    background:var(--brand-hover);
    transform:translateY(-1px);
    box-shadow:0 14px 32px -10px rgba(37,99,235,.7);
}
.cf-submit:disabled{opacity:.85;cursor:default}
.cf-disclaimer{
    margin:14px 0 0;text-align:center;
    font-size:12px;color:var(--muted);
}

/* ---------- responsive ---------- */
@media (max-width:980px){
    .contacts-info h2{font-size:clamp(30px, 7vw, 42px)}
}

.features-grid{
    display:grid;
    grid-template-columns:1.15fr 1fr;
    grid-template-rows:1fr 1fr;
    gap:20px;
    margin-top:8px;
}
.fc{
    position:relative;
    border-radius:24px;
    overflow:hidden;
    padding:32px;
    display:flex;flex-direction:column;justify-content:space-between;
    min-height:260px;
    transition:transform .3s cubic-bezier(.34,1.2,.64,1), box-shadow .3s ease;
}
.fc:hover{transform:translateY(-3px)}

.fc-big{
    grid-column:1;grid-row:1 / 3;
    padding:40px 40px 0;
    min-height:540px;
}

.fc-dark{
    background:linear-gradient(170deg, #1c1c1c 0%, #0e0e0e 100%);
    border:1px solid rgba(255,255,255,.06);
    color:#fff;
}
.fc-light{
    background:#fff;color:#1a1a1a;
    box-shadow:0 1px 0 rgba(0,0,0,.04) inset;
}
.fc-accent{
    background:linear-gradient(135deg, #2563eb 0%, #1d4ed8 80%, #1e40af 100%);
    color:#fff;
}
.fc-light:hover{box-shadow:0 12px 30px -10px rgba(0,0,0,.18)}
.fc-accent:hover{box-shadow:0 18px 40px -10px rgba(37,99,235,.55)}
.fc-dark:hover{box-shadow:0 18px 40px -10px rgba(0,0,0,.6)}

.fc-body{position:relative;z-index:2}
.fc h3{
    margin:0 0 14px;
    font-size:clamp(20px, 2vw, 28px);font-weight:700;
    letter-spacing:-.02em;line-height:1.18;
}
.fc-grad{
    background:linear-gradient(120deg, var(--brand-sky), #93c5fd);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.fc p{
    margin:0;font-size:14.5px;line-height:1.55;max-width:460px;
    color:rgba(255,255,255,.62);
}
.fc-light p{color:rgba(40,40,40,.65)}
.fc-accent p{color:rgba(255,255,255,.85)}

.fc-visual{
    position:relative;
    flex:1;display:flex;
    margin-top:24px;
    min-height:130px;
}

.fc-api{
    display:block;
    width:100%;height:auto;max-height:340px;
    align-self:center;
    object-fit:contain;
    pointer-events:none;
    user-select:none;
    margin-bottom:-12px;
}
@media (max-width:980px){
    .fc-api{max-height:260px}
}

.fc-visual--line{align-items:flex-end;padding-bottom:6px}
.fc-visual--line svg{
    position:absolute;inset:auto 0 0 0;
    width:100%;height:110px;
}
.fc-badge{
    position:absolute;
    display:inline-flex;align-items:center;gap:6px;
    padding:6px 12px;border-radius:999px;
    font:600 12px 'Space Grotesk', sans-serif;
    background:#fff;color:#1a1a1a;
    box-shadow:0 6px 14px -4px rgba(0,0,0,.15);
    z-index:2;
}
.fc-badge-online{
    top:10px;right:10px;
    background:linear-gradient(135deg, #2563eb, #1d4ed8);
    color:#fff;
}
.fc-badge-online .fc-dot{
    width:6px;height:6px;border-radius:50%;background:#fff;
    box-shadow:0 0 6px #fff;
    animation:fc-pulse 1.6s ease-in-out infinite;
}
@keyframes fc-pulse{50%{opacity:.4}}
.fc-badge-stat{
    bottom:14px;right:14px;
    flex-direction:column;align-items:flex-start;gap:0;
    padding:8px 14px;
}
.fc-badge-stat b{font-size:14px;color:#1d4ed8}
.fc-badge-stat i{font-size:11px;font-style:normal;color:rgba(40,40,40,.55);font-weight:500}

/* Telegram chat preview */
.fc-visual--chat{
    align-items:flex-end;
    gap:8px;flex-direction:column;
    padding:0 4px 4px;
}
.fc-tg-logo{
    position:absolute;
    right:-10px;bottom:-22px;
    width:140px;height:140px;
    color:rgba(255,255,255,.10);
    pointer-events:none;
}
.fc-chat{
    position:relative;z-index:1;
    max-width:78%;
    padding:10px 14px;
    border-radius:14px;
    font-size:13.5px;line-height:1.35;
    backdrop-filter:blur(8px);
}
.fc-chat-user{
    align-self:flex-start;
    background:rgba(255,255,255,.16);
    color:#fff;
    border-bottom-left-radius:4px;
}
.fc-chat-mgr{
    align-self:flex-end;
    background:#fff;color:#1a1a1a;
    border-bottom-right-radius:4px;
    display:flex;flex-direction:column;gap:4px;
}
.fc-chat-mgr b{font-size:12px;color:#2563eb;font-weight:600}
.fc-chat-mgr span{font-size:13.5px}

@media (max-width:980px){
    .features-grid{
        grid-template-columns:1fr;
        grid-template-rows:auto;
        gap:14px;
    }
    .fc-big{
        grid-column:1;grid-row:auto;
        min-height:380px;
        padding:32px 28px 0;
    }
    .fc{padding:28px 24px;min-height:220px}
    .fc-tg-logo{width:100px;height:100px}
}
@media (max-width:560px){
    .fc h3{font-size:21px}
    .fc-big{min-height:340px;padding:26px 22px 0}
    .fc{padding:24px 20px;min-height:200px}
    .fc-badge-stat{padding:6px 11px}
    .fc-tg-logo{width:80px;height:80px;bottom:-12px;right:-6px}
}

.stats-bar{position:relative;color:#fff;filter:drop-shadow(0 30px 50px rgba(37,99,235,.35))}
.stats-shape{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block}
.stats-shape-mobile{
    position:absolute;inset:0;width:100%;height:100%;z-index:0;
    display:none;
}
.stats-content{position:relative;z-index:1;padding:78px 56px 48px}
.stats-head{
    font-size:15.5px;line-height:1.5;color:#dbeafe;max-width:420px;margin:0 0 28px;font-weight:500;
}
.stats-row{
    display:flex;align-items:stretch;gap:28px;
}
.stat{
    flex:1 1 0;min-width:0;
    display:flex;flex-direction:column;justify-content:center;
}
.stat b{
    display:flex;align-items:baseline;
    font-size:clamp(30px, 3.6vw, 52px);font-weight:700;
    letter-spacing:-.025em;line-height:1;color:#fff;
    white-space:nowrap;
}
.stat b .dollar{
    font-size:.58em;font-weight:700;color:#cfddff;
    align-self:flex-start;margin:.16em .08em 0 0;line-height:1;
}
.stat span{
    display:block;font-size:14.5px;color:#cfddff;
    margin-top:12px;font-weight:500;line-height:1.35;
}
.stat-sep{
    flex:0 0 auto;align-self:flex-start;
    margin-top:clamp(13px, 1.7vw, 24px);
    width:28px;height:30px;color:#c9d6ff;opacity:.85;
    display:grid;place-items:center;
}
.stat-sep svg{width:100%;height:100%;display:block}

.dock-pill .logo{flex-shrink:0;display:flex;align-items:center}
.dock-pill .logo img{display:block;flex-shrink:0}

.burger{
    display:none;
    background:transparent;border:0;cursor:pointer;
    width:32px;height:32px;padding:0;
    position:relative;flex-shrink:0;margin-left:auto;
}
.burger span{
    position:absolute;left:6px;right:6px;height:2px;
    background:rgba(255,255,255,.92);border-radius:2px;
    transition:transform .32s cubic-bezier(.7,0,.3,1),
               top .32s cubic-bezier(.7,0,.3,1),
               bottom .32s cubic-bezier(.7,0,.3,1),
               opacity .2s;
}
.burger span:nth-child(1){top:9px}
.burger span:nth-child(2){top:50%;margin-top:-1px}
.burger span:nth-child(3){bottom:9px}
.burger.open span:nth-child(1){top:50%;margin-top:-1px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){bottom:auto;top:50%;margin-top:-1px;transform:rotate(-45deg)}

.menu-mobile{
    position:fixed;top:64px;left:50%;
    transform:translateX(-50%) translateY(-12px) scale(.92);
    transform-origin:top center;
    background:#282828;
    color:#fff;
    border-radius:22px;
    padding:14px 18px;
    display:flex;flex-direction:column;gap:2px;
    min-width:220px;
    z-index:99;
    opacity:0;
    pointer-events:none;
    visibility:hidden;
    transition:opacity .28s ease,
               transform .42s cubic-bezier(.34,1.56,.64,1),
               visibility 0s linear .35s;
    box-shadow:0 24px 50px -10px rgba(0,0,0,.45),
               0 0 0 1px rgba(255,255,255,.06) inset;
}
.menu-wing{display:none}
.menu-mobile.open{
    opacity:1;
    transform:translateX(-50%) translateY(0) scale(1);
    pointer-events:auto;
    visibility:visible;
    transition:opacity .28s ease,
               transform .42s cubic-bezier(.34,1.56,.64,1),
               visibility 0s linear 0s;
}
.menu-mobile a{
    color:rgba(255,255,255,.85);
    padding:13px 22px;border-radius:12px;
    font-size:15px;font-weight:500;text-align:center;display:block;
    transition:background .15s ease, color .15s ease;
    opacity:0;transform:translateY(8px);
}
.menu-mobile a:hover, .menu-mobile a:focus-visible{
    background:rgba(255,255,255,.08);color:#fff;outline:none;
}
.menu-mobile.open a{
    animation:menuItemIn .38s cubic-bezier(.34,1.56,.64,1) forwards;
}
.menu-mobile.open a:nth-child(1){animation-delay:.08s}
.menu-mobile.open a:nth-child(2){animation-delay:.13s}
.menu-mobile.open a:nth-child(3){animation-delay:.18s}
.menu-mobile.open a:nth-child(4){animation-delay:.23s}
.menu-mobile.open a:nth-child(5){animation-delay:.28s}
.menu-mobile.open a:nth-child(6){animation-delay:.32s}
@keyframes menuItemIn{
    to{opacity:1;transform:translateY(0)}
}

.menu-backdrop{
    position:fixed;inset:0;
    background:rgba(20,20,30,0);
    z-index:98;
    pointer-events:none;
    transition:background .3s ease, backdrop-filter .3s ease;
}
.menu-backdrop.open{
    background:rgba(20,20,30,.4);
    pointer-events:auto;
    backdrop-filter:blur(6px);
    -webkit-backdrop-filter:blur(6px);
}

@media (max-width:1180px){
    .hero-grid{gap:30px;min-height:540px}
    .char-stage{max-width:580px;margin-bottom:-170px}
    .stats-content{padding:68px 44px 42px}
    .stats-row{gap:22px}
}

@media (max-width:1060px){
    .hero{padding:24px 0 0}
    .hero-grid{
        grid-template-columns:1fr;
        gap:0;
        min-height:0;
        align-items:start;
        justify-items:center;
    }
    .hero-left{
        display:flex;flex-direction:column;align-items:center;
        text-align:center;
        max-width:720px;
        width:100%;
        margin:0 auto;
    }
    .hero h1{margin-bottom:28px}
    .hero h1 br{display:none}
    .btn-lg{padding:16px 28px;font-size:15px}

    .hero-right{
        width:100%;
        min-height:0;
        display:grid;place-items:center;
        margin-top:0;
    }
    .char-stage{max-width:560px;margin-bottom:-140px}

    .chip{padding:14px 18px;border-radius:14px;min-width:150px}
    .chip .chip-k{font-size:17px}
    .chip .chip-v{font-size:13px}
    .chip-1{top:28%;left:0}
    .chip-2{top:58%;right:0}
}

@media (max-width:720px){
    .wrap{padding:0 22px}

    .char-stage{max-width:440px;margin-bottom:-60px}
    .chip{padding:12px 16px;min-width:135px}
    .chip .chip-k{font-size:15.5px}
    .chip .chip-v{font-size:12px}
    .chip-1{top:24%;left:0}
    .chip-2{top:62%;right:0}

    .stats-section{padding:0 0 40px}
    .stats-shape{display:none}
    .stats-shape-mobile{display:block}
    .stats-content{padding:54px 32px 44px;text-align:center}
    .stats-head{margin:0 auto 24px;max-width:320px}
    .stats-row{flex-direction:column;gap:22px}
    .stat{align-items:center}
    .stat b{justify-content:center}
    .stat-sep{transform:rotate(90deg);opacity:.5;margin-top:0}
}

@media (max-width:560px){
    .wrap{padding:0 16px}
    .logo img{height:28px}

    .hero h1{font-size:34px;margin-bottom:20px}
    .btn-lg{padding:13px 22px;font-size:14.5px}
    .char-stage{max-width:340px;margin-bottom:-30px}
    .chip{padding:10px 14px;min-width:118px}
    .chip .chip-k{font-size:14px}
    .chip .chip-v{font-size:11.5px}

    .stats-content{padding:42px 22px 32px}
    .stats-head{font-size:13.5px;margin-bottom:18px}
    .stat b{font-size:30px}
    .stat span{font-size:13px}

    .dock-pill .menu{display:none}
    .burger{display:block}
    .dock-pill .nav-inner{gap:12px}
    .dock-pill{padding: 12px 18px;}
    .dock-wing{ top: -2px}
}

@media (max-width:380px){
    .dock-pill .nav-inner{gap:10px}

    .hero h1{font-size:30px}
    .char-stage{max-width:300px}
    .chip{min-width:106px;padding:9px 12px}
    .chip .chip-k{font-size:13px}
    .chip .chip-v{font-size:11px}

    .menu-mobile{min-width:200px;border-radius:18px}
    .menu-mobile a{padding:11px 18px;font-size:14px}
}

.scroll-top{
    position:fixed;
    right:calc(env(safe-area-inset-right, 0px) + 20px);
    bottom:calc(env(safe-area-inset-bottom, 0px) + 20px);
    z-index:90;
    width:48px;height:48px;
    border-radius:50%;border:0;cursor:pointer;
    background:#282828;color:#fff;
    display:grid;place-items:center;
    box-shadow:0 18px 40px -14px rgba(11,29,51,.55),
               0 4px 10px -2px rgba(15,40,80,.18),
               0 1px 0 rgba(255,255,255,.06) inset;
    opacity:0;
    transform:translateY(12px) scale(.85);
    pointer-events:none;
    transition:opacity .28s ease,
               transform .38s cubic-bezier(.34,1.56,.64,1),
               background .18s ease;
}
.scroll-top.visible{
    opacity:1;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}
.scroll-top:hover{background:#3a3a3a}
.scroll-top:active{transform:translateY(0) scale(.94)}
.scroll-top svg{width:20px;height:20px;display:block}
@media (max-width:560px){
    .scroll-top{
        right:calc(env(safe-area-inset-right, 0px) + 16px);
        bottom:calc(env(safe-area-inset-bottom, 0px) + 16px);
        width:44px;height:44px;
    }
    .scroll-top svg{width:18px;height:18px}
}

.preloader{
    position:fixed;
    inset:0;
    z-index:1000;
    background:#282828;
    display:grid;
    place-items:center;
    opacity:1;
    transition:opacity .5s ease;
}
.preloader.hidden{
    opacity:0;
    pointer-events:none;
}
.preloader-ring{
    position:relative;
    width:96px;
    height:96px;
    display:grid;
    place-items:center;
}
.preloader-ring::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:50%;
    border:2px solid rgba(255,255,255,.08);
    border-top-color:var(--brand-sky);
    border-right-color:var(--brand);
    animation:preloader-spin 1s linear infinite;
}
.preloader-logo{
    width:42px;
    height:auto;
    display:block;
    animation:preloader-pulse 1.8s ease-in-out infinite;
}
@keyframes preloader-spin{
    to{transform:rotate(360deg)}
}
@keyframes preloader-pulse{
    0%,100%{opacity:.9;transform:scale(1)}
    50%{opacity:1;transform:scale(1.05)}
}