        /* ========== CSS Variables - Void Resonance Theme ========== */
        :root {
            /* Background colors - Deep void with warm undertones */
            --bg-primary: #0b0b12;
            --bg-secondary: #13131c;
            --bg-tertiary: #1b1b28;
            --bg-hover: #262640;
            --bg-active: #303058;
            
            /* Text colors - Enhanced readability */
            --text-primary: #f5f5fa;
            --text-secondary: #d0d0e8;
            --text-muted: #a0a0c8;
            --text-inverse: #0a0a0f;
            
            /* Accent colors - Vibrant void palette */
            --accent-primary: #a855f7;
            --accent-primary-hover: #9333ea;
            --accent-primary-glow: rgba(168, 85, 247, 0.35);
            --accent-secondary: #06b6d4;
            --accent-secondary-glow: rgba(6, 182, 212, 0.3);
            --accent-warning: #facc15;
            --accent-danger: #f43f5e;
            --accent-blue: #60a5fa;
            --accent-purple: #c084fc;
            --accent-cyan: #22d3ee;
            --accent-pink: #ec4899;
            --accent-orange: #fb923c;
            --accent-green: #4ade80;
            
            /* Gradient accents */
            --gradient-primary: linear-gradient(135deg, #a855f7 0%, #7c3aed 100%);
            --gradient-secondary: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
            --gradient-cosmic: linear-gradient(135deg, #7c3aed 0%, #ec4899 50%, #06b6d4 100%);
            --gradient-void: linear-gradient(180deg, rgba(124, 58, 237, 0.12) 0%, transparent 100%);
            --gradient-aurora: linear-gradient(135deg, #a855f7 0%, #06b6d4 50%, #4ade80 100%);
            
            /* Border colors */
            --border-primary: #2e2e48;
            --border-secondary: #42427a;
            --border-focus: #a855f7;
            --border-glow: rgba(168, 85, 247, 0.5);
            
            /* Shadows - Refined void glows */
            --shadow-sm: 0 1px 3px rgba(0,0,0,0.4);
            --shadow-md: 0 4px 12px rgba(0,0,0,0.35);
            --shadow-lg: 0 8px 32px rgba(0,0,0,0.4);
            --shadow-glow: 0 0 25px var(--accent-primary-glow);
            --shadow-glow-secondary: 0 0 20px var(--accent-secondary-glow);
            --shadow-neon: 0 0 15px rgba(168, 85, 247, 0.3), 0 0 30px rgba(168, 85, 247, 0.15);
            
            /* Spacing */
            --spacing-xs: 4px;
            --spacing-sm: 8px;
            --spacing-md: 16px;
            --spacing-lg: 24px;
            --spacing-xl: 32px;
            
            /* Border radius */
            --radius-sm: 8px;
            --radius-md: 12px;
            --radius-lg: 18px;
            --radius-xl: 24px;
            --radius-full: 9999px;
            
            /* Transitions */
            --transition-fast: 80ms ease-out;
            --transition-normal: 100ms ease-out;
            --transition-slow: 350ms ease;
            --transition-smooth: 400ms cubic-bezier(0.4, 0, 0.2, 1);
            
            /* Calendar specific */
            --calendar-cell-height: 120px;
            --sidebar-width: 280px;
            --header-height: 70px;
        }

        /* ========== Reset & Base ========== */
        *, *::before, *::after {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
        }

        html {
            font-size: 14px;
            -webkit-font-smoothing: antialiased;
            -moz-osx-font-smoothing: grayscale;
            width: 100%;
            overflow-x: hidden;
            overscroll-behavior-x: none;
        }

        body {
            font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
            background: var(--bg-primary);
            color: var(--text-primary);
            line-height: 1.5;
            min-height: 100vh;
            overflow-x: hidden;
            width: 100%;
            overscroll-behavior-x: none;
            position: relative;
        }

        /* Animated background - Void Resonance */
        body::before {
            content: '';
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: 
                radial-gradient(ellipse at 15% 15%, rgba(168, 85, 247, 0.10) 0%, transparent 45%),
                radial-gradient(ellipse at 85% 20%, rgba(6, 182, 212, 0.06) 0%, transparent 40%),
                radial-gradient(ellipse at 50% 80%, rgba(236, 72, 153, 0.06) 0%, transparent 50%),
                radial-gradient(ellipse at 20% 70%, rgba(74, 222, 128, 0.04) 0%, transparent 40%);
            pointer-events: none;
            z-index: 0;
            contain: strict;
        }

        body > * {
            position: relative;
            z-index: 1;
        }

        /* Subtle grid pattern - Enhanced void grid */
        /* Subtle grid pattern - Void grid (only visible near top) */
        .app-container::before {
            content: '';
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            height: 50vh;
            background-image: 
                linear-gradient(rgba(168, 85, 247, 0.03) 1px, transparent 1px),
                linear-gradient(90deg, rgba(168, 85, 247, 0.03) 1px, transparent 1px);
            background-size: 60px 60px;
            pointer-events: none;
            z-index: 0;
            contain: strict;
            mask-image: linear-gradient(to bottom, rgba(0,0,0,0.4) 0%, transparent 100%);
            -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,0.4) 0%, transparent 100%);
        }

        /* Scrollbar styling */
        ::-webkit-scrollbar {
            width: 8px;
            height: 8px;
        }
        ::-webkit-scrollbar-track {
            background: var(--bg-secondary);
        }
        ::-webkit-scrollbar-thumb {
            background: linear-gradient(180deg, var(--accent-secondary), var(--accent-purple));
            border-radius: var(--radius-full);
        }
        ::-webkit-scrollbar-thumb:hover {
            background: linear-gradient(180deg, var(--accent-purple), var(--accent-pink));
        }

        /* Selection */
        ::selection {
            background: var(--accent-primary);
            color: var(--text-inverse);
        }

        /* ========== Typography ========== */
        h1, h2, h3, h4, h5, h6 {
            font-weight: 700;
            line-height: 1.3;
        }

        a {
            color: var(--accent-primary);
            text-decoration: none;
            transition: color var(--transition-fast);
        }
        a:hover {
            color: var(--accent-primary-hover);
        }

        /* ========== Utility Classes ========== */
        .flex { display: flex; }
        .flex-col { flex-direction: column; }
        .items-center { align-items: center; }
        .justify-between { justify-content: space-between; }
        .justify-center { justify-content: center; }
        .gap-xs { gap: var(--spacing-xs); }
        .gap-sm { gap: var(--spacing-sm); }
        .gap-md { gap: var(--spacing-md); }
        .gap-lg { gap: var(--spacing-lg); }
        .text-center { text-align: center; }
        .text-muted { color: var(--text-muted); }
        .text-secondary { color: var(--text-secondary); }
        .font-medium { font-weight: 500; }
        .font-semibold { font-weight: 600; }

        /* Hidden but accessible */
        .sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0,0,0,0);
            border: 0;
        }

        /* ========== Layout ========== */
        .app-container {
            display: flex;
            flex-direction: column;
            min-height: 100vh;
            max-width: 100%;
            overflow-x: hidden;
        }

        .main-content {
            display: flex;
            flex: 1;
            overflow: hidden;
            min-width: 0;
            max-width: 100%;
        }

        /* ========== Header ========== */
        .header {
            height: var(--header-height);
            background: linear-gradient(180deg, rgba(19, 19, 28, 0.98) 0%, rgba(15, 15, 22, 0.95) 100%);
            border-bottom: 1px solid var(--border-primary);
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 0 var(--spacing-lg);
            position: sticky;
            top: 0;
            z-index: 200;
            overflow: hidden;
            gap: var(--spacing-sm);
            box-shadow: 0 1px 0 rgba(168, 85, 247, 0.05), 0 4px 20px rgba(0, 0, 0, 0.3);
        }

        .header > nav {
            display: contents;
        }

        .header-left {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            min-width: 0;
        }

        .logo {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            font-size: 1.15rem;
            font-weight: 800;
            color: var(--text-primary);
            text-decoration: none;
            transition: all var(--transition-fast);
        }

        .logo:hover {
            color: var(--accent-primary);
            text-shadow: var(--shadow-neon);
        }

        .logo-icon {
            font-size: 1.5rem;
            filter: drop-shadow(0 0 8px var(--accent-primary-glow));
        }

        .logo-text {
            background: var(--gradient-aurora);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            letter-spacing: 1px;
        }

        .logo-dot {
            color: var(--accent-cyan);
            -webkit-text-fill-color: var(--accent-cyan);
        }

        .logo-divider {
            color: var(--border-secondary);
            font-weight: 300;
        }

        .page-title {
            font-size: 0.95rem;
            font-weight: 600;
            color: var(--text-secondary);
        }

        .nav-controls {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .current-date {
            font-size: 1.5rem;
            font-weight: 800;
            min-width: 200px;
            color: var(--text-primary);
            letter-spacing: 0.5px;
            position: relative;
        }

        .current-date::after {
            content: '';
            position: absolute;
            bottom: -4px;
            left: 0;
            right: 0;
            height: 2px;
            background: linear-gradient(90deg, var(--accent-cyan) 0%, var(--accent-blue) 50%, var(--accent-purple) 100%);
            border-radius: 2px;
            opacity: 0.7;
        }

        .header-right {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            position: relative;
        }

        .timezone-display {
            font-size: 0.8rem;
            font-weight: 500;
            color: var(--accent-cyan);
            background: rgba(34, 211, 238, 0.1);
            border: 1px solid rgba(34, 211, 238, 0.2);
            padding: var(--spacing-xs) var(--spacing-sm);
            border-radius: var(--radius-full);
        }

        /* ========== Buttons ========== */
        .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: var(--spacing-xs);
            padding: var(--spacing-sm) var(--spacing-md);
            font-size: 0.9rem;
            font-weight: 600;
            border: none;
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all var(--transition-fast);
            white-space: nowrap;
            position: relative;
            overflow: hidden;
            touch-action: manipulation;
        }

        .btn::before {
            content: '';
            position: absolute;
            top: 0;
            left: -100%;
            width: 100%;
            height: 100%;
            background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
            transition: left 0.5s;
        }

        .btn:hover::before {
            left: 100%;
        }

        /* Focus-visible for keyboard accessibility */
        .btn:focus-visible,
        .view-btn:focus-visible,
        .calendar-cell:focus-visible,
        .event-chip:focus-visible,
        .category-item:focus-visible,
        .mini-cal-day:focus-visible,
        .settings-tab:focus-visible,
        .rsvp-btn:focus-visible,
        .invite-btn:focus-visible,
        .quick-option:focus-visible,
        .guide-btn:focus-visible,
        .tz-btn:focus-visible,
        .timezone-btn:focus-visible,
        .modal-close:focus-visible,
        .new-event-btn:focus-visible {
            outline: 2px solid var(--accent-primary);
            outline-offset: 2px;
        }

        .btn-icon {
            width: auto;
            min-width: 36px;
            height: 36px;
            padding: 0 var(--spacing-sm);
            border-radius: var(--radius-sm);
            gap: 4px;
        }

        .btn-label-text {
            font-size: 0.72rem;
            font-weight: 600;
            letter-spacing: 0.3px;
            color: var(--text-secondary);
            white-space: nowrap;
        }

        .btn-icon:hover .btn-label-text,
        .btn:hover .btn-label-text {
            color: var(--text-primary);
        }
        
        /* Hamburger Icon */
        .hamburger-icon {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            width: 20px;
            height: 16px;
            gap: 4px;
        }
        
        .hamburger-icon span {
            display: block;
            width: 100%;
            height: 2px;
            background: var(--text-primary);
            border-radius: 2px;
            transition: all var(--transition-fast);
        }
        
        .sidebar-toggle-btn:hover .hamburger-icon span {
            background: var(--accent-primary);
        }
        
        .sidebar-toggle-btn:hover .hamburger-icon span:nth-child(1) {
            transform: translateY(1px) rotate(5deg);
        }
        
        .sidebar-toggle-btn:hover .hamburger-icon span:nth-child(3) {
            transform: translateY(-1px) rotate(-5deg);
        }

        .btn-today {
            background: rgba(6, 182, 212, 0.1);
            color: var(--accent-cyan);
            font-weight: 600;
            padding: var(--spacing-sm) var(--spacing-lg);
            position: relative;
            border: 1px solid rgba(6, 182, 212, 0.25);
            border-left: 3px solid var(--accent-cyan);
            border-radius: 6px;
        }

        .btn-today:hover {
            background: rgba(6, 182, 212, 0.18);
            border-color: rgba(6, 182, 212, 0.4);
            transform: translateY(-1px);
            box-shadow: 0 3px 8px rgba(6, 182, 212, 0.15);
        }

        .today-pulse {
            position: absolute;
            top: 50%;
            left: 12px;
            width: 6px;
            height: 6px;
            background: var(--accent-cyan);
            border-radius: 50%;
            transform: translateY(-50%);
            box-shadow: 0 0 6px var(--accent-cyan);
        }

        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.5; }
        }

        .btn-primary {
            background: rgba(16, 185, 129, 0.1);
            color: #34d399;
            font-weight: 600;
            border: 1px solid rgba(16, 185, 129, 0.25);
            border-left: 3px solid #10b981;
            border-radius: 6px;
        }
        .btn-primary:hover {
            background: rgba(16, 185, 129, 0.18);
            border-color: rgba(16, 185, 129, 0.4);
            transform: translateY(-1px);
            box-shadow: 0 3px 8px rgba(16, 185, 129, 0.15);
        }

        .btn-secondary {
            background: rgba(100, 100, 140, 0.08);
            color: var(--text-primary);
            border: 1px solid rgba(100, 100, 140, 0.2);
            border-left: 3px solid rgba(100, 100, 140, 0.4);
            border-radius: 6px;
        }
        .btn-secondary:hover {
            background: rgba(100, 100, 140, 0.14);
            border-color: rgba(100, 100, 140, 0.35);
        }

        .btn-ghost {
            background: transparent;
            color: var(--text-secondary);
        }
        .btn-ghost:hover {
            background: rgba(100, 100, 140, 0.08);
            color: var(--text-primary);
        }
        
        .btn-sm {
            padding: var(--spacing-xs) var(--spacing-sm);
            font-size: 0.85rem;
        }

        .btn-danger {
            background: rgba(239, 68, 68, 0.1);
            color: #f87171;
            border: 1px solid rgba(239, 68, 68, 0.25);
            border-left: 3px solid #ef4444;
            border-radius: 6px;
        }
        .btn-danger:hover {
            background: rgba(239, 68, 68, 0.18);
            border-color: rgba(239, 68, 68, 0.4);
            box-shadow: 0 3px 8px rgba(239, 68, 68, 0.12);
        }
        
        /* User Menu */
        .user-menu {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: var(--spacing-xs) var(--spacing-sm);
            background: rgba(168, 85, 247, 0.06);
            border-radius: 6px;
            border: 1px solid rgba(168, 85, 247, 0.15);
            border-left: 3px solid rgba(168, 85, 247, 0.4);
        }
        
        .user-name {
            font-size: 0.85rem;
            color: var(--accent-primary);
            font-weight: 500;
        }

        /* View Switcher */
        .view-switcher {
            display: flex;
            gap: 3px;
            padding: 3px;
            border-radius: 8px;
            background: rgba(18, 18, 26, 0.7);
            border: 1px solid rgba(100, 100, 140, 0.2);
            box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
        }

        .view-btn {
            padding: 6px 14px;
            background: transparent;
            border: 1px solid transparent;
            color: var(--text-muted);
            font-size: 0.78rem;
            font-weight: 600;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            border-radius: 6px;
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .view-btn.active {
            background: rgba(168, 85, 247, 0.12);
            color: var(--accent-primary);
            border-color: rgba(168, 85, 247, 0.3);
            border-left: 3px solid var(--accent-primary);
            box-shadow: 0 1px 4px rgba(168, 85, 247, 0.12);
        }

        .view-btn:hover:not(.active) {
            color: var(--text-primary);
            border-color: rgba(100, 100, 140, 0.3);
            background: rgba(100, 100, 140, 0.08);
        }

        .new-event-btn {
            padding: 8px 16px;
            font-size: 0.78rem;
            font-weight: 600;
            letter-spacing: 0.08em;
            text-transform: uppercase;
            border-radius: 6px;
            background: rgba(168, 85, 247, 0.1);
            border: 1px solid rgba(168, 85, 247, 0.25);
            border-left: 3px solid var(--accent-primary);
            color: var(--accent-primary);
            box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
        }

        .new-event-btn span {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 18px;
            height: 18px;
            border-radius: 4px;
            background: rgba(168, 85, 247, 0.15);
            border: 1px solid rgba(168, 85, 247, 0.3);
            font-size: 0.9rem;
            line-height: 1;
            color: var(--accent-primary);
        }

        .new-event-btn:hover {
            background: rgba(168, 85, 247, 0.18);
            border-color: rgba(168, 85, 247, 0.4);
            transform: translateY(-1px);
            box-shadow: 0 3px 8px rgba(168, 85, 247, 0.15);
        }

        /* ========== Sidebar ========== */
        .sidebar {
            width: var(--sidebar-width);
            background: linear-gradient(180deg, var(--bg-secondary) 0%, rgba(19, 19, 28, 0.98) 100%);
            border-right: 1px solid var(--border-primary);
            padding: var(--spacing-lg);
            overflow-y: auto;
            flex-shrink: 0;
            transition: transform var(--transition-normal), opacity var(--transition-normal), margin var(--transition-normal);
            box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.02);
        }
        
        .sidebar.hidden {
            margin-left: calc(var(--sidebar-width) * -1);
            opacity: 0;
            pointer-events: none;
        }

        /* Sidebar overlay for mobile */
        .sidebar-overlay {
            position: fixed;
            top: var(--header-height);
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.75);
            z-index: 99;
            opacity: 0;
            visibility: hidden;
            transition: all var(--transition-normal);
        }
        
        .sidebar-overlay.active {
            opacity: 1;
            visibility: visible;
        }

        .sidebar-section {
            margin-bottom: var(--spacing-xl);
        }

        .sidebar-title {
            font-size: 0.75rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.1em;
            color: var(--accent-primary);
            margin-bottom: var(--spacing-md);
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
        }

        .sidebar-title::before {
            content: '';
            width: 3px;
            height: 12px;
            background: var(--gradient-primary);
            border-radius: 2px;
        }

        .sidebar-title-collapsible {
            cursor: pointer;
            user-select: none;
            padding: 6px 8px;
            border-radius: var(--radius-sm);
            transition: background var(--transition-fast);
        }

        .sidebar-title-collapsible:hover {
            background: var(--bg-hover);
        }

        .sidebar-collapse-icon {
            font-size: 0.6rem;
            transition: transform 0.25s ease;
            display: inline-flex;
            width: 12px;
            justify-content: center;
        }

        .sidebar-section.collapsed .sidebar-collapse-icon {
            transform: rotate(-90deg);
        }

        .sidebar-collapsible-content {
            max-height: 1000px;
            overflow: hidden;
            transition: max-height 0.3s ease, opacity 0.25s ease;
            opacity: 1;
        }

        .sidebar-section.collapsed .sidebar-collapsible-content {
            max-height: 0;
            opacity: 0;
        }

        /* Mini Calendar */
        .mini-calendar {
            background: linear-gradient(180deg, var(--bg-tertiary) 0%, rgba(27, 27, 40, 0.9) 100%);
            border-radius: var(--radius-md);
            padding: var(--spacing-md);
            border: 1px solid rgba(100, 100, 140, 0.12);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
        }

        .mini-cal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: var(--spacing-sm);
        }

        .mini-cal-title {
            font-weight: 600;
            font-size: 0.9rem;
        }

        .mini-cal-nav {
            display: flex;
            gap: 2px;
        }

        .mini-cal-nav button {
            width: 24px;
            height: 24px;
            background: transparent;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            border-radius: var(--radius-sm);
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .mini-cal-nav button:hover {
            background: var(--bg-hover);
            color: var(--text-primary);
        }

        .mini-cal-grid {
            display: grid;
            grid-template-columns: repeat(7, 1fr);
            gap: 2px;
            text-align: center;
        }

        .mini-cal-day-header {
            font-size: 0.75rem;
            color: var(--text-muted);
            padding: var(--spacing-xs);
        }

        .mini-cal-day {
            font-size: 0.8rem;
            padding: 4px;
            border-radius: var(--radius-sm);
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .mini-cal-day:hover {
            background: var(--bg-hover);
        }

        .mini-cal-day.other-month {
            color: var(--text-muted);
        }

        .mini-cal-day.today {
            background: var(--accent-primary);
            color: var(--text-inverse);
            font-weight: 600;
        }

        .mini-cal-day.selected {
            outline: 2px solid var(--accent-primary);
            outline-offset: -2px;
        }

        .mini-cal-day.has-events::after {
            content: '';
            display: block;
            width: 4px;
            height: 4px;
            background: var(--accent-secondary);
            border-radius: 50%;
            margin: 2px auto 0;
        }

        /* Categories List */
        .category-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-xs);
        }

        .category-item {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: var(--spacing-sm) var(--spacing-md);
            border-radius: 6px;
            cursor: pointer;
            transition: all var(--transition-fast);
            border: 1px solid transparent;
        }

        .category-item.active {
            background: rgba(168, 85, 247, 0.1);
            color: var(--accent-primary);
            font-weight: 600;
            border-color: rgba(168, 85, 247, 0.25);
            border-left: 3px solid var(--accent-primary);
        }

        .category-item:hover {
            background: rgba(100, 100, 140, 0.08);
            border-color: rgba(100, 100, 140, 0.15);
        }

        .category-color {
            width: 12px;
            height: 12px;
            border-radius: 3px;
            flex-shrink: 0;
        }

        .category-name {
            flex: 1;
            font-size: 0.9rem;
        }

        .category-count {
            font-size: 0.75rem;
            color: var(--text-muted);
            background: var(--bg-tertiary);
            padding: 2px 6px;
            border-radius: var(--radius-full);
        }

        /* Upcoming Events */
        .upcoming-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-xs);
        }

        .upcoming-item {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            background: linear-gradient(135deg, rgba(26, 26, 38, 0.9) 0%, rgba(18, 18, 26, 0.95) 100%);
            border-radius: var(--radius-lg);
            padding: 8px 12px;
            cursor: pointer;
            transition: all var(--transition-fast);
            border: 1px solid var(--border-secondary);
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
        }

        .upcoming-item:hover {
            background: linear-gradient(135deg, rgba(36, 36, 54, 0.9) 0%, rgba(26, 26, 38, 0.95) 100%);
            transform: translateY(-1px);
            border-color: rgba(168, 85, 247, 0.35);
            box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35), 0 0 12px rgba(168, 85, 247, 0.08);
        }

        .upcoming-item-color {
            width: 4px;
            min-height: 32px;
            border-radius: 2px;
            flex-shrink: 0;
            align-self: stretch;
        }

        .upcoming-item-content {
            flex: 1;
            min-width: 0;
        }

        .upcoming-title {
            font-weight: 700;
            font-size: 0.85rem;
            margin-bottom: 3px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
            color: var(--text-primary);
        }

        .upcoming-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 5px;
            align-items: center;
        }

        .upcoming-pill {
            display: inline-flex;
            align-items: center;
            gap: 3px;
            padding: 3px 9px;
            border-radius: var(--radius-full);
            font-size: 0.75rem;
            font-weight: 600;
            letter-spacing: 0.2px;
        }

        .upcoming-pill-time {
            background: rgba(34, 211, 238, 0.12);
            border: 1px solid rgba(34, 211, 238, 0.25);
            color: var(--accent-cyan);
        }

        .upcoming-pill-cat {
            background: rgba(168, 85, 247, 0.1);
            border: 1px solid rgba(168, 85, 247, 0.25);
            color: var(--accent-primary);
        }

        .upcoming-pill-countdown {
            background: rgba(52, 211, 153, 0.08);
            border: 1px solid rgba(52, 211, 153, 0.2);
            color: #34d399;
        }

        .upcoming-pill-live {
            background: rgba(34, 197, 94, 0.18);
            border: 1px solid rgba(34, 197, 94, 0.5);
            color: #22c55e;
            box-shadow: 0 0 8px rgba(34, 197, 94, 0.2);
        }

        .upcoming-pill-ended {
            background: rgba(107, 114, 128, 0.08);
            border: 1px solid rgba(107, 114, 128, 0.2);
            color: #9ca3af;
        }

        .upcoming-item.live {
            border-color: rgba(34, 197, 94, 0.3);
        }

        .upcoming-item.ended {
            opacity: 0.6;
        }

        /* ========== Calendar Grid ========== */
        .calendar-container {
            flex: 1;
            display: flex;
            flex-direction: column;
            overflow: hidden;
            padding: var(--spacing-md);
            min-width: 0;
            max-width: 100%;
        }

        .calendar-grid {
            flex: 1;
            display: flex;
            flex-direction: column;
            background: linear-gradient(180deg, var(--bg-secondary) 0%, rgba(19, 19, 28, 0.95) 100%);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-primary);
            overflow: hidden;
            box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, 0.02);
            min-width: 0;
            max-width: 100%;
            width: 100%;
        }

        .calendar-header-row {
            display: grid;
            grid-template-columns: repeat(7, minmax(0, 1fr));
            background: linear-gradient(180deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%);
            border-bottom: 1px solid var(--border-primary);
            min-width: 0;
            max-width: 100%;
            overflow: hidden;
        }

        .calendar-header-cell {
            padding: var(--spacing-sm) var(--spacing-md);
            text-align: center;
            font-weight: 700;
            font-size: 0.75rem;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--accent-cyan);
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
            background: linear-gradient(180deg, rgba(6, 182, 212, 0.08) 0%, rgba(6, 182, 212, 0.02) 100%);
            border-bottom: 1px solid rgba(6, 182, 212, 0.15);
        }

        .calendar-body {
            flex: 1;
            display: grid;
            grid-template-columns: repeat(7, minmax(0, 1fr));
            grid-auto-rows: minmax(var(--calendar-cell-height), 1fr);
            min-width: 0;
            max-width: 100%;
        }

        .calendar-grid.month-view {
            overflow-y: auto;
            overflow-x: hidden;
        }

        .calendar-grid.month-view .calendar-header-row {
            position: sticky;
            top: 0;
            z-index: 5;
        }

        .calendar-grid.month-view .calendar-body {
            grid-auto-rows: minmax(var(--calendar-cell-height), auto);
            align-content: start;
        }

        .calendar-cell {
            border-right: 1px solid var(--border-primary);
            border-bottom: 1px solid var(--border-primary);
            padding: var(--spacing-xs);
            min-height: var(--calendar-cell-height);
            position: relative;
            cursor: pointer;
            transition: all var(--transition-fast);
            min-width: 0;
            overflow: hidden;
        }

        .calendar-cell:nth-child(7n) {
            border-right: none;
        }

        .calendar-cell:hover {
            background: var(--bg-hover);
            box-shadow: inset 0 0 0 2px var(--accent-primary);
        }
        
        .calendar-cell:hover .day-number {
            background: rgba(168, 85, 247, 0.1);
            border-color: rgba(168, 85, 247, 0.3);
            color: var(--accent-primary);
        }

        .calendar-cell.other-month {
            background: var(--bg-primary);
            opacity: 0.5;
        }

        .calendar-cell.other-month .day-number {
            color: var(--text-muted);
        }

        .calendar-cell.today {
            background: rgba(6, 182, 212, 0.04);
        }

        .calendar-cell.today::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 2px;
            background: linear-gradient(90deg, var(--accent-cyan), var(--accent-primary));
            opacity: 0.6;
        }

        .calendar-cell.today .day-number {
            background: rgba(6, 182, 212, 0.12);
            color: var(--accent-cyan);
            font-weight: 700;
            border-color: rgba(6, 182, 212, 0.35);
            border-left: 3px solid var(--accent-cyan);
            box-shadow: 0 1px 4px rgba(6, 182, 212, 0.12);
        }

        .day-number {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 28px;
            height: 26px;
            padding: 0 8px;
            font-size: 0.85rem;
            font-weight: 600;
            border-radius: 6px;
            border: 1px solid transparent;
            margin-bottom: var(--spacing-xs);
            transition: all var(--transition-fast);
            position: relative;
            letter-spacing: 0.2px;
        }

        .day-number:hover {
            transform: translateY(-1px);
            box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
        }

        .day-events {
            display: flex;
            flex-direction: column;
            gap: 4px;
            overflow: hidden;
            margin-top: 2px;
            min-width: 0;
        }

        .event-icon-group {
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
            margin-top: 4px;
        }

        .event-icon {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            font-size: 0.8rem;
            padding: 2px 6px;
            border-radius: var(--radius-full);
            border: 1px solid rgba(255, 255, 255, 0.25);
            background: rgba(0, 0, 0, 0.25);
            line-height: 1;
            min-width: 0;
            cursor: pointer;
        }

        /* Event Chips on Calendar */
        .event-chip {
            font-size: 0.85rem;
            font-weight: 600;
            line-height: 1.4;
            padding: 5px 10px 5px 0;
            border-radius: 6px;
            cursor: pointer;
            transition: all var(--transition-fast);
            position: relative;
            border: 1px solid var(--chip-accent, rgba(100, 100, 140, 0.25));
            border-left: 3px solid var(--chip-accent, #3b82f6);
            box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
            letter-spacing: 0.1px;
            -webkit-font-smoothing: antialiased;
            min-width: 0;
            max-width: 100%;
            background: var(--chip-bg, rgba(59, 130, 246, 0.1));
            color: var(--chip-text, #e2e8f0);
        }


        .event-chip:hover {
            filter: brightness(1.15);
            transform: translateY(-1px);
            box-shadow: 0 3px 8px rgba(0, 0, 0, 0.25);
            border-color: var(--chip-accent, #3b82f6);
        }

        .event-chip.all-day {
            font-weight: 600;
            border-left-style: dashed;
        }

        .event-chip.live {
            border-left-color: #22c55e !important;
            border-color: rgba(34, 197, 94, 0.35);
        }

        .chip-live-dot {
            display: inline-block;
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: #22c55e;
            margin-right: 2px;
            flex-shrink: 0;
            box-shadow: 0 0 6px #22c55e;
        }

        .event-chip.ended {
            opacity: 0.5;
            border-left-color: #6b7280 !important;
        }

        .event-chip.stopped {
            opacity: 0.6;
            border-left-color: #f97316 !important;
            border-color: rgba(249, 115, 22, 0.3);
        }

        /* Overnight events: single pill that physically spans into the next day cell */
        .event-chip.overnight {
            position: absolute;
            left: 0;
            right: auto;
            /* Spans from current cell fully across into the next cell */
            width: calc(200% + 2px); /* 2px accounts for the cell border */
            z-index: 10;
            border-right: 3px solid var(--chip-accent, #3b82f6);
            border-top-right-radius: 6px;
            border-bottom-right-radius: 6px;
            max-width: none;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
        }
        /* Saturday column: event wraps to next row, can't span right — use indicator instead */
        .calendar-cell.overnight-sat .event-chip.overnight {
            position: relative;
            width: 100%;
            max-width: 100%;
            border-right: none;
            border-top-right-radius: 0;
            border-bottom-right-radius: 0;
        }
        .calendar-cell.overnight-sat .event-chip.overnight::after {
            content: '\276F';
            position: absolute;
            right: 2px;
            top: 50%;
            transform: translateY(-50%);
            font-size: 0.65rem;
            opacity: 0.7;
            pointer-events: none;
        }
        /* Spacer preserves vertical flow height when overnight chip is position:absolute */
        .overnight-spacer {
            height: 30px; /* match chip height */
            pointer-events: none;
        }
        /* Allow overnight chips to overflow their cell */
        .calendar-cell.has-overnight {
            overflow: visible;
            z-index: 6;
        }
        .calendar-cell.has-overnight > .day-events {
            overflow: visible;
            position: relative;
        }

        .more-events {
            font-size: 0.78rem;
            font-weight: 600;
            color: var(--accent-primary);
            padding: 3px 10px;
            cursor: pointer;
            transition: all var(--transition-fast);
            border-radius: 6px;
            background: rgba(168, 85, 247, 0.08);
            border: 1px solid rgba(168, 85, 247, 0.2);
            border-left: 3px solid var(--accent-primary);
            width: fit-content;
            box-shadow: none;
        }

        .more-events:hover {
            transform: translateY(-1px);
            background: rgba(168, 85, 247, 0.15);
            border-color: rgba(168, 85, 247, 0.35);
        }

        /* ========== Week View ========== */
        .week-cell {
            display: flex;
            flex-direction: column;
        }

        .week-day-header {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: var(--spacing-sm) var(--spacing-md);
            border-bottom: 2px solid var(--border-primary);
            background: linear-gradient(135deg, var(--bg-primary) 0%, rgba(34, 211, 238, 0.01) 100%);
        }

        .week-day-header .day-name {
            font-size: 0.85rem;
            color: var(--text-secondary);
            text-transform: uppercase;
            font-weight: 700;
            letter-spacing: 0.5px;
            position: relative;
        }

        .week-day-header .day-name::after {
            content: '';
            position: absolute;
            bottom: -6px;
            left: 0;
            right: 0;
            height: 2px;
            background: linear-gradient(90deg, var(--accent-cyan) 0%, var(--accent-blue) 50%, var(--accent-purple) 100%);
            border-radius: 1px;
            opacity: 0.6;
        }

        .week-events {
            flex: 1;
            padding: var(--spacing-xs);
            overflow-y: auto;
        }

        /* Month label hidden on desktop — only shown on mobile week cards */
        .week-day-month {
            display: none;
        }

        /* ========== Day View ========== */
        .day-view-container {
            position: relative;
        }

        .all-day-section {
            background: var(--bg-tertiary);
        }

        .hour-row:hover .hour-content {
            background: var(--bg-hover);
        }

        .hour-label {
            border-right: 1px solid var(--border-primary);
        }

        /* ========== Category Filter Active State ========== */
        .category-item.active {
            background: var(--bg-hover);
            border-radius: var(--radius-sm);
        }

        .category-item.active .category-color {
            box-shadow: 0 0 0 2px var(--bg-secondary), 0 0 0 4px currentColor;
        }

        /* ========== Modals ========== */
        .modal-overlay {
            position: fixed;
            inset: 0;
            background: rgba(5, 5, 8, 0.92);
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 1000;
            opacity: 0;
            visibility: hidden;
            transition: opacity 60ms ease-out, visibility 60ms ease-out;
        }

        .modal-overlay.active {
            opacity: 1;
            visibility: visible;
        }

        .modal {
            background: linear-gradient(180deg, rgba(19, 19, 28, 0.98) 0%, rgba(11, 11, 18, 0.99) 100%);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-secondary);
            box-shadow: var(--shadow-lg), 0 0 40px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.03);
            width: 90%;
            max-width: 500px;
            max-height: 90vh;
            overflow: hidden;
            transform: translateY(6px);
            transition: transform 60ms ease-out;
        }

        .modal-overlay.active .modal {
            transform: translateY(0);
        }



        .modal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-lg);
            border-bottom: 1px solid var(--border-primary);
            background: linear-gradient(135deg, rgba(168, 85, 247, 0.08) 0%, rgba(6, 182, 212, 0.06) 100%);
        }

        .modal-title {
            font-size: 1.2rem;
            font-weight: 700;
            background: linear-gradient(135deg, var(--text-primary) 0%, var(--accent-cyan) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
        }

        #viewEventTitle {
            flex: 1 1 auto;
            min-width: 0;
            overflow-wrap: anywhere;
            word-break: break-word;
        }

        #viewEventDescription {
            margin: 0;
            line-height: 1.5;
            overflow-wrap: anywhere;
            word-break: break-word;
            white-space: pre-wrap;
            max-width: 100%;
        }

        #viewEventLocation {
            overflow-wrap: anywhere;
            word-break: break-word;
        }

        #viewEventCategory,
        #viewEventDate,
        #viewEventTime,
        #viewEventCreator {
            max-width: 100%;
            overflow-wrap: anywhere;
            word-break: break-word;
        }

        #viewEventCategory {
            flex: 0 0 auto;
            min-width: 0;
            width: fit-content;
        }

        .event-detail-header {
            min-width: 0;
        }

        .event-detail-meta {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-sm);
            flex-wrap: wrap;
            min-width: 0;
        }

        .event-category-pill {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 4px 10px;
            border-radius: var(--radius-full);
            background: linear-gradient(90deg, rgba(168, 85, 247, 0.25) 0%, rgba(6, 182, 212, 0.18) 100%);
            border: 1px solid rgba(168, 85, 247, 0.4);
            color: var(--text-secondary);
            font-size: 0.8rem;
            font-weight: 600;
            box-shadow: 0 8px 16px rgba(0, 0, 0, 0.35);
            flex: 0 0 auto;
            max-width: 100%;
        }

        .event-detail-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
            gap: var(--spacing-lg);
            min-width: 0;
        }

        .event-detail-grid > div,
        .event-detail-card {
            min-width: 0;
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            padding: var(--spacing-md);
            border-radius: var(--radius-md);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.35);
        }

        .event-detail-description {
            margin-bottom: var(--spacing-lg);
        }

        .event-detail-grid > div > *:not(.event-detail-label),
        .event-detail-card > *:not(.event-detail-label) {
            margin: 0;
            font-weight: 500;
            line-height: 1.4;
            overflow-wrap: anywhere;
            word-break: break-word;
        }

        .event-detail-label {
            font-size: 0.8rem;
            display: flex;
            align-items: center;
            gap: 6px;
            flex-wrap: wrap;
            white-space: normal;
        }

        /* ========== View Modal Styles ========== */
        .view-modal-section {
            margin-bottom: var(--spacing-md);
        }

        .view-modal-section:last-child {
            margin-bottom: 0;
        }

        .view-section-title {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            color: var(--text-muted);
            margin-bottom: 10px;
        }

        /* Hero header with event title */
        .view-hero {
            text-align: center;
            padding-bottom: var(--spacing-md);
            margin-bottom: var(--spacing-md);
            border-bottom: 1px solid var(--border-primary);
        }

        .view-hero-badges {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            flex-wrap: wrap;
            margin-bottom: 10px;
        }

        .view-hero-title {
            font-size: 1.4rem;
            font-weight: 700;
            color: var(--text-primary);
            margin: 0 0 6px 0;
            line-height: 1.3;
        }

        .view-hero-creator {
            font-size: 0.85rem;
            color: var(--text-muted);
        }

        .view-hero-creator strong {
            color: var(--text-secondary);
            font-weight: 500;
        }

        /* Info cards grid */
        .view-info-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
        }

        @media (max-width: 480px) {
            .view-info-grid {
                grid-template-columns: 1fr;
            }
        }

        .view-info-card {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px;
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }

        .view-info-card.full-width {
            grid-column: 1 / -1;
        }

        .view-info-icon {
            width: 32px;
            height: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 8px;
            flex-shrink: 0;
        }

        .view-info-icon svg {
            width: 16px;
            height: 16px;
        }

        .view-info-icon.icon-date {
            background: rgba(34, 211, 238, 0.12);
        }
        .view-info-icon.icon-date svg { fill: var(--accent-cyan); }

        .view-info-icon.icon-time {
            background: rgba(250, 204, 21, 0.12);
        }
        .view-info-icon.icon-time svg { fill: var(--accent-warning); }

        .view-info-icon.icon-location {
            background: rgba(34, 197, 94, 0.12);
        }
        .view-info-icon.icon-location svg { fill: var(--accent-green); }

        .view-info-content {
            flex: 1;
            min-width: 0;
        }

        .view-info-label {
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.4px;
            color: var(--text-muted);
            margin-bottom: 2px;
        }

        .view-info-value {
            font-size: 0.9rem;
            font-weight: 500;
            color: var(--text-primary);
            line-height: 1.3;
        }

        /* Description area */
        .view-description-box {
            padding: 14px;
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }

        .view-description-text {
            margin: 0;
            font-size: 0.9rem;
            line-height: 1.6;
            color: var(--text-secondary);
            white-space: pre-wrap;
        }

        .view-description-text:empty::before {
            content: 'No description provided';
            color: var(--text-muted);
            font-style: italic;
        }

        /* RSVP buttons */
        .view-rsvp-buttons {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 8px;
        }

        .view-rsvp-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            padding: 12px 8px;
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all 0.15s ease;
            font-family: inherit;
            color: var(--text-secondary);
        }

        .view-rsvp-btn:hover {
            border-color: var(--border-secondary);
            background: var(--bg-hover);
        }

        .view-rsvp-btn .rsvp-icon {
            font-size: 1.2rem;
            line-height: 1;
        }

        .view-rsvp-btn .rsvp-label {
            font-size: 0.72rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.3px;
        }

        .view-rsvp-btn.active.going {
            background: rgba(34, 197, 94, 0.12);
            border-color: var(--accent-green);
            color: var(--accent-green);
        }

        .view-rsvp-btn.active.maybe {
            background: rgba(250, 204, 21, 0.12);
            border-color: var(--accent-warning);
            color: var(--accent-warning);
        }

        .view-rsvp-btn.active.declined {
            background: rgba(239, 68, 68, 0.12);
            border-color: var(--accent-danger);
            color: var(--accent-danger);
        }

        /* Attendees compact display */
        .view-attendees-compact {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .view-attendee-chip {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 4px 10px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-full);
            font-size: 0.78rem;
            font-weight: 500;
            color: var(--text-secondary);
        }

        .view-attendee-chip.going {
            background: rgba(34, 197, 94, 0.1);
            border-color: rgba(34, 197, 94, 0.25);
            color: var(--accent-green);
        }

        .view-attendee-chip.maybe {
            background: rgba(250, 204, 21, 0.1);
            border-color: rgba(250, 204, 21, 0.25);
            color: var(--accent-warning);
        }

        .view-attendee-chip.declined {
            background: rgba(239, 68, 68, 0.08);
            border-color: rgba(239, 68, 68, 0.2);
            color: var(--accent-danger);
        }

        .view-attendee-chip .status-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            flex-shrink: 0;
        }

        .view-attendee-chip.going .status-dot { background: var(--accent-green); }
        .view-attendee-chip.maybe .status-dot { background: var(--accent-warning); }
        .view-attendee-chip.declined .status-dot { background: var(--accent-danger); }

        .view-no-attendees {
            font-size: 0.85rem;
            color: var(--text-muted);
            font-style: italic;
        }

        /* Share buttons grid */
        .view-share-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .view-share-btn {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 36px;
            height: 36px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all 0.15s ease;
            color: var(--text-secondary);
        }

        .view-share-btn:hover {
            border-color: var(--border-secondary);
        }

        .view-share-btn svg {
            width: 16px;
            height: 16px;
            fill: currentColor;
        }

        .view-share-btn.btn-copy {
            width: auto;
            padding: 0 12px;
            gap: 6px;
            font-size: 0.75rem;
            font-weight: 600;
        }

        .view-share-btn.btn-x:hover { background: #000; color: #fff; border-color: #000; }
        .view-share-btn.btn-facebook:hover { background: #1877f2; color: #fff; border-color: #1877f2; }
        .view-share-btn.btn-linkedin:hover { background: #0a66c2; color: #fff; border-color: #0a66c2; }
        .view-share-btn.btn-discord:hover { background: #5865f2; color: #fff; border-color: #5865f2; }
        .view-share-btn.btn-copy:hover { background: var(--accent-primary); color: #fff; border-color: var(--accent-primary); }

        /* Game link button */
        .view-steam-btn {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            padding: 8px 14px;
            background: linear-gradient(135deg, #1b2838 0%, #2a475e 100%);
            border: 1px solid rgba(102, 192, 244, 0.3);
            border-radius: var(--radius-md);
            color: #66c0f4;
            font-size: 0.82rem;
            font-weight: 600;
            text-decoration: none;
            transition: all 0.15s ease;
        }

        .view-steam-btn:hover {
            background: linear-gradient(135deg, #2a475e 0%, #3d6a8e 100%);
            border-color: #66c0f4;
        }

        .view-steam-btn svg {
            width: 16px;
            height: 16px;
            fill: currentColor;
        }

        /* Discord community link */
        .view-discord-link {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 10px 14px;
            background: linear-gradient(135deg, #5865f2 0%, #7289da 100%);
            border-radius: var(--radius-md);
            color: #fff;
            text-decoration: none;
            font-size: 0.85rem;
            font-weight: 600;
            transition: all 0.15s ease;
        }

        .view-discord-link:hover {
            transform: translateY(-1px);
            box-shadow: 0 4px 12px rgba(88, 101, 242, 0.4);
        }

        .view-discord-link svg {
            width: 18px;
            height: 18px;
            fill: currentColor;
            flex-shrink: 0;
        }

        /* Divider between sections */
        .view-divider {
            height: 1px;
            background: var(--border-primary);
            margin: var(--spacing-md) 0;
        }

        /* Attendee count badge */
        .attendee-count-badge {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 18px;
            height: 18px;
            padding: 0 5px;
            background: var(--bg-tertiary);
            border-radius: var(--radius-full);
            font-size: 0.7rem;
            font-weight: 600;
            color: var(--text-muted);
            margin-left: auto;
        }

        /* Legacy compatibility */
        .view-detail-row { display: none; }
        .view-detail-item { display: none; }
        .view-rsvp-panel { display: none; }
        .view-attendees-panel { display: none; }

        .modal-close {
            width: 32px;
            height: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: transparent;
            border: none;
            color: var(--text-muted);
            cursor: pointer;
            border-radius: var(--radius-sm);
            font-size: 1.25rem;
            transition: all var(--transition-fast);
        }

        .modal-close:hover {
            background: var(--accent-danger);
            color: white;
            transform: rotate(90deg);
        }

        .modal-body {
            padding: var(--spacing-lg);
            overflow-y: auto;
            overflow-x: hidden;
            max-height: 70vh;
            -webkit-overflow-scrolling: touch;
            overscroll-behavior: contain;
        }
        
        /* Ensure select dropdowns display properly */
        .form-select {
            appearance: none;
            -webkit-appearance: none;
            -moz-appearance: none;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239090b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 12px center;
            padding-right: 36px;
            cursor: pointer;
        }
        
        .form-select option {
            background: var(--bg-secondary);
            color: var(--text-primary);
            padding: 8px;
        }

        .modal-footer {
            display: flex;
            align-items: center;
            justify-content: flex-end;
            gap: var(--spacing-sm);
            padding: var(--spacing-lg);
            border-top: 1px solid var(--border-primary);
        }

        .day-modal-cta {
            flex-direction: column;
            align-items: stretch;
            gap: var(--spacing-xs);
            background: linear-gradient(135deg, rgba(6, 182, 212, 0.08) 0%, rgba(168, 85, 247, 0.14) 100%);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
            padding: var(--spacing-md);
        }

        .day-modal-cta-title {
            margin: 0;
        }

        .day-modal-cta-subtitle {
            display: inline-flex;
            align-items: center;
            width: fit-content;
            padding: 4px 10px;
            border-radius: var(--radius-full);
            font-size: 0.85rem;
            color: var(--text-muted);
            background: linear-gradient(90deg, rgba(6, 182, 212, 0.18) 0%, rgba(168, 85, 247, 0.16) 100%);
            border: 1px solid rgba(6, 182, 212, 0.28);
        }

        .day-modal-cta-btn {
            width: 100%;
            justify-content: center;
            font-size: 0.95rem;
            font-weight: 700;
            letter-spacing: 0.3px;
            padding: 12px 16px;
            border-radius: var(--radius-md);
            border: 1px solid rgba(255, 255, 255, 0.2);
            box-shadow: 0 14px 24px rgba(6, 182, 212, 0.2), 0 4px 10px rgba(0, 0, 0, 0.35);
            white-space: normal;
            text-align: center;
        }

        .day-modal-cta-btn:hover {
            filter: brightness(1.05);
            transform: translateY(-1px);
        }

        .day-modal-cta-label-btn {
            cursor: pointer;
            padding: 10px 16px;
            font-size: 0.8rem;
            letter-spacing: 0.14em;
            text-transform: uppercase;
            border-radius: var(--radius-full);
            border: 1px solid rgba(168, 85, 247, 0.45);
            background: linear-gradient(90deg, rgba(168, 85, 247, 0.32) 0%, rgba(6, 182, 212, 0.2) 100%);
            box-shadow: 0 10px 20px rgba(0, 0, 0, 0.35), inset 0 0 0 1px rgba(255, 255, 255, 0.05);
        }

        .day-modal-cta-label-btn:hover {
            filter: brightness(1.05);
            transform: translateY(-1px);
        }

        /* Day Modal Event List */
        .day-event-item {
            display: flex;
            align-items: flex-start;
            gap: var(--spacing-md);
            padding: var(--spacing-md) var(--spacing-lg);
            border-bottom: 1px solid var(--border-primary);
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .day-event-item:hover {
            background: var(--bg-hover);
        }
        
        .day-event-item:last-child {
            border-bottom: none;
        }
        
        .day-event-time {
            min-width: 86px;
            font-size: 0.82rem;
            font-weight: 700;
            color: var(--accent-cyan);
            text-align: center;
            padding: 4px 8px;
            border-radius: var(--radius-full);
            background: rgba(34, 211, 238, 0.16);
            border: 1px solid rgba(34, 211, 238, 0.35);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15);
        }
        
        .day-event-time.all-day {
            color: var(--accent-warning);
            background: rgba(250, 204, 21, 0.16);
            border-color: rgba(250, 204, 21, 0.35);
        }
        
        .day-event-info {
            flex: 1;
            min-width: 0;
        }
        
        .day-event-title {
            font-weight: 700;
            background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 50%, var(--accent-purple) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin-bottom: 4px;
            text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
            letter-spacing: 0.2px;
            overflow-wrap: anywhere;
            word-break: break-word;
        }
        
        .day-event-meta {
            font-size: 0.8rem;
            color: var(--text-muted);
            display: flex;
            gap: var(--spacing-sm);
            flex-wrap: wrap;
        }

        .day-event-meta span {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 2px 8px;
            border-radius: var(--radius-full);
            background: rgba(148, 163, 184, 0.12);
            border: 1px solid rgba(148, 163, 184, 0.25);
            color: var(--text-secondary);
        }
        
        .day-event-color {
            width: 4px;
            border-radius: 2px;
            flex-shrink: 0;
        }

        /* ========== Form Elements ========== */
        .form-group {
            margin-bottom: var(--spacing-lg);
        }

        .form-group small.text-muted,
        .form-group > small {
            display: block;
            margin-top: 6px;
            font-size: 0.72rem;
            color: var(--text-muted);
            opacity: 0.75;
            line-height: 1.4;
            padding-left: 2px;
        }

        .form-label {
            display: inline-flex;
            align-items: center;
            gap: var(--spacing-sm);
            width: fit-content;
            font-size: 0.82rem;
            font-weight: 800;
            color: #fff;
            margin-bottom: var(--spacing-sm);
            letter-spacing: 1px;
            text-transform: uppercase;
            line-height: 1.2;
            padding: 8px 16px;
            border-radius: var(--radius-full);
            background: linear-gradient(135deg, rgba(168, 85, 247, 0.32) 0%, rgba(6, 182, 212, 0.18) 50%, rgba(168, 85, 247, 0.15) 100%);
            border: 1.5px solid rgba(168, 85, 247, 0.5);
            box-shadow:
                inset 0 1px 0 rgba(255, 255, 255, 0.08),
                0 4px 16px rgba(0, 0, 0, 0.4),
                0 0 20px rgba(168, 85, 247, 0.2),
                0 0 40px rgba(168, 85, 247, 0.06);
            text-shadow: 0 0 12px rgba(168, 85, 247, 0.4), 0 1px 2px rgba(0, 0, 0, 0.5);
        }

        .form-label::before {
            content: '';
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: radial-gradient(circle, var(--accent-cyan) 0%, rgba(34, 211, 238, 0.3) 70%);
            box-shadow: 0 0 10px rgba(34, 211, 238, 0.6);
            flex-shrink: 0;
        }

        /* Pause animations for off-screen elements */
        .settings-panel:not(.active) .form-label::before,
        .modal:not(.active) .form-label::before {
            animation-play-state: paused;
        }

        @keyframes labelDotPulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.7; }
        }

        /* Respect reduced motion preference */
        @media (prefers-reduced-motion: reduce) {
            .form-label::before,
            .cron-hero-spinner,
            .chip-live-dot,
            .today-pulse,
            .onboarding-icon,
            .loading-spinner { animation: none; }
            
            body::before { display: none; }
        }

        .form-label .text-muted {
            display: inline-flex;
            align-items: center;
            padding: 2px 6px;
            border-radius: var(--radius-full);
            background: rgba(144, 144, 184, 0.12);
            border: 1px solid rgba(144, 144, 184, 0.25);
            color: var(--text-muted);
            font-size: 0.65rem;
            font-weight: 600;
            letter-spacing: 0.6px;
            text-transform: uppercase;
        }

        .form-input,
        .form-select,
        .form-textarea {
            width: 100%;
            padding: var(--spacing-sm) var(--spacing-md);
            background: var(--bg-secondary);
            border: 1px solid var(--border-secondary);
            border-radius: var(--radius-md);
            color: var(--text-primary);
            font-size: 0.95rem;
            transition: all var(--transition-fast);
        }
        
        .form-input::placeholder {
            color: var(--text-muted);
        }

        .form-input:focus,
        .form-select:focus,
        .form-textarea:focus {
            outline: none;
            border-color: var(--accent-primary);
            box-shadow: 0 0 0 3px var(--accent-primary-glow);
        }

        /* Date and Time input icons - make them visible on dark background */
        .form-input[type="date"],
        .form-input[type="time"],
        input[type="date"],
        input[type="time"] {
            color-scheme: dark;
        }
        
        .form-input[type="date"]::-webkit-calendar-picker-indicator,
        .form-input[type="time"]::-webkit-calendar-picker-indicator,
        input[type="date"]::-webkit-calendar-picker-indicator,
        input[type="time"]::-webkit-calendar-picker-indicator {
            filter: invert(0.8) brightness(1.2);
            cursor: pointer;
            opacity: 0.8;
            transition: opacity 0.2s ease;
        }
        
        .form-input[type="date"]::-webkit-calendar-picker-indicator:hover,
        .form-input[type="time"]::-webkit-calendar-picker-indicator:hover,
        input[type="date"]::-webkit-calendar-picker-indicator:hover,
        input[type="time"]::-webkit-calendar-picker-indicator:hover {
            opacity: 1;
        }

        .form-textarea {
            min-height: 100px;
            resize: vertical;
        }

        .form-row {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--spacing-md);
        }

        .form-checkbox {
            display: inline-flex;
            align-items: center;
            gap: var(--spacing-xs);
            cursor: pointer;
            color: var(--text-secondary);
            font-size: 0.8rem;
            font-weight: 600;
            letter-spacing: 0.3px;
            padding: 6px 10px;
            border-radius: var(--radius-full);
            border: 1px solid rgba(61, 61, 92, 0.7);
            background: linear-gradient(180deg, rgba(18, 18, 26, 0.9) 0%, rgba(10, 10, 15, 0.7) 100%);
            box-shadow:
                inset 0 0 0 1px rgba(255, 255, 255, 0.03),
                0 8px 16px rgba(0, 0, 0, 0.45);
            transition:
                transform var(--transition-fast),
                border-color var(--transition-fast),
                box-shadow var(--transition-fast),
                color var(--transition-fast),
                background var(--transition-fast);
        }

        .form-checkbox span {
            transition: color var(--transition-fast), text-shadow var(--transition-fast);
        }

        .form-checkbox:hover {
            transform: translateY(-1px);
            border-color: rgba(34, 211, 238, 0.45);
            box-shadow:
                inset 0 0 0 1px rgba(255, 255, 255, 0.05),
                0 10px 18px rgba(0, 0, 0, 0.45),
                0 0 12px rgba(34, 211, 238, 0.12);
            color: var(--text-primary);
        }

        .form-checkbox:has(input:checked) {
            border-color: rgba(34, 211, 238, 0.65);
            background: linear-gradient(90deg, rgba(34, 211, 238, 0.2) 0%, rgba(168, 85, 247, 0.16) 100%);
            box-shadow:
                inset 0 0 0 1px rgba(34, 211, 238, 0.2),
                0 12px 24px rgba(34, 211, 238, 0.18);
            color: var(--text-primary);
        }

        .form-checkbox input:checked + span {
            color: var(--accent-cyan);
            text-shadow: 0 0 10px rgba(34, 211, 238, 0.45);
        }

        .form-checkbox input {
            width: 18px;
            height: 18px;
            accent-color: var(--accent-primary);
        }

        /* ========== Password Strength Meter ========== */
        .password-strength-container {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-sm);
        }
        
        .password-strength-bar {
            flex: 1;
            height: 6px;
            background: var(--bg-tertiary);
            border-radius: var(--radius-full);
            overflow: hidden;
        }
        
        .password-strength-fill {
            height: 100%;
            width: 0%;
            border-radius: var(--radius-full);
            transition: all 0.3s ease;
        }
        
        .password-strength-fill.weak {
            width: 33%;
            background: linear-gradient(90deg, #ef4444 0%, #f87171 100%);
        }
        
        .password-strength-fill.medium {
            width: 66%;
            background: linear-gradient(90deg, #f59e0b 0%, #fbbf24 100%);
        }
        
        .password-strength-fill.strong {
            width: 100%;
            background: linear-gradient(90deg, #22c55e 0%, #4ade80 100%);
        }
        
        .password-strength-label {
            font-size: 0.7rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            min-width: 55px;
            text-align: right;
        }
        
        .password-strength-label.weak { color: #ef4444; }
        .password-strength-label.medium { color: #f59e0b; }
        .password-strength-label.strong { color: #22c55e; }
        
        /* Password Requirements List */
        .password-requirements {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 6px 12px;
            margin-top: var(--spacing-md);
            padding: var(--spacing-sm) var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }
        
        .password-req {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 0.72rem;
            color: var(--text-muted);
            transition: color 0.2s ease;
        }
        
        .password-req .req-icon {
            width: 14px;
            height: 14px;
            flex-shrink: 0;
            fill: none;
            stroke: var(--text-muted);
            stroke-width: 2;
            transition: all 0.2s ease;
        }
        
        .password-req.met {
            color: #22c55e;
        }
        
        .password-req.met .req-icon {
            stroke: #22c55e;
            fill: rgba(34, 197, 94, 0.2);
        }

        /* Color Picker */
        .color-options {
            display: flex;
            gap: var(--spacing-xs);
            flex-wrap: wrap;
        }

        .color-option {
            width: 28px;
            height: 28px;
            border-radius: var(--radius-sm);
            cursor: pointer;
            border: 2px solid transparent;
            transition: all var(--transition-fast);
        }

        .color-option:hover {
            transform: scale(1.1);
        }

        .color-option.selected {
            border-color: white;
            box-shadow: 0 0 0 2px var(--bg-secondary);
        }

        /* ========== RSVP Buttons ========== */
        .rsvp-buttons {
            display: flex;
            gap: var(--spacing-sm);
        }

        .rsvp-btn {
            flex: 1;
            padding: var(--spacing-sm) var(--spacing-md);
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all var(--transition-fast);
            text-align: center;
            color: var(--text-primary);
            font-size: 0.9rem;
            font-weight: 500;
        }

        /* Body scroll lock when modal/popup is open */
        body.scroll-locked {
            overflow: hidden !important;
        }

        /* ========== Timezone Selector ========== */
        .timezone-selector {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
        }

        .timezone-btn {
            display: flex;
            align-items: center;
            gap: 4px;
            padding: 6px 10px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-secondary);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .timezone-btn:hover {
            background: var(--bg-hover);
            border-color: var(--border-secondary);
        }

        .timezone-btn .tz-icon {
            font-size: 1rem;
        }

        .timezone-btn .tz-abbr {
            font-weight: 600;
            color: var(--accent-cyan);
        }

        /* ========== Timezone Picker Popup (Global) ========== */
        .tz-picker-overlay {
            position: fixed;
            inset: 0;
            background: rgba(5, 5, 8, 0.85);
            z-index: 10000;
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.15s ease, visibility 0s 0.15s;
        }

        .tz-picker-overlay.active {
            opacity: 1;
            visibility: visible;
            transition: opacity 0.25s ease, visibility 0s 0s;
        }

        .tz-picker-panel {
            background: var(--bg-secondary);
            border: 1px solid var(--border-secondary);
            border-radius: var(--radius-lg);
            box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(99, 102, 241, 0.08);
            width: 340px;
            max-width: 90vw;
            max-height: 70vh;
            display: flex;
            flex-direction: column;
            transform: scale(0.92) translateY(12px);
            transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1);
            overflow: hidden;
        }

        .tz-picker-overlay.active .tz-picker-panel {
            transform: scale(1) translateY(0);
        }

        .tz-picker-handle {
            display: none;
        }

        .tz-picker-title {
            padding: var(--spacing-md) var(--spacing-lg);
            font-size: 1rem;
            font-weight: 700;
            color: var(--text-primary);
            border-bottom: 1px solid var(--border-primary);
            background: linear-gradient(90deg, rgba(99, 102, 241, 0.08) 0%, rgba(34, 211, 238, 0.08) 100%);
            flex-shrink: 0;
        }

        .tz-picker-options {
            overflow-y: auto;
            flex: 1;
            overscroll-behavior: contain;
        }

        .timezone-dropdown-header {
            padding: var(--spacing-sm) var(--spacing-md);
            border-bottom: 1px solid var(--border-primary);
            font-size: 0.75rem;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            position: sticky;
            top: 0;
            background: var(--bg-secondary);
            z-index: 1;
        }

        .timezone-option {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: var(--spacing-sm) var(--spacing-md);
            cursor: pointer;
            transition: background var(--transition-fast);
        }

        .timezone-option:hover {
            background: var(--bg-hover);
        }

        .timezone-option.selected {
            background: rgba(168, 85, 247, 0.15);
        }

        .timezone-option .tz-name {
            font-size: 0.85rem;
            color: var(--text-primary);
        }

        .timezone-option .tz-offset {
            font-size: 0.75rem;
            color: var(--text-muted);
            font-family: monospace;
        }

        .timezone-option.auto {
            border-bottom: 1px solid var(--border-primary);
        }

        .timezone-option.auto .tz-name {
            color: var(--accent-cyan);
        }

        .timezone-option.server-tz {
            background: rgba(168, 85, 247, 0.08);
            border-bottom: 1px solid var(--border-primary);
        }

        .timezone-option.server-tz .tz-name {
            color: var(--accent-purple);
        }

        /* Header Actions Group */
        .header-actions-group {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            padding-left: var(--spacing-sm);
            border-left: 1px solid var(--border-primary);
        }

        /* Mobile Menu (hidden on desktop) */
        .mobile-menu-toggle {
            display: none;
        }

        .mobile-menu-dropdown {
            display: none;
            position: absolute;
            top: calc(var(--header-height) - 4px);
            right: var(--spacing-sm);
            background: var(--bg-secondary);
            border: 1px solid var(--border-primary);
            border-radius: 16px;
            padding: var(--spacing-sm);
            min-width: 220px;
            box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04);
            z-index: 200;
            animation: mobileMenuFadeIn 0.18s ease;
        }

        .mobile-menu-dropdown.open {
            display: block;
        }

        @keyframes mobileMenuFadeIn {
            from { opacity: 0; transform: translateY(-8px); }
            to { opacity: 1; transform: translateY(0); }
        }

        .mobile-menu-item {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            padding: 11px 14px;
            border-radius: 10px;
            cursor: pointer;
            color: var(--text-primary);
            font-size: 0.9rem;
            font-weight: 500;
            transition: background var(--transition-fast);
            width: 100%;
            border: none;
            background: none;
            text-align: left;
        }

        .mobile-menu-item:hover,
        .mobile-menu-item:active {
            background: var(--bg-hover);
        }

        .mobile-menu-icon {
            font-size: 1.1rem;
            width: 26px;
            text-align: center;
            flex-shrink: 0;
        }

        .mobile-menu-label {
            flex: 1;
        }

        .mobile-menu-value {
            font-size: 0.78rem;
            color: var(--text-muted);
            font-weight: 400;
            background: var(--bg-tertiary);
            padding: 2px 8px;
            border-radius: 6px;
        }

        .mobile-menu-section-label {
            font-size: 0.68rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-muted);
            padding: 6px 14px 2px;
            opacity: 0.7;
        }

        .mobile-menu-divider {
            height: 1px;
            background: var(--border-primary);
            margin: 6px 8px;
            opacity: 0.5;
        }

        .mobile-menu-btn-submit {
            font-family: inherit;
        }

        .mobile-menu-view-switcher {
            display: flex;
            gap: 3px;
            padding: 4px;
            background: var(--bg-tertiary);
            border-radius: 10px;
            margin-bottom: 4px;
        }

        .mobile-view-btn {
            flex: 1;
            padding: 9px 4px;
            border: none;
            background: transparent;
            color: var(--text-muted);
            font-size: 0.82rem;
            font-weight: 600;
            border-radius: 8px;
            cursor: pointer;
            transition: all var(--transition-fast);
            font-family: inherit;
        }

        .mobile-view-btn.active {
            background: var(--accent-primary);
            color: #fff;
            box-shadow: 0 2px 8px rgba(99, 102, 241, 0.3);
        }

        .mobile-view-btn:not(.active):hover {
            background: var(--bg-hover);
            color: var(--text-primary);
        }

        .rsvp-btn:hover {
            border-color: var(--border-secondary);
            background: var(--bg-hover);
        }

        .rsvp-btn.going {
            color: var(--accent-green);
            border-color: rgba(74, 222, 128, 0.3);
        }
        .rsvp-btn.going:hover {
            background: rgba(74, 222, 128, 0.1);
            border-color: var(--accent-green);
        }

        .rsvp-btn.maybe {
            color: var(--accent-warning);
            border-color: rgba(250, 204, 21, 0.3);
        }
        .rsvp-btn.maybe:hover {
            background: rgba(250, 204, 21, 0.1);
            border-color: var(--accent-warning);
        }

        .rsvp-btn.declined {
            color: var(--accent-danger);
            border-color: rgba(244, 63, 94, 0.3);
        }
        .rsvp-btn.declined:hover {
            background: rgba(244, 63, 94, 0.1);
            border-color: var(--accent-danger);
        }

        .rsvp-btn.going.active {
            background: rgba(74, 222, 128, 0.25);
            border-color: var(--accent-green);
            color: #4ade80;
            font-weight: 600;
        }

        .rsvp-btn.maybe.active {
            background: rgba(250, 204, 21, 0.25);
            border-color: var(--accent-warning);
            color: #fbbf24;
            font-weight: 600;
        }

        .rsvp-btn.declined.active {
            background: rgba(244, 63, 94, 0.25);
            border-color: var(--accent-danger);
            color: #fb7185;
            font-weight: 600;
        }

        .rsvp-btn span {
            display: block;
            font-size: 1.2rem;
            margin-bottom: 2px;
        }

        /* ========== Invite/Social Buttons ========== */
        .invite-section {
            margin-top: var(--spacing-lg);
            padding-top: var(--spacing-md);
            border-top: 1px solid var(--border-primary);
        }

        .invite-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        .invite-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 8px 14px;
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-full);
            font-size: 0.8rem;
            font-weight: 500;
            font-family: inherit;
            cursor: pointer;
            transition: all 0.2s ease;
            text-decoration: none;
            background: var(--bg-secondary);
            color: var(--text-secondary);
        }

        .invite-btn svg {
            width: 16px;
            height: 16px;
            fill: currentColor;
            flex-shrink: 0;
        }

        .invite-btn.btn-x {
            border-color: rgba(255, 255, 255, 0.2);
            color: #fff;
        }
        .invite-btn.btn-x svg {
            fill: #fff;
        }
        .invite-btn.btn-x:hover {
            background: rgba(255, 255, 255, 0.1);
            border-color: rgba(255, 255, 255, 0.4);
        }

        .invite-btn.btn-type-1 {
            border-color: rgba(59, 130, 246, 0.4);
            color: #60a5fa;
        }
        .invite-btn.btn-type-1 svg {
            fill: #60a5fa;
        }
        .invite-btn.btn-type-1:hover {
            background: rgba(59, 130, 246, 0.15);
            border-color: rgba(59, 130, 246, 0.6);
        }

        .invite-btn.btn-type-2 {
            border-color: rgba(56, 189, 248, 0.4);
            color: #38bdf8;
        }
        .invite-btn.btn-type-2 svg {
            fill: #38bdf8;
        }
        .invite-btn.btn-type-2:hover {
            background: rgba(56, 189, 248, 0.15);
            border-color: rgba(56, 189, 248, 0.6);
        }

        .invite-btn.btn-dc {
            border-color: rgba(129, 140, 248, 0.4);
            color: #a5b4fc;
        }
        .invite-btn.btn-dc svg {
            fill: #a5b4fc;
        }
        .invite-btn.btn-dc:hover {
            background: rgba(129, 140, 248, 0.15);
            border-color: rgba(129, 140, 248, 0.6);
        }

        .invite-btn.btn-cp {
            border-color: var(--border-primary);
            color: var(--text-primary);
        }
        .invite-btn.btn-cp:hover {
            background: var(--bg-hover);
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
        }
        .invite-btn.btn-cp svg {
            fill: currentColor;
        }
        .invite-btn.btn-cp.copied {
            background: rgba(74, 222, 128, 0.15);
            border-color: rgba(74, 222, 128, 0.5);
            color: #4ade80;
        }

        .invite-btn.btn-native {
            border-color: rgba(168, 85, 247, 0.4);
            color: #c084fc;
            background: var(--bg-secondary);
        }
        .invite-btn.btn-native svg {
            fill: #c084fc;
        }
        .invite-btn.btn-native:hover {
            background: rgba(168, 85, 247, 0.15);
            border-color: rgba(168, 85, 247, 0.6);
        }

        /* ========== Attendees List ========== */
        .attendee-count-badge {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            min-width: 22px;
            height: 22px;
            padding: 0 6px;
            background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-cyan) 100%);
            border-radius: var(--radius-full);
            font-size: 0.78rem;
            font-weight: 700;
            color: #fff;
        }

        .attendee-group {
            margin-bottom: var(--spacing-sm);
        }

        .attendee-group:last-child {
            margin-bottom: 0;
        }

        .attendee-group-header {
            display: flex;
            align-items: center;
            gap: 6px;
            margin-bottom: 6px;
            font-size: 0.78rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .attendee-group-header.going { color: var(--accent-green); }
        .attendee-group-header.maybe { color: var(--accent-warning); }
        .attendee-group-header.declined { color: var(--accent-danger); }

        .attendee-group-dot {
            width: 8px;
            height: 8px;
            border-radius: 50%;
            flex-shrink: 0;
        }

        .attendee-group-dot.going { background: var(--accent-green); }
        .attendee-group-dot.maybe { background: var(--accent-warning); }
        .attendee-group-dot.declined { background: var(--accent-danger); }

        .attendee-names {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .attendee-chip {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 5px 10px;
            background: var(--bg-secondary);
            border-radius: var(--radius-full);
            font-size: 0.82rem;
            font-weight: 500;
            color: var(--text-primary);
            border: 1px solid var(--border-primary);
        }

        .attendee-chip.going {
            background: rgba(74, 222, 128, 0.1);
            border-color: rgba(74, 222, 128, 0.3);
        }

        .attendee-chip.maybe {
            background: rgba(250, 204, 21, 0.1);
            border-color: rgba(250, 204, 21, 0.3);
        }

        .attendee-chip.declined {
            background: rgba(244, 63, 94, 0.1);
            border-color: rgba(244, 63, 94, 0.3);
        }

        .view-location-card {
            background: linear-gradient(135deg, rgba(74, 222, 128, 0.08) 0%, rgba(6, 182, 212, 0.05) 100%);
            border-color: rgba(74, 222, 128, 0.2);
        }

        /* ========== Toast Notifications ========== */
        .toast-container {
            position: fixed;
            bottom: var(--spacing-lg);
            right: var(--spacing-lg);
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            z-index: 99999;
        }

        .toast {
            padding: var(--spacing-md) var(--spacing-lg);
            background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
            border: 1px solid var(--border-secondary);
            border-radius: var(--radius-md);
            box-shadow: var(--shadow-lg);
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            animation: slideIn 0.3s ease;
            font-weight: 500;
            transition: opacity 0.3s ease, transform 0.3s ease;
        }

        .toast.success { 
            border-left: 4px solid var(--accent-primary); 
            box-shadow: var(--shadow-lg), -4px 0 20px var(--accent-primary-glow);
        }
        .toast.error { 
            border-left: 4px solid var(--accent-danger); 
            box-shadow: var(--shadow-lg), -4px 0 20px rgba(244, 63, 94, 0.3);
        }
        .toast.warning { 
            border-left: 4px solid var(--accent-warning); 
            box-shadow: var(--shadow-lg), -4px 0 20px rgba(251, 191, 36, 0.3);
        }
        .toast.info { 
            border-left: 4px solid var(--accent-secondary); 
            box-shadow: var(--shadow-lg), -4px 0 20px var(--accent-secondary-glow);
        }

        @keyframes slideIn {
            from { transform: translateX(100%); opacity: 0; }
            to { transform: translateX(0); opacity: 1; }
        }

        /* ========== Settings Modal ========== */
        .settings-tabs {
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
            margin-bottom: var(--spacing-lg);
            border-bottom: none;
            padding: 3px;
            background: rgba(18, 18, 26, 0.5);
            border-radius: 8px;
            border: 1px solid rgba(100, 100, 140, 0.15);
        }

        .settings-tab {
            padding: var(--spacing-sm) var(--spacing-md);
            background: transparent;
            border: 1px solid transparent;
            color: var(--text-secondary);
            cursor: pointer;
            border-radius: 6px;
            transition: all var(--transition-fast);
            font-size: 0.82rem;
            font-weight: 600;
        }

        .settings-tab:hover {
            color: var(--text-primary);
            background: rgba(100, 100, 140, 0.08);
            border-color: rgba(100, 100, 140, 0.2);
        }

        .settings-tab.active {
            color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.1);
            border-color: rgba(168, 85, 247, 0.25);
            border-left: 3px solid var(--accent-primary);
        }

        .settings-panel {
            display: none;
        }

        .settings-panel.active {
            display: block;
        }

        /* Admin Events Management */
        .admin-events-filters {
            display: flex;
            gap: 4px;
        }
        .admin-filter-btn {
            padding: 4px 12px;
            border-radius: 8px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            font-size: 0.78rem;
            cursor: pointer;
            transition: all var(--transition-fast);
            white-space: nowrap;
        }
        .admin-filter-btn:hover {
            border-color: var(--accent-primary);
            color: var(--text-primary);
        }
        .admin-filter-btn.active {
            border-color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.15);
            color: var(--accent-primary);
            font-weight: 600;
        }
        .admin-events-list {
            display: flex;
            flex-direction: column;
            gap: 6px;
            max-height: 420px;
            overflow-y: auto;
            scrollbar-width: thin;
            scrollbar-color: var(--border-secondary) transparent;
        }
        .admin-event-row {
            display: grid;
            grid-template-columns: 8px 1fr auto;
            gap: 10px;
            align-items: center;
            padding: 10px 12px;
            border-radius: 10px;
            border: 1px solid var(--border-primary);
            background: var(--bg-secondary);
            transition: all var(--transition-fast);
            cursor: default;
        }
        .admin-event-row:hover {
            border-color: var(--border-secondary);
            background: var(--bg-tertiary);
        }
        .admin-event-color {
            width: 8px;
            height: 36px;
            border-radius: 4px;
            flex-shrink: 0;
        }
        .admin-event-info {
            min-width: 0;
        }
        .admin-event-title {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-primary);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
        }
        .admin-event-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-top: 3px;
            font-size: 0.73rem;
            color: var(--text-muted);
        }
        .admin-event-meta span {
            display: inline-flex;
            align-items: center;
            gap: 3px;
        }
        .admin-event-badge {
            display: inline-flex;
            align-items: center;
            padding: 1px 7px;
            border-radius: 5px;
            font-size: 0.68rem;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: 0.3px;
        }
        .admin-event-badge.private {
            background: rgba(239, 68, 68, 0.15);
            color: #ef4444;
        }
        .admin-event-badge.past {
            background: rgba(107, 114, 128, 0.15);
            color: #9ca3af;
        }
        .admin-event-actions {
            display: flex;
            gap: 4px;
            flex-shrink: 0;
        }
        .admin-event-actions button {
            padding: 5px 10px;
            border-radius: 6px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            font-size: 0.75rem;
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        .admin-event-actions button:hover {
            border-color: var(--accent-primary);
            color: var(--accent-primary);
        }
        .admin-event-actions .btn-danger-sm:hover {
            border-color: #ef4444;
            color: #ef4444;
            background: rgba(239, 68, 68, 0.1);
        }
        .admin-events-pagination {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: 8px;
            margin-top: var(--spacing-sm);
            font-size: 0.8rem;
            color: var(--text-secondary);
        }
        .admin-events-pagination button {
            padding: 4px 12px;
            border-radius: 6px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            font-size: 0.78rem;
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        .admin-events-pagination button:hover:not(:disabled) {
            border-color: var(--accent-primary);
            color: var(--accent-primary);
        }
        .admin-events-pagination button:disabled {
            opacity: 0.4;
            cursor: not-allowed;
        }
        .admin-event-count {
            font-size: 0.75rem;
            color: var(--text-muted);
            text-align: center;
            padding: 8px;
        }
        .admin-mass-delete-bar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            padding: 10px 14px;
            border-radius: 10px;
            border: 1px solid rgba(239, 68, 68, 0.3);
            background: rgba(239, 68, 68, 0.08);
            margin-bottom: var(--spacing-sm);
            font-size: 0.8rem;
            color: var(--text-secondary);
            flex-wrap: wrap;
        }
        .admin-mass-delete-bar .btn-danger {
            white-space: nowrap;
            font-size: 0.75rem;
            padding: 5px 14px;
        }
        .admin-user-filter {
            border-radius: 8px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            color: var(--text-secondary);
            cursor: pointer;
        }

        /* Webhook List */
        .webhook-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
        }

        .webhook-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md) var(--spacing-lg);
            background: linear-gradient(135deg, var(--bg-tertiary) 0%, rgba(18, 18, 26, 0.95) 100%);
            border-radius: var(--radius-lg);
            border: 1px solid var(--border-secondary);
            transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
        }

        .webhook-item:hover {
            border-color: rgba(168, 85, 247, 0.35);
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3), 0 0 15px rgba(168, 85, 247, 0.08);
        }

        .webhook-item.disabled {
            opacity: 0.45;
            filter: grayscale(0.3);
        }

        .webhook-info {
            flex: 1;
            min-width: 0;
        }

        .webhook-name {
            font-weight: 700;
            font-size: 0.95rem;
            margin-bottom: 6px;
            color: var(--text-primary);
        }

        .webhook-meta {
            font-size: 0.75rem;
            color: var(--text-muted);
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            align-items: center;
        }

        .webhook-pill {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 3px 10px;
            border-radius: var(--radius-full);
            font-size: 0.7rem;
            font-weight: 600;
            letter-spacing: 0.3px;
            text-transform: uppercase;
            border: 1px solid rgba(61, 61, 92, 0.5);
            background: rgba(18, 18, 26, 0.7);
            color: var(--text-secondary);
        }

        .webhook-pill.pill-trigger {
            background: rgba(34, 211, 238, 0.08);
            border-color: rgba(34, 211, 238, 0.25);
            color: var(--accent-cyan);
        }

        .webhook-pill.pill-mention {
            background: rgba(168, 85, 247, 0.1);
            border-color: rgba(168, 85, 247, 0.3);
            color: var(--accent-primary);
        }

        .webhook-pill.pill-template {
            background: rgba(52, 211, 153, 0.08);
            border-color: rgba(52, 211, 153, 0.25);
            color: #34d399;
        }

        .webhook-pill.pill-last {
            background: rgba(144, 144, 184, 0.06);
            border-color: rgba(144, 144, 184, 0.2);
            color: var(--text-muted);
            font-size: 0.65rem;
            text-transform: none;
        }

        .webhook-pill.pill-cooldown {
            background: rgba(251, 191, 36, 0.08);
            border-color: rgba(251, 191, 36, 0.25);
            color: #fbbf24;
        }

        /* Webhook form section layout */
        .wh-section {
            padding: var(--spacing-md);
            margin-bottom: var(--spacing-md);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
            background: rgba(255, 255, 255, 0.02);
        }

        .wh-section-title {
            font-size: 0.9rem;
            font-weight: 700;
            color: var(--text-primary);
            margin-bottom: var(--spacing-sm);
            letter-spacing: 0.02em;
        }

        /* Toggle pill labels for triggers / reminder times */
        .wh-trigger-pill {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 14px;
            border-radius: 999px;
            border: 1px solid var(--border-secondary);
            background: rgba(255, 255, 255, 0.03);
            color: var(--text-secondary);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all 0.2s ease;
            user-select: none;
        }

        .wh-trigger-pill:hover {
            border-color: var(--accent-primary);
            background: rgba(var(--accent-primary-rgb, 99, 102, 241), 0.08);
        }

        .wh-trigger-pill input[type="checkbox"] {
            display: none;
        }

        .wh-trigger-pill input[type="radio"] {
            display: none;
        }

        .wh-trigger-pill:has(input:checked),
        .wh-trigger-pill.active {
            background: rgba(var(--accent-primary-rgb, 99, 102, 241), 0.15);
            border-color: var(--accent-primary);
            color: var(--text-primary);
        }

        .trigger-msg-row {
            margin-bottom: 8px;
        }
        .trigger-msg-row:last-child {
            margin-bottom: 0;
        }

        /* Webhook Wizard Steps */
        .wh-wizard-steps {
            display: flex;
            gap: 0;
            margin-bottom: var(--spacing-lg);
            position: relative;
        }
        .wh-wizard-step {
            flex: 1;
            text-align: center;
            position: relative;
            padding: 10px 4px 6px;
            font-size: 0.75rem;
            color: var(--text-muted);
            cursor: pointer;
            transition: color 0.2s;
        }
        .wh-wizard-step::before {
            content: attr(data-num);
            display: block;
            width: 28px; height: 28px;
            margin: 0 auto 4px;
            border-radius: 50%;
            background: var(--bg-tertiary);
            border: 2px solid var(--border-secondary);
            line-height: 24px;
            font-weight: 700;
            font-size: 0.8rem;
            transition: all 0.2s;
        }
        .wh-wizard-step.active {
            color: var(--text-primary);
        }
        .wh-wizard-step.active::before {
            border-color: var(--accent-primary);
            background: rgba(var(--accent-primary-rgb, 99, 102, 241), 0.2);
            color: var(--accent-primary);
        }
        .wh-wizard-step.completed::before {
            content: '✓';
            border-color: #22c55e;
            background: rgba(34, 197, 94, 0.2);
            color: #22c55e;
        }
        .wh-wizard-step + .wh-wizard-step::after {
            content: '';
            position: absolute;
            top: 24px;
            left: -50%;
            width: 100%;
            height: 2px;
            background: var(--border-secondary);
            z-index: -1;
        }
        .wh-wizard-step.completed + .wh-wizard-step::after,
        .wh-wizard-step.active + .wh-wizard-step::after {
            background: linear-gradient(90deg, #22c55e, var(--border-secondary));
        }
        .wh-wizard-page { display: none; }
        .wh-wizard-page.active { display: block; }
        .wh-wizard-nav {
            display: flex;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-lg);
            padding-top: var(--spacing-md);
            border-top: 1px solid var(--border-primary);
        }
        .wh-wizard-copy-select {
            margin-bottom: var(--spacing-md);
            padding: var(--spacing-sm);
            border-radius: var(--radius-sm);
            border: 1px dashed rgba(34, 197, 94, 0.3);
            background: rgba(34, 197, 94, 0.03);
        }

        .webhook-actions {
            display: flex;
            gap: var(--spacing-xs);
            align-items: center;
        }

        .mention-role-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 8px;
            min-height: 0;
        }

        .mention-role-chips:empty {
            margin-bottom: 0;
        }

        /* Cron Job List */
        .cron-job-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
        }

        .cron-job-info {
            flex: 1;
            min-width: 0;
        }

        .cron-job-name {
            font-weight: 600;
            margin-bottom: 4px;
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .cron-job-desc {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin-bottom: 4px;
        }

        .cron-job-meta {
            font-size: 0.8rem;
            color: var(--text-muted);
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-sm);
        }

        .cron-job-meta span {
            display: inline-flex;
            align-items: center;
            gap: 4px;
        }

        .cron-status-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 2px 8px;
            border-radius: var(--radius-full);
            font-size: 0.7rem;
            font-weight: 600;
            text-transform: uppercase;
        }

        .cron-status-badge.active {
            background: rgba(74, 222, 128, 0.2);
            color: var(--accent-green);
        }

        .cron-status-badge.pending {
            background: rgba(250, 204, 21, 0.2);
            color: var(--accent-warning);
        }

        .cron-status-badge.overdue {
            background: rgba(244, 63, 94, 0.2);
            color: var(--accent-danger);
        }

        .cron-status-badge.disabled {
            background: var(--bg-hover);
            color: var(--text-muted);
        }

        .cron-job-actions {
            display: flex;
            gap: var(--spacing-xs);
            flex-shrink: 0;
        }

        /* ========== Cron Hero Banner ========== */
        .cron-hero-banner {
            display: flex;
            align-items: center;
            gap: var(--spacing-lg);
            padding: var(--spacing-lg);
            background: linear-gradient(135deg, var(--bg-tertiary) 0%, rgba(42, 42, 64, 0.6) 100%);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-lg);
            margin-bottom: var(--spacing-lg);
            position: relative;
            overflow: hidden;
        }

        .cron-hero-banner::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 3px;
            background: var(--gradient-aurora);
            opacity: 0.7;
        }

        .cron-hero-icon {
            width: 48px;
            height: 48px;
            border-radius: 50%;
            background: var(--bg-hover);
            border: 2px solid var(--border-secondary);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.5rem;
            flex-shrink: 0;
        }

        .cron-hero-icon.status-ok {
            border-color: var(--accent-green);
            background: rgba(74, 222, 128, 0.1);
            box-shadow: 0 0 20px rgba(74, 222, 128, 0.15);
        }

        .cron-hero-icon.status-warning {
            border-color: var(--accent-warning);
            background: rgba(250, 204, 21, 0.1);
            box-shadow: 0 0 20px rgba(250, 204, 21, 0.15);
        }

        .cron-hero-icon.status-error {
            border-color: var(--accent-danger);
            background: rgba(244, 63, 94, 0.1);
            box-shadow: 0 0 20px rgba(244, 63, 94, 0.15);
        }

        .cron-hero-spinner {
            width: 20px;
            height: 20px;
            border: 2px solid var(--border-secondary);
            border-top-color: var(--accent-primary);
            border-radius: 50%;
            animation: spin 1s linear infinite;
        }

        @keyframes spin { to { transform: rotate(360deg); } }

        .cron-hero-content {
            flex: 1;
            min-width: 0;
        }

        .cron-hero-title {
            font-size: 1rem;
            font-weight: 700;
            margin: 0 0 4px;
            color: var(--text-primary);
        }

        .cron-hero-details {
            font-size: 0.85rem;
            color: var(--text-muted);
            margin: 0;
        }

        .cron-hero-actions {
            display: flex;
            gap: var(--spacing-sm);
            flex-shrink: 0;
        }

        /* ========== Setup Guide ========== */
        .setup-guide {
            background: var(--bg-secondary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-lg);
            margin-bottom: var(--spacing-lg);
            overflow: hidden;
        }

        .setup-guide-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md) var(--spacing-lg);
            cursor: pointer;
            transition: background var(--transition-fast);
            user-select: none;
        }

        .setup-guide-header:hover {
            background: var(--bg-hover);
        }

        .setup-guide-header-left {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
        }

        .setup-guide-icon {
            font-size: 1.5rem;
        }

        .setup-guide-title {
            font-size: 0.95rem;
            font-weight: 700;
            margin: 0;
            color: var(--text-primary);
        }

        .setup-guide-subtitle {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin: 2px 0 0;
        }

        .setup-guide-toggle {
            font-size: 1.2rem;
            color: var(--text-muted);
            transition: transform var(--transition-fast);
        }

        .setup-guide-toggle.collapsed {
            transform: rotate(-90deg);
        }

        .setup-guide-body {
            padding: 0 var(--spacing-lg) var(--spacing-lg);
            border-top: 1px solid var(--border-primary);
        }

        .setup-guide-body.collapsed {
            display: none;
        }

        /* Setup Steps */
        .setup-step {
            display: flex;
            gap: var(--spacing-md);
            padding: var(--spacing-md) 0;
            border-bottom: 1px solid rgba(42, 42, 64, 0.5);
        }

        .setup-step:last-of-type {
            border-bottom: none;
        }

        .setup-step-number {
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background: var(--gradient-primary);
            color: white;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 800;
            font-size: 0.85rem;
            flex-shrink: 0;
            box-shadow: 0 4px 12px var(--accent-primary-glow);
        }

        .setup-step-content {
            flex: 1;
            min-width: 0;
        }

        .setup-step-title {
            font-size: 0.95rem;
            font-weight: 700;
            margin: 0 0 4px;
            color: var(--text-primary);
        }

        .setup-step-desc {
            font-size: 0.85rem;
            color: var(--text-secondary);
            margin: 0 0 var(--spacing-sm);
            line-height: 1.5;
        }

        .setup-step-hint {
            font-size: 0.8rem;
            color: var(--text-muted);
            margin: var(--spacing-sm) 0 0;
            line-height: 1.5;
        }

        .setup-code-block {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            background: var(--bg-primary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-sm);
            padding: var(--spacing-sm) var(--spacing-md);
            position: relative;
        }

        .setup-code-block code {
            flex: 1;
            font-size: 0.82rem;
            color: var(--accent-cyan);
            word-break: break-all;
            font-family: 'Fira Code', 'Cascadia Code', 'JetBrains Mono', monospace;
            line-height: 1.5;
        }

        .setup-code-highlight {
            border-color: rgba(168, 85, 247, 0.3);
            background: linear-gradient(135deg, rgba(10, 10, 15, 0.95) 0%, rgba(18, 18, 26, 0.95) 100%);
        }

        .setup-copy-btn {
            background: var(--bg-hover);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-sm);
            padding: 4px 8px;
            cursor: pointer;
            font-size: 0.75rem;
            color: var(--text-muted);
            transition: all var(--transition-fast);
            flex-shrink: 0;
        }

        .setup-copy-btn:hover {
            background: var(--bg-active);
            color: var(--text-primary);
        }

        .setup-step-note {
            margin-top: var(--spacing-sm);
            padding: var(--spacing-sm) var(--spacing-md);
            background: rgba(42, 42, 64, 0.3);
            border-radius: var(--radius-sm);
            border-left: 3px solid var(--accent-primary);
        }

        .setup-note-row {
            display: flex;
            gap: var(--spacing-sm);
            align-items: baseline;
            padding: 3px 0;
            font-size: 0.8rem;
        }

        .setup-note-row code {
            color: var(--accent-cyan);
            font-size: 0.78rem;
        }

        .setup-note-label {
            flex-shrink: 0;
            color: var(--text-secondary);
        }

        .setup-note-value {
            color: var(--text-muted);
        }

        /* Details/Summary collapsible */
        .setup-details {
            margin-top: var(--spacing-sm);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-sm);
            overflow: hidden;
        }

        .setup-details summary {
            padding: var(--spacing-sm) var(--spacing-md);
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-secondary);
            cursor: pointer;
            background: var(--bg-tertiary);
            transition: all var(--transition-fast);
            list-style: none;
        }

        .setup-details summary::-webkit-details-marker { display: none; }
        .setup-details summary::before { content: '▸ '; color: var(--accent-primary); }
        .setup-details[open] summary::before { content: '▾ '; }
        .setup-details[open] summary { border-bottom: 1px solid var(--border-primary); }

        .setup-details summary:hover {
            background: var(--bg-hover);
            color: var(--text-primary);
        }

        .setup-php-paths {
            padding: var(--spacing-md);
            display: flex;
            flex-direction: column;
            gap: 6px;
        }

        .setup-path-item {
            display: flex;
            gap: var(--spacing-sm);
            align-items: center;
            font-size: 0.82rem;
        }

        .setup-path-label {
            color: var(--text-secondary);
            min-width: 160px;
            flex-shrink: 0;
        }

        .setup-path-item code {
            color: var(--accent-cyan);
            background: var(--bg-primary);
            padding: 2px 6px;
            border-radius: 3px;
            font-size: 0.78rem;
        }

        .setup-alt-methods {
            padding: var(--spacing-md);
        }

        .setup-services-grid {
            display: flex;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-md);
            flex-wrap: wrap;
        }

        .setup-service-link {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 14px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-full);
            color: var(--text-secondary);
            font-size: 0.82rem;
            font-weight: 500;
            text-decoration: none;
            transition: all var(--transition-fast);
        }

        .setup-service-link:hover {
            border-color: var(--accent-primary);
            color: var(--text-primary);
            background: var(--bg-hover);
        }

        .setup-service-badge {
            font-size: 0.65rem;
            font-weight: 700;
            text-transform: uppercase;
            background: rgba(74, 222, 128, 0.2);
            color: var(--accent-green);
            padding: 1px 6px;
            border-radius: var(--radius-full);
        }

        /* Cron Section Header */
        .cron-section-header {
            display: flex;
            align-items: baseline;
            justify-content: space-between;
            margin-bottom: var(--spacing-md);
            padding-bottom: var(--spacing-sm);
            border-bottom: 1px solid var(--border-primary);
        }

        .cron-section-header h4 {
            font-size: 1rem;
            font-weight: 700;
            color: var(--text-primary);
            margin: 0;
        }

        /* Cron Empty State */
        .cron-empty-state {
            text-align: center;
            padding: var(--spacing-xl) var(--spacing-lg);
            background: var(--bg-tertiary);
            border: 2px dashed var(--border-primary);
            border-radius: var(--radius-lg);
        }

        .cron-empty-state .cron-empty-icon {
            font-size: 2.5rem;
            margin-bottom: var(--spacing-sm);
            opacity: 0.6;
        }

        .cron-empty-state h4 {
            font-size: 1rem;
            font-weight: 700;
            color: var(--text-secondary);
            margin: 0 0 var(--spacing-xs);
        }

        .cron-empty-state p {
            font-size: 0.85rem;
            color: var(--text-muted);
            margin: 0;
            max-width: 320px;
            margin: 0 auto;
        }

        /* Settings Form Card */
        .settings-form-card {
            margin-top: var(--spacing-lg);
            padding: var(--spacing-lg);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-lg);
        }

        .settings-form-title {
            font-size: 1rem;
            font-weight: 700;
            margin: 0 0 var(--spacing-lg);
            color: var(--text-primary);
        }

        .settings-form-actions {
            display: flex;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-lg);
            padding-top: var(--spacing-md);
            border-top: 1px solid var(--border-primary);
        }

        .form-required {
            color: var(--accent-danger);
        }

        .form-hint {
            display: block;
            font-size: 0.75rem;
            color: var(--text-muted);
            margin-top: 4px;
        }

        kbd {
            display: inline-block;
            padding: 2px 6px;
            font-size: 0.78rem;
            font-family: 'Fira Code', 'Cascadia Code', monospace;
            background: var(--bg-primary);
            border: 1px solid var(--border-secondary);
            border-radius: 4px;
            box-shadow: 0 1px 0 var(--border-primary);
            color: var(--text-secondary);
        }

        /* ========== Cron Job Modal ========== */
        .cron-modal-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: rgba(0, 0, 0, 0.8);
            z-index: 10000;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: var(--spacing-lg);
        }

        @keyframes cronModalSlideUp {
            from { opacity: 0; transform: translateY(30px) scale(0.97); }
            to { opacity: 1; transform: translateY(0) scale(1); }
        }

        .cron-modal {
            background: var(--bg-secondary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-xl);
            width: 100%;
            max-width: 580px;
            max-height: 85vh;
            display: flex;
            flex-direction: column;
            box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(168, 85, 247, 0.1);
            animation: cronModalSlideUp 0.3s ease;
        }

        .cron-modal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-lg) var(--spacing-xl);
            border-bottom: 1px solid var(--border-primary);
            background: linear-gradient(135deg, rgba(168, 85, 247, 0.08) 0%, rgba(6, 182, 212, 0.04) 100%);
            border-radius: var(--radius-xl) var(--radius-xl) 0 0;
        }

        .cron-modal-header-left {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
        }

        .cron-modal-icon {
            font-size: 1.6rem;
            width: 44px;
            height: 44px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(168, 85, 247, 0.15);
            border-radius: var(--radius-md);
            border: 1px solid rgba(168, 85, 247, 0.2);
        }

        .cron-modal-title {
            font-size: 1.1rem;
            font-weight: 800;
            color: var(--text-primary);
            margin: 0;
        }

        .cron-modal-subtitle {
            font-size: 0.78rem;
            color: var(--text-muted);
            margin: 2px 0 0;
        }

        .cron-modal-close {
            width: 36px;
            height: 36px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            color: var(--text-muted);
            border-radius: var(--radius-md);
            font-size: 1.3rem;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s ease;
        }

        .cron-modal-close:hover {
            background: rgba(244, 63, 94, 0.15);
            color: var(--accent-danger);
            border-color: rgba(244, 63, 94, 0.3);
        }

        .cron-modal-body {
            padding: var(--spacing-lg) var(--spacing-xl);
            overflow-y: auto;
            flex: 1;
        }

        .cron-modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: var(--spacing-sm);
            padding: var(--spacing-md) var(--spacing-xl);
            border-top: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            border-radius: 0 0 var(--radius-xl) var(--radius-xl);
        }

        /* Form Sections */
        .cron-form-section {
            margin-bottom: var(--spacing-lg);
        }

        .cron-form-section-header {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-md);
        }

        .cron-form-section-num {
            width: 26px;
            height: 26px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: linear-gradient(135deg, var(--accent-purple), var(--accent-cyan));
            color: #fff;
            font-size: 0.75rem;
            font-weight: 800;
            border-radius: 50%;
            flex-shrink: 0;
        }

        .cron-form-section-label {
            font-size: 0.92rem;
            font-weight: 700;
            color: var(--text-primary);
        }

        /* Type Selection Cards */
        .cron-type-cards {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }

        .cron-type-card {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all 0.2s ease;
            position: relative;
        }

        .cron-type-card:hover {
            border-color: rgba(168, 85, 247, 0.4);
            background: rgba(168, 85, 247, 0.06);
        }

        .cron-type-card:has(input:checked) {
            border-color: var(--accent-purple);
            background: rgba(168, 85, 247, 0.1);
            box-shadow: 0 0 0 1px rgba(168, 85, 247, 0.2), 0 4px 16px rgba(168, 85, 247, 0.1);
        }

        .cron-type-card input[type="radio"] {
            display: none;
        }

        .cron-type-card-icon {
            font-size: 1.5rem;
            width: 42px;
            height: 42px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(168, 85, 247, 0.1);
            border-radius: var(--radius-md);
            flex-shrink: 0;
        }

        .cron-type-card-info {
            flex: 1;
        }

        .cron-type-card-info strong {
            display: block;
            font-size: 0.88rem;
            color: var(--text-primary);
            margin-bottom: 2px;
        }

        .cron-type-card-info span {
            font-size: 0.76rem;
            color: var(--text-muted);
        }

        .cron-type-badge {
            font-size: 0.65rem;
            font-weight: 700;
            padding: 3px 8px;
            border-radius: var(--radius-full);
            letter-spacing: 0.5px;
            text-transform: uppercase;
            white-space: nowrap;
        }

        .cron-type-badge-recommended {
            background: rgba(16, 185, 129, 0.15);
            color: var(--accent-green);
            border: 1px solid rgba(16, 185, 129, 0.3);
        }

        .cron-type-badge-deprecated {
            background: rgba(245, 158, 11, 0.12);
            color: var(--accent-warning);
            border: 1px solid rgba(245, 158, 11, 0.3);
        }

        /* Type Info Panel */
        .cron-type-info-panel {
            margin-bottom: var(--spacing-lg);
            padding: var(--spacing-md);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
            background: rgba(168, 85, 247, 0.06);
        }

        /* Form Grid */
        .cron-form-grid {
            display: grid;
            gap: var(--spacing-md);
        }

        /* Schedule Options */
        .cron-schedule-options {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 6px;
        }

        .cron-schedule-option {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 10px 6px;
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all 0.15s ease;
            text-align: center;
            min-height: 52px;
        }

        .cron-schedule-option:hover {
            border-color: rgba(6, 182, 212, 0.4);
        }

        .cron-schedule-option.selected,
        .cron-schedule-option:has(input:checked) {
            border-color: var(--accent-cyan);
            background: rgba(6, 182, 212, 0.1);
            box-shadow: 0 0 0 1px rgba(6, 182, 212, 0.2);
        }

        .cron-schedule-option input[type="radio"] {
            display: none;
        }

        .cron-schedule-freq {
            font-size: 0.78rem;
            font-weight: 700;
            color: var(--text-primary);
        }

        .cron-schedule-note {
            font-size: 0.65rem;
            color: var(--accent-green);
            margin-top: 2px;
        }

        .cron-enabled-toggle {
            margin-top: var(--spacing-md);
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
        }

        /* Webhook Cron Notice */
        .webhook-cron-notice {
            display: flex;
            gap: var(--spacing-md);
            align-items: flex-start;
            padding: var(--spacing-md);
            background: linear-gradient(135deg, rgba(6, 182, 212, 0.08) 0%, rgba(168, 85, 247, 0.05) 100%);
            border: 1px solid rgba(6, 182, 212, 0.2);
            border-radius: var(--radius-md);
            margin-bottom: var(--spacing-md);
        }

        .webhook-cron-notice-icon {
            font-size: 1.3rem;
            flex-shrink: 0;
            margin-top: 2px;
        }

        .webhook-cron-notice-content {
            flex: 1;
        }

        .webhook-cron-notice-content strong {
            display: block;
            font-size: 0.9rem;
            color: var(--text-primary);
            margin-bottom: 4px;
        }

        .webhook-cron-notice-content p {
            font-size: 0.82rem;
            color: var(--text-muted);
            margin: 0;
            line-height: 1.5;
        }

        /* Enhanced Cron Job Items */
        .cron-job-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
            gap: var(--spacing-md);
            transition: all var(--transition-fast);
        }

        .cron-job-item:hover {
            border-color: var(--border-secondary);
            box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
        }

        .cron-job-item.disabled {
            opacity: 0.55;
        }

        .cron-job-item .cron-job-name {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            font-weight: 700;
            font-size: 0.95rem;
            margin-bottom: 4px;
        }

        .cron-job-item .cron-job-desc {
            font-size: 0.82rem;
            color: var(--text-secondary);
            margin-bottom: 6px;
            line-height: 1.4;
        }

        .cron-job-item .cron-job-meta {
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-sm);
            font-size: 0.78rem;
            color: var(--text-muted);
        }

        .cron-job-meta-tag {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 2px 8px;
            background: var(--bg-hover);
            border-radius: var(--radius-full);
            font-size: 0.75rem;
        }

        .cron-job-actions .btn {
            font-size: 0.78rem;
        }

        /* User List */
        .user-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
        }

        /* Category Management List */
        .category-manage-list {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
        }

        .category-manage-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
            transition: all var(--transition-fast);
        }

        .category-manage-item:hover {
            border-color: var(--border-secondary);
        }

        .category-info {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            flex: 1;
        }

        .category-color-preview {
            width: 12px;
            height: 36px;
            border-radius: 4px;
            flex-shrink: 0;
        }

        .category-details {
            flex: 1;
        }

        .category-title {
            font-weight: 600;
            margin-bottom: 4px;
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .category-roles {
            font-size: 0.8rem;
            color: var(--text-muted);
        }

        .category-roles span {
            display: inline-block;
            padding: 1px 6px;
            background: var(--bg-hover);
            border-radius: 4px;
            margin-right: 4px;
            font-size: 0.75rem;
        }

        .category-actions {
            display: flex;
            gap: var(--spacing-xs);
        }

        /* Subcategory chips in wizard */
        .subcategory-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-top: var(--spacing-sm);
            padding: var(--spacing-sm) 0;
        }
        .subcategory-chip {
            display: inline-flex;
            align-items: center;
            gap: 5px;
            padding: 6px 14px;
            border-radius: var(--radius-full);
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all 0.2s ease;
            color: var(--text-secondary);
        }
        .subcategory-chip:hover {
            border-color: rgba(168, 85, 247, 0.5);
            color: var(--text-primary);
            background: rgba(168, 85, 247, 0.06);
            transform: translateY(-1px);
        }
        .subcategory-chip.selected {
            border-color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.15);
            color: var(--accent-primary);
            font-weight: 600;
            box-shadow: 0 0 10px rgba(168, 85, 247, 0.15);
        }
        .subcategory-chip .sub-icon {
            font-size: 0.95rem;
        }
        .subcategory-chip .sub-arrow {
            font-size: 1rem;
            opacity: 0.5;
            margin-left: 2px;
        }
        /* A–Z / Popular group headers inside the subcategory flex grid */
        .subcat-group-label {
            width: 100%;
            font-size: 0.68rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.1em;
            color: var(--text-muted);
            padding: 6px 2px 3px;
            margin-top: 4px;
            border-bottom: 1px solid var(--border-primary);
        }
        .subcat-group-label:first-child { margin-top: 0; padding-top: 0; }
        .subcategory-search-input {
            width: 100%;
            padding: 6px 10px;
            margin-bottom: 6px;
            border: 1px solid var(--border-primary);
            border-radius: 6px;
            background: var(--bg-secondary);
            color: var(--text-primary);
            font-size: 0.82rem;
        }
        .subcategory-search-input::placeholder { color: var(--text-muted); }

        /* Template Card Selector (DVD-cover style) */
        .template-selector {
            margin-bottom: var(--spacing-lg);
        }
        /* Quick Start Choice Panel */
        .qs-choice-panel {
            text-align: center;
            padding: 8px 0 4px;
        }
        .qs-choice-title {
            font-size: 0.9rem;
            font-weight: 700;
            color: var(--text-secondary);
            margin-bottom: 10px;
        }
        .qs-choice-buttons {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 10px;
        }
        .qs-choice-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            padding: 16px 12px;
            border-radius: var(--radius-md);
            border: 2px solid var(--border-primary);
            background: var(--bg-secondary);
            cursor: pointer;
            transition: all 0.2s ease;
        }
        .qs-choice-btn:hover {
            border-color: var(--accent-primary);
            transform: translateY(-2px);
            box-shadow: 0 6px 16px rgba(0,0,0,0.2);
        }
        .qs-choice-icon {
            font-size: 1.8rem;
            line-height: 1;
        }
        .qs-choice-label {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-primary);
        }
        .qs-choice-desc {
            font-size: 0.78rem;
            color: var(--text-muted);
        }
        /* Template picker panel */
        .qs-panel-header {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 8px;
        }
        .qs-back-btn {
            background: none;
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-sm);
            color: var(--text-secondary);
            font-size: 0.8rem;
            padding: 3px 10px;
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        .qs-back-btn:hover {
            border-color: var(--accent-primary);
            color: var(--accent-primary);
        }
        .qs-panel-title {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-secondary);
        }
        .template-selector-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: var(--spacing-sm);
            padding: 0 2px;
        }
        .template-selector-title {
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-secondary);
        }
        .template-selector-hint {
            font-size: 0.75rem;
            color: var(--text-muted);
        }
        /* Quick Start category/subcategory pill rows */
        .qs-pill-group-label {
            width: 100%;
            font-size: 0.70rem;
            font-weight: 700;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.7px;
            padding: 6px 0 2px;
            margin-top: 2px;
        }
        .qs-row {
            margin-bottom: 8px;
        }
        .qs-section-label {
            font-size: 0.74rem;
            font-weight: 700;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 6px;
            padding-left: 9px;
            border-left: 2px solid var(--accent-primary);
        }
        .qs-pills {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }
        .qs-pill {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 7px 14px;
            border-radius: 10px;
            border: 1.5px solid var(--border-primary);
            background: linear-gradient(135deg, rgba(30, 41, 59, 0.7) 0%, rgba(15, 23, 42, 0.6) 100%);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all 0.2s ease;
            color: var(--text-secondary);
            white-space: nowrap;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
            position: relative;
            overflow: hidden;
        }
        .qs-pill::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 3px;
            background: var(--pill-accent, var(--border-secondary));
            opacity: 0.5;
            transition: opacity 0.2s ease;
        }
        .qs-pill:hover {
            border-color: var(--pill-accent, var(--accent-primary));
            color: var(--text-primary);
            transform: translateY(-2px);
            box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
        }
        .qs-pill:hover::before {
            opacity: 1;
        }
        .qs-pill.active {
            border-color: var(--pill-accent, var(--accent-primary));
            background: linear-gradient(135deg, color-mix(in srgb, var(--pill-accent, var(--accent-primary)) 15%, transparent) 0%, rgba(34, 211, 238, 0.08) 100%);
            color: var(--pill-accent, var(--accent-primary));
            font-weight: 600;
            box-shadow: 0 0 0 1px color-mix(in srgb, var(--pill-accent, var(--accent-primary)) 30%, transparent), 0 4px 16px color-mix(in srgb, var(--pill-accent, var(--accent-primary)) 20%, transparent);
        }
        .qs-pill.active::before {
            background: var(--pill-accent, var(--accent-primary));
            opacity: 1;
        }
        .qs-pill .qs-icon {
            font-size: 1.05rem;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 24px;
            height: 24px;
            border-radius: 6px;
            background: rgba(255, 255, 255, 0.06);
        }
        .qs-pill--all {
            border-style: dashed;
            font-weight: 500;
        }
        .qs-pill--all::before {
            display: none;
        }
        .qs-pill--all.active {
            border-style: solid;
        }
        .template-strip {
            display: flex;
            gap: 10px;
            overflow-x: auto;
            padding: 8px 6px 10px;
            scrollbar-width: thin;
            scrollbar-color: var(--border-secondary) transparent;
            -webkit-overflow-scrolling: touch;
            background: rgba(15, 23, 42, 0.3);
            border-radius: 12px;
            border: 1px solid rgba(255, 255, 255, 0.04);
        }
        .template-strip::-webkit-scrollbar {
            height: 4px;
        }
        .template-strip::-webkit-scrollbar-thumb {
            background: var(--border-secondary);
            border-radius: 4px;
        }
        .tpl-card {
            flex: 0 0 130px;
            display: flex;
            flex-direction: column;
            border-radius: 10px;
            border: 2px solid var(--border-primary);
            background: var(--bg-secondary);
            cursor: pointer;
            transition: all 0.2s ease;
            overflow: hidden;
            position: relative;
        }
        .tpl-card:hover {
            border-color: var(--accent-primary);
            transform: translateY(-2px);
            box-shadow: 0 6px 16px rgba(0,0,0,0.25);
        }
        .tpl-card.active {
            border-color: var(--accent-primary);
            box-shadow: 0 0 0 1px var(--accent-primary), 0 6px 20px rgba(168, 85, 247, 0.3);
        }
        .tpl-card-banner {
            height: 6px;
            width: 100%;
            flex-shrink: 0;
        }
        .tpl-card-body {
            padding: 10px 10px 8px;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            flex: 1;
        }
        .tpl-card-icon {
            font-size: 1.6rem;
            line-height: 1;
        }
        .tpl-card-name {
            font-size: 0.8rem;
            font-weight: 600;
            color: var(--text-primary);
            text-align: center;
            line-height: 1.2;
            word-break: break-word;
        }
        .tpl-card-meta {
            font-size: 0.75rem;
            color: var(--text-muted);
            text-align: center;
            line-height: 1.3;
        }
        .tpl-card-badges {
            display: flex;
            flex-wrap: wrap;
            gap: 4px;
            justify-content: center;
            margin-top: auto;
            padding-top: 6px;
        }
        .tpl-badge {
            display: inline-flex;
            align-items: center;
            gap: 2px;
            font-size: 0.72rem;
            font-weight: 500;
            padding: 2px 7px;
            border-radius: 6px;
            background: rgba(255,255,255,0.06);
            color: var(--text-secondary);
            white-space: nowrap;
        }
        .tpl-card.active .tpl-card-name { color: var(--accent-primary); }
        .tpl-card.active .tpl-badge { background: rgba(168, 85, 247, 0.12); color: var(--accent-primary); }

        /* Custom card variant */
        .tpl-card--custom {
            border-style: dashed;
            justify-content: center;
        }
        .tpl-card--custom .tpl-card-body {
            justify-content: center;
            padding: 16px 10px;
        }
        .tpl-card--custom:hover {
            border-style: solid;
        }
        .tpl-card--custom.active {
            border-style: solid;
        }

        /* Quick Date Buttons */
        .quick-date-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: var(--spacing-md);
        }
        .quick-date-btn {
            padding: 8px 14px;
            border-radius: 16px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all var(--transition-fast);
            color: var(--text-secondary);
            text-align: center;
        }
        .quick-date-btn:hover {
            border-color: var(--accent-primary);
            color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.05);
        }
        .quick-date-btn.selected {
            border-color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.15);
            color: var(--accent-primary);
            font-weight: 500;
        }
        /* Quick Date: sub-label */
        .quick-date-btn .qd-day {
            display: block;
            font-size: 0.8rem;
            font-weight: 600;
        }
        .quick-date-btn .qd-date {
            display: block;
            font-size: 0.73rem;
            opacity: 0.75;
            margin-top: 1px;
        }

        /* Quick Time Buttons */
        .quick-time-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: var(--spacing-sm);
        }
        .quick-time-btn {
            padding: 5px 12px;
            border-radius: 16px;
            border: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
            font-size: 0.8rem;
            cursor: pointer;
            transition: all var(--transition-fast);
            color: var(--text-secondary);
        }
        .quick-time-btn:hover {
            border-color: var(--accent-primary);
            color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.05);
        }
        .quick-time-btn.selected {
            border-color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.15);
            color: var(--accent-primary);
            font-weight: 500;
        }

        .user-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }

        .user-item.disabled {
            opacity: 0.5;
        }

        .user-info {
            flex: 1;
        }

        .user-name {
            font-weight: 600;
            margin-bottom: 4px;
        }

        .user-meta {
            font-size: 0.8rem;
            color: var(--text-muted);
            display: flex;
            gap: var(--spacing-md);
        }

        .user-actions {
            display: flex;
            gap: var(--spacing-xs);
            flex-wrap: wrap;
            justify-content: flex-end;
        }

        .role-badge {
            display: inline-block;
            padding: 2px 8px;
            border-radius: var(--radius-sm);
            font-size: 0.75rem;
            font-weight: 600;
            text-transform: uppercase;
        }

        .role-badge.admin {
            background: rgba(168, 85, 247, 0.25);
            color: var(--accent-primary);
        }

        .role-badge.create {
            background: rgba(6, 182, 212, 0.25);
            color: var(--accent-secondary);
        }

        .role-badge.view {
            background: rgba(148, 163, 184, 0.2);
            color: var(--text-muted);
        }

        /* ========== Event Wizard Styles ========== */
        .wizard-container {
            position: relative;
            display: flex;
            flex-direction: column;
            max-height: 90vh;
        }

        .wizard-container form {
            display: flex;
            flex-direction: column;
            flex: 1;
            min-height: 0;
            overflow-y: auto;
            overflow-x: hidden;
        }

        .wizard-nav {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-lg);
            border-top: 1px solid var(--border-primary);
            background: var(--bg-secondary);
        }

        .wizard-nav-right {
            display: flex;
            gap: var(--spacing-sm);
        }

        .wizard-nav-btn {
            padding: 8px 18px;
            font-size: 0.76rem;
            font-weight: 700;
            letter-spacing: 0.18em;
            text-transform: uppercase;
            border-radius: var(--radius-full);
            border: 1px solid rgba(168, 85, 247, 0.45);
            background: linear-gradient(90deg, rgba(168, 85, 247, 0.28) 0%, rgba(6, 182, 212, 0.18) 100%);
            color: var(--text-primary);
            box-shadow:
                0 8px 16px rgba(0, 0, 0, 0.4),
                inset 0 0 0 1px rgba(255, 255, 255, 0.05);
        }

        .wizard-nav-btn:hover {
            filter: brightness(1.05);
            transform: translateY(-1px);
        }

        .wizard-nav-btn:disabled {
            opacity: 0.5;
            cursor: not-allowed;
            transform: none;
        }

        .wizard-progress {
            display: flex;
            justify-content: center;
            gap: var(--spacing-sm);
            padding: var(--spacing-md) var(--spacing-lg);
            border-bottom: 1px solid var(--border-primary);
            background: var(--bg-tertiary);
        }

        .wizard-step-indicator {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            padding: var(--spacing-xs) var(--spacing-md);
            border-radius: var(--radius-full);
            font-size: 0.8rem;
            color: var(--text-muted);
            background: var(--bg-hover);
            transition: all var(--transition-fast);
            cursor: pointer;
        }

        .wizard-step-indicator:hover {
            color: var(--text-secondary);
        }

        .wizard-step-indicator.active {
            background: var(--accent-primary);
            color: white;
        }

        .wizard-step-indicator.completed {
            background: rgba(16, 185, 129, 0.2);
            color: var(--accent-green);
        }

        .wizard-step-indicator .step-num {
            width: 20px;
            height: 20px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 50%;
            background: var(--bg-primary);
            font-weight: 600;
            font-size: 0.75rem;
        }

        .wizard-step-indicator.active .step-num {
            background: rgba(255, 255, 255, 0.2);
            color: white;
        }

        .wizard-step-indicator.completed .step-num {
            background: var(--accent-green);
            color: white;
        }

        .wizard-steps {
            position: relative;
        }

        .wizard-step {
            display: none;
            padding: var(--spacing-lg);
            animation: wizardFadeIn 0.3s ease;
        }

        .wizard-step.active {
            display: block;
        }

        @keyframes wizardFadeIn {
            from { opacity: 0; transform: translateX(20px); }
            to { opacity: 1; transform: translateX(0); }
        }

        .wizard-step-title {
            font-size: 1.25rem;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: var(--spacing-xs);
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }

        .wizard-step-subtitle {
            color: var(--text-muted);
            font-size: 0.9rem;
            margin-bottom: var(--spacing-lg);
        }

        .wizard-input-large {
            width: 100%;
            padding: var(--spacing-md) var(--spacing-lg);
            font-size: 1.2rem;
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-primary);
            transition: all var(--transition-fast);
        }

        .wizard-input-large:focus {
            outline: none;
            border-color: var(--accent-primary);
            background: var(--bg-primary);
        }

        .wizard-input-large::placeholder {
            color: var(--text-muted);
        }

        .wizard-textarea {
            width: 100%;
            min-height: 100px;
            padding: var(--spacing-md);
            font-size: 1rem;
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-primary);
            resize: vertical;
        }

        .wizard-textarea:focus {
            outline: none;
            border-color: var(--accent-primary);
        }

        .desc-counter {
            margin-top: 6px;
            font-size: 0.72rem;
            color: var(--text-muted);
            text-align: right;
            transition: color 0.2s ease;
        }

        .desc-counter.warn {
            color: #f59e0b;
        }

        .desc-counter.danger {
            color: #ef4444;
            font-weight: 600;
        }

        /* Load Draft Button */
        .btn-load-draft {
            display: inline-flex;
            align-items: center;
            gap: 5px;
            padding: 4px 10px;
            background: rgba(168, 85, 247, 0.1);
            border: 1px solid rgba(168, 85, 247, 0.3);
            border-radius: var(--radius-full);
            color: var(--accent-primary);
            font-size: 0.75rem;
            font-weight: 500;
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .btn-load-draft:hover {
            background: rgba(168, 85, 247, 0.2);
            border-color: rgba(168, 85, 247, 0.5);
        }

        .btn-load-draft svg {
            stroke: currentColor;
        }

        /* Image Upload Area */
        .image-upload-area {
            border: 2px dashed var(--border-primary);
            border-radius: var(--radius-md);
            padding: var(--spacing-md);
            text-align: center;
            cursor: pointer;
            transition: border-color 0.2s, background 0.2s;
            background: var(--bg-tertiary);
            min-height: 80px;
            display: flex;
            align-items: center;
            justify-content: center;
        }
        .image-upload-area:hover,
        .image-upload-area.dragover {
            border-color: var(--accent-primary);
            background: rgba(168, 85, 247, 0.06);
        }
        .image-upload-placeholder {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            color: var(--text-muted);
            font-size: 0.85rem;
        }
        .image-upload-preview {
            position: relative;
            display: inline-block;
            max-width: 100%;
        }
        .image-upload-preview img {
            max-width: 100%;
            max-height: 160px;
            border-radius: var(--radius-sm);
            display: block;
        }
        .image-upload-remove {
            position: absolute;
            top: 6px;
            right: 6px;
            width: 26px;
            height: 26px;
            border-radius: 50%;
            background: rgba(239, 68, 68, 0.85);
            color: #fff;
            border: none;
            cursor: pointer;
            font-size: 0.85rem;
            display: flex;
            align-items: center;
            justify-content: center;
            line-height: 1;
        }
        .image-upload-remove:hover {
            background: rgba(239, 68, 68, 1);
        }

        /* Wizard Timezone Hint */
        .wizard-tz-hint {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 8px 14px;
            margin-bottom: var(--spacing-md);
            border-radius: var(--radius-md);
            font-size: 0.78rem;
            color: var(--accent-cyan);
            background: rgba(6, 182, 212, 0.06);
            border: 1px solid rgba(6, 182, 212, 0.15);
            line-height: 1.4;
        }

        .wizard-tz-hint strong {
            color: var(--text-primary);
            font-weight: 600;
        }

        /* Date/Time Cards */
        .datetime-cards {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--spacing-md);
        }

        .datetime-card {
            background: linear-gradient(135deg, var(--bg-secondary) 0%, rgba(34, 211, 238, 0.02) 100%);
            border-radius: var(--radius-lg);
            padding: var(--spacing-lg);
            transition: all var(--transition-smooth);
            position: relative;
            border: 1px solid var(--border-primary);
            box-shadow:
                0 4px 12px rgba(0, 0, 0, 0.1),
                inset 0 1px 0 rgba(255, 255, 255, 0.05);
        }

        .datetime-card:hover {
            transform: translateY(-2px);
            box-shadow:
                0 8px 25px rgba(0, 0, 0, 0.15),
                0 0 20px rgba(34, 211, 238, 0.08),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
            border-color: rgba(34, 211, 238, 0.3);
        }

        .datetime-card:focus-within {
            box-shadow:
                0 0 0 3px rgba(34, 211, 238, 0.15),
                0 12px 30px rgba(0, 0, 0, 0.2),
                0 0 30px rgba(34, 211, 238, 0.1),
                inset 0 1px 0 rgba(255, 255, 255, 0.15);
            border-color: var(--accent-cyan);
            transform: translateY(-3px);
        }

        .datetime-card-label {
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
            font-size: 0.9rem;
            background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 50%, var(--accent-purple) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            margin-bottom: var(--spacing-sm);
            font-weight: 700;
            letter-spacing: 0.3px;
            text-transform: uppercase;
            position: relative;
            text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
        }

        .datetime-card-label::before {
            content: '';
            position: absolute;
            left: -8px;
            top: 50%;
            transform: translateY(-50%);
            width: 4px;
            height: 70%;
            background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 100%);
            border-radius: 2px;
            box-shadow: 0 0 8px rgba(34, 211, 238, 0.4);
        }

        .datetime-card-label svg {
            width: 20px;
            height: 20px;
            flex-shrink: 0;
            filter: drop-shadow(0 2px 4px rgba(34, 211, 238, 0.3));
        }

        .datetime-card-label svg path {
            fill: var(--accent-cyan);
        }

        .datetime-card input {
            width: 100%;
            background: linear-gradient(135deg, var(--bg-primary) 0%, rgba(34, 211, 238, 0.02) 100%);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-lg);
            color: var(--text-primary);
            font-size: 1.1rem;
            padding: var(--spacing-md) var(--spacing-lg);
            font-weight: 600;
            letter-spacing: 0.5px;
            box-shadow:
                0 4px 12px rgba(0, 0, 0, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.1);
            transition: all var(--transition-fast);
            position: relative;
        }

        .datetime-card input:hover {
            border-color: rgba(34, 211, 238, 0.4);
            box-shadow:
                0 6px 20px rgba(0, 0, 0, 0.2),
                0 0 20px rgba(34, 211, 238, 0.1),
                inset 0 1px 0 rgba(255, 255, 255, 0.15);
            transform: translateY(-1px);
        }

        .datetime-card input:focus {
            outline: none;
            border-color: var(--accent-cyan);
            box-shadow:
                0 0 0 3px rgba(34, 211, 238, 0.2),
                0 8px 25px rgba(0, 0, 0, 0.25),
                0 0 30px rgba(34, 211, 238, 0.15),
                inset 0 1px 0 rgba(255, 255, 255, 0.2);
            transform: translateY(-2px);
        }

        .datetime-card input::placeholder {
            color: var(--text-secondary);
            opacity: 0.7;
            font-weight: 500;
        }

        /* Make native date/time picker icons visible */
        .datetime-card input::-webkit-calendar-picker-indicator {
            filter: invert(1);
            cursor: pointer;
            padding: 4px;
            opacity: 0.8;
        }

        .datetime-card input::-webkit-calendar-picker-indicator:hover {
            opacity: 1;
        }

        /* Quick Options */
        .quick-options {
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-md);
        }

        .quick-option {
            display: flex;
            align-items: center;
            gap: var(--spacing-xs);
            padding: var(--spacing-xs) var(--spacing-md);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-full);
            cursor: pointer;
            transition: all var(--transition-fast);
            font-size: 0.85rem;
            color: var(--text-secondary);
        }

        .quick-option:hover {
            border-color: var(--accent-primary);
            color: var(--text-primary);
        }

        .quick-option.active {
            background: var(--accent-primary);
            border-color: var(--accent-primary);
            color: white;
        }

        /* Category Grid */
        .category-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
            gap: var(--spacing-sm);
        }

        .category-option {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            padding: 14px var(--spacing-sm) 10px;
            background: linear-gradient(135deg, var(--bg-tertiary) 0%, rgba(30, 30, 45, 0.8) 100%);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-lg);
            cursor: pointer;
            transition: all 0.2s ease;
            text-align: center;
            position: relative;
            overflow: hidden;
        }

        .category-option::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 3px;
            background: linear-gradient(90deg, var(--accent-primary), var(--accent-cyan));
            opacity: 0;
            transition: opacity 0.2s ease;
        }

        .category-option:hover {
            border-color: rgba(168, 85, 247, 0.4);
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
        }

        .category-option:hover::before {
            opacity: 0.5;
        }

        .category-option.selected {
            border-color: var(--accent-primary);
            background: linear-gradient(135deg, rgba(168, 85, 247, 0.12) 0%, rgba(6, 182, 212, 0.08) 100%);
            box-shadow: 0 0 16px rgba(168, 85, 247, 0.2), inset 0 0 0 1px rgba(168, 85, 247, 0.1);
        }

        .category-option.selected::before {
            opacity: 1;
        }

        .category-option-icon {
            font-size: 1.6rem;
            line-height: 1;
        }

        .category-option-name {
            font-size: 0.78rem;
            color: var(--text-secondary);
            font-weight: 500;
            line-height: 1.2;
        }

        .category-option.selected .category-option-name {
            color: var(--text-primary);
        }

        /* Color Grid */
        .color-grid {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            gap: var(--spacing-sm);
        }

        .color-choice {
            aspect-ratio: 1;
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all var(--transition-fast);
            border: 3px solid transparent;
        }

        .color-choice:hover {
            transform: scale(1.1);
        }

        .color-choice.selected {
            border-color: white;
            box-shadow: 0 0 0 2px var(--accent-primary);
        }

        /* Summary Preview */
        .event-preview {
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            padding: var(--spacing-lg);
            border-left: 4px solid var(--accent-primary);
        }

        .event-preview-title {
            font-size: 1.25rem;
            font-weight: 700;
            margin-bottom: var(--spacing-md);
            background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 50%, var(--accent-purple) 100%);
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            background-clip: text;
            text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
            letter-spacing: 0.2px;
        }

        .event-preview-details {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            min-width: 0;
        }

        .event-preview-row {
            display: grid;
            grid-template-columns: 110px minmax(0, 1fr);
            align-items: start;
            gap: var(--spacing-md);
            color: var(--text-secondary);
            font-size: 0.9rem;
            min-width: 0;
        }

        .event-preview-row > * {
            min-width: 0;
        }

        .event-preview-label {
            display: inline-flex;
            align-items: center;
            width: fit-content;
            justify-self: start;
            padding: 4px 10px;
            border-radius: var(--radius-md);
            background: linear-gradient(90deg, rgba(34, 211, 238, 0.2) 0%, rgba(168, 85, 247, 0.18) 100%);
            border: 1px solid rgba(34, 211, 238, 0.38);
            box-shadow: 0 8px 14px rgba(0, 0, 0, 0.32);
            font-size: 0.78rem;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            color: var(--text-muted);
            white-space: nowrap;
        }

        .event-preview-value {
            overflow-wrap: anywhere;
            word-break: break-word;
            line-height: 1.4;
        }

        .event-preview-value-pill {
            display: inline-block;
            padding: 6px 12px;
            border-radius: var(--radius-md);
            background: linear-gradient(90deg, rgba(168, 85, 247, 0.18) 0%, rgba(6, 182, 212, 0.16) 100%);
            border: 1px solid rgba(168, 85, 247, 0.35);
            color: var(--text-secondary);
            box-shadow: 0 8px 14px rgba(0, 0, 0, 0.35);
            max-width: 100%;
            width: fit-content;
            box-sizing: border-box;
            white-space: pre-wrap;
            overflow-wrap: anywhere;
            word-break: break-word;
            line-height: 1.4;
            justify-self: start;
            align-self: start;
            min-width: 0;
        }

        #previewDescription.event-preview-value-pill {
            word-break: break-all;
            max-width: 100%;
        }

        #previewDescription.is-collapsed {
            max-height: 220px;
            overflow: hidden;
        }

        .event-preview-desc {
            display: inline-flex;
            flex-direction: column;
            align-items: flex-start;
            gap: var(--spacing-xs);
            min-width: 0;
            max-width: 100%;
            width: fit-content;
            justify-self: start;
            align-self: start;
        }

        .event-preview-toggle {
            display: none;
            align-items: center;
            gap: 6px;
            padding: 4px 10px;
            border-radius: var(--radius-md);
            border: 1px solid rgba(34, 211, 238, 0.3);
            background: rgba(15, 23, 42, 0.45);
            color: var(--text-secondary);
            font-size: 0.78rem;
            font-weight: 700;
            letter-spacing: 0.12em;
            text-transform: uppercase;
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .event-preview-toggle:hover {
            filter: brightness(1.05);
            transform: translateY(-1px);
        }

        .event-preview-pill {
            display: inline-block;
            padding: 4px 10px;
            border-radius: var(--radius-md);
            background: rgba(168, 85, 247, 0.18);
            border: 1px solid rgba(168, 85, 247, 0.4);
            color: var(--text-secondary);
            font-weight: 600;
            box-shadow: 0 8px 14px rgba(0, 0, 0, 0.35);
            justify-self: start;
            max-width: 100%;
            box-sizing: border-box;
            white-space: nowrap;
            text-overflow: ellipsis;
            overflow-wrap: anywhere;
            word-break: break-word;
            line-height: 1.3;
        }

        .event-preview-type-list {
            display: flex;
            flex-wrap: wrap;
            gap: var(--spacing-xs);
        }

        .event-preview-type-list .event-type-badge {
            border-radius: var(--radius-md);
        }

        /* Mobile Responsive */
        @media (max-width: 600px) {
            .wizard-progress {
                overflow-x: auto;
                padding: var(--spacing-sm);
                touch-action: pan-x;
            }
            
            .wizard-step-indicator span:not(.step-num) {
                display: none;
            }
            
            .datetime-cards {
                grid-template-columns: 1fr;
            }
            
            .category-grid {
                grid-template-columns: repeat(3, 1fr);
            }
            
            .color-grid {
                grid-template-columns: repeat(4, 1fr);
            }

            .event-preview-row {
                grid-template-columns: 90px minmax(0, 1fr);
            }
        }

        /* ========== Discord Preview ========== */
        .discord-preview {
            background: #36393f;
            border-radius: 8px;
            padding: 16px;
            font-family: 'gg sans', 'Noto Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
            font-size: 14px;
            color: #dcddde;
        }

        .discord-embed {
            display: flex;
            max-width: 520px;
            border-radius: 4px;
            overflow: hidden;
        }

        .discord-embed-color {
            width: 4px;
            flex-shrink: 0;
        }

        .discord-embed-content {
            padding: 12px 16px;
            background: #2f3136;
            flex: 1;
        }

        .discord-embed-author {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 8px;
        }

        .discord-embed-author-icon {
            width: 24px;
            height: 24px;
            border-radius: 50%;
            background: #5865f2;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
        }

        .discord-embed-author-name {
            font-size: 13px;
            font-weight: 600;
            color: #fff;
        }

        .discord-embed-title {
            font-size: 16px;
            font-weight: 700;
            color: #00aff4;
            margin-bottom: 8px;
        }

        .discord-embed-description {
            color: #dcddde;
            margin-bottom: 12px;
            line-height: 1.4;
        }

        .discord-embed-fields {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 8px;
        }

        .discord-embed-field {
            min-width: 0;
        }

        .discord-embed-field-name {
            font-size: 12px;
            font-weight: 700;
            color: #fff;
            margin-bottom: 2px;
        }

        .discord-embed-field-value {
            font-size: 14px;
            color: #dcddde;
        }

        .discord-embed-footer {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-top: 12px;
            padding-top: 8px;
            border-top: 1px solid #40444b;
            font-size: 12px;
            color: #72767d;
        }

        .discord-mention {
            background: rgba(88, 101, 242, 0.3);
            color: #dee0fc;
            padding: 0 2px;
            border-radius: 3px;
        }

        .discord-content {
            margin-bottom: 8px;
            color: #fff;
        }

        /* Compact embed style */
        .discord-embed.compact .discord-embed-content {
            padding: 8px 12px;
        }

        .discord-embed.compact .discord-embed-fields {
            display: flex;
            flex-wrap: wrap;
            gap: 16px;
        }

        /* ========== Event Type Icons ========== */
        .event-type-badge {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 2px 8px;
            border-radius: var(--radius-full);
            font-size: 0.75rem;
            font-weight: 500;
            border: 1px solid rgba(255, 255, 255, 0.2);
            box-shadow: 0 6px 12px rgba(0, 0, 0, 0.25);
        }

        .event-type-badge.gaming { background: rgba(16, 185, 129, 0.2); color: #10b981; }
        .event-type-badge.maintenance { background: rgba(245, 158, 11, 0.2); color: #f59e0b; }
        .event-type-badge.tournament { background: rgba(139, 92, 246, 0.2); color: #8b5cf6; }
        .event-type-badge.community { background: rgba(59, 130, 246, 0.2); color: #3b82f6; }
        .event-type-badge.update { background: rgba(6, 182, 212, 0.2); color: #06b6d4; }
        .event-type-badge.stream { background: rgba(239, 68, 68, 0.2); color: #ef4444; }
        .event-type-badge.meeting { background: rgba(107, 114, 128, 0.2); color: #9ca3af; }
        .event-type-badge.live {
            background: rgba(34, 197, 94, 0.2);
            color: #22c55e;
            box-shadow: 0 0 8px rgba(34, 197, 94, 0.3);
        }
        .event-type-badge.ended {
            background: rgba(107, 114, 128, 0.15);
            color: #9ca3af;
        }

        /* ========== Event Chip Icons ========== */
        .chip-icon {
            font-size: 1em;
            margin-right: 0;
            opacity: 0.9;
            line-height: 1;
            flex: 0 0 auto;
        }
        
        .chip-text {
            min-width: 0;
            display: flex;
            align-items: baseline;
            justify-content: flex-start;
            gap: 6px;
            flex: 1 1 auto;
            flex-wrap: wrap;
            white-space: normal;
            max-width: 100%;
        }

        .chip-title {
            flex: 1 1 auto;
            white-space: normal;
            word-break: break-word;
            min-width: 0;
            font-weight: 600;
            display: inline;
            line-height: 1.3;
            color: var(--chip-title-color, #f1f5f9);
        }

        .chip-time {
            font-variant-numeric: tabular-nums;
            font-size: 0.9em;
            font-weight: 600;
            opacity: 0.85;
            flex: 0 0 auto;
            color: var(--chip-title-color, #cbd5e1);
        }

        .chip-cat {
            font-size: 1em;
            flex: 0 0 auto;
            line-height: 1;
            padding-left: 5px;
        }
        
        .event-chip {
            display: flex;
            align-items: center;
            gap: 5px;
        }

        /* ========== Responsive - Tablet ========== */
        @media (max-width: 1024px) {
            .sidebar {
                position: fixed;
                left: 0;
                top: var(--header-height);
                height: calc(100vh - var(--header-height));
                z-index: 100;
                transform: translateX(-100%);
                transition: transform var(--transition-normal);
                box-shadow: var(--shadow-lg);
                background: var(--bg-secondary);
            }

            .sidebar.open {
                transform: translateX(0);
            }
            
            #sidebarToggle {
                display: flex !important;
            }

            :root {
                --calendar-cell-height: 90px;
            }

            .header-left {
                gap: var(--spacing-sm);
            }

            .logo-text {
                display: none;
            }

            .page-title {
                font-size: 1rem;
            }

            .logo-divider {
                display: none;
            }

            .view-switcher {
                gap: 2px;
                padding: 2px;
            }

            .view-btn {
                padding: 6px 10px;
                font-size: 0.7rem;
                letter-spacing: 0.06em;
            }

            .new-event-btn {
                padding: 7px 12px;
                font-size: 0.7rem;
                letter-spacing: 0.06em;
            }

            .new-event-btn span {
                width: 16px;
                height: 16px;
                font-size: 0.8rem;
                border-radius: 3px;
            }

            .btn-today {
                padding: var(--spacing-xs) var(--spacing-sm);
                font-size: 0.8rem;
            }

            .modal {
                width: 90%;
                max-width: 550px;
            }

            .form-row {
                grid-template-columns: 1fr;
            }

            .rsvp-buttons {
                flex-wrap: wrap;
            }

            .rsvp-btn {
                min-width: calc(50% - var(--spacing-xs));
            }

            /* Timezone selector tablet */
            .timezone-btn .tz-icon {
                display: none;
            }
        }

        /* ========== Responsive - Small Tablet ========== */
        @media (max-width: 768px) {
            .header-right {
                gap: var(--spacing-xs);
            }

            .header-actions-group {
                gap: 2px;
            }

            .new-event-btn {
                padding: 6px 10px;
                font-size: 0.68rem;
            }

            .nav-controls {
                gap: var(--spacing-xs);
            }

            .current-date {
                font-size: 1.1rem;
                min-width: auto;
            }

            .discord-embed {
                max-width: 100%;
            }

            .user-menu .user-name {
                display: none;
            }

            .btn-label-text {
                display: none;
            }

            /* Reduce continuous animation on smaller devices */
            body::before {
                animation: none;
                opacity: 0.7;
            }
        }

        /* ========== Responsive - Mobile ========== */
        @media (max-width: 640px) {
            :root {
                --header-height: 56px;
                --calendar-cell-height: 110px;
            }

            body {
                font-size: 15px;
                touch-action: pan-y;
            }

            .calendar-container {
                padding: var(--spacing-sm);
            }

            .calendar-body {
                grid-auto-rows: var(--calendar-cell-height);
            }

            .calendar-grid.month-view {
                overflow-y: hidden;
            }

            .calendar-grid.month-view .calendar-body {
                grid-auto-rows: var(--calendar-cell-height);
            }

            #previewDescription.is-collapsed {
                max-height: 160px;
            }

            .header {
                padding: 0 var(--spacing-sm);
                gap: var(--spacing-xs);
                overflow: visible;
            }

            .header-left {
                gap: var(--spacing-xs);
            }

            .logo-icon {
                font-size: 1.3rem;
            }

            .page-title {
                display: none;
            }

            .logo-divider {
                display: none;
            }

            /* Timezone picker mobile - bottom sheet variant */
            .timezone-btn {
                padding: 6px 10px;
                font-size: 0.8rem;
                font-weight: 500;
            }

            .tz-picker-panel {
                position: fixed;
                bottom: 0;
                left: 0;
                right: 0;
                width: 100%;
                max-width: 100vw;
                max-height: 80vh;
                border-radius: 16px 16px 0 0;
                transform: translateY(100%);
                transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
                padding-bottom: env(safe-area-inset-bottom, 0);
            }

            .tz-picker-overlay.active .tz-picker-panel {
                transform: translateY(0);
            }

            .tz-picker-overlay {
                align-items: flex-end;
            }

            .tz-picker-handle {
                display: flex !important;
                justify-content: center;
                padding: 10px 0 2px;
            }
            .tz-picker-handle::after {
                content: '';
                width: 36px;
                height: 4px;
                border-radius: 2px;
                background: var(--text-muted);
                opacity: 0.5;
            }

            .timezone-option {
                padding: 14px var(--spacing-md);
                font-size: 0.95rem;
            }

            .timezone-option .tz-name {
                font-size: 0.95rem;
            }

            .timezone-option .tz-offset {
                font-size: 0.85rem;
            }

            /* Onboarding popup mobile */
            .onboarding-overlay {
                padding: var(--spacing-md);
                align-items: center;
                justify-content: center;
            }

            .onboarding-box {
                padding: var(--spacing-md);
                max-width: 100%;
                margin: auto;
                border-radius: 16px;
                max-height: calc(100vh - 32px);
                max-height: calc(100dvh - 32px);
                overflow-y: auto;
            }

            .onboarding-icon {
                font-size: 2rem;
            }

            .onboarding-title {
                font-size: 1.15rem;
            }

            .onboarding-subtitle {
                font-size: 0.85rem;
            }

            .onboarding-account-option {
                padding: var(--spacing-sm) var(--spacing-md);
            }

            .onboarding-account-icon {
                width: 38px;
                height: 38px;
            }

            .onboarding-account-icon svg {
                width: 20px;
                height: 20px;
            }

            .onboarding-account-title {
                font-size: 0.95rem;
            }

            .onboarding-account-desc {
                font-size: 0.78rem;
            }

            .onboarding-settings-content {
                padding: var(--spacing-sm);
            }

            .onboarding-detection-card {
                padding: 8px 10px;
            }

            .onboarding-categories-grid {
                max-height: none;
            }

            .onboarding-features {
                grid-template-columns: 1fr;
                gap: var(--spacing-xs);
            }

            .onboarding-tz-select select {
                font-size: 16px; /* Prevents iOS zoom */
            }

            .current-date {
                font-size: 0.88rem;
                font-weight: 700;
                min-width: auto;
                padding: 0 var(--spacing-xs);
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
            }

            .current-date::after {
                display: none;
            }

            .header-left {
                min-width: 0;
                flex: 1;
                overflow: visible;
            }

            .header-right {
                flex-shrink: 0;
            }

            .nav-controls {
                gap: 4px;
                min-width: 0;
            }

            .btn-today {
                padding: 5px 10px;
                font-size: 0.78rem;
                font-weight: 600;
            }

            .btn-today .today-pulse {
                display: none;
            }

            .btn-icon {
                width: auto;
                min-width: 32px;
                height: 32px;
                font-size: 0.85rem;
                padding: 0 6px;
            }

            .btn-label-text {
                font-size: 0.65rem;
            }

            .view-switcher {
                display: none;
            }

            .header-actions-group {
                display: none;
            }

            .mobile-menu-toggle {
                display: flex;
                font-size: 1.2rem;
                font-weight: 700;
                min-width: 36px;
                height: 36px;
                padding: 0;
                letter-spacing: 2px;
            }

            .header-right {
                flex-shrink: 0;
                min-width: 0;
                gap: var(--spacing-xs);
            }

            .user-menu .user-name {
                display: none;
            }

            .new-event-btn {
                display: none;
            }

            /* ========== Mobile Week View ========== */
            .week-cell-mobile {
                min-height: unset !important;
                border-bottom: 1px solid var(--border-primary);
                padding: 0 !important;
                margin-bottom: var(--spacing-xs);
                border-radius: var(--radius-md);
                background: var(--bg-secondary);
                overflow: visible;
            }

            .week-cell-mobile .week-day-header {
                display: flex;
                align-items: center;
                gap: var(--spacing-sm);
                padding: var(--spacing-sm) var(--spacing-md);
                background: linear-gradient(135deg, var(--bg-tertiary) 0%, rgba(34, 211, 238, 0.04) 100%);
                border-bottom: 1px solid var(--border-primary);
            }

            .week-cell-mobile .week-day-header .day-name {
                font-size: 0.82rem;
                font-weight: 700;
                text-transform: uppercase;
                color: var(--text-secondary);
                letter-spacing: 0.5px;
                min-width: 32px;
            }

            .week-cell-mobile .week-day-header .day-name::after {
                display: none;
            }

            .week-cell-mobile .week-day-header .day-number {
                font-size: 1rem;
                font-weight: 700;
                color: var(--text-primary);
                min-width: unset;
                height: unset;
                padding: 0;
                margin: 0;
            }

            .week-cell-mobile.today .week-day-header .day-number {
                background: var(--accent-cyan);
                color: var(--bg-primary);
                border-radius: 50%;
                width: 28px;
                height: 28px;
                display: flex;
                align-items: center;
                justify-content: center;
            }

            .week-cell-mobile .week-day-month {
                display: inline;
                font-size: 0.78rem;
                color: var(--text-muted);
                font-weight: 500;
            }

            .week-cell-mobile .week-events {
                padding: var(--spacing-xs) var(--spacing-sm);
                overflow: visible;
                min-height: 24px;
            }

            .week-cell-mobile .week-events:empty::after {
                content: 'No events';
                display: block;
                color: var(--text-muted);
                font-size: 0.78rem;
                font-style: italic;
                padding: var(--spacing-xs) 0;
                text-align: center;
                opacity: 0.6;
            }

            .week-cell-mobile .event-chip {
                width: 100%;
                margin-bottom: var(--spacing-xs);
                font-size: 0.84rem;
                white-space: normal;
                text-overflow: clip;
            }

            .week-cell-mobile .event-chip:last-child {
                margin-bottom: 0;
            }

            /* Calendar Grid Mobile */
            .calendar-header-cell {
                padding: 4px 2px;
                font-size: 0;
                font-weight: 600;
                letter-spacing: 0.3px;
            }

            .calendar-header-cell::after {
                content: attr(data-short);
                font-size: 0.7rem;
                font-weight: 600;
                letter-spacing: 0.3px;
            }

            .calendar-cell {
                padding: 2px;
                overflow: visible;
            }

            .day-number {
                min-width: 24px;
                height: 22px;
                font-size: 0.75rem;
                padding: 0 5px;
                font-weight: 600;
                margin-bottom: 2px;
            }

            .event-chip {
                font-size: 0.84rem;
                line-height: 1.35;
                padding: 5px 8px 5px 0;
                margin-bottom: 3px;
                font-weight: 600;
                align-items: flex-start;
                width: 100%;
                white-space: normal;
                text-overflow: clip;
                position: relative;
                z-index: 1;
            }

            /* On small screens, overnight chips stay inline (no grid spanning) */
            .event-chip.overnight {
                position: relative;
                width: 100%;
                max-width: 100%;
            }
            .overnight-spacer { display: none; }

            .day-events {
                overflow: visible;
            }

            .event-icon {
                font-size: 0.75rem;
                padding: 2px 5px;
            }

            .event-icon-group {
                max-height: 52px;
                overflow: hidden;
            }

            .more-events {
                font-size: 0.74rem;
                padding: 3px 7px;
                font-weight: 600;
            }

            .chip-text {
                flex-direction: row;
                flex-wrap: wrap;
                align-items: baseline;
                gap: 4px;
            }

            .chip-time {
                font-size: 0.85em;
            }

            .chip-title {
                font-size: 0.92em;
                white-space: normal;
                word-break: break-word;
            }

            .chip-icon {
                font-size: 1em;
            }

            .chip-cat {
                font-size: 1em;
            }

            /* Sidebar Mobile */
            .sidebar {
                width: 100%;
                max-width: 320px;
            }

            .mini-calendar {
                padding: var(--spacing-sm);
            }

            .mini-calendar-grid {
                gap: 3px;
            }

            .mini-day {
                width: 32px;
                height: 32px;
                font-size: 0.8rem;
                font-weight: 500;
            }

            /* Modal Mobile */
            .modal-overlay {
                padding: 0;
                align-items: flex-end;
                overflow-y: auto;
                -webkit-overflow-scrolling: touch;
            }

            .modal {
                width: 100%;
                max-width: none;
                max-height: 90vh;
                margin: 0;
                border-radius: var(--radius-lg) var(--radius-lg) 0 0;
                overflow-y: auto;
                -webkit-overflow-scrolling: touch;
            }

            .modal-header {
                padding: var(--spacing-md);
                position: sticky;
                top: 0;
                background: var(--bg-secondary);
                z-index: 10;
            }

            .modal-title {
                font-size: 1.1rem;
            }

            .modal-body {
                padding: var(--spacing-md);
                font-size: 0.95rem;
                overflow-x: hidden;
                touch-action: pan-y;
            }

            .event-detail-grid {
                grid-template-columns: 1fr;
                gap: var(--spacing-md);
            }

            .event-detail-label {
                font-size: 0.75rem;
            }

            /* Instant appearance for event view modal */
            #viewModal {
                transition: none;
            }
            #viewModal .modal {
                transition: none;
                transform: none;
            }

            #viewModal .modal-header {
                flex-wrap: wrap;
                gap: var(--spacing-xs);
            }

            #viewEventTitle {
                flex-basis: 100%;
            }

            /* View Modal Mobile Styles */
            .view-modal-section {
                margin-bottom: var(--spacing-md);
            }

            .view-section-title {
                font-size: 0.68rem;
                padding-bottom: 5px;
            }

            .view-detail-row {
                grid-template-columns: 1fr;
                gap: var(--spacing-sm);
            }

            .view-detail-item {
                padding: 10px 12px;
            }

            .view-detail-icon {
                width: 24px;
                height: 24px;
            }

            .view-detail-icon svg {
                width: 12px;
                height: 12px;
            }

            .view-detail-label {
                font-size: 0.6rem;
            }

            .view-detail-value {
                font-size: 0.84rem;
            }

            .view-description-box {
                padding: var(--spacing-sm) var(--spacing-md);
            }

            .view-description-text {
                font-size: 0.88rem;
            }

            .view-rsvp-panel,
            .view-attendees-panel {
                padding: var(--spacing-sm) var(--spacing-md);
            }

            .view-share-grid {
                gap: 6px;
            }

            .day-modal-cta-btn span:first-child {
                display: inline-flex;
            }

            .modal-footer {
                padding: var(--spacing-md);
                position: sticky;
                bottom: 0;
                background: var(--bg-secondary);
            }

            .form-group {
                margin-bottom: var(--spacing-md);
            }

            .form-label {
                font-size: 0.76rem;
                font-weight: 800;
                margin-bottom: var(--spacing-xs);
                padding: 7px 14px;
                letter-spacing: 0.8px;
                color: #fff;
                text-shadow: 0 0 10px rgba(168, 85, 247, 0.35);
            }

            .form-label::before {
                width: 8px;
                height: 8px;
            }

            .form-input,
            .form-select,
            .form-textarea {
                font-size: 16px; /* Prevents iOS zoom */
                padding: var(--spacing-sm) var(--spacing-md);
            }

            .text-secondary {
                font-size: 0.9rem;
            }

            .text-muted {
                font-size: 0.85rem;
            }

            .color-options {
                gap: var(--spacing-xs);
            }

            .color-option {
                width: 28px;
                height: 28px;
            }

            /* RSVP Mobile */
            .rsvp-buttons {
                flex-direction: column;
            }

            .rsvp-btn {
                width: 100%;
                padding: var(--spacing-sm);
            }

            /* Share Buttons Mobile */
            .invite-section {
                margin-top: var(--spacing-md);
                padding-top: var(--spacing-md);
            }

            .invite-actions {
                flex-wrap: wrap;
                gap: 6px;
            }

            .invite-btn {
                padding: 6px 10px;
                font-size: 0.75rem;
            }

            .invite-btn svg {
                width: 14px;
                height: 14px;
            }

            /* View Event Modal Mobile */
            .event-info-grid {
                grid-template-columns: 1fr;
            }

            /* Day Modal Mobile */
            .day-event-item {
                flex-direction: column;
                align-items: flex-start;
                gap: var(--spacing-xs);
            }

            .day-event-time {
                width: auto;
            }

            /* Week/Day View Mobile */
            .week-header,
            .day-header {
                display: none;
            }

            .week-grid {
                grid-template-columns: 50px 1fr;
            }

            /* Settings Modal Mobile */
            .settings-tabs {
                flex-wrap: wrap;
                gap: 3px;
            }

            .settings-tab {
                flex: 1;
                min-width: calc(50% - 4px);
                text-align: center;
                font-size: 0.78rem;
                padding: var(--spacing-sm) var(--spacing-xs);
            }

            .webhook-item {
                flex-direction: column;
                align-items: flex-start;
                gap: var(--spacing-sm);
            }

            .webhook-actions {
                width: 100%;
                justify-content: flex-end;
            }

            .webhook-meta {
                gap: 4px;
            }

            /* Cron Hero Banner Mobile */
            .cron-hero-banner {
                flex-direction: column;
                gap: var(--spacing-md);
                padding: var(--spacing-md);
                text-align: center;
            }

            .cron-hero-icon {
                width: 44px;
                height: 44px;
                margin: 0 auto;
            }

            .cron-hero-content {
                text-align: center;
            }

            .cron-hero-title {
                font-size: 0.95rem;
            }

            .cron-hero-details {
                font-size: 0.8rem;
            }

            .cron-hero-actions {
                width: 100%;
                justify-content: center;
            }

            /* Setup Guide Mobile */
            .setup-guide-header {
                padding: var(--spacing-sm) var(--spacing-md);
            }

            .setup-guide-title {
                font-size: 0.88rem;
            }

            .setup-guide-subtitle {
                font-size: 0.75rem;
            }

            .setup-guide-body {
                padding: 0 var(--spacing-md) var(--spacing-md);
            }

            .setup-step {
                gap: var(--spacing-sm);
                padding: var(--spacing-sm) 0;
            }

            .setup-step-number {
                width: 28px;
                height: 28px;
                font-size: 0.8rem;
            }

            .setup-step-title {
                font-size: 0.88rem;
            }

            .setup-step-desc {
                font-size: 0.82rem;
            }

            .setup-code-block {
                flex-direction: column;
                gap: 6px;
                align-items: stretch;
                padding: var(--spacing-sm);
            }

            .setup-code-block code {
                font-size: 0.72rem;
                word-break: break-all;
                overflow-wrap: anywhere;
            }

            .setup-copy-btn {
                align-self: flex-end;
                padding: 6px 12px;
                font-size: 0.75rem;
            }

            .setup-step-note {
                padding: var(--spacing-sm);
            }

            .setup-note-row {
                flex-direction: column;
                gap: 2px;
                padding: 4px 0;
            }

            .setup-note-label {
                font-size: 0.78rem;
                font-weight: 600;
            }

            .setup-note-value {
                font-size: 0.75rem;
                padding-left: 20px;
            }

            .setup-path-item {
                flex-direction: column;
                gap: 2px;
            }

            .setup-path-label {
                min-width: auto;
                font-size: 0.78rem;
                font-weight: 600;
            }

            .setup-services-grid {
                flex-direction: column;
            }

            .setup-service-link {
                justify-content: center;
            }

            /* Cron Job Items Mobile */
            .cron-job-item {
                flex-direction: column;
                align-items: flex-start;
            }

            .cron-job-actions {
                width: 100%;
                justify-content: flex-start;
                margin-top: var(--spacing-sm);
                flex-wrap: wrap;
            }

            .cron-job-actions .btn {
                flex: 1;
                min-width: 0;
                justify-content: center;
                font-size: 0.75rem;
            }

            .cron-job-meta {
                flex-direction: row;
                flex-wrap: wrap;
                gap: 4px;
            }

            .cron-job-meta-tag {
                font-size: 0.7rem;
            }

            .cron-job-name {
                flex-wrap: wrap;
            }

            .cron-status-badge {
                font-size: 0.65rem;
            }

            /* Cron Section Header Mobile */
            .cron-section-header {
                flex-direction: column;
                gap: 4px;
            }

            /* Settings Form Card Mobile */
            .settings-form-card {
                padding: var(--spacing-md);
                margin-top: var(--spacing-md);
            }

            .settings-form-title {
                font-size: 0.95rem;
            }

            .settings-form-actions {
                flex-direction: column;
            }

            .settings-form-actions .btn {
                width: 100%;
                justify-content: center;
            }

            /* Webhook Cron Notice Mobile */
            .webhook-cron-notice {
                flex-direction: column;
                text-align: center;
                padding: var(--spacing-md);
            }

            .webhook-cron-notice-icon {
                margin: 0 auto;
            }

            .webhook-cron-notice-content strong {
                font-size: 0.85rem;
            }

            .webhook-cron-notice-content p {
                font-size: 0.78rem;
            }

            /* Cron Empty State Mobile */
            .cron-empty-state {
                padding: var(--spacing-lg);
            }

            .cron-empty-state .cron-empty-icon {
                font-size: 2rem;
            }

            .cron-setup-info code {
                font-size: 0.7rem !important;
            }

            /* Cron Modal Mobile */
            .cron-modal-overlay {
                padding: 0;
                align-items: flex-end;
            }

            .cron-modal {
                max-width: 100%;
                max-height: 92vh;
                border-radius: var(--radius-xl) var(--radius-xl) 0 0;
            }

            .cron-modal-header {
                padding: var(--spacing-md);
            }

            .cron-modal-body {
                padding: var(--spacing-md);
            }

            .cron-modal-footer {
                padding: var(--spacing-md);
            }

            .cron-modal-icon {
                width: 36px;
                height: 36px;
                font-size: 1.2rem;
            }

            .cron-modal-title {
                font-size: 0.95rem;
            }

            .cron-type-card {
                padding: var(--spacing-sm);
                gap: var(--spacing-sm);
            }

            .cron-type-card-icon {
                width: 34px;
                height: 34px;
                font-size: 1.2rem;
            }

            .cron-type-card-info strong {
                font-size: 0.82rem;
            }

            .cron-schedule-options {
                grid-template-columns: repeat(2, 1fr);
            }

            /* Toast Mobile */
            #toastContainer {
                bottom: 70px;
                right: var(--spacing-sm);
                left: var(--spacing-sm);
            }

            .toast {
                width: 100%;
            }
        }

        /* ========== Responsive - Small Mobile ========== */
        @media (max-width: 380px) {
            :root {
                --calendar-cell-height: 95px;
            }

            .logo-icon {
                display: none;
            }

            .logo {
                display: none;
            }

            .btn-today {
                padding: 4px 7px;
                font-size: 0.72rem;
            }

            .btn-icon {
                min-width: 28px;
                height: 28px;
                font-size: 0.78rem;
                padding: 0 4px;
            }

            .calendar-container {
                padding: var(--spacing-xs);
            }

            .page-title {
                display: none;
            }

            .current-date {
                font-size: 0.88rem;
                font-weight: 700;
            }

            .day-number {
                min-width: 20px;
                height: 20px;
                font-size: 0.7rem;
                padding: 0 4px;
            }

            .event-chip {
                font-size: 0.8rem;
                padding: 4px 6px 4px 0;
            }

            .chip-time {
                font-size: 0.82em;
            }

            .chip-title {
                font-size: 0.88em;
                white-space: normal;
                word-break: break-word;
            }

            .chip-icon {
                font-size: 0.95em;
            }

            .chip-cat {
                font-size: 0.95em;
            }

            .calendar-header-cell {
                font-size: 0;
            }

            .calendar-header-cell::after {
                content: attr(data-tiny);
                font-size: 0.65rem;
            }

            /* Extra small mobile - new components */
            .cron-hero-banner {
                padding: var(--spacing-sm);
            }

            .cron-hero-title {
                font-size: 0.85rem;
            }

            .cron-hero-details {
                font-size: 0.75rem;
            }

            .setup-step-number {
                width: 24px;
                height: 24px;
                font-size: 0.72rem;
            }

            .setup-code-block code {
                font-size: 0.65rem;
            }

            .form-label {
                font-size: 0.7rem;
                padding: 6px 12px;
            }

            .settings-form-card {
                padding: var(--spacing-sm);
            }

            .cron-job-actions .btn {
                font-size: 0.7rem;
                padding: 6px 8px;
            }

            .cron-schedule-options {
                grid-template-columns: 1fr 1fr;
                gap: 4px;
            }

            .cron-schedule-option {
                padding: 8px 4px;
                min-height: 44px;
            }

            .cron-type-card-info span {
                display: none;
            }

            .cron-type-badge {
                font-size: 0.58rem;
                padding: 2px 6px;
            }
        }

        /* ========== Touch Optimizations ========== */
        @media (pointer: coarse) {
            .btn,
            .calendar-day,
            .mini-day,
            .event-chip,
            .rsvp-btn {
                min-height: 44px;
            }

            .mini-day {
                min-width: 32px;
                min-height: 32px;
            }

            .calendar-day {
                min-height: var(--calendar-cell-height);
            }

            .event-chip {
                min-height: auto;
                padding: 6px 10px;
            }

            .view-btn,
            .category-item,
            .settings-tab,
            .timezone-option,
            .modal-close,
            .quick-option,
            .guide-btn,
            .tz-btn {
                min-height: 44px;
            }

            .modal-close {
                min-width: 44px;
                font-size: 1.5rem;
            }

            .mini-cal-nav button {
                min-width: 36px;
                min-height: 36px;
            }

            .color-option,
            .color-choice {
                min-width: 44px;
                min-height: 44px;
            }

            .wizard-step-indicator {
                min-width: 44px;
                min-height: 44px;
            }
        }

        /* ========== Landscape Phone ========== */
        @media (max-height: 500px) and (orientation: landscape) {
            :root {
                --header-height: 50px;
                --calendar-cell-height: 60px;
            }

            .modal {
                max-height: 95vh;
            }

            .modal-body {
                max-height: 60vh;
            }
        }
        
        /* ========== Combined Onboarding Popup ========== */
        .onboarding-overlay {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(6, 6, 12, 0.94);
            z-index: 10002;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: var(--spacing-md);
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.15s ease, visibility 0.15s ease;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
        }

        .onboarding-overlay.active {
            opacity: 1;
            visibility: visible;
        }

        .onboarding-box {
            background: linear-gradient(165deg, var(--bg-secondary) 0%, rgba(20, 20, 35, 0.98) 100%);
            border: 1px solid rgba(34, 211, 238, 0.25);
            border-radius: 16px;
            padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);
            max-width: 420px;
            width: 100%;
            max-height: 90vh;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
            overscroll-behavior: contain;
            touch-action: pan-y;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
            transform: scale(0.96) translateY(8px);
            transition: transform 0.2s ease;
            position: relative;
        }

        .onboarding-overlay.active .onboarding-box {
            transform: scale(1) translateY(0);
        }

        /* Header */
        .onboarding-header {
            text-align: center;
            margin-bottom: var(--spacing-lg);
        }

        .onboarding-icon {
            font-size: 2.5rem;
            margin-bottom: var(--spacing-sm);
        }

        .onboarding-title {
            font-size: 1.45rem;
            font-weight: 800;
            color: var(--text-primary);
            margin-bottom: 4px;
            letter-spacing: 0.3px;
        }

        .onboarding-subtitle {
            color: var(--text-secondary);
            font-size: 0.9rem;
            line-height: 1.5;
            max-width: 300px;
            margin: 0 auto;
        }

        /* Account options section */
        .onboarding-account-section {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-md);
        }

        .onboarding-account-option {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .onboarding-account-option:hover {
            border-color: var(--accent-cyan);
            background: rgba(34, 211, 238, 0.06);
        }

        .onboarding-account-icon {
            width: 44px;
            height: 44px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(34, 211, 238, 0.12);
            border-radius: var(--radius-md);
            color: var(--accent-cyan);
            flex-shrink: 0;
        }

        .onboarding-account-icon-alt {
            background: rgba(168, 85, 247, 0.12);
            color: var(--accent-purple);
        }

        .onboarding-account-option-primary {
            background: linear-gradient(135deg, rgba(34, 197, 94, 0.08) 0%, rgba(34, 211, 238, 0.04) 100%);
            border-color: rgba(34, 197, 94, 0.3);
        }

        .onboarding-account-option-primary:hover {
            border-color: rgba(34, 197, 94, 0.6);
            background: linear-gradient(135deg, rgba(34, 197, 94, 0.12) 0%, rgba(34, 211, 238, 0.06) 100%);
        }

        .onboarding-account-icon-primary {
            background: rgba(34, 197, 94, 0.15);
            color: #22c55e;
        }

        .onboarding-account-option-primary:hover .onboarding-account-arrow {
            color: #22c55e;
        }

        .onboarding-account-info {
            flex: 1;
            display: flex;
            flex-direction: column;
            gap: 2px;
        }

        .onboarding-account-title {
            font-size: 1rem;
            font-weight: 700;
            color: var(--text-primary);
        }

        .onboarding-account-desc {
            font-size: 0.82rem;
            color: var(--text-secondary);
        }

        .onboarding-account-arrow {
            flex-shrink: 0;
            color: var(--text-muted);
            transition: transform var(--transition-fast);
        }

        .onboarding-account-option:hover .onboarding-account-arrow {
            transform: translateX(3px);
            color: var(--accent-cyan);
        }

        /* Settings section */
        .onboarding-settings-section {
            margin-bottom: var(--spacing-md);
        }

        .onboarding-settings-toggle {
            width: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 10px;
            background: transparent;
            border: 1px dashed var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-secondary);
            font-size: 0.85rem;
            font-weight: 500;
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .onboarding-settings-toggle:hover {
            border-color: var(--accent-cyan);
            color: var(--text-primary);
            background: rgba(34, 211, 238, 0.04);
        }

        .onboarding-settings-toggle.active {
            border-style: solid;
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
            background: rgba(34, 211, 238, 0.06);
        }

        .onboarding-settings-chevron {
            transition: transform var(--transition-fast);
        }

        .onboarding-settings-toggle.active .onboarding-settings-chevron {
            transform: rotate(180deg);
        }

        .onboarding-settings-content {
            display: none;
            margin-top: var(--spacing-sm);
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
        }

        .onboarding-settings-content.active {
            display: block;
        }

        /* Smaller toggles */
        .onboarding-toggle-sm {
            width: 36px;
            height: 20px;
        }

        .onboarding-toggle-sm .onboarding-toggle-slider::before {
            height: 14px;
            width: 14px;
        }

        .onboarding-toggle-sm input:checked + .onboarding-toggle-slider::before {
            transform: translateX(16px);
        }

        /* Compact detection cards */
        .onboarding-settings-content .onboarding-detections {
            gap: 6px;
            margin-bottom: var(--spacing-sm);
        }

        .onboarding-settings-content .onboarding-detection-card {
            padding: 10px 12px;
        }

        .onboarding-settings-content .onboarding-detection-icon {
            width: 32px;
            height: 32px;
        }

        .onboarding-settings-content .onboarding-detection-value {
            font-size: 0.9rem;
        }

        /* Divider */
        .onboarding-divider {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            margin: var(--spacing-md) 0;
            color: var(--text-muted);
            font-size: 0.8rem;
        }

        .onboarding-divider::before,
        .onboarding-divider::after {
            content: '';
            flex: 1;
            height: 1px;
            background: var(--border-primary);
        }

        /* Timezone select */
        .onboarding-tz-select {
            margin-top: var(--spacing-sm);
            margin-bottom: var(--spacing-md);
            display: flex;
            gap: var(--spacing-sm);
            align-items: center;
        }

        .onboarding-tz-select select {
            flex: 1;
            padding: var(--spacing-sm) var(--spacing-md);
            border-radius: var(--radius-md);
            background: var(--bg-tertiary);
            color: var(--text-primary);
            border: 1px solid var(--border-primary);
            font-size: 0.9rem;
            cursor: pointer;
            transition: border-color var(--transition-fast);
        }

        .onboarding-tz-select select:focus {
            border-color: var(--accent-primary);
            outline: none;
        }

        .onboarding-btn-sm {
            padding: var(--spacing-sm) var(--spacing-md) !important;
            font-size: 0.85rem !important;
            display: inline-flex;
            align-items: center;
            gap: 6px;
        }

        /* View selector */
        .onboarding-view-select {
            margin-top: var(--spacing-sm);
            margin-bottom: var(--spacing-md);
        }

        .onboarding-view-options {
            display: flex;
            gap: var(--spacing-sm);
        }

        .onboarding-view-option {
            flex: 1;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 6px;
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border: 2px solid var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-secondary);
            cursor: pointer;
            transition: all var(--transition-fast);
        }

        .onboarding-view-option:hover {
            border-color: var(--accent-cyan);
            color: var(--text-primary);
            background: rgba(34, 211, 238, 0.06);
        }

        .onboarding-view-option.active {
            border-color: var(--accent-cyan);
            background: rgba(34, 211, 238, 0.12);
            color: var(--accent-cyan);
        }

        .onboarding-view-option span {
            font-size: 0.85rem;
            font-weight: 600;
        }

        /* Detection cards */
        .onboarding-detections {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-lg);
        }

        .onboarding-detection-card {
            display: flex;
            align-items: center;
            gap: var(--spacing-md);
            padding: var(--spacing-md);
            background: linear-gradient(135deg, rgba(34, 211, 238, 0.04) 0%, rgba(168, 85, 247, 0.02) 100%);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            transition: all var(--transition-fast);
        }

        .onboarding-detection-card:hover {
            border-color: rgba(34, 211, 238, 0.3);
        }

        .onboarding-detection-icon {
            flex-shrink: 0;
            width: 40px;
            height: 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            background: rgba(34, 211, 238, 0.1);
            border-radius: var(--radius-md);
            color: var(--accent-cyan);
        }

        .onboarding-detection-icon svg {
            width: 20px;
            height: 20px;
        }

        .onboarding-detection-info {
            flex: 1;
            min-width: 0;
        }

        .onboarding-detection-label {
            font-size: 0.72rem;
            font-weight: 600;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 2px;
        }

        .onboarding-detection-value {
            font-size: 1rem;
            font-weight: 700;
            color: var(--text-primary);
            line-height: 1.3;
        }

        .onboarding-detection-note {
            font-size: 0.78rem;
            color: var(--text-secondary);
            margin-top: 2px;
        }

        .onboarding-change-btn {
            background: none;
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-sm);
            padding: 6px 10px;
            font-size: 0.85rem;
            cursor: pointer;
            color: var(--text-secondary);
            transition: all var(--transition-fast);
        }

        .onboarding-change-btn:hover {
            background: var(--bg-tertiary);
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
        }

        /* Features grid */
        .onboarding-features {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: var(--spacing-sm);
            margin-bottom: var(--spacing-lg);
        }

        .onboarding-feature {
            display: flex;
            align-items: flex-start;
            gap: var(--spacing-sm);
            padding: var(--spacing-md);
            background: rgba(255, 255, 255, 0.02);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            transition: all var(--transition-fast);
        }

        .onboarding-feature:hover {
            background: rgba(34, 211, 238, 0.04);
            border-color: rgba(34, 211, 238, 0.2);
        }

        .onboarding-feature-icon {
            font-size: 1.3rem;
            flex-shrink: 0;
            line-height: 1;
            margin-top: 2px;
        }

        .onboarding-feature-info {
            display: flex;
            flex-direction: column;
            gap: 2px;
        }

        .onboarding-feature-info strong {
            font-size: 0.92rem;
            font-weight: 700;
            color: var(--text-primary);
            line-height: 1.3;
        }

        .onboarding-feature-info span {
            font-size: 0.82rem;
            color: var(--text-secondary);
            line-height: 1.4;
        }

        /* Actions */
        .onboarding-actions {
            display: flex;
            flex-direction: column;
            gap: var(--spacing-sm);
            margin-top: var(--spacing-md);
        }

        .onboarding-btn {
            padding: 12px var(--spacing-lg);
            border-radius: var(--radius-md);
            font-weight: 600;
            cursor: pointer;
            border: 1px solid transparent;
            font-size: 0.9rem;
            transition: all var(--transition-fast);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
        }

        .onboarding-btn svg {
            flex-shrink: 0;
        }

        .onboarding-btn-primary {
            background: var(--gradient-primary);
            color: white;
        }

        .onboarding-btn-primary:hover {
            transform: translateY(-1px);
            box-shadow: 0 4px 16px rgba(34, 211, 238, 0.25);
        }

        .onboarding-btn-secondary {
            background: var(--bg-tertiary);
            color: var(--text-primary);
            border-color: var(--border-primary);
        }

        .onboarding-btn-secondary:hover {
            background: var(--bg-secondary);
            border-color: var(--accent-cyan);
        }

        /* Onboarding toggles */
        .onboarding-toggle {
            position: relative;
            display: inline-block;
            width: 44px;
            height: 24px;
            flex-shrink: 0;
            cursor: pointer;
        }
        
        .onboarding-toggle input {
            position: absolute;
            opacity: 0;
            width: 100%;
            height: 100%;
            margin: 0;
            cursor: pointer;
            z-index: 2;
        }
        
        .onboarding-toggle-slider {
            position: absolute;
            cursor: pointer;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: 12px;
            transition: all var(--transition-fast);
        }
        
        .onboarding-toggle-slider::before {
            position: absolute;
            content: "";
            height: 18px;
            width: 18px;
            left: 2px;
            bottom: 2px;
            background: var(--text-muted);
            border-radius: 50%;
            transition: all var(--transition-fast);
        }
        
        .onboarding-toggle input:checked + .onboarding-toggle-slider {
            background: rgba(6, 182, 212, 0.2);
            border-color: var(--accent-cyan);
        }
        
        .onboarding-toggle input:checked + .onboarding-toggle-slider::before {
            transform: translateX(20px);
            background: var(--accent-cyan);
        }
        
        .onboarding-toggles {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: var(--spacing-md);
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }
        
        .onboarding-toggle-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: var(--spacing-md);
            cursor: pointer;
        }
        
        .onboarding-toggle-info {
            flex: 1;
            min-width: 0;
        }
        
        .onboarding-toggle-label {
            font-size: 0.85rem;
            font-weight: 500;
            color: var(--text-primary);
        }

        /* Onboarding steps */
        .onboarding-step {
            display: none;
        }

        .onboarding-step.active {
            display: block;
        }

        .onboarding-back-btn {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 12px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-full);
            color: var(--text-secondary);
            font-size: 0.8rem;
            font-weight: 500;
            cursor: pointer;
            transition: all var(--transition-fast);
            margin-bottom: var(--spacing-md);
        }

        .onboarding-back-btn:hover {
            background: var(--bg-hover);
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
        }

        .onboarding-form {
            margin-top: var(--spacing-md);
        }

        .onboarding-form .form-group {
            margin-bottom: var(--spacing-md);
        }

        .onboarding-form .form-label {
            display: block;
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--text-secondary);
            margin-bottom: 6px;
        }

        .onboarding-form .form-input {
            width: 100%;
            padding: 12px 14px;
            background: var(--bg-tertiary);
            border: 1px solid var(--border-primary);
            border-radius: var(--radius-md);
            color: var(--text-primary);
            font-size: 0.95rem;
            font-family: inherit;
            transition: all var(--transition-fast);
        }

        .onboarding-form .form-input:focus {
            outline: none;
            border-color: var(--accent-cyan);
            box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.1);
        }

        .onboarding-form .form-error {
            padding: 10px 14px;
            background: rgba(239, 68, 68, 0.1);
            border: 1px solid rgba(239, 68, 68, 0.3);
            border-radius: var(--radius-md);
            color: #f87171;
            font-size: 0.85rem;
            margin-top: var(--spacing-md);
        }

        .password-match-status {
            display: flex;
            align-items: center;
            gap: 6px;
            margin-top: 6px;
            font-size: 0.8rem;
            font-weight: 500;
        }

        .password-match-status.match {
            color: #4ade80;
        }

        .password-match-status.no-match {
            color: #f87171;
        }

        .password-match-status svg {
            width: 14px;
            height: 14px;
        }
        
        /* Onboarding categories section */
        .onboarding-section {
            margin-top: var(--spacing-md);
        }
        
        .onboarding-section-title {
            display: flex;
            align-items: center;
            gap: 8px;
            font-size: 0.8rem;
            font-weight: 600;
            color: var(--text-secondary);
            margin-bottom: var(--spacing-sm);
            text-transform: uppercase;
            letter-spacing: 0.05em;
        }
        
        .onboarding-section-title svg {
            color: var(--accent-cyan);
        }
        
        .onboarding-section-note {
            font-weight: 400;
            color: var(--text-muted);
            font-size: 0.75rem;
            text-transform: none;
            letter-spacing: 0;
        }
        
        .onboarding-categories-wrapper {
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            border: 1px solid var(--border-primary);
        }
        
        .onboarding-categories-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 8px 12px;
            border-bottom: 1px solid var(--border-primary);
        }
        
        .onboarding-categories-info {
            font-size: 0.75rem;
            color: var(--text-muted);
        }
        
        .onboarding-categories-info strong {
            color: var(--accent-cyan);
        }
        
        .onboarding-categories-actions {
            display: flex;
            gap: 6px;
        }
        
        .onboarding-categories-action-btn {
            padding: 3px 8px;
            font-size: 0.7rem;
            font-weight: 600;
            border-radius: 4px;
            border: 1px solid var(--border-primary);
            background: transparent;
            color: var(--text-muted);
            cursor: pointer;
            transition: all var(--transition-fast);
        }
        
        .onboarding-categories-action-btn:hover {
            border-color: var(--accent-cyan);
            color: var(--accent-cyan);
        }
        
        .onboarding-categories-grid {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            max-height: 140px;
            overflow-y: auto;
            padding: 12px;
        }
        
        .onboarding-category-chip {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 6px 10px;
            border-radius: var(--radius-full);
            font-size: 0.8rem;
            font-weight: 500;
            cursor: pointer;
            border: 1px solid var(--border-primary);
            background: var(--bg-secondary);
            color: var(--text-secondary);
            transition: all var(--transition-fast);
            white-space: nowrap;
        }
        
        .onboarding-category-chip:hover {
            border-color: var(--text-muted);
            background: var(--bg-hover);
        }
        
        .onboarding-category-chip.active {
            background: rgba(34, 197, 94, 0.15);
            border-color: rgba(34, 197, 94, 0.5);
            color: var(--text-primary);
        }
        
        .onboarding-category-chip .cat-check {
            width: 14px;
            height: 14px;
            border-radius: 3px;
            border: 1.5px solid var(--border-secondary);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: all var(--transition-fast);
        }
        
        .onboarding-category-chip.active .cat-check {
            background: #22c55e;
            border-color: #22c55e;
        }
        
        .onboarding-category-chip .cat-check svg {
            width: 8px;
            height: 8px;
            stroke: white;
            stroke-width: 3;
            opacity: 0;
        }
        
        .onboarding-category-chip.active .cat-check svg {
            opacity: 1;
        }
        
        .onboarding-category-chip .cat-icon {
            font-size: 0.9rem;
        }
        
        .onboarding-category-chip .cat-color {
            width: 8px;
            height: 8px;
            border-radius: 50%;
            flex-shrink: 0;
        }

        /* ========== Screen Reader Only (SEO h1) ========== */
        .sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
            border: 0;
        }

        /* ========== Footer ========== */
        .site-footer {
            margin-top: auto;
            padding: 24px 20px;
            text-align: center;
            color: var(--text-muted);
            font-size: 0.78rem;
            border-top: 1px solid var(--border-primary);
            background: var(--bg-primary);
        }
        .site-footer .footer-inner {
            max-width: 900px;
            margin: 0 auto;
            display: flex;
            flex-direction: column;
            gap: 8px;
            align-items: center;
        }
        .site-footer a {
            color: var(--text-secondary);
            text-decoration: none;
            transition: color 0.2s;
        }
        .site-footer a:hover {
            color: var(--accent-primary);
        }
        .site-footer nav {
            display: flex;
            flex-wrap: wrap;
            gap: 6px 16px;
            justify-content: center;
        }

        /* ========== No JavaScript Warning ========== */
        .noscript-warning {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: var(--bg-primary);
            z-index: 99999;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: var(--spacing-lg);
        }
        
        .noscript-box {
            background: var(--bg-secondary);
            border: 2px solid var(--accent-danger);
            border-radius: var(--radius-lg);
            padding: var(--spacing-xl);
            max-width: 500px;
            text-align: center;
            box-shadow: 0 0 40px rgba(244, 63, 94, 0.3);
        }
        
        .noscript-icon {
            font-size: 4rem;
            margin-bottom: var(--spacing-md);
        }
        
        .noscript-title {
            color: var(--accent-danger);
            font-size: 1.5rem;
            font-weight: 700;
            margin-bottom: var(--spacing-md);
        }
        
        .noscript-text {
            color: var(--text-secondary);
            line-height: 1.6;
            margin-bottom: var(--spacing-md);
        }
        
        .noscript-help {
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            padding: var(--spacing-md);
            font-size: 0.9rem;
            color: var(--text-muted);
        }
        
        /* ========== Preferences Panel Styles ========== */
        .pref-section {
            margin-bottom: var(--spacing-lg);
            padding-bottom: var(--spacing-lg);
            border-bottom: 1px solid var(--border-primary);
        }
        
        .pref-section:last-child {
            margin-bottom: 0;
            padding-bottom: 0;
            border-bottom: none;
        }
        
        .pref-section-title {
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: var(--spacing-sm);
            display: flex;
            align-items: center;
            gap: var(--spacing-sm);
        }
        
        .pref-section-desc {
            color: var(--text-muted);
            font-size: 0.85rem;
            margin-bottom: var(--spacing-md);
        }
        
        .pref-toggle {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: var(--spacing-md);
            background: var(--bg-tertiary);
            border-radius: var(--radius-md);
            margin-bottom: var(--spacing-md);
            border: 1px solid var(--border-primary);
        }
        
        .pref-toggle:last-child {
            margin-bottom: 0;
        }
        
        .pref-toggle-info {
            flex: 1;
        }
        
        .pref-toggle-label {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            font-weight: 700;
            color: var(--text-primary);
            margin-bottom: 2px;
            letter-spacing: 0.8px;
            text-transform: uppercase;
            font-size: 0.78rem;
        }

        .pref-toggle-label::before {
            content: '';
            width: 8px;
            height: 8px;
            border-radius: 50%;
            background: linear-gradient(135deg, var(--accent-primary) 0%, var(--accent-cyan) 100%);
            box-shadow: 0 0 10px rgba(168, 85, 247, 0.5);
            flex-shrink: 0;
        }
        
        .pref-toggle-desc {
            font-size: 0.8rem;
            color: var(--text-muted);
        }
        
        /* Toggle Switch - iOS Style */
        .toggle-switch {
            position: relative;
            display: inline-block;
            width: 52px;
            height: 28px;
            flex-shrink: 0;
            margin-left: var(--spacing-md);
        }
        
        .toggle-switch input {
            opacity: 0;
            width: 0;
            height: 0;
            position: absolute;
        }
        
        .toggle-slider {
            position: absolute;
            cursor: pointer;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: var(--bg-hover);
            border: 2px solid var(--border-secondary);
            border-radius: 28px;
            transition: all 0.3s ease;
        }
        
        .toggle-slider:before {
            position: absolute;
            content: "";
            height: 20px;
            width: 20px;
            left: 2px;
            top: 50%;
            transform: translateY(-50%);
            background: #666;
            border-radius: 50%;
            transition: all 0.3s ease;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
        }
        
        .toggle-switch input:checked + .toggle-slider {
            background: var(--accent-primary);
            border-color: var(--accent-primary);
        }
        
        .toggle-switch input:checked + .toggle-slider:before {
            transform: translateY(-50%) translateX(24px);
            background: white;
        }
        
        .toggle-switch:hover .toggle-slider {
            border-color: var(--accent-primary);
        }
        
        .toggle-switch input:focus + .toggle-slider {
            box-shadow: 0 0 0 2px rgba(168, 85, 247, 0.3);
        }

        /* Standalone div toggle (webhook/user lists - no inner input/slider) */
        .webhook-actions .toggle-switch,
        .user-actions .toggle-switch {
            cursor: pointer;
            border-radius: 28px;
            background: var(--bg-hover);
            border: 2px solid var(--border-secondary);
            transition: all 0.3s ease;
        }
        .webhook-actions .toggle-switch::after,
        .user-actions .toggle-switch::after {
            content: "";
            position: absolute;
            height: 20px;
            width: 20px;
            left: 2px;
            top: 50%;
            transform: translateY(-50%);
            background: #666;
            border-radius: 50%;
            transition: all 0.3s ease;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
        }
        .webhook-actions .toggle-switch.active,
        .user-actions .toggle-switch.active {
            background: var(--accent-primary);
            border-color: var(--accent-primary);
        }
        .webhook-actions .toggle-switch.active::after,
        .user-actions .toggle-switch.active::after {
            transform: translateY(-50%) translateX(24px);
            background: white;
        }
        .webhook-actions .toggle-switch:hover,
        .user-actions .toggle-switch:hover {
            border-color: var(--accent-primary);
        }

        /* ========== Reduced Motion ========== */
        @media (prefers-reduced-motion: reduce) {
            *, *::before, *::after {
                animation-duration: 0.01ms !important;
                animation-iteration-count: 1 !important;
                transition-duration: 0.01ms !important;
                scroll-behavior: auto !important;
            }

            .modal {
                transform: none !important;
            }

            .modal-overlay.active .modal {
                transform: none !important;
            }

            body::before {
                animation: none !important;
            }
        }

        /* ========== Backdrop Filter Fallback ========== */
        @supports not (backdrop-filter: blur(1px)) {
            .header {
                background: var(--bg-secondary);
            }

            .modal-overlay {
                background: rgba(5, 5, 8, 0.95);
            }

            .sidebar-overlay {
                background: rgba(0, 0, 0, 0.85);
            }
        }

        /* ========== Safe Area Insets ========== */
        @supports (padding: env(safe-area-inset-top)) {
            .header {
                padding-top: env(safe-area-inset-top);
                height: calc(var(--header-height) + env(safe-area-inset-top));
            }

            @media (max-width: 640px) {
                .modal {
                    padding-bottom: env(safe-area-inset-bottom);
                }

                .toast-container {
                    bottom: calc(var(--spacing-lg) + env(safe-area-inset-bottom));
                }

                .wizard-nav {
                    padding-bottom: calc(var(--spacing-lg) + env(safe-area-inset-bottom));
                }
            }
        }

        /* ========== Skeleton Loading ========== */
        @keyframes shimmer {
            0% { background-position: -200% 0; }
            100% { background-position: 200% 0; }
        }

        .calendar-body.loading .calendar-cell {
            position: relative;
        }

        .calendar-body.loading .calendar-cell::after {
            display: none !important;
        }

        .calendar-body.loading .day-events {
            opacity: 0.55 !important;
            visibility: visible !important;
            pointer-events: none !important;
            transition: opacity 0.18s ease !important;
        }

        /* =================================================================
           ✨ PREMIUM OLED REDESIGN — COMPLETE GROUND UP OVERHAUL
           ================================================================= */

        /* ── Design Tokens ─────────────────────────────────────────────── */
        :root {
            --bg-primary:   #000000 !important;
            --bg-secondary: #080810 !important;
            --bg-tertiary:  #0f0f1a !important;
            --bg-hover:     #16162a !important;
            --bg-active:    #1e1e35 !important;
            --border-primary:   rgba(255,255,255,0.08) !important;
            --border-secondary: rgba(255,255,255,0.14) !important;
            --text-primary:   #ffffff !important;
            --text-secondary: #e2e8f0 !important;
            --text-muted:     #94a3b8 !important;
            --accent-primary:  #a855f7;
            --accent-cyan:     #06b6d4;
            --accent-green:    #22c55e;
            --accent-danger:   #ef4444;
            --accent-warning:  #f59e0b;
            --glow-purple: rgba(168,85,247,0.35);
            --glow-cyan:   rgba(6,182,212,0.35);
        }

        /* ── Global Font ─────────────────────────────────────────────── */
        body, .modal, .settings-tabs, .btn, .form-label, .form-input,
        .form-select, .pref-section-title, .pref-toggle-label {
            font-family: 'Outfit', 'Inter', -apple-system, sans-serif !important;
        }

        /* ── Custom Scrollbars ──────────────────────────────────────── */
        ::-webkit-scrollbar { width: 5px; height: 5px; }
        ::-webkit-scrollbar-track { background: #000; }
        ::-webkit-scrollbar-thumb { background: rgba(168,85,247,0.3); border-radius: 10px; }
        ::-webkit-scrollbar-thumb:hover { background: rgba(168,85,247,0.55); }

        /* ═══════════════════════════════════════════════════════════════
           HEADER REDESIGN
        ════════════════════════════════════════════════════════════════ */
        .header {
            background: rgba(0,0,0,0.92) !important;
            border-bottom: 1px solid rgba(168,85,247,0.15) !important;
            backdrop-filter: blur(20px) !important;
            -webkit-backdrop-filter: blur(20px) !important;
        }

        /* ── Today Button ── */
        .btn-today {
            background: rgba(6,182,212,0.08) !important;
            border: 1px solid rgba(6,182,212,0.2) !important;
            border-left: 2px solid var(--accent-cyan) !important;
            color: var(--accent-cyan) !important;
            border-radius: 8px !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            padding: 7px 16px !important;
            transition: all 0.2s ease !important;
        }
        .btn-today:hover {
            background: rgba(6,182,212,0.15) !important;
            box-shadow: 0 0 14px rgba(6,182,212,0.2) !important;
            transform: translateY(-1px) !important;
        }
        .today-pulse {
            background: var(--accent-cyan) !important;
            box-shadow: 0 0 8px var(--accent-cyan) !important;
            animation: todayPulse 2s ease-in-out infinite !important;
        }
        @keyframes todayPulse {
            0%,100% { opacity:1; transform: translateY(-50%) scale(1); }
            50% { opacity:0.5; transform: translateY(-50%) scale(0.8); }
        }

        /* ── View Switcher (Month/Week/Day) ── */
        .view-switcher {
            background: #000 !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 10px !important;
            padding: 3px !important;
            gap: 2px !important;
            box-shadow: none !important;
        }
        .view-btn {
            background: transparent !important;
            border: 1px solid transparent !important;
            color: #64748b !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            font-weight: 600 !important;
            letter-spacing: 0.05em !important;
            text-transform: uppercase !important;
            border-radius: 7px !important;
            padding: 6px 14px !important;
            transition: all 0.15s ease !important;
        }
        .view-btn.active {
            background: rgba(168,85,247,0.15) !important;
            color: #c084fc !important;
            border-color: rgba(168,85,247,0.3) !important;
            border-left: 1px solid rgba(168,85,247,0.3) !important;
            box-shadow: 0 0 10px rgba(168,85,247,0.15) !important;
        }
        .view-btn:hover:not(.active) {
            color: #e2e8f0 !important;
            background: rgba(255,255,255,0.05) !important;
        }

        /* ══════════════════════════════════════════════════════════════
           + NEW EVENT BUTTON — BOLD, BRIGHT, UNMISSABLE CTA
        ═══════════════════════════════════════════════════════════════ */
        .new-event-btn {
            display: inline-flex !important;
            align-items: center !important;
            gap: 8px !important;
            padding: 9px 20px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.88rem !important;
            font-weight: 700 !important;
            letter-spacing: 0.02em !important;
            text-transform: none !important;
            color: #ffffff !important;
            background: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #c084fc 100%) !important;
            border: 1px solid rgba(168,85,247,0.5) !important;
            border-radius: 10px !important;
            box-shadow: 0 0 20px rgba(168,85,247,0.35), 0 4px 12px rgba(0,0,0,0.5) !important;
            position: relative !important;
            overflow: hidden !important;
            transition: all 0.2s cubic-bezier(0.16,1,0.3,1) !important;
        }
        .new-event-btn::before {
            content: '' !important;
            position: absolute !important;
            inset: 0 !important;
            background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 60%) !important;
            pointer-events: none !important;
        }
        .new-event-btn span {
            display: inline-flex !important;
            align-items: center !important;
            justify-content: center !important;
            width: 20px !important;
            height: 20px !important;
            background: rgba(255,255,255,0.2) !important;
            border-radius: 5px !important;
            font-size: 1.1rem !important;
            font-weight: 800 !important;
            line-height: 1 !important;
            border: none !important;
            color: #fff !important;
        }
        .new-event-btn:hover {
            transform: translateY(-2px) !important;
            box-shadow: 0 0 30px rgba(168,85,247,0.55), 0 8px 20px rgba(0,0,0,0.6) !important;
            background: linear-gradient(135deg, #8b46ff 0%, #b46fff 50%, #d09aff 100%) !important;
        }
        .new-event-btn:active {
            transform: translateY(0) !important;
        }

        /* ── Ghost / Icon Buttons — Readable on pure black header ── */
        .btn-ghost, .btn-icon.btn-ghost {
            background: transparent !important;
            border: 1px solid transparent !important;
            color: #94a3b8 !important;
            border-radius: 8px !important;
            transition: all 0.15s ease !important;
        }
        .btn-ghost:hover, .btn-icon.btn-ghost:hover {
            background: rgba(255,255,255,0.06) !important;
            color: #f1f5f9 !important;
            border-color: rgba(255,255,255,0.12) !important;
        }

        /* ── User Menu ── */
        .user-menu {
            background: rgba(168,85,247,0.06) !important;
            border: 1px solid rgba(168,85,247,0.15) !important;
            border-left: 2px solid rgba(168,85,247,0.4) !important;
            border-radius: 8px !important;
        }
        .user-name { color: #c084fc !important; font-weight: 600 !important; }

        /* ═══════════════════════════════════════════════════════════════
           MODAL BASE — GLASSY DARK
        ════════════════════════════════════════════════════════════════ */
        .modal-overlay {
            background: rgba(0,0,0,0.75) !important;
            backdrop-filter: blur(6px) !important;
            -webkit-backdrop-filter: blur(6px) !important;
            transition: opacity 120ms ease, visibility 120ms ease !important;
        }

        .modal {
            background: #080810 !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 18px !important;
            box-shadow:
                0 0 0 1px rgba(168,85,247,0.08),
                0 30px 80px rgba(0,0,0,0.9),
                0 0 40px rgba(168,85,247,0.08) !important;
            transform: translateY(12px) scale(0.97) !important;
            transition: transform 120ms cubic-bezier(0.2, 0.8, 0.2, 1), opacity 120ms ease !important;
        }
        .modal-overlay.active .modal {
            transform: translateY(0) scale(1) !important;
        }

        .modal-header {
            padding: 18px 24px 14px !important;
            border-bottom: 1px solid rgba(255,255,255,0.07) !important;
            background: rgba(255,255,255,0.02) !important;
            border-radius: 18px 18px 0 0 !important;
        }
        .modal-title {
            font-size: 1.15rem !important;
            font-weight: 700 !important;
            color: #ffffff !important;
            letter-spacing: -0.01em !important;
        }
        .modal-close {
            width: 32px !important;
            height: 32px !important;
            background: rgba(255,255,255,0.06) !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 8px !important;
            color: #64748b !important;
            font-size: 1.2rem !important;
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            transition: all 0.15s ease !important;
        }
        .modal-close:hover {
            background: rgba(239,68,68,0.15) !important;
            border-color: rgba(239,68,68,0.3) !important;
            color: #f87171 !important;
        }
        .modal-footer {
            background: rgba(0,0,0,0.3) !important;
            border-top: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 0 0 18px 18px !important;
        }

        /* ═══════════════════════════════════════════════════════════════
           SETTINGS MODAL — REDESIGNED split-pane vertical sidebar
        ════════════════════════════════════════════════════════════════ */
        .settings-modal-wide {
            max-width: 950px !important;
            width: 90% !important;
            height: 80vh !important;
            max-height: 80vh !important;
            display: flex !important;
            flex-direction: column !important;
        }

        #settingsModal .modal-body {
            flex: 1 !important;
            padding: 0 !important;
            overflow: hidden !important;
            display: flex !important;
            flex-direction: column !important;
        }

        /* ── Settings Container (Split Pane) ── */
        .settings-container {
            display: flex !important;
            flex-direction: row !important;
            height: 100% !important;
            min-height: 0 !important;
            flex: 1 !important;
            overflow: hidden !important;
        }

        /* ── Settings Sidebar (Tabs) ── */
        .settings-tabs {
            display: flex !important;
            flex-direction: column !important;
            flex-shrink: 0 !important;
            width: 230px !important;
            background: #000000 !important;
            border-right: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-bottom: none !important;
            padding: 16px 8px !important;
            gap: 4px !important;
            position: relative !important;
            top: 0 !important;
            z-index: 10 !important;
            overflow-y: auto !important;
            height: 100% !important;
        }

        .settings-tab {
            display: flex !important;
            align-items: center !important;
            gap: 10px !important;
            padding: 12px 14px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.85rem !important;
            font-weight: 600 !important;
            color: #64748b !important;
            background: transparent !important;
            border: none !important;
            border-bottom: none !important;
            border-left: 3px solid transparent !important;
            border-radius: 8px !important;
            cursor: pointer !important;
            white-space: nowrap !important;
            transition: all 0.2s ease !important;
            margin-bottom: 0 !important;
            text-align: left !important;
            width: auto !important;
        }

        .settings-tab:hover {
            color: #e2e8f0 !important;
            background: rgba(255, 255, 255, 0.03) !important;
        }

        .settings-tab.active {
            color: #c084fc !important;
            border-left-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.08) !important;
            border-bottom-color: transparent !important;
            border-radius: 0 8px 8px 0 !important;
        }

        /* ── Settings Content Area ── */
        .settings-content {
            flex: 1 !important;
            overflow-y: auto !important;
            background: #040408 !important;
            height: 100% !important;
            padding: 28px !important;
        }

        /* ── Settings Panels ── */
        .settings-panel {
            display: none;
            flex: 1;
        }
        .settings-panel.active {
            display: block;
        }

        /* Pulsing Webhook Status Dots */
        .webhook-item {
            display: flex !important;
            justify-content: space-between !important;
            align-items: center !important;
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 12px !important;
            padding: 16px 20px !important;
            margin-bottom: 12px !important;
            transition: all 0.2s ease !important;
        }
        .webhook-item:hover {
            border-color: rgba(168, 85, 247, 0.3) !important;
            box-shadow: 0 6px 20px rgba(0,0,0,0.6), 0 0 12px rgba(168,85,247,0.1) !important;
            transform: translateY(-1.5px) !important;
        }
        .webhook-item.disabled {
            opacity: 0.55 !important;
        }
        .webhook-item .webhook-name {
            display: flex !important;
            align-items: center !important;
            gap: 8px !important;
            font-size: 0.95rem !important;
            font-weight: 700 !important;
            color: #ffffff !important;
        }
        .webhook-item:not(.disabled) .webhook-name::after {
            content: "" !important;
            display: inline-block !important;
            width: 7px !important;
            height: 7px !important;
            background-color: var(--accent-green) !important;
            border-radius: 50% !important;
            box-shadow: 0 0 8px var(--accent-green) !important;
            animation: webhookStatusPulse 2s infinite !important;
        }
        .webhook-item.disabled .webhook-name::after {
            content: "" !important;
            display: inline-block !important;
            width: 7px !important;
            height: 7px !important;
            background-color: var(--text-muted) !important;
            border-radius: 50% !important;
            opacity: 0.4 !important;
        }
        @keyframes webhookStatusPulse {
            0% { transform: scale(0.9); opacity: 0.7; box-shadow: 0 0 4px var(--accent-green); }
            50% { transform: scale(1.15); opacity: 1; box-shadow: 0 0 12px var(--accent-green); }
            100% { transform: scale(0.9); opacity: 0.7; box-shadow: 0 0 4px var(--accent-green); }
        }

        .webhook-pill {
            background: rgba(255, 255, 255, 0.04) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: var(--text-secondary) !important;
            border-radius: 6px !important;
            padding: 3px 8px !important;
            font-size: 0.72rem !important;
            font-weight: 500 !important;
            display: inline-flex !important;
            align-items: center !important;
            gap: 4px !important;
            margin-right: 4px !important;
            margin-bottom: 4px !important;
        }
        .webhook-pill.pill-trigger {
            background: rgba(168, 85, 247, 0.08) !important;
            border-color: rgba(168, 85, 247, 0.2) !important;
            color: #c084fc !important;
        }
        .webhook-pill.pill-mention {
            background: rgba(6, 182, 212, 0.08) !important;
            border-color: rgba(6, 182, 212, 0.2) !important;
            color: #22d3ee !important;
        }

        /* Responsive Mobile Layout Override */
        @media (max-width: 768px) {
            .settings-modal-wide {
                max-width: 100% !important;
                width: 95% !important;
                height: 85vh !important;
                max-height: 85vh !important;
            }

            .settings-container {
                flex-direction: column !important;
            }

            .settings-tabs {
                flex-direction: row !important;
                width: 100% !important;
                height: auto !important;
                border-right: none !important;
                border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
                padding: 10px 8px !important;
                overflow-x: auto !important;
                overflow-y: hidden !important;
                white-space: nowrap !important;
                gap: 6px !important;
                -webkit-overflow-scrolling: touch !important;
            }

            .settings-tab {
                display: inline-flex !important;
                padding: 8px 14px !important;
                border: 1px solid rgba(255, 255, 255, 0.08) !important;
                border-radius: 20px !important;
                background: #0f0f1a !important;
                gap: 6px !important;
                font-size: 0.78rem !important;
            }

            .settings-tab.active {
                background: var(--accent-primary) !important;
                color: #ffffff !important;
                border-left-color: transparent !important;
                border-color: var(--accent-primary) !important;
                border-radius: 20px !important;
            }

            .settings-content {
                padding: 18px !important;
            }
        }

        /* ── Preference Sections ── */
        .pref-section {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 14px !important;
            padding: 20px !important;
            margin-bottom: 16px !important;
        }
        .pref-section:last-child { margin-bottom: 0 !important; }
        .pref-section-title {
            font-size: 0.95rem !important;
            font-weight: 700 !important;
            color: #f1f5f9 !important;
            margin-bottom: 4px !important;
            display: flex !important;
            align-items: center !important;
            gap: 8px !important;
        }
        .pref-section-desc {
            font-size: 0.82rem !important;
            color: #64748b !important;
            margin-bottom: 16px !important;
            line-height: 1.5 !important;
        }

        /* ── Preference Toggle Row ── */
        .pref-toggle {
            display: flex !important;
            align-items: center !important;
            justify-content: space-between !important;
            padding: 14px 16px !important;
            background: #000 !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 10px !important;
            margin-bottom: 10px !important;
            gap: 16px !important;
        }
        .pref-toggle:last-child { margin-bottom: 0 !important; }
        .pref-toggle-info { flex: 1 !important; min-width: 0 !important; }
        .pref-toggle-label {
            font-size: 0.88rem !important;
            font-weight: 600 !important;
            color: #e2e8f0 !important;
            margin-bottom: 2px !important;
            display: block !important;
            letter-spacing: 0 !important;
            text-transform: none !important;
        }
        .pref-toggle-label::before { display: none !important; }
        .pref-toggle-desc {
            font-size: 0.78rem !important;
            color: #475569 !important;
        }

        /* ── Toggle Switches — Pill Style ── */
        .toggle-switch {
            width: 44px !important;
            height: 24px !important;
            border-radius: 12px !important;
            flex-shrink: 0 !important;
            margin-left: 8px !important;
        }
        .toggle-slider {
            background: #1e1e35 !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
            border-radius: 12px !important;
            transition: all 0.25s cubic-bezier(0.16,1,0.3,1) !important;
        }
        .toggle-slider:before {
            width: 16px !important;
            height: 16px !important;
            border-radius: 50% !important;
            background: #475569 !important;
            left: 3px !important;
            box-shadow: 0 1px 4px rgba(0,0,0,0.5) !important;
            transition: all 0.25s cubic-bezier(0.16,1,0.3,1) !important;
        }
        .toggle-switch input:checked + .toggle-slider {
            background: #7c3aed !important;
            border-color: rgba(168,85,247,0.4) !important;
            box-shadow: 0 0 12px rgba(168,85,247,0.4) !important;
        }
        .toggle-switch input:checked + .toggle-slider:before {
            transform: translateY(-50%) translateX(20px) !important;
            background: #ffffff !important;
            box-shadow: 0 2px 6px rgba(168,85,247,0.5) !important;
        }
        .toggle-switch:hover .toggle-slider {
            border-color: rgba(168,85,247,0.35) !important;
        }
        .toggle-switch input:focus + .toggle-slider {
            box-shadow: 0 0 0 3px rgba(168,85,247,0.25) !important;
        }

        /* Standalone div toggles in lists */
        .webhook-actions .toggle-switch,
        .user-actions .toggle-switch {
            border-radius: 12px !important;
            background: #1e1e35 !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
        }
        .webhook-actions .toggle-switch::after,
        .user-actions .toggle-switch::after {
            width: 16px !important;
            height: 16px !important;
            border-radius: 50% !important;
            background: #475569 !important;
            left: 3px !important;
            box-shadow: 0 1px 4px rgba(0,0,0,0.5) !important;
            transition: all 0.25s cubic-bezier(0.16,1,0.3,1) !important;
        }
        .webhook-actions .toggle-switch.active,
        .user-actions .toggle-switch.active {
            background: #7c3aed !important;
            border-color: rgba(168,85,247,0.4) !important;
            box-shadow: 0 0 12px rgba(168,85,247,0.4) !important;
        }
        .webhook-actions .toggle-switch.active::after,
        .user-actions .toggle-switch.active::after {
            transform: translateY(-50%) translateX(20px) !important;
            background: #ffffff !important;
        }
        .webhook-actions .toggle-switch:hover,
        .user-actions .toggle-switch:hover {
            border-color: rgba(168,85,247,0.35) !important;
        }

        /* ── Form Controls ── */
        .form-input, .form-select, textarea.form-input, .wizard-input-large {
            background: #000 !important;
            color: #f1f5f9 !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
            border-radius: 10px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.9rem !important;
            transition: all 0.15s ease !important;
        }
        .form-input:focus, .form-select:focus, textarea.form-input:focus, .wizard-input-large:focus {
            border-color: rgba(168,85,247,0.6) !important;
            box-shadow: 0 0 0 3px rgba(168,85,247,0.15) !important;
            outline: none !important;
            background: #080810 !important;
        }
        .form-input::placeholder, .wizard-input-large::placeholder { color: #334155 !important; }
        .form-label {
            font-size: 0.82rem !important;
            font-weight: 600 !important;
            color: #94a3b8 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.06em !important;
        }
        .form-select option { background: #080810 !important; color: #f1f5f9 !important; }

        /* ── Webhook Cron Notice ── */
        .webhook-cron-notice {
            background: rgba(168,85,247,0.05) !important;
            border: 1px solid rgba(168,85,247,0.15) !important;
            border-radius: 12px !important;
        }

        /* ── Webhook / Category / User List Items ── */
        .webhook-item {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 12px !important;
            transition: all 0.2s ease !important;
        }
        .webhook-item:hover {
            border-color: rgba(168,85,247,0.3) !important;
            box-shadow: 0 6px 20px rgba(0,0,0,0.5), 0 0 12px rgba(168,85,247,0.08) !important;
            transform: translateY(-1px) !important;
        }
        .webhook-item.disabled { opacity: 0.4 !important; }

        .category-manage-item {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 12px !important;
            transition: all 0.15s ease !important;
        }
        .category-manage-item:hover {
            border-color: rgba(168,85,247,0.25) !important;
            transform: translateY(-1px) !important;
        }

        /* ── Trigger Pills (webhooks) ── */
        .wh-trigger-pill {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 8px !important;
            color: #64748b !important;
            font-family: 'Outfit', sans-serif !important;
            transition: all 0.15s ease !important;
        }
        .wh-trigger-pill:hover {
            border-color: rgba(168,85,247,0.3) !important;
            color: #c084fc !important;
            background: rgba(168,85,247,0.06) !important;
        }
        .wh-trigger-pill:has(input:checked),
        .wh-trigger-pill.active {
            background: rgba(168,85,247,0.12) !important;
            border-color: rgba(168,85,247,0.4) !important;
            color: #c084fc !important;
        }

        /* ── Webhook Wizard Steps ── */
        .wh-wizard-step {
            color: #475569 !important;
        }
        .wh-wizard-step::before {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 50% !important;
            color: #475569 !important;
        }
        .wh-wizard-step.active { color: #e2e8f0 !important; }
        .wh-wizard-step.active::before {
            background: #7c3aed !important;
            border-color: #a855f7 !important;
            color: #fff !important;
            box-shadow: 0 0 12px rgba(168,85,247,0.5) !important;
        }
        .wh-wizard-step.completed::before {
            background: rgba(34,197,94,0.2) !important;
            border-color: #22c55e !important;
            color: #22c55e !important;
        }
        .wh-wizard-step + .wh-wizard-step::after {
            background: rgba(255,255,255,0.07) !important;
        }
        .wh-section {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 10px !important;
        }
        .wh-section-title { color: #e2e8f0 !important; font-family: 'Outfit', sans-serif !important; }
        .wh-wizard-copy-select {
            background: rgba(34,197,94,0.03) !important;
            border: 1px dashed rgba(34,197,94,0.2) !important;
            border-radius: 8px !important;
        }

        /* ── Bot Audit Table ── */
        .table {
            border-collapse: collapse !important;
            width: 100% !important;
        }
        .table thead th {
            background: #0f0f1a !important;
            color: #94a3b8 !important;
            border-bottom: 1px solid rgba(255,255,255,0.08) !important;
            padding: 10px 14px !important;
            font-size: 0.75rem !important;
            font-weight: 700 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.08em !important;
        }
        .table tbody tr {
            border-bottom: 1px solid rgba(255,255,255,0.04) !important;
            transition: background 0.1s !important;
        }
        .table tbody tr:hover { background: rgba(255,255,255,0.02) !important; }
        .table tbody td {
            padding: 10px 14px !important;
            font-size: 0.83rem !important;
            color: #e2e8f0 !important;
        }
        #panel-botaudit > div {
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 12px !important;
            overflow: hidden !important;
        }

        /* ── SQL Import ── */
        #sqlImportResults table { border-collapse: collapse !important; }
        #sqlImportResults th {
            background: #0f0f1a !important;
            color: #94a3b8 !important;
            padding: 8px 12px !important;
            font-size: 0.75rem !important;
            font-weight: 700 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.06em !important;
            border-bottom: 1px solid rgba(255,255,255,0.08) !important;
        }
        #sqlImportResults td { padding: 8px 12px !important; color: #e2e8f0 !important; }

        /* ── Drag & Drop Upload Areas ── */
        #defaultOgImageUpload, #sqlDropZone {
            background: #000 !important;
            border: 2px dashed rgba(255,255,255,0.12) !important;
            border-radius: 14px !important;
            color: #475569 !important;
            transition: all 0.2s ease !important;
        }
        #defaultOgImageUpload:hover, #sqlDropZone:hover,
        #defaultOgImageUpload.dragover, #sqlDropZone.dragover {
            border-color: rgba(168,85,247,0.5) !important;
            background: rgba(168,85,247,0.04) !important;
            box-shadow: 0 0 20px rgba(168,85,247,0.1) !important;
        }

        /* ── Cron Hero Banner ── */
        .cron-hero-banner {
            background: linear-gradient(135deg, #0f0f1a 0%, #080810 100%) !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 14px !important;
        }

        /* ── Setup Guide ── */
        .setup-guide {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 14px !important;
            overflow: hidden !important;
        }
        .setup-guide-header { background: transparent !important; }
        .setup-guide-header:hover { background: rgba(255,255,255,0.02) !important; }
        .setup-guide-body { border-top: 1px solid rgba(255,255,255,0.06) !important; }
        .setup-step { border-bottom: 1px solid rgba(255,255,255,0.05) !important; }
        .setup-code-block {
            background: #000 !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 8px !important;
        }
        .setup-code-highlight {
            border-color: rgba(168,85,247,0.25) !important;
            background: linear-gradient(135deg, #0a0a12 0%, #000 100%) !important;
        }
        .setup-details {
            border: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 8px !important;
        }
        .setup-details summary {
            background: #0f0f1a !important;
            color: #64748b !important;
        }
        .setup-details summary:hover {
            background: #16162a !important;
            color: #94a3b8 !important;
        }

        /* ── Details/Summary Global ── */
        details > summary {
            list-style: none !important;
            cursor: pointer !important;
        }
        details > summary::-webkit-details-marker { display: none !important; }

        /* ── Cron Section ── */
        .cron-section-header {
            border-bottom: 1px solid rgba(255,255,255,0.07) !important;
        }

        /* ═══════════════════════════════════════════════════════════════
           NEW EVENT WIZARD POPUP
        ════════════════════════════════════════════════════════════════ */
        .wizard-container {
            overflow: hidden !important;
        }
        .wizard-progress {
            background: #000 !important;
            border-bottom: 1px solid rgba(255,255,255,0.07) !important;
            padding: 16px 20px !important;
            gap: 6px !important;
        }
        .wizard-step-indicator {
            background: #0f0f1a !important;
            color: #475569 !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 8px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            padding: 6px 14px !important;
            transition: all 0.15s ease !important;
        }
        .wizard-step-indicator:hover { color: #94a3b8 !important; }
        .wizard-step-indicator .step-num {
            background: rgba(255,255,255,0.08) !important;
            border-radius: 5px !important;
            width: 20px !important;
            height: 20px !important;
            color: #475569 !important;
        }
        .wizard-step-indicator.active {
            background: rgba(168,85,247,0.12) !important;
            color: #c084fc !important;
            border-color: rgba(168,85,247,0.35) !important;
        }
        .wizard-step-indicator.active .step-num {
            background: #7c3aed !important;
            color: #fff !important;
        }
        .wizard-step-indicator.completed {
            background: rgba(34,197,94,0.08) !important;
            color: #4ade80 !important;
            border-color: rgba(34,197,94,0.25) !important;
        }
        .wizard-step-indicator.completed .step-num {
            background: #16a34a !important;
            color: #fff !important;
        }

        .wizard-input-large {
            background: #000 !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
            border-radius: 12px !important;
            color: #f1f5f9 !important;
            font-size: 1.2rem !important;
            font-weight: 500 !important;
            padding: 14px 18px !important;
        }
        .wizard-input-large:focus {
            border-color: rgba(168,85,247,0.6) !important;
            box-shadow: 0 0 0 3px rgba(168,85,247,0.12) !important;
            background: #080810 !important;
        }
        .wizard-textarea {
            background: #000 !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
            border-radius: 10px !important;
            color: #f1f5f9 !important;
            font-family: 'Outfit', sans-serif !important;
        }
        .wizard-textarea:focus {
            border-color: rgba(168,85,247,0.6) !important;
            box-shadow: 0 0 0 3px rgba(168,85,247,0.12) !important;
            outline: none !important;
        }
        .wizard-step-title {
            color: #f1f5f9 !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
        }
        .wizard-step-subtitle { color: #475569 !important; }
        .wizard-tz-hint {
            background: rgba(168,85,247,0.06) !important;
            border: 1px solid rgba(168,85,247,0.15) !important;
            border-radius: 8px !important;
            color: #94a3b8 !important;
        }

        /* Quick Start Panel */
        .qs-choice-btn {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 12px !important;
            transition: all 0.2s ease !important;
        }
        .qs-choice-btn:hover {
            border-color: rgba(168,85,247,0.4) !important;
            background: rgba(168,85,247,0.06) !important;
            transform: translateY(-2px) !important;
            box-shadow: 0 8px 20px rgba(0,0,0,0.4), 0 0 15px rgba(168,85,247,0.1) !important;
        }
        .qs-choice-label { color: #f1f5f9 !important; font-family: 'Outfit', sans-serif !important; }
        .qs-choice-desc { color: #475569 !important; }

        /* Date/Time Cards in wizard */
        .datetime-card {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 12px !important;
        }
        .datetime-card:focus-within {
            border-color: rgba(168,85,247,0.4) !important;
            box-shadow: 0 0 0 3px rgba(168,85,247,0.1) !important;
        }
        .datetime-card input[type=date],
        .datetime-card input[type=time] {
            color-scheme: dark !important;
            background: transparent !important;
            color: #f1f5f9 !important;
            border: none !important;
        }

        /* Quick date/time pickers */
        .quick-date-grid .quick-date-btn,
        .quick-time-grid .quick-option {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 8px !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            transition: all 0.15s ease !important;
        }
        .quick-date-grid .quick-date-btn:hover,
        .quick-time-grid .quick-option:hover {
            border-color: rgba(168,85,247,0.35) !important;
            color: #c084fc !important;
            background: rgba(168,85,247,0.07) !important;
        }
        .quick-date-grid .quick-date-btn.active,
        .quick-time-grid .quick-option.selected {
            background: rgba(168,85,247,0.15) !important;
            border-color: rgba(168,85,247,0.5) !important;
            color: #c084fc !important;
        }

        /* Wizard nav */
        .wizard-nav {
            background: #000 !important;
            border-top: 1px solid rgba(255,255,255,0.07) !important;
        }

        /* ═══════════════════════════════════════════════════════════════
           UNIVERSAL BUTTON REDESIGN
        ════════════════════════════════════════════════════════════════ */
        .btn {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            border-radius: 9px !important;
            transition: all 0.18s ease !important;
        }
        /* Inside modals/settings: real filled primary */
        .modal .btn-primary,
        .settings-panel .btn-primary,
        .cron-modal .btn-primary {
            background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
            color: #ffffff !important;
            border: 1px solid rgba(168,85,247,0.4) !important;
            box-shadow: 0 0 14px rgba(168,85,247,0.25) !important;
        }
        .modal .btn-primary:hover,
        .settings-panel .btn-primary:hover,
        .cron-modal .btn-primary:hover {
            transform: translateY(-1px) !important;
            box-shadow: 0 0 20px rgba(168,85,247,0.4) !important;
            background: linear-gradient(135deg, #8b46ff, #b46fff) !important;
        }
        .modal .btn-secondary,
        .settings-panel .btn-secondary,
        .cron-modal .btn-secondary {
            background: rgba(255,255,255,0.05) !important;
            border: 1px solid rgba(255,255,255,0.12) !important;
            color: #e2e8f0 !important;
        }
        .modal .btn-secondary:hover,
        .settings-panel .btn-secondary:hover,
        .cron-modal .btn-secondary:hover {
            background: rgba(255,255,255,0.09) !important;
            border-color: rgba(255,255,255,0.2) !important;
            transform: translateY(-1px) !important;
        }
        .modal .btn-ghost,
        .settings-panel .btn-ghost,
        .cron-modal .btn-ghost {
            background: transparent !important;
            border: 1px solid transparent !important;
            color: #64748b !important;
        }
        .modal .btn-ghost:hover,
        .settings-panel .btn-ghost:hover,
        .cron-modal .btn-ghost:hover {
            background: rgba(255,255,255,0.04) !important;
            border-color: rgba(255,255,255,0.08) !important;
            color: #94a3b8 !important;
        }
        .modal .btn-danger,
        .settings-panel .btn-danger {
            background: rgba(239,68,68,0.12) !important;
            color: #f87171 !important;
            border: 1px solid rgba(239,68,68,0.25) !important;
        }
        .modal .btn-danger:hover,
        .settings-panel .btn-danger:hover {
            background: rgba(239,68,68,0.2) !important;
            box-shadow: 0 0 14px rgba(239,68,68,0.2) !important;
        }

        /* ── Cron Modal ── */
        .cron-modal-overlay { background: rgba(0,0,0,0.85) !important; }
        .cron-modal {
            background: #080810 !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 18px !important;
            box-shadow: 0 30px 80px rgba(0,0,0,0.9) !important;
        }
        .cron-modal-header {
            background: rgba(168,85,247,0.06) !important;
            border-bottom: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 18px 18px 0 0 !important;
        }
        .cron-modal-icon {
            background: rgba(168,85,247,0.15) !important;
            border-color: rgba(168,85,247,0.25) !important;
            border-radius: 10px !important;
        }
        .cron-modal-footer {
            background: #000 !important;
            border-top: 1px solid rgba(255,255,255,0.07) !important;
            border-radius: 0 0 18px 18px !important;
        }
        .cron-modal-close {
            background: rgba(255,255,255,0.05) !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            color: #64748b !important;
            border-radius: 8px !important;
        }
        .cron-modal-close:hover {
            background: rgba(239,68,68,0.15) !important;
            border-color: rgba(239,68,68,0.3) !important;
            color: #f87171 !important;
        }

        /* ── Login / Register / Day / View Modals ── */
        #loginModal .modal,
        #registerModal .modal,
        #changePasswordModal .modal,
        #resetPasswordModal .modal {
            background: #080810 !important;
        }
        #dayModal .modal,
        #viewModal .modal,
        #editModal .modal {
            background: #080810 !important;
        }

        /* ── Event View Modal Details ── */
        .event-detail-title { color: #f1f5f9 !important; font-family: 'Outfit', sans-serif !important; }
        .event-detail-meta { color: #64748b !important; }
        .rsvp-btn {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            border-radius: 9px !important;
        }

        /* ── Toast Notifications ── */
        .toast {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.1) !important;
            border-radius: 12px !important;
            box-shadow: 0 10px 30px rgba(0,0,0,0.7) !important;
            font-family: 'Outfit', sans-serif !important;
            color: #f1f5f9 !important;
        }
        .toast.toast-success { border-left: 3px solid #22c55e !important; }

        /* ========== PREMIUM OLED STYLE OVERRIDES ========== */

        :root {
            --bg-primary: #000000 !important;
            --bg-secondary: #000000 !important;
            --bg-tertiary: #05050c !important;
            --bg-hover: #0d0d1a !important;
            --bg-active: #15152a !important;
            --border-primary: rgba(255, 255, 255, 0.08) !important;
            --border-secondary: rgba(255, 255, 255, 0.12) !important;
        }

        /* ── Scrollbars OLED Tuning ── */
        ::-webkit-scrollbar {
            width: 8px !important;
            height: 8px !important;
        }
        ::-webkit-scrollbar-track {
            background: #000000 !important;
        }
        ::-webkit-scrollbar-thumb {
            background: #15152a !important;
            border-radius: 4px !important;
            border: 2px solid #000000 !important;
        }
        ::-webkit-scrollbar-thumb:hover {
            background: #a855f7 !important;
        }

        .toast.toast-error   { border-left: 3px solid #ef4444 !important; }
        .toast.toast-info    { border-left: 3px solid #a855f7 !important; }
        .toast.toast-warning { border-left: 3px solid #f59e0b !important; }

        /* ── Discord Preview Box ── */
        .discord-preview {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 10px !important;
        }

        /* ── Cron Type Card ── */
        .cron-type-card {
            background: #0f0f1a !important;
            border: 2px solid rgba(255,255,255,0.07) !important;
            border-radius: 12px !important;
            transition: all 0.15s ease !important;
        }
        .cron-type-card:hover { border-color: rgba(168,85,247,0.3) !important; }
        .cron-type-card.selected {
            border-color: rgba(168,85,247,0.5) !important;
            background: rgba(168,85,247,0.06) !important;
        }

        /* ── Admin Events List ── */
        .admin-filter-btn {
            background: #0f0f1a !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            color: #64748b !important;
            font-family: 'Outfit', sans-serif !important;
            border-radius: 7px !important;
            transition: all 0.15s ease !important;
        }
        .admin-filter-btn.active {
            background: rgba(168,85,247,0.12) !important;
            border-color: rgba(168,85,247,0.35) !important;
            color: #c084fc !important;
        }
        .admin-filter-btn:hover:not(.active) {
            color: #94a3b8 !important;
            background: rgba(255,255,255,0.04) !important;
        }

        /* ── Preferences Modal Specifics ── */
        #preferencesModal .modal {
            background: #080810 !important;
        }
        #preferencesModal .pref-section:last-child {
            border-bottom: none !important;
        }

        /* ========== PREMIUM OLED STYLE OVERRIDES ========== */

        /* ── Header Branding & Logo ── */
        .logo {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 900 !important;
            letter-spacing: -0.02em !important;
            transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        .logo-icon {
            background: linear-gradient(135deg, #a855f7, #06b6d4) !important;
            -webkit-background-clip: text !important;
            -webkit-text-fill-color: transparent !important;
            background-clip: text !important;
            font-weight: 900 !important;
            filter: drop-shadow(0 0 10px rgba(168, 85, 247, 0.25)) !important;
        }
        .logo-text {
            font-weight: 800 !important;
            letter-spacing: -0.01em !important;
            background: linear-gradient(90deg, #ffffff, #cbd5e1) !important;
            -webkit-background-clip: text !important;
            -webkit-text-fill-color: transparent !important;
            background-clip: text !important;
        }
        .logo-dot {
            color: #06b6d4 !important;
            -webkit-text-fill-color: #06b6d4 !important;
            text-shadow: 0 0 8px rgba(6, 182, 212, 0.4) !important;
        }
        .logo-divider {
            color: rgba(255, 255, 255, 0.12) !important;
            margin: 0 12px !important;
        }
        .page-title {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.08em !important;
            font-size: 0.8rem !important;
            color: #94a3b8 !important;
        }

        /* ── Header Date Navigation Controls ── */
        .nav-controls {
            gap: 10px !important;
        }
        .nav-controls .btn-ghost {
            width: 32px !important;
            height: 32px !important;
            padding: 0 !important;
            display: inline-flex !important;
            align-items: center !important;
            justify-content: center !important;
            border-radius: 50% !important;
            background: rgba(255, 255, 255, 0.03) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #94a3b8 !important;
            transition: all 0.2s ease !important;
        }
        .nav-controls .btn-ghost:hover {
            background: rgba(168, 85, 247, 0.08) !important;
            border-color: rgba(168, 85, 247, 0.3) !important;
            color: #c084fc !important;
            transform: scale(1.05) !important;
        }
        .current-date {
            font-family: 'Outfit', sans-serif !important;
            font-size: 1.35rem !important;
            font-weight: 800 !important;
            color: #ffffff !important;
            letter-spacing: -0.01em !important;
            min-width: unset !important;
            margin-left: 4px !important;
        }
        .current-date::after {
            background: linear-gradient(90deg, #06b6d4, #a855f7) !important;
            height: 2px !important;
            bottom: -6px !important;
        }

        /* ── Header Right Action Buttons & User Menu ── */
        .header-right {
            gap: 12px !important;
        }
        .header-actions-group {
            gap: 8px !important;
            align-items: center !important;
        }
        .header .btn-ghost:not(.nav-controls .btn-ghost) {
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
            background: rgba(255, 255, 255, 0.03) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 8px !important;
            padding: 6px 12px !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            font-weight: 600 !important;
            transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        .header .btn-ghost:not(.nav-controls .btn-ghost):hover {
            background: rgba(168, 85, 247, 0.08) !important;
            border-color: rgba(168, 85, 247, 0.3) !important;
            color: #c084fc !important;
            box-shadow: 0 0 12px rgba(168, 85, 247, 0.15) !important;
            transform: translateY(-1px) !important;
        }
        .timezone-btn {
            background: rgba(6, 182, 212, 0.04) !important;
            border: 1px solid rgba(6, 182, 212, 0.15) !important;
            border-radius: 8px !important;
            padding: 6px 12px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            color: #e2e8f0 !important;
            transition: all 0.2s ease !important;
            height: unset !important;
        }
        .timezone-btn:hover {
            background: rgba(6, 182, 212, 0.08) !important;
            border-color: rgba(6, 182, 212, 0.3) !important;
            box-shadow: 0 0 12px rgba(6, 182, 212, 0.15) !important;
            transform: translateY(-1px) !important;
        }
        .timezone-btn .tz-abbr {
            color: #06b6d4 !important;
            font-weight: 700 !important;
        }
        .user-menu {
            background: rgba(168, 85, 247, 0.04) !important;
            border: 1px solid rgba(168, 85, 247, 0.15) !important;
            border-radius: 8px !important;
            padding: 3px 8px !important;
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
            height: unset !important;
        }
        .user-name {
            color: #c084fc !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
            font-size: 0.82rem !important;
            margin-right: 4px !important;
        }
        .user-menu .btn-ghost {
            background: transparent !important;
            border: none !important;
            padding: 4px 6px !important;
            font-size: 0.82rem !important;
            color: #94a3b8 !important;
            transition: all 0.15s ease !important;
        }
        .user-menu .btn-ghost:hover {
            color: #ffffff !important;
            background: rgba(255, 255, 255, 0.05) !important;
        }
        .user-menu form button[type="submit"]:hover {
            color: #ef4444 !important;
        }

                /* ViewModal styles moved to the modernized block at the end of the file */

        /* ── Settings Content Overhaul ── */
        .settings-content h4 {
            color: #ffffff !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
            font-size: 1.15rem !important;
            margin-bottom: 6px !important;
            letter-spacing: -0.01em !important;
        }
        .settings-content p.text-secondary {
            font-size: 0.88rem !important;
            color: #94a3b8 !important;
        }
        .settings-content .form-label {
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.78rem !important;
            font-weight: 700 !important;
            color: #64748b !important;
            text-transform: uppercase !important;
            letter-spacing: 0.05em !important;
            margin-bottom: 6px !important;
        }
        .settings-panel div[style*="background: linear-gradient"],
        .settings-panel div[style*="background:linear-gradient"],
        .settings-panel div[style*="background: rgba(18, 18, 26"],
        .settings-panel div[style*="background:rgba(18"] {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.9), 0 0 20px rgba(168, 85, 247, 0.03) !important;
            border-radius: 14px !important;
        }
        .category-color-preview {
            box-shadow: 0 0 10px rgba(168, 85, 247, 0.25) !important;
        }
        .category-roles span {
            background: rgba(255, 255, 255, 0.04) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 5px !important;
            padding: 2px 6px !important;
            font-size: 0.72rem !important;
            color: #94a3b8 !important;
            margin-right: 4px !important;
            display: inline-block !important;
        }
        .setup-code-block {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            padding: 12px 16px !important;
        }
        .setup-code-highlight {
            border-color: rgba(168, 85, 247, 0.3) !important;
            box-shadow: 0 0 15px rgba(168, 85, 247, 0.05) !important;
        }
        .setup-copy-btn {
            background: rgba(255, 255, 255, 0.05) !important;
            border: 1px solid rgba(255, 255, 255, 0.1) !important;
            border-radius: 6px !important;
            transition: all 0.15s ease !important;
            padding: 4px 8px !important;
            height: unset !important;
        }
        .setup-copy-btn:hover {
            background: rgba(168, 85, 247, 0.15) !important;
            border-color: rgba(168, 85, 247, 0.3) !important;
            color: #ffffff !important;
        }

        /* Details summary boxes inside settings content */
        .settings-content details {
            background: rgba(255, 255, 255, 0.01) !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 10px !important;
            margin-bottom: 12px !important;
            overflow: hidden !important;
            transition: all 0.2s ease !important;
        }
        .settings-content details summary {
            padding: 12px 16px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.85rem !important;
            font-weight: 700 !important;
            color: #cbd5e1 !important;
            background: rgba(255, 255, 255, 0.03) !important;
            list-style: none !important;
            cursor: pointer !important;
            display: flex !important;
            align-items: center !important;
            justify-content: space-between !important;
            outline: none !important;
            border-bottom: 1px solid transparent !important;
        }
        .settings-content details summary::after {
            content: "➔" !important;
            font-size: 0.75rem !important;
            transition: transform 0.2s ease !important;
            color: #64748b !important;
        }
        .settings-content details[open] summary::after {
            transform: rotate(90deg) !important;
            color: #c084fc !important;
        }
        .settings-content details[open] summary {
            background: rgba(168, 85, 247, 0.04) !important;
            border-bottom-color: rgba(255, 255, 255, 0.07) !important;
            color: #c084fc !important;
        }
        .settings-content details > div {
            padding: 16px !important;
            background: #000000 !important;
        }

        /* Color inputs & numbers inside settings */
        .settings-panel input[type="color"] {
            border-radius: 8px !important;
            border: 1px solid rgba(255, 255, 255, 0.12) !important;
            cursor: pointer !important;
            background: transparent !important;
            transition: all 0.15s ease !important;
        }
        .settings-panel input[type="color"]:hover {
            border-color: rgba(168, 85, 247, 0.4) !important;
            transform: scale(1.05) !important;
        }

        /* Code/Text block alignments in Wizard & Info guides */
        .settings-panel pre, .settings-panel code {
            font-family: 'Fira Code', 'Courier New', monospace !important;
            font-size: 0.82rem !important;
            color: #c084fc !important;
        }

        /* Cron status banner and spinner updates */
        .cron-hero-banner {
            display: flex !important;
            align-items: center !important;
            justify-content: space-between !important;
            padding: 20px !important;
            background: linear-gradient(135deg, #05050a 0%, #000000 100%) !important;
            border: 1px solid rgba(168, 85, 247, 0.15) !important;
            border-left: 3px solid #a855f7 !important;
            border-radius: 12px !important;
            margin-bottom: 20px !important;
            box-shadow: 0 4px 20px rgba(0, 0, 0, 0.8), 0 0 15px rgba(168, 85, 247, 0.04) !important;
        }
        .cron-hero-spinner {
            border: 2px solid rgba(255, 255, 255, 0.05) !important;
            border-top: 2px solid #a855f7 !important;
            border-radius: 50% !important;
            width: 24px !important;
            height: 24px !important;
            animation: cronSpin 1s linear infinite !important;
        }
        @keyframes cronSpin {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }

        /* Webhook / list items tweaks */
        .webhook-list, .category-manage-list, .subcategory-manage-list {
            margin-top: 12px !important;
        }
        .webhook-item, .category-manage-item {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 14px !important;
            padding: 16px 20px !important;
            margin-bottom: 12px !important;
            transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        .webhook-item:hover, .category-manage-item:hover {
            border-color: rgba(168, 85, 247, 0.3) !important;
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.9), 0 0 12px rgba(168, 85, 247, 0.08) !important;
            transform: translateY(-1.5px) !important;
        }

        /* Mobile Menu Dropdown OLED */
        .mobile-menu-dropdown {
            background: #080810 !important;
            border-color: rgba(255, 255, 255, 0.08) !important;
            box-shadow: 0 15px 40px rgba(0, 0, 0, 0.85), 0 0 15px rgba(168, 85, 247, 0.05) !important;
        }
        .mobile-menu-item:hover, .mobile-menu-item:active {
            background: rgba(255, 255, 255, 0.04) !important;
        }

        /* ── Header SVG Micro-animations & Transitions ── */
        .header .btn-ghost svg, .timezone-btn svg, .user-menu svg {
            transition: transform 0.25s cubic-bezier(0.16, 1, 0.3, 1), stroke 0.2s ease !important;
            flex-shrink: 0 !important;
            display: inline-block !important;
            vertical-align: middle !important;
        }
        .header .btn-ghost:hover svg {
            transform: scale(1.15) !important;
            stroke: #c084fc !important;
        }
        .timezone-btn:hover svg {
            transform: scale(1.15) rotate(15deg) !important;
            stroke: #06b6d4 !important;
        }
        .user-menu .btn-ghost:hover svg {
            transform: scale(1.15) !important;
            stroke: #ffffff !important;
        }
        .user-menu form button[type="submit"]:hover svg {
            transform: scale(1.15) translate(1px, -1px) !important;
            stroke: #ef4444 !important;
        }

        /* =================================================================
           SETTINGS PANELS CONTENT OVERHAUL
           ================================================================= */

        /* ── Form Card Rework ── */
        .settings-panel form,
        .settings-panel div[id$="Form"],
        .settings-panel div[id$="Form"] > div {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 16px !important;
            box-shadow: 0 10px 45px rgba(0, 0, 0, 0.95), 0 0 25px rgba(168, 85, 247, 0.04) !important;
            padding: 24px !important;
            margin-top: 18px !important;
        }

        /* Form Row Layouts */
        .form-row {
            display: grid !important;
            grid-template-columns: 1fr 1fr !important;
            gap: 16px !important;
            margin-bottom: 12px !important;
        }
        .form-group {
            margin-bottom: 16px !important;
            display: flex !important;
            flex-direction: column !important;
            gap: 6px !important;
        }

        /* ── Styled Capsules (Pill Checkboxes) ── */
        .wh-trigger-pill {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 8px !important;
            padding: 8px 14px !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            font-weight: 600 !important;
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
        }
        .wh-trigger-pill:hover {
            border-color: rgba(168, 85, 247, 0.35) !important;
            color: #c084fc !important;
            background: rgba(168, 85, 247, 0.05) !important;
        }
        .wh-trigger-pill:has(input:checked) {
            background: rgba(168, 85, 247, 0.12) !important;
            border-color: #a855f7 !important;
            color: #c084fc !important;
            box-shadow: 0 0 10px rgba(168, 85, 247, 0.20) !important;
        }
        .wh-trigger-pill input[type="checkbox"],
        .wh-trigger-pill input[type="radio"] {
            display: none !important; /* Hide raw checkboxes */
        }

        /* ── Settings Panel Module Cards ── */
        .user-item, .webhook-item, .category-manage-item {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 14px !important;
            padding: 16px 20px !important;
            margin-bottom: 12px !important;
            display: flex !important;
            align-items: center !important;
            justify-content: space-between !important;
            transition: all 0.22s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        .user-item:hover, .webhook-item:hover, .category-manage-item:hover {
            border-color: rgba(168, 85, 247, 0.3) !important;
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.95), 0 0 12px rgba(168, 85, 247, 0.06) !important;
            transform: translateY(-1.5px) !important;
        }
        .user-info, .webhook-info {
            flex: 1 !important;
        }
        .user-name, .webhook-name {
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.95rem !important;
            font-weight: 700 !important;
            color: #ffffff !important;
            display: flex !important;
            align-items: center !important;
            gap: 8px !important;
        }
        .user-meta, .webhook-meta {
            margin-top: 6px !important;
            font-size: 0.78rem !important;
            color: #64748b !important;
            display: flex !important;
            flex-wrap: wrap !important;
            gap: 8px !important;
            align-items: center !important;
        }

        /* ── Bulk Actions & Toolbars ── */
        #userBulkBar {
            background: #000000 !important;
            border: 1px solid rgba(168, 85, 247, 0.22) !important;
            box-shadow: 0 4px 15px rgba(168, 85, 247, 0.05) !important;
            border-radius: 10px !important;
            padding: 10px 14px !important;
            margin-bottom: 12px !important;
            display: flex !important;
            align-items: center !important;
            gap: 8px !important;
        }
        .admin-mass-delete-bar {
            background: rgba(239, 68, 68, 0.06) !important;
            border: 1px solid rgba(239, 68, 68, 0.22) !important;
            border-radius: 10px !important;
            padding: 12px 16px !important;
            margin-bottom: 14px !important;
            color: #f87171 !important;
        }

        /* ── Drag & Drop SQL Import Zone ── */
        #sqlDropZone {
            border: 2px dashed rgba(255, 255, 255, 0.12) !important;
            background: #000000 !important;
            border-radius: 12px !important;
            padding: 24px !important;
            color: #94a3b8 !important;
            text-align: center !important;
            cursor: pointer !important;
            transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        #sqlDropZone:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.05) !important;
            color: #ffffff !important;
        }

        /* SQL Textarea */
        #sqlImportText {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            padding: 12px 14px !important;
            color: #cbd5e1 !important;
            font-family: 'Fira Code', 'Courier New', monospace !important;
            font-size: 0.85rem !important;
            margin-top: 10px !important;
        }

        /* Checkbox list container inside Import panel */
        .settings-panel div[style*="background:rgba(168,85,247,.07)"] {
            background: rgba(168, 85, 247, 0.04) !important;
            border: 1px solid rgba(168, 85, 247, 0.2) !important;
            border-radius: 10px !important;
            padding: 10px 14px !important;
        }

        /* ── Dynamic Tables (Import Results & Audit) ── */
        #sqlImportResults > div[style*="overflow-y:auto"] {
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 12px !important;
            background: #000000 !important;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5) !important;
        }
        #sqlImportResults table {
            border-collapse: collapse !important;
            width: 100% !important;
        }
        #sqlImportResults table thead th {
            background: #05050a !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.75rem !important;
            font-weight: 700 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.05em !important;
            padding: 8px 12px !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
        }
        #sqlImportResults table tbody tr {
            border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
            transition: background 0.15s ease !important;
        }
        #sqlImportResults table tbody tr:hover {
            background: rgba(255, 255, 255, 0.02) !important;
        }
        #sqlImportResults table tbody td {
            padding: 8px 12px !important;
            font-size: 0.82rem !important;
            color: #cbd5e1 !important;
        }

        /* ── Settings Panel Header Dividers ── */
        .settings-panel > div:first-of-type {
            border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
            padding-bottom: 14px !important;
            margin-bottom: 18px !important;
        }
        .settings-panel input[type="text"].form-input,
        .settings-panel select.form-input,
        .settings-panel select.form-select {
            height: 38px !important;
            padding: 6px 12px !important;
            background: #000000 !important;
            border-radius: 8px !important;
        }
        .settings-panel .form-checkbox {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.1) !important;
            border-radius: 8px !important;
            padding: 8px 12px !important;
        }
        .settings-panel .form-checkbox:hover {
            border-color: rgba(168, 85, 247, 0.3) !important;
            background: rgba(168, 85, 247, 0.04) !important;
        }
        .settings-panel .pref-section {
            background: rgba(255, 255, 255, 0.01) !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            box-shadow: 0 4px 15px rgba(0, 0, 0, 0.5) !important;
        }
        .settings-panel .pref-toggle {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
        }

        /* ═══════════════════════════════════════════════════════════════
           Performance pass: remove expensive full-screen compositing
           These overrides intentionally sit last to beat older theme blocks.
        ════════════════════════════════════════════════════════════════ */
        body::before,
        .app-container::before {
            display: none !important;
        }

        .header,
        .modal-overlay,
        .sidebar-overlay {
            backdrop-filter: none !important;
            -webkit-backdrop-filter: none !important;
        }

        .header {
            background: #05050a !important;
        }

        .modal-overlay {
            background: rgba(0, 0, 0, 0.82) !important;
            transition: opacity 60ms ease-out, visibility 60ms ease-out !important;
        }

        .modal,
        #viewModal .modal,
        #dayModal .modal,
        #editModal .modal,
        #settingsModal .modal,
        .settings-modal-wide {
            transform: none !important;
            transition: opacity 60ms ease-out !important;
            box-shadow: 0 16px 42px rgba(0, 0, 0, 0.72) !important;
            will-change: auto !important;
        }

        .modal-overlay.active .modal {
            transform: none !important;
        }

        #viewModal .modal-body,
        .modal-body,
        .settings-panel,
        .calendar-grid,
        .calendar-body,
        .sidebar {
            contain: layout paint;
        }

        .view-info-card,
        .view-rsvp-btn,
        .view-share-btn,
        .event-chip,
        .calendar-cell,
        .btn,
        .category-item,
        .upcoming-item {
            transition-property: background, border-color, color, opacity !important;
            transform: none !important;
            filter: none !important;
        }

        .view-info-card:hover,
        .view-rsvp-btn:hover,
        .view-share-btn:hover,
        .event-chip:hover,
        .calendar-cell:hover,
        .btn:hover,
        .category-item:hover,
        .upcoming-item:hover {
            transform: none !important;
        }

        .today-pulse,
        .webhook-status-dot.active,
        .cron-loading-spinner {
            animation: none !important;
        }

        @media (prefers-reduced-motion: reduce) {
            *,
            *::before,
            *::after {
                animation-duration: 0.001ms !important;
                animation-iteration-count: 1 !important;
                scroll-behavior: auto !important;
                transition-duration: 0.001ms !important;
            }
        }

        /* ═══════════════════════════════════════════════════════════════
           OLED admin polish: settings, users, bot audit, preferences, SQL
        ════════════════════════════════════════════════════════════════ */
        #settingsModal .settings-modal-wide,
        #preferencesModal .modal {
            background: #000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
        }

        #settingsModal .modal-header,
        #preferencesModal .modal-header {
            background: #000 !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
        }

        #settingsModal .modal-title,
        #preferencesModal .modal-title {
            color: #f8fafc !important;
            -webkit-text-fill-color: currentColor !important;
            background: none !important;
            letter-spacing: 0 !important;
        }

        .settings-tabs {
            background: #000 !important;
            border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
        }

        .settings-tab {
            min-height: 38px !important;
            border-radius: 8px !important;
            color: #6b7280 !important;
            transition-property: background, border-color, color !important;
        }

        .settings-tab:hover {
            background: #050509 !important;
            color: #cbd5e1 !important;
        }

        .settings-tab.active {
            background: #090911 !important;
            color: #f8fafc !important;
            border-left-color: #22d3ee !important;
            box-shadow: inset 0 0 0 1px rgba(34, 211, 238, 0.12) !important;
        }

        .settings-content {
            background: #000 !important;
            padding: 22px !important;
        }

        .settings-panel {
            content-visibility: auto;
            contain-intrinsic-size: 900px;
        }

        .settings-loading {
            padding: 22px !important;
            text-align: center !important;
            color: #64748b !important;
            background: #030306 !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 10px !important;
        }

        .pref-section,
        .settings-form-card,
        .webhook-cron-notice,
        .setup-guide,
        .system-alerts-section,
        #userForm,
        #categoryForm,
        #subcategoryForm,
        #templateForm,
        #webhookForm > div,
        #webhookWizard,
        #panel-botaudit > div,
        #sqlDropZone,
        #defaultOgImageUpload {
            background: #020204 !important;
            border: 1px solid rgba(255, 255, 255, 0.075) !important;
            border-radius: 10px !important;
            box-shadow: none !important;
        }

        .pref-section-title,
        .settings-form-title,
        .cron-section-header h4,
        .setup-guide-title {
            color: #f8fafc !important;
            letter-spacing: 0 !important;
        }

        .pref-section-desc,
        .pref-toggle-desc,
        .setup-guide-subtitle,
        .setup-step-desc,
        .text-muted {
            color: #64748b !important;
        }

        .pref-toggle,
        .form-checkbox,
        .user-item,
        .webhook-item,
        .cron-job-item,
        .category-manage-item,
        .admin-event-row,
        .wh-section,
        .cron-form-section,
        .cron-type-card,
        .cron-schedule-option {
            background: #050507 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 9px !important;
            box-shadow: none !important;
            transition-property: background, border-color, color, opacity !important;
        }

        .user-item:hover,
        .webhook-item:hover,
        .cron-job-item:hover,
        .category-manage-item:hover,
        .admin-event-row:hover,
        .cron-type-card:hover,
        .cron-schedule-option:hover {
            background: #08080d !important;
            border-color: rgba(34, 211, 238, 0.24) !important;
            box-shadow: none !important;
            transform: none !important;
        }

        .user-list,
        .webhook-list,
        .cron-job-list,
        .category-manage-list,
        .admin-events-list {
            display: flex !important;
            flex-direction: column !important;
            gap: 10px !important;
        }

        .user-item {
            display: grid !important;
            grid-template-columns: auto minmax(0, 1fr) auto !important;
            gap: 12px !important;
            align-items: center !important;
            padding: 14px 16px !important;
        }

        .user-info,
        .webhook-info,
        .cron-job-info,
        .admin-event-info {
            min-width: 0 !important;
        }

        .user-name,
        .webhook-name,
        .cron-job-name,
        .admin-event-title {
            color: #f8fafc !important;
            font-weight: 700 !important;
            letter-spacing: 0 !important;
        }

        .user-meta,
        .webhook-meta,
        .cron-job-meta,
        .admin-event-meta {
            color: #71717a !important;
            display: flex !important;
            flex-wrap: wrap !important;
            gap: 6px 10px !important;
            margin-top: 5px !important;
        }

        .user-actions,
        .webhook-actions,
        .cron-job-actions,
        .admin-event-actions {
            display: flex !important;
            gap: 6px !important;
            align-items: center !important;
            flex-wrap: wrap !important;
            justify-content: flex-end !important;
        }

        /* ── Event View Modal (Event Details) Overhaul ── */
        #viewModal .modal {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            box-shadow: 0 25px 70px rgba(0, 0, 0, 0.95), 0 0 40px rgba(168, 85, 247, 0.06) !important;
            border-radius: 18px !important;
            padding: 0 !important;
            overflow: hidden !important;
        }
        #viewModal .modal-body {
            padding: 24px !important;
        }
        .view-hero {
            background: rgba(255, 255, 255, 0.01) !important;
            border: 1px solid rgba(255, 255, 255, 0.05) !important;
            border-radius: 14px !important;
            padding: 20px !important;
            margin-bottom: 20px !important;
            text-align: left !important;
            border-left: 4px solid var(--accent-primary) !important;
            transition: border-color 0.3s ease !important;
        }
        .view-hero-badges {
            display: flex !important;
            align-items: center !important;
            justify-content: flex-start !important;
            gap: 8px !important;
            flex-wrap: wrap !important;
            margin-bottom: 10px !important;
        }
        .view-hero-title {
            font-family: 'Outfit', sans-serif !important;
            font-size: 1.6rem !important;
            font-weight: 800 !important;
            color: #ffffff !important;
            letter-spacing: -0.015em !important;
            line-height: 1.25 !important;
            margin-top: 8px !important;
            margin-bottom: 6px !important;
            text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5) !important;
        }
        .view-hero-creator {
            font-size: 0.82rem !important;
            color: #64748b !important;
            margin: 0 !important;
        }
        .view-hero-creator strong {
            color: #c084fc !important;
            font-weight: 600 !important;
        }
        .event-category-pill {
            background: rgba(255, 255, 255, 0.04) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #e2e8f0 !important;
            border-radius: 20px !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            letter-spacing: 0.02em !important;
        }
        .view-info-card {
            background: #05050a !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 14px !important;
            padding: 14px 18px !important;
            transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1) !important;
        }
        .view-info-card:hover {
            border-color: rgba(168, 85, 247, 0.25) !important;
            box-shadow: 0 4px 20px rgba(168, 85, 247, 0.05) !important;
            transform: translateY(-1.5px) !important;
        }
        .view-info-icon {
            background: rgba(255, 255, 255, 0.02) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 50% !important;
            width: 38px !important;
            height: 38px !important;
        }
        .view-info-icon.icon-date {
            background: rgba(6, 182, 212, 0.06) !important;
            border-color: rgba(6, 182, 212, 0.2) !important;
        }
        .view-info-icon.icon-date svg {
            fill: var(--accent-cyan) !important;
        }
        .view-info-icon.icon-time {
            background: rgba(168, 85, 247, 0.06) !important;
            border-color: rgba(168, 85, 247, 0.2) !important;
        }
        .view-info-icon.icon-time svg {
            fill: var(--accent-primary) !important;
        }
        .view-info-icon.icon-location {
            background: rgba(34, 197, 94, 0.06) !important;
            border-color: rgba(34, 197, 94, 0.2) !important;
        }
        .view-info-icon.icon-location svg {
            fill: var(--accent-green) !important;
        }
        .view-info-label {
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.72rem !important;
            font-weight: 700 !important;
            color: #64748b !important;
            text-transform: uppercase !important;
            letter-spacing: 0.06em !important;
        }
        .view-info-value {
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.95rem !important;
            font-weight: 600 !important;
            color: #f1f5f9 !important;
        }
        .view-description-box {
            background: #05050a !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 14px !important;
            padding: 16px 20px !important;
        }
        .view-description-text {
            font-size: 0.9rem !important;
            line-height: 1.6 !important;
            color: #cbd5e1 !important;
            margin: 0 !important;
        }
        .view-section-title {
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.75rem !important;
            font-weight: 700 !important;
            color: #64748b !important;
            letter-spacing: 0.08em !important;
            text-transform: uppercase !important;
        }
        .view-rsvp-buttons {
            display: grid !important;
            grid-template-columns: repeat(3, 1fr) !important;
            gap: 8px !important;
        }
        .view-rsvp-btn {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 12px !important;
            padding: 14px 8px !important;
            color: #94a3b8 !important;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
            height: unset !important;
        }
        .view-rsvp-btn:hover {
            background: rgba(255, 255, 255, 0.03) !important;
            border-color: rgba(255, 255, 255, 0.15) !important;
            color: #e2e8f0 !important;
            transform: translateY(-1px) !important;
        }
        .view-rsvp-btn.active {
            transform: scale(0.98) !important;
        }
        .view-rsvp-btn.active.going {
            background: rgba(34, 197, 94, 0.1) !important;
            border-color: #22c55e !important;
            color: #4ade80 !important;
            box-shadow: 0 0 15px rgba(34, 197, 94, 0.15) !important;
        }
        .view-rsvp-btn.active.maybe {
            background: rgba(245, 158, 11, 0.1) !important;
            border-color: #f59e0b !important;
            color: #fbbf24 !important;
            box-shadow: 0 0 15px rgba(245, 158, 11, 0.15) !important;
        }
        .view-rsvp-btn.active.declined {
            background: rgba(239, 68, 68, 0.1) !important;
            border-color: #ef4444 !important;
            color: #f87171 !important;
            box-shadow: 0 0 15px rgba(239, 68, 68, 0.15) !important;
        }
        .view-attendees-compact {
            gap: 6px !important;
        }
        .view-attendee-chip {
            background: rgba(255, 255, 255, 0.03) !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 8px !important;
            padding: 6px 12px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            color: #e2e8f0 !important;
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
        }
        .view-attendee-chip.going { border-color: rgba(34, 197, 94, 0.25) !important; }
        .view-attendee-chip.maybe { border-color: rgba(245, 158, 11, 0.25) !important; }
        .view-attendee-chip.declined { border-color: rgba(239, 68, 68, 0.25) !important; }
        
        .view-share-grid {
            gap: 8px !important;
        }
        .view-share-btn {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            color: #94a3b8 !important;
            padding: 8px 12px !important;
            transition: all 0.2s ease !important;
            height: unset !important;
        }
        .view-share-btn:hover {
            border-color: rgba(168, 85, 247, 0.35) !important;
            color: #c084fc !important;
            background: rgba(168, 85, 247, 0.05) !important;
            transform: translateY(-1.5px) !important;
        }
        .view-divider {
            border-top: 1px solid rgba(255, 255, 255, 0.07) !important;
            margin: 18px 0 !important;
            border-bottom: none !important;
            height: unset !important;
        }

        /* Mobile specific overrides for event details view */
        @media (max-width: 480px) {
            #viewModal .modal {
                width: 92% !important;
                margin: 16px auto !important;
                max-height: calc(100vh - 32px) !important;
                display: flex !important;
                flex-direction: column !important;
            }
            #viewModal .modal-body {
                padding: 16px !important;
                overflow-y: auto !important;
                -webkit-overflow-scrolling: touch !important;
            }
            .view-hero {
                padding: 14px 16px !important;
                margin-bottom: 14px !important;
            }
            .view-hero-title {
                font-size: 1.3rem !important;
            }
            .view-info-card {
                padding: 12px 14px !important;
            }
            .view-info-value {
                font-size: 0.88rem !important;
            }
            .view-rsvp-buttons {
                gap: 6px !important;
            }
            .view-rsvp-btn {
                padding: 12px 6px !important;
            }
            .view-rsvp-btn .rsvp-icon {
                font-size: 1.1rem !important;
            }
            .view-rsvp-btn .rsvp-label {
                font-size: 0.65rem !important;
            }
        }

        .role-badge,
        .webhook-pill,
        .cron-job-meta-tag,
        .cron-status-badge,
        .admin-event-badge,
        .cron-job-type-tag {
            background: #090911 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            border-radius: 999px !important;
            color: #cbd5e1 !important;
            box-shadow: none !important;
        }

        .role-badge.admin,
        .webhook-pill.pill-trigger,
        .cron-status-badge.active {
            color: #22d3ee !important;
            border-color: rgba(34, 211, 238, 0.22) !important;
            background: rgba(34, 211, 238, 0.06) !important;
        }

        .role-badge.create,
        .cron-status-badge.pending {
            color: #c084fc !important;
            border-color: rgba(192, 132, 252, 0.22) !important;
            background: rgba(192, 132, 252, 0.06) !important;
        }

        .cron-status-badge.overdue {
            color: #fb7185 !important;
            border-color: rgba(251, 113, 133, 0.24) !important;
            background: rgba(251, 113, 133, 0.06) !important;
        }

        .role-badge.view,
        .cron-status-badge.disabled {
            color: #94a3b8 !important;
        }

        #userBulkBar,
        .admin-mass-delete-bar,
        .cron-hero-banner {
            background: #030306 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            box-shadow: none !important;
        }

        .cron-hero-icon {
            background: #050507 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            box-shadow: none !important;
        }

        .setup-code-block {
            background: #000 !important;
            border: 1px solid rgba(34, 211, 238, 0.2) !important;
            border-radius: 9px !important;
            padding: 12px 44px 12px 14px !important;
            position: relative !important;
        }

        .setup-code-block code {
            color: #d1fae5 !important;
            font-family: "Cascadia Mono", "SFMono-Regular", Consolas, monospace !important;
            font-size: 0.82rem !important;
            line-height: 1.45 !important;
            white-space: pre-wrap !important;
            word-break: break-word !important;
        }

        .setup-code-highlight {
            background: #010304 !important;
            border-color: rgba(34, 211, 238, 0.32) !important;
        }

        .setup-copy-btn {
            position: absolute !important;
            right: 8px !important;
            top: 8px !important;
            background: #071014 !important;
            border: 1px solid rgba(34, 211, 238, 0.22) !important;
            border-radius: 7px !important;
            color: #22d3ee !important;
        }

        #panel-botaudit .table {
            background: #000 !important;
        }

        #panel-botaudit .table thead th {
            background: #030306 !important;
            color: #94a3b8 !important;
            position: sticky !important;
            top: 0 !important;
            z-index: 1 !important;
        }

        #panel-botaudit .table tbody tr {
            background: #010103 !important;
        }

        #panel-botaudit .table tbody tr:nth-child(even) {
            background: #050507 !important;
        }

        #panel-botaudit code {
            color: #22d3ee !important;
            background: rgba(34, 211, 238, 0.06) !important;
            border: 1px solid rgba(34, 211, 238, 0.14) !important;
            border-radius: 5px !important;
            padding: 1px 5px !important;
        }

        #sqlImportResults,
        #blockedDatesList,
        #skipGamesList,
        #allowlistUsersList {
            background: #000 !important;
            border-radius: 9px !important;
        }

        @media (max-width: 760px) {
            .user-item {
                grid-template-columns: auto minmax(0, 1fr) !important;
            }
            .user-actions {
                grid-column: 1 / -1 !important;
                justify-content: flex-start !important;
            }
        }

        /* ── Event Create/Edit Modal (New Event Wizard) Overhaul ── */
        #editModal .modal {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            box-shadow: 0 25px 70px rgba(0, 0, 0, 0.95), 0 0 50px rgba(168, 85, 247, 0.12) !important;
            border-radius: 18px !important;
            padding: 0 !important;
            overflow: hidden !important;
        }
        #editModal .modal-header {
            padding: 22px 24px 10px 24px !important;
            background: #000000 !important;
            border-bottom: none !important;
        }
        #editModal .modal-title {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 800 !important;
            color: #ffffff !important;
            font-size: 1.35rem !important;
            letter-spacing: -0.01em !important;
        }
        #editModal .modal-close {
            background: rgba(255, 255, 255, 0.04) !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #94a3b8 !important;
            border-radius: 50% !important;
            width: 32px !important;
            height: 32px !important;
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            font-size: 1.1rem !important;
            padding: 0 !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.5) !important;
        }
        #editModal .modal-close:hover {
            color: #ffffff !important;
            background: rgba(255, 255, 255, 0.08) !important;
            border-color: rgba(255, 255, 255, 0.2) !important;
            transform: scale(1.08) !important;
        }
        
        .wizard-progress {
            background: #000000 !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
            padding: 14px 24px !important;
            gap: 12px !important;
        }
        .wizard-step-indicator {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            color: #64748b !important;
            border-radius: 20px !important;
            padding: 6px 14px !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            font-size: 0.8rem !important;
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02) !important;
            transition: all 0.2s ease !important;
        }
        .wizard-step-indicator:hover {
            color: #e2e8f0 !important;
            border-color: rgba(255, 255, 255, 0.15) !important;
            background: #090914 !important;
        }
        .wizard-step-indicator.active {
            background: rgba(168, 85, 247, 0.08) !important;
            border-color: #a855f7 !important;
            color: #d8b4fe !important;
            box-shadow: 0 0 14px rgba(168, 85, 247, 0.18) !important;
        }
        .wizard-step-indicator.completed {
            background: rgba(34, 197, 94, 0.06) !important;
            border-color: #22c55e !important;
            color: #4ade80 !important;
            box-shadow: 0 0 10px rgba(34, 197, 94, 0.1) !important;
        }
        .wizard-step-indicator .step-num {
            background: rgba(255, 255, 255, 0.05) !important;
            color: #94a3b8 !important;
            width: 20px !important;
            height: 20px !important;
            font-size: 0.72rem !important;
            border-radius: 50% !important;
            display: inline-flex !important;
            align-items: center !important;
            justify-content: center !important;
            margin-right: 6px !important;
        }
        .wizard-step-indicator.active .step-num {
            background: #a855f7 !important;
            color: #ffffff !important;
            box-shadow: 0 0 8px rgba(168, 85, 247, 0.4) !important;
        }
        .wizard-step-indicator.completed .step-num {
            background: #22c55e !important;
            color: #ffffff !important;
            box-shadow: 0 0 8px rgba(34, 197, 94, 0.4) !important;
        }
        .wizard-step {
            padding: 24px 28px !important;
            background: #000000 !important;
        }
        .wizard-step-title {
            font-family: 'Outfit', sans-serif !important;
            font-size: 1.3rem !important;
            font-weight: 800 !important;
            color: #ffffff !important;
            margin-bottom: 6px !important;
            letter-spacing: -0.01em !important;
        }
        .wizard-step-subtitle {
            color: #475569 !important;
            font-size: 0.88rem !important;
            margin-bottom: 24px !important;
        }
        
        /* Inputs in wizard */
        #editModal .form-input,
        #editModal .form-select,
        #editModal textarea.form-input,
        #editModal .wizard-input-large,
        #editModal .wizard-textarea {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            color: #f8fafc !important;
            font-size: 0.95rem !important;
            padding: 11px 15px !important;
            box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.6) !important;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
        }
        #editModal .wizard-input-large {
            font-size: 1.2rem !important;
            font-weight: 600 !important;
            border-radius: 12px !important;
            letter-spacing: -0.01em !important;
        }
        #editModal .form-input:focus,
        #editModal .form-select:focus,
        #editModal .wizard-input-large:focus,
        #editModal .wizard-textarea:focus {
            border-color: #a855f7 !important;
            background: #000000 !important;
            box-shadow: 
                0 0 0 3px rgba(168, 85, 247, 0.2),
                0 0 12px rgba(168, 85, 247, 0.3),
                inset 0 2px 4px rgba(0, 0, 0, 0.8) !important;
            outline: none !important;
        }
        #editModal .form-input::placeholder,
        #editModal .wizard-input-large::placeholder,
        #editModal .wizard-textarea::placeholder {
            color: #475569 !important;
        }

        /* Game Link presets styling */
        #editModal #gameLinkPresetSelect {
            background-color: #05050c !important;
            border-color: rgba(255, 255, 255, 0.08) !important;
            color: #e2e8f0 !important;
        }
        #editModal #gameLinkPresetSelect:focus {
            border-color: #a855f7 !important;
        }
        
        /* Quick Option Grids & Buttons (ALL DAY, visibility) */
        #editModal .quick-option {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 10px !important;
            color: #94a3b8 !important;
            font-size: 0.85rem !important;
            font-weight: 600 !important;
            padding: 9px 14px !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
        }
        #editModal .quick-option:hover {
            background: #090915 !important;
            border-color: rgba(255, 255, 255, 0.15) !important;
            color: #e2e8f0 !important;
        }
        #editModal .quick-option.active {
            background: rgba(168, 85, 247, 0.1) !important;
            border-color: #a855f7 !important;
            color: #d8b4fe !important;
            box-shadow: 0 0 15px rgba(168, 85, 247, 0.15) !important;
        }
        
        /* Quick Start choice buttons */
        .qs-choice-btn {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 14px !important;
            padding: 24px 18px !important;
            transition: all 0.22s cubic-bezier(0.4, 0, 0.2, 1) !important;
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.01) !important;
        }
        .qs-choice-btn:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.03) !important;
            box-shadow: 
                0 12px 30px rgba(0, 0, 0, 0.8), 
                0 0 20px rgba(168, 85, 247, 0.08),
                inset 0 1px 0 rgba(255, 255, 255, 0.02) !important;
            transform: translateY(-2px) !important;
        }
        .qs-choice-label {
            font-family: 'Outfit', sans-serif !important;
            color: #f8fafc !important;
            font-weight: 700 !important;
            font-size: 0.95rem !important;
        }
        .qs-choice-desc {
            color: #475569 !important;
            font-size: 0.78rem !important;
            margin-top: 2px !important;
        }

        /* Quick Start template search filter */
        #editModal .subcategory-search-input {
            background: #05050c !important;
            border: 1px solid rgba(255,255,255,0.08) !important;
            border-radius: 10px !important;
            color: #fff !important;
            padding: 8px 14px !important;
            font-size: 0.88rem !important;
            margin-bottom: var(--spacing-md) !important;
        }
        #editModal .subcategory-search-input:focus {
            border-color: #a855f7 !important;
            box-shadow: 0 0 10px rgba(168,85,247,0.15) !important;
            outline: none !important;
        }
        
        /* Template cards */
        .tpl-card {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 12px !important;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
            padding: 12px !important;
        }
        .tpl-card:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.03) !important;
            transform: translateY(-2.5px) !important;
            box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6) !important;
        }
        .tpl-card.active {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.08) !important;
            box-shadow: 0 0 20px rgba(168, 85, 247, 0.22) !important;
        }
        .tpl-card-name {
            color: #f8fafc !important;
            font-weight: 700 !important;
            font-size: 0.85rem !important;
        }
        
        /* Category selection pills in template header */
        .qs-pill {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 20px !important;
            color: #94a3b8 !important;
            font-weight: 600 !important;
            transition: all 0.2s ease !important;
        }
        .qs-pill:hover {
            border-color: rgba(255, 255, 255, 0.18) !important;
            color: #f1f5f9 !important;
            background: #090915 !important;
        }
        .qs-pill.active {
            background: rgba(168, 85, 247, 0.1) !important;
            border-color: #a855f7 !important;
            color: #d8b4fe !important;
            box-shadow: 0 0 12px rgba(168, 85, 247, 0.12) !important;
        }

        /* Aligning quick date/time buttons styles with JS classes */
        .quick-date-grid .quick-date-btn,
        .quick-time-grid .quick-time-btn {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 10px !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            padding: 8px 14px !important;
            transition: all 0.2s ease !important;
            cursor: pointer !important;
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.01) !important;
        }
        .quick-date-grid .quick-date-btn:hover,
        .quick-time-grid .quick-time-btn:hover {
            border-color: rgba(168, 85, 247, 0.35) !important;
            color: #d8b4fe !important;
            background: rgba(168, 85, 247, 0.05) !important;
        }
        .quick-date-grid .quick-date-btn.selected,
        .quick-date-grid .quick-date-btn.active,
        .quick-time-grid .quick-time-btn.selected,
        .quick-time-grid .quick-time-btn.active {
            background: rgba(168, 85, 247, 0.12) !important;
            border-color: #a855f7 !important;
            color: #d8b4fe !important;
            box-shadow: 0 0 15px rgba(168, 85, 247, 0.18) !important;
            font-weight: 700 !important;
        }
        .quick-date-btn .qd-day {
            font-weight: 700 !important;
        }
        .quick-date-btn .qd-date {
            font-size: 0.72rem !important;
            opacity: 0.8 !important;
        }
        
        /* Date / Time Card Selectors */
        .datetime-card {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 12px !important;
            padding: 10px 14px !important;
            box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.5) !important;
        }
        .datetime-card-label {
            display: flex !important;
            align-items: center !important;
            gap: 6px !important;
            color: #94a3b8 !important;
            font-size: 0.75rem !important;
            font-weight: 700 !important;
            text-transform: uppercase !important;
            letter-spacing: 0.05em !important;
            margin-bottom: 4px !important;
        }
        .datetime-card input[type="date"],
        .datetime-card input[type="time"] {
            background: transparent !important;
            border: none !important;
            color: #ffffff !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
            font-size: 1rem !important;
            width: 100% !important;
            padding: 4px 0 !important;
            box-sizing: border-box !important;
            color-scheme: dark !important;
        }
        .datetime-card input[type="date"]:focus,
        .datetime-card input[type="time"]:focus {
            outline: none !important;
        }

        /* Category steps selection grids */
        .category-option {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 12px !important;
            box-shadow: inset 0 1px 0 rgba(255,255,255,0.01) !important;
            transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
        }
        .category-option:hover {
            border-color: rgba(168, 85, 247, 0.3) !important;
            transform: translateY(-2px) !important;
            background: #090915 !important;
            box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6) !important;
        }
        .category-option.selected {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.08) !important;
            box-shadow: 0 0 20px rgba(168, 85, 247, 0.2) !important;
        }
        .category-option::before {
            display: none !important; /* Hide old heavy gradient bar */
        }
        .category-option.selected::before {
            display: none !important;
        }
        .category-option-name {
            color: #94a3b8 !important;
            font-weight: 600 !important;
        }
        .category-option.selected .category-option-name {
            color: #d8b4fe !important;
        }

        /* Subcategory chips */
        .subcategory-grid {
            gap: 8px !important;
        }
        .subcategory-option {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 10px !important;
            color: #94a3b8 !important;
            font-weight: 600 !important;
            font-size: 0.8rem !important;
            padding: 8px 14px !important;
            transition: all 0.2s ease !important;
        }
        .subcategory-option:hover {
            border-color: rgba(255, 255, 255, 0.18) !important;
            color: #f1f5f9 !important;
            background: #090915 !important;
        }
        .subcategory-option.selected {
            background: rgba(168, 85, 247, 0.1) !important;
            border-color: #a855f7 !important;
            color: #d8b4fe !important;
            box-shadow: 0 0 12px rgba(168, 85, 247, 0.12) !important;
        }

        /* Color choices */
        .color-choice {
            border-radius: 50% !important;
            border: 2px solid transparent !important;
            aspect-ratio: 1 !important;
            transition: all 0.2s ease !important;
        }
        .color-choice:hover {
            transform: scale(1.18) !important;
        }
        .color-choice.selected {
            border-color: #ffffff !important;
            box-shadow: 0 0 0 2px #a855f7, 0 0 12px #a855f7 !important;
        }

        /* Host inputs and badges */
        .host-badge {
            background: #090915 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 8px !important;
            color: #e2e8f0 !important;
            font-size: 0.82rem !important;
            font-weight: 600 !important;
            padding: 5px 10px !important;
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
        }
        .host-badge-remove {
            color: #ef4444 !important;
            cursor: pointer !important;
            font-weight: 700 !important;
            transition: opacity 0.2s !important;
        }
        .host-badge-remove:hover {
            opacity: 0.8 !important;
        }
        
        /* Image upload area */
        .image-upload-area {
            background: #05050c !important;
            border: 1.5px dashed rgba(255, 255, 255, 0.12) !important;
            border-radius: 12px !important;
            transition: all 0.22s ease !important;
            padding: 24px !important;
            text-align: center !important;
        }
        .image-upload-area:hover,
        .image-upload-area.dragover {
            border-color: #a855f7 !important;
            border-style: solid !important;
            background: rgba(168, 85, 247, 0.03) !important;
            box-shadow: 0 0 15px rgba(168, 85, 247, 0.08) !important;
        }
        .image-upload-placeholder {
            color: #64748b !important;
            font-size: 0.85rem !important;
        }
        
        /* Step 4: Summary Preview Card (OLED Overhaul) */
        .event-preview {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.12) !important;
            border-radius: 14px !important;
            padding: 20px !important;
            border-left: 4px solid #a855f7 !important;
            box-shadow: 0 12px 36px rgba(0, 0, 0, 0.8) !important;
        }
        .event-preview-title {
            font-size: 1.35rem !important;
            font-weight: 800 !important;
            margin-bottom: 16px !important;
            letter-spacing: -0.01em !important;
        }
        .event-preview-row {
            grid-template-columns: 110px minmax(0, 1fr) !important;
            gap: 16px !important;
            margin-bottom: 8px !important;
            align-items: center !important;
        }
        .event-preview-label {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 6px !important;
            color: #94a3b8 !important;
            font-size: 0.72rem !important;
            font-weight: 700 !important;
            letter-spacing: 0.08em !important;
            padding: 3px 8px !important;
            box-shadow: none !important;
        }
        .event-preview-value-pill {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #e2e8f0 !important;
            border-radius: 8px !important;
            padding: 5px 12px !important;
            font-size: 0.88rem !important;
            box-shadow: none !important;
        }
        .event-preview-desc {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 8px !important;
            padding: 10px 14px !important;
            color: #cbd5e1 !important;
        }
        .event-preview-desc .event-preview-value-pill {
            background: transparent !important;
            border: none !important;
            padding: 0 !important;
            color: inherit !important;
            box-shadow: none !important;
        }
        .event-preview-toggle {
            color: #c084fc !important;
            font-weight: 600 !important;
            font-size: 0.78rem !important;
            margin-top: 6px !important;
        }
        .event-preview-toggle:hover {
            color: #a855f7 !important;
        }

        /* Footer navigation in wizard */
        .wizard-nav {
            background: #000000 !important;
            border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
            padding: 18px 24px !important;
            display: flex !important;
            align-items: center !important;
            justify-content: space-between !important;
        }
        .wizard-nav-btn {
            border-radius: 8px !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.8rem !important;
            font-weight: 700 !important;
            padding: 10px 20px !important;
            letter-spacing: 0.05em !important;
            text-transform: none !important;
            height: unset !important;
            box-shadow: none !important;
            background: transparent !important;
            border: 1px solid rgba(255, 255, 255, 0.1) !important;
            color: #94a3b8 !important;
            transition: all 0.2s ease !important;
        }
        .wizard-nav-btn:hover {
            background: rgba(255, 255, 255, 0.04) !important;
            color: #ffffff !important;
            border-color: rgba(255, 255, 255, 0.2) !important;
            transform: translateY(-1px) !important;
        }
        .wizard-nav-btn:disabled {
            opacity: 0.35 !important;
            transform: none !important;
        }
        #wizardPrevBtn {
            border-radius: 8px !important;
        }
        #wizardNextBtn,
        #wizardSaveBtn {
            background: #a855f7 !important;
            color: #ffffff !important;
            border: none !important;
            box-shadow: 0 4px 14px rgba(168, 85, 247, 0.3) !important;
        }
        #wizardNextBtn:hover,
        #wizardSaveBtn:hover {
            background: #9333ea !important;
            box-shadow: 0 6px 20px rgba(168, 85, 247, 0.45) !important;
            transform: translateY(-1px) !important;
        }
        
        /* Mobile specific overrides for Edit Modal */
        @media (max-width: 480px) {
            #editModal .modal {
                width: 94% !important;
                margin: 10px auto !important;
                max-height: calc(100vh - 20px) !important;
                display: flex !important;
                flex-direction: column !important;
                border-radius: 14px !important;
            }
            .wizard-progress {
                padding: 12px 14px !important;
                gap: 8px !important;
            }
            .wizard-step-indicator {
                padding: 5px 10px !important;
                font-size: 0.72rem !important;
            }
            .wizard-step-indicator span:not(.step-num) {
                display: none !important;
            }
            .wizard-step-indicator .step-num {
                margin-right: 0 !important;
            }
            .wizard-step {
                padding: 16px 20px !important;
            }
            .wizard-step-title {
                font-size: 1.15rem !important;
            }
            .wizard-step-subtitle {
                font-size: 0.82rem !important;
                margin-bottom: 16px !important;
            }
            .wizard-input-large {
                font-size: 1.05rem !important;
            }
            .wizard-nav {
                padding: 12px 20px !important;
            }
            .wizard-nav-btn {
                padding: 9px 14px !important;
                font-size: 0.74rem !important;
            }
            .qs-choice-buttons {
                grid-template-columns: 1fr !important;
                gap: 8px !important;
            }
            .qs-choice-btn {
                padding: 16px 12px !important;
            }
            .qs-pill {
                padding: 6px 12px !important;
                font-size: 0.75rem !important;
            }
            .quick-date-grid .quick-date-btn,
            .quick-time-grid .quick-time-btn {
                padding: 6px 12px !important;
                font-size: 0.75rem !important;
            }
            .datetime-cards {
                grid-template-columns: 1fr !important;
                gap: 8px !important;
            }
            .datetime-card {
                padding: 8px 12px !important;
            }
            .category-grid {
                grid-template-columns: repeat(2, 1fr) !important;
                gap: 8px !important;
            }
            .color-grid {
                grid-template-columns: repeat(4, 1fr) !important;
                gap: 8px !important;
            }
            .event-preview-row {
                grid-template-columns: 80px minmax(0, 1fr) !important;
                gap: 8px !important;
            }
        }

        /* ── Onboarding / Welcome Popup OLED Overhaul ── */
        .onboarding-overlay {
            background: rgba(0, 0, 0, 0.90) !important;
            display: flex !important;
            align-items: flex-start !important;
            justify-content: center !important;
            overflow-y: auto !important;
            -webkit-overflow-scrolling: touch !important;
            padding: var(--spacing-md) !important;
        }
        .onboarding-box {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            border-radius: 18px !important;
            box-shadow: 
                0 25px 70px rgba(0, 0, 0, 0.95), 
                0 0 40px rgba(168, 85, 247, 0.06) !important;
            max-height: none !important;
            margin: auto !important;
            padding: 24px 24px 20px 24px !important;
            display: flex !important;
            flex-direction: column !important;
        }
        .onboarding-title {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 800 !important;
            color: #ffffff !important;
        }
        .onboarding-subtitle {
            color: #64748b !important;
            font-size: 0.85rem !important;
        }
        
        .onboarding-account-option {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 12px !important;
            transition: all 0.2s ease !important;
        }
        .onboarding-account-option:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.03) !important;
        }
        .onboarding-account-icon {
            background: rgba(168, 85, 247, 0.08) !important;
            color: #c084fc !important;
            border-radius: 8px !important;
        }
        .onboarding-account-icon-alt {
            background: rgba(192, 132, 252, 0.08) !important;
            color: #c084fc !important;
        }
        .onboarding-account-option-primary {
            background: rgba(34, 197, 94, 0.04) !important;
            border-color: rgba(34, 197, 94, 0.25) !important;
        }
        .onboarding-account-option-primary:hover {
            background: rgba(34, 197, 94, 0.08) !important;
            border-color: #22c55e !important;
        }
        .onboarding-account-icon-primary {
            background: rgba(34, 197, 94, 0.12) !important;
            color: #4ade80 !important;
        }
        .onboarding-account-title {
            color: #f8fafc !important;
            font-family: 'Outfit', sans-serif !important;
        }
        .onboarding-account-desc {
            color: #475569 !important;
        }
        .onboarding-account-option:hover .onboarding-account-arrow {
            color: #c084fc !important;
        }
        .onboarding-account-option-primary:hover .onboarding-account-arrow {
            color: #4ade80 !important;
        }

        /* Side-by-side Auth Buttons Grid */
        .onboarding-account-grid {
            display: grid !important;
            grid-template-columns: 1fr 1fr !important;
            gap: 12px !important;
            margin-bottom: var(--spacing-md) !important;
        }
        .onboarding-account-btn {
            display: flex !important;
            align-items: center !important;
            justify-content: center !important;
            gap: 8px !important;
            padding: 12px !important;
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 12px !important;
            color: #94a3b8 !important;
            font-weight: 600 !important;
            font-size: 0.88rem !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
            font-family: 'Outfit', sans-serif !important;
            outline: none !important;
        }
        .onboarding-account-btn:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.04) !important;
            color: #ffffff !important;
        }
        .onboarding-account-btn svg {
            color: #c084fc !important;
            flex-shrink: 0 !important;
        }

        .onboarding-divider {
            color: #475569 !important;
            margin: 16px 0 !important;
        }
        .onboarding-divider::before,
        .onboarding-divider::after {
            background: rgba(255, 255, 255, 0.06) !important;
        }
        
        .onboarding-settings-toggle {
            background: #05050c !important;
            border: 1px dashed rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            color: #94a3b8 !important;
            transition: all 0.2s ease !important;
        }
        .onboarding-settings-toggle:hover {
            background: #090915 !important;
            border-color: rgba(255, 255, 255, 0.18) !important;
            color: #ffffff !important;
        }
        .onboarding-settings-toggle.active {
            border-style: solid !important;
            border-color: #a855f7 !important;
            color: #c084fc !important;
            background: rgba(168, 85, 247, 0.05) !important;
        }
        
        .onboarding-settings-content {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 12px !important;
            padding: 16px !important;
        }
        .onboarding-detection-card {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 10px !important;
        }
        .onboarding-detection-card:hover {
            border-color: rgba(255, 255, 255, 0.15) !important;
        }
        .onboarding-detection-icon {
            background: rgba(255, 255, 255, 0.03) !important;
            color: #94a3b8 !important;
            border-radius: 8px !important;
        }
        .onboarding-detection-label {
            color: #475569 !important;
        }
        .onboarding-detection-value {
            color: #f8fafc !important;
        }
        .onboarding-change-btn {
            border-color: rgba(255, 255, 255, 0.08) !important;
            background: #05050c !important;
            color: #94a3b8 !important;
        }
        .onboarding-change-btn:hover {
            background: #090915 !important;
            border-color: #a855f7 !important;
            color: #c084fc !important;
        }
        
        .onboarding-tz-select select {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #f8fafc !important;
        }
        .onboarding-tz-select select:focus {
            border-color: #a855f7 !important;
        }

        .onboarding-view-option {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
        }
        .onboarding-view-option:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.02) !important;
            color: #ffffff !important;
        }
        .onboarding-view-option.active {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.08) !important;
            color: #c084fc !important;
        }

        /* Category Selector wrapper and flex grid */
        .onboarding-categories-wrapper {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 12px !important;
        }
        .onboarding-categories-header {
            border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
            background: #000000 !important;
            border-top-left-radius: 12px !important;
            border-top-right-radius: 12px !important;
        }
        .onboarding-categories-info strong {
            color: #22c55e !important;
        }
        .onboarding-categories-action-btn {
            border-color: rgba(255, 255, 255, 0.08) !important;
            color: #94a3b8 !important;
        }
        .onboarding-categories-action-btn:hover {
            border-color: #22c55e !important;
            color: #4ade80 !important;
            background: rgba(34, 197, 94, 0.04) !important;
        }
        .onboarding-categories-grid {
            display: flex !important;
            flex-wrap: wrap !important;
            gap: 6px !important;
            max-height: none !important; /* Remove tiny scrollbox */
            overflow-y: visible !important;
            padding: 12px !important;
        }
        .onboarding-category-chip {
            display: inline-flex !important;
            align-items: center !important;
            gap: 6px !important;
            white-space: nowrap !important;
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            color: #94a3b8 !important;
            border-radius: 20px !important;
            padding: 6px 12px !important;
            transition: all 0.2s ease !important;
            outline: none !important;
        }
        .onboarding-category-chip:hover {
            border-color: rgba(255, 255, 255, 0.15) !important;
            background: #090915 !important;
            color: #ffffff !important;
        }
        .onboarding-category-chip.active {
            background: rgba(34, 197, 94, 0.08) !important;
            border-color: #22c55e !important;
            color: #4ade80 !important;
        }
        .onboarding-category-chip.active .cat-check {
            background: #22c55e !important;
            border-color: #22c55e !important;
        }

        .onboarding-toggles {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
            border-radius: 12px !important;
        }
        .onboarding-toggle-slider {
            background: #000000 !important;
            border-color: rgba(255, 255, 255, 0.08) !important;
        }
        .onboarding-toggle input:checked + .onboarding-toggle-slider {
            background: rgba(34, 197, 94, 0.15) !important;
            border-color: #22c55e !important;
        }
        .onboarding-toggle input:checked + .onboarding-toggle-slider::before {
            background: #22c55e !important;
        }

        /* ── Onboarding Form OLED Controls & Passwords ── */
        .onboarding-form .form-group {
            margin-bottom: 16px !important;
        }
        .onboarding-form .form-label {
            color: #94a3b8 !important;
            font-size: 0.8rem !important;
            font-weight: 600 !important;
            font-family: 'Outfit', sans-serif !important;
            letter-spacing: 0.3px !important;
            margin-bottom: 6px !important;
            display: block !important;
        }
        .onboarding-form .form-input {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #f8fafc !important;
            border-radius: 12px !important;
            padding: 12px 14px !important;
            font-size: 0.92rem !important;
            font-family: inherit !important;
            transition: all 0.2s ease !important;
            outline: none !important;
            box-sizing: border-box !important;
            width: 100% !important;
        }
        .onboarding-form .form-input:focus {
            border-color: #a855f7 !important;
            box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.15) !important;
            background: #090915 !important;
        }
        .onboarding-back-btn {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #94a3b8 !important;
            border-radius: 20px !important;
            padding: 6px 14px !important;
            font-size: 0.78rem !important;
            font-weight: 600 !important;
            font-family: 'Outfit', sans-serif !important;
            margin-bottom: 16px !important;
            transition: all 0.2s ease !important;
            outline: none !important;
        }
        .onboarding-back-btn:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.05) !important;
            color: #ffffff !important;
        }
        .password-strength-container {
            display: flex !important;
            align-items: center !important;
            gap: 10px !important;
            margin-top: 8px !important;
        }
        .password-strength-bar {
            flex: 1 !important;
            height: 6px !important;
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
            border-radius: 10px !important;
            overflow: hidden !important;
        }
        .password-strength-fill {
            height: 100% !important;
            border-radius: 10px !important;
            transition: all 0.3s ease !important;
        }
        .password-strength-fill.weak {
            background: linear-gradient(90deg, #ef4444 0%, #f87171 100%) !important;
        }
        .password-strength-fill.medium {
            background: linear-gradient(90deg, #f59e0b 0%, #fbbf24 100%) !important;
        }
        .password-strength-fill.strong {
            background: linear-gradient(90deg, #22c55e 0%, #4ade80 100%) !important;
        }
        .password-strength-label {
            font-size: 0.7rem !important;
            font-weight: 700 !important;
            letter-spacing: 0.5px !important;
            text-transform: uppercase !important;
            font-family: 'Outfit', sans-serif !important;
            min-width: 55px !important;
            text-align: right !important;
        }
        .password-strength-label.weak { color: #f87171 !important; }
        .password-strength-label.medium { color: #fbbf24 !important; }
        .password-strength-label.strong { color: #4ade80 !important; }

        .password-requirements {
            display: grid !important;
            grid-template-columns: 1fr 1fr !important;
            gap: 8px 12px !important;
            margin-top: 12px !important;
            padding: 10px 14px !important;
            background: #000000 !important;
            border-radius: 10px !important;
            border: 1px solid rgba(255, 255, 255, 0.06) !important;
        }
        .password-req {
            display: flex !important;
            align-items: center !important;
            gap: 6px !important;
            font-size: 0.72rem !important;
            color: #64748b !important;
            font-family: 'Outfit', sans-serif !important;
        }
        .password-req .req-icon {
            width: 12px !important;
            height: 12px !important;
            stroke: #475569 !important;
            stroke-width: 3 !important;
            fill: none !important;
            transition: all 0.2s ease !important;
        }
        .password-req.met {
            color: #4ade80 !important;
        }
        .password-req.met .req-icon {
            stroke: #22c55e !important;
            fill: rgba(34, 197, 94, 0.15) !important;
        }
        .password-match-status {
            display: flex !important;
            align-items: center !important;
            gap: 6px !important;
            margin-top: 8px !important;
            font-size: 0.8rem !important;
            font-weight: 600 !important;
            font-family: 'Outfit', sans-serif !important;
        }
        .password-match-status.match {
            color: #4ade80 !important;
        }
        .password-match-status.no-match {
            color: #f87171 !important;
        }
        .password-match-status svg {
            width: 14px !important;
            height: 14px !important;
            flex-shrink: 0 !important;
        }

        /* Submit Buttons Overrides */
        .onboarding-form button.btn-primary,
        .onboarding-form .btn-primary {
            background: linear-gradient(135deg, #a855f7 0%, #7c3aed 100%) !important;
            border: none !important;
            border-radius: 12px !important;
            color: #ffffff !important;
            font-weight: 700 !important;
            font-family: 'Outfit', sans-serif !important;
            box-shadow: 0 4px 14px rgba(168, 85, 247, 0.25) !important;
            transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
            cursor: pointer !important;
            outline: none !important;
        }
        .onboarding-form button.btn-primary:hover,
        .onboarding-form .btn-primary:hover {
            transform: translateY(-1px) scale(1.01) !important;
            box-shadow: 0 6px 20px rgba(168, 85, 247, 0.45) !important;
        }
        .onboarding-form button.btn-primary:active,
        .onboarding-form .btn-primary:active {
            transform: translateY(1px) scale(0.99) !important;
        }

        /* Form Error Banners */
        .onboarding-form .form-error {
            background: #000000 !important;
            border: 1px solid #ef4444 !important;
            border-radius: 12px !important;
            color: #f87171 !important;
            box-shadow: 0 0 12px rgba(239, 68, 68, 0.15) !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 500 !important;
            font-size: 0.82rem !important;
            padding: 12px 14px !important;
            margin-top: 12px !important;
        }

        /* Form Navigation Links */
        .onboarding-step p a,
        .onboarding-form p a,
        .onboarding-form a {
            color: #c084fc !important;
            font-weight: 600 !important;
            text-decoration: none !important;
            transition: all 0.2s ease !important;
        }
        .onboarding-step p a:hover,
        .onboarding-form p a:hover,
        .onboarding-form a:hover {
            color: #a855f7 !important;
            text-decoration: underline !important;
        }

        /* ── Timezone Picker OLED overrides ── */
        .tz-picker-overlay {
            background: rgba(0, 0, 0, 0.90) !important;
        }
        .tz-picker-panel {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            box-shadow: 
                0 25px 70px rgba(0, 0, 0, 0.95), 
                0 0 40px rgba(168, 85, 247, 0.05) !important;
            border-radius: 18px !important;
        }
        .tz-picker-title {
            background: #000000 !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
            color: #ffffff !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 800 !important;
            letter-spacing: 0.3px !important;
        }
        .tz-picker-close-btn {
            color: #94a3b8 !important;
            outline: none !important;
        }
        .tz-picker-close-btn:hover {
            color: #ffffff !important;
        }
        .timezone-dropdown-header {
            background: #05050c !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.05) !important;
            color: #475569 !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 700 !important;
            letter-spacing: 0.8px !important;
            font-size: 0.82rem !important;
        }
        .timezone-option {
            background: #000000 !important;
            border-bottom: 1px solid rgba(255, 255, 255, 0.03) !important;
            transition: all 0.2s ease !important;
        }
        .timezone-option:hover {
            background: #090915 !important;
        }
        .timezone-option.selected {
            background: rgba(168, 85, 247, 0.08) !important;
        }
        .timezone-option.selected .tz-name {
            color: #c084fc !important;
            font-weight: 600 !important;
        }
        .timezone-option .tz-name {
            color: #f8fafc !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.94rem !important;
        }
        .timezone-option .tz-offset {
            color: #64748b !important;
            font-family: monospace !important;
            font-size: 0.85rem !important;
        }
        .timezone-option.auto {
            border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
        }
        .timezone-option.auto .tz-name {
            color: #22c55e !important;
        }
        .timezone-option.server-tz {
            background: rgba(168, 85, 247, 0.03) !important;
            border-bottom: 1px solid rgba(168, 85, 247, 0.15) !important;
        }
        .timezone-option.server-tz .tz-name {
            color: #a855f7 !important;
        }

        /* ── Preferences Modal OLED overrides ── */
        #preferencesModal .modal {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            border-radius: 18px !important;
            box-shadow: 
                0 25px 70px rgba(0, 0, 0, 0.95), 
                0 0 40px rgba(168, 85, 247, 0.05) !important;
        }
        #preferencesModal .modal-header {
            border-bottom: 1px solid rgba(255, 255, 255, 0.07) !important;
            padding: 16px 20px !important;
        }
        #preferencesModal .modal-title {
            color: #ffffff !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 800 !important;
        }
        #preferencesModal .modal-close {
            color: #94a3b8 !important;
            outline: none !important;
        }
        #preferencesModal .modal-close:hover {
            color: #ffffff !important;
        }
        .pref-section {
            background: #05050c !important;
            border: 1px solid rgba(255, 255, 255, 0.07) !important;
            border-radius: 12px !important;
            padding: 16px !important;
            margin-bottom: 12px !important;
        }
        .pref-section-title {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 800 !important;
            color: #ffffff !important;
        }
        .pref-section-desc {
            color: #475569 !important;
        }
        .pref-toggle-label {
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            color: #f8fafc !important;
            font-size: 0.88rem !important;
        }
        .pref-toggle-desc {
            color: #475569 !important;
            font-size: 0.76rem !important;
        }
        #preferencesModal select.form-select {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            color: #f8fafc !important;
            border-radius: 8px !important;
            padding: 6px 12px !important;
            outline: none !important;
            font-family: 'Outfit', sans-serif !important;
            font-size: 0.88rem !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
        }
        #preferencesModal select.form-select:focus {
            border-color: #a855f7 !important;
            box-shadow: 0 0 0 3px rgba(168, 85, 247, 0.15) !important;
        }
        #preferencesModal .pref-toggle button.btn-secondary {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.09) !important;
            color: #94a3b8 !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            font-size: 0.82rem !important;
            border-radius: 8px !important;
            padding: 6px 14px !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
            outline: none !important;
        }
        #preferencesModal .pref-toggle button.btn-secondary:hover {
            border-color: #a855f7 !important;
            background: rgba(168, 85, 247, 0.05) !important;
            color: #ffffff !important;
        }
        #preferencesModal .btn-danger {
            background: rgba(239, 68, 68, 0.08) !important;
            border: 1px solid rgba(239, 68, 68, 0.25) !important;
            color: #f87171 !important;
            font-family: 'Outfit', sans-serif !important;
            font-weight: 600 !important;
            font-size: 0.85rem !important;
            border-radius: 10px !important;
            padding: 10px 16px !important;
            cursor: pointer !important;
            transition: all 0.2s ease !important;
            outline: none !important;
        }
        #preferencesModal .btn-danger:hover {
            background: rgba(239, 68, 68, 0.15) !important;
            border-color: #ef4444 !important;
        }

        /* ── Glowing Switch Toggles inside Modals ── */
        .modal-body .toggle-switch .toggle-slider {
            background: #000000 !important;
            border: 1px solid rgba(255, 255, 255, 0.08) !important;
        }
        .modal-body .toggle-switch .toggle-slider:before {
            background: #475569 !important;
        }
        .modal-body .toggle-switch input:checked + .toggle-slider {
            background: rgba(34, 197, 94, 0.15) !important;
            border-color: #22c55e !important;
            box-shadow: 0 0 12px rgba(34, 197, 94, 0.2) !important;
        }
        .modal-body .toggle-switch input:checked + .toggle-slider:before {
            background: #22c55e !important;
            box-shadow: 0 2px 6px rgba(34, 197, 94, 0.3) !important;
        }

        /* Mobile overrides */
        @media (max-width: 480px) {
            .onboarding-box {
                width: 94% !important;
                padding: 20px 16px 12px 16px !important;
                margin: 10px auto !important;
                border-radius: 14px !important;
            }
            .onboarding-icon {
                font-size: 2.2rem !important;
            }
            .onboarding-title {
                font-size: 1.25rem !important;
            }
            .onboarding-subtitle {
                font-size: 0.8rem !important;
            }
            .onboarding-account-option {
                padding: 10px 12px !important;
                gap: 10px !important;
            }
            .onboarding-account-icon {
                width: 36px !important;
                height: 36px !important;
            }
            .onboarding-account-title {
                font-size: 0.9rem !important;
            }
            .onboarding-account-desc {
                font-size: 0.76rem !important;
            }
            .onboarding-settings-content {
                padding: 10px !important;
            }
            .onboarding-categories-grid {
                padding: 8px !important;
                gap: 4px !important;
            }
            .onboarding-category-chip {
                padding: 5px 10px !important;
                font-size: 0.74rem !important;
            }

            /* Create Account Form Mobile Optimization */
            .onboarding-form .form-group {
                margin-bottom: 10px !important;
            }
            .onboarding-form .form-label {
                font-size: 0.75rem !important;
                margin-bottom: 4px !important;
            }
            .onboarding-form .form-input {
                padding: 10px 12px !important;
                font-size: 0.88rem !important;
            }
            .password-requirements {
                grid-template-columns: 1fr !important;
                gap: 6px !important;
                padding: 8px 12px !important;
                margin-top: 8px !important;
            }
            .onboarding-back-btn {
                margin-bottom: 10px !important;
                padding: 5px 12px !important;
                font-size: 0.74rem !important;
            }
            .onboarding-form button.btn-primary,
            .onboarding-form .btn-primary {
                padding: 12px !important;
                font-size: 0.88rem !important;
                margin-top: 12px !important;
            }

            /* Timezone Picker Mobile sheet overrides */
            .tz-picker-panel {
                background: #000000 !important;
                border-top: 1px solid rgba(255, 255, 255, 0.09) !important;
                border-left: none !important;
                border-right: none !important;
                border-bottom: none !important;
                box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.9) !important;
            }
            .tz-picker-handle::after {
                background: rgba(255, 255, 255, 0.2) !important;
            }
            .tz-picker-title {
                padding: 12px 16px !important;
                font-size: 0.95rem !important;
            }
            .timezone-option {
                padding: 10px 16px !important;
            }
            .timezone-option .tz-name {
                font-size: 0.88rem !important;
            }
            .timezone-option .tz-offset {
                font-size: 0.80rem !important;
            }
            .timezone-dropdown-header {
                padding: 6px 16px !important;
                font-size: 0.76rem !important;
            }

            /* Preferences Modal Mobile Overrides */
            #preferencesModal .modal {
                width: 94% !important;
                padding: 0 !important;
                margin: 10px auto !important;
            }
            .pref-section {
                padding: 12px !important;
                margin-bottom: 10px !important;
                border-radius: 10px !important;
            }
            .pref-section-title {
                font-size: 0.88rem !important;
            }
            .pref-section-desc {
                font-size: 0.76rem !important;
                margin-bottom: 12px !important;
            }
            .pref-toggle-label {
                font-size: 0.82rem !important;
            }
            .pref-toggle-desc {
                font-size: 0.72rem !important;
            }
        }




