* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
    min-height: 100vh;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: #e9eef7;
    background:
        radial-gradient(1100px 650px at 15% 15%, rgba(0,170,255,0.16), rgba(0,0,0,0) 55%),
        radial-gradient(900px 600px at 85% 25%, rgba(255,185,90,0.12), rgba(0,0,0,0) 55%),
        radial-gradient(circle at top, #101622 0, #05060a 45%, #020308 100%);
}
a { color: inherit; text-decoration: none; }

.page { max-width: 1080px; margin: 0 auto; padding: 20px 16px 40px; }
body.launcher-open {
    overflow: hidden;
}
body.launcher-open .page {
    filter: blur(4px);
    transform: scale(0.985);
    transition: filter 0.25s ease, transform 0.25s ease;
}
.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 22px;
    padding: 10px 14px;
    border-radius: 999px;
    background:
        radial-gradient(circle at 0 0, rgba(0,170,255,0.16), transparent 60%),
        radial-gradient(circle at 100% 100%, rgba(255,190,90,0.12), transparent 60%),
        rgba(5,8,20,0.90);
    border: 1px solid rgba(90,130,230,0.60);
    box-shadow: 0 12px 40px rgba(0,0,0,0.80);
}
.top-left { display: flex; align-items: center; gap: 10px; }
.mn-orbit {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(115,170,255,0.85);
    box-shadow: 0 0 22px rgba(115,170,255,0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #9fd1ff;
    background: radial-gradient(circle at 30% 0, #243359 0, #05060a 55%);
}
.mn-text-main { font-size: 14px; font-weight: 700; }
.mn-text-sub { font-size: 11px; color: #b8c6d9; }
.top-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 12px;
    color: #cfd8e8;
}

.top-nav a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 11px;
    border-radius: 999px;
    border: 1px solid rgba(120,150,240,0.35);
    background: rgba(9,16,38,0.62);
    color: #cfdbf9;
    opacity: 0.95;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease, color 0.15s ease;
}

.top-nav a:hover {
    border-color: rgba(245,195,122,0.65);
    box-shadow: 0 0 12px rgba(245,195,122,0.22);
    color: #f4dcaf;
    transform: translateY(-1px);
}

.top-nav a.active {
    border-color: rgba(95,179,255,0.75);
    background: rgba(15,33,70,0.82);
    color: #e9f1ff;
    box-shadow: 0 0 15px rgba(95,179,255,0.22);
}
.lang { display: flex; gap: 8px; }
.lang a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid rgba(120,150,240,0.55);
    background: rgba(4,10,30,0.70);
    color: #b8c6d9;
    font-size: 12px;
}
.lang a.active {
    background: rgba(24,36,51,0.92);
    border-color: rgba(120,150,240,0.85);
    color: #e9eef7;
    box-shadow: 0 0 18px rgba(90,130,230,0.22);
}

.hero {
    position: relative;
    overflow: hidden;
    border-radius: 26px;
    padding: 26px 22px 24px;
    margin-bottom: 26px;
    background:
        radial-gradient(circle at 0 0, rgba(0,180,255,0.16), transparent 60%),
        radial-gradient(circle at 100% 0, rgba(240,170,60,0.14), transparent 55%),
        linear-gradient(135deg, rgba(3,6,16,0.96), rgba(3,5,10,0.98));
    box-shadow: 0 24px 90px rgba(0,0,0,0.90);
    border: 1px solid rgba(90,130,230,0.35);
}
.hero-grid {
    display: grid;
    grid-template-columns: minmax(0,2.1fr) minmax(0,1.4fr);
    gap: 26px;
    align-items: start;
}
.badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: #8ea7ff;
    background: rgba(8,16,40,0.90);
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid rgba(114,167,255,0.45);
    margin-bottom: 16px;
}
.badge-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #31ff9c;
    box-shadow: 0 0 8px rgba(49,255,156,0.85);
}
.hero-title { font-size: 30px; line-height: 1.15; margin-bottom: 10px; }
.hero-title span { color: #f7c768; }
.hero-sub { font-size: 15px; color: #d2d9ea; max-width: 560px; margin-bottom: 12px; line-height: 1.6; }
.hero-buttons { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0; }
.btn {
    border-radius: 999px;
    padding: 10px 18px;
    font-size: 14px;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}
.btn-main {
    background: linear-gradient(135deg,#f6c365,#f0a83c);
    color: #1a1007;
    font-weight: 700;
    box-shadow: 0 0 22px rgba(240,168,60,0.55);
}
.btn-secondary {
    background: rgba(5,10,26,0.90);
    color: #f6e1b2;
    border-color: rgba(245,195,122,0.55);
}
.btn-ghost {
    background: rgba(4,10,30,0.75);
    color: #b8c7ff;
    border-color: rgba(120,150,240,0.55);
    font-size: 13px;
}
.hero-note {
    font-size: 12px;
    color: #9fb2ff;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(20,26,58,0.70);
    padding: 6px 10px;
    border-radius: 999px;
    border: 1px solid rgba(105,145,255,0.45);
}
.hero-note .dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #59ffe4;
    box-shadow: 0 0 9px rgba(89,255,228,0.70);
}
.hero-card {
    border-radius: 18px;
    padding: 16px;
    background: linear-gradient(120deg, rgba(4,10,30,0.96), rgba(8,16,45,0.96));
    border: 1px solid rgba(120,150,240,0.55);
}
.hero-card-label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: #8ba6ff; margin-bottom: 6px; }
.hero-card-title { font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.hero-card-text { font-size: 13px; color: #d7e2f3; margin-bottom: 10px; line-height: 1.55; }
.hero-card-meta { font-size: 11px; color: #9f9aa9; }
.hero-card-meta strong { color: #f7c768; }

.section {
    margin-bottom: 18px;
    padding: 20px 18px 18px;
    border-radius: 20px;
    background: rgba(3,6,16,0.92);
    border: 1px solid rgba(65,85,160,0.55);
    box-shadow: 0 18px 60px rgba(0,0,0,0.45);
}
.section-header { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.section-title { font-size: 18px; font-weight: 800; }
.section-tag { font-size: 11px; color: #9f9aa9; text-transform: uppercase; letter-spacing: 0.14em; }
.section-text { font-size: 14px; color: #d5dff0; margin-bottom: 14px; line-height: 1.62; }
.section-list { list-style: none; display: grid; gap: 6px; font-size: 13px; color: #e4eefc; }
.section-list li { display: flex; gap: 6px; }
.section-list li::before { content: "•"; color: #f7c768; margin-top: 1px; }

.mn-block {
    margin-bottom: 18px;
    border-radius: 24px;
    padding: 22px 20px 20px;
    background: linear-gradient(90deg, rgba(5,10,30,0.96) 0%, rgba(5,10,30,0.94) 45%, rgba(8,16,40,0.96) 55%, rgba(10,20,55,0.98) 100%);
    border: 1px solid rgba(90,130,230,0.65);
    position: relative;
    overflow: hidden;
    box-shadow: 0 24px 90px rgba(0,0,0,0.50);
}
.mn-line {
    position: absolute;
    top: -20%;
    bottom: -20%;
    left: 50%;
    width: 1px;
    background: linear-gradient(to bottom, transparent, rgba(160,210,255,0.55), transparent);
}
.mn-grid {
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 20% 20%, rgba(240,190,90,0.16) 0, transparent 55%),
        radial-gradient(circle at 80% 65%, rgba(110,170,255,0.22) 0, transparent 60%);
}
.mn-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0,1.2fr) minmax(0,1.4fr);
    gap: 22px;
}
.mn-title { font-size: 20px; font-weight: 800; margin-bottom: 8px; }
.mn-sub { font-size: 13px; color: #d9e4f8; line-height: 1.6; }
.mn-chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; font-size: 11px; }
.mn-chip { padding: 5px 10px; border-radius: 999px; border: 1px solid rgba(120,150,240,0.65); background: rgba(8,14,40,0.72); color: #b8c7ff; }
.mn-list { list-style: none; font-size: 13px; color: #e5f0ff; display: grid; gap: 6px; }
.mn-list li { display: flex; gap: 8px; line-height: 1.55; }
.mn-list li::before { content: "◆"; color: #f7c768; font-size: 11px; margin-top: 2px; }

.process-pipeline {
    margin-top: 14px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
}

.process-step {
    font-size: 12px;
    color: #c9d7f4;
    border: 1px solid rgba(120,150,240,0.3);
    border-radius: 10px;
    padding: 10px 8px;
    text-align: center;
    background: rgba(9,16,38,0.65);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

.process-step.active {
    border-color: rgba(245,195,122,0.75);
    color: #f5ddb3;
    box-shadow: 0 0 0 2px rgba(245,195,122,0.2);
}

.footer {
    font-size: 12px;
    color: #8f9bb0;
    border-top: 1px solid rgba(80,95,150,0.55);
    padding-top: 14px;
    margin-top: 8px;
}
.footer-wrap { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
.contacts { display: flex; flex-direction: column; gap: 4px; }
.contacts a { color: #c8d6f1; }

.contact-launcher-overlay {
    position: fixed;
    inset: 0;
    background: rgba(2, 6, 18, 0);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px 16px;
    z-index: 1000;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.24s ease, background-color 0.24s ease;
}

.contact-launcher-overlay.open {
    pointer-events: auto;
    opacity: 1;
    background: rgba(2, 6, 18, 0.72);
}

.contact-launcher-overlay.active {
    pointer-events: auto;
    opacity: 1;
    background: rgba(2, 6, 18, 0.72);
}

.contact-launcher-panel {
    width: min(460px, 96vw);
    border-radius: 20px;
    border: 1px solid rgba(120,150,240,0.45);
    background:
        radial-gradient(circle at 0 0, rgba(0,170,255,0.12), transparent 52%),
        linear-gradient(160deg, rgba(8,14,35,0.98), rgba(12,22,52,0.98));
    box-shadow: 0 24px 60px rgba(0,0,0,0.52), 0 0 20px rgba(120,150,240,0.18);
    padding: 16px;
    position: relative;
    opacity: 0;
    transform: translateY(80px);
    transition: opacity 0.24s ease, transform 0.24s ease;
}

.contact-launcher-overlay.open .contact-launcher-panel {
    opacity: 1;
    transform: translateY(0);
}

.contact-launcher-panel.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.contact-launcher-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.contact-launcher-kicker {
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #9fb2df;
}

.contact-launcher-kicker::before {
    content: "● ";
    color: #59ffe4;
}

.contact-launcher-close {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    border: 1px solid rgba(120,150,240,0.4);
    background: rgba(6,12,30,0.8);
    color: #cfdcf8;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
}

.contact-launcher-title {
    font-size: 20px;
    margin-bottom: 8px;
}

.contact-launcher-subtitle {
    font-size: 14px;
    color: #cbd6ee;
    margin-bottom: 14px;
}

.contact-launcher-actions {
    display: grid;
    gap: 10px;
}

.launcher-step {
    display: none;
}

.launcher-step.active {
    display: block;
}

.launcher-option {
    width: 100%;
    border: 1px solid rgba(120,150,240,0.45);
    border-radius: 14px;
    background: rgba(7,13,32,0.82);
    color: #e8eefc;
    padding: 14px;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.launcher-option:hover {
    border-color: rgba(245,195,122,0.75);
    box-shadow: 0 0 0 1px rgba(245,195,122,0.24), 0 0 20px rgba(245,195,122,0.22);
    transform: translateY(-1px);
}

.launcher-option-title {
    display: block;
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 4px;
}

.launcher-option-desc {
    display: block;
    font-size: 12px;
    color: #b9c8e8;
}

.launcher-option-arrow {
    font-size: 22px;
    color: #f6d8a3;
}

.launcher-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.launcher-system-log {
    margin-top: 12px;
    padding-top: 10px;
    border-top: 1px solid rgba(120,150,240,0.25);
    display: grid;
    gap: 6px;
}

.launcher-log-line {
    font-size: 12px;
    color: #afc1e8;
    opacity: 0;
    transform: translateY(4px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.launcher-log-line.show {
    opacity: 1;
    transform: translateY(0);
}

.launcher-log-line::before {
    content: "● ";
    color: #59ffe4;
}

.blog-cards {
    display: grid;
    gap: 12px;
}

.blog-card {
    display: block;
    border: 1px solid rgba(90,130,230,0.55);
    border-radius: 14px;
    padding: 16px;
    background: rgba(8,14,35,0.7);
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.blog-card:hover {
    border-color: rgba(245,195,122,0.65);
    box-shadow: 0 10px 28px rgba(0,0,0,0.35);
    transform: translateY(-1px);
}

.blog-card-title {
    font-size: 20px;
    line-height: 1.35;
    margin-bottom: 10px;
    color: #f1f4ff;
}

.blog-card-intro {
    font-size: 14px;
    line-height: 1.6;
    color: #d2d9ea;
    margin-bottom: 14px;
}

.blog-read-btn {
    pointer-events: none;
}

.product-mvp {
    margin-top: 8px;
    font-size: 12px;
    color: #9eb3df;
    opacity: 0;
    transform: translateY(3px);
    transition: opacity 0.15s ease, transform 0.15s ease;
}

.blog-card:hover .product-mvp {
    opacity: 1;
    transform: translateY(0);
}

.live-system {
    overflow: hidden;
}

.system-indicator {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    font-size: 12px;
    color: #b5c3e4;
}

.pulse-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #59ffe4;
    box-shadow: 0 0 8px rgba(89,255,228,0.8);
    animation: pulseGlow 1.4s infinite;
}

@keyframes pulseGlow {
    0%, 100% { opacity: 0.4; transform: scale(0.85); }
    50% { opacity: 1; transform: scale(1); }
}

.live-scene {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto 1.6fr 1.1fr;
    gap: 12px;
    align-items: stretch;
    min-height: 220px;
}

.live-left,
.live-right {
    border: 1px solid rgba(90,130,230,0.45);
    border-radius: 14px;
    background: rgba(8,14,35,0.62);
    padding: 12px;
}

.live-source {
    border: 1px solid rgba(120,150,240,0.45);
    border-radius: 10px;
    padding: 10px 12px;
    margin-bottom: 8px;
    background: rgba(16,26,58,0.55);
    font-size: 13px;
    color: #d5def5;
    transition: box-shadow 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.live-source-active {
    border-color: rgba(245,195,122,0.72);
    box-shadow: 0 0 18px rgba(245,195,122,0.28);
    transform: translateX(2px);
}

.live-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #9fb3e6;
    font-size: 24px;
}

.live-system-title {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #e7edff;
}

.live-list {
    display: grid;
    gap: 8px;
}

.live-item {
    border: 1px solid rgba(120,150,240,0.34);
    border-radius: 10px;
    padding: 8px 10px;
    background: rgba(11,18,44,0.72);
    transition: box-shadow 0.3s ease;
}

.live-item-highlight {
    box-shadow: 0 0 0 2px rgba(120,150,240,0.28);
}

.live-item-head {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    font-size: 12px;
    margin-bottom: 6px;
}

.live-item-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.live-time {
    font-size: 11px;
    color: #9fb2d8;
}

.live-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.live-events {
    border: 1px solid rgba(90,130,230,0.45);
    border-radius: 14px;
    background: rgba(8,14,35,0.62);
    padding: 12px;
}

.live-events-list {
    display: grid;
    gap: 6px;
}

.live-event {
    font-size: 12px;
    color: #d7e2f8;
    border: 1px solid rgba(120,150,240,0.25);
    border-radius: 8px;
    padding: 7px 9px;
    background: rgba(12,20,46,0.7);
}

.live-result {
    margin-top: 10px;
    min-height: 18px;
    font-size: 12px;
    color: #f7d59f;
    opacity: 0;
    transition: opacity 0.25s ease;
}

.live-result.show {
    opacity: 1;
}

.lead-flight {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 11px;
    border: 1px solid rgba(245,195,122,0.55);
    background: rgba(245,195,122,0.18);
    color: #f7dfb6;
    transition: transform 0.6s ease, opacity 0.4s ease;
    white-space: nowrap;
}

.mockup-card {
    border-radius: 18px;
    padding: 16px;
    background: linear-gradient(120deg, rgba(4,10,30,0.96), rgba(8,16,45,0.96));
    border: 1px solid rgba(120,150,240,0.55);
    box-shadow: 0 10px 30px rgba(0,0,0,0.35);
}

.mockup-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 12px;
    color: #f1f4ff;
}

.lead-row {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 8px;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid rgba(120,150,240,0.2);
    font-size: 13px;
    color: #dce6f8;
}

.lead-time {
    font-size: 11px;
    color: #9fb2d8;
    margin: 4px 0 8px;
    text-align: right;
}

.lead-source {
    color: #9ab4ff;
    font-size: 12px;
}

.status-badge {
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 999px;
    border: 1px solid transparent;
    white-space: nowrap;
}

.status-new {
    background: rgba(245,195,122,0.18);
    border-color: rgba(245,195,122,0.55);
    color: #f6d89d;
}

.status-work {
    background: rgba(120,150,240,0.18);
    border-color: rgba(120,150,240,0.55);
    color: #bed0ff;
}

.status-done {
    background: rgba(92,215,146,0.18);
    border-color: rgba(92,215,146,0.55);
    color: #b6f5ce;
}

.mockup-stats {
    margin-top: 12px;
    display: grid;
    gap: 6px;
    font-size: 12px;
    color: #cdd8ef;
}

.mockup-stats div {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.mockup-stats strong {
    color: #f1f4ff;
}

.before-after-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin: 12px 0 16px;
}

.before-card,
.after-card {
    border-radius: 14px;
    padding: 14px;
    border: 1px solid rgba(90,130,230,0.55);
    background: rgba(8,14,35,0.7);
}

.before-card {
    border-color: rgba(220,100,100,0.55);
    background: rgba(45,16,22,0.5);
}

.after-card {
    border-color: rgba(100,210,140,0.55);
    background: rgba(14,42,34,0.5);
}

@media (max-width: 780px) {
    .topbar { flex-direction: column; align-items: flex-start; border-radius: 18px; }
    .top-nav { width: 100%; gap: 7px; }
    .top-nav a { flex: 1 1 calc(50% - 7px); justify-content: center; }
    .lang { align-self: flex-end; }
    .hero { padding: 22px 18px 20px; }
    .hero-grid { grid-template-columns: 1fr; }
    .contact-launcher-panel {
        width: 100%;
        max-width: 100%;
        border-radius: 24px 24px 0 0;
        margin-top: auto;
    }
    .launcher-actions .btn,
    .contact-launcher-actions .btn {
        width: 100%;
        justify-content: center;
    }
    .contact-launcher-overlay {
        align-items: flex-end;
        padding: 8px 0 0;
    }
    .launcher-option {
        padding: 15px 14px;
    }
    .live-scene { grid-template-columns: 1fr; min-height: 0; }
    .live-arrow { transform: rotate(90deg); font-size: 18px; margin: -2px 0; }
    .process-pipeline { grid-template-columns: 1fr; }
    .product-mvp { opacity: 1; transform: none; }
    .mn-inner { grid-template-columns: 1fr; }
    .mn-line { left: 100%; }
    .before-after-grid { grid-template-columns: 1fr; }
}
