/* ========================================
   ИГРАЙ — система жизни v3
   Дизайн: Death Stranding influenced (Cargo Management vibes)
   Шрифт: iA Writer Mono V (Стасов, тот же что в Obsidian)
   ======================================== */

@font-face {
    font-family: 'iA Writer Mono V';
    src: url('fonts/iAWriterMonoV.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
.clickable { cursor: pointer; }

/* ===== ПАЛИТРА — Death Stranding tone ===== */
:root {
    /* фоны: тёмные сине-серые (вместо чёрного) */
    --bg-dark: #0E1419;
    --bg-card: #161D26;
    --bg-card-hover: #1D2832;
    --bg-input: #14191F;
    --bg-secondary: #1D2832;
    --bg-elev: #2A3C47;
    --bg-surface: #34343C;

    /* текст — тёплый off-white (DS не использует чистый белый) */
    --text-primary: #E8E6E0;
    --text: #E8E6E0;
    --text-secondary: #9BA8B5;
    --text-muted: #5E6B78;

    /* основной интерактивный — chiral cyan (а не зелёный) */
    --accent: #5FB4C9;
    --accent-hover: #7CCDDF;
    --accent-light: #93D9E8;
    --accent-rgb: 95, 180, 201;
    --primary: #5FB4C9;
    --danger: #C8403A;

    /* линии и сепараторы (DS — тёплые сепараторы) */
    --border-color: #2A3441;
    --border-light: #3A4858;
    --border-warm: #CAB4A1;    /* DS warm separator — для крайних разделителей */
    --shadow-color: rgba(0, 0, 0, 0.4);

    /* glassmorphism */
    --glass-bg: rgba(255, 255, 255, 0.025);
    --glass-bg-hover: rgba(255, 255, 255, 0.05);
    --glass-bg-active: rgba(95, 180, 201, 0.08);
    --glass-border: rgba(202, 180, 161, 0.12);
    --glass-border-light: rgba(202, 180, 161, 0.06);
    --glass-inset: rgba(255, 255, 255, 0.04);

    /* === ВЕКТОРЫ ЖИЗНИ (как цветные веса гирь, но с DS-приглушением) === */
    --v-body: #E07060;          /* 🏋️ тело */
    --v-breath: #5FB4C9;        /* 🧘 дыхание = chiral */
    --v-relations: #E089B5;     /* ❤️ отношения */
    --v-money: #D4A847;         /* 💰 деньги */
    --v-head: #6B9DC9;          /* 🧠 голова */
    --v-voice: #B07ED4;         /* 📣 голос */
    --v-system: #7DCB8E;        /* ⚡ система */

    /* DS события — тёплые акценты */
    --neon-cyan: #5FB4C9;
    --neon-magenta: #E089B5;
    --neon-lime: #93D9E8;
    --gold: #F4D136;
    --ds-amber: #DC8D18;
    --ds-gold-ds: #F4D136;
    --ds-chiral: #5FB4C9;
    --ds-chiral-soft: #316B74;
    --ds-blue-deep: #3E5E8D;
    --ds-bg-deep: #0E1419;
    --ds-bg: #161D26;
    --ds-bg-elev: #2A3C47;
    --ds-text-warm: #E8E6E0;
    --ds-line: #CAB4A1;
    --ds-warn: #C8403A;

    /* z-index шкала */
    --z-sticky: 100;
    --z-nav: 300;
    --z-overlay: 500;
    --z-modal: 600;
    --z-toast: 900;

    /* heatmap уровни — холодная DS гамма */
    --cal-level-0-bg: #161D26;
    --cal-level-0-border: #2A3441;
    --cal-level-1: #1F3B47;
    --cal-level-2: #2D5C6E;
    --cal-level-3: #4690A8;
    --cal-level-4: #5FB4C9;
}

/* === светлая тема (если Telegram переключит) === */
[data-theme="light"] {
    --bg-dark: #f5f5f5;
    --bg-card: #ffffff;
    --bg-card-hover: #f0f0f0;
    --bg-input: #ffffff;
    --bg-secondary: #ffffff;
    --text-primary: #1a1a1a;
    --text: #1a1a1a;
    --text-secondary: #666666;
    --text-muted: #999999;
    --accent: #16a34a;
    --border-color: #e5e5e5;
    --border-light: #d4d4d4;
    --glass-bg: rgba(0, 0, 0, 0.02);
    --glass-bg-hover: rgba(0, 0, 0, 0.04);
    --glass-border: rgba(0, 0, 0, 0.08);
    --cal-level-0-bg: #ebedf0;
    --cal-level-0-border: #d0d7de;
    --cal-level-1: #9be9a8;
    --cal-level-2: #40c463;
    --cal-level-3: #30a14e;
    --cal-level-4: #216e39;
}

body {
    font-family: 'iA Writer Mono V', 'JetBrains Mono', 'Fira Code', monospace;
    background-color: var(--bg-dark);
    color: var(--text-primary);
    line-height: 1.55;
    min-height: 100vh;
    min-height: 100dvh;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    font-feature-settings: "tnum" on, "lnum" on;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0;
}

/* === DS фон: тонкий blue tint + scan lines + cargo grid === */
.bg-grid {
    position: fixed; inset: 0; z-index: -3;
    background-image:
        linear-gradient(rgba(95, 180, 201, 0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(95, 180, 201, 0.02) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse at center, black 20%, transparent 75%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 20%, transparent 75%);
    pointer-events: none;
}
.bg-scanlines {
    position: fixed; inset: 0; z-index: -2;
    background: repeating-linear-gradient(
        to bottom,
        transparent 0px,
        transparent 3px,
        rgba(95, 180, 201, 0.018) 3px,
        rgba(95, 180, 201, 0.018) 4px
    );
    pointer-events: none;
}
.bg-glow {
    position: fixed; inset: 0; z-index: -1;
    background:
        radial-gradient(ellipse at 15% 0%, rgba(95, 180, 201, 0.08) 0%, transparent 55%),
        radial-gradient(ellipse at 85% 100%, rgba(220, 141, 24, 0.04) 0%, transparent 50%);
    pointer-events: none;
}

[data-theme="light"] .bg-scanlines,
[data-theme="light"] .bg-grid,
[data-theme="light"] .bg-glow { display: none; }

/* === app container === */
/* мобильник: узкая колонка. десктоп: широкий контейнер + multi-col grid внутри view */
.app {
    max-width: 480px;
    margin: 0 auto;
    padding: 56px 16px 80px;
    position: relative;
}
@media (max-width: 480px) {
    .app { padding: 48px 12px 76px; }
}
@media (min-width: 900px) {
    .app { max-width: 1280px; padding: 64px 24px 88px; }
}

/* === DESKTOP layout: grid для контента дашборда === */
@media (min-width: 900px) {
    /* дашборд — 2 колонки. Стодневка и задачи на сегодня — full row */
    #view-dashboard {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 14px;
        align-items: start;
    }
    #view-dashboard > .card-glow,
    #view-dashboard > .card-day,
    #view-dashboard > .card-row {
        grid-column: 1 / -1;
    }
    #view-dashboard > .card-row { display: flex; }

    /* статистика — auto-grid */
    #view-stats {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 14px;
        align-items: start;
    }
    #view-stats > .stat-grid {
        grid-column: 1 / -1;
        grid-template-columns: repeat(6, 1fr);
    }
    #view-stats > .card:nth-of-type(3),
    #view-stats > .card:nth-of-type(4) {
        grid-column: 1 / -1;
    }

    /* привычки — 2 колонки */
    #view-habits { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: start; }
    #view-habits > .card-add { grid-column: 1 / -1; }

    /* задачи — input + filter full width, список в 2 колонки если LIST */
    #view-tasks { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: start; }
    #view-tasks > .projects-strip,
    #view-tasks > .project-banner,
    #view-tasks > .card-add,
    #view-tasks > .filter-bar { grid-column: 1 / -1; }
    /* board сам уже grid, ему full-width */
    #view-tasks > #tasks-list:has(.board) { grid-column: 1 / -1; }

    /* цели — full на главных карточках, по колонкам goals+vectors */
    #view-goals { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: start; }
    #view-goals > .card-glow { grid-column: 1 / -1; }

    /* карта — не растягиваем по полной ширине, центрируем */
    #view-map .card { max-width: 720px; margin-left: auto; margin-right: auto; }
}

@media (min-width: 1200px) {
    /* очень широкий — дашборд 3 колонки */
    #view-dashboard { grid-template-columns: 1fr 1fr 1fr; }
}

/* ===== HUD HEADER — DS Cargo Management vibes ===== */
/* тонкий, прямоугольный, с разделителями-линиями, без скруглений-радиусов */
.hud {
    background: linear-gradient(180deg, rgba(22, 29, 38, 0.42), rgba(14, 20, 25, 0.38));
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--border-warm);
    border-radius: 0;
    padding: 14px 16px 12px;
    margin-top: 12px;
    margin-bottom: 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    backdrop-filter: blur(25px) saturate(1.4);
    -webkit-backdrop-filter: blur(25px) saturate(1.4);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 4px 20px rgba(0, 0, 0, 0.35);
}

/* тонкая длинная линия слева сверху (как в DS title bars) */
.hud::before {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 80px; height: 1px;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}
.hud::after {
    content: '';
    position: absolute;
    bottom: -1px; right: 0;
    width: 120px; height: 1px;
    background: var(--border-warm);
    opacity: 0.35;
}

.hud-left { display: flex; flex-direction: column; gap: 4px; min-width: 0; flex: 0 1 auto; }
.hud-right { display: flex; gap: 14px; align-items: center; flex: 1; justify-content: flex-end; }

.callsign {
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 2px;
    color: var(--text-primary);
    line-height: 1;
    text-transform: uppercase;
}
.callsign-prefix { color: var(--text-muted); font-weight: 400; letter-spacing: 1.5px; }
.callsign-name { color: var(--accent); font-weight: 500; text-shadow: 0 0 8px rgba(95, 180, 201, 0.4); }

.callsign-sub {
    font-size: 9px;
    color: var(--text-muted);
    display: flex;
    gap: 8px;
    align-items: center;
    letter-spacing: 1.2px;
    margin-top: 2px;
    text-transform: uppercase;
}
.dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
    animation: pulseDot 2.2s infinite;
}
@keyframes pulseDot { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }

.hud-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    gap: 4px;
    padding-left: 12px;
    border-left: 1px solid var(--border-color);
}
.hud-stat:first-child { padding-left: 0; border-left: none; }

.hud-stat-wide { flex: 1; min-width: 0; max-width: 180px; padding-left: 12px; }

.hud-label {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 400;
}

.hud-value {
    font-weight: 500;
    font-size: 20px;
    color: var(--text-primary);
    letter-spacing: 0.5px;
    font-variant-numeric: tabular-nums;
}

.glow-cyan { color: var(--accent) !important; text-shadow: 0 0 8px rgba(95, 180, 201, 0.5); }
.glow-magenta { color: var(--v-relations) !important; text-shadow: 0 0 8px rgba(224, 137, 181, 0.4); }
.glow-lime { color: var(--ds-gold-ds) !important; text-shadow: 0 0 8px rgba(244, 209, 54, 0.5); }

.xp-bar {
    position: relative;
    height: 8px;
    background: rgba(14, 20, 25, 0.8);
    border: 1px solid var(--border-color);
    border-radius: 0;
    overflow: hidden;
    width: 100%;
}

.xp-bar-fill {
    position: absolute;
    inset: 0;
    width: 0%;
    background: linear-gradient(90deg, var(--accent) 0%, var(--accent-light) 100%);
    box-shadow: 0 0 10px rgba(95, 180, 201, 0.5);
    transition: width 0.5s ease;
    border-radius: 0;
}

.xp-bar-fill::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    animation: shimmer 2s infinite;
}
@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

.xp-bar-text {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 9px;
    color: #fff;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    text-shadow: 0 0 4px rgba(0,0,0,0.9);
    z-index: 1;
}

/* ===== NAV — DS tab strip ===== */
/* ===== NAV — DS Bottom navigation (как меню убежища) ===== */
.nav.nav-bottom {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    top: auto;
    z-index: 90;
    display: flex;
    gap: 1px;
    margin-bottom: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 8px 6px;
    padding-bottom: calc(8px + env(safe-area-inset-bottom, 0));
    border-top: none;
    background: rgba(14, 20, 25, 0.42);
    backdrop-filter: blur(25px) saturate(1.4);
    -webkit-backdrop-filter: blur(25px) saturate(1.4);
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.45);
}

.nav::-webkit-scrollbar { display: none; }

/* тонкая cyan-линия снизу-сверху */
.nav.nav-bottom::before {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 80px; height: 1px;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}

.nav-btn {
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-secondary);
    padding: 8px 4px 6px;
    border-radius: 0;
    font-family: inherit;
    font-size: 9px;
    font-weight: 400;
    letter-spacing: 1.5px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex: 1;
    min-width: 0;
    transition: all 0.2s;
    text-transform: uppercase;
    position: relative;
}

.nav-btn:hover { color: var(--text-primary); }

.nav-btn.active {
    color: var(--accent);
}
.nav-btn.active::before {
    content: '';
    position: absolute;
    top: -4px; left: 50%;
    transform: translateX(-50%);
    width: 28px; height: 2px;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent);
}

/* иконки в нижней навигации скрыты — только подписи */
.nav.nav-bottom .nav-icon { display: none; }
.nav-icon {
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: currentColor;
}
.nav-icon svg { width: 100%; height: 100%; display: block; }
.nav-label { font-size: 9px; line-height: 1; letter-spacing: 1px; }
.nav.nav-bottom .nav-label { font-size: 11px; letter-spacing: 1.5px; }

/* ===== VIEW ===== */
.view { display: none; }
.view.active { display: block; }
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===== CARD — DS cargo panel ===== */
/* прямоугольные, тонкие линии, без больших радиусов */
.card {
    background: linear-gradient(180deg, rgba(22, 29, 38, 0.85), rgba(20, 25, 31, 0.92));
    border: 1px solid var(--border-color);
    border-radius: 2px;
    padding: 16px 18px;
    margin-bottom: 12px;
    position: relative;
}

/* тонкая cyan-полоска сверху слева (DS title accent) */
.card::before {
    content: '';
    position: absolute;
    top: -1px; left: 0;
    width: 50px; height: 1px;
    background: var(--accent);
    box-shadow: 0 0 6px rgba(95, 180, 201, 0.5);
}

.card-glow {
    border-color: rgba(95, 180, 201, 0.3);
    box-shadow: 0 0 16px rgba(95, 180, 201, 0.06);
}

.card-add {
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    backdrop-filter: blur(10px);
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
    position: relative;
}

/* подложка-фон под заголовком как в Cargo (тонкая полупрозрачная линия снизу) */
.card-header::after {
    content: '';
    position: absolute;
    bottom: -1px; right: 0;
    width: 40%; height: 1px;
    background: var(--accent);
    opacity: 0.3;
}

.card-title {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 2.5px;
    color: var(--text-primary);
    text-transform: uppercase;
}

.card-meta {
    font-size: 10px;
    color: var(--text-secondary);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    font-variant-numeric: tabular-nums;
}

.card-row { display: flex; gap: 8px; margin-bottom: 12px; }

/* ===== DS PALETTE (Death Stranding) — добавочный слой ===== */
/* применяется поверх базы. Используется для тостов, ачивок, дня закрытого. */
:root {
    --ds-bg-deep: #14191F;
    --ds-bg: #1D2832;
    --ds-bg-elev: #2A3C47;
    --ds-chiral: #5FB4C9;
    --ds-chiral-soft: #316B74;
    --ds-blue-deep: #3E5E8D;
    --ds-amber: #DC8D18;
    --ds-gold-ds: #F4D136;
    --ds-text-warm: #E8E6E0;
    --ds-line: #CAB4A1;
}

/* ===== ДЕНЬ — 100 XP прогресс (стиль DS amber/chiral) ===== */
.card-day {
    background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-card-hover) 100%);
    position: relative;
    overflow: hidden;
}

.card-day::after {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(0deg, transparent 0 3px, rgba(95, 180, 201, 0.025) 3px 4px);
    pointer-events: none;
}

.day-progress-row {
    padding: 4px 0 6px;
    position: relative;
    z-index: 1;
}

.day-xp-bar {
    position: relative;
    height: 24px;
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: 4px;
    overflow: hidden;
}

.day-xp-fill {
    position: absolute;
    inset: 0;
    width: 0%;
    background: linear-gradient(90deg,
        var(--ds-chiral) 0%,
        var(--accent) 60%,
        var(--ds-amber) 92%,
        var(--ds-gold-ds) 100%);
    box-shadow: 0 0 12px rgba(95, 180, 201, 0.4);
    transition: width 0.6s cubic-bezier(.2, .8, .2, 1);
    border-radius: 4px;
}

.day-xp-fill.closed {
    background: linear-gradient(90deg, var(--ds-amber) 0%, var(--ds-gold-ds) 100%);
    box-shadow: 0 0 16px rgba(220, 141, 24, 0.6);
}

.day-xp-fill::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    animation: shimmer 2.5s infinite;
}

.day-xp-ticks {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(90deg, transparent calc(25% - 0.5px), rgba(255, 255, 255, 0.18) 25%, transparent calc(25% + 0.5px)),
        linear-gradient(90deg, transparent calc(50% - 0.5px), rgba(255, 255, 255, 0.25) 50%, transparent calc(50% + 0.5px)),
        linear-gradient(90deg, transparent calc(75% - 0.5px), rgba(255, 255, 255, 0.18) 75%, transparent calc(75% + 0.5px));
    pointer-events: none;
}

.day-xp-text {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    text-shadow: 0 0 4px rgba(0, 0, 0, 0.9);
    letter-spacing: 0.8px;
    z-index: 2;
    font-variant-numeric: tabular-nums;
}

.day-hint {
    font-size: 10px;
    color: var(--text-secondary);
    margin-top: 8px;
    letter-spacing: 0.5px;
    text-align: center;
    font-style: italic;
    text-transform: uppercase;
}

#today-status.closed {
    color: var(--ds-gold-ds);
    text-shadow: 0 0 6px rgba(244, 209, 54, 0.5);
    font-weight: 700;
}

/* ===== STATUS HUD — DS Cuff Links верхняя панель (главные показатели жизни) ===== */
.status-hud {
    position: fixed;
    left: 0; right: 0; top: 0;
    bottom: auto;
    display: flex;
    align-items: stretch;
    gap: 1px;
    background: rgba(14, 20, 25, 0.95);
    border-bottom: 1px solid var(--border-warm);
    border-top: none;
    padding: 6px 10px;
    padding-top: calc(6px + env(safe-area-inset-top, 0));
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 80;
    box-shadow: inset 0 1px 0 rgba(95, 180, 201, 0.08);
}

.status-hud::before {
    content: '';
    position: absolute;
    bottom: -1px; left: 16px;
    width: 50px; height: 1px;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}

.status-cell {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 8px;
    border-right: 1px solid var(--border-color);
    min-width: 0;
    flex: 1;
}
.status-cell:last-child { border-right: none; }

.status-icon {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--text-secondary);
}
.status-icon svg { width: 100%; height: 100%; display: block; }

.status-cell[data-stat="hp"] .status-icon { color: var(--danger); border-color: var(--danger); }
.status-cell[data-stat="stamina"] .status-icon { color: var(--accent); border-color: var(--accent); }
.status-cell[data-stat="stress"] .status-icon { color: var(--ds-amber); border-color: var(--ds-amber); }
.status-cell[data-stat="will"] .status-icon { color: var(--ds-gold-ds); border-color: var(--ds-gold-ds); }
.status-cell[data-stat="balance"] .status-icon { color: var(--accent); border-color: var(--border-light); }
.status-cell[data-stat="links"] .status-icon { color: var(--ds-gold-ds); border-color: var(--ds-gold-ds); }

.status-bar {
    flex: 1;
    height: 10px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--border-color);
    overflow: hidden;
    position: relative;
    min-width: 30px;
    max-width: 80px;
}

.status-bar-hp .status-fill {
    background: linear-gradient(90deg, #C8403A, #E07060);
    box-shadow: 0 0 6px rgba(200, 64, 58, 0.5);
}

.status-bar-stress .status-fill {
    background: linear-gradient(90deg, var(--ds-amber), #E07060);
    box-shadow: 0 0 6px rgba(220, 141, 24, 0.5);
}

.status-fill {
    position: absolute;
    inset: 0;
    width: 50%;
    transition: width 0.6s ease;
}

.status-segments {
    position: absolute;
    inset: 1px;
    display: flex;
    gap: 1px;
}

.status-seg {
    flex: 1;
    background: rgba(95, 180, 201, 0.15);
    border-right: none;
    transition: background 0.3s;
}
.status-seg.on {
    background: var(--accent);
    box-shadow: 0 0 4px var(--accent);
}

.status-text, .status-num {
    font-size: 9px;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.5px;
    white-space: nowrap;
    font-weight: 500;
}

.status-cell[data-stat="will"] .status-num { color: var(--ds-gold-ds); text-shadow: 0 0 4px rgba(244, 209, 54, 0.4); }
.status-cell[data-stat="links"] .status-num { color: var(--ds-gold-ds); }

@media (max-width: 480px) {
    .status-hud { padding: 6px 8px; padding-bottom: calc(6px + env(safe-area-inset-bottom, 0)); gap: 0; }
    .status-cell { padding: 4px 6px; gap: 4px; }
    .status-bar { max-width: 50px; }
    .status-icon { width: 14px; height: 14px; font-size: 11px; }
    .status-text, .status-num { font-size: 8px; }
}

/* (padding для .app задан выше — учитывает status-hud сверху + nav снизу) */

/* ===== CORNER TICKS — DS decorative ===== */
.corner-tick {
    position: fixed;
    width: 20px;
    height: 20px;
    pointer-events: none;
    z-index: 70;
    opacity: 0.4;
}
.corner-tick.tl { top: 44px; left: 6px; border-top: 1px solid var(--accent); border-left: 1px solid var(--accent); }
.corner-tick.tr { top: 44px; right: 6px; border-top: 1px solid var(--accent); border-right: 1px solid var(--accent); }
.corner-tick.bl { bottom: 64px; left: 6px; border-bottom: 1px solid var(--accent); border-left: 1px solid var(--accent); }
.corner-tick.br { bottom: 64px; right: 6px; border-bottom: 1px solid var(--accent); border-right: 1px solid var(--accent); }

.frame-line {
    position: fixed;
    pointer-events: none;
    z-index: 70;
    opacity: 0.3;
}
.frame-line.frame-top { display: none; }

/* === flash при закрытии дня — оранжевая amber-вспышка === */
.level-up-flash.day-closed {
    background: radial-gradient(circle at center,
        rgba(244, 209, 54, 0.55) 0%,
        rgba(220, 141, 24, 0.35) 30%,
        rgba(95, 180, 201, 0.15) 60%,
        transparent 80%);
}


/* === стодневка === */
.hundred-progress { padding: 4px 0 0; }

.hundred-bar {
    height: 10px;
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    overflow: hidden;
    margin-bottom: 8px;
    position: relative;
}

.hundred-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--accent), var(--neon-cyan));
    box-shadow: 0 0 8px var(--accent);
    transition: width 0.4s;
    border-radius: 5px;
}

.hundred-meta, .hundred-meta-2 {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    color: var(--text-secondary);
    font-family: 'JetBrains Mono', monospace;
}
.hundred-meta-2 {
    font-size: 12px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}

/* сетка 10×10 для стодневки */
.hundred-grid {
    display: grid;
    grid-template-columns: repeat(20, 1fr);
    gap: 3px;
    margin: 8px 0;
}

.hundred-day {
    aspect-ratio: 1;
    background: var(--cal-level-0-bg);
    border: 1px solid var(--cal-level-0-border);
    border-radius: 2px;
    transition: all 0.15s;
    cursor: pointer;
}
.hundred-day.l1 { background: var(--cal-level-1); border-color: transparent; }
.hundred-day.l2 { background: var(--cal-level-2); border-color: transparent; }
.hundred-day.l3 { background: var(--cal-level-3); border-color: transparent; }
.hundred-day.l4 { background: var(--cal-level-4); border-color: transparent; box-shadow: 0 0 4px var(--cal-level-4); }
.hundred-day.current { outline: 2px solid var(--ds-amber); outline-offset: 1px; animation: pulseGlow 2s infinite; z-index: 2; }
.hundred-day.future { opacity: 0.3; }

/* саммари стодневки */
.hundred-summary {
    display: flex;
    gap: 14px;
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
    font-size: 11px;
    font-family: 'JetBrains Mono', monospace;
    letter-spacing: 0.5px;
    flex-wrap: wrap;
    justify-content: space-around;
}
.hs-closed { color: var(--accent); }
.hs-missed { color: var(--ds-amber); }
.hs-streak { color: var(--ds-gold-ds); text-shadow: 0 0 6px rgba(244, 209, 54, 0.3); }

@keyframes pulseGlow {
    0%, 100% { box-shadow: 0 0 4px var(--ds-amber); }
    50% { box-shadow: 0 0 14px var(--ds-amber); }
}

/* ===== ВЕКТОРЫ СЕГОДНЯ ===== */
.vectors-today {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
}

.vector-cell {
    aspect-ratio: 1;
    background: var(--bg-card-hover);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    overflow: hidden;
}

.vector-cell::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 0%, var(--v-color, var(--accent)) 100%);
    opacity: 0;
    transition: opacity 0.2s;
}

.vector-cell:hover::before { opacity: 0.1; }

.vector-cell.completed {
    background: var(--bg-card);
    border-color: var(--v-color);
    box-shadow: 0 0 12px var(--v-color), inset 0 0 12px rgba(255, 255, 255, 0.03);
}

.vector-cell.completed::after {
    content: '✓';
    position: absolute;
    top: 3px; right: 5px;
    font-size: 10px;
    color: var(--v-color);
    font-weight: 700;
}

.vector-emoji {
    width: 26px; height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
    color: var(--v-color, var(--accent));
}
.vector-emoji svg { width: 100%; height: 100%; display: block; }
.vector-name { font-size: 9px; color: var(--text-secondary); letter-spacing: 1px; position: relative; z-index: 1; text-transform: uppercase; }

/* === быстрые кнопки — DS terminal style === */
.quick-btn {
    flex: 1;
    background: transparent;
    border: 1px solid var(--border-color);
    border-bottom: 1px solid var(--accent);
    color: var(--text-primary);
    padding: 14px 8px;
    border-radius: 0;
    font-family: inherit;
    cursor: pointer;
    transition: all 0.2s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    position: relative;
}

.quick-btn:hover {
    border-color: var(--accent);
    background: rgba(95, 180, 201, 0.06);
    color: var(--accent);
}

.quick-icon { width: 22px; height: 22px; color: var(--accent); display: inline-flex; align-items: center; justify-content: center; }
.quick-icon svg { width: 100%; height: 100%; display: block; }
.quick-label { font-size: 9px; letter-spacing: 2px; font-weight: 400; text-transform: uppercase; }

/* tv-icon — мелкая SVG-иконка вектора рядом с текстом */
.tv-icon {
    width: 12px; height: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 4px;
    vertical-align: -2px;
}
.tv-icon svg { width: 100%; height: 100%; display: block; }

.task-vector-badge { display: inline-flex; align-items: center; }
.bt-vec { display: inline-flex; align-items: center; }

/* === inputs / select / buttons — DS terminal style === */
.input, .select {
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-light);
    color: var(--text-primary);
    padding: 10px 12px;
    border-radius: 0;
    font-family: inherit;
    font-size: 13px;
    outline: none;
    transition: border-color 0.2s;
    min-width: 0;
    letter-spacing: 0.3px;
}

.input::placeholder { color: var(--text-muted); letter-spacing: 0.5px; }
.input:focus, .select:focus { border-color: var(--accent); border-bottom-color: var(--accent); box-shadow: 0 1px 0 var(--accent); }

.input-num { max-width: 80px; text-align: center; }
.input-emoji { max-width: 56px; text-align: center; font-size: 22px; padding: 6px; }
.input-date { max-width: 140px; }

.select { cursor: pointer; padding-right: 30px; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%235FB4C9' d='M6 9L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; }
select option { background: var(--bg-card); color: var(--text-primary); }

.btn-primary {
    background: transparent;
    color: var(--accent);
    border: 1px solid var(--accent);
    padding: 10px 18px;
    border-radius: 0;
    font-family: inherit;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.18s;
    min-width: 44px;
    position: relative;
}

.btn-primary:hover {
    background: rgba(95, 180, 201, 0.12);
    box-shadow: 0 0 12px rgba(95, 180, 201, 0.3), inset 0 0 0 1px rgba(95, 180, 201, 0.2);
    color: var(--accent-light);
}
.btn-primary:active { transform: translateY(1px); }

.btn-mini {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    width: 28px;
    height: 28px;
    padding: 0;
    border-radius: 0;
    font-size: 14px;
    cursor: pointer;
}
.btn-mini:hover { border-color: var(--accent); color: var(--accent); }

/* === task / habit input rows === */
.task-input-row, .habit-input-row {
    display: flex;
    gap: 6px;
    margin-bottom: 8px;
}
.task-input-row .input, .habit-input-row .input { flex: 1; }

.task-meta-row, .habit-meta-row {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.task-meta-row .select, .habit-meta-row .select { flex: 1; min-width: 0; }

/* ===== PROJECTS STRIP (Things 3 Areas) ===== */
.projects-strip {
    display: flex;
    gap: 4px;
    overflow-x: auto;
    scrollbar-width: none;
    padding: 4px 0 8px;
    margin-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}
.projects-strip::-webkit-scrollbar { display: none; }

.project-chip {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: transparent;
    border: 1px solid var(--border-color);
    border-radius: 0;
    color: var(--text-secondary);
    font-family: inherit;
    font-size: 11px;
    letter-spacing: 0.8px;
    cursor: pointer;
    transition: all 0.18s;
    white-space: nowrap;
    flex-shrink: 0;
}
.project-chip:hover { color: var(--text-primary); border-color: var(--border-light); }

.project-chip.active {
    background: rgba(95, 180, 201, 0.1);
    border-color: var(--project-color, var(--accent));
    color: var(--project-color, var(--accent));
    box-shadow: inset 0 -2px 0 var(--project-color, var(--accent));
}

.project-chip-emoji { font-size: 13px; line-height: 1; }
.project-chip-count {
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    padding: 1px 6px;
    font-size: 9px;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.5px;
}
.project-chip.active .project-chip-count { color: var(--project-color, var(--accent)); border-color: var(--project-color, var(--accent)); }

.project-chip-add {
    padding: 6px 10px;
    color: var(--text-muted);
    border-style: dashed;
}
.project-chip-add:hover { color: var(--accent); border-color: var(--accent); border-style: solid; }

/* ===== PROJECT BANNER ===== */
.project-banner {
    position: relative;
    border: 1px solid var(--border-color);
    margin-bottom: 12px;
    overflow: hidden;
    aspect-ratio: 5 / 1;
    min-height: 80px;
}

.project-banner-img {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.55) saturate(0.8);
}

.project-banner.no-image .project-banner-img {
    background: linear-gradient(135deg, var(--project-color, var(--accent)) 0%, transparent 80%), repeating-linear-gradient(45deg, transparent 0 14px, rgba(95,180,201,0.08) 14px 16px);
    filter: none;
    opacity: 0.18;
}

.project-banner-info {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    z-index: 1;
}

.project-banner-name {
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 2px;
    color: var(--text-primary);
    text-transform: uppercase;
    text-shadow: 0 2px 8px rgba(0,0,0,0.6);
}

.project-banner-actions {
    display: flex;
    gap: 4px;
}

.btn-mini-del:hover { color: var(--danger); border-color: var(--danger); }

.btn-mini > input[type="file"] { display: none; }

/* ===== BOARD VIEW (Kanban — конфигурируемые колонки + drag&drop) ===== */
.board {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
    overflow-x: auto;
    scrollbar-width: thin;
    padding-bottom: 6px;
    align-items: flex-start;
}

.board-col {
    flex: 0 0 240px;
    background: rgba(14, 20, 25, 0.5);
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--col-color, var(--accent));
    min-height: 200px;
    padding: 10px 8px 8px;
    position: relative;
    transition: background 0.15s, border-color 0.15s;
}
.board-col.is-done {
    background: rgba(34, 197, 94, 0.04);
}
.board-col.drag-over {
    background: rgba(var(--accent-rgb), 0.10);
    border-color: var(--col-color, var(--accent));
    box-shadow: 0 0 12px -2px var(--col-color, var(--accent));
}

.board-col-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 6px;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px dashed var(--border-color);
}

.board-col-title {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 2px;
    color: var(--col-color, var(--accent));
    text-transform: uppercase;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.board-col-done {
    color: var(--col-color, var(--accent));
    margin-left: 4px;
    font-size: 11px;
}

.board-col-count {
    font-size: 10px;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
}

.board-col-menu {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 14px;
    padding: 0 4px;
    line-height: 1;
}
.board-col-menu:hover { color: var(--col-color, var(--accent)); }

.board-col-list {
    min-height: 40px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.board-col-empty {
    color: var(--text-muted);
    font-size: 10px;
    text-align: center;
    padding: 10px 0;
    letter-spacing: 1px;
}

.board-col-add {
    width: 100%;
    margin-top: 8px;
    background: transparent;
    border: 1px dashed var(--border-color);
    color: var(--text-muted);
    padding: 6px;
    font-family: inherit;
    font-size: 10px;
    letter-spacing: 1px;
    cursor: pointer;
    text-transform: uppercase;
    transition: all 0.15s;
}
.board-col-add:hover {
    border-color: var(--col-color, var(--accent));
    color: var(--col-color, var(--accent));
}

.board-col-ghost {
    flex: 0 0 160px;
    background: transparent;
    border: 1px dashed var(--border-color);
    color: var(--text-muted);
    cursor: pointer;
    font-family: inherit;
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: all 0.15s;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.board-col-ghost:hover { border-color: var(--accent); color: var(--accent); }

.board-task {
    position: relative;
    background: rgba(20, 25, 31, 0.7);
    border: 1px solid var(--border-color);
    border-left: 2px solid var(--col-color, var(--accent));
    padding: 0;
    font-size: 11px;
    color: var(--text-primary);
    cursor: grab;
    transition: all 0.15s;
    line-height: 1.4;
    user-select: none;
    overflow: hidden;
}
.board-task:active { cursor: grabbing; }
.board-task.dragging {
    opacity: 0.4;
    transform: rotate(-1deg);
}
.board-task:hover {
    border-color: var(--col-color, var(--accent));
    background: rgba(95, 180, 201, 0.06);
}
.board-task.completed { opacity: 0.55; }
.board-task.completed .bt-title { text-decoration: line-through; }
.board-task.priority-high { border-left-width: 3px; }
.board-task.priority-crit {
    border-left-width: 3px;
    border-left-color: #ef4444;
}

.board-task .bt-body { padding: 8px 10px; }
.board-task .bt-title { word-break: break-word; }
.board-task .bt-meta {
    font-size: 9px;
    color: var(--text-muted);
    margin-top: 4px;
    letter-spacing: 0.5px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
}
.board-task .bt-xp { color: var(--accent); }

/* === COVER (фото к задаче) === */
.board-task .bt-cover {
    position: relative;
    width: 100%;
    height: 72px;
    background-size: cover;
    background-position: center;
    background-color: var(--bg-input);
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
}
.board-task .bt-cover-count {
    position: absolute;
    bottom: 4px;
    right: 4px;
    background: rgba(14, 20, 25, 0.85);
    color: var(--text-primary);
    font-size: 9px;
    padding: 2px 5px;
    letter-spacing: 0.5px;
    border: 1px solid var(--border-warm);
    backdrop-filter: blur(4px);
}

/* === PAPERCLIP (прикрепить фото) === */
.board-task .bt-attach {
    position: absolute;
    top: 4px;
    right: 4px;
    background: rgba(14, 20, 25, 0.75);
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    font-size: 11px;
    line-height: 1;
    padding: 3px 5px;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.15s, color 0.15s, border-color 0.15s;
    backdrop-filter: blur(4px);
    z-index: 2;
}
.board-task:hover .bt-attach,
.board-task .bt-cover + .bt-body + .bt-attach,
.board-task .bt-attach:focus {
    opacity: 1;
}
.board-task .bt-attach:hover {
    color: var(--accent);
    border-color: var(--accent);
}
/* на тач-устройствах paperclip всегда видна (нет :hover) */
@media (hover: none) {
    .board-task .bt-attach { opacity: 0.7; }
}

.board-task .bt-photo-count {
    color: var(--accent-light);
}

@media (max-width: 480px) {
    .board-col { flex: 0 0 80vw; }
    .board-col-ghost { flex: 0 0 60vw; }
}

/* filter-bar удалён — функции перенесены в .mainview-nav (магистральные виды) */

/* ===== TASKS — DS cargo row style ===== */
.task-item {
    background: rgba(20, 25, 31, 0.5);
    border: 1px solid var(--border-color);
    border-left: 2px solid var(--accent);
    border-radius: 0;
    padding: 12px 14px;
    margin-bottom: 4px;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all 0.18s;
}

.task-item:hover { background: rgba(95, 180, 201, 0.06); border-color: var(--accent); }

.task-item.priority-low { border-left-color: var(--text-muted); }
.task-item.priority-med { border-left-color: var(--accent); }
.task-item.priority-high { border-left-color: var(--ds-amber); }
.task-item.priority-crit { border-left-color: var(--danger); box-shadow: 0 0 8px rgba(200, 64, 58, 0.2); }

.task-item.completed { opacity: 0.5; }
.task-item.completed .task-title { text-decoration: line-through; }

.task-check {
    width: 18px; height: 18px;
    border: 1px solid var(--border-light);
    border-radius: 0;
    background: rgba(14, 20, 25, 0.7);
    cursor: pointer;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.18s;
}

.task-check:hover { border-color: var(--accent); }
.task-check.checked { background: var(--accent); border-color: var(--accent); box-shadow: 0 0 8px rgba(95, 180, 201, 0.5); }
.task-check.checked::after { content: '✓'; color: var(--ds-bg-deep); font-weight: 700; font-size: 12px; }

.task-body { flex: 1; min-width: 0; }
.task-title { font-size: 13px; color: var(--text-primary); letter-spacing: 0.2px; }
.task-meta { font-size: 10px; color: var(--text-secondary); margin-top: 4px; display: flex; gap: 8px; align-items: center; letter-spacing: 0.5px; }
.task-vector-badge {
    padding: 2px 8px;
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    border-radius: 0;
    font-size: 9px;
    font-weight: 400;
    letter-spacing: 0.8px;
    text-transform: uppercase;
}
.task-xp {
    color: var(--accent);
    font-weight: 500;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.3px;
}

.task-delete {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 6px 10px;
    font-size: 14px;
    transition: color 0.2s;
}
.task-delete:hover { color: var(--danger); }

/* ===== HABITS — DS panel ===== */
.habit-item {
    background: rgba(20, 25, 31, 0.6);
    border: 1px solid var(--border-color);
    border-radius: 0;
    padding: 14px 16px;
    margin-bottom: 6px;
    transition: border-color 0.2s;
}
.habit-item:hover { border-color: var(--border-light); }

.habit-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.habit-emoji-big {
    font-size: 22px;
    width: 40px; height: 40px;
    background: rgba(14, 20, 25, 0.8);
    border: 1px solid var(--border-color);
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--accent);
}
.habit-emoji-big svg { width: 60%; height: 60%; }

.habit-info { flex: 1; min-width: 0; }
.habit-name { font-size: 13px; font-weight: 400; color: var(--text-primary); letter-spacing: 0.3px; }
.habit-stats { font-size: 10px; color: var(--text-secondary); margin-top: 3px; letter-spacing: 0.5px; text-transform: uppercase; }

.habit-streak {
    text-align: center;
    padding: 6px 12px;
    background: rgba(14, 20, 25, 0.7);
    border: 1px solid var(--accent);
    border-radius: 0;
    color: var(--accent);
    box-shadow: inset 0 0 8px rgba(95, 180, 201, 0.08);
}

.habit-streak-num {
    font-weight: 500;
    font-size: 18px;
    line-height: 1;
    display: block;
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.5px;
}
.habit-streak-label { font-size: 8px; color: var(--text-secondary); letter-spacing: 1.2px; text-transform: uppercase; }

.habit-actions {
    display: flex;
    gap: 6px;
    margin-left: 6px;
}

.habit-today-btn {
    background: transparent;
    border: 1px solid var(--accent);
    color: var(--accent);
    padding: 10px 14px;
    border-radius: 0;
    font-family: inherit;
    font-size: 11px;
    cursor: pointer;
    font-weight: 500;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: all 0.18s;
}

.habit-today-btn:hover {
    background: rgba(95, 180, 201, 0.12);
    box-shadow: 0 0 10px rgba(95, 180, 201, 0.3);
}

.habit-today-btn.done {
    background: var(--accent);
    color: var(--ds-bg-deep);
    box-shadow: 0 0 12px rgba(95, 180, 201, 0.4);
    border-color: var(--accent);
}

.habit-today-btn:active { transform: translateY(1px); }

.habit-delete {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-muted);
    width: 32px;
    height: 32px;
    border-radius: 0;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.18s;
}
.habit-delete:hover { color: var(--danger); border-color: var(--danger); }

/* === HEATMAP по привычке (мини, годовой = в статистике) === */
.habit-heatmap {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(14px, 1fr));
    gap: 3px;
    padding-top: 8px;
    border-top: 1px solid var(--border-color);
    margin-top: 12px;
}

.heatmap-cell {
    aspect-ratio: 1;
    background: var(--cal-level-0-bg);
    border: 1px solid var(--cal-level-0-border);
    border-radius: 3px;
    cursor: pointer;
    transition: transform 0.15s;
}
.heatmap-cell:hover { transform: scale(1.4); z-index: 2; }
.heatmap-cell.l1 { background: var(--cal-level-1); border-color: transparent; }
.heatmap-cell.l2 { background: var(--cal-level-2); border-color: transparent; }
.heatmap-cell.l3 { background: var(--cal-level-3); border-color: transparent; }
.heatmap-cell.l4 { background: var(--cal-level-4); border-color: transparent; }
.heatmap-cell.today { outline: 2px solid var(--accent); outline-offset: 1px; }
.heatmap-cell.future { opacity: 0.25; }

/* ===== СТАТИСТИКА ===== */
.stat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 12px;
}

.stat-cell {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 8px;
    text-align: center;
}

.stat-cell .stat-label {
    font-size: 9px;
    color: var(--text-secondary);
    letter-spacing: 0.8px;
    text-transform: uppercase;
    margin-bottom: 6px;
}

.stat-cell .stat-value {
    font-family: 'JetBrains Mono', monospace;
    font-weight: 700;
    font-size: 22px;
    color: var(--text-primary);
    letter-spacing: -0.5px;
}

/* === CHART === */
.chart-container {
    height: 130px;
    display: flex;
    align-items: flex-end;
    gap: 3px;
    padding: 10px 0;
}

.chart-bar {
    flex: 1;
    background: var(--cal-level-2);
    border-radius: 3px 3px 0 0;
    min-height: 2px;
    position: relative;
    transition: all 0.3s;
    cursor: pointer;
}

.chart-bar:hover {
    background: var(--cal-level-4);
    box-shadow: 0 0 8px var(--cal-level-4);
}

.chart-bar.today { background: var(--accent); box-shadow: 0 0 8px var(--accent); }

/* === векторы статистика === */
.vector-stat-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
}
.vector-stat-row:last-child { border-bottom: none; }

.vector-stat-emoji { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vector-stat-emoji svg { width: 100%; height: 100%; display: block; }
.vector-stat-name { font-size: 12px; width: 90px; color: var(--text-primary); }

.vector-stat-bar {
    flex: 1;
    height: 6px;
    background: var(--bg-input);
    border-radius: 3px;
    overflow: hidden;
}

.vector-stat-fill {
    height: 100%;
    background: var(--v-color, var(--accent));
    box-shadow: 0 0 6px var(--v-color, var(--accent));
    transition: width 0.4s;
    border-radius: 3px;
}

.vector-stat-value {
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 600;
    font-family: 'JetBrains Mono', monospace;
    width: 56px;
    text-align: right;
}

/* === heatmap годовой (как GitHub в гиревой) === */
.heatmap-yearly {
    display: grid;
    grid-template-columns: repeat(53, 1fr);
    gap: 2px;
    padding-top: 4px;
    overflow-x: auto;
    scrollbar-width: none;
}
.heatmap-yearly::-webkit-scrollbar { display: none; }
.heatmap-yearly .heatmap-cell { min-width: 8px; }

/* === ACHIEVEMENTS (золото + glow) === */
.achievements-recent {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 4px 0;
    scrollbar-width: none;
}
.achievements-recent::-webkit-scrollbar { display: none; }

.achievement-recent {
    flex-shrink: 0;
    padding: 8px 12px;
    background: var(--bg-card-hover);
    border: 1px solid var(--gold);
    border-radius: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 0 8px rgba(251, 191, 36, 0.25);
}

.achievement-recent-icon { font-size: 20px; }
.achievement-recent-name {
    font-size: 11px;
    color: var(--gold);
    font-weight: 600;
    letter-spacing: 0.3px;
}

.achievements-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 8px;
}

.achievement {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 12px 8px;
    text-align: center;
    transition: all 0.2s;
}

.achievement.unlocked {
    border-color: var(--gold);
    background: var(--bg-card-hover);
    box-shadow: 0 0 12px rgba(251, 191, 36, 0.15);
}

.achievement.locked {
    opacity: 0.35;
    filter: grayscale(0.9);
}

.achievement-icon { font-size: 28px; margin-bottom: 6px; line-height: 1; }
.achievement-name { font-size: 11px; font-weight: 600; color: var(--text-primary); margin-bottom: 3px; line-height: 1.2; }
.achievement-desc { font-size: 9px; color: var(--text-secondary); line-height: 1.3; }

/* === MAP (карта персонажа — SVG с векторами в круг) === */
.map-container {
    aspect-ratio: 1;
    max-width: 480px;
    margin: 0 auto;
    padding: 8px;
}
#map-svg { width: 100%; height: 100%; display: block; }

.map-node-circle { transition: all 0.3s; cursor: pointer; }
.map-node-circle:hover { filter: brightness(1.35); }

.map-line { animation: dash 60s linear infinite; }
@keyframes dash { to { stroke-dashoffset: -200; } }

.vector-detail {
    background: var(--bg-card-hover);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 14px;
    margin-top: 10px;
}

.vector-detail-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

.vector-detail-emoji { width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center; }
.vector-detail-emoji svg { width: 100%; height: 100%; display: block; }
.vector-detail-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--v-color, var(--accent));
}

.vector-detail-row {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    padding: 4px 0;
    color: var(--text-secondary);
}
.vector-detail-row .v { color: var(--text-primary); font-weight: 600; font-family: 'JetBrains Mono', monospace; }

/* === GOALS === */
.goal-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-left: 3px solid var(--accent);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    gap: 12px;
}

.goal-item.completed { opacity: 0.5; }
.goal-item.completed .goal-title { text-decoration: line-through; }

.goal-title { flex: 1; font-size: 13px; color: var(--text-primary); }

.big-vector-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--border-color);
    border-radius: 12px;
    margin-bottom: 8px;
    background: var(--bg-card-hover);
}

.big-vector-num {
    font-family: 'JetBrains Mono', monospace;
    color: var(--accent);
    font-weight: 700;
    width: 28px;
    text-align: center;
    font-size: 18px;
}

.big-vector-content { flex: 1; }
.big-vector-title { font-size: 13px; color: var(--text-primary); font-weight: 500; }
.big-vector-sub { font-size: 11px; color: var(--text-secondary); margin-top: 2px; }

/* === MODAL === */
.modal {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.modal-content {
    position: relative;
    background: var(--bg-card);
    border: 1px solid var(--accent);
    border-radius: 16px;
    max-width: 460px;
    width: 100%;
    max-height: 80vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 0 24px rgba(34, 197, 94, 0.15);
}

.modal-header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.modal-title {
    font-size: 13px;
    color: var(--accent);
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 700;
}

.modal-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 24px;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}

.modal-body {
    padding: 16px;
    overflow-y: auto;
    font-size: 13px;
    color: var(--text-primary);
}

/* === TOAST (liquid glass) === */
.toast {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(30, 30, 30, 0.55);
    backdrop-filter: blur(25px) saturate(1.4);
    -webkit-backdrop-filter: blur(25px) saturate(1.4);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 999px;
    padding: 10px 18px;
    color: var(--accent);
    font-size: 13px;
    font-weight: 600;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06), 0 4px 20px rgba(0, 0, 0, 0.4);
    z-index: var(--z-toast);
    animation: toastIn 0.3s ease;
    max-width: 90%;
}

@keyframes toastIn {
    from { opacity: 0; transform: translate(-50%, 20px); }
    to { opacity: 1; transform: translate(-50%, 0); }
}

.toast.gold { color: var(--gold); border-color: rgba(251, 191, 36, 0.35); }
.toast.error { color: var(--danger); border-color: rgba(239, 68, 68, 0.35); }

/* Плашка "офлайн режим" — стекло с янтарным акцентом (как в гиревой) */
.toast.offline {
    background: rgba(245, 158, 11, 0.16);
    border-color: rgba(245, 158, 11, 0.35);
    color: #f59e0b;
}

/* === misc === */
.muted { color: var(--text-muted); font-size: 12px; }
.mono { font-family: 'JetBrains Mono', monospace; }
.accent-cyan { color: var(--accent); }
.safe-bottom { height: env(safe-area-inset-bottom, 12px); }

.empty-state {
    text-align: center;
    padding: 24px 16px;
    color: var(--text-secondary);
    font-size: 12px;
}

.empty-state-icon { font-size: 32px; margin-bottom: 8px; opacity: 0.5; }

/* === level up animation === */
.level-up-flash {
    position: fixed; inset: 0;
    background: radial-gradient(circle at center, rgba(34, 197, 94, 0.4) 0%, transparent 70%);
    z-index: var(--z-toast);
    pointer-events: none;
    animation: levelUpFlash 1.2s ease-out forwards;
}
@keyframes levelUpFlash {
    0% { opacity: 0; transform: scale(0.5); }
    30% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(1.5); }
}

/* === tap flash (вектор / привычка) — короткая цветная вспышка на весь экран === */
.tap-flash {
    position: fixed; inset: 0;
    background: radial-gradient(circle at center,
        var(--flash-color, rgba(95, 180, 201, 0.45)) 0%,
        transparent 65%);
    z-index: var(--z-toast);
    pointer-events: none;
    animation: tapFlash 0.55s ease-out forwards;
}
@keyframes tapFlash {
    0% { opacity: 0; transform: scale(0.7); }
    25% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(1.2); }
}

/* === LARGE SCREENS === */
@media (max-width: 380px) {
    .hud { flex-direction: column; align-items: stretch; gap: 10px; }
    .hud-right { gap: 8px; justify-content: space-between; }
    .stat-grid { grid-template-columns: repeat(2, 1fr); }
    .nav-btn { min-width: 56px; padding: 8px 4px; }
    .vector-emoji { font-size: 16px; }
    .quick-icon { font-size: 18px; }
    .hundred-grid { grid-template-columns: repeat(10, 1fr); }
}

/* ============================================================
   THINGS-3-INSPIRED LAYOUT
   ============================================================ */

/* === MAINVIEW NAV (Today / Upcoming / Projects) === */
.mainview-nav {
    display: flex;
    gap: 4px;
    margin-bottom: 12px;
    background: rgba(14, 20, 25, 0.55);
    border: 1px solid var(--border-color);
    padding: 4px;
}
.mainview-btn {
    flex: 1;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-secondary);
    padding: 8px 6px;
    font-family: inherit;
    font-size: 10px;
    letter-spacing: 1.5px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    text-transform: uppercase;
    transition: all 0.15s;
}
.mainview-btn:hover { color: var(--accent); }
.mainview-btn.active {
    background: rgba(var(--accent-rgb), 0.10);
    border-color: var(--accent);
    color: var(--accent);
    box-shadow: inset 0 -2px 0 var(--accent);
}
.mainview-icon { font-size: 13px; opacity: 0.85; }
.mainview-label { font-weight: 500; }
.mainview-count {
    font-size: 9px;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    margin-left: 2px;
    opacity: 0.7;
}
.mainview-btn.active .mainview-count { color: var(--accent); opacity: 1; }

/* === STATUS CIRCLE === */
.status-circle {
    width: 18px; height: 18px;
    border: 1px solid var(--border-light);
    border-radius: 50%;
    background: rgba(14, 20, 25, 0.7);
    cursor: pointer;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.18s;
    padding: 0;
    position: relative;
    color: var(--ds-bg-deep);
    font-size: 11px;
    line-height: 1;
}
.status-circle.status-sm { width: 14px; height: 14px; font-size: 9px; }
.status-circle:hover { border-color: var(--accent); }
.status-circle.status-todo {}
.status-circle.status-doing {
    border-color: var(--accent);
}
.status-circle.status-doing .sc-half {
    width: 100%; height: 100%;
    border-radius: 50%;
    background: conic-gradient(var(--accent) 0deg 180deg, transparent 180deg 360deg);
}
.status-circle.status-done {
    background: var(--accent);
    border-color: var(--accent);
    box-shadow: 0 0 8px rgba(95, 180, 201, 0.4);
}
.status-circle.status-done .sc-glyph { color: var(--ds-bg-deep); font-weight: 700; }
.status-circle.status-cancelled {
    background: transparent;
    border-color: var(--text-muted);
    color: var(--text-muted);
}
.status-circle.status-cancelled .sc-glyph { font-weight: 700; }

.task-check-wrap { display: flex; align-items: center; }

/* === GROUP HEADS (Today/Upcoming/Project sections) === */
.tasks-group-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 4px 6px;
    margin-top: 4px;
    border-bottom: 1px dashed var(--border-color);
    cursor: default;
}
.tasks-group-head .tgh-title {
    font-size: 11px;
    letter-spacing: 2px;
    color: var(--text-secondary);
    text-transform: uppercase;
}
.tasks-group-head .tgh-meta {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 1px;
    font-variant-numeric: tabular-nums;
}
.tasks-group-head.project-group-head {
    cursor: pointer;
    transition: color 0.15s;
}
.tasks-group-head.project-group-head:hover .tgh-title { color: var(--project-color, var(--accent)); }
.tasks-group-head.project-group-head .tgh-title { color: var(--project-color, var(--accent)); }
.tasks-group-head.area-head .tgh-title { color: var(--text-muted); }
.tasks-group-head.tasks-group-done .tgh-title { color: var(--text-muted); opacity: 0.6; }

/* === PROJECTS GRID (для view=projects, группы по area) === */
.projects-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 6px;
    margin: 8px 0 16px;
}
.project-card {
    background: rgba(20, 25, 31, 0.55);
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--project-color, var(--accent));
    padding: 14px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    align-items: flex-start;
    cursor: pointer;
    font-family: inherit;
    color: var(--text-primary);
    text-align: left;
    transition: all 0.15s;
    min-height: 88px;
}
.project-card:hover {
    background: rgba(var(--accent-rgb), 0.05);
    border-color: var(--project-color, var(--accent));
}
.project-card-emoji { font-size: 18px; line-height: 1; }
.project-card-name {
    font-size: 12px;
    letter-spacing: 0.8px;
    color: var(--text-primary);
    text-transform: uppercase;
    word-break: break-word;
}
.project-card-meta {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 1px;
    margin-top: auto;
}
.project-card-add {
    border-top-color: var(--text-muted);
    color: var(--text-muted);
    align-items: center;
    justify-content: center;
    border-style: dashed;
}
.project-card-add:hover { color: var(--accent); border-color: var(--accent); }
.add-project-row { margin-top: 8px; }

/* === TAG CHIPS === */
.task-tags, .bt-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}
.tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 6px;
    background: rgba(95, 180, 201, 0.08);
    border: 1px solid rgba(95, 180, 201, 0.25);
    color: var(--accent-light);
    font-size: 9px;
    letter-spacing: 0.5px;
    text-transform: lowercase;
    line-height: 1.3;
}
.tag-chip-sm { font-size: 8px; padding: 1px 5px; }
.tag-chip-removable {
    cursor: pointer;
    transition: background 0.15s;
    font-family: inherit;
}
.tag-chip-removable:hover { background: rgba(200, 64, 58, 0.15); border-color: var(--danger); color: var(--danger); }
.tag-x { font-weight: 700; opacity: 0.6; }

/* === BADGES (subtasks/photos count in cards) === */
.task-badge, .bt-badge {
    color: var(--text-muted);
    font-size: 9px;
    letter-spacing: 0.5px;
}

/* ============================================================
   TASK MODAL
   ============================================================ */
.task-modal {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    display: none;
    align-items: stretch;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.15s;
}
.task-modal.open { opacity: 1; }
.task-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.task-modal-content {
    position: relative;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--border-warm);
    width: 100%;
    max-width: 520px;
    margin: auto;
    max-height: 92vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    box-shadow: 0 12px 60px rgba(0, 0, 0, 0.5);
    transform: translateY(8px);
    transition: transform 0.18s;
}
.task-modal.open .task-modal-content { transform: translateY(0); }

.task-modal-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 14px 12px;
    border-bottom: 1px dashed var(--border-color);
}
.tm-status-wrap { display: flex; align-items: center; padding-top: 4px; }
.tm-title {
    flex: 1;
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-family: inherit;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.3px;
    outline: none;
    padding: 4px 0;
}
.tm-title::placeholder { color: var(--text-muted); }
.tm-close {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
    padding: 0 4px;
}
.tm-close:hover { color: var(--danger); }

.task-modal-body {
    padding: 12px 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.tm-tags-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}
.tm-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.tm-tag-input {
    background: transparent;
    border: none;
    border-bottom: 1px dashed var(--border-color);
    color: var(--text-primary);
    font-family: inherit;
    font-size: 11px;
    outline: none;
    padding: 4px 2px;
    min-width: 120px;
    letter-spacing: 0.5px;
}
.tm-tag-input::placeholder { color: var(--text-muted); }
.tm-tag-input:focus { border-bottom-color: var(--accent); }

.tm-desc {
    width: 100%;
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    font-family: inherit;
    font-size: 12px;
    line-height: 1.55;
    padding: 10px 12px;
    min-height: 80px;
    resize: vertical;
    outline: none;
}
.tm-desc::placeholder { color: var(--text-muted); }
.tm-desc:focus { border-color: var(--accent); }

.tm-row { display: flex; gap: 10px; }
.tm-row .tm-field { flex: 1; min-width: 0; }
.tm-field { display: flex; flex-direction: column; gap: 4px; }
.tm-label {
    font-size: 9px;
    letter-spacing: 1.5px;
    color: var(--text-muted);
    text-transform: uppercase;
}

.tm-subtasks-block, .tm-photos-block {
    border-top: 1px dashed var(--border-color);
    padding-top: 12px;
}
.tm-subtasks-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
.tm-sub-progress {
    color: var(--accent);
    font-weight: 500;
    margin-left: 6px;
}
.tm-subtasks {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.tm-subtask {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0;
}
.tm-subtask.done .tm-subtask-title { text-decoration: line-through; color: var(--text-muted); }
.tm-subtask-check {
    width: 14px; height: 14px;
    border: 1px solid var(--border-light);
    border-radius: 50%;
    background: rgba(14, 20, 25, 0.7);
    cursor: pointer;
    flex-shrink: 0;
    transition: all 0.15s;
}
.tm-subtask-check:hover { border-color: var(--accent); }
.tm-subtask-check.checked {
    background: var(--accent);
    border-color: var(--accent);
}
.tm-subtask-title {
    flex: 1;
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-family: inherit;
    font-size: 12px;
    outline: none;
    padding: 2px 0;
    min-width: 0;
}
.tm-subtask-del {
    background: transparent;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0 6px;
    font-size: 14px;
    line-height: 1;
}
.tm-subtask-del:hover { color: var(--danger); }
.tm-subtask-add { margin-top: 6px; }
.tm-subtask-input {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px dashed var(--border-color);
    color: var(--text-primary);
    font-family: inherit;
    font-size: 11px;
    outline: none;
    padding: 4px 0;
    letter-spacing: 0.3px;
}
.tm-subtask-input:focus { border-bottom-color: var(--accent); }
.tm-subtask-input::placeholder { color: var(--text-muted); }

.tm-photos {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(72px, 1fr));
    gap: 6px;
}
.tm-photo {
    position: relative;
    aspect-ratio: 1;
    background-size: cover;
    background-position: center;
    background-color: var(--bg-input);
    border: 1px solid var(--border-color);
}
.tm-photo-x {
    position: absolute;
    top: 2px; right: 2px;
    background: rgba(14, 20, 25, 0.85);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    cursor: pointer;
    font-size: 11px;
    line-height: 1;
    padding: 1px 5px;
}
.tm-photo-x:hover { color: var(--danger); border-color: var(--danger); }

.task-modal-foot {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 14px;
    border-top: 1px dashed var(--border-color);
    background: rgba(14, 20, 25, 0.4);
    position: sticky;
    bottom: 0;
}

/* === смена layout у task-item чтобы влезли теги внизу === */
.task-item {
    align-items: flex-start;
}
.task-item .task-check-wrap { padding-top: 2px; }

/* ============================================================
   ТАЙМЛАЙН (Day-view) — time-blocking, как Apple Cal / Sunsama
   ============================================================ */

.today-layout-toggle {
    display: flex;
    gap: 4px;
    margin-bottom: 10px;
    background: rgba(14, 20, 25, 0.4);
    border: 1px solid var(--border-color);
    padding: 3px;
}
.tlt-btn {
    flex: 1;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-muted);
    padding: 6px 10px;
    font-family: inherit;
    font-size: 10px;
    letter-spacing: 1.5px;
    cursor: pointer;
    text-transform: uppercase;
    transition: all 0.15s;
}
.tlt-btn.active {
    background: rgba(var(--accent-rgb), 0.10);
    border-color: var(--accent);
    color: var(--accent);
}

/* === ПУЛ незапланированных === */
.tl-pool {
    background: rgba(20, 25, 31, 0.5);
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--ds-amber);
    padding: 8px 10px;
    margin-bottom: 12px;
    transition: background 0.15s, border-color 0.15s;
}
.tl-pool.tl-drop-over {
    background: rgba(var(--accent-rgb), 0.10);
    border-color: var(--accent);
    box-shadow: inset 0 0 0 1px var(--accent);
}
.tl-pool-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
    padding-bottom: 6px;
    border-bottom: 1px dashed var(--border-color);
}
.tl-pool-title {
    font-size: 10px;
    letter-spacing: 2px;
    color: var(--ds-amber);
    text-transform: uppercase;
}
.tl-pool-count {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 1px;
    font-variant-numeric: tabular-nums;
}
.tl-pool-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.tl-pool-empty {
    color: var(--text-muted);
    font-size: 10px;
    letter-spacing: 1px;
    padding: 8px 0;
    width: 100%;
    text-align: center;
}
.tl-pool-card {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    border-left: 2px solid var(--accent);
    padding: 6px 10px;
    font-size: 11px;
    color: var(--text-primary);
    cursor: grab;
    user-select: none;
    transition: all 0.15s;
    max-width: 100%;
}
.tl-pool-card:active { cursor: grabbing; }
.tl-pool-card:hover { background: rgba(var(--accent-rgb), 0.08); }
.tl-pool-card.priority-high { border-left-color: var(--ds-amber); }
.tl-pool-card.priority-crit { border-left-color: var(--danger); }
.tl-pool-card.priority-low { border-left-color: var(--text-muted); }
.tl-pool-emoji { width: 14px; display: inline-flex; align-items: center; justify-content: center; }
.tl-pool-emoji svg { width: 12px; height: 12px; }
.tl-pool-title-text {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 220px;
}
.tl-pool-dur {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 0.5px;
    font-variant-numeric: tabular-nums;
}

/* === GRID часов === */
.tl-grid {
    position: relative;
    background: rgba(14, 20, 25, 0.4);
    border: 1px solid var(--border-color);
    border-top: 1px solid var(--ds-chiral);
    margin-bottom: 16px;
    overflow: hidden;
    transition: background 0.15s, border-color 0.15s;
}
.tl-grid.tl-drop-over {
    background: rgba(var(--accent-rgb), 0.06);
}
.tl-hour {
    position: absolute;
    left: 0; right: 0;
    border-top: 1px solid rgba(58, 72, 88, 0.4);
    pointer-events: none;
}
.tl-hour:first-child { border-top-color: transparent; }
.tl-hour-label {
    position: absolute;
    left: 6px;
    top: -7px;
    font-size: 9px;
    letter-spacing: 0.8px;
    color: var(--text-muted);
    background: var(--bg-dark);
    padding: 1px 4px;
    font-variant-numeric: tabular-nums;
}

/* === БЛОКИ задач на сетке === */
.tl-block {
    position: absolute;
    background: rgba(20, 25, 31, 0.92);
    border: 1px solid var(--border-color);
    border-left: 2px solid var(--block-color, var(--accent));
    padding: 4px 8px 6px;
    cursor: grab;
    overflow: hidden;
    transition: box-shadow 0.15s, border-color 0.15s;
    user-select: none;
    min-height: 22px;
}
.tl-block:hover {
    border-color: var(--block-color, var(--accent));
    box-shadow: 0 0 8px -2px var(--block-color, var(--accent));
    z-index: 2;
}
.tl-block:active { cursor: grabbing; }
.tl-block.completed { opacity: 0.55; }
.tl-block.completed .tl-block-title { text-decoration: line-through; }
.tl-block.priority-high { border-left-width: 3px; }
.tl-block.priority-crit { border-left-width: 3px; border-left-color: var(--danger); }
.tl-block.priority-low  { border-left-color: var(--text-muted); }

.tl-block-time {
    font-size: 8px;
    letter-spacing: 0.8px;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
}
.tl-block-title {
    font-size: 11px;
    color: var(--text-primary);
    line-height: 1.3;
    margin-top: 1px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.tl-block-status {
    position: absolute;
    top: 4px;
    right: 4px;
    z-index: 1;
}
.tl-block-resize {
    position: absolute;
    left: 0; right: 0;
    bottom: 0;
    height: 6px;
    cursor: ns-resize;
    background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.04));
}
.tl-block-resize:hover {
    background: rgba(var(--accent-rgb), 0.20);
}

/* === NOW LINE (Apple Cal style: pill-time слева + точка + линия) === */
.tl-now-line {
    position: absolute;
    left: 0; right: 0;
    height: 0;
    border-top: 1.5px solid var(--danger);
    z-index: 3;
    pointer-events: none;
    box-shadow: 0 0 8px rgba(200, 64, 58, 0.45);
}
.tl-now-line::before {
    content: attr(data-label);
    position: absolute;
    left: 2px;
    top: -10px;
    background: var(--danger);
    color: #fff;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3px;
    padding: 2px 7px;
    border-radius: 11px;
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
.tl-now-line::after {
    content: '';
    position: absolute;
    left: 38px;
    top: -5px;
    width: 8px; height: 8px;
    background: var(--danger);
    border-radius: 50%;
    box-shadow: 0 0 6px var(--danger);
}

/* === GHOST при drag (Apple-style: компактная карточка с лёгким наклоном) === */
.tl-ghost {
    transform: rotate(-1.5deg) scale(1.02);
    opacity: 0.92;
    border: 1px solid var(--accent) !important;
    box-shadow: 0 8px 28px rgba(0,0,0,0.55), 0 0 0 1px rgba(var(--accent-rgb), 0.35);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    background: rgba(20, 25, 31, 0.85) !important;
    transition: transform 0.08s;
}
body.tl-dragging { cursor: grabbing; }
body.tl-dragging * { cursor: grabbing !important; }

/* sticky pool — остаётся видимым при scroll по таймлайну */
.tl-pool.tl-pool-sticky {
    position: sticky;
    top: 0;
    z-index: 5;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    background: rgba(14, 20, 25, 0.88);
}

@media (max-width: 480px) {
    .tl-pool-title-text { max-width: 150px; }
    .tl-block-title { font-size: 10px; }
}

/* ============================================================
   КАЛЕНДАРЬ (Apple Cal — Day/Week/Month/Year)
   ============================================================ */

.cal-head {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px dashed var(--border-color);
}
.cal-title-row {
    display: flex;
    align-items: center;
    gap: 6px;
}
.cal-title {
    flex: 1;
    font-size: 13px;
    letter-spacing: 1.5px;
    color: var(--text-primary);
    text-transform: uppercase;
    margin-left: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cal-nav-btn {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    width: 28px; height: 28px;
    padding: 0;
    font-family: inherit;
    font-size: 12px;
    cursor: pointer;
    line-height: 1;
    transition: all 0.15s;
}
.cal-nav-btn:hover { color: var(--accent); border-color: var(--accent); }
.cal-today-btn { color: var(--danger); border-color: var(--danger); }
.cal-today-btn:hover { background: rgba(200, 64, 58, 0.12); }

.cal-sub-nav {
    display: flex;
    gap: 3px;
    background: rgba(14, 20, 25, 0.45);
    border: 1px solid var(--border-color);
    padding: 3px;
}
.cal-sub-btn {
    flex: 1;
    background: transparent;
    border: 1px solid transparent;
    color: var(--text-muted);
    padding: 6px 4px;
    font-family: inherit;
    font-size: 10px;
    letter-spacing: 1.5px;
    cursor: pointer;
    text-transform: uppercase;
    transition: all 0.15s;
}
.cal-sub-btn:hover { color: var(--accent); }
.cal-sub-btn.active {
    background: rgba(var(--accent-rgb), 0.12);
    color: var(--accent);
    border-color: var(--accent);
}

/* === WEEK VIEW === */
.cal-week-headers {
    display: grid;
    grid-template-columns: 48px repeat(7, 1fr);
    position: sticky;
    top: 0;
    z-index: 6;
    background: rgba(14, 20, 25, 0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--border-color);
}
.cal-week-gutter { width: 48px; }
.cal-week-dayhead {
    text-align: center;
    padding: 8px 2px;
    border-left: 1px solid var(--border-color);
    cursor: pointer;
    transition: background 0.15s;
}
.cal-week-dayhead:hover { background: rgba(var(--accent-rgb), 0.06); }
.cwd-dow {
    font-size: 9px;
    letter-spacing: 1.5px;
    color: var(--text-muted);
    text-transform: uppercase;
}
.cwd-num {
    font-size: 18px;
    color: var(--text-primary);
    font-weight: 400;
    font-variant-numeric: tabular-nums;
    margin-top: 2px;
}
.cal-week-dayhead.today .cwd-num {
    display: inline-block;
    background: var(--danger);
    color: #fff;
    border-radius: 50%;
    width: 26px; height: 26px;
    line-height: 26px;
    font-weight: 600;
}
.cal-week-dayhead.today .cwd-dow { color: var(--danger); }
.cal-week-dayhead.weekend .cwd-dow { color: var(--ds-amber); }

.cal-week-allday {
    display: grid;
    grid-template-columns: 48px repeat(7, 1fr);
    border-bottom: 1px solid var(--border-color);
    background: rgba(20, 25, 31, 0.35);
    min-height: 28px;
    position: sticky;
    top: 56px;
    z-index: 5;
    backdrop-filter: blur(8px);
}
.cal-week-allday-gutter {
    font-size: 8px;
    letter-spacing: 1px;
    color: var(--text-muted);
    text-align: right;
    padding: 6px 4px 4px 0;
    text-transform: uppercase;
    line-height: 1.2;
}
.cal-week-allday-cell {
    border-left: 1px solid var(--border-color);
    padding: 3px 2px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    transition: background 0.15s;
}
.cal-week-allday-cell.tl-drop-over { background: rgba(var(--accent-rgb), 0.18); }
.cw-allday-chip {
    background: rgba(var(--accent-rgb), 0.12);
    border-left: 2px solid var(--block-color, var(--accent));
    color: var(--text-primary);
    font-size: 9px;
    line-height: 1.2;
    padding: 2px 5px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: grab;
    user-select: none;
}
.cw-allday-more { font-size: 8px; color: var(--text-muted); padding: 0 4px; }

.cal-week-grid {
    position: relative;
    display: grid;
    grid-template-columns: 48px repeat(7, 1fr);
    background: rgba(14, 20, 25, 0.35);
    border: 1px solid var(--border-color);
    border-top: none;
}
.cal-week-gutter-col { position: relative; }
.cw-hour-label {
    position: absolute;
    right: 4px;
    transform: translateY(-50%);
    font-size: 9px;
    letter-spacing: 0.5px;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
    background: var(--bg-dark);
    padding: 0 3px;
}
.cal-week-daycol {
    position: relative;
    border-left: 1px solid var(--border-color);
    transition: background 0.15s;
}
.cal-week-daycol.today { background: rgba(200, 64, 58, 0.03); }
.cal-week-daycol.weekend { background: rgba(220, 141, 24, 0.025); }
.cal-week-daycol.tl-drop-over { background: rgba(var(--accent-rgb), 0.10); }
.cw-hour-line {
    position: absolute;
    left: 0; right: 0;
    height: 0;
    border-top: 1px solid rgba(58, 72, 88, 0.35);
    pointer-events: none;
}

.cw-block {
    position: absolute;
    background: rgba(20, 25, 31, 0.92);
    border: 1px solid var(--border-color);
    border-left: 2px solid var(--block-color, var(--accent));
    padding: 3px 5px;
    overflow: hidden;
    cursor: grab;
    user-select: none;
    transition: box-shadow 0.15s, border-color 0.15s;
    min-height: 20px;
}
.cw-block:hover {
    border-color: var(--block-color, var(--accent));
    box-shadow: 0 0 6px -1px var(--block-color, var(--accent));
    z-index: 2;
}
.cw-block:active { cursor: grabbing; }
.cw-block.completed { opacity: 0.55; }
.cw-block.completed .cw-block-title { text-decoration: line-through; }
.cw-block.priority-high { border-left-width: 3px; }
.cw-block.priority-crit { border-left-width: 3px; border-left-color: var(--danger); }
.cw-block-title {
    font-size: 9px;
    line-height: 1.2;
    color: var(--text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.cw-block-time {
    font-size: 8px;
    color: var(--text-muted);
    letter-spacing: 0.3px;
    font-variant-numeric: tabular-nums;
    margin-top: 1px;
}
.cw-now-line { left: 0; right: 0; }

/* === MONTH VIEW === */
.cal-month-dow {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: rgba(14, 20, 25, 0.6);
    border: 1px solid var(--border-color);
    border-bottom: none;
}
.cmd-dow {
    text-align: center;
    font-size: 9px;
    letter-spacing: 2px;
    color: var(--text-muted);
    text-transform: uppercase;
    padding: 8px 4px;
    border-left: 1px solid var(--border-color);
}
.cmd-dow:first-child { border-left: none; }
.cmd-dow.weekend { color: var(--ds-amber); }

.cal-month-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-auto-rows: minmax(80px, 1fr);
    border: 1px solid var(--border-color);
    background: rgba(14, 20, 25, 0.3);
}
.cm-cell {
    border-left: 1px solid var(--border-color);
    border-top: 1px solid var(--border-color);
    padding: 4px 6px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 2px;
    transition: background 0.15s;
    overflow: hidden;
}
.cm-cell:hover { background: rgba(var(--accent-rgb), 0.05); }
.cm-cell.out { opacity: 0.35; }
.cm-cell.weekend { background: rgba(220, 141, 24, 0.03); }
.cm-cell.today { background: rgba(200, 64, 58, 0.05); }
.cm-cell.tl-drop-over { background: rgba(var(--accent-rgb), 0.18); }
.cm-num {
    font-size: 13px;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.cm-today-badge {
    display: inline-block;
    background: var(--danger);
    color: #fff;
    border-radius: 50%;
    width: 22px; height: 22px;
    line-height: 22px;
    text-align: center;
    font-weight: 600;
    font-size: 11px;
}
.cm-events {
    display: flex;
    flex-direction: column;
    gap: 1px;
    overflow: hidden;
}
.cm-event {
    display: flex;
    align-items: center;
    gap: 4px;
    background: rgba(var(--accent-rgb), 0.08);
    color: var(--text-primary);
    font-size: 9px;
    line-height: 1.2;
    padding: 1px 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: grab;
    user-select: none;
    border-left: 2px solid var(--block-color, var(--accent));
}
.cm-event-dot {
    width: 4px; height: 4px;
    background: var(--block-color, var(--accent));
    border-radius: 50%;
    flex-shrink: 0;
}
.cm-more {
    font-size: 8px;
    color: var(--text-muted);
    padding: 0 4px;
    letter-spacing: 0.3px;
}

/* === YEAR VIEW === */
.cal-year-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-top: 8px;
}
.cal-year-mini {
    background: rgba(20, 25, 31, 0.5);
    border: 1px solid var(--border-color);
    padding: 8px 8px 10px;
}
.cal-year-mini.current { border-color: var(--danger); }
.cym-head {
    font-size: 11px;
    letter-spacing: 1.5px;
    color: var(--text-primary);
    text-transform: uppercase;
    cursor: pointer;
    margin-bottom: 6px;
    padding-bottom: 4px;
    border-bottom: 1px dashed var(--border-color);
    transition: color 0.15s;
}
.cal-year-mini.current .cym-head { color: var(--danger); }
.cym-head:hover { color: var(--accent); }
.cym-dow {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
    margin-bottom: 2px;
}
.cym-dow span {
    font-size: 7px;
    letter-spacing: 0.3px;
    color: var(--text-muted);
    text-align: center;
    text-transform: uppercase;
}
.cym-cells {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 1px;
}
.cym-cell {
    font-size: 9px;
    line-height: 1.6;
    color: var(--text-secondary);
    text-align: center;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-variant-numeric: tabular-nums;
    transition: background 0.1s;
    border-radius: 50%;
}
.cym-cell.out { color: var(--text-muted); opacity: 0.35; cursor: default; }
.cym-cell.has-tasks { color: var(--accent); font-weight: 500; }
.cym-cell.today {
    background: var(--danger);
    color: #fff;
    font-weight: 600;
}
.cym-cell:hover:not(.out):not(.today) { background: rgba(var(--accent-rgb), 0.15); }

@media (max-width: 720px) {
    .cal-year-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .cal-year-grid { grid-template-columns: repeat(2, 1fr); }
    .cal-week-headers, .cal-week-grid, .cal-week-allday { grid-template-columns: 36px repeat(7, minmax(70px, 1fr)); }
    .cal-week-headers, .cal-week-allday {
        overflow-x: auto;
        position: relative;
        top: auto;
    }
    .cal-month-grid { grid-auto-rows: minmax(58px, 1fr); }
    .cm-event { font-size: 8px; }
    .cwd-num { font-size: 15px; }
}


/* ============================================================
   ТАЙМЕР РАУНДОВ — floating widget + picker
   Эстетика: DS chiral cyan, мягкое дыхание во время раунда,
   яркая вспышка при завершении.
   ============================================================ */

.round-widget {
    position: fixed;
    bottom: 16px;
    right: 16px;
    width: 156px;
    height: 156px;
    z-index: 9000;
    border-radius: 50%;
    background:
        radial-gradient(circle at 30% 30%, rgba(var(--accent-rgb), 0.18), transparent 60%),
        rgba(14, 20, 25, 0.78);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border: 1px solid rgba(var(--accent-rgb), 0.35);
    box-shadow:
        0 0 0 1px rgba(var(--accent-rgb), 0.08),
        0 0 24px rgba(var(--accent-rgb), 0.22),
        0 12px 32px rgba(0, 0, 0, 0.5),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    transform: scale(0.85);
    opacity: 0;
    transition: transform .25s cubic-bezier(.2,.9,.2,1.1), opacity .25s;
    user-select: none;
    animation: round-breath 2.6s ease-in-out infinite;
}
.round-widget.open { transform: scale(1); opacity: 1; }
.round-widget.flash { animation: round-flash .55s ease-out, round-breath 2.6s ease-in-out infinite .55s; }
.round-widget.done-pulse { animation: round-done 1.2s ease-in-out infinite; border-color: var(--ok, #6FA770); }

@keyframes round-breath {
    0%, 100% { box-shadow: 0 0 0 1px rgba(var(--accent-rgb), 0.08), 0 0 24px rgba(var(--accent-rgb), 0.22), 0 12px 32px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04); }
    50%      { box-shadow: 0 0 0 2px rgba(var(--accent-rgb), 0.16), 0 0 36px rgba(var(--accent-rgb), 0.38), 0 12px 32px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04); }
}
@keyframes round-done {
    0%, 100% { box-shadow: 0 0 0 2px rgba(111, 167, 112, .35), 0 0 28px rgba(111, 167, 112, .55), 0 12px 32px rgba(0,0,0,.5); }
    50%      { box-shadow: 0 0 0 4px rgba(111, 167, 112, .55), 0 0 56px rgba(111, 167, 112, .85), 0 12px 32px rgba(0,0,0,.5); }
}
@keyframes round-flash {
    0%   { transform: scale(1); filter: brightness(1); }
    35%  { transform: scale(1.08); filter: brightness(1.6); }
    100% { transform: scale(1); filter: brightness(1); }
}

.round-ring {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
    pointer-events: none;
}
.round-ring-bg {
    fill: none;
    stroke: rgba(202, 180, 161, 0.10); /* warm separator, чуть видно */
    stroke-width: 3;
}
.round-ring-pulse {
    fill: none;
    stroke: rgba(var(--accent-rgb), 0.06);
    stroke-width: 12;
    animation: round-pulse-ring 2.6s ease-in-out infinite;
}
@keyframes round-pulse-ring {
    0%, 100% { stroke-width: 8; opacity: .4; }
    50%      { stroke-width: 18; opacity: .15; }
}
.round-ring-fg {
    fill: none;
    stroke: var(--accent);
    stroke-width: 4;
    stroke-linecap: round;
    transition: stroke-dashoffset .35s linear;
    filter: drop-shadow(0 0 6px rgba(var(--accent-rgb), 0.7));
}
.round-widget.done-pulse .round-ring-fg { stroke: var(--ok, #6FA770); }

.round-center {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    pointer-events: none;
}
.round-time {
    font-family: 'Orbitron', 'iA Writer Mono V', monospace;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text-primary);
    text-shadow: 0 0 12px rgba(var(--accent-rgb), 0.45);
    line-height: 1;
}
.round-widget.done-pulse .round-time {
    color: #DDEAD0;
    text-shadow: 0 0 16px rgba(111, 167, 112, .8);
}
.round-sub {
    margin-top: 4px;
    font-size: 9px;
    letter-spacing: 0.18em;
    color: var(--text-secondary);
    font-weight: 600;
}

.round-act {
    position: absolute;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 1px solid rgba(var(--accent-rgb), 0.4);
    background: rgba(14, 20, 25, 0.85);
    color: var(--accent);
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: transform .12s, background .12s, border-color .12s;
    pointer-events: auto;
}
.round-act:hover { background: rgba(var(--accent-rgb), 0.18); transform: scale(1.08); }
.round-act:active { transform: scale(0.95); }
.round-act-pause { top: 6px;    right: 6px; }
.round-act-resume { top: 6px;   right: 6px; color: var(--ok, #6FA770); border-color: rgba(111,167,112,.4); }
.round-act-done  { bottom: 6px; right: 6px; color: var(--ok, #6FA770); border-color: rgba(111,167,112,.4); }
.round-act-abort { bottom: 6px; left:  6px; color: var(--danger); border-color: rgba(200, 64, 58, .4); font-size: 14px; }

.round-task {
    position: absolute;
    bottom: -28px;
    left: 50%;
    transform: translateX(-50%);
    max-width: 240px;
    padding: 4px 10px;
    border-radius: 12px;
    background: rgba(14, 20, 25, 0.92);
    border: 1px solid rgba(202, 180, 161, 0.12);
    font-size: 10px;
    color: var(--text-secondary);
    letter-spacing: 0.06em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    pointer-events: none;
}
.round-task:empty { display: none; }

@media (max-width: 480px) {
    .round-widget { width: 132px; height: 132px; bottom: 84px; }
    .round-time { font-size: 22px; }
    .round-sub { font-size: 8px; }
    .round-act { width: 28px; height: 28px; font-size: 14px; }
}

/* ===== PICKER ===== */
.round-picker {
    position: fixed; inset: 0;
    z-index: 9100;
    display: flex; align-items: center; justify-content: center;
    opacity: 0;
    transition: opacity .2s;
}
.round-picker.open { opacity: 1; }
.round-picker-backdrop {
    position: absolute; inset: 0;
    background: rgba(8, 12, 16, 0.7);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.round-picker-content {
    position: relative;
    width: min(520px, calc(100vw - 24px));
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: 18px;
    padding: 20px;
    box-shadow: 0 24px 60px rgba(0,0,0,.6);
}
.round-picker-head {
    display: flex; justify-content: space-between; align-items: center;
    font-family: 'Orbitron', sans-serif;
    font-size: 13px;
    letter-spacing: 0.2em;
    color: var(--accent);
    margin-bottom: 6px;
}
.round-picker-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 22px;
    cursor: pointer;
    padding: 0 4px;
}
.round-picker-task {
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 16px;
    word-break: break-word;
}
.round-preset-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.round-preset {
    background: var(--bg-input);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    padding: 14px 12px;
    text-align: left;
    cursor: pointer;
    color: var(--text-primary);
    transition: transform .12s, border-color .12s, background .12s;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.round-preset:hover {
    border-color: var(--accent);
    background: rgba(var(--accent-rgb), 0.08);
    transform: translateY(-1px);
}
.round-preset.rp-champ {
    grid-column: 1 / -1;
    background:
        linear-gradient(120deg, rgba(var(--accent-rgb), 0.10), rgba(244,209,54,0.06));
    border-color: rgba(244, 209, 54, 0.35);
}
.round-preset.rp-champ:hover { border-color: rgba(244, 209, 54, 0.7); }
.rp-name {
    font-family: 'Orbitron', sans-serif;
    font-size: 12px;
    letter-spacing: 0.16em;
    color: var(--accent);
}
.round-preset.rp-champ .rp-name { color: #F4D136; }
.rp-mins {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 0.02em;
}
.rp-desc {
    font-size: 11px;
    color: var(--text-muted);
}
.rp-input {
    width: 100%;
    padding: 6px 10px;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    margin: 2px 0;
}
.round-preset.rp-custom { grid-column: 1 / -1; }
.round-picker-hint {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border-light);
    font-size: 11px;
    color: var(--text-muted);
    font-style: italic;
}

/* ===== TASK MODAL — ROUNDS BLOCK ===== */
.tm-rounds-block {
    margin: 14px 0;
    padding: 12px;
    border-radius: 10px;
    background: rgba(var(--accent-rgb), 0.04);
    border: 1px solid rgba(var(--accent-rgb), 0.15);
}
.tm-rounds-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}
.btn-round-start {
    background: var(--accent);
    color: var(--bg-dark);
    border: none;
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    cursor: pointer;
    font-family: 'Orbitron', sans-serif;
    transition: transform .12s, background .12s;
}
.btn-round-start:hover { background: var(--accent-hover); transform: translateY(-1px); }
.btn-round-start.active { background: rgba(var(--accent-rgb), 0.15); color: var(--accent); border: 1px solid var(--accent); }
.tm-rounds-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.tm-field-small .tm-label { font-size: 10px; }
.tm-rounds-list {
    margin-top: 10px;
}
.tm-round-hint {
    font-size: 12px;
    color: var(--text-secondary);
}

/* ============================================================
   TOPBAR — единая sticky-шапка (2 строки, glass, тап = sheet)
   ============================================================ */

:root {
    --topbar-h: 96px; /* динамически обновляется JS через getBoundingClientRect */
}

.topbar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 95;
    padding: calc(env(safe-area-inset-top, 0px) + 6px) 12px 8px;
    background: rgba(14, 20, 25, 0.42);
    backdrop-filter: blur(25px) saturate(1.4);
    -webkit-backdrop-filter: blur(25px) saturate(1.4);
    border-bottom: 1px solid var(--border-color);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.topbar::before {
    content: '';
    position: absolute;
    top: -1px; right: 0;
    width: 120px; height: 1px;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent);
}

.topbar-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.topbar-row1 { justify-content: space-between; }

.tb-user {
    display: flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-size: 11px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    cursor: pointer;
    padding: 4px 6px 4px 0;
    flex-shrink: 0;
}
.tb-user .callsign-prefix { color: var(--text-muted); }
.tb-user .callsign-name { color: var(--accent); font-weight: 500; text-shadow: 0 0 6px rgba(95, 180, 201, 0.4); }
.tb-lvl {
    margin-left: 6px;
    padding: 2px 6px;
    background: rgba(95, 180, 201, 0.12);
    border: 1px solid rgba(95, 180, 201, 0.25);
    border-radius: 4px;
    font-size: 10px;
    color: var(--accent);
    letter-spacing: 0.5px;
}
.tb-lvl span { font-weight: 600; }

.topbar-cells {
    display: flex;
    gap: 4px;
    flex: 1;
    justify-content: flex-end;
    overflow-x: auto;
    scrollbar-width: none;
}
.topbar-cells::-webkit-scrollbar { display: none; }

.tb-stat {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid var(--glass-border);
    border-radius: 6px;
    padding: 5px 8px;
    color: var(--text-primary);
    font-size: 11px;
    font-variant-numeric: tabular-nums;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    flex-shrink: 0;
    min-width: 0;
}
.tb-stat:active { background: rgba(95, 180, 201, 0.12); }
.tb-stat .tb-icon {
    width: 14px; height: 14px;
    display: inline-flex;
    color: var(--text-secondary);
}
.tb-stat .tb-icon svg { width: 100%; height: 100%; }
.tb-stat .tb-val { font-weight: 500; }

/* цветовые акценты на иконках */
.tb-stat[data-sheet="hp"] .tb-icon { color: #ec4899; }
.tb-stat[data-sheet="sleep"] .tb-icon { color: #a78bfa; }
.tb-stat[data-sheet="energy"] .tb-icon { color: #facc15; }
.tb-stat[data-sheet="mood"] .tb-icon { color: #5FB4C9; }
.tb-stat[data-sheet="balance"] .tb-icon { color: #22c55e; }

.tb-stat-money .tb-val.negative { color: var(--danger); }
.tb-stat-money .tb-val.positive { color: var(--accent); }

/* ---- второй ряд: стодневка + день + серия ---- */
.topbar-row2 {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 6px;
}

.tb-block {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, 0.025);
    border: 1px solid var(--glass-border);
    border-radius: 6px;
    padding: 6px 10px;
    cursor: pointer;
    transition: background 0.15s;
    min-width: 0;
}
.tb-block:active { background: rgba(95, 180, 201, 0.12); }

.tb-block .tb-label {
    font-size: 9px;
    color: var(--text-muted);
    letter-spacing: 1.2px;
    text-transform: uppercase;
    white-space: nowrap;
    flex-shrink: 0;
}
.tb-block .tb-label span { color: var(--accent); }

.tb-bar {
    flex: 1;
    height: 6px;
    background: rgba(14, 20, 25, 0.7);
    border: 1px solid var(--border-color);
    border-radius: 3px;
    overflow: hidden;
    min-width: 30px;
}
.tb-bar-fill {
    height: 100%; width: 0%;
    background: linear-gradient(90deg, var(--accent), var(--accent-light));
    box-shadow: 0 0 6px rgba(95, 180, 201, 0.4);
    transition: width 0.5s ease;
}
.tb-bar-fill-day {
    background: linear-gradient(90deg, var(--ds-gold-ds), #f4d136);
    box-shadow: 0 0 6px rgba(244, 209, 54, 0.4);
}

.tb-block .tb-meta,
.tb-block .tb-val {
    font-size: 10px;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    flex-shrink: 0;
}
.tb-block-tight {
    padding: 6px 10px;
    gap: 4px;
}
.tb-block-tight .tb-val { font-size: 14px; font-weight: 600; }

@media (max-width: 480px) {
    :root { --topbar-h: 100px; }
    .topbar { padding-left: 8px; padding-right: 8px; }
    .tb-user { font-size: 10px; letter-spacing: 1px; }
    .tb-user .tb-lvl { font-size: 9px; padding: 2px 4px; }
    .tb-stat { padding: 5px 6px; font-size: 10px; gap: 3px; }
    .tb-block { padding: 5px 8px; }
    .tb-block .tb-label { font-size: 8px; letter-spacing: 0.8px; }
    .tb-block .tb-meta { font-size: 9px; }
}

/* main отступ под фикс-шапку */
.app { padding-top: calc(var(--topbar-h) + 8px) !important; }

/* ============================================================
   BOTTOM SHEET — раскрытие topbar-ячейки снизу
   ============================================================ */
.sheet {
    position: fixed; inset: 0;
    z-index: var(--z-modal, 200);
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.sheet-backdrop {
    position: absolute; inset: 0;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    animation: sheetFadeIn 0.22s ease-out;
}

.sheet-content {
    position: relative;
    width: 100%;
    max-width: 480px;
    max-height: 85vh;
    background: rgba(20, 26, 32, 0.85);
    backdrop-filter: blur(28px) saturate(1.5);
    -webkit-backdrop-filter: blur(28px) saturate(1.5);
    border: 1px solid var(--glass-border);
    border-bottom: none;
    border-radius: 18px 18px 0 0;
    padding: 8px 16px 24px;
    padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px));
    display: flex;
    flex-direction: column;
    animation: sheetSlideUp 0.28s cubic-bezier(0.22, 0.61, 0.36, 1);
    box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.5);
}

.sheet-handle {
    width: 40px; height: 4px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 2px;
    margin: 4px auto 12px;
}

.sheet-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}
.sheet-title {
    font-size: 13px;
    color: var(--accent);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 600;
}
.sheet-close {
    background: transparent;
    border: none;
    color: var(--text-secondary);
    font-size: 24px;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}
.sheet-body {
    overflow-y: auto;
    font-size: 13px;
    color: var(--text-primary);
    padding-right: 4px;
}

@keyframes sheetSlideUp {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
}
@keyframes sheetFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ---- содержимое sheet'ов ---- */
.sheet-section { margin-bottom: 16px; }
.sheet-section-title {
    font-size: 10px;
    color: var(--text-muted);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.sheet-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.sheet-field-label {
    font-size: 11px;
    color: var(--text-secondary);
    letter-spacing: 0.5px;
}
.sheet-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.sheet-scale {
    display: grid;
    grid-template-columns: repeat(11, 1fr);
    gap: 3px;
    margin-top: 4px;
}
.sheet-scale-btn {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--glass-border);
    color: var(--text-secondary);
    padding: 8px 0;
    font-size: 11px;
    font-weight: 600;
    border-radius: 5px;
    cursor: pointer;
    text-align: center;
}
.sheet-scale-btn.active {
    background: var(--accent);
    color: var(--bg-dark);
    border-color: var(--accent);
}
.sheet-textarea {
    width: 100%;
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--glass-border);
    border-radius: 6px;
    color: var(--text-primary);
    padding: 8px 10px;
    font-family: inherit;
    font-size: 12px;
    min-height: 60px;
    resize: vertical;
}
.sheet-time-input {
    background: rgba(0, 0, 0, 0.3);
    border: 1px solid var(--glass-border);
    border-radius: 6px;
    color: var(--text-primary);
    padding: 6px 10px;
    font-family: inherit;
    font-size: 13px;
    max-width: 110px;
}
.sheet-save-row {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color);
}
.sheet-big {
    font-size: 36px;
    font-weight: 700;
    color: var(--accent);
    text-align: center;
    margin: 8px 0 4px;
    font-variant-numeric: tabular-nums;
}
.sheet-sub {
    text-align: center;
    color: var(--text-secondary);
    font-size: 11px;
    margin-bottom: 12px;
}

/* стодневка sheet: сетка квадратиков 10×10 */
.sheet-hundred-grid {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    gap: 3px;
    margin: 8px 0;
}
.sheet-hundred-cell {
    aspect-ratio: 1;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: 2px;
}
.sheet-hundred-cell.done { background: var(--accent); border-color: var(--accent); }
.sheet-hundred-cell.today { box-shadow: 0 0 8px var(--ds-gold-ds); border-color: var(--ds-gold-ds); }

/* ============================================================
   FAB — floating add task
   ============================================================ */
.fab {
    position: fixed;
    z-index: 92;
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--bg-dark);
    border: 1px solid rgba(255, 255, 255, 0.15);
    box-shadow: 0 8px 24px rgba(95, 180, 201, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    font-weight: 300;
    line-height: 1;
    transition: transform 0.15s, box-shadow 0.15s;
    /* mobile: правый низ, над нижним меню */
    right: 20px;
    bottom: calc(80px + env(safe-area-inset-bottom, 0px));
}
.fab:active { transform: scale(0.94); box-shadow: 0 4px 16px rgba(95, 180, 201, 0.5); }
.fab-plus { display: block; transform: translateY(-1px); }

@media (min-width: 720px) {
    /* десктоп: центр снизу */
    .fab {
        right: auto;
        left: 50%;
        transform: translateX(-50%);
        bottom: calc(80px + env(safe-area-inset-bottom, 0px));
    }
    .fab:active { transform: translateX(-50%) scale(0.94); }
}

/* ============================================================
   QUICK-ADD TASK — компактный диалог
   ============================================================ */
.qadd {
    position: fixed; inset: 0;
    z-index: var(--z-modal, 200);
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.qadd-backdrop {
    position: absolute; inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.qadd-content {
    position: relative;
    width: 100%;
    max-width: 480px;
    background: rgba(20, 26, 32, 0.92);
    backdrop-filter: blur(24px) saturate(1.4);
    -webkit-backdrop-filter: blur(24px) saturate(1.4);
    border: 1px solid var(--glass-border);
    border-bottom: none;
    border-radius: 18px 18px 0 0;
    padding: 18px 16px;
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px));
    display: flex;
    flex-direction: column;
    gap: 10px;
    animation: sheetSlideUp 0.25s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.qadd-input {
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--glass-border);
    color: var(--text-primary);
    padding: 8px 4px;
    font-size: 16px;
    font-family: inherit;
    outline: none;
}
.qadd-input::placeholder { color: var(--text-muted); }
.qadd-meta {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.qadd-select, .qadd-date {
    flex: 1;
    min-width: 80px;
}
.qadd-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 4px;
}

@media (min-width: 720px) {
    .qadd { align-items: center; }
    .qadd-content {
        border-radius: 14px;
        border-bottom: 1px solid var(--glass-border);
        padding-bottom: 18px;
    }
}

/* финансы — sheet баланса */
.balance-big {
    font-size: 32px;
    font-weight: 700;
    color: var(--text-primary);
    text-align: center;
    margin: 8px 0 2px;
    font-variant-numeric: tabular-nums;
}
.balance-delta {
    text-align: center;
    font-size: 13px;
    margin-bottom: 12px;
}
.balance-delta.positive { color: var(--accent); }
.balance-delta.negative { color: var(--danger); }
.balance-accounts {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 8px;
}
.balance-account {
    display: flex;
    justify-content: space-between;
    padding: 6px 8px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--glass-border);
    border-radius: 4px;
    font-size: 12px;
}
.balance-account-name { color: var(--text-secondary); }
.balance-account-sum { color: var(--text-primary); font-variant-numeric: tabular-nums; }

/* === таблица чувств === */
.feelings-grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.feeling-group { display: flex; flex-direction: column; gap: 6px; }
.feeling-group-head {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.feeling-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}
.feeling-chip {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--glass-border);
    color: var(--text-secondary);
    padding: 5px 9px;
    border-radius: 12px;
    font-size: 11px;
    font-family: inherit;
    cursor: pointer;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.feeling-chip:active { transform: scale(0.96); }
.feeling-chip.active {
    background: color-mix(in srgb, var(--chip-color) 18%, transparent);
    border-color: var(--chip-color);
    color: var(--chip-color);
}

