*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,.theme-dark{--bg-primary: #0a0a14;--bg-secondary: #0d0d1a;--bg-card: #111827;--bg-overlay: rgba(0, 0, 0, .6);--border: #1f2937;--border-strong: #374151;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #4b5563;--accent: #6C63FF;--accent-glow: #6C63FF22;--green: #4ade80;--blue: #60a5fa;--yellow: #fbbf24;--orange: #fb923c;--red: #f87171;--header-bg: rgba(10, 10, 20, .8);--card-gradient-start: #0f0f20;--card-gradient-end: #0a0a14;--progress-bg: #0d0d1a}.theme-light{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-card: #ffffff;--bg-overlay: rgba(0, 0, 0, .3);--border: #e2e8f0;--border-strong: #cbd5e1;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #6C63FF;--accent-glow: #6C63FF11;--green: #16a34a;--blue: #2563eb;--yellow: #ca8a04;--orange: #ea580c;--red: #dc2626;--header-bg: rgba(248, 250, 252, .9);--card-gradient-start: #f1f5f9;--card-gradient-end: #f8fafc;--progress-bg: #e2e8f0}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;-webkit-font-smoothing:antialiased}#app{width:100vw;height:100vh;display:flex;flex-direction:column}.app{width:100%;height:100%;display:flex;flex-direction:column;position:relative;background:radial-gradient(ellipse at top,var(--card-gradient-start) 0%,var(--bg-primary) 70%)}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--border);background:var(--header-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;position:relative;z-index:10}.header__left,.header__right{display:flex;align-items:center;gap:16px}.logo{font-size:22px;font-weight:900;letter-spacing:3px;text-transform:uppercase}.logo__thrill{color:var(--accent)}.logo__ops{color:var(--text-primary)}.header-pills{display:flex;gap:8px;align-items:center}.pill{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.5px}.pill-green{background:#052e16;color:var(--green);border:1px solid #166534}.pill-blue{background:#0c1a2e;color:var(--blue);border:1px solid #1e40af}.pill-orange{background:#1c0d00;color:var(--orange);border:1px solid #9a3412}.pill-preview{background:#1c1400;color:var(--yellow);border:1px solid #854d0e;font-size:9px;letter-spacing:2px}.theme-light .pill-green{background:#dcfce7;border-color:#86efac}.theme-light .pill-blue{background:#dbeafe;border-color:#93c5fd}.theme-light .pill-orange{background:#ffedd5;border-color:#fdba74}.theme-light .pill-preview{background:#fef9c3;border-color:#fde047}.pause-btn{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.pause-btn:hover{background:var(--border-strong);color:var(--text-primary)}.settings-gear{background:none;border:1px solid var(--border);color:var(--text-muted);width:36px;height:36px;border-radius:8px;font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.settings-gear:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-glow)}.clock{text-align:right}.clock__time{color:var(--text-primary);font-size:28px;font-weight:700;letter-spacing:1px;font-variant-numeric:tabular-nums}.clock__date{color:var(--text-muted);font-size:12px}.page-indicator{display:flex;gap:8px;align-items:center}.page-indicator__btn{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-muted);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.page-indicator__btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.main-content{flex:1;padding:24px 28px;overflow:hidden;display:flex;flex-direction:column}.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;flex:1;align-content:start}@media (min-width: 1600px){.rooms-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1200px){.rooms-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.rooms-grid{grid-template-columns:1fr}}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:var(--text-muted);font-size:16px}.empty-state__icon{font-size:48px;opacity:.5}.page-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.cycle-progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--progress-bg)}.cycle-progress__bar{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);transition:width .5s linear}.connection-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:8px 16px;font-size:13px;font-weight:600;letter-spacing:.5px;flex-shrink:0;z-index:20;transition:all .4s ease}.connection-banner--success{background:#052e16;color:var(--green);height:4px;padding:0;overflow:hidden;animation:bannerSlideDown .3s ease,bannerFadeOut 2s .5s ease forwards}.connection-banner--connecting{background:#0c1a2e;color:var(--blue);border-bottom:1px solid #1e40af44}.connection-banner--reconnecting{background:#1c1400;color:var(--yellow);border-bottom:1px solid #854d0e44;animation:bannerPulse 2s ease-in-out infinite}.connection-banner--stale{background:#1c0505;color:var(--red);border-bottom:2px solid var(--red)}.connection-banner__icon{font-size:16px}.connection-banner__attempts{opacity:.7;font-size:11px;font-weight:400}.connection-banner__spinner{width:14px;height:14px;border:2px solid var(--yellow);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.theme-light .connection-banner--success{background:#dcfce7}.theme-light .connection-banner--connecting{background:#dbeafe}.theme-light .connection-banner--reconnecting{background:#fef9c3;color:#854d0e}.theme-light .connection-banner--stale{background:#fef2f2;color:#b91c1c}@keyframes bannerPulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes bannerSlideDown{0%{height:0}to{height:4px}}@keyframes bannerFadeOut{to{opacity:0;height:0}}@keyframes spin{to{transform:rotate(360deg)}}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:100;display:flex;justify-content:flex-end;animation:overlayFadeIn .2s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.settings-panel{width:380px;max-width:90vw;height:100%;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;animation:panelSlideIn .3s ease;overflow:hidden}@keyframes panelSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.settings-panel__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.settings-panel__title{font-size:18px;font-weight:700;color:var(--text-primary)}.settings-panel__close{background:none;border:1px solid var(--border);color:var(--text-muted);width:32px;height:32px;border-radius:6px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.settings-panel__close:hover{color:var(--text-primary);border-color:var(--text-secondary)}.settings-panel__content{flex:1;overflow-y:auto;padding:24px}.settings-panel__controls{display:flex;flex-direction:column;gap:24px}.settings-group{display:flex;flex-direction:column;gap:8px}.settings-group__label{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}.settings-group__row{display:flex;gap:8px}.settings-group__slider-row{display:flex;align-items:center;gap:12px;margin-top:4px}.settings-group__value{font-size:14px;font-weight:700;color:var(--accent);min-width:36px;text-align:right}.settings-group__list{display:flex;flex-direction:column;gap:6px}.settings-group__empty{color:var(--text-muted);font-size:13px;font-style:italic}.settings-group__info{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-secondary)}.settings-group__token{font-family:monospace;font-size:11px;color:var(--text-muted);background:var(--bg-primary);padding:4px 8px;border-radius:4px}.settings-toggle{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-muted);padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.settings-toggle:hover{color:var(--text-primary);border-color:var(--accent)}.settings-toggle--active{background:var(--accent);border-color:var(--accent);color:#fff}.settings-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;background:var(--border);border-radius:2px;outline:none}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer}.settings-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.settings-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.settings-btn{background:var(--accent);border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.settings-btn:hover{opacity:.9}.settings-btn--secondary{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-secondary)}.settings-btn--secondary:hover{color:var(--text-primary);border-color:var(--text-secondary)}.pin-entry{display:flex;flex-direction:column;align-items:center;gap:24px;padding:20px 0}.pin-entry__title{font-size:16px;font-weight:700;color:var(--text-primary)}.pin-entry__dots{display:flex;gap:12px}.pin-entry__dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-strong);transition:all .15s}.pin-entry__dot--filled{background:var(--accent);border-color:var(--accent)}.pin-entry__error{color:var(--red);font-size:12px;font-weight:600}.pin-entry__keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:400px}.pin-entry__key{background:var(--bg-card);border:1px solid var(--border-strong);color:var(--text-primary);width:100%;min-height:120px;border-radius:14px;font-size:36px;font-weight:600;cursor:pointer;transition:all .1s;display:flex;align-items:center;justify-content:center}.pin-entry__key:hover{background:var(--border-strong)}.pin-entry__key:active{transform:scale(.95)}.pin-entry__key--action{font-size:18px;color:var(--accent)}.pin-entry__key--action:disabled{opacity:.3;cursor:default}.pin-entry__key--spacer{background:transparent;border:none;cursor:default}.schedule-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.schedule-date{color:var(--text-muted);font-size:14px}.schedule-slot-header{color:var(--text-muted);font-size:10px;font-weight:600;text-align:center;padding:4px 2px;border-bottom:1px solid var(--border)}.schedule-room-label{color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 4px;display:flex;flex-direction:column;justify-content:center;gap:2px;border-right:1px solid var(--border)}.schedule-room-label__name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.schedule-room-label__state{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.schedule-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;color:var(--text-muted)}.schedule-empty__icon{font-size:48px;opacity:.5}.schedule-empty h3{font-size:18px;font-weight:700;color:var(--text-secondary)}.schedule-empty p{font-size:14px}.stats-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.stats-date{color:var(--text-muted);font-size:14px}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:16px;flex:1}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.stat-card--accent{background:linear-gradient(135deg,#1a0b3b 0%,var(--bg-secondary) 100%);border-color:#6c63ff44;box-shadow:0 0 30px var(--accent-glow)}.theme-light .stat-card--accent{background:linear-gradient(135deg,#ede9fe 0%,var(--bg-secondary) 100%)}.stat-card__glow{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.stat-card__label{color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.stat-card__value{font-size:52px;font-weight:800;line-height:1;letter-spacing:-2px}.stat-card__sub{color:var(--text-muted);font-size:13px}.mini-room-status{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:24px;display:flex;flex-direction:column;gap:16px}.mini-room-status__label{color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.mini-room-status__list{display:flex;flex-direction:column;gap:10px}.mini-room-status__item{display:flex;align-items:center;gap:10px}.mini-room-status__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.mini-room-status__name{color:var(--text-secondary);font-size:13px;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-room-status__state{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.mini-room-status__empty{color:var(--text-muted);font-size:13px;font-style:italic}.state-breakdown{display:flex;flex-direction:column;gap:8px}.state-breakdown__label{color:var(--text-muted);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.state-breakdown__bar{display:flex;height:8px;border-radius:4px;overflow:hidden;gap:2px}.state-breakdown__segment{min-width:4px;border-radius:2px;transition:width .5s ease}.state-breakdown__legend{display:flex;gap:16px;flex-wrap:wrap}.state-breakdown__item{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:11px}.state-breakdown__dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease forwards}.fade-out{opacity:0;transform:translateY(-8px);transition:opacity .3s ease,transform .3s ease}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@keyframes glowPulse{0%,to{opacity:1}50%{opacity:.6}}:fullscreen .header{padding:12px 24px}:fullscreen .main-content{padding:20px 24px}
