/* ══════════════════════════════════════════════════════
   ДРУГОЙ ПУТЬ — styles.css v4
   The Alters: holographic map · light/dark theme · sharp labels
   ══════════════════════════════════════════════════════ */

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

/* ── Theme tokens ─────────────────────────────────────── */
:root, [data-theme="light"] {
    --amber:        #b45309;
    --amber-soft:   rgba(180,83,9,.07);
    --amber-border: rgba(180,83,9,.22);
    --blue:         #1e40af;
    --blue-soft:    rgba(30,64,175,.06);
    --blue-border:  rgba(30,64,175,.18);
    --green:        #166534;

    --text:         #111008;
    --text2:        #4a4940;
    --text3:        #9a9890;

    --bg:           #ffffff;
    --bg2:          #f4f3f0;
    --bg3:          #fafaf7;
    --border:       #e6e4dd;
    --border2:      #c9c7be;

    --sh1: 0 1px 3px rgba(0,0,0,.04);
    --sh2: 0 4px 16px rgba(0,0,0,.06);
    --sh3: 0 10px 40px rgba(0,0,0,.10);
    --sh-modal: 0 30px 80px rgba(17,16,8,.22), 0 4px 12px rgba(17,16,8,.08);
}

[data-theme="dark"] {
    --amber:        #f59e0b;
    --amber-soft:   rgba(245,158,11,.10);
    --amber-border: rgba(245,158,11,.35);
    --blue:         #60a5fa;
    --blue-soft:    rgba(96,165,250,.08);
    --blue-border:  rgba(96,165,250,.25);
    --green:        #4ade80;

    --text:         #f5f4ed;
    --text2:        #c8c6bd;
    --text3:        #7a7870;

    --bg:           #0e0d0a;
    --bg2:          #1a1815;
    --bg3:          #15130f;
    --border:       #2a2823;
    --border2:      #3d3b34;

    --sh1: 0 1px 3px rgba(0,0,0,.3);
    --sh2: 0 4px 16px rgba(0,0,0,.4);
    --sh3: 0 10px 40px rgba(0,0,0,.5);
    --sh-modal: 0 30px 80px rgba(0,0,0,.7), 0 4px 12px rgba(0,0,0,.5);
}

/* ── Globals ──────────────────────────────────────────── */
:root {
    --r-sm: 3px;
    --r-md: 5px;
    --r-lg: 8px;
    --r-xl: 10px;
    --font: 'Space Grotesk', 'Inter', system-ui, sans-serif;
    --body: 'Inter', system-ui, sans-serif;
    --mono: 'JetBrains Mono', 'SF Mono', 'Cascadia Code', monospace;
    --t: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--body);
    background: var(--bg);
    color: var(--text);
    min-height: 100dvh;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    transition: background 0.25s ease, color 0.25s ease;
}

/* ── Theme toggle (fixed, bottom-right) ───────────────── */
.theme-toggle {
    position: fixed;
    bottom: 18px;
    right: 18px;
    z-index: 1000;
    width: 36px;
    height: 36px;
    border: 1px solid var(--border);
    border-radius: 50%;
    background: var(--bg);
    color: var(--text2);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--t), border-color var(--t), color var(--t), transform var(--t);
    box-shadow: var(--sh1);
}
.theme-toggle:hover {
    border-color: var(--text2);
    color: var(--text);
    transform: translateY(-1px);
    box-shadow: var(--sh2);
}
.theme-toggle svg { width: 16px; height: 16px; }
.theme-toggle .sun-icon  { display: none; }
.theme-toggle .moon-icon { display: block; }
[data-theme="dark"] .theme-toggle .sun-icon  { display: block; }
[data-theme="dark"] .theme-toggle .moon-icon { display: none; }

/* ── Screens ─────────────────────────────────────────── */
.screen        { display: none; min-height: 100dvh; flex-direction: column; }
.screen.active { display: flex; }
.screen.s-anim { animation: screenReveal .28s ease both; }
@keyframes screenReveal {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════════════════════
   LANDING
   ══════════════════════════════════════════════════════ */
#screen-landing { background: var(--bg); overflow: hidden; }

.top-nav {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 48px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.nav-logo {
    font-family: var(--font);
    font-size: 15px; font-weight: 600; letter-spacing: -.1px;
}
.nav-right {
    display: flex; align-items: center; gap: 10px;
}
.nav-blog-link {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--mono); font-size: 11px; font-weight: 600;
    color: var(--text2);
    background: var(--bg2);
    border: 1px solid var(--border);
    padding: 5px 12px; border-radius: var(--r-sm);
    text-decoration: none; letter-spacing: .3px;
    transition: border-color var(--t), color var(--t), background var(--t);
}
.nav-blog-link:hover {
    border-color: var(--amber);
    color: var(--amber);
    background: var(--amber-soft);
}
.nav-privacy {
    display: flex; align-items: center; gap: 7px;
    font-family: var(--mono); font-size: 11px; font-weight: 500;
    color: var(--green); background: rgba(22,101,52,.05);
    border: 1px solid rgba(22,101,52,.2);
    padding: 5px 13px; border-radius: var(--r-sm); letter-spacing: .3px;
}
[data-theme="dark"] .nav-privacy { background: rgba(74,222,128,.08); border-color: rgba(74,222,128,.25); }
.privacy-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--green); flex-shrink: 0;
    animation: dotBlink 3s ease-in-out infinite;
}
@keyframes dotBlink { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

.landing-wrap {
    flex: 1; display: grid; grid-template-columns: 1fr 1fr;
    align-items: center; gap: 64px; padding: 72px 80px;
    max-width: 1280px; margin: 0 auto; width: 100%;
}

.landing-eyebrow {
    font-family: var(--mono);
    font-size: 10px; font-weight: 500; text-transform: uppercase;
    letter-spacing: 2px; color: var(--text3); margin-bottom: 22px;
    display: flex; align-items: center; gap: 10px;
}
.landing-eyebrow::before {
    content: ''; display: block;
    width: 20px; height: 1px; background: var(--border2); flex-shrink: 0;
}

h1 {
    font-family: var(--font);
    font-size: clamp(42px, 5.2vw, 74px);
    font-weight: 700; letter-spacing: -2px; line-height: 1.04;
    color: var(--text); margin-bottom: 26px;
}
.amber-text { color: var(--amber); }

.landing-desc {
    font-size: 17px; color: var(--text2);
    line-height: 1.7; max-width: 440px; margin-bottom: 32px;
}
.chips-row { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 38px; }
.chip {
    font-family: var(--mono); font-size: 11px; font-weight: 500;
    color: var(--text3); background: transparent;
    border: 1px solid var(--border); padding: 5px 12px;
    border-radius: var(--r-sm); letter-spacing: .3px;
}

.btn-cta {
    display: inline-flex; align-items: center; gap: 10px;
    background: var(--text); color: var(--bg);
    border: none; border-radius: var(--r-sm);
    padding: 14px 28px; font-family: var(--font);
    font-size: 15px; font-weight: 600; letter-spacing: -.1px;
    cursor: pointer; margin-bottom: 20px;
    box-shadow: 3px 3px 0 0 var(--border);
    transition: background var(--t), transform var(--t), box-shadow var(--t);
}
.btn-cta:hover  { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 0 var(--border2); }
.btn-cta:active { transform: translate(1px,1px); box-shadow: 2px 2px 0 0 var(--border); }

.landing-disclaimer { font-size: 11px; color: var(--text3); line-height: 1.6; max-width: 380px; }

/* ── Tree preview ─────────────────────────────────────── */
.landing-visual { display: flex; align-items: center; justify-content: center; }
.tree-preview {
    position: relative; display: flex; flex-direction: column;
    align-items: center; user-select: none; padding: 20px;
}
.tree-preview::before {
    content: ''; position: absolute; top: 0; left: 0;
    width: 18px; height: 18px;
    border-top: 1.5px solid var(--amber); border-left: 1.5px solid var(--amber);
    pointer-events: none;
}
.tree-preview::after {
    content: ''; position: absolute; bottom: 0; right: 0;
    width: 18px; height: 18px;
    border-bottom: 1.5px solid var(--amber); border-right: 1.5px solid var(--amber);
    pointer-events: none;
}

.preview-center {
    width: 72px; height: 72px; border-radius: 50%;
    background: var(--text);
    display: flex; align-items: center; justify-content: center;
    font-family: var(--mono); font-size: 13px; font-weight: 600; color: var(--bg);
    position: relative; z-index: 3; box-shadow: var(--sh2);
}
.preview-ring {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
    border-radius: 50%; border: 1px solid; animation: ringExpand 4s ease-in-out infinite;
    pointer-events: none;
}
.r1 { width:72px; height:72px; border-color:rgba(17,16,8,.18); animation-delay:0s; }
.r2 { width:72px; height:72px; border-color:rgba(180,83,9,.13); animation-delay:1.3s; }
[data-theme="dark"] .r1 { border-color: rgba(245,244,237,.18); }
[data-theme="dark"] .r2 { border-color: rgba(245,158,11,.18); }
@keyframes ringExpand {
    0%   { width:72px;  height:72px;  opacity:.8; }
    100% { width:165px; height:165px; opacity:0; }
}
.preview-core { position: relative; z-index: 1; }

.preview-svg       { width: 360px; max-width: 100%; height: 220px; overflow: visible; margin-top: -24px; }
.preview-svg-right { position: absolute; right: -110px; top: 50%; transform: translateY(-70%); width: 110px; height: 160px; overflow: visible; }
.preview-future-label {
    position: absolute; right: -180px; top: 52%; transform: translateY(-50%);
    font-family: var(--mono); font-size: 10px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1.5px; color: var(--amber);
    opacity: 0; animation: labelFade .4s ease 1.6s forwards;
}
@keyframes labelFade { to { opacity: 1; } }

.pvl {
    stroke: var(--border); stroke-width: 1; stroke-linecap: round; fill: none;
    stroke-dasharray: var(--len, 300); stroke-dashoffset: var(--len, 300);
    animation: drawPV .45s ease forwards; animation-delay: var(--d, 0s);
}
.pvl-blue { stroke: rgba(180,83,9,.18); }
[data-theme="dark"] .pvl-blue { stroke: rgba(245,158,11,.28); }
@keyframes drawPV { to { stroke-dashoffset: 0; } }
.pvd {
    fill: var(--c, var(--border2)); opacity: 0;
    animation: pvdShow .3s ease forwards; animation-delay: var(--d, 0s);
}
.pvd-end { animation: pvdPop .35s cubic-bezier(0.34,1.4,0.64,1) forwards; animation-delay: var(--d, 0s); }
@keyframes pvdShow { to { opacity: 1; } }
@keyframes pvdPop  { from { opacity:0; transform:scale(0); } to { opacity:1; transform:scale(1); } }
.preview-labels { display: flex; gap: 28px; margin-top: 14px; }
.preview-labels span {
    font-family: var(--mono); font-size: 9px; font-weight: 500;
    color: var(--c, var(--text3)); text-transform: uppercase; letter-spacing: .6px;
    opacity: 0; animation: pvdShow .3s ease 1.2s forwards; white-space: nowrap;
}

/* ══════════════════════════════════════════════════════
   FORM PAGES
   ══════════════════════════════════════════════════════ */
.form-page {
    flex: 1; display: flex; flex-direction: column;
    max-width: 600px; margin: 0 auto; width: 100%; padding: 0 28px 48px;
}
.steps-bar { display: flex; align-items: center; padding: 36px 0 44px; }
.step-item { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.step-item span {
    font-size: 12px; font-weight: 500; color: var(--text3);
    transition: color var(--t);
}
.si-active span { color: var(--text2); }
.si-done   span { color: var(--amber); }
.step-dot {
    font-family: var(--mono); font-size: 11px; font-weight: 600;
    width: 28px; height: 28px; border-radius: var(--r-sm);
    border: 1px solid var(--border); color: var(--text3);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; transition: all var(--t);
}
.si-active .step-dot { border-color: var(--text2); color: var(--text); background: var(--bg2); }
.si-done   .step-dot { border-color: var(--amber); color: var(--amber); background: var(--amber-soft); font-size: 10px; }
.step-line { flex: 1; height: 1px; background: var(--border); min-width: 16px; margin: 0 8px; transition: background var(--t); }
.sl-active { background: var(--amber); }

.form-content    { flex: 1; display: flex; flex-direction: column; }
.form-content h2 {
    font-family: var(--font);
    font-size: 30px; font-weight: 700; letter-spacing: -.8px;
    margin-bottom: 12px; color: var(--text);
}
.form-sub { font-size: 14px; color: var(--text2); line-height: 1.65; margin-bottom: 24px; }
.form-sub a      { color: var(--blue); text-decoration: none; }
.form-sub a:hover{ text-decoration: underline; }

.example-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 16px; }
.ex-chip {
    font-size: 12px; font-weight: 500; color: var(--text2);
    background: var(--bg2); border: 1px solid var(--border);
    padding: 5px 12px; border-radius: var(--r-sm); cursor: pointer;
    transition: border-color var(--t), color var(--t), background var(--t);
}
.ex-chip:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-soft); }

textarea {
    width: 100%; min-height: 148px; padding: 14px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    font-size: 14px; font-family: var(--body); color: var(--text);
    resize: vertical; outline: none; background: var(--bg); line-height: 1.65;
    transition: border-color var(--t), box-shadow var(--t);
}
textarea:focus        { border-color: var(--text2); box-shadow: 0 0 0 3px rgba(17,16,8,.04); }
[data-theme="dark"] textarea:focus { box-shadow: 0 0 0 3px rgba(245,244,237,.06); }
textarea::placeholder { color: var(--text3); }

.char-row { font-family: var(--mono); font-size: 11px; color: var(--text3); text-align: right; margin: 5px 0 16px; }

.age-row   { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.age-label { font-size: 14px; font-weight: 500; color: var(--text2); white-space: nowrap; }
.age-input {
    width: 80px; padding: 9px 12px;
    border: 1px solid var(--border); border-radius: var(--r-sm);
    font-family: var(--mono); font-size: 14px; color: var(--text);
    text-align: center; outline: none; background: var(--bg);
    transition: border-color var(--t);
    -moz-appearance: textfield; appearance: textfield;
}
.age-input:focus { border-color: var(--text2); }
.age-input::-webkit-outer-spin-button,
.age-input::-webkit-inner-spin-button { -webkit-appearance: none; }
.age-unit { font-family: var(--mono); font-size: 12px; color: var(--text3); }

.field-error {
    font-size: 12px; color: #7c1d1d;
    background: #fef2f2; border: 1px solid #fecaca;
    padding: 9px 14px; border-radius: var(--r-sm); margin-bottom: 14px;
    animation: errIn .2s ease;
}
[data-theme="dark"] .field-error { color: #fca5a5; background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.3); }
.field-error.hidden { display: none; }
@keyframes errIn { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:none; } }

.btn-primary {
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--text); color: var(--bg);
    border: none; border-radius: var(--r-sm);
    padding: 12px 28px; font-family: var(--font);
    font-size: 14px; font-weight: 600; letter-spacing: -.1px;
    cursor: pointer; margin-top: 8px; align-self: flex-start;
    box-shadow: 2px 2px 0 0 var(--border);
    transition: background var(--t), transform var(--t), box-shadow var(--t);
}
.btn-primary:hover  { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 0 var(--border2); }
.btn-primary:active { transform: translate(1px,1px); box-shadow: 1px 1px 0 0 var(--border); }

.btn-back {
    background: none; border: none; color: var(--text3);
    font-family: var(--mono); font-size: 11px; font-weight: 500;
    cursor: pointer; padding: 18px 0 8px; text-align: left;
    text-transform: uppercase; letter-spacing: .5px;
    transition: color var(--t); flex-shrink: 0;
}
.btn-back:hover { color: var(--text2); }

/* ── Quiz ─────────────────────────────────────────────── */
.quiz-block       { animation: quizIn .22s ease both; }
@keyframes quizIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }
.quiz-label {
    font-family: var(--mono); font-size: 10px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 2px; color: var(--amber); margin-bottom: 10px;
}
.quiz-question {
    font-family: var(--font);
    font-size: 22px; font-weight: 600; letter-spacing: -.3px;
    line-height: 1.3; margin-bottom: 24px; color: var(--text);
}
.quiz-progress-wrap { height: 1px; background: var(--border); border-radius: 1px; overflow: hidden; margin-bottom: 6px; }
.quiz-progress-bar  { height: 100%; background: var(--amber); border-radius: 1px; transition: width .4s ease; }

.quiz-nav-row { display: flex; justify-content: space-between; align-items: center; padding-top: 8px; }

/* ── API screen ───────────────────────────────────────── */
.input-group { display: flex; flex-direction: column; gap: 7px; margin-bottom: 20px; }
.input-label {
    font-family: var(--mono); font-size: 10px; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1.5px; color: var(--text3);
}
.key-wrap { position: relative; display: flex; align-items: center; }
.key-wrap input {
    width: 100%; padding: 12px 44px 12px 12px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    font-family: var(--mono); font-size: 14px; color: var(--text);
    outline: none; background: var(--bg);
    transition: border-color var(--t); letter-spacing: .4px;
}
.key-wrap input:focus { border-color: var(--text2); }
.eye-btn {
    position: absolute; right: 10px; background: none; border: none;
    cursor: pointer; padding: 4px; color: var(--text3);
    display: flex; align-items: center; transition: color var(--t);
}
.eye-btn:hover { color: var(--text2); }
.key-link {
    font-family: var(--mono); font-size: 11px; color: var(--amber);
    font-weight: 500; text-decoration: none; letter-spacing: .3px;
}
.key-link:hover { text-decoration: underline; }
select {
    padding: 12px 36px 12px 12px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    font-size: 13px; font-family: var(--body); color: var(--text);
    background: var(--bg); cursor: pointer; outline: none;
    transition: border-color var(--t); appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9890' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 12px center;
}
select:focus { border-color: var(--text2); }
.security-box {
    margin-top: 16px; font-family: var(--mono); font-size: 11px;
    color: var(--text3); background: var(--bg2);
    border: 1px solid var(--border); padding: 12px 14px;
    border-radius: var(--r-sm); line-height: 1.6; letter-spacing: .2px;
}

/* ── Perplexity Sonar toggle ──────────────────────────── */
.sonar-toggle {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px; margin-bottom: 18px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--bg2);
    cursor: pointer;
    transition: border-color var(--t), background var(--t);
    user-select: none;
}
.sonar-toggle:hover { border-color: var(--text2); }
.sonar-toggle.active { border-color: var(--amber); background: var(--amber-soft); }
.sonar-checkbox {
    width: 18px; height: 18px; flex-shrink: 0;
    border: 1.5px solid var(--border2); border-radius: 3px;
    background: var(--bg); position: relative;
    transition: all var(--t); margin-top: 1px;
}
.sonar-toggle.active .sonar-checkbox {
    background: var(--amber); border-color: var(--amber);
}
.sonar-toggle.active .sonar-checkbox::after {
    content: ''; position: absolute;
    left: 5px; top: 1px; width: 5px; height: 10px;
    border: solid #fff; border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.sonar-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.sonar-text { flex: 1; }
.sonar-title {
    font-family: var(--font); font-size: 14px; font-weight: 600;
    color: var(--text); display: flex; align-items: center; gap: 8px; margin-bottom: 3px;
}
.sonar-badge {
    font-family: var(--mono); font-size: 9px; font-weight: 700;
    color: var(--amber); background: var(--amber-soft);
    border: 1px solid var(--amber-border); padding: 1px 6px;
    border-radius: 2px; text-transform: uppercase; letter-spacing: .8px;
}
.sonar-desc { font-size: 12px; color: var(--text2); line-height: 1.5; }

/* ── Consent (юридическое согласие) ─────────────────── */
.consent-toggle {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px; margin-bottom: 16px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--bg2);
    cursor: pointer;
    transition: border-color var(--t), background var(--t);
    user-select: none;
}
.consent-toggle:hover  { border-color: var(--text2); }
.consent-toggle.active {
    border-color: var(--green);
    background: rgba(22,101,52,.04);
}
[data-theme="dark"] .consent-toggle.active { background: rgba(74,222,128,.06); }
.consent-toggle.active .sonar-checkbox {
    background: var(--green); border-color: var(--green);
}
.consent-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.consent-title {
    font-family: var(--font); font-size: 13px; font-weight: 700;
    color: var(--text); margin-bottom: 4px;
}
.consent-desc {
    font-size: 12px; color: var(--text2); line-height: 1.55;
}
.consent-desc strong { color: var(--text); font-weight: 600; }
.consent-desc a {
    color: var(--amber); text-decoration: none; font-weight: 600;
    border-bottom: 1px dashed var(--amber-border);
}
.consent-desc a:hover { color: var(--amber); border-bottom-style: solid; }
.consent-shake { animation: consentShake .45s ease; }
@keyframes consentShake {
    0%,100% { transform: translateX(0); }
    20%,60% { transform: translateX(-6px); }
    40%,80% { transform: translateX(6px); }
}

/* ── Privacy / Terms modal ──────────────────────────── */
/* Static "privacy-modal" должен быть НАД consent-modal-wrap */
#privacy-modal { z-index: 800 !important; }

.privacy-modal-wrap {
    position: fixed; inset: 0; z-index: 700;
    background: rgba(10,14,21,.55);
    backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
    display: flex; align-items: flex-start; justify-content: center;
    padding: 40px 16px;
    overflow-y: auto;
    animation: modalBgIn .25s ease both;
}
.privacy-modal {
    position: relative;
    width: 100%; max-width: 640px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 36px 40px 32px;
    box-shadow: var(--sh-modal);
    animation: modalIn .3s cubic-bezier(0.34,1.2,0.64,1) both;
}
.pm-label {
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px;
    color: var(--amber); margin-bottom: 10px;
}
.pm-title {
    font-family: var(--font); font-size: 24px; font-weight: 700;
    letter-spacing: -.5px; color: var(--text);
    margin-bottom: 24px; line-height: 1.2;
}
.pm-section {
    padding: 18px 0;
    border-top: 1px solid var(--border);
}
.pm-section:first-of-type { border-top: none; padding-top: 0; }
.pm-section-title {
    font-family: var(--font); font-size: 14px; font-weight: 700;
    color: var(--text); margin-bottom: 8px;
    display: flex; align-items: center; gap: 8px;
}
.pm-section-title::before {
    content: '◈'; color: var(--amber); font-size: 11px;
}
.pm-section p {
    font-size: 13px; color: var(--text2);
    line-height: 1.7; margin-bottom: 8px;
}
.pm-section p:last-child { margin-bottom: 0; }
.pm-section strong { color: var(--text); font-weight: 600; }
.pm-section code {
    font-family: var(--mono); font-size: 12px;
    background: var(--bg2); padding: 1px 6px; border-radius: 3px;
    border: 1px solid var(--border); color: var(--text2);
}
.pm-section a {
    color: var(--blue); text-decoration: none; font-weight: 500;
}
.pm-section a:hover { text-decoration: underline; }
.pm-section ul {
    margin: 6px 0 8px 18px;
    font-size: 13px; color: var(--text2); line-height: 1.85;
}
.pm-ok {
    margin-top: 24px;
    width: 100%; padding: 13px;
    background: var(--text); color: var(--bg);
    border: none; border-radius: var(--r-sm);
    font-family: var(--font); font-size: 14px; font-weight: 600;
    cursor: pointer; letter-spacing: -.1px;
    box-shadow: 2px 2px 0 0 var(--border);
    transition: transform var(--t), box-shadow var(--t);
}
.pm-ok:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 0 var(--border2); }
.pm-ok:active { transform: translate(1px,1px); box-shadow: 1px 1px 0 0 var(--border); }

/* ── Inline consent modal (Build button + Cancel link) ─── */
.consent-modal-wrap { padding: 20px 16px; }
.consent-modal {
    max-width: 460px;
    padding: 30px 30px 22px;
}
.consent-modal .sm-close {
    position: absolute; top: 14px; right: 14px;
    background: none; border: none;
    font-size: 18px; color: var(--text3);
    cursor: pointer; padding: 4px 8px;
    transition: color var(--t);
}
.consent-modal .sm-close:hover { color: var(--text); }

.consent-info {
    font-size: 13px; color: var(--text2);
    line-height: 1.65; margin-bottom: 18px;
}
.consent-info p { margin-bottom: 8px; }
.consent-info p:last-child { margin-bottom: 0; }
.consent-info a {
    color: var(--amber); text-decoration: none; font-weight: 600;
    border-bottom: 1px dashed var(--amber-border);
}
.consent-info a:hover { border-bottom-style: solid; }

.consent-row {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--bg2);
    cursor: pointer;
    transition: border-color var(--t), background var(--t);
    user-select: none;
    margin-bottom: 10px;
}
.consent-row:hover { border-color: var(--text2); }
.consent-row.active.consent-toggle { border-color: var(--green); background: rgba(22,101,52,.04); }
.consent-row.active.consent-toggle .sonar-checkbox { background: var(--green); border-color: var(--green); }
.consent-row.active.sonar-toggle { border-color: var(--amber); background: var(--amber-soft); }
.consent-row.active.sonar-toggle .sonar-checkbox { background: var(--amber); border-color: var(--amber); }
.consent-row.active .sonar-checkbox::after {
    content: ''; position: absolute;
    left: 5px; top: 1px; width: 5px; height: 10px;
    border: solid #fff; border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}
.consent-row .sonar-checkbox {
    width: 18px; height: 18px; flex-shrink: 0;
    border: 1.5px solid var(--border2); border-radius: 3px;
    background: var(--bg); position: relative;
    transition: all var(--t); margin-top: 1px;
}
[data-theme="dark"] .consent-row.active.consent-toggle { background: rgba(74,222,128,.06); }

.consent-go-btn {
    display: block; width: 100%;
    margin-top: 16px;
    padding: 14px 24px;
    background: var(--text); color: var(--bg);
    border: none; border-radius: var(--r-sm);
    font-family: var(--font); font-size: 15px; font-weight: 600;
    letter-spacing: -.1px; cursor: pointer;
    box-shadow: 2px 2px 0 0 var(--border);
    transition: transform var(--t), box-shadow var(--t);
}
.consent-go-btn:hover  { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 0 var(--border2); }
.consent-go-btn:active { transform: translate(1px,1px); box-shadow: 1px 1px 0 0 var(--border); }

.consent-cancel-link {
    display: block; width: 100%;
    margin-top: 8px; padding: 8px;
    background: none; border: none;
    font-family: var(--mono); font-size: 11px;
    color: var(--text3); cursor: pointer;
    text-transform: uppercase; letter-spacing: .8px;
    transition: color var(--t);
}
.consent-cancel-link:hover { color: var(--text); }

@media (max-width: 480px) {
    .consent-modal { padding: 24px 20px 18px; }
    .consent-go-btn { font-size: 14px; padding: 12px 20px; }
}

/* ══════════════════════════════════════════════════════
   LOADING — terminal scanner style
   ══════════════════════════════════════════════════════ */
#screen-loading { align-items:center; justify-content:center; background:var(--bg); }
.loading-scene  { display:flex; flex-direction:column; align-items:center; gap:28px; padding:40px; text-align:center; }

.loading-scan {
    width:110px; height:110px; border:1px solid var(--border);
    position:relative; overflow:hidden; background:var(--bg2);
    flex-shrink:0;
}
.ls-grid {
    position:absolute; inset:0;
    background-image:
        linear-gradient(var(--border) 1px, transparent 1px),
        linear-gradient(90deg, var(--border) 1px, transparent 1px);
    background-size:18px 18px;
}
.ls-scanline {
    position:absolute; left:0; right:0; height:2px;
    background:linear-gradient(to right, transparent 0%, var(--amber) 50%, transparent 100%);
    animation:scanDown 1.8s ease-in-out infinite;
}
@keyframes scanDown { 0%{top:-2px} 50%{top:100%} 100%{top:-2px} }
.ls-crosshair { position:absolute; background:var(--amber); opacity:.25; }
.ls-ch-h { top:50%; left:0; right:0; height:1px; transform:translateY(-50%); }
.ls-ch-v { left:50%; top:0; bottom:0; width:1px;  transform:translateX(-50%); }

.loading-title {
    font-family:var(--font); font-size:22px; font-weight:700;
    letter-spacing:-.4px; color:var(--text);
}
.loading-sub {
    font-size: 13px; color: var(--text2);
    line-height: 1.55; max-width: 380px;
    text-align: center;
}
.loading-sub strong { color: var(--text); font-weight: 600; }

.loading-progress {
    width: 340px; max-width: 90vw;
    display: flex; flex-direction: column; gap: 6px;
}
.loading-progress-track {
    height: 4px; background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 2px; overflow: hidden;
}
.loading-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--amber), #fbbf24);
    border-radius: 2px;
    transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 0 8px rgba(245, 158, 11, .35);
}
.loading-timer {
    font-family: var(--mono); font-size: 10px;
    color: var(--text3); text-align: right;
    letter-spacing: .5px;
}
.loading-timer span { color: var(--amber); font-weight: 700; }

.loading-blog-cta {
    margin-top: 8px;
    padding: 14px 20px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    max-width: 380px; width: 100%;
    text-align: center;
    font-size: 12px; color: var(--text2);
    line-height: 1.55;
}
.loading-blog-cta a {
    color: var(--amber); font-weight: 600;
    text-decoration: none;
    border-bottom: 1px dashed var(--amber-border);
    margin-left: 4px;
}
.loading-blog-cta a:hover { border-bottom-style: solid; }
.lbc-sub {
    display: block; margin-top: 4px;
    font-family: var(--mono); font-size: 10px;
    color: var(--text3); letter-spacing: .5px;
}

.ll-waiting-line .ll-text {
    transition: opacity .2s ease;
    color: var(--amber);
}

.loading-log {
    width:340px; max-width:90vw; max-height:180px;
    overflow:hidden; display:flex; flex-direction:column; gap:4px;
    text-align:left;
}
.ll-line {
    display:flex; align-items:center; gap:8px;
    font-family:var(--mono); font-size:12px; color:var(--text2);
    opacity:0; transform:translateY(4px);
    transition:opacity .25s ease, transform .25s ease;
}
.ll-line.ll-visible { opacity:1; transform:none; }
.ll-prompt { color:var(--amber); flex-shrink:0; }

.loading-steps { display:flex; align-items:center; gap:8px; flex-wrap: wrap; justify-content: center; }
.ls-step {
    font-family:var(--mono); font-size:11px; font-weight:600;
    color:var(--text3); padding:5px 14px; border-radius:var(--r-sm);
    border:1px solid transparent; transition:all var(--t);
    letter-spacing:.3px; text-transform:uppercase;
}
.ls-active { color:var(--amber); background:var(--amber-soft); border-color:var(--amber-border); }
.ls-done   { color:var(--green); background:rgba(22,101,52,.06); border-color:rgba(22,101,52,.2); }
[data-theme="dark"] .ls-done { background: rgba(74,222,128,.08); border-color: rgba(74,222,128,.25); }
.ls-arrow  { font-family:var(--mono); font-size:12px; color:var(--border2); }

/* ══════════════════════════════════════════════════════
   RESULTS BAR
   ══════════════════════════════════════════════════════ */
#screen-results { background: var(--bg3); }
.results-bar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 32px;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    position: sticky; top: 0; z-index: 100; flex-shrink: 0;
}
.res-back-btn {
    background:none; border:none; color:var(--amber);
    font-family:var(--mono); font-size:12px; font-weight:600;
    cursor:pointer; padding:4px 0;
    letter-spacing:.5px; text-transform:uppercase; transition:opacity var(--t);
}
.res-back-btn:hover { opacity:.6; }
.res-disclaimer { font-family:var(--mono); font-size:10px; color:var(--text3); letter-spacing:.3px; }
.res-share-btn {
    background:none; border:1px solid var(--border);
    color:var(--text2); font-size:12px; font-weight:500;
    cursor:pointer; padding:6px 16px; border-radius:var(--r-sm);
    transition:border-color var(--t), color var(--t);
}
.res-share-btn:hover { border-color:var(--text2); color:var(--text); }

#results-root { display:flex; flex-direction:column; width:100%; min-height:0; }

/* ── Timeline header ─────────────────────────────────── */
.tl-header { max-width:860px; margin:0 auto; padding:48px 48px 24px; width:100%; }
.tl-path-title {
    font-family:var(--font); font-size:28px; font-weight:700;
    letter-spacing:-.8px; color:var(--text); margin-bottom:10px;
}
.tl-path-desc { font-size:14px; color:var(--text2); line-height:1.7; margin-bottom:14px; }
.tl-potential {
    font-family:var(--mono); font-size:12px; color:var(--amber);
    background:var(--amber-soft); border:1px solid var(--amber-border);
    border-radius:var(--r-sm); padding:10px 14px; line-height:1.55;
    margin-bottom:20px; letter-spacing:.2px;
}
.tl-legend { display:flex; flex-wrap:wrap; gap:16px; align-items:center; padding:16px 0 0; }
.leg {
    font-family:var(--mono); font-size:10px; font-weight:600;
    text-transform:uppercase; letter-spacing:1.2px;
    color:var(--lc, var(--text3)); display:flex; align-items:center; gap:5px;
}
.leg::before {
    content:''; width:6px; height:6px; border-radius:50%;
    border:1.5px solid var(--lc, var(--text3)); flex-shrink:0;
}
.leg-current         { color:var(--text); }
.leg-current::before { background:var(--text); border-color:var(--text); }

/* ══════════════════════════════════════════════════════
   TIMELINE MAP — Always holographic dark "Alters" style
   ══════════════════════════════════════════════════════ */
.tl-viewport {
    /* Map palette — independent of theme */
    --map-bg-1:    #0a0e15;
    --map-bg-2:    #060a12;
    --map-line:    rgba(180,200,255,.04);
    --map-text:    #e6e9f0;
    --map-text2:   #9ba4b8;
    --map-text3:   #5a6275;
    --map-accent:  #f59e0b;
    --map-border:  rgba(180,200,255,.10);

    width:100%; height:clamp(420px, 70vh, 760px);
    overflow:hidden; position:relative; cursor:grab;
    border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    background:
        radial-gradient(ellipse 90% 70% at 50% 50%, rgba(245,158,11,.04), transparent 60%),
        radial-gradient(ellipse 60% 90% at 50% 50%, var(--map-bg-1), var(--map-bg-2));
    color: var(--map-text);
    user-select:none; -webkit-user-select:none;
    --zoom: 1;
}
.tl-viewport:active { cursor: grabbing; }

/* Subtle dot grid + scan lines */
.tl-viewport::before {
    content:''; position:absolute; inset:0; pointer-events:none;
    background-image:
        radial-gradient(circle at 1px 1px, rgba(180,200,255,.08) 1px, transparent 0);
    background-size: 32px 32px;
    opacity: .6;
    z-index: 1;
}
.tl-viewport::after {
    content:''; position:absolute; inset:0; pointer-events:none;
    background:
        linear-gradient(180deg, transparent 0%, rgba(0,0,0,.15) 100%),
        repeating-linear-gradient(0deg, transparent 0px, transparent 3px, rgba(255,255,255,.012) 3px, rgba(255,255,255,.012) 4px);
    z-index: 2;
}

/* Zoom controls */
.tl-zoom-controls {
    position:absolute; top:14px; right:14px; z-index:50;
    display:flex; align-items:center; gap:4px;
    background:rgba(10,14,21,.85);
    border:1px solid rgba(180,200,255,.15); border-radius:var(--r-sm);
    padding:4px 6px; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
}
.tzc-btn {
    font-family:var(--mono); font-size:14px; font-weight:600;
    width:28px; height:28px; border:none; background:none;
    color:#c8cdda; cursor:pointer; border-radius:var(--r-sm);
    display:flex; align-items:center; justify-content:center;
    transition:background var(--t), color var(--t);
}
.tzc-btn:hover { background:rgba(245,158,11,.15); color:#f59e0b; }
.tzc-reset { font-size:12px; }
.tzc-fit   { font-size:13px; }
.tzc-level {
    font-family:var(--mono); font-size:11px; color:#9ba4b8;
    min-width:36px; text-align:center; letter-spacing:.3px;
}

/* ── Minimap ─────────────────────────────────── */
.tl-minimap {
    position: absolute;
    bottom: 50px;
    right: 18px;
    width: 200px;
    height: 120px;
    background: rgba(6,8,13,.85);
    border: 1px solid rgba(180,200,255,.18);
    border-radius: var(--r-sm);
    backdrop-filter: blur(10px);
    overflow: hidden;
    z-index: 55;
    cursor: crosshair;
    box-shadow: 0 8px 24px rgba(0,0,0,.5);
}
.tl-minimap::before {
    content: 'minimap';
    position: absolute; top: 4px; left: 8px;
    font-family: var(--mono); font-size: 9px; font-weight: 600;
    color: rgba(155,164,184,.6);
    text-transform: uppercase; letter-spacing: 1.5px;
    pointer-events: none; z-index: 2;
}
.tl-minimap canvas { display: block; width: 100%; height: 100%; }
.mm-viewport {
    position: absolute;
    border: 1.5px solid #f59e0b;
    background: rgba(245,158,11,.08);
    pointer-events: none;
    box-shadow: 0 0 8px rgba(245,158,11,.4);
}

.tl-hint {
    position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
    font-family:var(--mono); font-size:10px; color:#9ba4b8;
    letter-spacing:.3px; pointer-events:none; white-space:nowrap;
    opacity:.5; z-index: 50;
}

/* ── Life Questions ──────────────────────────────────── */
.lq-list   { display:flex; flex-direction:column; gap:22px; }
.lq-item   { display:flex; flex-direction:column; gap:6px; }
.lq-header { display:flex; align-items:center; gap:0; }
.lq-num    {
    font-family:var(--mono); font-size:10px; font-weight:600;
    color:var(--amber); text-transform:uppercase; letter-spacing:1.5px;
}
.lq-q {
    font-family:var(--font); font-size:16px; font-weight:600;
    color:var(--text); letter-spacing:-.2px; line-height:1.3;
}
.lq-ta {
    width:100%; min-height:88px; max-height:160px;
    padding:12px; border:1px solid var(--border); border-radius:var(--r-md);
    font-size:13px; font-family:var(--body); color:var(--text);
    resize:vertical; outline:none; background:var(--bg); line-height:1.65;
    transition:border-color var(--t), box-shadow var(--t);
}
.lq-ta:focus { border-color:var(--text2); box-shadow:0 0 0 3px rgba(17,16,8,.04); }
[data-theme="dark"] .lq-ta:focus { box-shadow:0 0 0 3px rgba(245,244,237,.06); }
.lq-ta::placeholder { color:var(--text3); }
.lq-ta.lq-err { border-color:#ef4444; animation:errIn .2s ease; }
.lq-chars {
    font-family:var(--mono); font-size:10px; color:var(--text3);
    text-align:right; letter-spacing:.3px;
}

/* ── Timeline canvas / SVG ───────────────────────────── */
.tl-canvas {
    position:absolute; top:0; left:0; z-index: 3;
    transform-origin:0 0; will-change:transform;
}
.tl-svg    { position:absolute; top:0; left:0; pointer-events:none; }

/* ── Lane labels ─────────────────────────────────────── */
.lane-lbl {
    position:absolute; left:10px;
    transform: translateY(-50%) scale(calc(1 / var(--zoom, 1)));
    transform-origin: left center;
    font-family:var(--mono); font-size:11px; font-weight:700;
    text-transform:uppercase; letter-spacing:1.5px;
    white-space:nowrap; pointer-events:none; z-index:5;
    opacity: .85;
    text-shadow: 0 0 12px currentColor;
    filter: brightness(1.3);
    padding: 4px 10px 4px 0;
    background: linear-gradient(90deg, rgba(10,14,21,.85) 0%, rgba(10,14,21,.6) 70%, transparent 100%);
    border-left: 2px solid currentColor;
    padding-left: 8px;
}

/* ── Nodes ───────────────────────────────────────────── */
.tl-node {
    position:absolute; border-radius:50%;
    border:1.5px solid var(--nc, #f5f4ed);
    background: rgba(10,14,21,.7);
    cursor:pointer; z-index:10;
    transition: background 0.15s ease, box-shadow 0.2s ease;
    display:flex; align-items:center; justify-content:center;
    box-shadow:
        0 0 0 1px rgba(10,14,21,.4),
        0 0 10px var(--nc, rgba(245,244,237,.3)),
        inset 0 0 6px rgba(255,255,255,.08);
}
.tl-node::after {
    content:''; position:absolute; inset:-3px; border-radius:50%;
    border:1px solid var(--nc);
    opacity:.0; transition: opacity .2s ease;
    pointer-events: none;
}
.tl-node:hover  {
    background: var(--nc);
    box-shadow:
        0 0 0 2px rgba(10,14,21,.6),
        0 0 24px var(--nc),
        0 0 48px var(--nc),
        inset 0 0 8px rgba(255,255,255,.2);
    z-index:20;
}
.tl-node:hover::after { opacity: .5; }
.tl-node.active {
    background: var(--nc);
    box-shadow:
        0 0 0 2px rgba(10,14,21,.6),
        0 0 18px var(--nc),
        0 0 36px var(--nc);
    z-index:20;
}
.tl-n-fork {
    box-shadow:
        0 0 0 1px rgba(10,14,21,.4),
        0 0 14px var(--nc, rgba(245,244,237,.3)),
        0 0 30px var(--nc, rgba(245,244,237,.15));
}
.tl-n-fork::before {
    content:''; position:absolute; inset:-7px; border-radius:50%;
    border:1px dashed var(--nc); opacity:.4; pointer-events:none;
    animation: forkSpin 12s linear infinite;
}
@keyframes forkSpin { to { transform: rotate(360deg); } }
.tl-n-now {
    animation: nowGlow 2.4s ease-in-out infinite;
}
@keyframes nowGlow {
    0%,100% {
        box-shadow:
            0 0 0 1px rgba(10,14,21,.4),
            0 0 14px var(--nc),
            0 0 28px rgba(245,158,11,.3);
    }
    50% {
        box-shadow:
            0 0 0 2px rgba(10,14,21,.4),
            0 0 22px var(--nc),
            0 0 50px rgba(245,158,11,.55);
    }
}
.tl-n-opportunity { border-style:dashed; }

/* Будущие узлы — пунктирная обводка + слабее свечение, но с пульсацией */
.tl-n-future {
    border-style: dashed;
    background: rgba(10,14,21,.55);
    animation: futurePulse 3.2s ease-in-out infinite;
}
@keyframes futurePulse {
    0%,100% { box-shadow: 0 0 0 1px rgba(10,14,21,.4), 0 0 8px var(--nc); opacity: .82; }
    50%     { box-shadow: 0 0 0 1px rgba(10,14,21,.4), 0 0 18px var(--nc), 0 0 32px var(--nc); opacity: 1; }
}
.tl-n-future::before {
    content: ''; position: absolute; inset: -6px; border-radius: 50%;
    border: 1px dashed var(--nc); opacity: .25;
}

/* ── Node labels (counter-scaled for sharp text) ─────── */
.node-label {
    position:absolute; display:flex; flex-direction:column;
    align-items:center; gap:2px; pointer-events:none; width:130px;
    left:50%;
    --label-scale: calc(1 / var(--zoom, 1));
    /* Background pill makes labels readable even when overlapping */
    padding: 4px 8px;
    border-radius: 4px;
    background: rgba(8,12,20,.75);
    border: 1px solid rgba(180,200,255,.08);
    box-shadow: 0 2px 8px rgba(0,0,0,.4);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
}
.nl-above {
    bottom:calc(100% + 10px);
    transform: translateX(-50%) scale(var(--label-scale));
    transform-origin: center bottom;
}
.nl-below {
    top:calc(100% + 10px);
    transform: translateX(-50%) scale(var(--label-scale));
    transform-origin: center top;
}
.tl-node:hover .node-label,
.tl-node.active .node-label {
    background: rgba(8,12,20,.92);
    border-color: rgba(180,200,255,.18);
    z-index: 25;
}
.nl-age {
    font-family:var(--mono); font-size:9px; color:#9ba4b8;
    white-space:nowrap; letter-spacing:.5px; font-weight: 600;
}
.nl-title {
    font-size:11px; font-weight:600; color:#eef1f8;
    text-align:center; line-height:1.25;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    hyphens: auto;
}

/* ── Now marker ──────────────────────────────────────── */
.now-marker {
    position:absolute; top:0; width:1px;
    background: linear-gradient(180deg,
        rgba(245,158,11,0) 0%,
        rgba(245,158,11,.5) 15%,
        rgba(245,158,11,.5) 85%,
        rgba(245,158,11,0) 100%);
    transform:translateX(-50%); pointer-events:none; z-index:4;
}
.now-label {
    position:absolute; top:-22px; left:50%;
    transform: translateX(-50%) scale(calc(1 / var(--zoom, 1)));
    transform-origin: center bottom;
    font-family:var(--mono); font-size:9px; font-weight:700;
    text-transform:uppercase; letter-spacing:2px;
    color: #f59e0b; white-space:nowrap;
    text-shadow: 0 0 12px rgba(245,158,11,.6), 0 1px 4px rgba(0,0,0,.8);
}

/* ── Age ruler ───────────────────────────────────────── */
.tl-ruler   {
    position:absolute; bottom:0; left:0; right:0; height:34px;
    border-top:1px solid rgba(180,200,255,.10);
    background: linear-gradient(180deg, rgba(10,14,21,.6), rgba(10,14,21,.95));
    backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
    pointer-events:none; z-index:3;
}
.age-tick   { position:absolute; bottom:6px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:2px; }
.at-line    { width:1px; height:6px; background:rgba(180,200,255,.3); }
.at-label   {
    font-family:var(--mono); font-size:9px; color:#9ba4b8;
    white-space:nowrap;
    transform: scale(calc(1 / var(--ruler-zoom, 1)));
    transform-origin: center top;
}
.age-tick-now .at-line  { background:var(--amber); height:10px; box-shadow: 0 0 8px var(--amber); }
.age-tick-now .at-label { color:#f59e0b; font-weight:700; }

/* ══════════════════════════════════════════════════════
   DETAIL MODAL (centered, slides from top, Alters card style)
   ══════════════════════════════════════════════════════ */
.node-modal-wrap {
    position: fixed; inset: 0; z-index: 500;
    display: none; align-items: flex-start; justify-content: center;
    padding: 60px 20px 20px;
    background: radial-gradient(ellipse at center, rgba(10,14,21,.55), rgba(10,14,21,.8));
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    overflow-y: auto;
    animation: modalBgIn .25s ease both;
}
.node-modal-wrap.open { display: flex; }
@keyframes modalBgIn { from { opacity: 0; } to { opacity: 1; } }

.node-modal {
    position: relative;
    width: 100%; max-width: 540px;
    background: linear-gradient(180deg, #131722 0%, #0e1119 100%);
    border: 1px solid rgba(180,200,255,.14);
    border-radius: var(--r-lg);
    box-shadow:
        0 30px 80px rgba(0,0,0,.6),
        0 0 60px rgba(245,158,11,.08),
        inset 0 1px 0 rgba(255,255,255,.05);
    color: #e6e9f0;
    overflow: hidden;
    animation: modalIn .32s cubic-bezier(0.34,1.2,0.64,1) both;
}
@keyframes modalIn {
    from { opacity: 0; transform: translateY(-30px) scale(0.97); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Top accent bar */
.node-modal::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--pc, #f59e0b), transparent);
    opacity: .8;
}

.nm-close {
    position: absolute; top: 14px; right: 14px;
    width: 32px; height: 32px;
    background: rgba(255,255,255,.04); border: 1px solid rgba(180,200,255,.10);
    color: #9ba4b8; cursor: pointer; border-radius: 50%;
    font-family: var(--mono); font-size: 14px;
    display: flex; align-items: center; justify-content: center;
    transition: background var(--t), color var(--t), border-color var(--t);
    z-index: 2;
}
.nm-close:hover { background: rgba(245,158,11,.12); color: #f59e0b; border-color: rgba(245,158,11,.4); }

/* Header section */
.nm-header {
    padding: 32px 36px 24px;
    position: relative;
    border-bottom: 1px solid rgba(180,200,255,.08);
}
.nm-header::after {
    content: ''; position: absolute; top: 16px; left: 36px;
    width: 24px; height: 1px;
    background: var(--pc, #f59e0b); opacity: .6;
}

.nm-badge {
    display: inline-block;
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px;
    color: var(--pc, #f59e0b);
    padding: 4px 10px;
    background: rgba(245,158,11,.08);
    border: 1px solid rgba(245,158,11,.25);
    border-radius: 2px;
    margin-bottom: 18px;
    margin-top: 12px;
}

.nm-age-row {
    display: flex; align-items: baseline; gap: 12px; margin-bottom: 6px;
}
.nm-age {
    font-family: var(--mono); font-size: 14px; font-weight: 600;
    color: #9ba4b8; letter-spacing: 1px;
}
.nm-age-line {
    flex: 1; height: 1px; background: rgba(180,200,255,.10);
}

.nm-title {
    font-family: var(--font); font-size: 28px; font-weight: 700;
    letter-spacing: -.7px; color: #fafbff;
    line-height: 1.2;
    text-shadow: 0 1px 12px rgba(245,158,11,.1);
}

/* Body section */
.nm-body {
    padding: 24px 36px 32px;
    display: flex; flex-direction: column; gap: 18px;
}

.nm-desc {
    font-size: 15px; color: #c5cad6;
    line-height: 1.75;
}

.nm-moment {
    position: relative;
    background: rgba(245,158,11,.06);
    border-left: 3px solid var(--pc, #f59e0b);
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
    padding: 14px 18px;
}
.nm-moment-label {
    font-family: var(--mono); font-size: 9px; font-weight: 700;
    color: var(--pc, #f59e0b);
    text-transform: uppercase; letter-spacing: 2px;
    margin-bottom: 8px;
}
.nm-moment-text {
    font-size: 14px; color: #d8dce6;
    line-height: 1.7; font-style: italic;
}

.nm-skills-label {
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    color: #9ba4b8; text-transform: uppercase; letter-spacing: 2px;
    margin-bottom: 4px;
}
.nm-skills {
    display: flex; flex-wrap: wrap; gap: 6px;
}
.nm-skill {
    font-family: var(--mono); font-size: 11px; color: #c5cad6;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(180,200,255,.12);
    padding: 5px 11px; border-radius: 3px;
    letter-spacing: .3px; font-weight: 500;
}

/* "Прогноз" пилюля в badge */
.nm-future-pill {
    display: inline-block;
    margin-left: 6px;
    font-size: 8px; font-weight: 700;
    color: #a78bfa;
    background: rgba(167,139,250,.12);
    border: 1px solid rgba(167,139,250,.4);
    padding: 1px 6px; border-radius: 2px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    vertical-align: middle;
}

/* "Кем бы ты был" — карточка будущего я */
.nm-future {
    background: linear-gradient(135deg, rgba(167,139,250,.08), rgba(245,158,11,.05));
    border: 1px solid rgba(167,139,250,.25);
    border-radius: var(--r-md);
    padding: 18px;
    position: relative;
}
.nm-future-label {
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    color: #c4b5fd; text-transform: uppercase; letter-spacing: 2px;
    margin-bottom: 14px;
}
.nm-future-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
    margin-bottom: 12px;
}
.nm-fcell {
    display: flex; flex-direction: column; gap: 3px;
    padding: 10px 12px;
    background: rgba(10,14,21,.5);
    border: 1px solid rgba(180,200,255,.10);
    border-radius: var(--r-sm);
}
.nm-fkey {
    font-family: var(--mono); font-size: 9px; font-weight: 600;
    color: #9ba4b8; text-transform: uppercase; letter-spacing: 1.2px;
}
.nm-fval {
    font-family: var(--font); font-size: 13px; font-weight: 600;
    color: #eef1f8; line-height: 1.3;
}
.nm-flife {
    font-size: 13px; color: #c5cad6;
    line-height: 1.65;
    padding-top: 6px;
}
.nm-fquote {
    margin-top: 12px;
    padding: 12px 14px 12px 18px;
    border-left: 2px solid #a78bfa;
    background: rgba(167,139,250,.04);
    font-size: 13px; color: #e6e9f0;
    line-height: 1.65; font-style: italic;
    border-radius: 0 var(--r-sm) var(--r-sm) 0;
}

/* Holographic decorative corners */
.node-modal .nm-corner {
    position: absolute; width: 18px; height: 18px; pointer-events: none;
    opacity: .35;
}
.node-modal .nm-corner-tl { top: 10px; left: 10px;     border-top: 1.5px solid var(--pc,#f59e0b); border-left: 1.5px solid var(--pc,#f59e0b); }
.node-modal .nm-corner-tr { top: 10px; right: 10px;    border-top: 1.5px solid var(--pc,#f59e0b); border-right: 1.5px solid var(--pc,#f59e0b); }
.node-modal .nm-corner-bl { bottom: 10px; left: 10px;  border-bottom: 1.5px solid var(--pc,#f59e0b); border-left: 1.5px solid var(--pc,#f59e0b); }
.node-modal .nm-corner-br { bottom: 10px; right: 10px; border-bottom: 1.5px solid var(--pc,#f59e0b); border-right: 1.5px solid var(--pc,#f59e0b); }

/* ══════════════════════════════════════════════════════
   REPORT (текстовый разбор + тренды)
   ══════════════════════════════════════════════════════ */
.report-section {
    max-width: 860px; margin: 0 auto; padding: 12px 48px 48px; width: 100%;
}
.report-block {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 32px 36px;
    margin-bottom: 24px;
    box-shadow: var(--sh1);
}
.report-block-title {
    font-family: var(--font);
    font-size: 13px; font-weight: 700;
    color: var(--amber);
    text-transform: uppercase; letter-spacing: 2px;
    margin-bottom: 16px;
    display: flex; align-items: center; gap: 10px;
}
.report-block-title::before {
    content: ''; width: 24px; height: 1px;
    background: var(--amber); display: block;
}
.report-text {
    font-size: 15px; color: var(--text);
    line-height: 1.85;
}
.report-text p { margin-bottom: 14px; }
.report-text p:last-child { margin-bottom: 0; }
.report-text strong { color: var(--text); font-weight: 600; }

/* Trends list */
.trends-list { display: flex; flex-direction: column; gap: 14px; margin-top: 6px; }
.trend-item {
    display: flex; gap: 14px;
    padding: 16px 18px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-left: 3px solid var(--amber);
    border-radius: var(--r-md);
    transition: border-color var(--t), background var(--t);
}
.trend-item:hover {
    border-color: var(--border2); border-left-color: var(--amber);
}
.trend-num {
    font-family: var(--mono); font-size: 18px; font-weight: 700;
    color: var(--amber); flex-shrink: 0;
    line-height: 1; min-width: 28px;
}
.trend-body { flex: 1; min-width: 0; }
.trend-title {
    font-family: var(--font); font-size: 15px; font-weight: 700;
    color: var(--text); letter-spacing: -.2px; margin-bottom: 5px;
    line-height: 1.3;
}
.trend-desc { font-size: 13px; color: var(--text2); line-height: 1.65; }
.trend-tag {
    display: inline-block; margin-top: 8px;
    font-family: var(--mono); font-size: 10px; font-weight: 600;
    color: var(--amber); background: var(--amber-soft);
    border: 1px solid var(--amber-border);
    padding: 2px 8px; border-radius: 3px;
    text-transform: uppercase; letter-spacing: .8px;
}

/* ══════════════════════════════════════════════════════
   MAP PREVIEW (миниатюра-кнопка в потоке отчёта)
   ══════════════════════════════════════════════════════ */
.map-preview-card {
    position: relative;
    width: 100%; height: 280px;
    border-radius: var(--r-lg);
    overflow: hidden;
    cursor: pointer;
    border: 1px solid var(--border);
    background:
        radial-gradient(ellipse 90% 70% at 50% 50%, rgba(245,158,11,.06), transparent 60%),
        radial-gradient(ellipse 60% 90% at 50% 50%, #0a0e15, #060a12);
    box-shadow: var(--sh2);
    transition: transform .25s ease, box-shadow .25s ease, border-color var(--t);
    display: flex; align-items: center; justify-content: center;
}
.map-preview-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh3);
    border-color: var(--amber);
}
.map-preview-card::before {
    content: ''; position: absolute; inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(180,200,255,.08) 1px, transparent 0);
    background-size: 22px 22px;
    opacity: .7;
}
.map-preview-card::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.45) 100%);
    pointer-events: none;
}
.mpc-content {
    position: relative; z-index: 2;
    text-align: center; padding: 0 24px;
    pointer-events: none;
}
.mpc-eyebrow {
    font-family: var(--mono); font-size: 10px; font-weight: 700;
    color: #f59e0b; text-transform: uppercase; letter-spacing: 2.5px;
    margin-bottom: 14px;
}
.mpc-title {
    font-family: var(--font); font-size: 28px; font-weight: 700;
    color: #fafbff; letter-spacing: -.6px; line-height: 1.15;
    margin-bottom: 12px;
    text-shadow: 0 2px 12px rgba(245,158,11,.2);
}
.mpc-sub {
    font-size: 13px; color: #9ba4b8;
    line-height: 1.5; max-width: 360px; margin: 0 auto 18px;
}
.mpc-btn {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--font); font-size: 13px; font-weight: 600;
    color: #0a0e15; background: #f59e0b;
    padding: 10px 22px; border-radius: var(--r-sm);
    box-shadow: 0 4px 16px rgba(245,158,11,.3);
    transition: transform var(--t);
}
.map-preview-card:hover .mpc-btn { transform: translate(-1px, -1px); box-shadow: 0 6px 22px rgba(245,158,11,.4); }
.mpc-corner {
    position: absolute; width: 22px; height: 22px;
    pointer-events: none; opacity: .55; z-index: 2;
}
.mpc-corner-tl { top: 14px; left: 14px;     border-top: 1.5px solid #f59e0b; border-left: 1.5px solid #f59e0b; }
.mpc-corner-tr { top: 14px; right: 14px;    border-top: 1.5px solid #f59e0b; border-right: 1.5px solid #f59e0b; }
.mpc-corner-bl { bottom: 14px; left: 14px;  border-bottom: 1.5px solid #f59e0b; border-left: 1.5px solid #f59e0b; }
.mpc-corner-br { bottom: 14px; right: 14px; border-bottom: 1.5px solid #f59e0b; border-right: 1.5px solid #f59e0b; }

/* mini-pulse dots inside preview */
.mpc-mini {
    position: absolute; width: 6px; height: 6px; border-radius: 50%;
    box-shadow: 0 0 10px currentColor;
    animation: miniPulse 3s ease-in-out infinite;
    z-index: 1;
}
@keyframes miniPulse { 0%,100% { opacity: .5; transform: scale(.9); } 50% { opacity: 1; transform: scale(1.1); } }

/* ══════════════════════════════════════════════════════
   FULLSCREEN MAP OVERLAY
   ══════════════════════════════════════════════════════ */
.map-overlay {
    position: fixed; inset: 0;
    z-index: 400;
    background: #060a12;
    display: none; flex-direction: column;
    animation: mapOverlayIn .35s ease both;
}
.map-overlay.open { display: flex; }
@keyframes mapOverlayIn {
    from { opacity: 0; transform: scale(.97); }
    to   { opacity: 1; transform: none; }
}

.map-overlay #map-overlay-body {
    flex: 1;
    min-height: 0;
    display: flex;
    width: 100%;
}
.map-overlay .tl-viewport {
    width: 100%;
    height: 100%;
    border: none;
    flex: 1;
}

/* В overlay сдвигаем зум-контролы ниже бара, иначе их прячет градиент */
.map-overlay .tl-zoom-controls { top: 64px; right: 18px; }
.map-overlay .tl-hint { bottom: 14px; }

.map-overlay-bar {
    position: absolute; top: 0; left: 0; right: 0; z-index: 60;
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 22px;
    background: linear-gradient(180deg, rgba(6,10,18,.95) 0%, rgba(6,10,18,.4) 80%, transparent 100%);
    pointer-events: none;
}
.map-overlay-bar > * { pointer-events: auto; }
.mob-title {
    font-family: var(--font); font-size: 14px; font-weight: 600;
    color: #e6e9f0; letter-spacing: -.2px;
    display: flex; align-items: center; gap: 10px;
}
.mob-title::before {
    content: '◈'; color: #f59e0b; font-size: 12px;
}
.mob-actions {
    display: flex; align-items: center; gap: 8px;
}
.mob-close {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(180,200,255,.15);
    color: #e6e9f0;
    font-family: var(--mono); font-size: 12px; font-weight: 600;
    padding: 8px 16px; border-radius: var(--r-sm);
    cursor: pointer; letter-spacing: .5px;
    transition: background var(--t), border-color var(--t);
    display: flex; align-items: center; gap: 8px;
}
.mob-close:hover { background: rgba(245,158,11,.15); border-color: rgba(245,158,11,.5); color: #f59e0b; }

/* Кнопка музыки */
.mob-music {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(180,200,255,.15);
    color: #9ba4b8;
    font-family: var(--mono); font-size: 12px; font-weight: 600;
    padding: 8px 14px; border-radius: var(--r-sm);
    cursor: pointer; letter-spacing: .5px;
    transition: background var(--t), border-color var(--t), color var(--t);
    display: flex; align-items: center; gap: 8px;
    position: relative;
}
.mob-music:hover {
    background: rgba(167,139,250,.12);
    border-color: rgba(167,139,250,.4);
    color: #c4b5fd;
}
.mob-music .ic-music-on  { display: none; }
.mob-music .ic-music-off { display: block; }
.mob-music.music-on .ic-music-on  { display: block; }
.mob-music.music-on .ic-music-off { display: none; }
.mob-music.music-on {
    color: #c4b5fd;
    border-color: rgba(167,139,250,.4);
    background: rgba(167,139,250,.08);
}
/* Лёгкое пульсирующее свечение когда играет */
.mob-music.music-on::after {
    content: ''; position: absolute; inset: -1px;
    border-radius: var(--r-sm);
    box-shadow: 0 0 0 0 rgba(167,139,250,.5);
    animation: musicPulse 2.4s ease-in-out infinite;
    pointer-events: none;
}
@keyframes musicPulse {
    0%,100% { box-shadow: 0 0 0 0 rgba(167,139,250,.45); }
    50%     { box-shadow: 0 0 0 6px rgba(167,139,250,0); }
}

/* ══════════════════════════════════════════════════════
   KNOWLEDGE BASE CTA
   ══════════════════════════════════════════════════════ */
.kb-cta-wrap {
    max-width: 860px; margin: 0 auto;
    padding: 12px 48px 32px; width: 100%;
}
.kb-cta {
    background: linear-gradient(135deg, var(--amber-soft), rgba(167,139,250,.06));
    border: 1px solid var(--amber-border);
    border-radius: var(--r-lg);
    padding: 32px 36px;
    position: relative;
    overflow: hidden;
}
.kb-cta::before {
    content: ''; position: absolute;
    top: -40px; right: -40px;
    width: 140px; height: 140px;
    background: radial-gradient(circle, rgba(245,158,11,.18), transparent 65%);
    pointer-events: none;
}
.kb-cta-eyebrow {
    font-family: var(--mono); font-size: 11px; font-weight: 700;
    color: var(--amber); text-transform: uppercase; letter-spacing: 2px;
    margin-bottom: 12px;
}
.kb-cta-title {
    font-family: var(--font); font-size: 24px; font-weight: 700;
    letter-spacing: -.5px; color: var(--text);
    margin-bottom: 12px; line-height: 1.2;
}
.kb-cta-desc {
    font-size: 14px; color: var(--text2);
    line-height: 1.7; margin-bottom: 18px;
    max-width: 520px;
}
.kb-cta-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--text); color: var(--bg);
    border: none; border-radius: var(--r-sm);
    padding: 12px 22px;
    font-family: var(--font); font-size: 14px; font-weight: 600;
    text-decoration: none; letter-spacing: -.1px;
    cursor: pointer;
    box-shadow: 2px 2px 0 0 var(--amber);
    transition: transform var(--t), box-shadow var(--t);
}
.kb-cta-btn:hover {
    transform: translate(-1px, -1px);
    box-shadow: 3px 3px 0 0 var(--amber);
}

@media (max-width: 720px) {
    .kb-cta-wrap { padding: 8px 18px 24px; }
    .kb-cta      { padding: 22px 22px; }
    .kb-cta-title{ font-size: 20px; }
    .kb-cta-desc { font-size: 13px; }
}

/* ══════════════════════════════════════════════════════
   BRAND FOOTER (Elton Labs)
   ══════════════════════════════════════════════════════ */
.brand-footer {
    max-width: 860px; margin: 0 auto;
    padding: 24px 48px 48px;
    border-top: 1px solid var(--border);
    text-align: center;
    width: 100%;
}
.brand-line {
    font-family: var(--mono); font-size: 11px; font-weight: 500;
    color: var(--text3); letter-spacing: .3px;
    margin-bottom: 14px;
}
.brand-name {
    font-family: var(--font); font-size: 18px; font-weight: 700;
    color: var(--text); letter-spacing: -.4px;
    margin-bottom: 16px;
}
.brand-name::before {
    content: '◈ '; color: var(--amber);
}
.brand-links {
    display: flex; justify-content: center; flex-wrap: wrap; gap: 10px;
}
.brand-link {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--mono); font-size: 12px; font-weight: 600;
    color: var(--text2);
    background: var(--bg2); border: 1px solid var(--border);
    padding: 8px 14px; border-radius: var(--r-sm);
    text-decoration: none;
    transition: border-color var(--t), color var(--t), background var(--t), transform var(--t);
    letter-spacing: .3px;
}
.brand-link:hover {
    border-color: var(--amber);
    color: var(--amber);
    background: var(--amber-soft);
    transform: translateY(-1px);
}
.brand-link svg { width: 14px; height: 14px; flex-shrink: 0; }
.brand-tg svg path { fill: currentColor; }
.brand-yt svg path { fill: currentColor; }

/* Tiny brand mark in landing nav */
.nav-brand-mark {
    font-family: var(--mono); font-size: 10px; font-weight: 600;
    color: var(--text3); letter-spacing: 1.2px;
    text-transform: uppercase;
    display: inline-flex; align-items: center; gap: 6px;
    text-decoration: none;
    transition: color var(--t);
}
.nav-brand-mark:hover { color: var(--amber); }
.nav-brand-mark::before {
    content: ''; width: 14px; height: 1px; background: var(--border2);
}

/* ── Timeline footer ─────────────────────────────────── */
.tl-footer {
    max-width:860px; margin:0 auto; padding:24px 48px 18px; width:100%;
    font-family:var(--mono); font-size:11px; color:var(--text3);
    line-height:1.85; text-align:center; letter-spacing:.3px;
}
.tl-footer strong { color:var(--text2); }

/* ══════════════════════════════════════════════════════
   GENERATION ERROR OVERLAY
   ══════════════════════════════════════════════════════ */
.gen-error-overlay {
    position:fixed; inset:0; z-index:600;
    background:rgba(17,16,8,.4); backdrop-filter:blur(4px);
    display:flex; align-items:center; justify-content:center; padding:20px;
}
.gen-error-box {
    background:var(--bg); border:1px solid #fecaca;
    border-radius:var(--r-lg); padding:28px 32px;
    width:100%; max-width:400px; box-shadow:var(--sh3);
}
[data-theme="dark"] .gen-error-box { border-color: rgba(239,68,68,.4); }
.gen-error-label {
    font-family:var(--mono); font-size:10px; font-weight:700;
    text-transform:uppercase; letter-spacing:1.5px; color:#ef4444; margin-bottom:10px;
}
.gen-error-msg { font-size:13px; color:var(--text2); line-height:1.6; margin-bottom:20px; word-break:break-word; }
.gen-error-btn {
    width:100%; padding:11px; background:none;
    border:1px solid var(--border); border-radius:var(--r-sm);
    font-family:var(--font); font-size:13px; font-weight:600;
    color:var(--text); cursor:pointer;
    transition:background var(--t), color var(--t);
}
.gen-error-btn:hover { background:var(--text); color:var(--bg); }

/* ══════════════════════════════════════════════════════
   SHARE MODAL
   ══════════════════════════════════════════════════════ */
.share-modal-wrap {
    position:fixed; inset:0; z-index:500;
    background:rgba(17,16,8,.35);
    display:flex; align-items:center; justify-content:center;
    padding:20px;
    backdrop-filter:blur(4px);
}
.share-modal {
    background:var(--bg); border:1px solid var(--border);
    border-radius:var(--r-lg); padding:32px;
    width:100%; max-width:400px; position:relative;
    box-shadow:var(--sh-modal);
}
.sm-close {
    position:absolute; top:16px; right:16px;
    background:none; border:none; font-family:var(--mono);
    font-size:14px; color:var(--text3); cursor:pointer;
    transition:color var(--t); padding:4px 8px;
}
.sm-close:hover { color:var(--text); }
.sm-label {
    font-family:var(--mono); font-size:10px; font-weight:600;
    text-transform:uppercase; letter-spacing:1.5px;
    color:var(--amber); margin-bottom:12px;
}
.sm-title { font-family:var(--font); font-size:22px; font-weight:700; letter-spacing:-.4px; margin-bottom:8px; color: var(--text); }
.sm-desc  { font-size:13px; color:var(--text2); line-height:1.6; margin-bottom:20px; }
.sm-url-box {
    font-family:var(--mono); font-size:12px; color:var(--text2);
    background:var(--bg2); border:1px solid var(--border);
    border-radius:var(--r-sm); padding:10px 12px;
    word-break:break-all; line-height:1.5; margin-bottom:14px;
    letter-spacing:.2px; min-height:38px;
}
.sm-copy-btn {
    width:100%; padding:12px; background:none;
    border:1px solid var(--text); border-radius:var(--r-sm);
    font-family:var(--font); font-size:14px; font-weight:600;
    color:var(--text); cursor:pointer;
    box-shadow:2px 2px 0 0 var(--border);
    transition:background var(--t), color var(--t), transform var(--t), box-shadow var(--t), border-color var(--t);
}
.sm-copy-btn:hover {
    background:var(--text); color:var(--bg);
    transform:translate(-1px,-1px); box-shadow:3px 3px 0 0 var(--border2);
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════ */
@media (max-width: 960px) {
    .landing-wrap    { grid-template-columns:1fr; padding:48px 40px; text-align:center; gap:40px; }
    .landing-text    { align-items:center; order:1; }
    .landing-visual  { order:0; }
    .landing-eyebrow { justify-content:center; }
    .preview-svg-right     { right:-80px; }
    .preview-future-label  { right:-145px; }
    .landing-desc          { text-align:center; }
    .landing-disclaimer    { text-align:center; }
}
@media (max-width: 720px) {
    .top-nav      { padding:14px 16px; }
    .nav-privacy  { display: none; }
    .nav-blog-link { font-size: 10px; padding: 5px 10px; }
    .landing-wrap { padding:32px 22px; }
    h1            { font-size:40px; letter-spacing:-1.5px; }
    .landing-desc { font-size:15px; }
    .tree-preview { transform:scale(0.8); transform-origin:top center; }
    .preview-svg-right    { display:none; }
    .preview-future-label { display:none; }
    .form-page    { padding:0 18px 36px; }
    .results-bar  { padding:10px 16px; }
    .res-disclaimer { display:none; }
    .tl-header    { padding:28px 18px 18px; }
    .tl-footer    { padding:18px 18px 28px; }
    .node-modal-wrap { padding: 40px 12px 20px; }
    .nm-header    { padding: 24px 22px 18px; }
    .nm-body      { padding: 18px 22px 26px; }
    .nm-title     { font-size: 22px; }
    .lane-lbl     { font-size: 10px; padding-left: 6px; left: 6px; }
    .report-section { padding: 8px 18px 28px; }
    .report-block   { padding: 22px 20px; }
    .map-preview-card { height: 220px; }
    .mpc-title    { font-size: 22px; }
    .mpc-sub      { font-size: 12px; max-width: 280px; }
    .brand-footer { padding: 22px 18px 30px; }
    .brand-name   { font-size: 16px; }
    .brand-link   { font-size: 11px; padding: 7px 12px; }
    .map-overlay-bar { padding: 12px 14px; }
    .mob-title    { font-size: 12px; }
    .mob-close    { font-size: 11px; padding: 6px 12px; }
    .mob-actions  { gap: 6px; }
    .mob-music    { padding: 6px 10px; font-size: 11px; }
    .mob-music-label { display: none; }    /* на мобиле оставляем только иконку */
    .theme-toggle { bottom: 14px; right: 14px; width: 32px; height: 32px; }
    .theme-toggle svg { width: 14px; height: 14px; }
    .tl-minimap   { width: 130px; height: 80px; right: 12px; bottom: 44px; }
    .map-overlay .tl-zoom-controls { top: 58px; right: 12px; padding: 3px 4px; }
    .tzc-btn      { width: 26px; height: 26px; font-size: 13px; }
    .nm-future    { padding: 14px; }
    .nm-future-grid { grid-template-columns: 1fr; gap: 8px; }
}
@media (max-width: 480px) {
    h1            { font-size:34px; letter-spacing:-1px; }
    .btn-cta      { padding:13px 24px; font-size:14px; }
    .form-content h2 { font-size:26px; }
    .loading-scene { padding:28px 20px; }
    .map-preview-card { height: 200px; }
    .mpc-title    { font-size: 20px; }
    .report-block-title { font-size: 11px; letter-spacing: 1.5px; }
    .report-text  { font-size: 14px; }
    .trend-title  { font-size: 14px; }
    .trend-desc   { font-size: 12px; }
}
