/* ===== ЕДИНАЯ ГЛОБАЛЬНАЯ СИСТЕМА СТИЛЕЙ ===== */
:root {
    /* Тёмная тема по умолчанию */
    --primary: #ffffff; --primary-soft: #e5e5e5; --secondary: #d1d5db; --tertiary: #9ca3af; --quaternary: #6b7280;
    --surface: #1f1f1f; --surface-elevated: #2a2a2a; --background: #0a0a0a;
    --border: #374151; --border-light: #1f2937;
    --accent: #6366f1; --success: #22c55e; --warning: #eab308; --error: #ef4444;
    --font-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem; --space-6: 1.5rem; --space-8: 2rem;
    --space-10: 2.5rem; --space-12: 3rem; --space-16: 4rem; --space-24: 6rem;
    --radius: 0.5rem; --radius-lg: 0.75rem; --radius-xl: 1rem;
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);

    /* ! НОВОЕ: Переменные для SVG-схемы */
    --svg-ink-stroke: #bbb;
    --svg-ink-fill: #e5e5e5;
    --svg-green-stroke: #22c55e;
    --svg-grey-stroke: #606060;
}

/* Светлая тема */
[data-theme="light"] {
    --primary: #000000; --primary-soft: #1a1a1a; --secondary: #333333; --tertiary: #666666; --quaternary: #999999;
    --surface: #f8f9fa; --surface-elevated: #ffffff; --background: #fdfdfd;
    --border: #e5e7eb; --border-light: #f3f4f6;
    --accent: #4f46e5; --success: #16a34a; --warning: #d97706; --error: #dc2626;

    /* ! НОВОЕ: Переопределение переменных для светлой темы */
    --svg-ink-stroke: #555;
    --svg-ink-fill:   #111;
    --svg-green-stroke: #16a34a;
    --svg-grey-stroke: #9ca3af;
}

/* Общие сбросы и стили */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--font-primary);
    background-color: var(--background);
    color: var(--primary);
    line-height: 1.6;
    transition: background-color 0.3s, color 0.3s;
    overflow-x: hidden;
}

/* ===== НАВИГАЦИЯ ===== */
.nav { position: absolute; top: 0; width: 100%; z-index: 1000; padding: var(--space-6) var(--space-8); background: transparent; }
.nav-container { display: flex; justify-content: space-between; align-items: center; max-width: 1400px; margin: 0 auto; }
.logo { font-size: 1.75rem; font-weight: 600; text-decoration: none; color: var(--primary); }
.nav-links { display: flex; list-style: none; gap: var(--space-8); }
.nav-link { color: var(--secondary); text-decoration: none; font-weight: 500; transition: color 0.2s; }
.nav-link.active, .nav-link:hover { color: var(--primary); }
.nav-controls { display: flex; align-items: center; gap: var(--space-4); }
.language-select { background: none; border: 1px solid var(--border); border-radius: var(--radius); padding: var(--space-2); color: var(--secondary); cursor: pointer; }
.language-select option { background: var(--background); color: var(--primary); }
.theme-toggle { width: 44px; height: 24px; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; cursor: pointer; position: relative; }
.theme-toggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: var(--primary); border-radius: 50%; transition: transform 0.3s; transform: translateX(0); }
[data-theme="light"] .theme-toggle::after { transform: translateX(20px); }

/* ===== СТИЛИ СТРАНИЦЫ ===== */
.btn { display: inline-flex; padding: var(--space-4) var(--space-6); font-size: 1rem; font-weight: 500; text-decoration: none; border: 1px solid; border-radius: var(--radius); cursor: pointer; transition: all 0.2s; }
.btn-primary { background: var(--accent); color: #ffffff; border-color: var(--accent); }
.btn-primary:hover { opacity: 0.9; transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn-secondary { color: var(--primary); border-color: var(--border); background: transparent; }
.btn-secondary:hover { background: var(--surface); border-color: var(--tertiary); }

.container { max-width: 1200px; margin: 0 auto; }
.container-wide { max-width: 1600px; margin: 0 auto; padding: 0 var(--space-8); }
.text-center { text-align: center; }

h2.section-title { font-size: 2.5rem; font-weight: 600; margin-bottom: var(--space-8); }
.page-subtitle { font-size: 1.1rem; color: var(--secondary); max-width: 700px; margin: var(--space-4) auto 0; }

.hero { min-height: 100vh; position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; background-color: #0a0a0a; }
#background-canvas { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; }
.hero-content { position: relative; z-index: 1; text-align: center; max-width: 900px; padding: 0 var(--space-8); }
.hero-logo { font-size: clamp(4rem, 12vw, 10rem); font-weight: 700; line-height: 1.0; letter-spacing: -0.05em; color: var(--primary); margin-bottom: var(--space-2); }
.hero-subtitle { font-size: clamp(1.1rem, 2.5vw, 1.6rem); color: var(--secondary); margin-bottom: var(--space-10); font-weight: 400; max-width: 700px; line-height: 1.4; }
.hero-cta { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }
.problem-section, .solution-section, .metrics-section, .cta-section, .roadmap-section { padding: var(--space-16) var(--space-8); }
.problem-section, .metrics-section, .roadmap-section { background: var(--surface); }
.solution-grid, .metrics-grid, .cta-grid { display: grid; gap: var(--space-8); max-width: 1200px; margin: var(--space-12) auto 0; }
.solution-grid { grid-template-columns: repeat(3, 1fr); }
.metrics-grid { grid-template-columns: repeat(4, 1fr); }
.cta-grid { grid-template-columns: repeat(3, 1fr); }

/* ... (остальные стили секций остаются без изменений) ... */
.solution-card { background: var(--surface); padding: var(--space-8); border-radius: var(--radius-xl); border: 1px solid var(--border); transition: all 0.3s; }
.solution-card:hover { transform: translateY(-4px); border-color: var(--accent); }
.solution-card-title { font-size: 1.25rem; font-weight: 600; margin-bottom: var(--space-4); color: var(--primary); }
.solution-card-text { font-size: 0.95rem; line-height: 1.6; color: var(--secondary); }
.metric-card { text-align: center; }
.metric-value { font-size: 3rem; font-weight: 700; color: var(--accent); }
.metric-label { font-size: 1rem; font-weight: 500; color: var(--primary); margin-top: var(--space-2); }
.metric-desc { font-size: 0.9rem; color: var(--tertiary); margin-top: var(--space-2); }
.cta-card { text-align: center; background: var(--surface); padding: var(--space-8); border-radius: var(--radius-xl); border: 1px solid var(--border); }
.cta-card-title { font-size: 1.2rem; font-weight: 600; margin-bottom: var(--space-4); }
.cta-card-text { color: var(--secondary); margin-bottom: var(--space-6); min-height: 60px; }

/* ! НОВОЕ: Стили для компонента Roadmap */
.roadmap-section { padding: var(--space-16) 0; overflow: hidden; }
.rm-switch { display: flex; justify-content: center; gap: var(--space-3); margin-bottom: var(--space-8); }
.rm-tab { background: transparent; border: 1px solid var(--border); color: var(--tertiary); padding: var(--space-3) var(--space-6); border-radius: var(--radius); cursor: pointer; font-weight: 500; transition: all 0.2s; }
.rm-tab:hover { color: var(--primary); border-color: var(--tertiary); }
.rm-tab.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.rm-svg-viewport { position: relative; }
.rm-svg-wrap { overflow-x: auto; scroll-behavior: smooth; -ms-overflow-style: none; scrollbar-width: none; }
.rm-svg-wrap::-webkit-scrollbar { display: none; }
.rm-svg-wrap svg { display: block; min-width: 1600px; /* Минимальная ширина, чтобы прокрутка работала */ width: 100%; height: auto; }
.rm-svg-nav { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; width: 44px; height: 44px; border-radius: 50%; background: var(--surface-elevated); border: 1px solid var(--border); color: var(--primary); font-size: 1.5rem; cursor: pointer; opacity: 0.5; transition: opacity 0.2s; }
.rm-svg-nav:hover { opacity: 1; }
.rm-svg-nav--left { left: var(--space-8); }
.rm-svg-nav--right { right: var(--space-8); }


/* Подвал */
.footer { text-align: center; padding: var(--space-12) var(--space-8); margin-top: var(--space-16); border-top: 1px solid var(--border); }
.footer p { color: var(--tertiary); font-size: 0.9rem; }

@media (max-width: 968px) { .solution-grid, .metrics-grid, .cta-grid { grid-template-columns: 1fr; } }
@media (max-width: 768px) { h2.section-title { font-size: 2rem; } .metric-value { font-size: 2.5rem; } .hero-logo { font-size: 3.5rem; } .hero-cta { flex-direction: column; width: 100%; } .btn { width: 100%; justify-content: center; } .rm-svg-nav { display: none; } }