/* ===== SIRIUS — Neo-Glass UI (bright neon glass-morphism, premium feel) ===== */

/* Reset */
*, *::before, *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent;
}

/* CSS Variables — Bright Neon Glass palette */
:root {
    --bg-primary: #060a12;
    --bg-primary-subtle: #0a0f1a;
    --bg-card: rgba(14, 20, 35, 0.65);
    --bg-card-solid: #0e1423;
    --bg-elevated: rgba(18, 26, 45, 0.8);
    --bg-input: rgba(16, 22, 40, 0.85);
    --accent: #1e90ff;
    --accent-rgb: 30, 144, 255;
    --accent-light: #55aaff;
    --accent-bright: #88ccff;
    --accent-glow: rgba(30, 144, 255, 0.65);
    --accent-glow-strong: rgba(30, 144, 255, 0.85);
    --accent-gradient: linear-gradient(135deg, #1e90ff 0%, #0060df 100%);
    --accent-neon: 0 0 8px rgba(30, 144, 255, 0.8), 0 0 22px rgba(30, 144, 255, 0.5), 0 0 45px rgba(30, 144, 255, 0.25);
    --success: #00e699;
    --success-glow: rgba(0, 230, 153, 0.5);
    --danger: #ff5c5c;
    --danger-glow: rgba(255, 92, 92, 0.5);
    --warning: #ffd000;
    --text-primary: #ffffff;
    --text-secondary: #c8d8f0;
    --text-tertiary: #8baac8;
    --text-glow: 0 0 14px rgba(255, 255, 255, 0.25), 0 0 4px rgba(255,255,255,0.5);
    --border: rgba(255, 255, 255, 0.10);
    --border-light: rgba(255, 255, 255, 0.18);
    --border-glow: rgba(30, 144, 255, 0.5);
    --border-active: rgba(30, 144, 255, 0.8);
    --glass: rgba(10, 16, 30, 0.72);
    --glass-bright: rgba(18, 28, 52, 0.65);
    --glass-border: rgba(255, 255, 255, 0.13);
    --glass-shine: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.02) 50%, transparent 100%);
    --radius-sm: 12px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 24px;
    --radius-pill: 9999px;
    --shadow-card: 0 4px 24px rgba(0, 0, 0, 0.4);
    --shadow-glow: 0 0 28px rgba(30, 144, 255, 0.55), 0 0 56px rgba(30, 144, 255, 0.2);
    --shadow-glow-subtle: 0 0 0 1px rgba(30, 144, 255, 0.4), 0 0 20px rgba(30, 144, 255, 0.15);
    --shadow-neon: 0 0 12px rgba(30, 144, 255, 0.55), 0 0 35px rgba(30, 144, 255, 0.25), 0 0 70px rgba(30, 144, 255, 0.1);
    --shadow-elevate: 0 8px 32px rgba(0, 0, 0, 0.5);
    --transition: 0.22s cubic-bezier(0.4, 0, 0.2, 1);
    --tab-height: 68px;
    --header-height: 52px;
    --safe-bottom: env(safe-area-inset-bottom, 0px);
    --bg-page: #060a12;

    /* Legacy compat for games.css */
    --bg-color: var(--bg-card-solid);
    --bg-secondary: var(--bg-elevated);
    --primary-color: var(--accent);
    --text-color: var(--text-primary);
    --border-color: var(--border);
    --border-radius: 14px;
    --shadow: var(--shadow-card);
    --shadow-lg: 0 8px 32px rgba(0,0,0,0.5);
    --danger-color: var(--danger);
    --success-color: var(--success);
}

/* Body — deep dark base */
html {
    background: #060a12 !important;
    color: #ffffff !important;
}
body {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'SF Pro Text', 'Inter', 'Helvetica Neue', Arial, sans-serif;
    background: var(--bg-primary) !important;
    color: var(--text-primary) !important;
    line-height: 1.5;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ===== APP STRUCTURE ===== */

#app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
    background: var(--bg-primary);
    color: var(--text-primary);
}

/* ===== GLASS CARD — core reusable component with real glass feel ===== */
.glass-card {
    background: rgba(14, 22, 40, 0.58);
    backdrop-filter: blur(32px) saturate(170%);
    -webkit-backdrop-filter: blur(32px) saturate(170%);
    border-radius: var(--radius-lg);
    border: 1px solid rgba(30, 144, 255, 0.25);
    box-shadow: 0 0 0 1px rgba(30, 144, 255, 0.2), 0 0 24px rgba(30, 144, 255, 0.1), var(--shadow-card), inset 0 1px 0 rgba(255,255,255,0.10);
    transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
    position: relative;
    overflow: hidden;
}
.glass-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
    pointer-events: none;
}
.glass-card:hover {
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.4), 0 0 24px rgba(77, 159, 255, 0.25), 0 0 48px rgba(77, 159, 255, 0.1), var(--shadow-card);
    border-color: rgba(77, 159, 255, 0.45);
    transform: translateY(-2px);
}

/* Header — frosted with neon edge */
.app-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    background: rgba(6, 10, 18, 0.85);
    backdrop-filter: blur(32px) saturate(140%);
    -webkit-backdrop-filter: blur(32px) saturate(140%);
    border-bottom: 1px solid rgba(77, 159, 255, 0.12);
    box-shadow: 0 1px 0 rgba(77, 159, 255, 0.1), 0 4px 20px rgba(0, 0, 0, 0.3);
    z-index: 100;
}

.logo-text {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 2px;
    background: linear-gradient(135deg, #a0d0ff, #4d9fff, #7ab8ff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 0 14px rgba(77, 159, 255, 0.4));
}

.streak-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(77, 159, 255, 0.12);
    padding: 6px 12px;
    border-radius: var(--radius-pill);
    font-size: 13px;
    font-weight: 600;
    border: 1px solid rgba(77, 159, 255, 0.25);
    backdrop-filter: blur(12px);
    box-shadow: 0 0 12px rgba(77, 159, 255, 0.15);
    color: var(--text-primary);
}
.streak-badge.hidden { display: none; }
.dashboard-missed-wrap.hidden { display: none; }
.missed-hint { font-size: 12px; color: var(--text-secondary); margin: 0 0 8px 0; }
#page-dashboard .btn-pill-small { padding: 6px 12px; font-size: 13px; }
.streak-fire { font-size: 14px; }

/* Pages container */
.pages-container {
    position: relative;
    flex: 1;
    padding-top: var(--header-height);
    padding-bottom: calc(var(--tab-height) + var(--safe-bottom));
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--bg-primary);
    color: var(--text-primary);
}

.page {
    display: none;
    min-height: calc(100vh - var(--header-height) - var(--tab-height));
    min-height: calc(100dvh - var(--header-height) - var(--tab-height));
    animation: pageFadeIn 0.25s ease;
    background: var(--bg-primary);
    color: var(--text-primary);
}
.page.active { display: block; }

.page.game-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--bg-page);
    z-index: 60;
    overflow-y: auto;
    padding-top: var(--header-height);
    padding-bottom: var(--tab-height);
}
.game-overlay-back-row {
    padding: 12px 16px;
    border-bottom: 1px solid rgba(77, 159, 255, 0.15);
    background: rgba(6, 10, 18, 0.95);
}
.game-overlay-back-row .btn-back-row {
    margin: 0;
}

/* Игры: такой же уверенный стиль, как во всём мини-апп (glass, неон) */
.game-overlay .game-setup,
.game-overlay .game-play {
    padding: 16px;
}
.game-overlay .game-btn {
    background: var(--accent-gradient);
    border: none;
    color: #fff;
    padding: 12px 24px;
    border-radius: var(--radius-pill);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    box-shadow: 0 0 16px var(--accent-glow);
    transition: all var(--transition);
}
.game-overlay .game-btn:hover:not(:disabled) {
    box-shadow: var(--shadow-neon);
    transform: translateY(-2px);
}
.game-overlay .game-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
.game-overlay .player-input-section {
    background: rgba(14, 22, 40, 0.6);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(77, 159, 255, 0.2);
    border-radius: var(--radius-lg);
    padding: 14px 16px;
    margin-bottom: 14px;
}
.game-overlay .player-count-btn,
.game-overlay .category-btn {
    background: rgba(14, 22, 40, 0.7);
    border: 1px solid rgba(77, 159, 255, 0.3);
    color: var(--text-secondary);
    border-radius: var(--radius-md);
    padding: 10px 14px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}
.game-overlay .player-count-btn:hover,
.game-overlay .category-btn:hover {
    background: rgba(77, 159, 255, 0.15);
    border-color: var(--accent);
    color: var(--accent-bright);
}
.game-overlay .player-count-btn.active,
.game-overlay .category-btn.active {
    background: rgba(77, 159, 255, 0.25);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 0 12px rgba(77, 159, 255, 0.3);
}
.game-overlay .container {
    max-width: 100%;
}
.game-overlay h2 {
    color: #fff;
    font-size: 20px;
    margin-bottom: 16px;
    text-shadow: 0 0 12px rgba(77, 159, 255, 0.2);
}

@keyframes pageFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.page-content {
    padding: 16px 16px 24px;
}

/* ===== BOTTOM TAB BAR — Bright neon glass capsule ===== */

.tab-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: calc(var(--tab-height) + var(--safe-bottom));
    padding-bottom: var(--safe-bottom);
    display: flex;
    align-items: center;
    justify-content: space-around;
    background: rgba(6, 10, 18, 0.97) !important;
    backdrop-filter: blur(32px) saturate(140%);
    -webkit-backdrop-filter: blur(32px) saturate(140%);
    border-top: 1px solid rgba(77, 159, 255, 0.15);
    box-shadow: 0 -1px 0 rgba(77, 159, 255, 0.12), 0 -4px 24px rgba(0, 0, 0, 0.3);
    z-index: 100;
}

.tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 8px 14px;
    background: none;
    border: none;
    color: var(--text-tertiary);
    cursor: pointer;
    transition: color var(--transition), transform var(--transition), text-shadow var(--transition);
    -webkit-tap-highlight-color: transparent;
    min-width: 56px;
    border-radius: var(--radius-md);
    position: relative;
}
.tab:hover {
    color: var(--text-secondary);
    transform: translateY(-1px);
}
.tab.active {
    color: #ffffff;
    text-shadow: 0 0 12px rgba(30, 144, 255, 0.8), 0 0 4px rgba(255,255,255,0.6);
}
.tab.active::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    height: 3px;
    border-radius: 2px;
    background: #1e90ff;
    box-shadow: 0 0 8px rgba(30, 144, 255, 0.9), 0 0 18px rgba(30, 144, 255, 0.5);
}
.tab.active .tab-icon {
    stroke: #88ccff;
    filter: drop-shadow(0 0 10px rgba(30, 144, 255, 0.7));
}

.tab-icon {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: stroke var(--transition), filter var(--transition);
}

.tab-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}

/* ===== DASHBOARD ===== */

/* Greeting */
/* ===== HERO CARD — time-based gradient, logo right ===== */
.hero-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    padding: 22px 20px;
    border-radius: var(--radius-lg);
    position: relative;
    overflow: hidden;
    transition: background 1.2s ease;
    background: linear-gradient(160deg, #0f2748 0%, #1a4a7a 50%, #2d5f96 100%);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.35);
}
.hero-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.04) 0%, transparent 60%);
    pointer-events: none;
}

/* Time-based gradients */
.hero-gradient-morning {
    background: linear-gradient(160deg, #0f2748 0%, #1a4a7a 50%, #2d6496 100%) !important;
}
.hero-gradient-day {
    background: linear-gradient(160deg, #0d47a1 0%, #1565c0 50%, #1976d2 100%) !important;
}
.hero-gradient-evening {
    background: linear-gradient(160deg, #060a12 0%, #0b1326 50%, #0d1f3c 100%) !important;
}

.hero-left {
    flex: 1;
    min-width: 0;
}
.hero-greeting {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 2px;
    color: #ffffff;
    line-height: 1.2;
}
.greeting-date {
    font-size: 13px;
    color: rgba(255,255,255,0.65);
    font-weight: 400;
    margin-bottom: 8px;
}
.hero-focus {
    font-size: 13px;
    color: rgba(255,255,255,0.8);
    font-weight: 500;
    background: rgba(255,255,255,0.1);
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    margin: 0;
}
.hero-right {
    flex-shrink: 0;
    margin-left: 16px;
}
.hero-logo {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: 14px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}

/* ===== DAILY QUOTE CARD — cream background, deep blue text ===== */
.quote-card {
    background: #faf5e8;
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    margin-bottom: 20px;
    border: 1px solid rgba(26, 35, 126, 0.12);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    position: relative;
    overflow: hidden;
}
.quote-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, #1a237e, #3949ab);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.quote-text {
    font-weight: 700;
    font-size: 14px;
    text-transform: uppercase;
    color: #1a237e;
    line-height: 1.6;
    letter-spacing: 0.3px;
}
.quote-source {
    display: inline;
    font-size: 13px;
    color: #1a237e;
    font-style: italic;
    font-weight: 400;
}
.quote-comment {
    font-size: 13px;
    color: #1a1a1a;
    line-height: 1.6;
    margin-top: 10px;
}

/* ===== Quote rotation countdown hint ===== */
.quote-rotation-hint {
    margin-top: 10px;
    font-size: 12px;
    color: rgba(26, 35, 126, 0.72);
    font-weight: 600;
}

/* ===== Fact card (fact of the day) ===== */
.fact-card {
    padding: 18px 20px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.fact-label {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: 800;
    color: rgba(255, 255, 255, 0.62);
}

.fact-stat {
    font-size: 22px;
    font-weight: 950;
    line-height: 1.05;
    color: #ffffff;
    margin: 2px 0 0;
}

.fact-body {
    font-size: 13px;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.84);
    margin: 6px 0 0;
    font-weight: 500;
}

.fact-details {
    list-style: none;
    padding: 0;
    margin: 12px 0 0;
    display: none;
    flex-direction: column;
    gap: 8px;
    border-top: 1px solid rgba(77, 159, 255, 0.16);
    padding-top: 12px;
}

.fact-detail-item {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.fact-detail-num {
    min-width: 22px;
    height: 22px;
    border-radius: 50%;
    background: rgba(77, 159, 255, 0.25);
    color: #ffffff;
    font-size: 12px;
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 1px;
}

.fact-detail-text {
    font-size: 13px;
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.86);
}

.fact-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
    color: rgba(77, 159, 255, 0.95);
    font-weight: 900;
    font-size: 13px;
}

.fact-toggle-icon {
    width: 14px;
    height: 14px;
    transition: transform 0.2s ease;
}

.fact-toggle-icon--open {
    transform: rotate(180deg);
}

/* Progress ring card */
.progress-card {
    background: rgba(14, 22, 40, 0.55);
    backdrop-filter: blur(32px) saturate(160%);
    -webkit-backdrop-filter: blur(32px) saturate(160%);
    border: 1px solid rgba(77, 159, 255, 0.2);
    border-radius: var(--radius-lg);
    padding: 24px 20px;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 24px;
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.15), 0 0 20px rgba(77, 159, 255, 0.1), var(--shadow-card), inset 0 1px 0 rgba(255,255,255,0.08);
    transition: box-shadow var(--transition), transform var(--transition);
    position: relative;
    overflow: hidden;
}
.progress-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
    pointer-events: none;
}

.progress-ring-wrap {
    position: relative;
    width: 100px;
    height: 100px;
    flex-shrink: 0;
}
.progress-ring {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}
.progress-ring-bg {
    fill: none !important;
    stroke: rgba(77, 159, 255, 0.15) !important;
    stroke-width: 8 !important;
}
.progress-ring-fill {
    fill: none !important;
    stroke: #4d9fff !important;
    stroke: var(--accent) !important;
    stroke-width: 8 !important;
    stroke-linecap: round !important;
    stroke-dasharray: 326.73 !important;
    stroke-dashoffset: 326.73;
    transition: stroke-dashoffset 1s ease;
    filter: drop-shadow(0 0 8px rgba(77, 159, 255, 0.5));
}
.progress-ring-label {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}
.progress-ring-value {
    display: block;
    font-size: 22px;
    font-weight: 700;
    color: #ffffff;
    text-shadow: 0 0 12px rgba(77, 159, 255, 0.4);
}
.progress-ring-text {
    display: block;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: -2px;
}

.progress-stats {
    flex: 1;
    display: flex;
    gap: 12px;
}
.progress-stat {
    flex: 1;
    text-align: center;
    background: rgba(77, 159, 255, 0.08);
    backdrop-filter: blur(16px);
    padding: 12px 4px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(77, 159, 255, 0.2);
    transition: transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 0 10px rgba(77, 159, 255, 0.06);
}
.progress-stat:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25), 0 0 16px rgba(77, 159, 255, 0.2);
    border-color: rgba(77, 159, 255, 0.35);
}
.progress-stat-value {
    display: block;
    font-size: 20px;
    font-weight: 700;
    color: #ffffff;
}
.progress-stat-label {
    display: block;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 2px;
    font-weight: 500;
}

/* Quick AI — pill search bar */
.quick-ai-card {
    margin-bottom: 24px;
}
.quick-ai-input-wrap {
    display: flex;
    gap: 10px;
    align-items: center;
    background: rgba(14, 20, 35, 0.7);
    backdrop-filter: blur(24px);
    border: 1px solid rgba(77, 159, 255, 0.25);
    border-radius: var(--radius-pill);
    padding: 6px 6px 6px 18px;
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.1), 0 0 16px rgba(77, 159, 255, 0.06), 0 2px 12px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255,255,255,0.06);
    transition: box-shadow var(--transition), border-color var(--transition);
}
.quick-ai-input-wrap:focus-within {
    border-color: rgba(77, 159, 255, 0.5);
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.3), 0 0 24px rgba(77, 159, 255, 0.15), 0 2px 16px rgba(0, 0, 0, 0.25);
}
.quick-ai-input {
    flex: 1;
    background: transparent;
    border: none;
    color: #ffffff;
    font-size: 15px;
    padding: 10px 4px;
    outline: none;
    font-family: inherit;
}
.quick-ai-input::placeholder {
    color: var(--text-tertiary);
}
.quick-ai-send {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-pill);
    background: var(--accent-gradient);
    border: none;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 0 12px var(--accent-glow);
}
.quick-ai-send:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-neon), 0 4px 12px rgba(0, 0, 0, 0.3);
}
.quick-ai-send:active {
    transform: scale(0.96);
}

/* Dashboard — яркие кнопки с эффектом glass */
#page-dashboard .btn-pill {
    background: rgba(77, 159, 255, 0.28);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(77, 159, 255, 0.5);
    color: #fff;
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.25), inset 0 1px 0 rgba(255,255,255,0.15);
}
#page-dashboard .btn-pill:hover {
    background: rgba(77, 159, 255, 0.4);
    box-shadow: 0 0 24px rgba(77, 159, 255, 0.4), 0 0 0 1px rgba(77, 159, 255, 0.5), inset 0 1px 0 rgba(255,255,255,0.2);
}
#page-dashboard .progress-card.glass-card {
    background: rgba(14, 22, 40, 0.75);
    border: 1px solid rgba(77, 159, 255, 0.3);
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.2), 0 0 24px rgba(77, 159, 255, 0.12), inset 0 1px 0 rgba(255,255,255,0.1);
}
#page-dashboard .quick-ai-input-wrap {
    background: rgba(14, 20, 35, 0.85);
    border: 1px solid rgba(77, 159, 255, 0.35);
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.15), 0 0 20px rgba(77, 159, 255, 0.1), inset 0 1px 0 rgba(255,255,255,0.06);
}
#page-dashboard .quick-ai-send {
    box-shadow: 0 0 18px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,0.2);
}
#page-dashboard .hero-card {
    box-shadow: 0 4px 28px rgba(0, 0, 0, 0.4);
}

/* Section headers */
.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}
.section-header h2 {
    font-size: 17px;
    font-weight: 700;
    color: #ffffff;
    text-shadow: var(--text-glow);
}
.btn-text {
    background: rgba(77, 159, 255, 0.15);
    border: 1px solid rgba(77, 159, 255, 0.3);
    color: var(--accent-bright);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-family: inherit;
    transition: all var(--transition);
    text-shadow: 0 0 8px rgba(77, 159, 255, 0.3);
}
.btn-text:hover {
    background: rgba(77, 159, 255, 0.25);
    transform: translateY(-1px);
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.25);
}

/* ===== TASK LIST & CARDS ===== */
.task-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 24px;
}
.task-card {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: 16px;
    padding: 14px 16px 12px;
    box-shadow: 0 2px 16px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.05);
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.3s ease;
}
.task-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 24px rgba(0,0,0,0.28), 0 0 0 1px rgba(77,159,255,0.12);
}
.task-card.task-removing {
    opacity: 0;
    transform: translateX(24px) scale(0.96);
}
.task-card-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}
.task-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--accent);
    flex-shrink: 0;
    box-shadow: 0 0 6px var(--accent-glow);
}
.task-dot.done { background: var(--success); box-shadow: 0 0 6px var(--success-glow); }
.task-dot.overdue { background: var(--danger); box-shadow: 0 0 6px var(--danger-glow); }
.task-content { flex: 1; min-width: 0; }
.task-text {
    font-size: 15px;
    font-weight: 500;
    color: #ffffff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.task-time {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 2px;
}
.task-card-actions {
    display: flex;
    gap: 8px;
}
.task-btn-done {
    flex: 1;
    background: linear-gradient(135deg, rgba(52,199,89,0.18) 0%, rgba(52,199,89,0.1) 100%);
    border: 1px solid rgba(52,199,89,0.35);
    color: #34c759;
    font-size: 13px;
    font-weight: 600;
    padding: 7px 0;
    border-radius: 10px;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.18s ease;
    letter-spacing: 0.1px;
}
.task-btn-done:hover {
    background: linear-gradient(135deg, rgba(52,199,89,0.3) 0%, rgba(52,199,89,0.2) 100%);
    border-color: rgba(52,199,89,0.6);
}
.task-btn-done:active { transform: scale(0.96); }
.task-btn-postpone {
    flex: 1;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.55);
    font-size: 13px;
    font-weight: 500;
    padding: 7px 0;
    border-radius: 10px;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.18s ease;
    letter-spacing: 0.1px;
}
.task-btn-postpone:hover {
    background: rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.8);
}
.task-btn-postpone:active { transform: scale(0.96); }

/* Backwards compat: keep .task-item for planner page */
.task-item {
    display: flex;
    align-items: center;
    gap: 12px;
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 14px 16px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.04);
    transition: transform var(--transition), box-shadow var(--transition);
}
.task-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.3), 0 0 0 1px rgba(77,159,255,0.15);
}
.task-item:active { transform: scale(0.98); }

/* Goals scroll */
.goals-scroll {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 8px;
    margin-bottom: 16px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.goals-scroll::-webkit-scrollbar { display: none; }

.goal-card-mini {
    min-width: 160px;
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 16px;
    flex-shrink: 0;
    box-shadow: var(--shadow-glow-subtle), inset 0 1px 0 rgba(255,255,255,0.04);
    transition: transform var(--transition), box-shadow var(--transition);
}
.goal-card-mini:hover {
    transform: translateY(-2px);
    box-shadow: 0 0 0 1px var(--border-glow), var(--shadow-neon);
}
.goal-card-title {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 10px;
    color: #ffffff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.goal-mini-bar {
    height: 6px;
    background: rgba(77, 159, 255, 0.12);
    border-radius: 3px;
    overflow: hidden;
    margin-bottom: 6px;
}
.goal-mini-fill {
    height: 100%;
    background: var(--accent-gradient);
    border-radius: 3px;
    transition: width 0.8s ease;
    box-shadow: 0 0 8px var(--accent-glow);
}
.goal-mini-pct {
    font-size: 12px;
    color: var(--text-secondary);
}

/* Empty states */
.empty-state-mini {
    text-align: center;
    padding: 24px 16px;
    color: var(--text-tertiary);
    font-size: 14px;
    font-weight: 500;
}

/* ===== CHAT PAGE ===== */

.chat-page {
    display: flex;
    flex-direction: column;
    height: calc(100vh - var(--header-height) - var(--tab-height));
    height: calc(100dvh - var(--header-height) - var(--tab-height));
    position: relative;
}

.message {
    max-width: 82%;
    padding: 10px 14px;
    border-radius: 16px;
    font-size: 15px;
    line-height: 1.45;
    word-wrap: break-word;
    animation: msgAppear 0.2s ease;
}
@keyframes msgAppear {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

.message.user {
    background: var(--accent-gradient);
    color: #fff;
    align-self: flex-end;
    border-bottom-right-radius: 4px;
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.25);
}
.message.assistant {
    background: rgba(14, 20, 35, 0.8);
    backdrop-filter: blur(16px);
    color: #ffffff;
    border: 1px solid var(--border-light);
    align-self: flex-start;
    border-bottom-left-radius: 4px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255,255,255,0.04);
}
.message.typing {
    color: var(--text-secondary);
}

/* Gemini-style formatted AI messages */
.ai-msg-formatted {
    line-height: 1.6;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.ai-msg-formatted p {
    margin: 0 0 0.6em 0;
}
.ai-msg-formatted p:last-child { margin-bottom: 0; }
.ai-msg-formatted strong {
    color: var(--accent-bright);
    font-weight: 700;
}
.ai-msg-formatted ul, .ai-msg-formatted ol {
    margin: 0.4em 0 0.6em 0;
    padding-left: 1.4em;
}
.ai-msg-formatted li {
    margin-bottom: 0.3em;
    line-height: 1.5;
}
.ai-msg-formatted ul li::marker {
    color: var(--accent);
}
.ai-msg-formatted ol li::marker {
    color: var(--accent-bright);
    font-weight: 600;
}
.ai-msg-formatted table {
    display: table !important;
    width: 100% !important;
    max-width: 100% !important;
    border-collapse: collapse !important;
    margin: 1rem 0 !important;
    background: #ffffff;
    table-layout: fixed;
}
.ai-msg-formatted th,
.ai-msg-formatted td {
    border: 1px solid #e2e8f0 !important;
    padding: 8px 8px !important;
    font-size: 0.78rem !important;
    text-align: center !important;
    vertical-align: top !important;
    word-break: break-word;
}
.ai-msg-formatted thead {
    background: #f8fafc !important;
    font-weight: 600;
}

.ai-msg-formatted code {
    background: rgba(14, 20, 35, 0.55);
    border: 1px solid rgba(77, 159, 255, 0.18);
    border-radius: 8px;
    padding: 2px 6px;
    font-size: 0.92em;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.ai-msg-formatted pre {
    background: #0b1220;
    color: #e2e8f0;
    border-radius: 12px;
    padding: 14px 16px;
    overflow-x: auto;
    margin: 0.8em 0;
    border: 1px solid rgba(77, 159, 255, 0.12);
}
.ai-msg-formatted pre code {
    background: transparent;
    border: none;
    padding: 0;
    font-size: 0.88em;
}

.ai-msg-formatted blockquote {
    margin: 0.8em 0;
    padding: 10px 14px;
    background: rgba(77, 159, 255, 0.08);
    border-left: 3px solid rgba(77, 159, 255, 0.9);
    border-radius: 12px;
}

.ai-msg-formatted a {
    color: #93c5fd;
    text-decoration: underline;
    text-decoration-thickness: 1px;
}

.ai-msg-formatted hr {
    border: none;
    border-top: 1px solid rgba(77, 159, 255, 0.18);
    margin: 1rem 0;
}

.ai-msg-formatted h1,
.ai-msg-formatted h2,
.ai-msg-formatted h3,
.ai-msg-formatted h4 {
    margin: 0.9em 0 0.45em 0;
    font-weight: 800;
    letter-spacing: -0.01em;
}
.ai-msg-formatted h2 { font-size: 1.25em; }
.ai-msg-formatted h3 { font-size: 1.12em; }
.ai-msg-formatted h4 { font-size: 1.02em; }

@media (max-width: 640px) {
    .message { max-width: 92%; }
    .ai-msg-formatted table {
        font-size: 0.78rem !important;
        margin: 0.65rem 0 !important;
    }
    .ai-msg-formatted th,
    .ai-msg-formatted td {
        padding: 6px 6px !important;
        font-size: 0.74rem !important;
    }
}

/* TTS speaker button on AI messages */
.message.assistant {
    position: relative;
}
.tts-speak-btn {
    position: absolute;
    bottom: 6px;
    right: 6px;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 50%;
    background: rgba(var(--accent-rgb, 168,85,247), 0.15);
    color: var(--accent, #a855f7);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.5;
    transition: opacity 0.2s, background 0.2s, transform 0.15s, box-shadow 0.2s;
    z-index: 2;
    padding: 0;
}
.tts-speak-btn:hover {
    opacity: 1;
    background: rgba(var(--accent-rgb, 168,85,247), 0.28);
    box-shadow: 0 0 10px rgba(var(--accent-rgb, 168,85,247), 0.35);
    transform: scale(1.1);
}
.tts-speak-btn.tts-loading {
    opacity: 1;
    animation: tts-pulse 1s ease-in-out infinite;
}
.tts-speak-btn.tts-playing {
    opacity: 1;
    background: rgba(var(--accent-rgb, 168,85,247), 0.35);
    box-shadow: 0 0 14px rgba(var(--accent-rgb, 168,85,247), 0.5);
    animation: tts-glow 1.5s ease-in-out infinite;
}
@keyframes tts-pulse {
    0%, 100% { transform: scale(1); opacity: 0.7; }
    50% { transform: scale(1.15); opacity: 1; }
}
@keyframes tts-glow {
    0%, 100% { box-shadow: 0 0 10px rgba(var(--accent-rgb, 168,85,247), 0.4); }
    50% { box-shadow: 0 0 20px rgba(var(--accent-rgb, 168,85,247), 0.7); }
}
.tts-speak-btn svg {
    pointer-events: none;
}

.chat-input-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    padding-bottom: calc(12px + var(--safe-bottom));
    background: rgba(6, 10, 18, 0.92);
    backdrop-filter: blur(28px);
    border-top: 1px solid rgba(77, 159, 255, 0.1);
    box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.25);
    position: relative;
    z-index: 10;
}
#assistant-attach {
    position: relative;
    z-index: 5;
    cursor: pointer;
    pointer-events: auto;
    min-width: 42px;
    min-height: 42px;
    flex-shrink: 0;
}
#file-input {
    position: absolute;
    width: 0;
    height: 0;
    opacity: 0;
    pointer-events: none;
}

.btn-icon {
    width: 42px;
    height: 42px;
    border-radius: var(--radius-pill);
    background: rgba(77, 159, 255, 0.1);
    border: 1px solid rgba(77, 159, 255, 0.2);
    color: var(--accent-light);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--transition);
}
.btn-icon:hover {
    background: rgba(77, 159, 255, 0.2);
    transform: translateY(-2px);
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.2);
}
.btn-icon:active { background: var(--bg-primary); transform: scale(0.96); }
.btn-icon.recording {
    background: var(--danger);
    color: #fff;
    border-color: var(--danger);
    animation: pulse-rec 1.2s ease infinite;
    box-shadow: 0 0 20px var(--danger-glow);
}
@keyframes pulse-rec {
    0%, 100% { box-shadow: 0 0 0 0 var(--danger-glow); }
    50% { box-shadow: 0 0 0 8px rgba(248, 113, 113, 0); }
}

.chat-input {
    flex: 1;
    background: rgba(14, 20, 35, 0.8);
    border: 1px solid rgba(77, 159, 255, 0.2);
    border-radius: var(--radius-pill);
    color: #ffffff;
    font-size: 15px;
    padding: 12px 18px;
    outline: none;
    font-family: inherit;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.chat-input:focus {
    border-color: rgba(77, 159, 255, 0.5);
    box-shadow: 0 0 0 3px rgba(77, 159, 255, 0.15), 0 0 12px rgba(77, 159, 255, 0.1);
}
.chat-input::placeholder {
    color: var(--text-tertiary);
}

.btn-send {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-pill);
    background: var(--accent-gradient);
    border: none;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 0 12px var(--accent-glow);
}
.btn-send:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-neon), 0 4px 12px rgba(0, 0, 0, 0.3);
}
.btn-send:active { transform: scale(0.94); }

/* ===== FILE PREVIEW STRIP ===== */

.file-preview-strip {
    display: flex;
    gap: 8px;
    padding: 8px 14px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    background: rgba(6, 10, 18, 0.85);
    border-top: 1px solid rgba(77, 159, 255, 0.08);
    border-bottom: 1px solid rgba(77, 159, 255, 0.08);
}
.file-preview-strip::-webkit-scrollbar { display: none; }

.file-preview-item {
    position: relative;
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(77, 159, 255, 0.25);
    overflow: hidden;
    background: rgba(14, 20, 35, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
}
.file-preview-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.file-preview-icon {
    font-size: 11px;
    font-weight: 700;
    color: var(--accent-bright);
    text-transform: uppercase;
    text-align: center;
    line-height: 1.2;
    padding: 4px;
    word-break: break-all;
}
.file-preview-remove {
    position: absolute;
    top: -2px;
    right: -2px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: rgba(248, 113, 113, 0.85);
    border: none;
    color: #fff;
    font-size: 13px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: all var(--transition);
}
.file-preview-remove:hover {
    background: var(--danger);
    transform: scale(1.1);
    box-shadow: 0 0 8px var(--danger-glow);
}
.file-count-badge {
    font-size: 11px;
    color: var(--text-tertiary);
    align-self: center;
    flex-shrink: 0;
    white-space: nowrap;
}

/* ===== PLANNER ===== */

.planner-full { padding-bottom: 100px; }

/* View toggle */
.planner-view-toggle {
    display: flex;
    gap: 4px;
    padding: 4px;
    background: rgba(14, 20, 35, 0.7);
    border-radius: var(--radius-pill);
    border: 1px solid rgba(77, 159, 255, 0.12);
    margin-bottom: 12px;
}
.pvt-btn {
    flex: 1;
    padding: 8px 0;
    background: transparent;
    border: none;
    border-radius: var(--radius-pill);
    color: var(--text-tertiary);
    font-size: 13px;
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: all var(--transition);
}
.pvt-btn:hover { color: var(--text-secondary); }
.pvt-btn.active {
    background: var(--accent-gradient);
    color: #ffffff;
    box-shadow: 0 0 12px var(--accent-glow);
}

/* Calendar container */
.planner-calendar { margin-bottom: 16px; }

/* Month navigation */
.month-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 4px;
    margin-bottom: 8px;
}
.month-nav-title {
    font-size: 16px;
    font-weight: 700;
    color: #ffffff;
    text-shadow: var(--text-glow);
}
.month-nav-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(77, 159, 255, 0.1);
    border: 1px solid rgba(77, 159, 255, 0.2);
    color: var(--accent-bright);
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition);
}
.month-nav-btn:hover {
    background: rgba(77, 159, 255, 0.2);
    box-shadow: 0 0 10px rgba(77, 159, 255, 0.2);
}

/* Month grid */
.month-grid { overflow: hidden; }
.month-grid-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    margin-bottom: 4px;
}
.mg-header-cell {
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    padding: 4px 0;
}
.month-grid-body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}
.mg-cell {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    background: rgba(14, 20, 35, 0.4);
    border: 1px solid transparent;
    cursor: pointer;
    position: relative;
    transition: all var(--transition);
    gap: 2px;
}
.mg-cell.empty { background: transparent; cursor: default; }
.mg-cell:not(.empty):hover {
    background: rgba(77, 159, 255, 0.1);
    border-color: rgba(77, 159, 255, 0.2);
}
.mg-cell.today {
    border-color: var(--accent);
    box-shadow: 0 0 8px rgba(77, 159, 255, 0.2);
}
.mg-cell.selected {
    background: rgba(77, 159, 255, 0.2);
    border-color: var(--accent);
    box-shadow: 0 0 12px rgba(77, 159, 255, 0.3);
}
.mg-day-num {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}
.mg-cell.today .mg-day-num { color: var(--accent-bright); text-shadow: 0 0 8px var(--accent-glow); }
.mg-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
}
.mg-dot.dot-normal {
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent-glow);
}
.mg-dot.dot-overdue {
    background: var(--danger);
    box-shadow: 0 0 6px var(--danger-glow);
}

/* Day dot indicator (week view) */
.day-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 6px var(--accent-glow);
    margin-top: 2px;
}

/* Year grid */
.year-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}
.mini-month {
    background: rgba(14, 20, 35, 0.5);
    border: 1px solid rgba(77, 159, 255, 0.1);
    border-radius: var(--radius-md);
    padding: 12px 10px;
    cursor: pointer;
    transition: all var(--transition);
    text-align: center;
}
.mini-month:hover {
    background: rgba(77, 159, 255, 0.08);
    border-color: rgba(77, 159, 255, 0.25);
    transform: translateY(-2px);
}
.mini-month.current {
    border-color: var(--accent);
    box-shadow: 0 0 12px rgba(77, 159, 255, 0.2);
}
.mini-month-name {
    font-size: 13px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 4px;
}
.mini-month-count {
    font-size: 11px;
    color: var(--text-tertiary);
    margin-bottom: 6px;
}
.mini-month-bar {
    height: 3px;
    background: rgba(77, 159, 255, 0.12);
    border-radius: 2px;
    overflow: hidden;
}
.mini-month-fill {
    height: 100%;
    background: var(--accent-gradient);
    border-radius: 2px;
    box-shadow: 0 0 6px var(--accent-glow);
}

/* Month summary in year view */
.planner-month-summary {
    padding: 10px 14px;
    background: rgba(14, 20, 35, 0.5);
    border: 1px solid rgba(77, 159, 255, 0.1);
    border-radius: var(--radius-sm);
    margin-bottom: 6px;
    border-left: 3px solid var(--accent);
}
.pms-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
}

.week-strip {
    display: flex;
    gap: 6px;
    padding: 4px 0 16px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.week-strip::-webkit-scrollbar { display: none; }

.week-day {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 10px 14px;
    border-radius: var(--radius-md);
    background: var(--bg-card);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border-light);
    cursor: pointer;
    min-width: 52px;
    transition: all var(--transition);
}
.week-day:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}
.week-day.today {
    background: var(--accent-gradient);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 0 0 1px rgba(77, 159, 255, 0.5), var(--shadow-neon);
}
.week-day.selected:not(.today) {
    border-color: var(--border-active);
    box-shadow: var(--shadow-glow-subtle);
}
.week-day-name {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--text-secondary);
}
.week-day.today .week-day-name { color: rgba(255,255,255,0.9); }
.week-day-num {
    font-size: 17px;
    font-weight: 700;
    color: #ffffff;
}

.planner-task-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-bottom: 80px;
}

/* Planner task — NEON left strip */
.planner-task {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 14px 16px;
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--accent);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255,255,255,0.04), -4px 0 16px rgba(77, 159, 255, 0.15);
    transition: transform var(--transition), box-shadow var(--transition);
    position: relative;
}
.planner-task::before {
    content: '';
    position: absolute;
    left: -1px;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--accent);
    box-shadow: 0 0 12px var(--accent-glow), 0 0 24px rgba(77, 159, 255, 0.2);
    border-radius: 4px 0 0 4px;
}
.planner-task:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(77, 159, 255, 0.15), -4px 0 20px rgba(77, 159, 255, 0.2);
}
.planner-task:active { transform: scale(0.98); }
.planner-task.overdue {
    border-left-color: var(--danger);
}
.planner-task.overdue::before {
    background: var(--danger);
    box-shadow: 0 0 12px var(--danger-glow), 0 0 24px rgba(248, 113, 113, 0.2);
}
.planner-task.done {
    border-left-color: var(--success);
    opacity: 0.6;
}
.planner-task.done::before {
    background: var(--success);
    box-shadow: 0 0 12px var(--success-glow);
}

.planner-task-time {
    font-size: 13px;
    font-weight: 700;
    color: var(--accent-bright);
    min-width: 50px;
    flex-shrink: 0;
    text-shadow: 0 0 8px rgba(77, 159, 255, 0.3);
}
.planner-task.overdue .planner-task-time { color: var(--danger); text-shadow: 0 0 8px var(--danger-glow); }
.planner-task-text {
    font-size: 15px;
    font-weight: 500;
    flex: 1;
    color: #ffffff;
}

.fab {
    position: fixed;
    bottom: calc(var(--tab-height) + var(--safe-bottom) + 20px);
    right: 24px;
    width: 56px;
    height: 56px;
    border-radius: var(--radius-pill);
    background: var(--accent-gradient);
    border: none;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-neon), 0 6px 20px rgba(0, 0, 0, 0.4);
    z-index: 50;
    transition: transform var(--transition), box-shadow var(--transition);
}
.fab:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 0 0 4px rgba(77, 159, 255, 0.2), 0 0 40px var(--accent-glow), 0 8px 24px rgba(0, 0, 0, 0.45);
}
.fab:active { transform: scale(0.94); }

/* ===== GOALS PAGE ===== */

/* ===== PLANNER TASK CARDS ===== */
#planner-tasks {
    transition: opacity 0.12s ease;
    min-height: 48px;
}
.planner-task-card {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-left: 3px solid var(--accent);
    border-radius: 14px;
    padding: 14px 14px 11px;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    box-shadow: 0 2px 14px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.04);
}
.planner-task-card:hover { transform: translateY(-2px); box-shadow: 0 6px 22px rgba(0,0,0,0.28); }
.planner-task-card.overdue { border-left-color: var(--danger); }
.planner-task-card.done { border-left-color: var(--success); }
/* Не снижаем opacity у карточки — иначе просвечивает красная кнопка «Удалить» */

/* Swipe-to-delete — кнопка видна только после свайпа */
.planner-card-swipe {
    position: relative;
    overflow: hidden;
    border-radius: 16px;
    margin-bottom: 10px;
}
.ptc-swipe-content {
    position: relative;
    z-index: 2;
    width: 100%;
    min-width: 100%;
    border-radius: 16px;
    transition: transform 0.32s cubic-bezier(0.25, 0.46, 0.45, 0.94), box-shadow 0.28s ease;
    will-change: transform;
    background: var(--bg-card);
    box-shadow: 0 2px 14px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.04);
}
.planner-card-swipe.swipe-open .ptc-swipe-content {
    transform: translateX(-80px);
    box-shadow: -8px 0 24px rgba(0,0,0,0.18), 0 2px 14px rgba(0,0,0,0.22);
}
.ptc-swipe-delete {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: #fff;
    cursor: pointer;
    z-index: 1;
    border-radius: 0 16px 16px 0;
    background: linear-gradient(135deg, #ff3b30 0%, #e6352a 100%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.12), 0 2px 12px rgba(255,59,48,0.35);
}
.ptc-swipe-delete::before {
    content: '';
    width: 20px;
    height: 20px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 6 5 6 21 6'%3E%3Cpath d='M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2'%3E%3Cline x1='10' y1='11' x2='10' y2='17'%3E%3Cline x1='14' y1='11' x2='14' y2='17'%3E%3C/svg%3E") center/contain no-repeat;
    opacity: 0.95;
}
.ptc-swipe-delete:active {
    background: linear-gradient(135deg, #e6352a 0%, #cc2d23 100%);
    transform: scale(0.98);
}
.planner-swipe-hint {
    font-size: 11px;
    color: var(--text-secondary);
    text-align: center;
    margin-bottom: 8px;
    padding: 0 8px;
}
.planner-day-actions { margin-bottom: 10px; }
.planner-day-actions .btn-pill-outline { font-size: 13px; }

.ptc-header { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 10px; }
.ptc-dot {
    width: 9px; height: 9px; border-radius: 50%; background: var(--accent);
    flex-shrink: 0; margin-top: 5px; box-shadow: 0 0 6px var(--accent-glow);
}
.ptc-dot.done { background: var(--success); box-shadow: 0 0 6px var(--success-glow); }
.ptc-dot.overdue { background: var(--danger); box-shadow: 0 0 6px var(--danger-glow); }
.ptc-content { flex: 1; min-width: 0; }
.ptc-text { font-size: 15px; font-weight: 500; color: #fff; margin-bottom: 3px; }
.ptc-text.strikethrough { text-decoration: line-through; opacity: 0.6; }
.ptc-meta { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.ptc-time { font-size: 12px; color: var(--text-secondary); }
.ptc-recur {
    font-size: 11px; font-weight: 600; padding: 2px 7px;
    background: rgba(77,159,255,0.15); border-radius: 20px;
    color: var(--accent-bright); border: 1px solid rgba(77,159,255,0.25);
}
.ptc-status-done {
    font-size: 11px; font-weight: 600; padding: 2px 7px;
    background: rgba(52,199,89,0.15); border-radius: 20px;
    color: #34c759; border: 1px solid rgba(52,199,89,0.3);
}
.ptc-actions { display: flex; gap: 7px; }
.ptc-btn {
    flex: 1; font-size: 12px; font-weight: 600; padding: 6px 0;
    border-radius: 9px; cursor: pointer; font-family: inherit;
    transition: all 0.16s ease; letter-spacing: 0.1px;
}
.ptc-btn-done {
    background: linear-gradient(135deg, rgba(52,199,89,0.18), rgba(52,199,89,0.1));
    border: 1px solid rgba(52,199,89,0.35); color: #34c759;
}
.ptc-btn-done:hover { background: rgba(52,199,89,0.28); border-color: rgba(52,199,89,0.6); }
.ptc-btn-edit {
    background: rgba(77,159,255,0.1); border: 1px solid rgba(77,159,255,0.25);
    color: var(--accent-bright);
}
.ptc-btn-edit:hover { background: rgba(77,159,255,0.2); border-color: rgba(77,159,255,0.5); }
.ptc-btn-reopen {
    background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14);
    color: rgba(255,255,255,0.6);
}
.ptc-btn-reopen:hover { background: rgba(255,255,255,0.12); color: #fff; }
.ptc-btn-progress {
    background: rgba(250,196,84,0.1); border: 1px solid rgba(250,196,84,0.3);
    color: #fac444;
}
.ptc-btn-progress:hover { background: rgba(250,196,84,0.2); border-color: rgba(250,196,84,0.55); }
.ptc-btn:active { transform: scale(0.95); }

/* ===== GOALS FULL LIST ===== */
.goals-full-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 20px;
}

/* Legacy goal-item kept for dashboard mini cards */
.goal-item {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 16px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}
.goal-title { font-size: 16px; font-weight: 700; margin-bottom: 4px; color: #fff; }
.goal-description { font-size: 13px; color: var(--text-secondary); margin-bottom: 10px; }
.goal-progress { height: 6px; background: rgba(77,159,255,0.12); border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.goal-progress-bar { height: 100%; background: var(--accent-gradient); border-radius: 3px; transition: width 0.8s ease; }
.goal-pct { font-size: 12px; color: var(--text-secondary); }

/* ===== GOAL FULL CARD ===== */
.goal-card-full {
    border-radius: 16px;
    padding: 16px 16px 12px;
    box-shadow: 0 2px 16px rgba(0,0,0,0.22), inset 0 1px 0 rgba(255,255,255,0.05);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.goal-card-full:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(0,0,0,0.28); }
.goal-card-full.done { opacity: 0.75; }
.goal-card-body { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.goal-card-info { flex: 1; min-width: 0; }
.goal-card-title {
    font-size: 16px; font-weight: 700; color: #fff; margin-bottom: 4px; word-break: break-word;
}
.goal-card-title.strikethrough { text-decoration: line-through; opacity: 0.6; }
.goal-card-desc { font-size: 13px; color: var(--text-secondary); line-height: 1.5; word-break: break-word; }
.goal-card-actions { display: flex; gap: 7px; }
.goal-donut-wrap { flex-shrink: 0; }
.goal-donut-svg { width: 72px; height: 72px; }
.goal-donut-text {
    font-size: 15px; font-weight: 700; fill: #ffffff;
    font-family: -apple-system, 'SF Pro Display', sans-serif;
}

.btn-accent-small {
    background: var(--accent-gradient);
    border: none;
    color: #fff;
    padding: 8px 16px;
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    transition: transform var(--transition), box-shadow var(--transition);
    box-shadow: 0 0 16px var(--accent-glow), 0 0 0 1px rgba(77, 159, 255, 0.3);
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.btn-accent-small:hover {
    box-shadow: 0 0 24px var(--accent-glow-strong), 0 0 48px rgba(77, 159, 255, 0.15);
    transform: translateY(-2px);
}
.btn-accent-small:active { transform: scale(0.95); }

/* ===== MORE PAGE ===== */

.page-title {
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 20px;
    color: #ffffff;
    text-shadow: var(--text-glow);
}

/* Back button row */
.btn-back-row {
    background: none;
    border: none;
    color: var(--accent-bright);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    padding: 8px 0;
    margin-bottom: 8px;
    font-family: inherit;
    display: flex;
    align-items: center;
    gap: 4px;
    text-shadow: 0 0 8px rgba(77, 159, 255, 0.3);
}

/* ===== SUB-PAGES ===== */

/* Templates */
.templates-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

/* Games — все карточки в стиле МоноСлово (премиум) */
.games-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.game-card {
    background: linear-gradient(135deg, rgba(20, 65, 160, 0.22) 0%, rgba(8, 22, 60, 0.45) 100%);
    border: 1px solid rgba(30, 144, 255, 0.35);
    border-radius: var(--radius-md);
    padding: 18px 14px;
    text-align: center;
    transition: all var(--transition);
    box-shadow: 0 0 18px rgba(30, 144, 255, 0.18);
}
.game-card-premium {
    background: linear-gradient(135deg, rgba(20, 65, 160, 0.22) 0%, rgba(8, 22, 60, 0.45) 100%);
    border: 1px solid rgba(30, 144, 255, 0.35);
    box-shadow: 0 0 18px rgba(30, 144, 255, 0.18);
}
.games-grid-single {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.games-grid-single .game-card {
    width: 100%;
}
.games-grid-single .ms-featured-card {
    grid-column: unset;
}
.ms-featured-card {
    grid-column: span 2;
}
.ms-game-emoji { font-size: 30px; margin-bottom: 4px; line-height: 1; }
.ms-game-hot {
    display: inline-block;
    background: linear-gradient(90deg, #ff6b35, #ff9500);
    color: #ffffff;
    font-size: 10px;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 20px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-top: 4px;
}
.game-card:hover {
    border-color: var(--border-glow);
    box-shadow: var(--shadow-neon);
    transform: translateY(-2px);
}
.game-card:active { transform: scale(0.97); }
.game-icon { font-size: 28px; margin-bottom: 8px; }
.game-card h3 {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 2px;
    color: #ffffff;
}
.game-card p {
    font-size: 12px;
    color: var(--text-secondary);
    margin-bottom: 10px;
}
.btn-game {
    background: linear-gradient(135deg, #1e90ff 0%, #0060df 100%);
    border: none;
    color: #ffffff;
    font-weight: 700;
    padding: 8px 20px;
    border-radius: 20px;
    font-size: 13px;
    cursor: pointer;
    width: 100%;
    font-family: inherit;
    transition: all var(--transition);
    box-shadow: 0 0 14px rgba(30, 144, 255, 0.5), 0 0 4px rgba(255,255,255,0.1);
    text-shadow: 0 0 6px rgba(255,255,255,0.3);
}
.btn-game:hover { box-shadow: var(--shadow-neon); }
.btn-game:active { transform: scale(0.95); }

/* Stats */
.stats-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 24px;
}
.stat-card-mini {
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 16px 8px;
    text-align: center;
}
.stat-card-value {
    display: block;
    font-size: 24px;
    font-weight: 700;
    color: var(--accent-bright);
    margin-bottom: 2px;
    text-shadow: 0 0 12px var(--accent-glow);
}
.stat-card-label {
    display: block;
    font-size: 12px;
    color: var(--text-secondary);
    font-weight: 500;
}

.achievements-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.achievement-item {
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 14px;
    text-align: center;
}

/* Voice tone */
.voicetone-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.voicetone-item {
    background: var(--bg-card);
    backdrop-filter: blur(16px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 14px 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all var(--transition);
}
.voicetone-item.active {
    border-color: var(--border-active);
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.15), 0 0 0 1px rgba(77, 159, 255, 0.3);
}
.voicetone-item:hover { background: rgba(77, 159, 255, 0.08); }
.voicetone-item:active { background: var(--bg-elevated); }
.voicetone-name {
    font-size: 15px;
    font-weight: 600;
    color: #ffffff;
}
.voicetone-desc {
    font-size: 12px;
    color: var(--text-secondary);
}
.voicetone-check {
    margin-left: auto;
    color: var(--accent-bright);
    font-size: 18px;
    display: none;
    text-shadow: 0 0 8px var(--accent-glow);
}
.voicetone-item.active .voicetone-check { display: block; }

/* ===== TOAST ===== */

.toast-container {
    position: fixed;
    top: calc(var(--header-height) + 8px);
    left: 16px;
    right: 16px;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
}
.toast {
    background: rgba(14, 20, 35, 0.92);
    backdrop-filter: blur(20px);
    color: #ffffff;
    padding: 12px 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-light);
    box-shadow: var(--shadow-card), 0 0 16px rgba(0,0,0,0.3);
    font-size: 14px;
    font-weight: 600;
    animation: toastIn 0.3s ease;
    pointer-events: auto;
}
.toast.success { border-left: 3px solid var(--success); box-shadow: var(--shadow-card), 0 0 12px var(--success-glow); }
.toast.error { border-left: 3px solid var(--danger); box-shadow: var(--shadow-card), 0 0 12px var(--danger-glow); }
.toast.info { border-left: 3px solid var(--accent); box-shadow: var(--shadow-card), 0 0 12px var(--accent-glow); }

@keyframes toastIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===== MODAL / CREATE FORMS ===== */

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    z-index: 200;
    animation: fadeIn 0.2s ease;
}
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.modal-sheet {
    background: rgba(14, 20, 35, 0.95);
    backdrop-filter: blur(32px) saturate(150%);
    -webkit-backdrop-filter: blur(32px) saturate(150%);
    border-top-left-radius: var(--radius-xl);
    border-top-right-radius: var(--radius-xl);
    border: 1px solid rgba(77, 159, 255, 0.15);
    border-bottom: none;
    box-shadow: 0 -2px 0 rgba(77, 159, 255, 0.2), 0 -12px 48px rgba(0, 0, 0, 0.5);
    width: 100%;
    max-width: 440px;
    padding: 24px 20px;
    padding-bottom: calc(24px + var(--safe-bottom));
    animation: sheetUp 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes sheetUp {
    from { transform: translateY(100%); }
    to { transform: translateY(0); }
}

.modal-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 16px;
    color: #ffffff;
    text-shadow: var(--text-glow);
}
.email-modal-desc {
    font-size: 13px;
    color: rgba(255,255,255,0.55);
    line-height: 1.55;
    margin-bottom: 16px;
    margin-top: -6px;
}

.form-field {
    margin-bottom: 14px;
}
.form-label {
    display: block;
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 6px;
    font-weight: 600;
}
.form-input {
    width: 100%;
    background: rgba(14, 20, 35, 0.8);
    border: 1px solid rgba(77, 159, 255, 0.2);
    border-radius: var(--radius-sm);
    color: #ffffff;
    font-size: 15px;
    padding: 12px 14px;
    outline: none;
    font-family: inherit;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.form-input:focus {
    border-color: rgba(77, 159, 255, 0.5);
    box-shadow: 0 0 0 3px rgba(77, 159, 255, 0.12);
}
.form-select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%234d9fff' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
    cursor: pointer;
}
.form-select option {
    background: #0d1b2a;
    color: #fff;
}
.form-textarea {
    resize: vertical;
    min-height: 80px;
    line-height: 1.5;
}

.btn-primary {
    width: 100%;
    background: linear-gradient(135deg, #1e90ff 0%, #0060df 100%);
    border: none;
    color: #ffffff;
    padding: 15px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    margin-top: 4px;
    box-shadow: 0 0 18px rgba(30,144,255,0.55), 0 4px 16px rgba(0,96,223,0.4), inset 0 1px 0 rgba(255,255,255,0.25);
    letter-spacing: 0.2px;
    text-shadow: 0 0 8px rgba(255,255,255,0.4);
}
.btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 22px rgba(29,111,229,0.45), inset 0 1px 0 rgba(255,255,255,0.22);
}
.btn-primary:active {
    transform: scale(0.98) translateY(0);
    box-shadow: 0 2px 10px rgba(29,111,229,0.3);
}

.btn-secondary {
    width: 100%;
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255,255,255,0.22);
    color: #ffffff;
    padding: 13px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    margin-top: 8px;
    transition: all 0.18s ease;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.1), 0 0 10px rgba(255,255,255,0.05);
    text-shadow: 0 0 6px rgba(255,255,255,0.25);
}
.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.13);
    color: var(--text-primary);
    border-color: rgba(255,255,255,0.22);
}
.btn-secondary:active { transform: scale(0.98); }

/* ===== CHAT SESSIONS ===== */

.chat-header-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: rgba(6, 10, 18, 0.88);
    backdrop-filter: blur(28px);
    border-bottom: 1px solid rgba(77, 159, 255, 0.1);
}
.chat-session-title {
    flex: 1;
    font-size: 15px;
    font-weight: 700;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #ffffff;
}
.btn-glass-icon {
    width: 38px;
    height: 38px;
    border-radius: var(--radius-pill);
    background: rgba(77, 159, 255, 0.1);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(77, 159, 255, 0.2);
    color: var(--accent-light);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--transition);
}
.btn-glass-icon:hover {
    background: rgba(77, 159, 255, 0.2);
    border-color: rgba(77, 159, 255, 0.4);
    color: var(--accent-bright);
    box-shadow: 0 0 16px rgba(77, 159, 255, 0.2);
}
.btn-glass-icon.btn-sm { width: 30px; height: 30px; }

/* Sessions panel with backdrop overlay */
.chat-sessions-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    z-index: 55;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.chat-sessions-backdrop.visible {
    opacity: 1;
    pointer-events: auto;
}

.chat-sessions-panel {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    background: rgba(8, 12, 22, 0.95);
    backdrop-filter: blur(32px) saturate(140%);
    border-right: 1px solid rgba(77, 159, 255, 0.15);
    z-index: 60;
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.5), 4px 0 40px rgba(77, 159, 255, 0.05);
}
.chat-sessions-panel.open { transform: translateX(0); }
.sessions-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid rgba(77, 159, 255, 0.1);
}
.sessions-header h3 { font-size: 16px; font-weight: 700; color: #ffffff; }
.sessions-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.session-item {
    padding: 12px 14px;
    border-radius: var(--radius-md);
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid transparent;
    cursor: pointer;
    transition: all var(--transition);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.session-item:hover { background: rgba(77, 159, 255, 0.1); border-color: rgba(77, 159, 255, 0.15); }
.session-item.active { background: rgba(77, 159, 255, 0.18); border-color: rgba(77, 159, 255, 0.35); box-shadow: 0 0 12px rgba(77, 159, 255, 0.12); }
.session-item-title { font-size: 14px; font-weight: 500; color: #ffffff; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.session-item-edit {
    background: none; border: none; color: var(--text-tertiary); cursor: pointer;
    padding: 4px; opacity: 0; transition: opacity var(--transition);
}
.session-item:hover .session-item-edit { opacity: 1; }

.btn-clear-chat {
    margin: 8px 12px 12px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background var(--transition), color var(--transition);
}
.btn-clear-chat:hover { background: rgba(255, 100, 100, 0.15); color: #ff8888; }

.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    -webkit-overflow-scrolling: touch;
    background-image: url('../img/chat-bg.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* ===== MODULES ROW (chat page) ===== */

.chat-modules-block {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px 8px;
    background: rgba(6, 10, 18, 0.6);
    border-bottom: 1px solid rgba(77, 159, 255, 0.1);
}
.chat-modules-label {
    font-size: 12px;
    color: var(--text-tertiary);
    flex-shrink: 0;
}
.chat-modules-strip {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding: 2px 0;
}
.chat-modules-strip::-webkit-scrollbar { display: none; }
.module-chip {
    flex-shrink: 0;
    padding: 6px 12px;
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(77, 159, 255, 0.25);
    background: rgba(14, 22, 40, 0.7);
    backdrop-filter: blur(12px);
    color: var(--text-secondary);
    cursor: pointer;
    font-family: inherit;
    transition: all 0.2s;
}
.module-chip:hover {
    background: rgba(77, 159, 255, 0.12);
    border-color: rgba(77, 159, 255, 0.4);
    color: var(--accent-bright);
}
.module-chip.active {
    background: rgba(77, 159, 255, 0.22);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 0 12px rgba(77, 159, 255, 0.25);
}

.module-type-picker {
    display: flex;
    gap: 6px;
    padding: 8px 14px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    background: rgba(10, 16, 28, 0.85);
    border-bottom: 1px solid rgba(77, 159, 255, 0.08);
    flex-wrap: nowrap;
    align-items: center;
}
.module-type-picker::-webkit-scrollbar { display: none; }

.module-type-btn {
    padding: 6px 12px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-pill);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all var(--transition);
}
.module-type-btn:hover {
    background: rgba(77, 159, 255, 0.1);
    color: var(--accent-light);
}
.module-type-btn.active {
    background: var(--accent-gradient);
    border-color: var(--accent);
    color: #ffffff;
    box-shadow: 0 0 8px rgba(77, 159, 255, 0.3);
}
.module-type-close {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(248, 113, 113, 0.15);
    border: 1px solid rgba(248, 113, 113, 0.3);
    color: var(--danger);
    font-size: 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all var(--transition);
}
.module-type-close:hover {
    background: rgba(248, 113, 113, 0.3);
    box-shadow: 0 0 8px var(--danger-glow);
}

/* ===== MORE PAGE — Bright Glass Grid ===== */

.more-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.more-glass-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 28px 16px;
    background: rgba(14, 22, 40, 0.6);
    backdrop-filter: blur(24px) saturate(140%);
    -webkit-backdrop-filter: blur(24px) saturate(140%);
    border: 1px solid rgba(77, 159, 255, 0.2);
    border-radius: var(--radius-lg);
    cursor: pointer;
    color: #ffffff;
    font-family: inherit;
    transition: all var(--transition);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25), inset 0 1px 0 rgba(255,255,255,0.06);
    position: relative;
    overflow: hidden;
}
.more-glass-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
    pointer-events: none;
}
.more-glass-card:hover {
    background: rgba(77, 159, 255, 0.12);
    border-color: var(--border-glow);
    box-shadow: var(--shadow-neon), 0 4px 16px rgba(0, 0, 0, 0.3);
    transform: translateY(-3px);
}
.more-glass-card:active { transform: scale(0.97); }
.more-card-icon {
    width: 32px;
    height: 32px;
    stroke: var(--accent-bright);
    filter: drop-shadow(0 0 10px rgba(77, 159, 255, 0.4));
    transition: filter var(--transition);
}
.more-glass-card:hover .more-card-icon {
    filter: drop-shadow(0 0 16px rgba(77, 159, 255, 0.6));
}
.more-card-label {
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.4px;
    color: #ffffff;
    text-shadow: var(--text-glow);
}

/* ===== TEMPLATES — Bright active indicator ===== */

.page-subtitle {
    font-size: 13px;
    color: var(--accent-bright);
    margin-bottom: 16px;
    font-weight: 600;
    text-shadow: 0 0 8px rgba(77, 159, 255, 0.2);
}
.template-card {
    background: rgba(14, 22, 40, 0.6);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 16px;
    cursor: pointer;
    transition: all var(--transition);
    position: relative;
    overflow: hidden;
}
.template-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: transparent;
    transition: background var(--transition);
}
.template-card:hover {
    background: rgba(77, 159, 255, 0.08);
    border-color: rgba(77, 159, 255, 0.25);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(77, 159, 255, 0.15);
}
.template-card:active { transform: scale(0.98); }
.template-card.active {
    border-color: var(--border-active);
    background: rgba(77, 159, 255, 0.15);
    box-shadow: 0 0 0 1px var(--border-active), var(--shadow-neon);
}
.template-card.active::before {
    background: var(--accent-gradient);
    box-shadow: 0 0 8px var(--accent-glow);
}
.template-card.active::after {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 22px;
    height: 22px;
    background: var(--accent-gradient);
    border-radius: 50%;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 10px var(--accent-glow);
}
.template-remove-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(248, 113, 113, 0.2);
    border: 1px solid rgba(248, 113, 113, 0.4);
    color: var(--danger);
    font-size: 16px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition);
    z-index: 2;
}
.template-remove-btn:hover {
    background: rgba(248, 113, 113, 0.4);
    box-shadow: 0 0 12px var(--danger-glow);
    transform: scale(1.1);
}
.template-card-name {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 4px;
    color: #ffffff;
}
.template-card-desc {
    font-size: 12px;
    color: var(--text-secondary);
}

/* Pill button */
.btn-pill {
    background: rgba(77, 159, 255, 0.18);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(77, 159, 255, 0.35);
    color: var(--accent-bright);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    padding: 6px 14px;
    border-radius: var(--radius-pill);
    font-family: inherit;
    transition: all var(--transition);
    text-shadow: 0 0 8px rgba(77, 159, 255, 0.3);
    box-shadow: 0 0 8px rgba(77, 159, 255, 0.1);
}
.btn-pill:hover {
    background: rgba(77, 159, 255, 0.3);
    transform: translateY(-1px);
    box-shadow: 0 0 20px rgba(77, 159, 255, 0.3);
    border-color: rgba(77, 159, 255, 0.5);
}

/* ===== NOTIFICATIONS PAGE ===== */

.notifications-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.notification-item {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    padding: 14px 16px;
    display: flex;
    gap: 12px;
    align-items: flex-start;
    border-left: 4px solid var(--accent);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2), -4px 0 12px rgba(77, 159, 255, 0.1);
    transition: all var(--transition);
    position: relative;
}
.notification-item::before {
    content: '';
    position: absolute;
    left: -1px;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--accent);
    box-shadow: 0 0 10px var(--accent-glow);
    border-radius: 4px 0 0 4px;
}
.notification-item.urgent { border-left-color: var(--danger); }
.notification-item.urgent::before { background: var(--danger); box-shadow: 0 0 10px var(--danger-glow); }
.notification-item.success-type { border-left-color: var(--success); }
.notification-item.success-type::before { background: var(--success); box-shadow: 0 0 10px var(--success-glow); }
.notification-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(77, 159, 255, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid rgba(77, 159, 255, 0.2);
}
.notification-icon svg {
    width: 18px;
    height: 18px;
    stroke: var(--accent-bright);
}
.notification-content { flex: 1; }
.notification-title {
    font-size: 14px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 2px;
}
.notification-text {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.4;
}
.notification-time {
    font-size: 11px;
    color: var(--text-tertiary);
    margin-top: 4px;
}

.notification-settings {
    background: var(--bg-card);
    backdrop-filter: blur(20px);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.notification-setting-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}
.notification-setting-col {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
}
.notification-setting-desc {
    font-size: 12px;
    font-weight: 400;
    color: var(--text-tertiary);
    line-height: 1.35;
}
.notification-setting-row .toggle-switch {
    flex-shrink: 0;
    margin-top: 2px;
}
.notification-setting-label {
    font-size: 14px;
    font-weight: 600;
    color: #ffffff;
}
.toggle-switch {
    width: 44px;
    height: 24px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid var(--border-light);
    position: relative;
    cursor: pointer;
    transition: all var(--transition);
}
.toggle-switch.active {
    background: var(--accent-gradient);
    border-color: var(--accent);
    box-shadow: 0 0 10px var(--accent-glow);
}
.toggle-switch::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #ffffff;
    transition: transform var(--transition);
    box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.toggle-switch.active::after {
    transform: translateX(20px);
}

/* ===== VOICE RECORDING — Neon pulse animation ===== */

.voice-recording-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(8px);
    z-index: 250;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 24px;
    animation: fadeIn 0.3s ease;
}
.voice-pulse-container {
    position: relative;
    width: 140px;
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.voice-pulse-ring {
    position: absolute;
    border-radius: 50%;
    border: 2px solid var(--accent);
    animation: voicePulse 1.5s ease-out infinite;
}
.voice-pulse-ring:nth-child(1) { width: 80px; height: 80px; animation-delay: 0s; }
.voice-pulse-ring:nth-child(2) { width: 80px; height: 80px; animation-delay: 0.4s; }
.voice-pulse-ring:nth-child(3) { width: 80px; height: 80px; animation-delay: 0.8s; }
@keyframes voicePulse {
    0% { width: 60px; height: 60px; opacity: 1; border-color: var(--accent-bright); box-shadow: 0 0 20px var(--accent-glow); }
    50% { opacity: 0.6; border-color: var(--accent); }
    100% { width: 140px; height: 140px; opacity: 0; border-color: transparent; box-shadow: 0 0 40px rgba(77, 159, 255, 0); }
}
.voice-pulse-core {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--accent-gradient);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-neon);
    z-index: 1;
    animation: voiceCorePulse 1s ease-in-out infinite alternate;
    cursor: pointer;
}
@keyframes voiceCorePulse {
    from { transform: scale(1); box-shadow: var(--shadow-neon); }
    to { transform: scale(1.08); box-shadow: 0 0 16px var(--accent-glow-strong), 0 0 40px var(--accent-glow), 0 0 60px rgba(77, 159, 255, 0.15); }
}
.voice-pulse-core svg {
    width: 28px;
    height: 28px;
    stroke: #fff;
}
.voice-recording-text {
    font-size: 16px;
    font-weight: 600;
    color: var(--accent-bright);
    text-shadow: 0 0 12px var(--accent-glow);
    animation: voiceTextPulse 1.5s ease-in-out infinite;
}
@keyframes voiceTextPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
.voice-recording-timer {
    font-size: 24px;
    font-weight: 700;
    color: #ffffff;
    font-variant-numeric: tabular-nums;
}
.voice-recording-hint {
    font-size: 13px;
    color: var(--text-tertiary);
}

/* ===== HERO / SPACE IMAGE — landing page + pricing ===== */

/* .hero-space-image — removed, replaced by .hero-logo */
.pricing-logo-wrap {
    text-align: center;
    margin-bottom: 16px;
}
/* ===== PRICING PAGE — Apple minimal redesign ===== */
.pricing-page-content {
    padding-bottom: 40px;
}
.pricing-logo-img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: 18px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}

/* Hero */
.pricing-hero {
    text-align: center;
    padding: 10px 0 22px;
}
.pricing-hero-logo {
    width: 64px;
    height: 64px;
    object-fit: cover;
    border-radius: 14px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.4);
    margin-bottom: 14px;
}
.pricing-hero-title {
    font-size: 28px;
    font-weight: 800;
    color: #ffffff;
    letter-spacing: -0.5px;
    line-height: 1;
}
.pricing-hero-sub {
    font-size: 14px;
    font-weight: 500;
    color: rgba(255,255,255,0.5);
    margin-top: 4px;
    margin-bottom: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
}
.pricing-tagline {
    font-size: 15px;
    color: rgba(255,255,255,0.75);
    line-height: 1.6;
    margin: 0;
    font-weight: 400;
}

/* Scarcity bar */
.pricing-scarcity {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 20px;
}
.scarcity-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
    gap: 8px;
}
.scarcity-title {
    font-size: 13px;
    font-weight: 600;
    color: rgba(255,255,255,0.85);
}
.scarcity-count {
    font-size: 12px;
    color: rgba(255,255,255,0.5);
    white-space: nowrap;
}
.scarcity-count strong { color: #fff; font-weight: 700; }
.scarcity-bar-wrap {
    height: 4px;
    background: rgba(255,255,255,0.1);
    border-radius: 2px;
    overflow: hidden;
}
.scarcity-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #1976d2, #42a5f5);
    border-radius: 2px;
    transition: width 0.8s ease;
}

/* Subscription active block (Gemini/Cursor style) */
.pricing-subscription-status {
    background: linear-gradient(135deg, rgba(76, 175, 80, 0.18), rgba(56, 142, 60, 0.12));
    border: 1px solid rgba(76, 175, 80, 0.4);
    border-radius: 14px;
    padding: 16px 18px;
    margin-bottom: 20px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px 16px;
}
.pricing-subscription-status .sub-active-text {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}
.pricing-subscription-status .sub-active-text::before {
    content: '';
    width: 20px;
    height: 20px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%234caf50'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") no-repeat center;
    background-size: contain;
    flex-shrink: 0;
}
.pricing-subscription-status .sub-active-date {
    font-size: 14px;
    color: rgba(255,255,255,0.8);
    margin: 0;
}
.pricing-subscription-status .sub-badge-early-bird {
    display: inline-block;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, #1976d2, #42a5f5);
    border-radius: 20px;
    letter-spacing: 0.3px;
}

/* What's included */
.pricing-features-block {
    margin-bottom: 22px;
}
.pricing-features-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: rgba(255,255,255,0.4);
    margin-bottom: 10px;
}
.pricing-features-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.pricing-features-list li {
    font-size: 14px;
    color: rgba(255,255,255,0.8);
    padding-left: 22px;
    position: relative;
    line-height: 1.4;
}
.pricing-features-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 5px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid rgba(77,159,255,0.6);
    background: rgba(77,159,255,0.15);
}

/* Plans */
.pricing-plans {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 16px;
}

/* Featured plan — 3 months */
.pricing-plan-card {
    border-radius: 18px;
    position: relative;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.pricing-plan-card:hover { transform: translateY(-2px); }

.plan-featured {
    background: linear-gradient(145deg, rgba(21,101,192,0.35) 0%, rgba(13,71,161,0.25) 100%);
    border: 1.5px solid rgba(77,159,255,0.45);
    padding: 22px 20px 18px;
    box-shadow: 0 8px 32px rgba(29,111,229,0.2), inset 0 1px 0 rgba(255,255,255,0.08);
}
.plan-badge-featured {
    display: inline-block;
    background: linear-gradient(135deg, #1d6fe5, #1557c7);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.8px;
    padding: 4px 12px;
    border-radius: 20px;
    margin-bottom: 14px;
    box-shadow: 0 2px 10px rgba(29,111,229,0.35);
}
.plan-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 12px;
}
.plan-name {
    font-size: 20px;
    font-weight: 700;
    color: #ffffff;
}
.plan-price-wrap {
    text-align: right;
}
.plan-price {
    display: block;
    font-size: 26px;
    font-weight: 800;
    color: #ffffff;
    line-height: 1;
}
.plan-price-note {
    font-size: 12px;
    color: rgba(255,255,255,0.55);
    margin-top: 2px;
    display: block;
}
.plan-desc {
    font-size: 13px;
    color: rgba(255,255,255,0.65);
    line-height: 1.55;
    margin-bottom: 18px;
}
.btn-plan-primary {
    width: 100%;
    background: linear-gradient(135deg, #1d6fe5 0%, #1557c7 100%);
    border: none;
    color: #fff;
    padding: 15px;
    border-radius: 14px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    letter-spacing: 0.1px;
    box-shadow: 0 4px 16px rgba(29,111,229,0.38), inset 0 1px 0 rgba(255,255,255,0.18);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.btn-plan-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 22px rgba(29,111,229,0.48);
}
.btn-plan-primary:active { transform: scale(0.98); }
.btn-plan-primary:disabled { opacity: 0.6; cursor: default; transform: none; }

/* Secondary plan — 1 month */
.plan-secondary {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    padding: 16px 20px;
    opacity: 0.85;
}
.plan-name-secondary { font-size: 16px; font-weight: 600; color: rgba(255,255,255,0.7); }
.plan-price-secondary { font-size: 20px; font-weight: 700; color: rgba(255,255,255,0.7); }
.btn-plan-secondary {
    width: 100%;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.6);
    padding: 12px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.18s ease;
    margin-top: 12px;
}
.btn-plan-secondary:hover { background: rgba(255,255,255,0.12); color: rgba(255,255,255,0.9); }
.btn-plan-secondary:active { transform: scale(0.98); }
.btn-plan-secondary:disabled { opacity: 0.5; cursor: default; }

/* Legal */
.pricing-legal {
    font-size: 12px;
    color: rgba(255,255,255,0.35);
    line-height: 1.6;
    text-align: center;
    margin: 8px 0 18px;
    padding: 0 8px;
}

/* Future price note */
.pricing-future-note {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    margin-bottom: 24px;
    border-radius: 12px;
    opacity: 0.6;
}
.pfn-label {
    font-size: 12px;
    color: rgba(255,255,255,0.5);
}
.pfn-price {
    font-size: 14px;
    font-weight: 600;
    color: rgba(255,255,255,0.5);
    text-decoration: line-through;
}

/* FAQ section title */
.pricing-faq-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: rgba(255,255,255,0.4);
    margin-bottom: 12px;
}

/* Legacy compatibility — keep for any remaining references */
.pricing-card { display: none; }
.pricing-future .btn-primary { display: none; }

/* FAQ */
.faq-intro {
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 12px;
}
.faq-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-bottom: 24px;
}
.faq-item {
    padding: 0;
    overflow: hidden;
    border-radius: var(--radius-md);
    border: 1px solid rgba(77, 159, 255, 0.2);
}
.faq-item.open {
    overflow: visible;
}
.faq-item:hover {
    border-color: rgba(77, 159, 255, 0.35);
}
.faq-question-btn {
    width: 100%;
    padding: 14px 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    background: rgba(255,255,255,0.04);
    border: none;
    cursor: pointer;
    text-align: left;
    font-family: inherit;
    transition: background 0.2s, color 0.2s;
    -webkit-tap-highlight-color: transparent;
}
.faq-question-btn:hover,
.faq-question-btn:focus {
    background: rgba(77, 159, 255, 0.12);
    color: var(--accent-bright);
    outline: none;
}
.faq-item.open .faq-question-btn {
    background: rgba(77, 159, 255, 0.1);
    border-bottom: 1px solid rgba(77, 159, 255, 0.15);
}
.faq-arrow {
    font-size: 12px;
    color: var(--text-tertiary);
    transition: transform 0.25s ease;
    flex-shrink: 0;
}
.faq-item.open .faq-arrow {
    transform: rotate(180deg);
    color: var(--accent);
}
.faq-answer {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.55;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
    padding: 0 16px;
    margin: 0;
}
.faq-item.open .faq-answer {
    max-height: 500px;
    padding: 12px 16px 16px 16px;
    overflow-y: auto;
}
.templates-hint {
    font-size: 12px;
    color: var(--text-tertiary);
    margin: -4px 0 12px 0;
}

.instruction-block {
    padding: 16px 18px;
    margin-bottom: 14px;
}
.instruction-block p {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--text-secondary);
}
.instruction-h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--accent-bright);
    margin: 0 0 10px 0;
    text-shadow: 0 0 10px rgba(77, 159, 255, 0.2);
}

/* ===== RESPONSIVE — Desktop (PC in Telegram + vectorargus.ru) ===== */

/* Tablet */
@media (min-width: 768px) {
    .pages-container {
        max-width: 520px;
        margin: 0 auto;
    }
    .tab-bar {
        max-width: 520px;
        left: 50%;
        transform: translateX(-50%);
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    }
    .app-header {
        max-width: 520px;
        left: 50%;
        transform: translateX(-50%);
    }
    .fab { right: calc(50% - 240px); }
    .hero-logo { width: 80px; height: 80px; }
}

/* Desktop — full-width layout with sidebar potential */
@media (min-width: 1024px) {
    body {
        background: var(--bg-primary);
    }
    #app {
        max-width: 600px;
        margin: 0 auto;
        position: relative;
        box-shadow: -1px 0 0 rgba(77, 159, 255, 0.08), 1px 0 0 rgba(77, 159, 255, 0.08);
        min-height: 100vh;
    }
    .pages-container {
        max-width: 100%;
    }
    .tab-bar {
        max-width: 600px;
        left: 50%;
        transform: translateX(-50%);
        border-radius: var(--radius-lg) var(--radius-lg) 0 0;
        border-left: 1px solid rgba(77, 159, 255, 0.08);
        border-right: 1px solid rgba(77, 159, 255, 0.08);
    }
    .app-header {
        max-width: 600px;
        left: 50%;
        transform: translateX(-50%);
        border-left: 1px solid rgba(77, 159, 255, 0.08);
        border-right: 1px solid rgba(77, 159, 255, 0.08);
    }
    .fab { right: calc(50% - 280px); }

    /* Larger cards on desktop */
    .page-content { padding: 20px 24px 28px; }
    .progress-card { padding: 28px 24px; }
    .more-grid { gap: 16px; }
    .more-glass-card { padding: 32px 20px; }
    .templates-grid { gap: 14px; }
    .games-grid { gap: 14px; }

    .chat-messages { padding: 20px 24px; }
    .chat-input-bar { padding: 14px 20px; }

    /* Mouse hover effects are more visible on desktop */
    .glass-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 0 0 1px var(--border-glow), 0 0 20px var(--accent-glow), 0 0 40px rgba(77, 159, 255, 0.1), var(--shadow-card);
    }
    .more-glass-card:hover {
        transform: translateY(-4px);
    }
    .task-item:hover {
        transform: translateY(-3px);
    }
    .planner-task:hover {
        transform: translateY(-3px);
    }
    .hero-logo { width: 88px; height: 88px; }
}

/* Extra large desktop */
@media (min-width: 1440px) {
    #app {
        max-width: 640px;
    }
    .tab-bar, .app-header {
        max-width: 640px;
    }
}

/* Legal footer */
.legal-footer {
    font-size: 11px;
    color: var(--text-tertiary);
    text-align: center;
    margin-top: 20px;
    padding-bottom: 8px;
    line-height: 1.6;
}
.legal-footer a { color: var(--accent); text-decoration: none; }

/* Scrollbar thin */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(77, 159, 255, 0.2); border-radius: 2px; }

/* ===== PAYOUT PAGE REDESIGN ===== */
.payout-hero-card {
    background: linear-gradient(135deg, #1a2744 0%, #0d1b35 50%, #1a1f3a 100%);
    border: 1px solid rgba(77, 159, 255, 0.25);
    border-radius: 20px;
    padding: 28px 24px;
    margin-bottom: 16px;
    text-align: center;
}
.payout-hero-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 10px;
}
.payout-hero-amount {
    font-size: 44px;
    font-weight: 700;
    color: #ffffff;
    letter-spacing: -1px;
    line-height: 1;
    margin-bottom: 10px;
}
.payout-hero-stats {
    font-size: 14px;
    color: var(--text-secondary);
}

.payout-ref-card { padding: 18px 18px 16px; margin-bottom: 12px; }
.payout-ref-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.7px;
    margin-bottom: 10px;
}
.payout-ref-row {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-bottom: 10px;
}
.payout-ref-value {
    flex: 1;
    font-size: 13px;
    color: var(--accent-bright);
    background: rgba(77, 159, 255, 0.07);
    border: 1px solid rgba(77, 159, 255, 0.18);
    border-radius: 10px;
    padding: 9px 12px;
    word-break: break-all;
    line-height: 1.4;
}
.payout-copy-btn {
    display: flex;
    align-items: center;
    gap: 5px;
    background: rgba(77, 159, 255, 0.12);
    border: 1px solid rgba(77, 159, 255, 0.25);
    border-radius: 10px;
    color: var(--accent-bright);
    font-size: 12px;
    font-weight: 600;
    padding: 9px 12px;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.2s, transform 0.1s;
    flex-shrink: 0;
}
.payout-copy-btn:active { transform: scale(0.95); background: rgba(77, 159, 255, 0.22); }
.payout-ref-hint {
    font-size: 12px;
    color: var(--text-tertiary);
    line-height: 1.5;
}

.payout-how-card { padding: 18px 18px 16px; margin-bottom: 12px; }
.payout-how-title {
    font-size: 15px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 14px;
}
.payout-how-steps { display: flex; flex-direction: column; gap: 12px; }
.payout-step {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.payout-step-num {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: rgba(77, 159, 255, 0.15);
    border: 1px solid rgba(77, 159, 255, 0.3);
    color: var(--accent-bright);
    font-size: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 1px;
}
.payout-step-text {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.5;
}

.payout-form-card { padding: 20px 18px; margin-bottom: 12px; }
.payout-form-title {
    font-size: 16px;
    font-weight: 700;
    color: #ffffff;
    margin-bottom: 6px;
}
.payout-form-desc {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 18px;
}
.payout-form-card .form-field { margin-bottom: 12px; }
.payout-submit-btn { width: 100%; margin-top: 6px; }

.payout-inn-status {
    font-size: 12px;
    margin-top: 6px;
    padding: 4px 8px;
    border-radius: 6px;
    min-height: 0;
    transition: all 0.2s;
}
.payout-inn-status:empty { display: none; }
.inn-ok { color: #4ade80; background: rgba(74, 222, 128, 0.08); }
.inn-error { color: #f87171; background: rgba(248, 113, 113, 0.08); }
.inn-checking { color: var(--text-secondary); }
.inn-warn { color: #fbbf24; background: rgba(251, 191, 36, 0.08); }

.payout-individual-warn {
    background: rgba(251, 191, 36, 0.08);
    border: 1px solid rgba(251, 191, 36, 0.2);
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 13px;
    color: #fbbf24;
    line-height: 1.5;
    margin-bottom: 12px;
}

.payout-phone-hint {
    font-size: 12px;
    color: var(--text-tertiary);
    margin-top: 6px;
    display: block;
    line-height: 1.4;
}

.payout-bank-select { width: 100%; }
.payout-bank-other:focus { outline: none; border-color: var(--accent); }

.payout-legal-cards {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.payout-legal-option {
    flex: 1;
    min-width: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 14px;
    border-radius: 12px;
    border: 2px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.04);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    font-size: 14px;
    font-weight: 500;
}
.payout-legal-option input { margin: 0 8px 0 0; accent-color: var(--accent); }
.payout-legal-option:hover { border-color: rgba(255,255,255,0.2); background: rgba(255,255,255,0.06); }
.payout-legal-option:has(input:checked) {
    border-color: var(--accent);
    background: rgba(30, 144, 255, 0.12);
}
.payout-legal-option.payout-legal-disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
.payout-legal-option.payout-legal-disabled:hover { border-color: rgba(255,255,255,0.12); background: rgba(255,255,255,0.04); }

/* ===== PARTNERS — коллекция карточек, премиум Apple-стиль, листание как колода ===== */
.partner-cards-section { margin-top: 20px; }
.partner-catalog-title {
    font-size: 15px;
    font-weight: 600;
    margin: 20px 0 12px;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    -webkit-font-smoothing: antialiased;
}
/* Колода: одна карта на экран, свайп влево/вправо */
.partner-cards-scroll {
    display: flex;
    gap: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 12px 0 20px;
    margin: 0 -4px;
    min-height: 320px;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}
.partner-cards-scroll::-webkit-scrollbar { height: 6px; }
.partner-cards-scroll::-webkit-scrollbar-track { background: rgba(255,255,255,0.06); border-radius: 3px; }
.partner-cards-scroll::-webkit-scrollbar-thumb { background: rgba(77,159,255,0.35); border-radius: 3px; }

.partner-card {
    flex: 0 0 calc(100vw - 32px);
    width: calc(100vw - 32px);
    max-width: 320px;
    min-height: 420px;
    margin: 0 8px 0 0;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    background: #FAF9F5;
    border-radius: 20px;
    padding: 20px 18px;
    border: 1px solid rgba(15, 30, 90, 0.08);
    box-shadow: 0 8px 32px rgba(0,0,0,0.08), 0 2px 8px rgba(0,0,0,0.04);
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.partner-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, #1a237e, #3949ab);
    border-radius: 20px 20px 0 0;
}
.partner-card-inner {
    position: relative;
    z-index: 1;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}
.partner-card.has-bg-image {
    background-size: 78% 100%;
    background-position: left center;
    background-color: #FAF9F5;
    background-repeat: no-repeat;
}
.partner-card-num-3.has-bg-image { background-position: 30% center; }
.partner-card-num-1.has-bg-image,
.partner-card-num-2.has-bg-image { background-position: 25% center; }
.partner-card-num-4.has-bg-image,
.partner-card-num-5.has-bg-image { background-position: center 20%; }
.partner-card-num-6.has-bg-image,
.partner-card-num-7.has-bg-image,
.partner-card-num-8.has-bg-image { background-position: 20% center; }
.partner-card-num-9.has-bg-image,
.partner-card-num-10.has-bg-image { background-position: 70% center; }
.partner-card.has-bg-image .partner-card-inner {
    background: linear-gradient(to top, #FAF9F5 0%, rgba(250,249,245,0.98) 18%, rgba(250,249,245,0.92) 35%, rgba(250,249,245,0.75) 50%, rgba(250,249,245,0.4) 65%, transparent 82%);
    border-radius: 0 0 20px 20px;
    margin: 0 -20px -20px -18px;
    padding: 48px 24px 20px 18px;
}
.partner-card-phrase {
    font-weight: 600;
    font-size: 17px;
    text-transform: uppercase;
    color: #0F1E5A;
    line-height: 1.5;
    letter-spacing: 0.02em;
    margin-bottom: 10px;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-shadow: 0 1px 2px rgba(255,255,255,0.9);
}
.partner-card-name {
    font-size: 13px;
    color: #1a237e;
    font-weight: 600;
    margin-top: 4px;
}
.partner-card-rarity {
    font-size: 10px;
    color: #3949ab;
    opacity: 0.9;
    margin-top: 8px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
/* Рамки редкости */
.partner-card.rarity-common { border-color: rgba(255,255,255,0.15); }
.partner-card.rarity-rare { border-color: rgba(57, 73, 171, 0.4); box-shadow: 0 8px 32px rgba(0,0,0,0.08), 0 0 0 1px rgba(57,73,171,0.2); }
.partner-card.rarity-epic { border-color: rgba(123, 31, 162, 0.4); box-shadow: 0 8px 32px rgba(0,0,0,0.08), 0 0 0 1px rgba(123,31,162,0.2); }
.partner-card.rarity-legendary { border-color: rgba(255, 193, 7, 0.5); box-shadow: 0 8px 32px rgba(0,0,0,0.08), 0 0 0 2px rgba(255,193,7,0.3); }
.partner-card.rarity-mythic { border-color: rgba(255, 193, 7, 0.7); box-shadow: 0 12px 40px rgba(0,0,0,0.12), 0 0 0 2px rgba(255,193,7,0.5), 0 0 24px rgba(255,193,7,0.15); }
.partner-card-emoji { display: none; } /* без стикеров */

/* Плейсхолдер в скролле когда карточек ещё нет */
.partner-card-placeholder {
    background: linear-gradient(160deg, #FAF9F5 0%, #F5F3EB 100%);
    border: 1px dashed rgba(26, 35, 126, 0.2);
    box-shadow: 0 4px 20px rgba(0,0,0,0.05);
}
.partner-card-placeholder .partner-card-phrase { color: #1a237e; opacity: 0.9; }
.partner-card-placeholder .partner-card-name { color: #0F1E5A; opacity: 0.8; }
.partner-card-placeholder .partner-card-emoji { display: none; }

/* Каталог 2×5 — серые не собранные, яркие + рамка редкости собранные */
.partner-catalog-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    padding-bottom: 8px;
}
.partner-catalog-item {
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: 14px 12px;
    text-align: center;
    min-height: 96px;
    transition: background 0.25s ease, border-color 0.25s ease;
    -webkit-font-smoothing: antialiased;
    background-size: cover;
    background-position: center;
}
.partner-catalog-item.collected {
    background: rgba(250,249,245,0.5);
    border-color: rgba(26, 35, 126, 0.25);
    box-shadow: 0 2px 12px rgba(26, 35, 126, 0.08);
}
.partner-catalog-item.collected.rarity-mythic {
    border-color: rgba(255, 193, 7, 0.5);
    box-shadow: 0 0 0 2px rgba(255,193,7,0.25);
}
.partner-catalog-item.collected.rarity-legendary {
    border-color: rgba(255, 193, 7, 0.35);
    box-shadow: 0 0 0 1px rgba(255,193,7,0.2);
}
.partner-catalog-item .catalog-emoji { display: none; }
.partner-catalog-item .catalog-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary);
    letter-spacing: -0.01em;
}
.partner-catalog-item.collected .catalog-name { color: #0F1E5A; }
.partner-catalog-item .catalog-phrase {
    font-size: 10px;
    color: var(--text-secondary);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-top: 6px;
    line-height: 1.35;
}
.partner-catalog-item.collected .catalog-phrase { color: #1a237e; }
.partner-catalog-item .catalog-lock {
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 6px;
    opacity: 0.8;
}
.partner-cards-empty {
    font-size: 14px;
    color: var(--text-secondary);
    padding: 14px 0 8px;
    line-height: 1.5;
}

/* Oferta acceptance in payment modal */
.oferta-accept-wrap {
    margin-bottom: 16px;
}
.oferta-accept-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
}
.oferta-checkbox {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    margin-top: 1px;
    accent-color: var(--accent);
    cursor: pointer;
}
.oferta-accept-text {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
}
.oferta-link {
    color: var(--accent-bright);
    text-decoration: none;
}
.oferta-link:hover { text-decoration: underline; }

/* ===== NEON POLISH — Сбалансированный неон (читаемый, без ослепления) ===== */

/* Кнопка primary — чистый белый текст, синее свечение на рамке */
.btn-primary {
    background: linear-gradient(135deg, #2693ff 0%, #0060df 100%) !important;
    color: #ffffff !important;
    text-shadow: none !important;
    box-shadow: 0 0 16px rgba(30,144,255,0.45), 0 4px 12px rgba(0,60,160,0.4), inset 0 1px 0 rgba(255,255,255,0.18) !important;
    font-weight: 700 !important;
}
.btn-primary:hover {
    box-shadow: 0 0 24px rgba(30,144,255,0.6), 0 4px 16px rgba(0,60,160,0.5) !important;
}

/* Кнопка secondary — мягкий белый без ослепления */
.btn-secondary {
    background: rgba(255, 255, 255, 0.07) !important;
    border: 1px solid rgba(255, 255, 255, 0.20) !important;
    color: #ffffff !important;
    text-shadow: none !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.10) !important;
    font-weight: 600 !important;
}
.btn-secondary:hover {
    background: rgba(255, 255, 255, 0.12) !important;
    border-color: rgba(255, 255, 255, 0.30) !important;
}

/* Кнопки игр — синий без белых вспышек */
.btn-game {
    background: linear-gradient(135deg, #2693ff 0%, #0060df 100%) !important;
    color: #ffffff !important;
    text-shadow: none !important;
    box-shadow: 0 0 12px rgba(30,144,255,0.4) !important;
    font-weight: 700 !important;
}

/* Нижняя навигация */
.tab-bar {
    border-top: 1px solid rgba(30, 144, 255, 0.18) !important;
    box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.35) !important;
}
.tab-label {
    font-weight: 700 !important;
}
.tab { color: rgba(160, 195, 240, 0.55) !important; }
.tab.active {
    color: #ffffff !important;
    text-shadow: none !important;
}
.tab.active .tab-icon {
    stroke: #7ab8ff !important;
    filter: drop-shadow(0 0 5px rgba(30, 144, 255, 0.6)) !important;
}
.tab.active::after {
    background: #2693ff !important;
    box-shadow: 0 0 8px rgba(30, 144, 255, 0.7) !important;
    width: 24px !important;
    height: 3px !important;
}

/* Input focus */
input:focus, textarea:focus, select:focus {
    border-color: rgba(30, 144, 255, 0.6) !important;
    box-shadow: 0 0 0 2px rgba(30, 144, 255, 0.18) !important;
}

/* МоноСлово featured card */
.ms-featured-card {
    background: linear-gradient(135deg, rgba(20, 65, 160, 0.22) 0%, rgba(8, 22, 60, 0.45) 100%) !important;
    border: 1px solid rgba(30, 144, 255, 0.35) !important;
    box-shadow: 0 0 18px rgba(30, 144, 255, 0.18) !important;
}
.ms-featured-card h3 {
    font-size: 18px !important;
    font-weight: 800 !important;
    text-shadow: none !important;
}

/* МоноСлово эмодзи — оставляем */
.ms-featured-card .ms-game-emoji {
    font-size: 36px !important;
}

/* МоноСлово: счёт 2–4 команд */
.ms-game-scores {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.ms-game-scores .ms-score {
    min-width: 60px;
}
.ms-game-scores .ms-round-badge {
    margin-left: 4px;
}

/* МоноСлово: экран лайков после хода */
.ms-likes-screen { padding: 0 16px 24px; }
.ms-likes-header {
    margin: 0 -16px 16px;
    padding: 20px 16px;
    color: #fff;
    text-align: center;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}
.ms-likes-title { font-size: 14px; opacity: 0.95; text-transform: uppercase; letter-spacing: 0.05em; }
.ms-likes-team { font-size: 18px; font-weight: 700; margin-top: 4px; }
.ms-likes-badge {
    display: inline-block;
    margin-top: 8px;
    padding: 4px 14px;
    background: rgba(255,255,255,0.25);
    border-radius: var(--radius-pill);
    font-weight: 700;
    font-size: 16px;
}
.ms-likes-hint {
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 16px;
    text-align: center;
}
.ms-likes-list { margin-bottom: 20px; }
.ms-round-word-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    margin-bottom: 8px;
    background: var(--bg-card);
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
}
.ms-round-word-text { font-weight: 600; font-size: 16px; }
.ms-like-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 2px solid var(--border);
    background: var(--bg-input);
    color: var(--text-tertiary);
    font-size: 22px;
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.ms-like-btn.ms-like-on {
    background: #ff7043;
    border-color: #ff7043;
    color: #fff;
}

.ms-likes-continue { width: 100%; margin-top: 8px; }

/* МоноСлово: кнопка паузы и оверлей */
.ms-gameplay { position: relative; }
.ms-timer-wrap {
    position: relative;
    padding-right: 48px;
}
.ms-pause-btn {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.ms-pause-btn:hover,
.ms-pause-btn:focus {
    background: var(--bg-elevated);
    color: var(--text-primary);
    border-color: var(--border-light);
}
.ms-pause-btn.ms-pause-active {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
}
.ms-pause-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    border-radius: var(--radius-lg);
}
.ms-pause-card {
    background: var(--bg-card-solid);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    padding: 24px;
    max-width: 320px;
    text-align: center;
    box-shadow: var(--shadow-card);
}
.ms-pause-icon { font-size: 48px; margin-bottom: 12px; line-height: 1; }
.ms-pause-title { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.ms-pause-hint {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 20px;
    line-height: 1.4;
}
.ms-pause-card .ms-btn-primary { width: 100%; }

/* Pricing card */
.pricing-card.featured {
    box-shadow: 0 0 22px rgba(30, 144, 255, 0.28) !important;
}

/* ========================================
   SIRIUS — LIGHT THEME
   White #FFF · Black #000 · Blue #0A2540/#0066FF · Yellow accent #F4C542
   Applied via [data-theme="light"] on <html>
   ======================================== */

/* Smooth transition when switching themes */
.theme-transition,
.theme-transition *,
.theme-transition *::before,
.theme-transition *::after {
    transition:
        background-color 0.35s ease,
        color 0.35s ease,
        border-color 0.35s ease,
        box-shadow 0.35s ease,
        fill 0.35s ease,
        stroke 0.35s ease !important;
}

/* ── CSS Variables ── */
[data-theme="light"] {
    --bg-primary: #FFFFFF;
    --bg-primary-subtle: #F8F9FA;
    --bg-card: #FFFFFF;
    --bg-card-solid: #FFFFFF;
    --bg-elevated: #F8F9FA;
    --bg-input: #F1F3F5;
    --accent: #0066FF;
    --accent-rgb: 0, 102, 255;
    --accent-light: #3385FF;
    --accent-bright: #0066FF;
    --accent-glow: rgba(0, 102, 255, 0.1);
    --accent-glow-strong: rgba(0, 102, 255, 0.2);
    --accent-gradient: linear-gradient(135deg, #0066FF 0%, #0A2540 100%);
    --accent-neon: none;
    --sirius-bg: #FFFFFF;
    --sirius-text: #000000;
    --sirius-accent-yellow: #F4C542;
    --sirius-button-blue: #0A2540;
    --success: #16A34A;
    --success-glow: rgba(22, 163, 74, 0.2);
    --danger: #DC2626;
    --danger-glow: rgba(220, 38, 38, 0.2);
    --warning: #F4C542;
    --text-primary: #000000;
    --text-secondary: #555555;
    --text-tertiary: #888888;
    --text-glow: none;
    --border: rgba(0, 0, 0, 0.08);
    --border-light: rgba(0, 0, 0, 0.08);
    --border-glow: rgba(0, 102, 255, 0.15);
    --border-active: rgba(0, 102, 255, 0.35);
    --glass: #FFFFFF;
    --glass-bright: #FFFFFF;
    --glass-border: rgba(0, 0, 0, 0.08);
    --glass-shine: none;
    --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.05), 0 4px 16px rgba(0, 0, 0, 0.07);
    --shadow-glow: 0 4px 16px rgba(0, 0, 0, 0.08);
    --shadow-glow-subtle: 0 2px 8px rgba(0, 0, 0, 0.06);
    --shadow-neon: 0 4px 16px rgba(0, 0, 0, 0.08);
    --shadow-elevate: 0 8px 24px rgba(0, 0, 0, 0.1);
    --bg-page: #F8F9FA;
    --bg-color: #FFFFFF;
    --bg-secondary: #F8F9FA;
    --text-color: #000000;
    --border-color: rgba(0, 0, 0, 0.1);
    --border-radius: 14px;
    --shadow: var(--shadow-card);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.1);
    --danger-color: #DC2626;
    --success-color: #16A34A;
    --primary-color: #0066FF;
}

/* ── Base ── */
[data-theme="light"] html { background: #FFFFFF !important; color: #000000 !important; }
[data-theme="light"] body { background: #F8F9FA !important; color: #000000 !important; }
[data-theme="light"] #app { background: #F8F9FA; color: #000000; box-shadow: none; }
[data-theme="light"] .pages-container { background: #F8F9FA; color: #000000; }
[data-theme="light"] .page { background: #F8F9FA; color: #000000; }

/* ── Header ── */
[data-theme="light"] .app-header {
    background: #FFFFFF !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: 1px solid #E5E7EB !important;
    box-shadow: 0 1px 0 rgba(0,0,0,0.06) !important;
}
[data-theme="light"] .logo-text {
    background: none !important;
    -webkit-background-clip: unset !important;
    -webkit-text-fill-color: #000000 !important;
    background-clip: unset !important;
    filter: none !important;
    color: #000000 !important;
}
[data-theme="light"] .streak-badge {
    background: rgba(0, 102, 255, 0.07);
    border-color: rgba(0, 102, 255, 0.15);
    color: #0066FF;
    box-shadow: none;
    backdrop-filter: none;
}

/* ── Tab bar ── */
[data-theme="light"] .tab-bar {
    background: #FFFFFF !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-top: 1px solid #E5E7EB !important;
    box-shadow: 0 -1px 0 rgba(0,0,0,0.06) !important;
}
[data-theme="light"] .tab { color: #888888 !important; }
[data-theme="light"] .tab:hover { color: #555555 !important; }
[data-theme="light"] .tab.active { color: #000000 !important; text-shadow: none !important; }
[data-theme="light"] .tab.active::after {
    background: #0066FF !important;
    box-shadow: none !important;
    width: 24px !important;
    height: 3px !important;
}
[data-theme="light"] .tab.active .tab-icon { stroke: #0066FF !important; filter: none !important; }
[data-theme="light"] .tab-label { font-weight: 700 !important; }

/* ── Glass cards → clean white cards ── */
[data-theme="light"] .glass-card {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 12px rgba(0,0,0,0.07);
}
[data-theme="light"] .glass-card::before { display: none; }
[data-theme="light"] .glass-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.10);
    border-color: #D1D5DB;
    transform: translateY(-2px);
}

/* ── Hero card (keep dark navy — brand anchor) ── */
[data-theme="light"] .hero-card {
    background: #0A2540 !important;
    box-shadow: 0 4px 20px rgba(10,37,64,0.2) !important;
}
[data-theme="light"] .hero-card::after { display: none; }
[data-theme="light"] .hero-greeting { color: #FFFFFF; }
[data-theme="light"] .greeting-date { color: rgba(255,255,255,0.65); }
[data-theme="light"] .hero-focus { color: rgba(255,255,255,0.85); background: rgba(255,255,255,0.12); }

/* ── Quote card (clean white, subtle top border) ── */
[data-theme="light"] .quote-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 4px rgba(0,0,0,0.05);
}
[data-theme="light"] .quote-card::before { background: linear-gradient(90deg, #0066FF, #0A2540); }
[data-theme="light"] .quote-text { color: #0A2540; }
[data-theme="light"] .quote-source { color: #555555; }
[data-theme="light"] .quote-comment { color: #111111; }
[data-theme="light"] .quote-rotation-hint { color: rgba(0,0,0,0.45); }

/* ── Fact card ── */
[data-theme="light"] .fact-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 12px rgba(0,0,0,0.07);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}
[data-theme="light"] .fact-label { color: #888888; }
[data-theme="light"] .fact-stat { color: #000000; }
[data-theme="light"] .fact-body { color: #333333; }
[data-theme="light"] .fact-detail-text { color: #333333; }
[data-theme="light"] .fact-detail-num { background: rgba(0,102,255,0.1); color: #0066FF; }
[data-theme="light"] .fact-details { border-top-color: #E5E7EB; }
[data-theme="light"] .fact-toggle { color: #0066FF; }

/* ── Progress card ── */
[data-theme="light"] .progress-card {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 12px rgba(0,0,0,0.07);
}
[data-theme="light"] .progress-card::before { display: none; }
[data-theme="light"] .progress-ring-bg { stroke: rgba(0,102,255,0.12) !important; }
[data-theme="light"] .progress-ring-fill { stroke: #0066FF !important; filter: none !important; }
[data-theme="light"] .progress-ring-value { color: #000000; text-shadow: none; }
[data-theme="light"] .progress-ring-text { color: #888888; }
[data-theme="light"] .progress-stat {
    background: rgba(0,102,255,0.04);
    border-color: rgba(0,102,255,0.1);
    backdrop-filter: none;
    box-shadow: none;
}
[data-theme="light"] .progress-stat:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.08); border-color: rgba(0,102,255,0.2); }
[data-theme="light"] .progress-stat-value { color: #000000; }
[data-theme="light"] .progress-stat-label { color: #888888; }
[data-theme="light"] #page-dashboard .progress-card.glass-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 12px rgba(0,0,0,0.07);
}

/* ── Quick AI bar ── */
[data-theme="light"] .quick-ai-input-wrap {
    background: #FFFFFF;
    border-color: #E5E7EB;
    backdrop-filter: none;
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
[data-theme="light"] .quick-ai-input-wrap:focus-within {
    border-color: rgba(0,102,255,0.4);
    box-shadow: 0 0 0 3px rgba(0,102,255,0.08);
}
[data-theme="light"] .quick-ai-input { color: #000000; }
[data-theme="light"] .quick-ai-input::placeholder { color: #888888; }
[data-theme="light"] .quick-ai-send { background: #0A2540; box-shadow: none; }
[data-theme="light"] .quick-ai-send:hover { background: #0066FF; box-shadow: 0 2px 8px rgba(0,102,255,0.3); transform: translateY(-2px); }
[data-theme="light"] #page-dashboard .quick-ai-input-wrap { background: #FFFFFF; border-color: #E5E7EB; box-shadow: 0 1px 4px rgba(0,0,0,0.06); }
[data-theme="light"] #page-dashboard .quick-ai-send { box-shadow: none; }
[data-theme="light"] #page-dashboard .btn-pill {
    background: rgba(0,102,255,0.07);
    border-color: rgba(0,102,255,0.18);
    color: #0066FF;
    box-shadow: none;
    backdrop-filter: none;
    text-shadow: none;
}
[data-theme="light"] #page-dashboard .btn-pill:hover { background: rgba(0,102,255,0.13); box-shadow: none; }

/* ── Section headers ── */
[data-theme="light"] .section-header h2 { color: #000000; text-shadow: none; }
[data-theme="light"] .page-title { color: #000000; text-shadow: none; }
[data-theme="light"] .missed-hint { color: #888888; }

/* ── Task cards ── */
[data-theme="light"] .task-card {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-color: #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 8px rgba(0,0,0,0.06);
}
[data-theme="light"] .task-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.10); }
[data-theme="light"] .task-text { color: #000000; }
[data-theme="light"] .task-time { color: #888888; }
[data-theme="light"] .task-btn-done {
    background: rgba(22,163,74,0.07);
    border-color: rgba(22,163,74,0.28);
    color: #16A34A;
}
[data-theme="light"] .task-btn-done:hover { background: rgba(22,163,74,0.13); border-color: rgba(22,163,74,0.45); }
[data-theme="light"] .task-btn-postpone {
    background: rgba(0,0,0,0.03);
    border-color: rgba(0,0,0,0.09);
    color: #888888;
}
[data-theme="light"] .task-btn-postpone:hover { background: rgba(0,0,0,0.06); color: #555555; }
[data-theme="light"] .task-item {
    background: #FFFFFF;
    backdrop-filter: none;
    border-color: #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

/* ── Goal cards ── */
[data-theme="light"] .goal-card-mini {
    background: #FFFFFF;
    backdrop-filter: none;
    border-color: #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 8px rgba(0,0,0,0.06);
}
[data-theme="light"] .goal-card-mini:hover { box-shadow: 0 4px 14px rgba(0,0,0,0.09); border-color: #D1D5DB; }
[data-theme="light"] .goal-card-title { color: #000000; }
[data-theme="light"] .goal-mini-bar { background: rgba(0,102,255,0.09); }
[data-theme="light"] .goal-mini-fill { background: #0066FF; box-shadow: none; }
[data-theme="light"] .goal-mini-pct { color: #888888; }
[data-theme="light"] .goal-item {
    background: #FFFFFF;
    backdrop-filter: none;
    border-color: #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
[data-theme="light"] .goal-title { color: #000000; }
[data-theme="light"] .goal-description { color: #555555; }
[data-theme="light"] .goal-progress { background: rgba(0,102,255,0.09); }
[data-theme="light"] .goal-progress-bar { background: #0066FF; }
[data-theme="light"] .goal-pct { color: #888888; }
[data-theme="light"] .goal-card-full {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 8px rgba(0,0,0,0.06);
}
[data-theme="light"] .goal-card-full:hover { box-shadow: 0 4px 14px rgba(0,0,0,0.09); }
[data-theme="light"] .goal-card-desc { color: #555555; }
[data-theme="light"] .goal-donut-text { fill: #000000; }
[data-theme="light"] .empty-state-mini { color: #888888; }

/* ── Buttons ── */
[data-theme="light"] .btn-primary {
    background: #0A2540 !important;
    color: #FFFFFF !important;
    text-shadow: none !important;
    box-shadow: 0 2px 8px rgba(10,37,64,0.2) !important;
    font-weight: 700 !important;
}
[data-theme="light"] .btn-primary:hover { background: #0066FF !important; box-shadow: 0 4px 16px rgba(0,102,255,0.25) !important; }
[data-theme="light"] .btn-secondary {
    background: rgba(0,0,0,0.04) !important;
    border: 1px solid rgba(0,0,0,0.12) !important;
    color: #000000 !important;
    text-shadow: none !important;
    box-shadow: none !important;
    font-weight: 600 !important;
}
[data-theme="light"] .btn-secondary:hover { background: rgba(0,0,0,0.08) !important; border-color: rgba(0,0,0,0.18) !important; }
[data-theme="light"] .btn-accent-small { background: #0A2540; box-shadow: none; }
[data-theme="light"] .btn-accent-small:hover { background: #0066FF; box-shadow: 0 2px 8px rgba(0,102,255,0.2); transform: translateY(-2px); }
[data-theme="light"] .btn-pill {
    background: rgba(0,102,255,0.06);
    border-color: rgba(0,102,255,0.18);
    color: #0066FF;
    text-shadow: none;
    box-shadow: none;
    backdrop-filter: none;
}
[data-theme="light"] .btn-pill:hover { background: rgba(0,102,255,0.12); box-shadow: none; border-color: rgba(0,102,255,0.28); transform: translateY(-1px); }
[data-theme="light"] .btn-pill-outline { border-color: rgba(0,0,0,0.18); color: #555555; background: transparent; }
[data-theme="light"] .btn-back-row { color: #0066FF; text-shadow: none; }
[data-theme="light"] .btn-text {
    background: rgba(0,102,255,0.06);
    border-color: rgba(0,102,255,0.18);
    color: #0066FF;
    text-shadow: none;
}

/* ── Chat header & sessions ── */
[data-theme="light"] .chat-header-bar {
    background: #FFFFFF;
    backdrop-filter: none;
    border-bottom-color: #E5E7EB;
}
[data-theme="light"] .chat-session-title { color: #000000; }
[data-theme="light"] .btn-glass-icon {
    background: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.1);
    color: #555555;
    backdrop-filter: none;
}
[data-theme="light"] .btn-glass-icon:hover { background: rgba(0,102,255,0.07); border-color: rgba(0,102,255,0.18); color: #0066FF; box-shadow: none; }
[data-theme="light"] .chat-sessions-panel {
    background: #FFFFFF;
    backdrop-filter: none;
    border-right-color: #E5E7EB;
    box-shadow: 4px 0 24px rgba(0,0,0,0.1);
}
[data-theme="light"] .sessions-header { border-bottom-color: #E5E7EB; }
[data-theme="light"] .sessions-header h3 { color: #000000; }
[data-theme="light"] .session-item { background: rgba(0,0,0,0.02); border-color: transparent; }
[data-theme="light"] .session-item:hover { background: rgba(0,102,255,0.05); border-color: rgba(0,102,255,0.1); }
[data-theme="light"] .session-item.active { background: rgba(0,102,255,0.09); border-color: rgba(0,102,255,0.22); box-shadow: none; }
[data-theme="light"] .session-item-title { color: #000000; }
[data-theme="light"] .btn-clear-chat { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); color: #888888; }
[data-theme="light"] .btn-clear-chat:hover { background: rgba(220,38,38,0.07); color: #DC2626; }

/* ── Chat modules ── */
[data-theme="light"] .chat-modules-block { background: #FFFFFF; border-bottom-color: #E5E7EB; }
[data-theme="light"] .chat-modules-label { color: #888888; }
[data-theme="light"] .module-chip { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.1); color: #555555; backdrop-filter: none; }
[data-theme="light"] .module-chip:hover { background: rgba(0,102,255,0.06); border-color: rgba(0,102,255,0.18); color: #0066FF; }
[data-theme="light"] .module-chip.active { background: #0A2540; border-color: #0A2540; color: #FFFFFF; box-shadow: none; }
[data-theme="light"] .module-type-picker { background: #F8F9FA; border-bottom-color: #E5E7EB; }
[data-theme="light"] .module-type-btn { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: #555555; }
[data-theme="light"] .module-type-btn:hover { background: rgba(0,102,255,0.06); color: #0066FF; }
[data-theme="light"] .module-type-btn.active { background: #0A2540; border-color: #0A2540; color: #FFFFFF; box-shadow: none; }

/* ── Chat messages ── */
[data-theme="light"] .message.assistant {
    background: #F1F3F5;
    backdrop-filter: none;
    color: #000000;
    border-color: #E5E7EB;
    box-shadow: 0 1px 4px rgba(0,0,0,0.05);
}
[data-theme="light"] .message.user { background: #0A2540; color: #FFFFFF; box-shadow: none; }
[data-theme="light"] .ai-msg-formatted strong { color: #0066FF; }
[data-theme="light"] .ai-msg-formatted ul li::marker { color: #0066FF; }
[data-theme="light"] .ai-msg-formatted ol li::marker { color: #0066FF; font-weight: 600; }
[data-theme="light"] .ai-msg-formatted code { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.1); color: #0A2540; }
[data-theme="light"] .ai-msg-formatted pre { background: #F1F3F5; color: #0A2540; border-color: #E5E7EB; }
[data-theme="light"] .ai-msg-formatted blockquote { background: rgba(0,102,255,0.04); border-left-color: rgba(0,102,255,0.45); }
[data-theme="light"] .ai-msg-formatted a { color: #0066FF; }
[data-theme="light"] .ai-msg-formatted hr { border-top-color: #E5E7EB; }

/* ── Chat input bar ── */
[data-theme="light"] .chat-input-bar { background: #FFFFFF; backdrop-filter: none; border-top-color: #E5E7EB; box-shadow: 0 -1px 0 rgba(0,0,0,0.06); }
[data-theme="light"] .chat-input { background: #F1F3F5; border-color: #E5E7EB; color: #000000; }
[data-theme="light"] .chat-input:focus { border-color: rgba(0,102,255,0.4); box-shadow: 0 0 0 3px rgba(0,102,255,0.08); }
[data-theme="light"] .chat-input::placeholder { color: #888888; }
[data-theme="light"] .btn-send { background: #0A2540; box-shadow: none; }
[data-theme="light"] .btn-send:hover { background: #0066FF; box-shadow: 0 2px 8px rgba(0,102,255,0.3); }
[data-theme="light"] .btn-icon { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #555555; }
[data-theme="light"] .btn-icon:hover { background: rgba(0,102,255,0.07); box-shadow: none; }
[data-theme="light"] .file-preview-strip { background: #F8F9FA; border-top-color: #E5E7EB; border-bottom-color: #E5E7EB; }
[data-theme="light"] .file-preview-item { background: #FFFFFF; border-color: #E5E7EB; }
[data-theme="light"] .file-preview-icon { color: #0066FF; }

/* ── Planner ── */
[data-theme="light"] .planner-view-toggle { background: #FFFFFF; border-color: #E5E7EB; backdrop-filter: none; }
[data-theme="light"] .pvt-btn { color: #888888; }
[data-theme="light"] .pvt-btn:hover { color: #555555; }
[data-theme="light"] .pvt-btn.active { background: #0A2540; color: #FFFFFF; box-shadow: none; }
[data-theme="light"] .month-nav-title { color: #000000; text-shadow: none; }
[data-theme="light"] .month-nav-btn { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); color: #555555; }
[data-theme="light"] .month-nav-btn:hover { background: rgba(0,102,255,0.07); box-shadow: none; }
[data-theme="light"] .mg-header-cell { color: #888888; }
[data-theme="light"] .mg-cell { background: rgba(0,0,0,0.02); border-color: transparent; }
[data-theme="light"] .mg-cell:not(.empty):hover { background: rgba(0,102,255,0.05); border-color: rgba(0,102,255,0.14); }
[data-theme="light"] .mg-cell.today { border-color: #0066FF; box-shadow: none; }
[data-theme="light"] .mg-cell.selected { background: rgba(0,102,255,0.1); border-color: #0066FF; box-shadow: none; }
[data-theme="light"] .mg-day-num { color: #000000; }
[data-theme="light"] .mg-cell.today .mg-day-num { color: #0066FF; text-shadow: none; }
[data-theme="light"] .mg-dot.dot-normal { background: #0066FF; box-shadow: none; }
[data-theme="light"] .mini-month { background: #FFFFFF; border-color: #E5E7EB; }
[data-theme="light"] .mini-month:hover { background: rgba(0,102,255,0.03); border-color: rgba(0,102,255,0.18); box-shadow: none; }
[data-theme="light"] .mini-month.current { border-color: #0066FF; box-shadow: none; }
[data-theme="light"] .mini-month-name { color: #000000; }
[data-theme="light"] .mini-month-count { color: #888888; }
[data-theme="light"] .mini-month-bar { background: rgba(0,102,255,0.09); }
[data-theme="light"] .mini-month-fill { background: #0066FF; box-shadow: none; }
[data-theme="light"] .planner-month-summary { background: #FFFFFF; border-color: #E5E7EB; border-left-color: #0066FF; }
[data-theme="light"] .pms-title { color: #555555; }
[data-theme="light"] .week-day { background: #FFFFFF; backdrop-filter: none; border-color: #E5E7EB; }
[data-theme="light"] .week-day:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.08); }
[data-theme="light"] .week-day.today { background: #0A2540; border-color: #0A2540; box-shadow: none; }
[data-theme="light"] .week-day-name { color: #888888; }
[data-theme="light"] .week-day.today .week-day-name { color: rgba(255,255,255,0.85); }
[data-theme="light"] .week-day-num { color: #000000; }
[data-theme="light"] .week-day.today .week-day-num { color: #FFFFFF; }
[data-theme="light"] .week-day.selected:not(.today) { border-color: rgba(0,102,255,0.38); box-shadow: none; }
[data-theme="light"] .day-dot { background: #0066FF; box-shadow: none; }
[data-theme="light"] .planner-task {
    background: #FFFFFF;
    backdrop-filter: none;
    border-color: #E5E7EB;
    border-left-color: #0066FF;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
[data-theme="light"] .planner-task::before { background: #0066FF; box-shadow: none; }
[data-theme="light"] .planner-task:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.09); }
[data-theme="light"] .planner-task-time { color: #0066FF; text-shadow: none; }
[data-theme="light"] .planner-task-text { color: #000000; }
[data-theme="light"] .planner-task.overdue { border-left-color: #DC2626; }
[data-theme="light"] .planner-task.overdue::before { background: #DC2626; box-shadow: none; }
[data-theme="light"] .planner-task-card {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-color: #E5E7EB;
    border-left-color: #0066FF;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 8px rgba(0,0,0,0.06);
}
[data-theme="light"] .planner-task-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.1); }
[data-theme="light"] .planner-task-card.overdue { border-left-color: #DC2626; }
[data-theme="light"] .planner-task-card.done { border-left-color: #16A34A; }
[data-theme="light"] .ptc-swipe-content {
    background: #FFFFFF;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
[data-theme="light"] .ptc-text { color: #000000; }
[data-theme="light"] .ptc-time { color: #888888; }
[data-theme="light"] .ptc-recur { background: rgba(0,102,255,0.07); color: #0066FF; border-color: rgba(0,102,255,0.18); }
[data-theme="light"] .ptc-dot { box-shadow: none; }
[data-theme="light"] .ptc-btn-done { background: rgba(22,163,74,0.07); border-color: rgba(22,163,74,0.28); color: #16A34A; }
[data-theme="light"] .ptc-btn-done:hover { background: rgba(22,163,74,0.13); border-color: rgba(22,163,74,0.45); }
[data-theme="light"] .ptc-btn-edit { background: rgba(0,102,255,0.05); border-color: rgba(0,102,255,0.16); color: #0066FF; }
[data-theme="light"] .ptc-btn-edit:hover { background: rgba(0,102,255,0.11); border-color: rgba(0,102,255,0.3); }
[data-theme="light"] .ptc-btn-reopen { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.09); color: #555555; }
[data-theme="light"] .ptc-btn-reopen:hover { background: rgba(0,0,0,0.06); color: #000000; }
[data-theme="light"] .ptc-btn-progress { background: rgba(244,197,66,0.07); border-color: rgba(244,197,66,0.28); color: #92650A; }
[data-theme="light"] .planner-swipe-hint { color: #888888; }

/* ── FAB ── */
[data-theme="light"] .fab { background: #0A2540; box-shadow: 0 4px 16px rgba(10,37,64,0.22); }
[data-theme="light"] .fab:hover { background: #0066FF; box-shadow: 0 6px 20px rgba(0,102,255,0.28); transform: translateY(-3px) scale(1.02); }

/* ── More page ── */
[data-theme="light"] .more-glass-card {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-color: #E5E7EB;
    color: #000000;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 2px 12px rgba(0,0,0,0.07);
}
[data-theme="light"] .more-glass-card::before { display: none; }
[data-theme="light"] .more-glass-card:hover { background: rgba(0,102,255,0.03); border-color: rgba(0,102,255,0.18); box-shadow: 0 4px 16px rgba(0,0,0,0.10); transform: translateY(-3px); }
[data-theme="light"] .more-card-icon { stroke: #0066FF; filter: none; }
[data-theme="light"] .more-glass-card:hover .more-card-icon { filter: none; }
[data-theme="light"] .more-card-label { color: #000000; text-shadow: none; }

/* ── Templates ── */
[data-theme="light"] .page-subtitle { color: #0066FF; text-shadow: none; }
[data-theme="light"] .template-card { background: #FFFFFF; backdrop-filter: none; border-color: #E5E7EB; }
[data-theme="light"] .template-card:hover { background: rgba(0,102,255,0.03); border-color: rgba(0,102,255,0.18); box-shadow: 0 2px 8px rgba(0,0,0,0.07); }
[data-theme="light"] .template-card.active { border-color: rgba(0,102,255,0.38); background: rgba(0,102,255,0.05); box-shadow: none; }
[data-theme="light"] .template-card-name { color: #000000; }
[data-theme="light"] .template-card-desc { color: #555555; }
[data-theme="light"] .templates-hint { color: #888888; }

/* ── Notifications ── */
[data-theme="light"] .notification-item { background: #FFFFFF; backdrop-filter: none; border-color: #E5E7EB; border-left-color: #0066FF; box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
[data-theme="light"] .notification-item::before { background: #0066FF; box-shadow: none; }
[data-theme="light"] .notification-icon { background: rgba(0,102,255,0.07); border-color: rgba(0,102,255,0.14); }
[data-theme="light"] .notification-icon svg { stroke: #0066FF; }
[data-theme="light"] .notification-title { color: #000000; }
[data-theme="light"] .notification-text { color: #555555; }
[data-theme="light"] .notification-time { color: #888888; }
[data-theme="light"] .notification-settings { background: #FFFFFF; backdrop-filter: none; border-color: #E5E7EB; }
[data-theme="light"] .notification-setting-label { color: #000000; }
[data-theme="light"] .notification-setting-desc { color: #6B7280; }
[data-theme="light"] .toggle-switch { background: rgba(0,0,0,0.1); border-color: rgba(0,0,0,0.1); }
[data-theme="light"] .toggle-switch.active { background: #0066FF; border-color: #0066FF; box-shadow: none; }

/* ── Voice tone ── */
[data-theme="light"] .voicetone-item { background: #FFFFFF; backdrop-filter: none; border-color: #E5E7EB; }
[data-theme="light"] .voicetone-item.active { border-color: rgba(0,102,255,0.38); box-shadow: none; }
[data-theme="light"] .voicetone-item:hover { background: rgba(0,102,255,0.03); }
[data-theme="light"] .voicetone-name { color: #000000; }
[data-theme="light"] .voicetone-desc { color: #555555; }
[data-theme="light"] .voicetone-check { color: #0066FF; text-shadow: none; }

/* ── Stats ── */
[data-theme="light"] .stat-card-mini { background: #FFFFFF; border-color: #E5E7EB; backdrop-filter: none; }
[data-theme="light"] .stat-card-value { color: #0066FF; text-shadow: none; }
[data-theme="light"] .stat-card-label { color: #888888; }
[data-theme="light"] .achievement-item { background: #FFFFFF; border-color: #E5E7EB; backdrop-filter: none; }

/* ── Instruction ── */
[data-theme="light"] .instruction-block { background: #FFFFFF; border: 1px solid #E5E7EB; box-shadow: 0 1px 3px rgba(0,0,0,0.05); backdrop-filter: none; }
[data-theme="light"] .instruction-block p { color: #333333; }
[data-theme="light"] .instruction-h3 { color: #0066FF; text-shadow: none; }

/* ── Toast ── */
[data-theme="light"] .toast { background: #FFFFFF; backdrop-filter: none; color: #000000; border-color: #E5E7EB; box-shadow: 0 4px 20px rgba(0,0,0,0.12); }

/* ── Modals ── */
[data-theme="light"] .modal-overlay { background: rgba(0,0,0,0.4); }
[data-theme="light"] .modal-sheet {
    background: #FFFFFF;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-color: #E5E7EB;
    box-shadow: 0 -4px 32px rgba(0,0,0,0.12);
}
[data-theme="light"] .modal-title { color: #000000; text-shadow: none; }
[data-theme="light"] .email-modal-desc { color: rgba(0,0,0,0.5); }

/* ── Forms ── */
[data-theme="light"] .form-label { color: #555555; }
[data-theme="light"] .form-input { background: #F1F3F5; border-color: #E5E7EB; color: #000000; }
[data-theme="light"] .form-input:focus { border-color: rgba(0,102,255,0.4); box-shadow: 0 0 0 3px rgba(0,102,255,0.08); }
[data-theme="light"] .form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230066FF' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
}
[data-theme="light"] .form-select option { background: #FFFFFF; color: #000000; }
[data-theme="light"] input:focus,
[data-theme="light"] textarea:focus,
[data-theme="light"] select:focus {
    border-color: rgba(0,102,255,0.4) !important;
    box-shadow: 0 0 0 3px rgba(0,102,255,0.08) !important;
}

/* ── Pricing page ── */
[data-theme="light"] .pricing-hero-title { color: #000000; }
[data-theme="light"] .pricing-hero-sub { color: rgba(0,0,0,0.45); }
[data-theme="light"] .pricing-tagline { color: rgba(0,0,0,0.65); }
[data-theme="light"] .pricing-features-title { color: rgba(0,0,0,0.4); }
[data-theme="light"] .pricing-features-list li { color: rgba(0,0,0,0.75); }
[data-theme="light"] .pricing-features-list li::before { border-color: rgba(0,102,255,0.45); background: rgba(0,102,255,0.09); }
[data-theme="light"] .plan-featured { background: #0A2540; border-color: rgba(0,102,255,0.35); box-shadow: 0 8px 32px rgba(10,37,64,0.18); }
[data-theme="light"] .plan-featured .plan-name { color: #FFFFFF; }
[data-theme="light"] .plan-featured .plan-price { color: #FFFFFF; }
[data-theme="light"] .plan-featured .plan-price-note { color: rgba(255,255,255,0.55); }
[data-theme="light"] .plan-featured .plan-desc { color: rgba(255,255,255,0.75); }
[data-theme="light"] .plan-badge-featured { background: linear-gradient(135deg, #0066FF, #0A2540); }
[data-theme="light"] .plan-secondary { background: #FFFFFF; border: 1px solid #E5E7EB; box-shadow: 0 1px 4px rgba(0,0,0,0.06); opacity: 1; }
[data-theme="light"] .plan-name-secondary { color: #555555; }
[data-theme="light"] .plan-price-secondary { color: #000000; }
[data-theme="light"] .btn-plan-secondary { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.12); color: #555555; }
[data-theme="light"] .btn-plan-secondary:hover { background: rgba(0,0,0,0.08); color: #000000; }
[data-theme="light"] .pricing-legal { color: rgba(0,0,0,0.4); }
[data-theme="light"] .pricing-future-note { background: #FFFFFF; border: 1px solid #E5E7EB; box-shadow: 0 1px 4px rgba(0,0,0,0.05); }
[data-theme="light"] .pfn-label { color: rgba(0,0,0,0.5); }
[data-theme="light"] .pfn-price { color: rgba(0,0,0,0.5); }
[data-theme="light"] .pricing-faq-title { color: rgba(0,0,0,0.4); }
[data-theme="light"] .pricing-scarcity { background: rgba(0,0,0,0.02); border-color: rgba(0,0,0,0.08); }
[data-theme="light"] .scarcity-title { color: rgba(0,0,0,0.75); }
[data-theme="light"] .scarcity-count { color: rgba(0,0,0,0.45); }
[data-theme="light"] .scarcity-count strong { color: #000000; }
[data-theme="light"] .scarcity-bar-wrap { background: rgba(0,0,0,0.08); }
[data-theme="light"] .pricing-subscription-status { background: linear-gradient(135deg, rgba(22,163,74,0.08), rgba(22,163,74,0.04)); border-color: rgba(22,163,74,0.28); }
[data-theme="light"] .pricing-subscription-status .sub-active-text { color: #000000; }
[data-theme="light"] .pricing-subscription-status .sub-active-date { color: rgba(0,0,0,0.7); }

/* FAQ */
[data-theme="light"] .faq-item { background: #FFFFFF; border-color: #E5E7EB; }
[data-theme="light"] .faq-item:hover { border-color: #D1D5DB; }
[data-theme="light"] .faq-question-btn { color: #000000; background: rgba(0,0,0,0.02); }
[data-theme="light"] .faq-question-btn:hover,
[data-theme="light"] .faq-question-btn:focus { background: rgba(0,102,255,0.04); color: #0066FF; outline: none; }
[data-theme="light"] .faq-item.open .faq-question-btn { background: rgba(0,102,255,0.05); border-bottom-color: #E5E7EB; }
[data-theme="light"] .faq-arrow { color: #888888; }
[data-theme="light"] .faq-item.open .faq-arrow { color: #0066FF; }
[data-theme="light"] .faq-answer { color: #555555; }

/* ── Payout / Partners ── */
[data-theme="light"] .payout-hero-card { background: #0A2540; border-color: rgba(0,102,255,0.2); }
[data-theme="light"] .payout-hero-label { color: rgba(255,255,255,0.65); }
[data-theme="light"] .payout-hero-amount { color: #FFFFFF; }
[data-theme="light"] .payout-hero-stats { color: rgba(255,255,255,0.75); }
[data-theme="light"] .payout-ref-value { color: #0066FF; background: rgba(0,102,255,0.05); border-color: rgba(0,102,255,0.14); }
[data-theme="light"] .payout-copy-btn { background: rgba(0,102,255,0.07); border-color: rgba(0,102,255,0.18); color: #0066FF; }
[data-theme="light"] .payout-ref-hint { color: #888888; }
[data-theme="light"] .payout-how-title { color: #000000; }
[data-theme="light"] .payout-step-num { background: rgba(0,102,255,0.07); border-color: rgba(0,102,255,0.18); color: #0066FF; }
[data-theme="light"] .payout-step-text { color: #555555; }
[data-theme="light"] .payout-form-title { color: #000000; }
[data-theme="light"] .payout-form-desc { color: #555555; }
[data-theme="light"] .payout-legal-option { border-color: rgba(0,0,0,0.1); background: rgba(0,0,0,0.02); }
[data-theme="light"] .payout-legal-option:hover { border-color: rgba(0,0,0,0.14); background: rgba(0,0,0,0.04); }
[data-theme="light"] .payout-legal-option:has(input:checked) { border-color: rgba(0,102,255,0.38); background: rgba(0,102,255,0.06); }
[data-theme="light"] .partner-catalog-item { background: #FFFFFF; border-color: #E5E7EB; }
[data-theme="light"] .partner-catalog-item .catalog-name { color: #555555; }
[data-theme="light"] .partner-catalog-item .catalog-phrase { color: #888888; }
[data-theme="light"] .partner-catalog-item.collected .catalog-name { color: #0A2540; }
[data-theme="light"] .partner-catalog-item.collected .catalog-phrase { color: #1a237e; }
[data-theme="light"] .partner-cards-empty { color: #555555; }
[data-theme="light"] .partner-catalog-title { color: #000000; }

/* ── Legal footer ── */
[data-theme="light"] .legal-footer { color: #888888; }
[data-theme="light"] .legal-footer a { color: #0066FF; }
[data-theme="light"] .oferta-accept-text { color: #555555; }
[data-theme="light"] .oferta-link { color: #0066FF; }

/* ── Games ── */
[data-theme="light"] .game-card { background: rgba(10,37,64,0.05); border-color: rgba(0,102,255,0.18); box-shadow: none; }
[data-theme="light"] .game-card-premium { background: rgba(10,37,64,0.04); border-color: rgba(0,102,255,0.16); box-shadow: none; }
[data-theme="light"] .game-card:hover { border-color: rgba(0,102,255,0.32); box-shadow: 0 4px 16px rgba(0,0,0,0.09); }
[data-theme="light"] .game-card h3 { color: #000000; }
[data-theme="light"] .game-card p { color: #555555; }
[data-theme="light"] .btn-game { background: #0A2540 !important; color: #FFFFFF !important; text-shadow: none !important; box-shadow: none !important; font-weight: 700 !important; }
[data-theme="light"] .btn-game:hover { background: #0066FF !important; box-shadow: 0 2px 8px rgba(0,102,255,0.25) !important; }
[data-theme="light"] .ms-featured-card { background: #0A2540 !important; border-color: rgba(0,102,255,0.28) !important; box-shadow: 0 4px 20px rgba(10,37,64,0.18) !important; }
[data-theme="light"] .ms-featured-card h3 { color: #FFFFFF !important; text-shadow: none !important; }
[data-theme="light"] .ms-featured-card p { color: rgba(255,255,255,0.75) !important; }

/* ── Scrollbar ── */
[data-theme="light"] ::-webkit-scrollbar-track { background: transparent; }
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.14); }

/* ── Desktop ── */
@media (min-width: 1024px) {
    [data-theme="light"] #app { box-shadow: -1px 0 0 rgba(0,0,0,0.06), 1px 0 0 rgba(0,0,0,0.06); }
    [data-theme="light"] .tab-bar { border-left: 1px solid rgba(0,0,0,0.06) !important; border-right: 1px solid rgba(0,0,0,0.06) !important; }
    [data-theme="light"] .app-header { border-left: 1px solid rgba(0,0,0,0.06) !important; border-right: 1px solid rgba(0,0,0,0.06) !important; }
    [data-theme="light"] .glass-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.10); border-color: #D1D5DB; transform: translateY(-3px); }
}

/* ── Theme toggle button (inside header-right) ── */
.theme-toggle-btn {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition), transform 0.2s;
    color: var(--text-secondary);
    flex-shrink: 0;
    padding: 0;
}
.theme-toggle-btn:hover { background: rgba(128,128,128,0.12); transform: scale(1.08); }
.theme-toggle-btn svg { width: 20px; height: 20px; transition: transform 0.4s cubic-bezier(0.4,0,0.2,1); }
/* Dark mode shows sun, light mode shows moon */
.theme-toggle-btn .icon-sun { display: block; }
.theme-toggle-btn .icon-moon { display: none; }
[data-theme="light"] .theme-toggle-btn .icon-sun { display: none; }
[data-theme="light"] .theme-toggle-btn .icon-moon { display: block; }
[data-theme="light"] .theme-toggle-btn { color: #555555; }

/* ========================================
   LIGHT THEME — GAME OVERLAY (spy / alias / music)
   ======================================== */
[data-theme="light"] .game-overlay-back-row {
    background: #FFFFFF;
    border-bottom: 1px solid rgba(0,0,0,0.08);
}
[data-theme="light"] .game-overlay h2 {
    color: #000000;
    text-shadow: none;
}
[data-theme="light"] .game-overlay .player-input-section {
    background: #F8F9FA;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
}
[data-theme="light"] .game-overlay .player-count-btn,
[data-theme="light"] .game-overlay .category-btn {
    background: #F1F3F5;
    border: 1px solid rgba(0,0,0,0.09);
    color: #333333;
}
[data-theme="light"] .game-overlay .player-count-btn:hover,
[data-theme="light"] .game-overlay .category-btn:hover {
    background: #E8EAED;
    border-color: #0066FF;
    color: #0066FF;
}
[data-theme="light"] .game-overlay .player-count-btn.active,
[data-theme="light"] .game-overlay .category-btn.active {
    background: #0066FF;
    border-color: #0066FF;
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(0,102,255,0.3);
}
[data-theme="light"] .game-overlay .game-btn {
    background: #0066FF;
    box-shadow: none;
}
[data-theme="light"] .game-overlay .game-btn:hover:not(:disabled) {
    background: #0052CC;
    box-shadow: 0 4px 16px rgba(0,102,255,0.25);
    transform: translateY(-1px);
}
[data-theme="light"] .game-overlay .player-input {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.12);
    color: #000000;
}
[data-theme="light"] .game-overlay .player-input:focus {
    border-color: #0066FF;
    box-shadow: 0 0 0 3px rgba(0,102,255,0.1);
}
[data-theme="light"] .game-overlay .player-input-label { color: #000000; }

/* ========================================
   LIGHT THEME — MONOSLOVO GAME (monoslovo.css overrides)
   ======================================== */

/* Layout & background */
[data-theme="light"] #monoslovo-interface { background: #FFFFFF; }

/* Header */
[data-theme="light"] .ms-back-btn { color: #0066FF; }
[data-theme="light"] .ms-back-btn:hover { text-shadow: none; text-decoration: underline; }
[data-theme="light"] .ms-title { color: #000000; text-shadow: none; }
[data-theme="light"] .ms-explain { color: #555555; }
[data-theme="light"] .ms-subtitle { color: #666666; }
[data-theme="light"] .ms-section-label { color: #888888; }

/* Deck cards */
[data-theme="light"] .ms-deck-card {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.09);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05), 0 4px 12px rgba(0,0,0,0.06);
}
[data-theme="light"] .ms-deck-card:hover {
    background: #F8F9FA;
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
}
[data-theme="light"] .ms-deck-selected {
    border-color: #0066FF;
    background: rgba(0,102,255,0.04);
    box-shadow: 0 0 0 2px rgba(0,102,255,0.25);
}
[data-theme="light"] .ms-deck-name { color: #000000; }
[data-theme="light"] .ms-deck-words { color: #888888; }
[data-theme="light"] .ms-deck-emoji {
    color: #0066FF;
    background: rgba(0,102,255,0.07);
    border-color: rgba(0,102,255,0.18);
}
[data-theme="light"] .ms-badge-free {
    background: rgba(22,163,74,0.08);
    color: #16A34A;
    border-color: rgba(22,163,74,0.2);
}
[data-theme="light"] .ms-badge-paid {
    background: rgba(220,38,38,0.06);
    color: #DC2626;
    border-color: rgba(220,38,38,0.18);
}

/* Buttons */
[data-theme="light"] .ms-btn-primary {
    background: #0066FF;
    color: #FFFFFF;
    border: none;
    box-shadow: none;
}
[data-theme="light"] .ms-btn-primary:hover {
    background: #0052CC;
    box-shadow: 0 4px 16px rgba(0,102,255,0.25);
}
[data-theme="light"] .ms-btn-secondary {
    background: #F1F3F5;
    color: #000000;
    border: 1px solid rgba(0,0,0,0.08);
}
[data-theme="light"] .ms-btn-secondary:hover { background: #E8EAED; box-shadow: none; }
[data-theme="light"] .ms-btn-danger {
    background: rgba(220,38,38,0.06);
    color: #DC2626;
    border: 1px solid rgba(220,38,38,0.18);
}
[data-theme="light"] .ms-btn-ghost { color: #666666; }

/* Count / round selector */
[data-theme="light"] .ms-count-btn {
    background: #F1F3F5;
    border: 1px solid rgba(0,0,0,0.08);
    color: #000000;
    backdrop-filter: none;
}
[data-theme="light"] .ms-count-btn:hover { background: #E8EAED; }
[data-theme="light"] .ms-count-active {
    background: rgba(0,102,255,0.08);
    border-color: #0066FF;
    color: #0066FF;
    box-shadow: none;
}

/* Player row inputs */
[data-theme="light"] .ms-player-team-badge { border-width: 1px; }
[data-theme="light"] .ms-team-num { color: #ffffff !important; }

/* Gameplay header */
[data-theme="light"] .ms-round-badge {
    background: #F1F3F5;
    border: none;
    color: #555555;
}
[data-theme="light"] .ms-current-player {
    background: #F8F9FA;
    border: 1px solid rgba(0,0,0,0.07);
    backdrop-filter: none;
}
[data-theme="light"] .ms-player-name-badge { color: #000000; }
[data-theme="light"] .ms-team-tag { color: #ffffff; }

/* Timer */
[data-theme="light"] .ms-timer-bar-bg { background: rgba(0,0,0,0.08); }
[data-theme="light"] .ms-timer-count { color: #000000; }

/* Word card — key gameplay element */
[data-theme="light"] .ms-word-card {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 4px 24px rgba(0,0,0,0.1);
}
[data-theme="light"] .ms-word-text { color: #000000; text-shadow: none; }

/* Score display */
[data-theme="light"] .ms-score-val { color: #000000; }
[data-theme="light"] .ms-score-1 .ms-score-val { color: #0066FF; text-shadow: none; }
[data-theme="light"] .ms-score-2 .ms-score-val { color: #D94F1E; text-shadow: none; }
[data-theme="light"] .ms-score-3 .ms-score-val { color: #16A34A; text-shadow: none; }
[data-theme="light"] .ms-score-4 .ms-score-val { color: #9333EA; text-shadow: none; }

/* Action buttons */
[data-theme="light"] .ms-btn-skip {
    background: rgba(220,38,38,0.06);
    color: #DC2626;
    border: 1px solid rgba(220,38,38,0.18);
}
[data-theme="light"] .ms-btn-skip:hover { box-shadow: 0 2px 10px rgba(220,38,38,0.15); }
[data-theme="light"] .ms-btn-correct {
    background: rgba(22,163,74,0.07);
    color: #16A34A;
    border: 1px solid rgba(22,163,74,0.2);
}
[data-theme="light"] .ms-btn-correct:hover { box-shadow: 0 2px 10px rgba(22,163,74,0.15); }
[data-theme="light"] .ms-end-round-btn {
    background: #F1F3F5;
    border: 1px solid rgba(0,0,0,0.07);
    color: #555555;
}

/* Team score cards */
[data-theme="light"] .ms-team-score-card {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
[data-theme="light"] .ms-ts-val { color: #000000; }
[data-theme="light"] .ms-team-1-card .ms-ts-val { color: #0066FF; }
[data-theme="light"] .ms-team-2-card .ms-ts-val { color: #D94F1E; }
[data-theme="light"] .ms-team-3-card .ms-ts-val { color: #16A34A; }
[data-theme="light"] .ms-team-4-card .ms-ts-val { color: #9333EA; }
[data-theme="light"] .ms-team-1-card { border-color: rgba(0,102,255,0.25); }
[data-theme="light"] .ms-team-2-card { border-color: rgba(217,79,30,0.25); }
[data-theme="light"] .ms-team-3-card { border-color: rgba(22,163,74,0.25); }
[data-theme="light"] .ms-team-4-card { border-color: rgba(147,51,234,0.25); }

/* Transition / next player */
[data-theme="light"] .ms-next-player-name { color: #000000; }

/* Likes screen */
[data-theme="light"] .ms-likes-header { color: #000000; }
[data-theme="light"] .ms-likes-badge { background: rgba(0,0,0,0.06); color: #000000; }
[data-theme="light"] .ms-round-word-row {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
}
[data-theme="light"] .ms-round-word-text { color: #000000; }
[data-theme="light"] .ms-like-btn { background: rgba(0,0,0,0.05); }
[data-theme="light"] .ms-like-btn:hover { background: rgba(0,0,0,0.09); }

/* Results screen */
[data-theme="light"] .ms-results-trophy { color: #F4C542; text-shadow: none; }
[data-theme="light"] .ms-results-title { color: #000000; text-shadow: none; }
[data-theme="light"] .ms-final-score-card {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
}
[data-theme="light"] .ms-winner-card {
    border-color: rgba(244,197,66,0.45);
    background: rgba(244,197,66,0.05);
    box-shadow: 0 4px 16px rgba(244,197,66,0.15);
}
[data-theme="light"] .ms-winner-crown { color: #F4C542; }
[data-theme="light"] .ms-fs-val { color: #000000; }
[data-theme="light"] .ms-award-card {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
}
[data-theme="light"] .ms-award-icon { color: #0066FF; }
[data-theme="light"] .ms-award-name { color: #000000; }

/* Share button */
[data-theme="light"] .ms-share-btn {
    background: rgba(0,102,255,0.07);
    border: 1px solid rgba(0,102,255,0.25);
    color: #0066FF;
}
[data-theme="light"] .ms-share-btn:hover:not(:disabled) { box-shadow: 0 4px 14px rgba(0,102,255,0.2); }

/* Payment modal */
[data-theme="light"] .ms-pay-btn {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.08);
    backdrop-filter: none;
}
[data-theme="light"] .ms-pay-btn:hover { background: #F8F9FA; }
[data-theme="light"] .ms-pay-stars { border-color: rgba(220,38,38,0.2); background: rgba(220,38,38,0.04); }
[data-theme="light"] .ms-pay-card { border-color: rgba(0,102,255,0.2); background: rgba(0,102,255,0.04); }
[data-theme="light"] .ms-pay-stars .ms-pay-icon { color: #DC2626; }
[data-theme="light"] .ms-pay-card .ms-pay-icon { color: #0066FF; }
[data-theme="light"] .ms-pay-label { color: #000000; }
[data-theme="light"] .ms-share-caption { color: rgba(0,0,0,0.45); }

/* ========================================
   LIGHT THEME — ADDITIONAL FIXES
   ======================================== */

/* Hero streak / badge inside dark navy hero card stays white (intentional) */
[data-theme="light"] .hero-card .hero-streak-badge { background: rgba(255,255,255,0.15); color: #fff; }

/* Activity page — bar charts */
[data-theme="light"] .activity-bar-bg { background: rgba(0,0,0,0.07); }
[data-theme="light"] .activity-bar-fill { background: #0066FF; }

/* Goals / Progress rings */
[data-theme="light"] .progress-ring-track { stroke: rgba(0,0,0,0.08); }
[data-theme="light"] .progress-ring-fill { stroke: #0066FF; }

/* Section headings */
[data-theme="light"] .section-title { color: #000000; }
[data-theme="light"] .section-subtitle { color: #666666; }

/* Habit row done state */
[data-theme="light"] .habit-row.done .habit-check { background: #16A34A; border-color: #16A34A; }
[data-theme="light"] .habit-row.done .habit-name { color: #888888; text-decoration: line-through; }

/* Calendar day active / today */
[data-theme="light"] .cal-day.today { background: rgba(0,102,255,0.08); color: #0066FF; font-weight: 700; }
[data-theme="light"] .cal-day.active { background: #0066FF; color: #ffffff; }
[data-theme="light"] .cal-day.has-event::after { background: #F4C542; }

/* Notification badge */
[data-theme="light"] .notif-badge { background: #DC2626; color: #fff; }

/* Scrollbar in content areas */
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.14); }
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,0.22); }
[data-theme="light"] ::-webkit-scrollbar-track { background: transparent; }

/* Modal close button */
[data-theme="light"] .modal-close,
[data-theme="light"] .sheet-close { color: #555555; background: rgba(0,0,0,0.05); }
[data-theme="light"] .modal-close:hover,
[data-theme="light"] .sheet-close:hover { background: rgba(0,0,0,0.1); color: #000000; }

/* Dropdown / select menus */
[data-theme="light"] select,
[data-theme="light"] .form-select {
    background: #FFFFFF;
    border: 1px solid rgba(0,0,0,0.12);
    color: #000000;
}
[data-theme="light"] select option { background: #FFFFFF; color: #000000; }

/* Textarea */
[data-theme="light"] textarea {
    background: #F8F9FA;
    border: 1px solid rgba(0,0,0,0.1);
    color: #000000;
}
[data-theme="light"] textarea:focus {
    background: #FFFFFF;
    border-color: #0066FF;
    box-shadow: 0 0 0 3px rgba(0,102,255,0.08);
}

/* Chip / tag elements */
[data-theme="light"] .chip,
[data-theme="light"] .tag {
    background: rgba(0,0,0,0.05);
    color: #333333;
    border: 1px solid rgba(0,0,0,0.08);
}
[data-theme="light"] .chip.active,
[data-theme="light"] .tag.active {
    background: #0066FF;
    color: #ffffff;
    border-color: #0066FF;
}

/* Dividers */
[data-theme="light"] .divider,
[data-theme="light"] hr { border-color: rgba(0,0,0,0.07); }

/* Empty state messages */
[data-theme="light"] .empty-state,
[data-theme="light"] .empty-text { color: #999999; }
[data-theme="light"] .empty-icon { opacity: 0.3; }

/* Loading skeleton */
[data-theme="light"] .skeleton { background: linear-gradient(90deg, #F0F0F0 25%, #E0E0E0 50%, #F0F0F0 75%); }

/* Badge labels (blue accent) */
[data-theme="light"] .badge-accent { background: rgba(0,102,255,0.1); color: #0066FF; }
[data-theme="light"] .badge-success { background: rgba(22,163,74,0.1); color: #16A34A; }
[data-theme="light"] .badge-warning { background: rgba(244,197,66,0.15); color: #B8860B; }
[data-theme="light"] .badge-danger { background: rgba(220,38,38,0.08); color: #DC2626; }

/* Voice/tone item hover */
[data-theme="light"] .voicetone-item:hover { background: #F1F3F5; border-color: rgba(0,0,0,0.12); }
[data-theme="light"] .voicetone-item.active { background: rgba(0,102,255,0.06); border-color: rgba(0,102,255,0.3); }

/* Payout page extras */
[data-theme="light"] .payout-stat-row { border-top: 1px solid rgba(0,0,0,0.07); }
[data-theme="light"] .payout-stat-val { color: #000000; }
[data-theme="light"] .payout-stat-label { color: #666666; }

/* Partner / referral card */
[data-theme="light"] .partner-card { background: #FFFFFF; border: 1px solid rgba(0,0,0,0.08); }
[data-theme="light"] .partner-link-box { background: #F8F9FA; border: 1px solid rgba(0,0,0,0.08); }
[data-theme="light"] .partner-link-text { color: #333333; }

/* AI chat extras */
[data-theme="light"] .chat-empty-state { color: #999999; }
[data-theme="light"] .chat-typing-dot { background: #0066FF; }

/* Quick AI input extras */
[data-theme="light"] .quick-ai-send-btn { background: #0066FF; color: #ffffff; }
[data-theme="light"] .quick-ai-send-btn:hover { background: #0052CC; }

/* Accordion / FAQ item open state */
[data-theme="light"] .faq-item.open { background: #FFFFFF; border-color: rgba(0,102,255,0.25); }
[data-theme="light"] .faq-answer { color: #333333; }

