:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:none}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--color-primary: #6366f1;--color-primary-hover: #5147dc;--color-primary-light: #a5b4fc;--color-secondary: #3b82f6;--color-accent: #f59e0b;--color-success: #10b981;--color-success-hover: #059669;--color-success-light: #34d399;--color-danger: #dc3545;--color-danger-hover: #c82333;--color-warning: #fbbf24;--color-warning-hover: #f59e0b;--color-info: #3b82f6;--color-info-hover: #2563eb;--color-surface-primary: rgba(255, 255, 255, .05);--color-surface-secondary: rgba(255, 255, 255, .08);--color-surface-hover: rgba(255, 255, 255, .1);--color-surface-active: rgba(255, 255, 255, .15);--color-surface-input: rgba(0, 0, 0, .3);--color-border-primary: rgba(255, 255, 255, .1);--color-border-secondary: rgba(255, 255, 255, .12);--color-border-focus: rgba(255, 255, 255, .2);--color-border-strong: rgba(255, 255, 255, .25);--color-text-primary: rgba(255, 255, 255, .9);--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .6);--color-text-disabled: rgba(255, 255, 255, .5);--color-text-inverse: white;--color-backdrop: rgba(24, 24, 28, .9);--color-backdrop-strong: rgba(24, 24, 28, .95);--color-modal-backdrop: rgba(0, 0, 0, .5);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem;--spacing-2xl: 2rem;--spacing-3xl: 3rem;--spacing-4xl: 4rem;--radius-sm: 3px;--radius-base: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 10px;--radius-2xl: 12px;--radius-3xl: 16px;--radius-full: 999px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.75rem;--font-size-4xl: 2rem;--font-size-5xl: 2.5rem;--font-size-6xl: 3.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-base: 1.4;--line-height-relaxed: 1.6;--size-icon-sm: 1.5rem;--size-icon-base: 2rem;--size-icon-lg: 2.5rem;--size-button-height: 2.5rem;--size-input-height: 2.5rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--backdrop-blur: blur(6px);--backdrop-blur-strong: blur(10px);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .1);--shadow-base: 0 4px 12px rgba(0, 0, 0, .15);--shadow-lg: 0 6px 20px rgba(0, 0, 0, .25);--shadow-glow: 0 4px 12px rgba(255, 215, 0, .25);--shadow-glow-strong: 0 6px 20px rgba(255, 215, 0, .4);--z-base: 1;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--max-width-container: 960px;--max-width-content: 1200px;--min-height-list-box: 29.5rem;--height-topbar: 3.25rem;--height-pager: 2.25rem}@media (prefers-color-scheme: light){:root{--color-surface-primary: rgba(0, 0, 0, .05);--color-surface-secondary: rgba(0, 0, 0, .03);--color-surface-hover: rgba(0, 0, 0, .08);--color-surface-active: rgba(0, 0, 0, .1);--color-surface-input: rgba(255, 255, 255, .8);--color-border-primary: rgba(0, 0, 0, .12);--color-border-secondary: rgba(0, 0, 0, .15);--color-border-focus: rgba(0, 0, 0, .2);--color-border-strong: rgba(0, 0, 0, .25);--color-text-primary: #1f2937;--color-text-secondary: #374151;--color-text-muted: #6b7280;--color-text-disabled: rgba(0, 0, 0, .5);--color-backdrop: rgba(248, 250, 252, .9);--color-backdrop-strong: rgba(255, 255, 255, .95);--color-modal-backdrop: rgba(0, 0, 0, .7);--shadow-glow: 0 4px 12px rgba(255, 193, 7, .2);--shadow-glow-strong: 0 6px 20px rgba(255, 193, 7, .35)}}*,*:before,*:after{box-sizing:border-box}input[type=text],input:not([type]),textarea,select,button{max-width:100%;font-family:inherit}button:focus,button:focus-visible,input:focus,select:focus,textarea:focus,.icon-button:focus,.primary-button:focus,.secondary-button:focus,.action-button:focus,.nav-link:focus{outline:none}ul,ol{margin:var(--spacing-sm) 0 0 var(--spacing-lg)}.entrants-list,.winners-list{overflow-wrap:anywhere}li{display:flex;align-items:center;gap:var(--spacing-sm);min-height:3.6rem}.link{background:transparent;color:#8b949e;border:none;text-decoration:underline;cursor:pointer}.empty{color:#888;margin:var(--spacing-sm) 0 0}#root{max-width:var(--max-width-container);margin:0 auto;padding:var(--spacing-2xl)}.container{padding-top:var(--height-topbar);padding-bottom:var(--spacing-2xl)}.columns{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.entrants-box,.winners-box{display:grid;grid-template-rows:auto var(--min-height-list-box) var(--height-pager);align-items:start;overflow:hidden}.entrants-box .listbox,.winners-box .listbox{grid-row:2;display:flow-root}.entrants-box>.empty,.winners-box>.empty{grid-row:2}.entrants-box .pager,.winners-box .pager{grid-row:3;margin-top:0;height:var(--height-pager);align-items:center}section{padding:var(--spacing-lg);border:1px solid var(--color-border-secondary);border-radius:var(--radius-lg)}.controls{display:flex;align-items:center;justify-content:flex-start;margin-bottom:var(--spacing-lg)}.controls input{flex:1;padding:var(--spacing-sm) var(--spacing-md)}.controls-bar{position:fixed;left:0;right:0;bottom:0;background:var(--color-backdrop);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-top:1px solid var(--color-border-secondary);padding:var(--spacing-sm) var(--spacing-lg);margin:0;z-index:900;padding-bottom:calc(var(--spacing-sm) + env(safe-area-inset-bottom))}.controls-bar .controls-inner{max-width:var(--max-width-container);margin:0 auto}.controls-left{display:flex;align-items:center;gap:var(--spacing-sm)}.controls-left>div{display:flex;gap:var(--spacing-sm);align-items:center}.bulk-panel{position:fixed;left:0;right:0;bottom:calc(var(--height-topbar) + env(safe-area-inset-bottom));background:var(--color-backdrop-strong);border-top:1px solid var(--color-border-secondary);padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);z-index:901}.bulk-panel .bulk{max-width:var(--max-width-container);margin:0 auto}.preserve-space{visibility:hidden}.topbar{position:fixed;top:0;left:0;right:0;background:var(--color-backdrop);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-bottom:1px solid var(--color-border-secondary);z-index:var(--z-fixed);padding-top:env(safe-area-inset-top);max-height:var(--height-topbar)}.topbar-inner{max-width:var(--max-width-container);margin:0 auto;padding:var(--spacing-sm) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);height:var(--height-topbar);max-height:var(--height-topbar);overflow:visible}.topbar-left{display:flex;align-items:center;gap:var(--spacing-lg)}.topbar-nav{display:flex;align-items:center;gap:var(--spacing-sm)}.topbar-title{margin:0;padding:0;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight);display:flex;align-items:center;transition:color var(--transition-base)}.topbar-title:hover{color:var(--color-primary)}.topbar-train-icon{filter:brightness(0) invert(1)}@media (prefers-color-scheme: light){.topbar-train-icon{filter:brightness(0) invert(0)}}.nav-link{color:var(--color-text-primary);text-decoration:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);transition:all var(--transition-base);background:none;border:none;cursor:pointer;font:inherit;display:inline-flex;align-items:center;gap:var(--spacing-sm)}.nav-link:hover{background:var(--color-surface-active);color:var(--color-text-primary);transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.nav-link.active{background:#6366f133;color:var(--color-primary-light)}@media (prefers-color-scheme: light){.nav-link:hover{background:var(--color-surface-active);color:var(--color-text-primary);box-shadow:0 2px 8px #0000001a}.nav-link.active{background:#6366f126;color:var(--color-primary);border:1px solid rgba(99,102,241,.3)}}.topbar-raffle-selector{display:flex;align-items:center;gap:var(--spacing-sm)}.topbar-raffle-selector select{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-inverse);min-width:120px;font-size:var(--font-size-sm)}.topbar-raffle-selector button{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-hover);color:var(--color-text-inverse);cursor:pointer;transition:background var(--transition-base)}.topbar-raffle-selector button:hover{background:var(--color-surface-active)}.topbar-raffle-selector .delete-raffle{background:var(--color-danger);border-color:var(--color-danger)}.topbar-raffle-selector .delete-raffle:hover{background:var(--color-danger-hover)}.topbar-auth,.topbar .auth-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.topbar .auth-controls input,.topbar .auth-controls button{padding:var(--spacing-sm) var(--spacing-md)}.signed-in{opacity:.9;margin-right:var(--spacing-xs)}.offline{color:var(--color-text-muted)}@media (prefers-color-scheme: light){.offline{color:var(--color-text-muted);opacity:.8}}.desktop-admin-controls{display:flex;align-items:center;gap:var(--spacing-sm)}.mobile-admin-menu{display:none;position:relative}.admin-dropdown{right:0;left:auto}.icon-button{padding:var(--spacing-sm);width:var(--size-icon-lg);height:var(--size-icon-lg);border-radius:var(--radius-md);border:1px solid var(--color-border-focus);background:var(--color-surface-hover);color:var(--color-text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.icon-button:hover{background:var(--color-surface-active)}.icon-button:disabled{opacity:.5;cursor:not-allowed}.icon-button.delete-raffle,.icon-button.scheduled{background:var(--color-danger);border-color:var(--color-danger);color:var(--color-text-inverse)}.icon-button.delete-raffle:hover:not(:disabled),.icon-button.scheduled:hover{background:var(--color-danger-hover)}.icon-button.clock-button:not(.scheduled){background:var(--color-success);border-color:var(--color-success)}.icon-button.clock-button:not(.scheduled):hover{background:var(--color-success-hover)}.icon-button.delete-button{background:#dc262633;border:1px solid rgba(220,38,38,.3);color:#fca5a5}.icon-button.delete-button:hover{background:#dc26264d;border-color:#dc262680}@media (prefers-color-scheme: light){.icon-button{background:#0000000d;border-color:#00000026;color:var(--color-text-primary)}.icon-button:hover{background:#0000001a;border-color:#0003}.icon-button.delete-button{background:#dc26261a;border-color:#dc262633;color:var(--color-danger)}.icon-button.delete-button:hover{background:#dc262626;border-color:#dc26264d}}.primary-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-primary);color:var(--color-text-inverse);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-base)}.primary-button:hover{background:var(--color-primary-hover)}.primary-button:disabled{background:#6366f180;cursor:not-allowed}.secondary-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-surface-hover);color:var(--color-text-primary);border:1px solid var(--color-border-focus);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-base)}.secondary-button:hover{background:var(--color-surface-active)}.action-button{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);border:1px solid var(--color-border-primary);background:var(--color-surface-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base)}.action-button:hover{background:var(--color-surface-active);transform:translateY(-1px)}.action-button:active{transform:translateY(0)}.action-button:disabled{opacity:.5;cursor:not-allowed}.redraw-button{border-color:#ffc10780;background:#ffc10726}.redraw-button:hover{background:#ffc10740;border-color:#ffc107b3}.confirm-button{border-color:#22c55e80;background:#22c55e26}.confirm-button:hover{background:#22c55e40;border-color:#22c55eb3}.back-button,.back-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface-hover);color:var(--color-text-primary);border:1px solid var(--color-border-focus);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-base);text-decoration:none}.back-button:hover,.back-btn:hover{background:var(--color-surface-active)}.delete-button{display:inline-flex;align-items:center;background:#dc354533;border:1px solid rgba(220,53,69,.4);color:var(--color-text-primary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-sm);white-space:nowrap}.delete-button:hover{background:#dc35454d;border-color:#dc354599}.remove-button{padding:var(--spacing-sm);background:#dc354533;border:1px solid rgba(220,53,69,.4);color:var(--color-text-primary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base);width:var(--size-icon-base);height:var(--size-icon-base);display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-button:hover{background:#dc35454d;border-color:#dc354599}.google-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.45rem .9rem;border-radius:var(--radius-full);border:1px solid var(--color-border-focus);background:#fff;color:#111;font-weight:var(--font-weight-semibold);line-height:1;box-shadow:var(--shadow-base);cursor:pointer;transition:all var(--transition-base)}.google-btn:hover{filter:brightness(.98);border-color:#00000026}.google-btn:focus-visible{outline:2px solid #8ab4f8;outline-offset:2px}.google-btn:active{transform:translateY(.5px)}.copy-button{padding:var(--spacing-sm) var(--spacing-lg);background:#007bff33;border:1px solid rgba(0,123,255,.4);color:var(--color-text-primary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-sm);white-space:nowrap}.copy-button:hover{background:#007bff4d;border-color:#007bff99}.create-link-button{padding:var(--spacing-md) var(--spacing-xl);background:#28a74533;border:1px solid rgba(40,167,69,.4);color:var(--color-text-primary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base);font-weight:var(--font-weight-medium);margin-top:var(--spacing-lg)}.create-link-button:hover:not(:disabled){background:#28a7454d;border-color:#28a74599}.create-link-button:disabled{opacity:.5;cursor:not-allowed}.form-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-field label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin:0}.form-field input,.form-field select,.form-field textarea{width:100%;padding:var(--spacing-md);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-primary);font-size:var(--font-size-base);box-sizing:border-box;font-family:inherit;transition:border-color var(--transition-base)}.form-field select{cursor:pointer}.form-field textarea{resize:vertical;min-height:120px}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--color-primary)}.form-field .help-text{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group input,.form-group select{width:100%;padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-primary);font-size:var(--font-size-base)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}.mode-toggle{display:flex;gap:var(--spacing-sm)}.mode-toggle button{flex:1;padding:var(--spacing-md);border:1px solid var(--color-border-focus);background:var(--color-surface-primary);color:var(--color-text-secondary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base)}.mode-toggle button.active{background:#646cff33;border-color:#646cff66;color:var(--color-text-primary)}.mode-toggle button:hover{background:var(--color-surface-secondary);border-color:var(--color-border-strong);color:var(--color-text-primary)}.mode-toggle button.active:hover{background:#646cff4d}.add-name-mode-toggle{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.add-name-mode-toggle button{padding:var(--spacing-sm) var(--spacing-lg);border:1px solid var(--color-border-focus);background:var(--color-surface-hover);color:var(--color-text-inverse);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base)}.add-name-mode-toggle button.active{background:#646cff4d;border-color:#646cff80}.single-add input,.bulk-add textarea{width:100%;padding:var(--spacing-md);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-inverse);margin-bottom:var(--spacing-lg);box-sizing:border-box}.bulk{margin:var(--spacing-sm) 0 var(--spacing-lg);width:100%}.bulk textarea{width:100%;resize:vertical}.bulk-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:var(--spacing-sm)}.bulk-row{display:flex;justify-content:flex-end}.modal-overlay,.modal-backdrop{position:fixed;inset:0;background:var(--color-modal-backdrop);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop)}.modal{background:var(--color-backdrop-strong);border:1px solid var(--color-border-secondary);border-radius:var(--radius-xl);width:min(90vw,720px);max-height:80vh;display:flex;flex-direction:column;box-sizing:border-box;overflow:auto;min-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-secondary)}.modal-header h2{margin:0;color:var(--color-text-primary)}.modal-header button{background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-2xl);cursor:pointer;padding:0;width:var(--size-icon-base);height:var(--size-icon-base);display:flex;align-items:center;justify-content:center;transition:color var(--transition-base)}.modal-header button:hover{color:var(--color-text-primary)}.modal-body{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);overflow:auto;box-sizing:border-box}.modal-body label{display:block;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.modal-body input{width:100%;padding:var(--spacing-md);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-primary);margin-top:var(--spacing-sm)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-lg);padding:var(--spacing-lg);border-top:1px solid var(--color-border-secondary)}.create-raffle-form,.schedule-draw-form,.add-entrant-form,.manage-entrants-form,.join-link-management-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.join-link-management-form{gap:var(--spacing-2xl)}.entrants-list,.winners-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.entrants-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.entrants-section .entrants-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.entrants-section .entrants-list li{list-style:none;margin:0;padding:.5em .6em;display:flex;flex-direction:row;gap:var(--spacing-sm);min-height:2.25rem}.entrants-list li{display:grid;grid-template-columns:1fr;grid-template-rows:1.5em 1.8em;grid-template-areas:"name" "actions";row-gap:.15rem;align-items:center;padding:.4rem 0}.entrants-list li+li{border-top:1px solid var(--color-border-secondary)}.entrants-list .name{grid-area:name;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entrants-list .name.blacklisted{text-decoration:line-through;opacity:.6;color:#888}.entrants-list .actions{grid-area:actions;justify-self:start;display:inline-flex;gap:var(--spacing-sm);white-space:nowrap}.entrants-list .actions .btn{appearance:none;border:1px solid var(--color-border-primary);background:var(--color-surface-secondary);color:var(--color-text-primary);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-sm);line-height:1.2;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:var(--spacing-xs)}.entrants-list .actions .btn:hover{background:var(--color-surface-hover)}.entrants-list .actions .btn:focus-visible{outline:2px solid #8ab4f8;outline-offset:1px}.entrants-list .actions .btn:active{transform:translateY(.5px)}.entrants-list .actions .btn-select{border-color:#10b98166;background:#10b98126;color:var(--color-success)}.entrants-list .actions .btn-select:hover{background:#10b98140;border-color:#10b98180}.entrants-list .actions .btn-remove{border-color:#dc354566;background:#dc354526;color:var(--color-danger)}.entrants-list .actions .btn-remove:hover{background:#dc354540;border-color:#dc354580}.entrants-list .actions .btn-ticket{border-color:#3b82f666;background:#3b82f626;color:var(--color-info)}.entrants-list .actions .btn-ticket:hover{background:#3b82f640;border-color:#3b82f680}@media (prefers-color-scheme: light){.entrants-list .actions .btn{background:#00000008;border-color:#0000001f;color:var(--color-text-primary)}.entrants-list .actions .btn:hover{background:#00000014;border-color:#00000026}.entrants-list .actions .btn-select{background:#10b98132;border-color:#10b98174;color:var(--color-success)}.entrants-list .actions .btn-select:hover{background:#10b98126;border-color:#10b9814d}.entrants-list .actions .btn-remove{background:#dc35451a;border-color:#dc354533;color:var(--color-danger)}.entrants-list .actions .btn-remove:hover{background:#dc354526;border-color:#dc35454d}.entrants-list .actions .btn-ticket{background:#3b82f61a;border-color:#3b82f633;color:var(--color-info)}.entrants-list .actions .btn-ticket:hover{background:#3b82f626;border-color:#3b82f64d}}.entrant-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-surface-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-base)}.entrant-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.winners-list li{display:grid;grid-template-columns:1fr;grid-template-rows:1.5em 1.8em;grid-template-areas:"name" "actions";row-gap:.15rem;align-items:center;padding:.4rem 0}.winners-list li+li{border-top:1px solid var(--color-border-secondary)}.winner-name{grid-area:name;white-space:normal;overflow:visible;text-overflow:clip;overflow-wrap:anywhere}.extra-tickets{font-size:var(--font-size-xs);color:#999;margin-left:var(--spacing-sm);opacity:.85;font-weight:var(--font-weight-medium)}.winner-meta{display:contents}.badge{grid-area:badge;justify-self:start;font-size:var(--font-size-sm);opacity:.85;background:var(--color-surface-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-full);padding:.1rem var(--spacing-sm)}.winner-time{grid-area:actions;justify-self:end;opacity:.75;text-align:right;font-variant-numeric:tabular-nums;font-size:var(--font-size-sm)}.winners-list .actions{grid-area:actions;justify-self:start;display:inline-flex;gap:var(--spacing-sm);white-space:nowrap;margin-top:.2rem}.winners-list .actions .btn{appearance:none;border:1px solid var(--color-border-primary);background:var(--color-surface-secondary);color:var(--color-text-primary);padding:.2rem .6rem;font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);line-height:1.2;border-radius:var(--radius-base)}.winners-list .actions .btn:hover{background:var(--color-surface-hover)}.winners-list .actions .btn:focus-visible{outline:2px solid #8ab4f8;outline-offset:1px}.winners-list .actions .btn:active{transform:translateY(.5px)}.winners-list .actions .btn-revert{border-color:#fbbf2466;background:#fbbf2426}.winners-list .actions .btn-revert:hover{background:#fbbf2440;border-color:#fbbf2480}@media (prefers-color-scheme: light){.winners-list .actions .btn{background:#00000008;border-color:#0000001f;color:var(--color-text-primary)}.winners-list .actions .btn:hover{background:#00000014;border-color:#00000026}.winners-list .actions .btn-revert{background:#fbbe243a;border-color:#fbbe2477}.winners-list .actions .btn-revert:hover{background:#fbbf2426;border-color:#fbbf244d}}.winner-display{flex:1}.winner-controls{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md);align-items:center}.last-winner{background:#646cff26;border:1px solid rgba(100,108,255,.4);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg)}.recent-winner{background:linear-gradient(135deg,#ffd70033,#ffa50026);border:2px solid rgba(255,215,0,.6);padding:1.25rem var(--spacing-xl);border-radius:var(--radius-2xl);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-glow);animation:glow 2s ease-in-out infinite alternate;margin-bottom:var(--spacing-lg)}@media (prefers-color-scheme: light){.last-winner{background:#646cff1a;border-color:#646cff4d;color:var(--color-text-primary)}.recent-winner{background:linear-gradient(135deg,#ffd70026,#ffa5001a);border-color:#ffd70066;color:var(--color-text-primary)}}@keyframes glow{0%{box-shadow:var(--shadow-glow)}to{box-shadow:var(--shadow-glow-strong)}}.scheduled-draw-countdown{background:#ffc10726;border:1px solid rgba(255,193,7,.4);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);text-align:center;animation:countdown-pulse 2s infinite ease-in-out}@keyframes countdown-pulse{0%,to{opacity:.8}50%{opacity:1}}.scheduled-draw-prompt{background:#dc354526;border:2px solid rgba(220,53,69,.5);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);animation:prompt-alert 1.5s infinite ease-in-out}.prompt-content{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.prompt-content svg{color:var(--color-danger);flex-shrink:0}.prompt-text{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:200px}.prompt-text strong{color:var(--color-danger);font-weight:var(--font-weight-semibold)}.prompt-text span{font-size:.9em;opacity:.8}.prompt-buttons{display:flex;gap:var(--spacing-sm);flex-shrink:0}.prompt-buttons .btn-primary{background:var(--color-danger);color:var(--color-text-inverse);border:none;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--spacing-sm);transition:background-color var(--transition-base)}.prompt-buttons .btn-primary svg{color:var(--color-text-inverse)}.prompt-buttons .btn-primary:hover:not(:disabled){background:var(--color-danger-hover)}.prompt-buttons .btn-primary:disabled{opacity:.6;cursor:not-allowed}.prompt-buttons .btn-secondary{background:transparent;color:#6c757d;border:1px solid #6c757d;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);display:flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-base)}.prompt-buttons .btn-secondary:hover{background:#6c757d;color:var(--color-text-inverse)}@keyframes prompt-alert{0%,to{border-color:#dc354580;background:#dc354526}50%{border-color:#dc3545cc;background:#dc354540}}.success-message{background:#10b98133;border:1px solid var(--color-success);border-radius:var(--radius-md);padding:var(--spacing-lg);margin:var(--spacing-lg) 0;color:var(--color-success)}.error-message{background:#ef444433;border:1px solid #ef4444;border-radius:var(--radius-md);padding:var(--spacing-lg);margin:var(--spacing-lg) 0;color:#ef4444}.error-state{text-align:center;padding:var(--spacing-4xl) var(--spacing-2xl)}.error-state h2{color:#ef4444;margin-bottom:var(--spacing-lg)}.empty-state{text-align:center;padding:var(--spacing-2xl) var(--spacing-lg)}.empty-message{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.empty-state h3{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.empty-state p{margin-bottom:var(--spacing-2xl)}.loading-overlay{display:flex;align-items:center;justify-content:center;min-height:400px;background:#18181c;border-radius:var(--radius-2xl);border:1px solid var(--color-border-primary)}@media (prefers-color-scheme: light){.loading-overlay{background:#fff}}.loading-content{text-align:center;color:var(--color-text-secondary)}.loading-content p{margin:var(--spacing-md) 0 0 0;font-size:var(--font-size-base)}.loading-spinner{animation:spin 1s linear infinite;color:var(--color-primary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.box-header h2{margin:0}.box-controls{display:flex;gap:var(--spacing-sm)}.section-header{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.section-header h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pager{margin-top:var(--spacing-sm);display:flex;height:var(--height-pager)}.pager-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;width:100%}.pager-inner button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface-hover);border:1px solid var(--color-border-primary);border-radius:var(--radius-base);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.pager-inner button:hover:not(:disabled){background:var(--color-surface-active);border-color:var(--color-border-strong)}.pager-inner button:disabled{opacity:.5;cursor:not-allowed}.pager-status{opacity:.8;color:var(--color-text-secondary)}.pager-inner>:first-child{justify-self:start}.pager-inner>.pager-status{justify-self:center}.pager-inner>:last-child{justify-self:end}@media (prefers-color-scheme: light){.pager-inner button{background:#0000000d;border-color:#0000001f}.pager-inner button:hover:not(:disabled){background:#0000001a;border-color:#0003}}.user-profile-dropdown{width:32px;height:32px;position:relative}.profile-button{width:32px;height:32px;padding:0;border:none;background:none;cursor:pointer;border-radius:var(--radius-full);overflow:hidden}.profile-picture{width:32px;height:32px;border-radius:var(--radius-full);object-fit:cover}.profile-picture-placeholder{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-surface-hover);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.dropdown-menu{position:absolute;top:calc(100% + var(--spacing-sm));right:0;background:var(--color-backdrop-strong);border:1px solid var(--color-border-secondary);border-radius:var(--radius-lg);padding:0;min-width:200px;z-index:var(--z-dropdown);-webkit-backdrop-filter:var(--backdrop-blur-strong);backdrop-filter:var(--backdrop-blur-strong)}.dropdown-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-secondary)}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.dropdown-item{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:none;border:none;color:var(--color-text-primary);cursor:pointer;text-align:left;display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);transition:background var(--transition-base)}.dropdown-item:hover{background:var(--color-surface-hover)}.create-link-section{display:flex;flex-direction:column;gap:var(--spacing-lg);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--color-border-primary)}.create-link-section h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.existing-links-section,.join-links-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.join-link-card{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-lg);background:var(--color-surface-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-md);gap:var(--spacing-lg)}.link-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.link-name{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.link-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);align-items:center}.stat{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.status.active{background:#28a74533;color:#28a745;border:1px solid rgba(40,167,69,.4)}.status.inactive{background:#6c757d33;color:#6c757d;border:1px solid rgba(108,117,125,.4)}.link-url{background:var(--color-surface-input);padding:var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border-primary)}.link-url code{font-size:var(--font-size-xs);color:var(--color-text-secondary);word-break:break-all}.link-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);flex-shrink:0}.raffle-variants{display:flex;flex-direction:column;gap:var(--spacing-lg)}.raffle-variants h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.variant-option{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);background:var(--color-surface-primary);cursor:pointer;transition:all var(--transition-base)}.variant-option:hover{background:var(--color-surface-secondary);border-color:var(--color-border-strong)}.variant-option input[type=checkbox]{width:1.25rem;height:1.25rem;margin:0;cursor:pointer;accent-color:rgba(100,108,255,.8)}.variant-option .variant-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.variant-option .variant-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.variant-option .variant-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;line-height:var(--line-height-base)}.variant-info strong{display:block;margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.variant-info p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.raffle-selector{margin:var(--spacing-lg) 0;padding:var(--spacing-lg);background:var(--color-surface-primary);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.raffle-selector label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.raffle-selector select{padding:var(--spacing-sm);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-inverse);min-width:150px}.raffle-selector button{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.raffle-selector .delete-raffle{background:var(--color-danger);color:var(--color-text-inverse)}.raffle-selector .delete-raffle:hover{background:var(--color-danger-hover)}.landing-page{max-width:var(--max-width-content);margin:0 auto;padding:var(--spacing-2xl)}.landing-hero{text-align:center;padding:var(--spacing-3xl) var(--spacing-lg);background:linear-gradient(135deg,#6366f11a,#a855f71a);border-radius:var(--radius-3xl);margin-bottom:var(--spacing-4xl)}.hero-content{max-width:600px;margin:0 auto}.hero-icon{margin-bottom:var(--spacing-xl)}.hero-icon .svg-mask{display:inline-block;width:160px;height:160px;background:var( --hero-icon-gradient, linear-gradient(135deg, #6366f1 0%, #a855f7 100%) );-webkit-mask:url(/train-time2.svg) no-repeat center / contain;mask:url(/train-time2.svg) no-repeat center / contain}.hero-icon .svg-mask[aria-hidden=true]{visibility:hidden}.hero-title{font-size:var(--font-size-6xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-lg);background:linear-gradient(135deg,#6366f1,#a855f7);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:var(--font-size-xl);color:var(--color-text-secondary);margin-bottom:0}.landing-description{margin-bottom:var(--spacing-4xl)}.description-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-2xl)}.feature-card{background:var(--color-surface-primary);border-radius:var(--radius-2xl);padding:var(--spacing-2xl);text-align:center;border:1px solid var(--color-border-primary);transition:transform var(--transition-base),background var(--transition-base)}.feature-card:hover{transform:translateY(-4px);background:var(--color-surface-secondary)}.feature-icon{color:var(--color-primary);margin-bottom:var(--spacing-lg)}.feature-card h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.feature-card p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.landing-actions{text-align:center}.raffles-list-page{max-width:var(--max-width-content);margin:0 auto;padding:var(--spacing-2xl)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.page-filters{display:flex;align-items:center;gap:var(--spacing-lg)}.filter-buttons{display:flex;gap:var(--spacing-sm);background:var(--color-surface-primary);border-radius:var(--radius-lg);padding:var(--spacing-xs);border:1px solid var(--color-border-primary)}.filter-button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.filter-button:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.filter-button.active{background:var(--color-primary);color:var(--color-text-inverse)}.filter-button.active:hover{background:var(--color-primary-hover)}.page-header h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin:0}.raffles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.raffle-card{background:var(--color-surface-primary);border-radius:var(--radius-2xl);padding:var(--spacing-xl);border:1px solid var(--color-border-primary);transition:transform var(--transition-base),background var(--transition-base);display:flex;flex-direction:column}.raffle-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.raffle-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0;color:var(--color-text-primary)}.raffle-actions{display:flex;gap:var(--spacing-xs)}.raffle-actions .icon-button{background:var(--color-surface-hover);border-color:var(--color-border-primary);color:var(--color-text-primary)}.raffle-actions .icon-button:hover{background:var(--color-surface-active);border-color:var(--color-border-strong)}.raffle-meta{margin-bottom:var(--spacing-xl)}.raffle-created,.raffle-creator{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--spacing-xs) 0}.raffle-features{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-md);align-items:center}.feature-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#6366f133;color:var(--color-primary-light);border-radius:var(--radius-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);vertical-align:middle;border:1px solid rgba(99,102,241,.3)}.raffle-view-button{width:100%;justify-content:center;margin-top:auto;background:var(--color-primary);color:var(--color-text-inverse);border:none;padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:background var(--transition-base);text-decoration:none;display:inline-flex;align-items:center}.raffle-view-button:hover{background:var(--color-primary-hover)}@media (prefers-color-scheme: light){.raffle-actions .icon-button{background:#0000000d;border-color:#00000026;color:var(--color-text-primary)}.raffle-actions .icon-button:hover{background:#0000001a;border-color:#0003}.raffle-actions .icon-button.delete-raffle{background:#dc35451a;border-color:#dc35454d;color:#dc3545}.raffle-actions .icon-button.delete-raffle:hover{background:#dc354533;border-color:#dc354566}.feature-badge{background:#6366f11a;color:var(--color-primary);border:1px solid rgba(99,102,241,.2)}.raffle-view-button{background:var(--color-primary);color:#fff}.raffle-view-button:hover{background:var(--color-primary-hover)}}.raffle-page{max-width:var(--max-width-content);margin:0 auto}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.raffle-info h1{font-size:var(--font-size-3xl);margin:0 0 var(--spacing-sm) 0}.raffle-title-row{display:flex;align-items:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-sm)}.raffle-options-dropdown{position:relative}.raffle-options-dropdown .options-button{width:var(--size-icon-base);height:var(--size-icon-base);border-radius:var(--radius-base)}.raffle-page .raffle-meta{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap;margin:0}.header-actions{display:flex;gap:var(--spacing-lg)}.raffle-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-2xl);margin-top:var(--spacing-2xl)}.join-link-page{max-width:600px;margin:0 auto;padding:var(--spacing-2xl);text-align:center}.join-link-info{background:var(--color-surface-primary);border-radius:var(--radius-lg);padding:var(--spacing-2xl);margin:var(--spacing-2xl) 0}.join-link-info h2{color:var(--color-warning);margin-bottom:var(--spacing-lg)}.join-link-stats{margin:var(--spacing-lg) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.join-link-stats p{margin:var(--spacing-sm) 0}.join-form{margin:var(--spacing-2xl) 0}.join-form .form-group{display:flex;gap:var(--spacing-sm);margin:var(--spacing-lg) 0}.join-form input{flex:1;padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-inverse);font-size:var(--font-size-base)}.join-form input::placeholder{color:var(--color-text-disabled)}.join-form button{padding:var(--spacing-md) var(--spacing-xl);background:var(--color-success);color:var(--color-text-inverse);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);cursor:pointer;transition:background-color var(--transition-base)}.join-form button:hover:not(:disabled){background:var(--color-success-hover)}.join-form button:disabled{background:var(--color-surface-focus);cursor:not-allowed}.join-link-form{background:var(--color-surface-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}.join-link-form h4{margin-top:0;margin-bottom:var(--spacing-lg);color:var(--color-warning)}.join-link-form input{width:100%;padding:var(--spacing-md);margin-bottom:var(--spacing-lg);border-radius:var(--radius-md);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-inverse);font-size:var(--font-size-base)}.join-link-form input::placeholder{color:var(--color-text-disabled)}.join-links-list h4{margin-bottom:var(--spacing-lg);color:var(--color-warning)}.join-links{display:flex;flex-direction:column;gap:var(--spacing-lg)}.join-link-item{background:var(--color-surface-primary);border:1px solid var(--color-border-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-lg)}.join-link-info h5{margin:0 0 var(--spacing-sm) 0;color:var(--color-text-inverse);font-size:var(--font-size-base)}.join-link-stats{display:flex;gap:var(--spacing-lg);margin:var(--spacing-sm) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.join-link-stats .status{padding:.2rem var(--spacing-sm);border-radius:var(--radius-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold)}.join-link-stats .status.active{background:#10b98133;color:var(--color-success)}.join-link-stats .status.inactive{background:#ef444433;color:#ef4444}.join-link-url{margin-top:var(--spacing-sm)}.join-link-url small{color:var(--color-text-disabled);font-family:monospace;word-break:break-all}.join-link-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.join-link-actions button{padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-base);cursor:pointer;font-size:var(--font-size-sm);transition:background-color var(--transition-base)}.join-link-actions button:first-child{background:var(--color-info);color:var(--color-text-inverse)}.join-link-actions button:first-child:hover{background:var(--color-info-hover)}.join-link-actions .delete-btn{background:#ef4444;color:var(--color-text-inverse)}.join-link-actions .delete-btn:hover{background:#dc2626}.u-hidden{display:none!important}.u-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}.u-mb-0{margin-bottom:0!important}.u-mb-1{margin-bottom:var(--spacing-sm)!important}.u-mb-2{margin-bottom:var(--spacing-lg)!important}.u-mb-3{margin-bottom:var(--spacing-xl)!important}.u-mb-4{margin-bottom:var(--spacing-2xl)!important}.u-mt-0{margin-top:0!important}.u-mt-1{margin-top:var(--spacing-sm)!important}.u-mt-2{margin-top:var(--spacing-lg)!important}.u-mt-3{margin-top:var(--spacing-xl)!important}.u-mt-4{margin-top:var(--spacing-2xl)!important}.u-text-center{text-align:center!important}.u-text-left{text-align:left!important}.u-text-right{text-align:right!important}.u-flex{display:flex!important}.u-flex-column{flex-direction:column!important}.u-flex-row{flex-direction:row!important}.u-justify-center{justify-content:center!important}.u-justify-between{justify-content:space-between!important}.u-align-center{align-items:center!important}.u-flex-1{flex:1!important}.u-full-width{width:100%!important}.u-auto-width{width:auto!important}@media (max-width: 900px){#root{padding:var(--spacing-lg)}.topbar-inner,.controls-bar{padding:var(--spacing-sm) var(--spacing-md)}.bulk-panel{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}}@media (max-width: 760px){.columns,.description-grid,.raffles-grid,.raffle-content{grid-template-columns:1fr}.entrants-box,.winners-box{min-width:0}.page-header{align-items:stretch}.header-left{flex-wrap:wrap}.topbar-inner{flex-direction:row;align-items:stretch;gap:var(--spacing-sm)}.topbar-left{flex-direction:row;align-items:center;gap:var(--spacing-sm)}.topbar-raffle-selector,.topbar-auth{justify-content:center}.hero-title{font-size:var(--font-size-5xl)}}@media (max-width: 520px){.form-row{grid-template-columns:1fr}.join-link-card{flex-direction:column;align-items:stretch}.link-actions{flex-direction:row;justify-content:flex-end}.modal{min-width:auto;margin:var(--spacing-lg);width:calc(100vw - 2rem);max-width:720px}.raffle-selector{flex-direction:column;align-items:stretch}.raffle-selector>*{width:100%}.join-link-item{flex-direction:column;align-items:stretch}.join-link-actions{flex-direction:row;justify-content:flex-end}.join-link-stats{flex-direction:column;gap:var(--spacing-xs)}.join-form .form-group{flex-direction:column}}@media (max-width: 440px){.hero-title{font-size:var(--font-size-4xl)}.hero-subtitle{font-size:var(--font-size-base)}.topbar-inner{flex-direction:row;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg)}.google-btn{font-size:.8em}.topbar-left{flex-direction:row;align-items:center;gap:var(--spacing-sm);width:100%}.topbar-title{font-size:var(--font-size-lg)}.topbar-raffle-selector{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm)}.topbar-raffle-selector>div{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.desktop-admin-controls{display:none!important}.mobile-admin-menu{display:block}.controls-left{flex-wrap:wrap}.controls-left>div{flex:1 1 240px}.controls input{min-width:0}.container{padding-top:var(--spacing-4xl);padding-bottom:var(--spacing-2xl)}.container h1{font-size:1.19rem}.page-header h1{font-size:1.6rem}.winners-list li{grid-template-columns:1fr auto}.pager-inner{grid-template-columns:auto 1fr auto}.join-link-page{padding:var(--spacing-lg)}.box-header h2{font-size:var(--font-size-lg)}}@media (max-width: 440px){.winner-time{display:none!important}.winner-clock-icon{display:inline-flex!important}}.winner-clock-icon{grid-row:actions;display:none;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:var(--radius-sm);background:var(--color-surface-secondary);border:1px solid var(--color-border-primary);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);margin-left:auto;padding:0}.winner-clock-icon:hover{background:var(--color-surface-hover);color:var(--color-text-primary);transform:translateY(-1px)}.winner-clock-icon:focus{outline:2px solid var(--color-primary);outline-offset:1px}.winner-clock-icon:active{transform:translateY(0)}.time-modal-backdrop{position:fixed;inset:0;background:var(--color-modal-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-popover);animation:fadeIn .2s ease-out}.time-modal{background:var(--color-backdrop-strong);border:1px solid var(--color-border-secondary);border-radius:var(--radius-lg);padding:var(--spacing-lg);min-width:280px;max-width:90vw;box-shadow:var(--shadow-lg);animation:modalSlideIn .25s ease-out}.time-modal-content{display:flex;flex-direction:column;gap:var(--spacing-md);text-align:center}.time-modal-icon{color:var(--color-primary);margin:0 auto}.time-modal h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.time-modal-details{display:flex;flex-direction:column;gap:var(--spacing-sm)}.time-detail{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);background:var(--color-surface-primary);border-radius:var(--radius-base)}.time-detail-label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.time-detail-value{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium);font-variant-numeric:tabular-nums}.time-modal-close{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface-hover);color:var(--color-text-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-base);cursor:pointer;transition:all var(--transition-base)}.time-modal-close:hover{background:var(--color-surface-active)}.time-modal-close:focus{outline:2px solid var(--color-primary);outline-offset:1px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.time-modal-backdrop.fade-out{animation:fadeOut .15s ease-in forwards}.time-modal-backdrop.fade-out .time-modal{animation:modalSlideOut .15s ease-in forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}@media (max-width: 400px){.container h1{font-size:.8rem}.page-header h1{font-size:1.4rem}}@media print{.topbar,.controls-bar,.bulk-panel,.modal-overlay,.icon-button,.action-button,.primary-button,.secondary-button{display:none!important}#root{padding:0;max-width:none}.container{padding-top:0}body{background:#fff!important;color:#000!important}section{border:1px solid #ccc}}.admin-page{max-width:var(--max-width-content);margin:0 auto;padding:var(--spacing-2xl)}.admin-page .page-header{margin-bottom:var(--spacing-3xl)}.admin-page .page-header h1{display:flex;align-items:center;gap:var(--spacing-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.admin-page .page-header p{color:var(--color-text-secondary);margin:0}.admin-page .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.admin-page .loading-icon{animation:spin 1s linear infinite;color:var(--color-primary)}.admin-page .error-message{display:flex;align-items:center;gap:var(--spacing-sm);background:#ef444433;border:1px solid #ef4444;border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-2xl);color:#ef4444}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-3xl)}.stat-card{background:var(--color-surface-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-lg);transition:transform var(--transition-base),background var(--transition-base)}.stat-card:hover{transform:translateY(-2px);background:var(--color-surface-secondary)}.stat-card svg{color:var(--color-primary);flex-shrink:0}.stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.users-table-container{margin-bottom:var(--spacing-3xl)}.users-table-container h2{margin-bottom:var(--spacing-xl);color:var(--color-text-primary)}.table-wrapper{background:var(--color-surface-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);overflow:hidden}.users-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.users-table th{background:var(--color-surface-secondary);padding:var(--spacing-lg);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border-bottom:1px solid var(--color-border-secondary)}.users-table td{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-primary);color:var(--color-text-primary);vertical-align:middle}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover{background:var(--color-surface-hover)}.user-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.user-uid{font-family:monospace;font-size:var(--font-size-xs);color:var(--color-text-muted);word-break:break-all}.role-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#fff;text-transform:uppercase;letter-spacing:.05em}.role-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.role-select{padding:var(--spacing-sm);border-radius:var(--radius-base);border:1px solid var(--color-border-focus);background:var(--color-surface-input);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer}.role-select:disabled{opacity:.5;cursor:not-allowed}.role-actions .loading-icon{color:var(--color-primary);animation:spin 1s linear infinite}.raffles-summary{margin-bottom:var(--spacing-2xl)}.raffles-summary h2{margin-bottom:var(--spacing-xl);color:var(--color-text-primary)}.raffles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.raffle-card{background:var(--color-surface-primary);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:transform var(--transition-base),background var(--transition-base)}.raffle-card:hover{transform:translateY(-2px);background:var(--color-surface-secondary)}.raffle-card .raffle-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.raffle-card .raffle-meta{display:flex;flex-direction:column;gap:var(--spacing-xs)}.raffle-card .raffle-meta>div{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.variant-tag{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:#6366f133;color:var(--color-primary-light);border-radius:var(--radius-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-top:var(--spacing-xs);margin-right:var(--spacing-xs)}.copy-feedback{position:fixed;top:calc(var(--height-topbar) + var(--spacing-sm));right:var(--spacing-lg);background:var(--color-success);color:var(--color-text-inverse);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);z-index:var(--z-popover);animation:slideInRight .3s ease-out;box-shadow:var(--shadow-lg)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (prefers-color-scheme: light){.copy-feedback{background:var(--color-success);color:#fff}}@media (max-width: 900px){.admin-stats{grid-template-columns:1fr}}@media (max-width: 760px){.admin-page{padding:var(--spacing-lg)}.table-wrapper{overflow-x:auto}.users-table{min-width:600px}.raffles-grid{grid-template-columns:1fr}}@media (max-width: 520px){.stat-card{flex-direction:column;text-align:center}.users-table th,.users-table td{padding:var(--spacing-sm)}}
