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

        :root {
            --bg: #000000;
            --text: #f5f5f0;
            --fg: #f5f5f0;
            --accent: #a0a090;
            --dim: #8a8a80;
            --muted: #6a6a60;
            --border: #2a2a25;
            --danger: #c44;
            --warn: #e8a825;
            --success: #6a6;
            --card-bg: rgba(255,255,255,0.07);
            --card: rgba(255,255,255,0.07);
            --surface: rgba(10,15,10,0.98);
            --surface2: rgba(255,255,255,0.05);
        }

        [data-theme="light"] {
            --bg: #f8fafc;
            --text: #0f172a;
            --fg: #0f172a;
            --accent: #16a34a;
            --dim: #64748b;
            --muted: #94a3b8;
            --border: #cbd5e1;
            --danger: #ef4444;
            --warn: #f59e0b;
            --success: #16a34a;
            --card-bg: #ffffff;
            --card: #ffffff;
            --surface: #ffffff;
            --surface2: #f1f5f9;
        }

        body {
            background: var(--bg);
            color: var(--text);
            font-family: system-ui, -apple-system, sans-serif;
            font-size: 17px;
            line-height: 1.6;
            min-height: 100vh;
            -webkit-font-smoothing: antialiased;
            overflow-x: hidden;
        }
        body::before, body::after {
            content: '';
            position: fixed;
            inset: 0;
            z-index: -1;
            pointer-events: none;
        }
        body::before {
            background:
                radial-gradient(ellipse at 20% 0%, rgba(16,85,60,0.25) 0%, transparent 60%),
                radial-gradient(ellipse at 80% 100%, rgba(10,60,80,0.2) 0%, transparent 60%);
            z-index: -2;
            background-color: var(--bg);
        }
        body::after {
            display: none;
        }
        [data-theme="light"] body {
            background: var(--bg);
        }
        [data-theme="light"] body::before {
            background: none;
            background-color: var(--bg);
        }
        [data-theme="light"] .aurora-blob { display: none; }

        /* ============================================================ */
        /* Aurora Background — ambient animated gradient blobs          */
        /* ============================================================ */
        .aurora-bg {
            position: fixed;
            inset: 0;
            z-index: 0;
            pointer-events: none;
            overflow: hidden;
            opacity: 0;
            transition: opacity 1.5s ease;
        }
        .aurora-bg.active { opacity: 1; }
        .aurora-bg.active + .aurora-static-fallback { opacity: 0; }

        .aurora-blob {
            position: absolute;
            border-radius: 50%;
            filter: blur(120px);
            will-change: transform;
            mix-blend-mode: screen;
        }
        .aurora-blob-1 {
            width: 60vmax; height: 60vmax;
            top: -20%; left: -10%;
            background: radial-gradient(circle, rgba(16,185,129,0.18) 0%, transparent 70%);
            animation: auroraFloat1 80s ease-in-out infinite;
        }
        .aurora-blob-2 {
            width: 50vmax; height: 50vmax;
            bottom: -15%; right: -10%;
            background: radial-gradient(circle, rgba(6,182,212,0.14) 0%, transparent 70%);
            animation: auroraFloat2 100s ease-in-out infinite;
        }
        .aurora-blob-3 {
            width: 45vmax; height: 45vmax;
            top: 30%; left: 40%;
            background: radial-gradient(circle, rgba(16,85,60,0.16) 0%, transparent 70%);
            animation: auroraFloat3 90s ease-in-out infinite;
        }
        .aurora-blob-4 {
            width: 35vmax; height: 35vmax;
            top: 60%; left: 10%;
            background: radial-gradient(circle, rgba(52,211,153,0.10) 0%, transparent 70%);
            animation: auroraFloat4 110s ease-in-out infinite;
        }

        @keyframes auroraFloat1 {
            0%, 100% { transform: translate(0, 0) scale(1); }
            25% { transform: translate(8vw, 12vh) scale(1.08); }
            50% { transform: translate(-5vw, 8vh) scale(0.95); }
            75% { transform: translate(10vw, -5vh) scale(1.04); }
        }
        @keyframes auroraFloat2 {
            0%, 100% { transform: translate(0, 0) scale(1); }
            25% { transform: translate(-10vw, -8vh) scale(1.06); }
            50% { transform: translate(6vw, -12vh) scale(0.97); }
            75% { transform: translate(-8vw, 5vh) scale(1.03); }
        }
        @keyframes auroraFloat3 {
            0%, 100% { transform: translate(0, 0) scale(1); }
            33% { transform: translate(-12vw, 6vh) scale(1.1); }
            66% { transform: translate(8vw, -10vh) scale(0.92); }
        }
        @keyframes auroraFloat4 {
            0%, 100% { transform: translate(0, 0) scale(1); }
            30% { transform: translate(15vw, -8vh) scale(1.05); }
            60% { transform: translate(-6vw, 10vh) scale(0.98); }
        }

        /* Light theme aurora — hidden */

        /* Reduced motion — pause animations */
        @media (prefers-reduced-motion: reduce) {
            .aurora-blob { animation: none !important; }
        }
        [data-theme="light"] h1 {
            background: linear-gradient(135deg, #0f172a 30%, #16a34a);
            -webkit-background-clip: text;
            background-clip: text;
        }
        [data-theme="light"] h2 {
            background: linear-gradient(135deg, #0f172a 40%, #16a34a);
            -webkit-background-clip: text;
            background-clip: text;
        }
        [data-theme="light"] .hdr-profile-btn { color: #6b7280; border-color: #d1d5db; }
        [data-theme="light"] .hdr-profile-btn:hover { color: #16a34a; border-color: #16a34a; }
        [data-theme="light"] .section-collapsible {
            background: #fff;
            border-color: var(--border);
            box-shadow: 0 1px 3px rgba(0,0,0,0.06);
            border-radius: 8px;
        }
        [data-theme="light"] .rule-item {
            background: #fff;
            border-color: var(--border);
            box-shadow: 0 1px 2px rgba(0,0,0,0.04);
        }
        [data-theme="light"] .btn {
            border-color: var(--border);
        }
        [data-theme="light"] .btn-primary {
            border: none;
            color: #fff;
            background: var(--success);
        }
        [data-theme="light"] .modal {
            background: #fff;
            box-shadow: 0 8px 32px rgba(0,0,0,0.12);
        }
        [data-theme="light"] .modal-overlay {
            background: rgba(0,0,0,0.3);
        }
        [data-theme="light"] #notification-panel {
            background: #fff;
            border-color: var(--border);
            box-shadow: 0 4px 20px rgba(0,0,0,0.1);
        }
        [data-theme="light"] #lang-dropdown,
        [data-theme="light"] #nav-more-dropdown {
            background: #fff !important;
            border-color: var(--border) !important;
            box-shadow: 0 4px 20px rgba(0,0,0,0.1) !important;
        }
        [data-theme="light"] .nav-dd-item { color: #374151; }
        [data-theme="light"] .nav-dd-item:hover { background: #f1f5f9; color: #16a34a; }
        [data-theme="light"] input,
        [data-theme="light"] select,
        [data-theme="light"] textarea {
            background: #fff;
            color: var(--text);
            border-color: var(--border);
        }
        [data-theme="light"] input:focus,
        [data-theme="light"] select:focus,
        [data-theme="light"] textarea:focus {
            border-color: var(--success);
            outline: none;
        }
        /* Light theme: fix inline rgba(255,255,255,...) backgrounds + text colors */
        [data-theme="light"] [style*="rgba(255,255,255,0.0"] { background-color: rgba(0,0,0,0.03) !important; }
        [data-theme="light"] [style*="rgba(255,255,255,0.1"] { background-color: rgba(0,0,0,0.04) !important; }
        [data-theme="light"] [style*="color:rgba(255,255,255"] { color: var(--text) !important; }
        [data-theme="light"] [style*="border-bottom:1px solid rgba(255,255,255"] { border-bottom-color: var(--border) !important; }
        [data-theme="light"] [style*="border:1px solid rgba(255,255,255"] { border-color: var(--border) !important; }
        [data-theme="light"] [style*="border-left:3px solid rgba(255,255,255"] { border-left-color: var(--border) !important; }
        /* Light: fix inline rgba backgrounds */
        [data-theme="light"] [style*="background:rgba(255,255,255,0.0"] { background: #f1f5f9 !important; }
        [data-theme="light"] [style*="background:rgba(255,255,255,0.1"] { background: #f1f5f9 !important; }
        [data-theme="light"] [style*="background: rgba(255,255,255,0.0"] { background: #f1f5f9 !important; }
        [data-theme="light"] [style*="background: rgba(255,255,255,0.1"] { background: #f1f5f9 !important; }
        [data-theme="light"] select option { background: #fff; color: var(--text); }
        [data-theme="light"] .hdr-theme-toggle { background: #fff; }
        [data-theme="light"] label { color: var(--dim); }
        [data-theme="light"] p { color: var(--dim); }
        [data-theme="light"] .tagline { color: var(--dim); }
        /* Theme toggle button */
        .hdr-theme-toggle { background: var(--card-bg); border: 1px solid var(--border); color: var(--text); padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.15s; font-family: inherit; }
        .hdr-theme-toggle:hover { border-color: var(--success); color: var(--success); }

        .app {
            max-width: 640px;
            margin: 0 auto;
            padding: 52px 24px 60px 24px;
        }

        /* Opera-style circular reveal theme transition */
        ::view-transition-old(root) {
            animation: none;
            z-index: -1;
        }
        ::view-transition-new(root) {
            animation: 0.7s ease-in-out both circleReveal;
        }
        @keyframes circleReveal {
            from { clip-path: circle(0% at var(--tx, 50%) var(--ty, 50%)); }
            to { clip-path: circle(150% at var(--tx, 50%) var(--ty, 50%)); }
        }
        .theme-transitioning,
        .theme-transitioning *,
        .theme-transitioning *::before,
        .theme-transitioning *::after {
            transition: background-color 0.6s ease, background 0.6s ease, color 0.5s ease, border-color 0.5s ease, box-shadow 0.5s ease, filter 0.5s ease !important;
        }

        /* Logo */
        .logo-wrap {
            display: flex;
            align-items: center;
            gap: 12px;
            margin-bottom: 8px;
        }
        .logo-wrap img {
            height: 32px;
            width: auto;
            filter: brightness(0) invert(1);
        }
        [data-theme="light"] .logo-wrap img {
            filter: brightness(0);
        }
        .logo-text {
            font-size: 1.1rem;
            font-weight: 600;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: var(--text);
        }

        /* Fixed Header */
        .app-header {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 100;
            background: var(--surface);
            border-bottom: 1px solid var(--border);
            padding: 8px 16px;
            align-items: center;
            justify-content: space-between;
        }
        .app-header-brand {
            display: flex;
            align-items: center;
            gap: 8px;
            text-decoration: none;
            cursor: pointer;
        }
        .app-header-brand img { height: 22px; width: auto; filter: brightness(0) invert(1); }
        .app-header-brand span {
            font-size: 0.85rem;
            font-weight: 600;
            letter-spacing: 2px;
            text-transform: uppercase;
            color: var(--text);
        }
        .app-header-utils {
            display: flex;
            align-items: center;
            gap: 2px;
        }
        .app-header-utils .hdr-btn {
            background: none;
            border: none;
            color: var(--text);
            cursor: pointer;
            padding: 6px 8px;
            font-size: 13px;
            font-family: inherit;
            transition: color 0.2s;
            position: relative;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .app-header-utils .hdr-btn:hover { color: var(--accent); }
        .hdr-burger-btn { display: none; }
        #hdr-pcl:hover { background: rgba(106,170,106,0.22) !important; border-color: rgba(106,170,106,0.4) !important; }
        .solid-bg { background: var(--surface); }
        [data-theme="light"] .app-header-brand img { filter: brightness(0); }
        [data-theme="light"] #hdr-pcl { background: rgba(106,170,106,0.1); border-color: rgba(106,170,106,0.3); }

        /* Nav Copyright */
        .nav-copyright {
            display: block;
            position: fixed;
            bottom: 0;
            left: 180px;
            right: 0;
            text-align: center;
            padding: 10px 12px;
            font-size: 11px;
            color: var(--dim);
            background: var(--surface);
            border-top: 1px solid var(--border);
            z-index: 99;
        }
        [data-theme="light"] .nav-copyright { box-shadow: 0 -1px 3px rgba(0,0,0,0.06); }
        .nav-copyright p { margin: 0; line-height: 1.6; font-size: 11px; }
        .nav-copyright a { color: var(--dim); text-decoration: none; font-size: 11px; }
        .nav-copyright a:hover { color: var(--accent); }
        [data-theme="light"] .nav-copyright { color: #4b5563; }
        [data-theme="light"] .nav-copyright a { color: #4b5563; }

        h1 {
            font-size: 1.75rem;
            font-weight: 600;
            margin-bottom: 8px;
            background: linear-gradient(135deg, var(--text) 30%, var(--success));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }
        h2 {
            font-size: 1.25rem;
            font-weight: 600;
            margin-bottom: 12px;
            background: linear-gradient(135deg, var(--text) 40%, var(--success));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }
        p {
            color: var(--accent);
            margin-bottom: 16px;
            font-size: 0.95rem;
        }
        .tagline {
            font-size: 1.1rem;
            color: var(--accent);
            margin-bottom: 32px;
        }

        /* Sections */
        .section {
            margin-bottom: 32px;
        }

        /* Buttons */
        .btn {
            display: block;
            width: 100%;
            padding: 14px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--text);
            font-size: 0.9rem;
            font-family: inherit;
            cursor: pointer;
            text-decoration: none;
            text-align: center;
            margin-bottom: 10px;
            transition: all 0.25s ease;
        }
        .btn:hover {
            border-color: var(--accent);
            transform: translateY(-1px);
        }
        .btn:active {
            transform: translateY(0);
        }
        .btn-primary {
            border: none;
            color: #fff;
            background: linear-gradient(135deg, #16a34a, #22d3ee);
        }
        .btn-primary:hover {
            opacity: 0.9;
            box-shadow: 0 2px 12px rgba(22,163,74,0.3);
        }
        .btn-danger {
            border-color: var(--danger);
            color: var(--danger);
        }
        .btn-danger:hover {
            background: var(--danger);
            color: var(--bg);
            box-shadow: 0 2px 12px rgba(204,68,68,0.2);
        }
        .btn-small {
            display: inline-block;
            width: auto;
            padding: 8px 16px;
            font-size: 0.8rem;
        }
        .btn-success {
            border-color: var(--success);
            color: var(--success);
        }
        .btn-success:hover {
            background: var(--success);
            color: var(--bg);
        }

        /* Action log items */
        .action-item {
            border-bottom: 1px solid var(--border);
            padding: 14px 0;
            transition: background 0.2s;
        }
        .action-item:hover {
            background: rgba(128,128,128,0.05);
        }
        .action-item:last-child {
            border-bottom: none;
        }
        .action-type {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--dim);
            margin-bottom: 4px;
        }
        .action-type[data-type="meeting_cancelled"] { color: var(--danger); }
        .action-type[data-type="zone_a_blocked"] { color: var(--success); }
        .action-type[data-type="meeting_moved"] { color: #ca6; }
        .action-type[data-type="emergency_activated"] { color: var(--danger); }
        .action-target {
            color: var(--text);
            font-size: 0.9rem;
        }
        .action-reason {
            color: var(--accent);
            font-size: 0.8rem;
            margin-top: 2px;
        }
        .action-time {
            color: var(--dim);
            font-size: 0.75rem;
            margin-top: 4px;
        }

        /* Rule items */
        .rule-item {
            border: 1px solid var(--border);
            padding: 16px 18px;
            margin-bottom: 8px;
            background: var(--card-bg);
            transition: all 0.25s ease;
        }
        .rule-item:hover {
            border-color: var(--accent);
            background: rgba(128,128,128,0.05);
            transform: translateX(2px);
        }
        .rule-label {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--dim);
            margin-bottom: 4px;
        }
        .rule-text {
            color: var(--text);
            font-size: 0.9rem;
        }
        .rule-locked {
            display: inline-block;
            font-size: 0.6rem;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--dim);
            background: var(--card-bg);
            padding: 2px 8px;
            border-radius: 8px;
            margin-left: 8px;
        }

        /* Report bullets */
        .report-bullet {
            padding: 12px 0;
            border-bottom: 1px solid var(--border);
            color: var(--text);
            font-size: 0.9rem;
        }
        .report-bullet:last-child {
            border-bottom: none;
        }
        .report-meta {
            color: var(--dim);
            font-size: 0.8rem;
            margin-top: 16px;
        }

        /* Account items */
        .account-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 14px 16px;
            border: 1px solid var(--border);
            margin-bottom: 8px;
            background: rgba(255,255,255,0.01);
            transition: all 0.2s ease;
        }
        .account-item:hover {
            border-color: #3a3a30;
            background: rgba(255,255,255,0.03);
        }
        .account-email {
            font-size: 0.9rem;
            color: var(--text);
        }
        .account-provider {
            font-size: 0.7rem;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--dim);
        }

        /* Emergency badge */
        .emergency-badge {
            display: inline-block;
            font-size: 0.7rem;
            text-transform: uppercase;
            letter-spacing: 1px;
            color: var(--danger);
            border: 1px solid var(--danger);
            padding: 4px 10px;
            margin-bottom: 16px;
        }

        /* Status indicator */
        .status-active {
            color: var(--success);
            font-size: 0.8rem;
            margin-bottom: 16px;
        }

        /* Pricing */
        .plan {
            border: 1px solid var(--border);
            padding: 24px;
            margin-bottom: 16px;
            background: rgba(255,255,255,0.01);
            transition: all 0.3s ease;
        }
        .plan:hover {
            border-color: #3a3a30;
            background: rgba(255,255,255,0.03);
            transform: translateY(-2px);
            box-shadow: 0 4px 20px rgba(0,0,0,0.3);
        }
        .plan-name {
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 2px;
            color: var(--dim);
            margin-bottom: 8px;
        }
        .plan-price {
            font-size: 1.5rem;
            font-weight: 600;
            color: var(--text);
            margin-bottom: 4px;
        }
        .plan-period {
            font-size: 0.8rem;
            color: var(--accent);
            margin-bottom: 12px;
        }
        .plan-annual {
            font-size: 0.8rem;
            color: var(--accent);
            margin-bottom: 16px;
        }
        .plan-features {
            list-style: none;
            margin-bottom: 16px;
        }
        .plan-features li {
            font-size: 0.85rem;
            color: var(--accent);
            padding: 4px 0;
        }
        .plan-features li::before {
            content: "- ";
            color: var(--dim);
        }
        .plan-toggle {
            display: flex;
            justify-content: center;
            gap: 16px;
            margin-bottom: 24px;
        }
        .plan-toggle-btn {
            background: transparent;
            border: 1px solid var(--border);
            color: var(--dim);
            padding: 8px 20px;
            font-family: inherit;
            font-size: 0.8rem;
            cursor: pointer;
        }
        .plan-toggle-btn.active {
            border-color: var(--accent);
            color: var(--text);
        }
        .plan-save {
            font-size: 0.7rem;
            color: var(--success);
            text-transform: uppercase;
            letter-spacing: 1px;
        }

        /* Privacy */
        .privacy-section {
            margin-bottom: 24px;
        }
        .privacy-section h3 {
            font-size: 0.95rem;
            font-weight: 600;
            margin-bottom: 8px;
            color: var(--text);
        }
        .privacy-section p {
            font-size: 0.85rem;
            color: var(--accent);
            line-height: 1.7;
        }

        /* Empty state */
        .empty {
            color: var(--dim);
            font-size: 0.9rem;
            padding: 32px 0;
        }

        /* Loading */
        .loading {
            color: var(--dim);
            font-size: 0.85rem;
            padding: 16px 0;
        }
        @keyframes pulse {
            0%, 100% { opacity: 0.4; }
            50% { opacity: 1; }
        }
        .loading::before {
            content: "";
            display: inline-block;
            width: 8px;
            height: 8px;
            background: var(--success);
            border-radius: 50%;
            margin-right: 8px;
            animation: pulse 1.5s ease infinite;
        }

        /* Page fade in */
        .page.active {
            animation: pageFadeIn 0.3s ease;
        }
        @keyframes pageFadeIn {
            from { opacity: 0; transform: translateY(8px); }
            to { opacity: 1; transform: translateY(0); }
        }

        /* ============================================================ */
        /* LEFT DRAWER NAVIGATION (mobile-first, overlay on all sizes) */
        /* ============================================================ */
        .sidebar {
            position: fixed;
            top: 48px;
            left: 0;
            bottom: 37px;
            width: 180px;
            background: var(--surface);
            border-right: 1px solid var(--border);
            z-index: 501;
            display: none;
            flex-direction: column;
            overflow: hidden;
        }

        /* Drawer header - hidden (brand is in app-header) */
        .sidebar-header { display: none; }

        /* Drawer body */
        .sidebar-nav {
            flex: 1;
            overflow-y: auto;
            padding: 8px 0;
            scrollbar-width: thin;
            scrollbar-color: var(--border) transparent;
        }
        .sidebar-nav::-webkit-scrollbar { width: 4px; }
        .sidebar-nav::-webkit-scrollbar-track { background: transparent; }
        .sidebar-nav::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

        .sidebar-group-label {
            padding: 12px 16px 4px;
            font-size: 10px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            color: var(--muted);
            opacity: 0.6;
        }
        .sidebar-item {
            display: flex;
            align-items: center;
            justify-content: flex-start;
            gap: 10px;
            padding: 10px 14px;
            margin: 1px 8px;
            border-radius: 10px;
            color: var(--muted);
            text-decoration: none;
            font-size: 15px;
            font-weight: 500;
            transition: all 0.15s;
            white-space: nowrap;
            overflow: hidden;
            cursor: pointer;
            position: relative;
        }
        .sidebar-item:hover { color: var(--text); background: var(--surface2); }
        .sidebar-item.active {
            color: var(--text);
            background: rgba(106,170,106,0.15);
            font-weight: 600;
        }
        .sidebar-item.active::before {
            content: '';
            position: absolute;
            left: 0;
            top: 8px;
            bottom: 8px;
            width: 3px;
            border-radius: 0 2px 2px 0;
            background: var(--success);
        }
        [data-theme="light"] .sidebar-item.active { background: rgba(106,170,106,0.12); color: #1a1a2e; }

        .sidebar-item-icon {
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            width: 20px;
            height: 20px;
        }
        .sidebar-item-icon svg { width: 16px; height: 16px; }
        .sidebar-item.active .sidebar-item-icon svg { stroke: var(--success); }

        /* Sidebar overlay — hidden on desktop, active on mobile */
        .sidebar-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.5);
            z-index: 500;
            opacity: 0;
            transition: opacity 0.2s;
        }
        .sidebar-overlay.open {
            opacity: 1;
        }

        /* Profile button in header (right side) */
        .hdr-profile-btn {
            background: none;
            border: 1px solid var(--border);
            color: var(--dim);
            cursor: pointer;
            width: 32px;
            height: 32px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: color 0.2s, border-color 0.2s;
            flex-shrink: 0;
        }
        .hdr-profile-btn:hover { color: var(--success); border-color: var(--success); }
        .hdr-profile-btn svg { width: 16px; height: 16px; }
        [data-theme="light"] .hdr-profile-btn { color: #6b7280; border-color: #d1d5db; }
        [data-theme="light"] .hdr-profile-btn:hover { color: #16a34a; border-color: #16a34a; }

        /* Account dropdown */
        .account-dropdown {
            display: none;
            position: absolute;
            top: 100%;
            right: 0;
            margin-top: 6px;
            min-width: 210px;
            background: var(--surface);
            border: 1px solid var(--border);
            border-radius: 10px;
            box-shadow: 0 8px 32px rgba(0,0,0,0.4);
            padding: 6px 0;
            z-index: 300;
        }
        .account-dropdown.open { display: block; }
        .account-dd-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 16px;
            color: var(--text);
            text-decoration: none;
            font-size: 0.82rem;
            transition: background 0.15s;
            cursor: pointer;
            white-space: nowrap;
        }
        .account-dd-item:hover { background: rgba(255,255,255,0.06); }
        .account-dd-item svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--dim); }
        .account-dd-item.danger { color: var(--danger); }
        .account-dd-item.danger svg { color: var(--danger); }
        .account-dd-sep { height: 1px; background: var(--border); margin: 4px 0; }
        [data-theme="light"] .account-dropdown { background: #fff; box-shadow: 0 8px 32px rgba(0,0,0,0.12); }
        [data-theme="light"] .account-dd-item:hover { background: rgba(0,0,0,0.04); }

        /* Landing page hero */
        .hero-section { text-align: center; padding: 40px 0 32px; }
        .hero-badge {
            display: inline-block;
            padding: 4px 14px;
            border: 1px solid rgba(102,170,102,0.3);
            border-radius: 20px;
            font-size: 0.72rem;
            font-weight: 600;
            letter-spacing: 1px;
            text-transform: uppercase;
            color: var(--success);
            background: rgba(102,170,102,0.08);
            margin-bottom: 20px;
        }
        .hero-title {
            font-size: 2rem;
            font-weight: 700;
            line-height: 1.2;
            margin-bottom: 16px;
            color: var(--text);
        }
        .hero-desc {
            font-size: 1rem;
            color: var(--accent);
            line-height: 1.7;
            max-width: 520px;
            margin: 0 auto 28px;
        }
        .hero-cta {
            display: inline-block;
            padding: 14px 36px;
            background: var(--success);
            color: #fff;
            font-size: 0.95rem;
            font-weight: 600;
            border-radius: 8px;
            text-decoration: none;
            transition: background 0.2s, transform 0.15s;
            border: none;
            cursor: pointer;
        }
        .hero-cta:hover { background: #5a5; transform: translateY(-1px); }
        .hero-sub {
            margin-top: 12px;
            font-size: 0.78rem;
            color: var(--dim);
        }

        /* How it works */
        .steps-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 20px;
            margin-top: 20px;
        }
        .step-card {
            text-align: center;
            padding: 24px 16px;
            border: 1px solid var(--border);
            border-radius: 10px;
            background: var(--card);
        }
        .step-num {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background: rgba(102,170,102,0.12);
            color: var(--success);
            font-weight: 700;
            font-size: 0.85rem;
            margin-bottom: 12px;
        }
        .step-card h3 {
            font-size: 0.88rem;
            font-weight: 600;
            margin-bottom: 6px;
            color: var(--text);
        }
        .step-card p {
            font-size: 0.78rem;
            color: var(--dim);
            line-height: 1.5;
        }

        /* Feature categories */
        .features-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 20px;
            margin-top: 20px;
        }
        .feature-cat {
            padding: 24px 20px;
            border: 1px solid var(--border);
            border-radius: 10px;
            background: var(--card);
        }
        .feature-cat-icon {
            width: 36px;
            height: 36px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 8px;
            background: rgba(102,170,102,0.1);
            margin-bottom: 14px;
        }
        .feature-cat-icon svg { width: 18px; height: 18px; color: var(--success); }
        .feature-cat h3 {
            font-size: 0.9rem;
            font-weight: 600;
            margin-bottom: 10px;
            color: var(--text);
        }
        .feature-cat ul {
            list-style: none;
            font-size: 0.8rem;
            color: var(--accent);
            line-height: 1.9;
        }
        .feature-cat li::before {
            content: '';
            display: inline-block;
            width: 4px;
            height: 4px;
            border-radius: 50%;
            background: var(--success);
            margin-right: 8px;
            vertical-align: middle;
        }

        /* Legacy compat */
        .nav-dd-item {
            display: block;
            padding: 9px 18px;
            color: #fff;
            text-decoration: none;
            font-size: 0.78rem;
            text-transform: uppercase;
            letter-spacing: 0.8px;
            transition: background 0.15s, color 0.15s;
            white-space: nowrap;
        }
        .nav-dd-item:hover { background: rgba(255,255,255,0.06); color: var(--accent); }
        .nav-dd-item.active { color: var(--success); }

        /* Footer links */
        .footer-links {
            margin-top: 48px;
            padding-top: 16px;
            border-top: 1px solid var(--border);
            display: flex;
            gap: 16px;
            flex-wrap: wrap;
        }
        .footer-links a {
            color: var(--dim);
            text-decoration: none;
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 1px;
        }
        .footer-links a:hover {
            color: var(--accent);
        }

        /* ============================================================ */
        /* MOBILE-FIRST RESPONSIVE (80% mobile / 20% desktop)           */
        /* ============================================================ */

        /* Legacy nav compat */
        .nav-icon { display: none; }
        .nav-label { }
        .nav-show-mobile-only { display: none !important; }
        .nav-hide-mobile { display: none; }

        /* Mobile menu drawer — hidden by default */
        #mobile-menu-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.5);
            backdrop-filter: blur(4px);
            -webkit-backdrop-filter: blur(4px);
            z-index: 999;
            opacity: 0;
            transition: opacity 0.25s ease;
        }
        #mobile-menu-overlay.active { opacity: 1; }
        #mobile-menu {
            display: none;
            position: fixed;
            bottom: 0;
            left: 0;
            right: 0;
            background: var(--card-bg);
            border-top: 2px solid var(--success);
            border-radius: 16px 16px 0 0;
            z-index: 1000;
            padding: 12px 16px;
            padding-bottom: 16px;
            max-height: 70vh;
            overflow-y: auto;
            transform: translateY(100%);
            transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
        }
        #mobile-menu.active { transform: translateY(0); }
        [data-theme="light"] #mobile-menu { background: #fff; }
        .mobile-menu-handle {
            width: 40px;
            height: 4px;
            background: #444;
            border-radius: 2px;
            margin: 0 auto 16px;
        }
        .mobile-menu-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 8px;
        }
        .mobile-menu-item {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 6px;
            padding: 16px 8px;
            border-radius: 12px;
            background: rgba(255,255,255,0.03);
            border: 1px solid var(--border);
            color: var(--text);
            text-decoration: none;
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            cursor: pointer;
            transition: background 0.2s, border-color 0.2s;
        }
        .mobile-menu-item:hover, .mobile-menu-item:active {
            background: rgba(102,170,102,0.08);
            border-color: var(--success);
        }
        .mobile-menu-item.active { color: var(--success); border-color: var(--success); }
        .mobile-menu-icon { font-size: 1.5rem; line-height: 1; }
        [data-theme="light"] .mobile-menu-item { background: rgba(0,0,0,0.02); }

        /* Collapsible analytics sections */
        .section-collapsible {
            border: 1px solid var(--border);
            padding: 0 16px;
            margin-top: 16px;
            overflow: hidden;
            transition: border-color 0.2s;
            background: var(--card-bg);
            border-radius: 8px;
        }
        .section-collapsible-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 14px 0;
            cursor: pointer;
            -webkit-tap-highlight-color: rgba(102,170,102,0.15);
        }
        .section-collapsible-header h2 { margin-bottom: 0; }
        .section-toggle-icon {
            font-size: 0.9rem;
            color: var(--dim);
            transition: transform 0.3s ease;
            flex-shrink: 0;
            width: 20px;
            text-align: center;
        }
        .section-collapsed .section-toggle-icon { transform: rotate(-90deg); }
        .section-collapsible-body {
            overflow: hidden;
            transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.25s ease;
            padding-bottom: 16px;
        }
        .section-collapsed .section-collapsible-body {
            max-height: 0 !important;
            opacity: 0;
            padding-bottom: 0;
            padding-top: 0;
        }

        /* PWA Install Prompt Banner */
        #pwa-install-banner {
            display: none;
            position: fixed;
            bottom: 0;
            left: 0;
            right: 0;
            background: linear-gradient(135deg, #0d2818, #1a4d2e);
            color: #fff;
            padding: 16px 20px;
            padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
            z-index: 9999;
            box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
            animation: slideUp 0.4s cubic-bezier(0.32,0.72,0,1);
        }
        @keyframes slideUp {
            from { transform: translateY(100%); }
            to { transform: translateY(0); }
        }
        #pwa-install-banner .pwa-banner-inner {
            display: flex;
            align-items: center;
            gap: 14px;
            max-width: 600px;
            margin: 0 auto;
        }
        #pwa-install-banner .pwa-icon {
            width: 48px;
            height: 48px;
            border-radius: 12px;
            flex-shrink: 0;
        }
        #pwa-install-banner .pwa-text {
            flex: 1;
        }
        #pwa-install-banner .pwa-text strong {
            display: block;
            font-size: 0.95rem;
            margin-bottom: 2px;
        }
        #pwa-install-banner .pwa-text span {
            font-size: 0.8rem;
            opacity: 0.85;
        }
        #pwa-install-banner .pwa-actions {
            display: flex;
            gap: 8px;
            flex-shrink: 0;
        }
        #pwa-install-banner .pwa-btn {
            padding: 8px 16px;
            border-radius: 8px;
            border: none;
            font-size: 0.85rem;
            font-weight: 600;
            cursor: pointer;
        }
        #pwa-install-banner .pwa-btn-install {
            background: #fff;
            color: #0d2818;
        }
        #pwa-install-banner .pwa-btn-dismiss {
            background: transparent;
            color: rgba(255,255,255,0.7);
            font-weight: 400;
        }

        /* Standalone mode adjustments (when installed as PWA) */
        @media (display-mode: standalone) {
            body { padding-top: env(safe-area-inset-top); }
            .sidebar { padding-top: env(safe-area-inset-top); }
        }

        @media (max-width: 768px) {
            /* Safe areas for notched phones */
            body {
                padding-top: env(safe-area-inset-top);
                padding-left: env(safe-area-inset-left);
                padding-right: env(safe-area-inset-right);
            }
            .app {
                padding: 52px 12px 60px 12px;
                margin: 0 auto;
                max-width: 100%;
            }

            /* Typography scaling */
            h1 { font-size: 1.45rem; }
            h2 { font-size: 1.1rem; }
            p { font-size: 1rem; }
            .tagline { font-size: 1.05rem; }

            /* Touch targets — minimum 44px */
            .btn {
                padding: 12px 16px;
                font-size: 1rem;
                min-height: 44px;
            }
            .btn-small {
                min-height: 40px;
                padding: 8px 14px;
                font-size: 0.9rem;
            }

            /* Touch-friendly interactions */
            * {
                -webkit-tap-highlight-color: rgba(102,170,102,0.12);
            }

            /* Cards full-width */
            .plan { padding: 16px; }
            .plan-price { font-size: 1.25rem; }

            /* Priority bar */
            .priority-bar .p-icon { width: 32px; height: 32px; font-size: 0.7rem; }

            /* Onboarding */
            .onboard-step h1 { font-size: 1.25rem; }
            #page-onboarding.active { padding: 20px 16px 60px; }
            .onboard-card { padding: 16px; }

            /* Logo */
            .logo-wrap img { height: 24px; }
            .logo-text { font-size: 0.9rem; letter-spacing: 1.5px; }

            /* Burger button — visible on mobile (JS controls show/hide based on auth) */
            .hdr-burger-btn { display: flex; }

            /* Mobile sidebar — hidden by default, slides in */
            .sidebar {
                top: 48px;
                bottom: 0;
                width: 260px;
                transform: translateX(-100%);
                transition: transform 0.25s ease;
                z-index: 502;
            }
            .sidebar.open { transform: translateX(0); }

            /* Sidebar overlay — enabled on mobile */
            .sidebar-overlay.open { display: block; }

            /* Footer bar — full width (no sidebar offset) */
            .nav-copyright { left: 0; text-align: center; }

            /* Landing page responsive */
            .hero-title { font-size: 1.5rem; }
            .steps-grid { grid-template-columns: 1fr; gap: 12px; }
            .features-grid { grid-template-columns: 1fr; gap: 12px; max-width: 400px; margin-left: auto; margin-right: auto; }
            .feature-cat { text-align: center; }
            .feature-cat .feature-cat-icon { margin-left: auto; margin-right: auto; }
            .hero-cta { width: 100%; text-align: center; display: block; }

            /* Focus widget */
            #focus-widget { bottom: 20px !important; right: 12px !important; }
            #focus-expanded { min-width: 240px !important; right: 0 !important; }
            #focus-collapsed { width: 44px !important; height: 44px !important; font-size: 16px !important; }

            /* Notification panel full-width */
            #notification-panel {
                left: 8px !important; right: 8px !important;
                width: auto !important; top: 46px !important;
                bottom: auto !important; max-height: 55vh !important;
            }

            /* Toast position */
            #toast-container {
                bottom: 20px !important;
                left: 12px !important;
                right: 12px !important;
            }

            /* Grid layouts — responsive on mobile */
            #briefing-stats { grid-template-columns: repeat(2, 1fr) !important; }
            #kanban-board { grid-template-columns: 1fr !important; }

            /* Forms — mobile-friendly */
            input, select, textarea {
                min-height: 44px;
                font-size: 16px !important; /* prevents iOS auto-zoom */
            }
            input[type="checkbox"], input[type="radio"], input[type="color"] {
                min-height: auto;
            }
            .modal input, .modal select, .modal textarea {
                min-height: 44px;
                font-size: 16px !important;
                padding: 10px 12px;
                border-radius: 8px;
            }
            .modal input[type="checkbox"] { min-height: auto; }

            /* Modal — bottom sheet on mobile */
            .modal-overlay.active {
                align-items: flex-end;
            }
            .modal {
                width: 100% !important;
                max-width: 100% !important;
                max-height: 85vh;
                border-radius: 16px 16px 0 0;
                padding: 20px 16px;
                padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
            }

            /* Day picker — larger touch targets */
            .day-picker .day-btn { width: 42px; height: 42px; font-size: 0.8rem; }

            /* Dashboard widgets — tighter spacing */
            .dashboard-widget > div { padding: 12px !important; }
            .dashboard-widget h2 { font-size: 0.95rem !important; }

            /* Streaks — stack on mobile */
            #streaks-content > div:first-child {
                flex-direction: column !important;
            }
            #streaks-content > div:first-child > div {
                min-width: 100% !important;
            }

            /* Account items — stack on very small */
            .account-item { padding: 12px; }

            /* Sections — less margin */
            .section { margin-bottom: 20px; }

            /* Flex wrapping for button groups */
            div[style*="display:flex;gap:8px"] { flex-wrap: wrap; }
            div[style*="display:flex;gap:6px"] { flex-wrap: wrap; }
            div[style*="display:flex;align-items:center;gap:12px"] { flex-wrap: wrap; }
            div[style*="display:flex;align-items:center;gap:8px"] { flex-wrap: wrap; }

            /* Grid form layouts — stack on mobile */
            div[style*="grid-template-columns:1fr 80px 60px"] {
                grid-template-columns: 1fr 80px !important;
            }

            /* Time entry form — stack */
            div[style*="grid-template-columns:1fr 80px 80px"] {
                grid-template-columns: 1fr !important;
            }
            div[style*="grid-template-columns:1fr 1fr"] {
                grid-template-columns: 1fr !important;
            }

            /* Footer links — centered on mobile */
            .footer-links {
                justify-content: center;
                gap: 12px;
            }
            .footer-links a { font-size: 0.7rem; }

            /* Mobile menu drawer */
            #mobile-menu { padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px)); }

            /* Header center — keep Clarity visible on mobile */

            /* Header — smaller buttons on mobile */
            .app-header { padding: 6px 10px !important; }
            .app-header-brand span { font-size: 0.75rem !important; letter-spacing: 1px !important; }
            .app-header-utils { gap: 0px !important; }
            .app-header-utils .hdr-btn { width: 32px !important; height: 32px !important; font-size: 13px !important; min-width: 32px !important; }
        }

        @media (max-width: 380px) {
            .app { padding: 52px 8px 60px 8px; }
            #focus-expanded { min-width: 200px !important; }
            h1 { font-size: 1.15rem; }
            /* Very small screens — keep Clarity visible */
            .app-header-brand img { height: 18px !important; }
            .app-header-brand span { font-size: 0.65rem !important; }
        }

        /* Disable hover effects on touch devices */
        @media (hover: none) {
            .btn:hover { transform: none; box-shadow: none; }
            .rule-item:hover { transform: none; background: var(--card-bg); }
            .plan:hover { transform: none; box-shadow: none; }
            .priority-bar:hover { transform: none; }
            .rule-card:hover { transform: none; }
            .action-item:hover { background: transparent; }
            .plan-option:hover { transform: none; }
            .onboard-card:hover { transform: none; }
            .account-item:hover { background: rgba(255,255,255,0.01); }
        }

        /* Hide all pages by default */
        .page { display: none; }
        .page.active { display: block; }

        /* ---- ONBOARDING STYLES ---- */
        #page-onboarding.active {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            min-height: 100vh;
            padding: 40px 20px 60px;
        }
        #page-onboarding .logo-wrap {
            margin-bottom: 32px;
            opacity: 0.9;
        }
        .onboard-step {
            max-width: 480px;
            width: 100%;
            margin: 0 auto;
            opacity: 0;
            transform: translateY(20px);
            animation: onboardFadeIn 0.5s ease forwards;
        }
        .onboard-step.onboard-exit {
            animation: onboardFadeOut 0.3s ease forwards;
        }
        @keyframes onboardFadeIn {
            from { opacity: 0; transform: translateY(20px); }
            to { opacity: 1; transform: translateY(0); }
        }
        @keyframes onboardFadeOut {
            from { opacity: 1; transform: translateY(0); }
            to { opacity: 0; transform: translateY(-12px); }
        }
        .onboard-step h1 {
            font-size: 1.6rem;
            font-weight: 700;
            letter-spacing: -0.5px;
            background: linear-gradient(135deg, var(--text) 30%, var(--success));
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }
        .onboard-card {
            border: 1px solid var(--border);
            padding: 20px;
            margin-bottom: 10px;
            background: rgba(255,255,255,0.02);
            backdrop-filter: blur(4px);
            transition: border-color 0.3s, background 0.3s, transform 0.2s;
        }
        .onboard-card:hover {
            border-color: #3a3a30;
            background: rgba(255,255,255,0.04);
        }
        .onboard-card-highlight {
            border: 2px solid var(--success);
            background: rgba(102,170,102,0.04);
        }
        .onboard-card-highlight:hover {
            border-color: #8c8;
            background: rgba(102,170,102,0.08);
            transform: translateY(-2px);
        }
        .onboard-progress {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            margin-top: 24px;
        }
        .onboard-dot {
            width: 32px;
            height: 4px;
            border-radius: 2px;
            background: var(--border);
            transition: background 0.4s ease, box-shadow 0.4s ease;
        }
        .onboard-dot.done {
            background: var(--success);
        }
        .onboard-dot.active {
            background: var(--success);
            box-shadow: 0 0 8px rgba(102,170,102,0.4);
        }
        .onboard-step-label {
            font-size: 0.65rem;
            color: var(--dim);
            text-transform: uppercase;
            letter-spacing: 2px;
            text-align: center;
            margin-bottom: 4px;
        }
        .onboard-btn-next {
            width: 100%;
            padding: 15px;
            font-size: 0.95rem;
            font-weight: 600;
            border: none;
            cursor: pointer;
            color: #000;
            background: linear-gradient(135deg, var(--success), #4a4);
            transition: transform 0.2s, box-shadow 0.2s;
            letter-spacing: 0.5px;
        }
        .onboard-btn-next:hover {
            transform: translateY(-1px);
            box-shadow: 0 4px 20px rgba(102,170,102,0.3);
        }
        .onboard-btn-back {
            width: 100%;
            padding: 12px;
            margin-top: 8px;
            background: transparent;
            border: 1px solid var(--border);
            color: var(--dim);
            cursor: pointer;
            font-size: 0.85rem;
            transition: color 0.2s, border-color 0.2s;
        }
        .onboard-btn-back:hover {
            color: var(--text);
            border-color: var(--accent);
        }
        .priority-bar {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 14px 16px;
            margin-bottom: 8px;
            border-left: 3px solid;
            transition: transform 0.2s;
        }
        .priority-bar:hover {
            transform: translateX(4px);
        }
        .priority-bar .p-icon {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 800;
            font-size: 0.75rem;
            flex-shrink: 0;
        }
        .rule-card {
            border: 1px solid var(--border);
            padding: 16px 18px;
            margin-bottom: 8px;
            position: relative;
            overflow: hidden;
            transition: border-color 0.3s, transform 0.2s;
        }
        .rule-card:hover {
            border-color: #3a3a30;
            transform: translateX(4px);
        }
        .rule-card .rule-icon {
            font-size: 1.2rem;
            margin-bottom: 6px;
        }
        .plan-option {
            padding: 22px;
            cursor: pointer;
            transition: all 0.3s ease;
            position: relative;
        }
        .plan-option:hover {
            transform: translateY(-2px);
        }

        /* Modal Overlay */
        .modal-overlay {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.7);
            backdrop-filter: blur(4px);
            z-index: 9000;
            justify-content: center;
            align-items: center;
            animation: modalFadeIn 0.2s ease;
        }
        .modal-overlay.active { display: flex; }
        @keyframes modalFadeIn { from { opacity: 0; } to { opacity: 1; } }
        .modal {
            background: var(--card-bg);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 28px 24px;
            width: 90%;
            max-width: 420px;
            max-height: 80vh;
            overflow-y: auto;
            animation: modalSlideIn 0.25s ease;
        }
        @keyframes modalSlideIn { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
        @keyframes pclSlideIn { from { transform: translateY(-50%) translateX(20px); opacity: 0; } to { transform: translateY(-50%) translateX(0); opacity: 1; } }
        @keyframes pclSlideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
        @keyframes pclPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
        .modal h3 { font-size: 1.1rem; margin-bottom: 16px; color: var(--text); }
        .modal label { display: block; font-size: 0.8rem; color: var(--dim); margin-bottom: 4px; margin-top: 12px; }
        select option { background: var(--card-bg); color: var(--text); }
        .modal input, .modal select {
            width: 100%;
            padding: 10px 12px;
            background: var(--card-bg);
            border: 1px solid var(--border);
            color: var(--text);
            font-size: 0.9rem;
            border-radius: 4px;
            outline: none;
            transition: border-color 0.2s;
        }
        .modal input:focus, .modal select:focus { border-color: var(--success); }
        .modal textarea {
            width: 100%;
            padding: 10px 12px;
            background: var(--card-bg);
            border: 1px solid var(--border);
            color: var(--text);
            font-size: 0.9rem;
            border-radius: 4px;
            outline: none;
            resize: vertical;
            min-height: 60px;
            font-family: inherit;
            transition: border-color 0.2s;
        }
        .modal textarea:focus { border-color: var(--success); }
        .modal-actions { display: flex; gap: 8px; margin-top: 20px; justify-content: flex-end; }
        .modal-actions .btn { min-width: 80px; }
        .modal .btn-cancel { background: transparent; border: 1px solid #2a2a25; color: var(--dim); }
        .modal .btn-cancel:hover { border-color: #555; color: var(--text); }
        .day-picker { display: flex; gap: 6px; margin-top: 6px; flex-wrap: wrap; }
        .day-picker .day-btn {
            width: 36px; height: 36px;
            border-radius: 50%;
            border: 1px solid #2a2a25;
            background: transparent;
            color: var(--dim);
            font-size: 0.75rem;
            cursor: pointer;
            transition: all 0.2s;
            display: flex; align-items: center; justify-content: center;
        }
        .day-picker .day-btn.selected { background: #0d2818; border-color: var(--success); color: var(--success); }
        .day-picker .day-btn:hover { border-color: #555; }

        /* Custom Date Picker */
        .dp-cal { position:fixed; z-index:10000; background:var(--card-bg,#1a1a2a); border:1px solid var(--border); border-radius:8px; padding:12px; min-width:260px; box-shadow:0 8px 32px rgba(0,0,0,0.5); }
        [data-theme="light"] .dp-cal { box-shadow:0 8px 32px rgba(0,0,0,0.15); }
        .dp-cal-nav { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
        .dp-cal-nav button { background:none; border:none; color:var(--text); cursor:pointer; font-size:1rem; padding:4px 8px; border-radius:4px; }
        .dp-cal-nav button:hover { background:rgba(255,255,255,0.05); }
        [data-theme="light"] .dp-cal-nav button:hover { background:rgba(0,0,0,0.05); }
        .dp-cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; text-align:center; }
        .dp-hdr { font-size:0.6rem; color:var(--dim); font-weight:700; padding:4px 2px; }
        .dp-day { padding:6px 2px; border-radius:4px; font-size:0.8rem; cursor:pointer; color:var(--text); transition:background 0.15s; }
        .dp-day:hover { background:rgba(102,170,102,0.2); }
        .dp-day.sel { background:var(--accent,#6a6); color:#fff; }
        .dp-day.today { outline:1px solid var(--accent,#6a6); }
        .dp-day.off { opacity:0.3; pointer-events:none; }
        .dp-foot { display:flex; justify-content:space-between; margin-top:8px; padding-top:8px; border-top:1px solid var(--border); }
        .dp-foot button { font-size:0.75rem; color:var(--dim); background:none; border:none; cursor:pointer; padding:4px 8px; }
        .dp-foot button:hover { color:var(--text); }
