:root{--ui-bg-primary: rgba(15, 23, 42, .95);--ui-bg-card: rgba(255, 255, 255, .05);--ui-bg-input: rgba(15, 23, 42, .8);--ui-bg-overlay: rgba(0, 0, 0, .6);--ui-border-card: rgba(255, 255, 255, .1);--ui-border-input: rgba(148, 163, 184, .3);--ui-border-input-focus: rgba(79, 172, 254, .6);--ui-border-divider: rgba(255, 255, 255, .1);--ui-border-divider-light: rgba(255, 255, 255, .06);--ui-shadow-card: 0 4px 20px rgba(0, 0, 0, .15);--ui-shadow-modal: 0 8px 32px rgba(0, 0, 0, .4);--ui-shadow-input-focus: 0 0 0 2px rgba(79, 172, 254, .2);--ui-shadow-btn-primary: 0 4px 15px rgba(79, 172, 254, .3);--ui-shadow-btn-primary-hover: 0 6px 20px rgba(79, 172, 254, .4);--ui-radius-sm: 8px;--ui-radius-md: 12px;--ui-radius-lg: 16px;--ui-radius-xl: 18px;--ui-text-primary: rgba(255, 255, 255, .95);--ui-text-secondary: rgba(255, 255, 255, .7);--ui-text-tertiary: rgba(255, 255, 255, .6);--ui-text-placeholder: rgba(255, 255, 255, .4);--ui-text-label: rgba(255, 255, 255, .9);--ui-primary: #4facfe;--ui-primary-gradient: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--ui-primary-hover: rgba(79, 172, 254, .3);--ui-primary-border: rgba(79, 172, 254, .4);--ui-danger: #ef4444;--ui-danger-bg: rgba(239, 68, 68, .1);--ui-danger-border: rgba(239, 68, 68, .3);--ui-spacing-xs: 8px;--ui-spacing-sm: 12px;--ui-spacing-md: 16px;--ui-spacing-lg: 20px;--ui-spacing-xl: 24px;--ui-spacing-2xl: 32px;--ui-font-xs: 12px;--ui-font-sm: 13px;--ui-font-md: 14px;--ui-font-lg: 16px;--ui-font-xl: 18px;--ui-font-2xl: 20px;--ui-font-3xl: 24px;--ui-font-normal: 400;--ui-font-medium: 500;--ui-font-semibold: 600;--ui-font-bold: 700;--ui-transition: all .2s ease;--ui-transition-slow: all .3s ease;--ui-blur-sm: blur(4px);--ui-blur-md: blur(8px);--ui-blur-lg: blur(20px);--bg: var(--ui-bg-primary);--surface: var(--ui-bg-card);--text: var(--ui-text-primary);--muted: var(--ui-text-secondary);--line: var(--ui-border-divider-light);--primary: var(--ui-primary);--danger: var(--ui-danger);--radius: var(--ui-radius-md);--app-bg: linear-gradient(135deg, #1e3c72 0%, #2a5298 100%);--app-surface: rgba(255, 255, 255, .08);--app-surface-2: #fff;--app-text: #fff;--app-text-muted: rgba(255, 255, 255, .8);--app-text-muted-2: rgba(255, 255, 255, .7);--app-text-muted-3: rgba(255, 255, 255, .6);--app-text-strong: rgba(255, 255, 255, .9);--app-border: rgba(255, 255, 255, .15);--app-radius: 12px;--app-gap-1: 8px;--app-gap-2: 12px;--app-gap-3: 16px;--app-gap-4: 20px;--app-gap-5: 24px;--app-shadow-1: 0 4px 24px rgba(0, 0, 0, .15);--app-text-shadow-1: 0 2px 10px rgba(0, 0, 0, .3);--app-page-max: 1400px;--app-page-pad: 16px;--app-page-pad-lg: 32px;--app-page-pad-md: 16px 12px;--app-page-pad-sm: 12px 10px;--app-content-text: #e2e8f0;--app-content-text-muted: rgba(255, 255, 255, .6);--app-content-text-tertiary: rgba(255, 255, 255, .4);--app-content-border: #e0e0e0;--app-content-shadow-1: 0 2px 4px rgba(0, 0, 0, .05);--app-page-card-pad: 24px;--app-accent: #1890ff;--app-accent-shadow: 0 4px 12px rgba(24, 144, 255, .15);--app-shell-accent: #4facfe;--app-shell-accent-2: #00f2fe;--app-shell-accent-glow: 0 0 10px rgba(79, 172, 254, .6);--app-shell-focus-border: rgba(79, 172, 254, .7);--app-shell-focus-ring: 0 0 0 4px rgba(79, 172, 254, .25);--app-surface-weak: rgba(255, 255, 255, .05);--app-surface-weak-2: rgba(255, 255, 255, .1);--app-surface-mid: rgba(255, 255, 255, .12);--app-surface-mid-2: rgba(255, 255, 255, .15);--app-surface-focus: rgba(255, 255, 255, .18);--app-surface-strong: rgba(255, 255, 255, .2);--app-surface-strong-2: rgba(255, 255, 255, .25);--app-surface-strong-3: rgba(255, 255, 255, .3);--app-surface-strong-4: rgba(255, 255, 255, .5);--app-border-weak: rgba(255, 255, 255, .1);--app-border-mid: rgba(255, 255, 255, .2);--app-border-strong: rgba(255, 255, 255, .3);--app-border-stronger: rgba(255, 255, 255, .5);--app-radius-xs: 2px;--app-radius-sm: 4px;--app-radius-md: 6px;--app-radius-lg: 8px;--app-radius-xl: 10px;--app-radius-2xl: 20px;--app-radius-3xl: 24px;--app-shadow-hover: 0 4px 12px rgba(0, 0, 0, .2);--app-shadow-active: 0 2px 6px rgba(0, 0, 0, .15);--app-shadow-2: 0 8px 32px rgba(0, 0, 0, .1);--app-panel-bg: rgba(255, 255, 255, .95);--app-panel-border: rgba(102, 126, 234, .2);--app-panel-divider: rgba(102, 126, 234, .2);--app-panel-shadow: 0 4px 20px rgba(0, 0, 0, .1);--app-panel-code-bg: rgba(102, 126, 234, .05);--app-panel-accent: #667eea;--app-panel-accent-bg: rgba(102, 126, 234, .1);--app-panel-accent-bg-hover: rgba(102, 126, 234, .2);--app-content-text-muted-2: rgba(255, 255, 255, .55);--app-danger-text: #ff4d4f;--app-brand-1: #667eea;--app-brand-2: #764ba2;--app-brand-gradient: linear-gradient(135deg, var(--app-brand-1) 0%, var(--app-brand-2) 100%);--app-brand-shadow-1: 0 4px 15px rgba(102, 126, 234, .3);--app-brand-shadow-2: 0 6px 20px rgba(102, 126, 234, .4);--app-modal-bg: var(--ui-bg-primary);--app-modal-overlay-bg: rgba(0, 0, 0, .55);--app-modal-radius: 12px;--app-modal-padding: 16px;--app-modal-max-width: 420px;--app-modal-max-height: 620px;--app-modal-shadow: var(--ui-shadow-modal);--app-modal-header-gap: 8px;--app-modal-close-size: 32px;--app-toast-bg: rgba(15, 23, 42, .95);--app-toast-radius: 12px;--app-toast-shadow: var(--ui-shadow-card);--app-toast-text: var(--ui-text-primary);--app-drawer-bg: var(--ui-bg-primary);--app-drawer-radius: 16px;--app-drawer-shadow: var(--ui-shadow-modal)}.ui-card{background:var(--ui-bg-card);border:1px solid var(--ui-border-card);border-radius:var(--ui-radius-md);padding:var(--ui-spacing-xl);box-shadow:var(--ui-shadow-card)}.ui-card-lg{border-radius:var(--ui-radius-xl);padding:var(--ui-spacing-xl)}.ui-section{margin-bottom:var(--ui-spacing-xl)}.ui-section:last-child{margin-bottom:0}.ui-section-title{font-size:var(--ui-font-sm);font-weight:var(--ui-font-semibold);color:var(--ui-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--ui-spacing-sm)}.ui-row{display:flex;justify-content:space-between;align-items:center;padding:var(--ui-spacing-md) 0;border-bottom:1px solid var(--ui-border-divider-light);transition:var(--ui-transition)}.ui-row:last-child{border-bottom:none}.ui-row-label{font-size:var(--ui-font-md);color:var(--ui-text-primary);font-weight:var(--ui-font-normal)}.ui-row-value{font-size:var(--ui-font-md);color:var(--ui-text-secondary);font-weight:var(--ui-font-normal)}.ui-row-arrow{font-size:var(--ui-font-2xl);color:var(--ui-text-tertiary);font-weight:300;line-height:1}.ui-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--ui-bg-overlay);-webkit-backdrop-filter:var(--ui-blur-sm);backdrop-filter:var(--ui-blur-sm);display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--ui-spacing-lg)}.ui-modal{background:var(--ui-bg-primary);-webkit-backdrop-filter:var(--ui-blur-lg);backdrop-filter:var(--ui-blur-lg);border:1px solid var(--ui-border-card);border-radius:var(--ui-radius-lg);padding:var(--ui-spacing-xl);max-width:500px;width:100%;box-shadow:var(--ui-shadow-modal);color:var(--ui-text-primary)}.ui-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--ui-spacing-lg);padding-bottom:var(--ui-spacing-md);border-bottom:1px solid var(--ui-border-divider)}.ui-modal-title{font-size:var(--ui-font-2xl);font-weight:var(--ui-font-bold);color:var(--ui-text-primary);margin:0}.ui-modal-body{margin-bottom:var(--ui-spacing-xl)}.ui-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--ui-spacing-sm);padding-top:var(--ui-spacing-md);border-top:1px solid var(--ui-border-divider)}.ui-form-group{margin-bottom:var(--ui-spacing-lg)}.ui-form-group:last-child{margin-bottom:0}.ui-form-label{display:block;font-size:var(--ui-font-md);font-weight:var(--ui-font-semibold);color:var(--ui-text-label);margin-bottom:var(--ui-spacing-xs)}.ui-form-label-required:after{content:" *";color:var(--ui-danger)}.ui-input{width:100%;padding:var(--ui-spacing-sm) var(--ui-spacing-md);background:var(--ui-bg-input);border:1px solid var(--ui-border-input);border-radius:var(--ui-radius-sm);font-size:max(16px,var(--ui-font-md));color:var(--ui-text-primary);outline:none;transition:var(--ui-transition);box-sizing:border-box}.ui-input::placeholder{color:var(--ui-text-placeholder)}.ui-input:focus{border-color:var(--ui-border-input-focus);background:#0f172af2;box-shadow:var(--ui-shadow-input-focus)}.ui-input:disabled{opacity:.6;cursor:not-allowed}.ui-input-error{border-color:var(--ui-danger)}.ui-input-error:focus{box-shadow:0 0 0 2px var(--ui-danger-border)}.ui-form-hint{margin-top:var(--ui-spacing-xs);font-size:var(--ui-font-xs);color:var(--ui-text-tertiary)}.ui-form-error{margin-top:var(--ui-spacing-xs);font-size:var(--ui-font-xs);color:var(--ui-danger)}.ui-btn{padding:var(--ui-spacing-sm) var(--ui-spacing-lg);border-radius:var(--ui-radius-sm);font-size:var(--ui-font-md);font-weight:var(--ui-font-medium);cursor:pointer;transition:var(--ui-transition);border:none;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.ui-btn:disabled{opacity:.6;cursor:not-allowed}.ui-btn-primary{background:var(--ui-primary-gradient);color:#fff;box-shadow:var(--ui-shadow-btn-primary)}.ui-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--ui-shadow-btn-primary-hover)}.ui-btn-primary:active:not(:disabled){transform:translateY(0)}.ui-btn-secondary{background:#ffffff1a;color:var(--ui-text-primary);border:1px solid var(--ui-border-card)}.ui-btn-secondary:hover:not(:disabled){background:#ffffff26}.ui-btn-danger{background:var(--ui-danger);color:#fff}.ui-btn-danger:hover:not(:disabled){background:#dc2626}.ui-btn-danger:active:not(:disabled){background:#b91c1c}.ui-btn-sm{padding:var(--ui-spacing-xs) var(--ui-spacing-md);font-size:var(--ui-font-sm)}.ui-btn-lg{padding:var(--ui-spacing-md) var(--ui-spacing-xl);font-size:var(--ui-font-lg);font-weight:var(--ui-font-semibold);border-radius:var(--ui-radius-md)}.ui-btn-block{width:100%}.ui-alert-error{padding:var(--ui-spacing-sm) var(--ui-spacing-md);background:var(--ui-danger-bg);border:1px solid var(--ui-danger-border);border-radius:var(--ui-radius-sm);color:var(--ui-danger);font-size:var(--ui-font-sm);margin-bottom:var(--ui-spacing-lg)}@media (max-width: 768px){.ui-card{padding:var(--ui-spacing-md);border-radius:var(--ui-radius-md)}.ui-modal{padding:var(--ui-spacing-md);margin:var(--ui-spacing-lg);max-width:calc(100% - 32px)}.ui-modal-title{font-size:var(--ui-font-xl)}.ui-row{padding:var(--ui-spacing-sm) 0}.ui-row-label,.ui-row-value{font-size:var(--ui-font-sm)}}@media (max-width: 480px){.ui-card{padding:var(--ui-spacing-sm)}.ui-modal-overlay{padding:var(--ui-spacing-md)}.ui-modal{padding:var(--ui-spacing-sm)}}.login-page{width:100%;max-width:100%;height:100vh;height:100dvh;min-height:100dvh;position:relative;overflow-x:hidden;overflow-y:auto;display:flex;align-items:center;justify-content:center;background:#0a111f;box-sizing:border-box;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);-webkit-overflow-scrolling:touch}.background-animation{display:none}.login-container{position:relative;z-index:10;width:100%;max-width:320px;padding:16px;box-sizing:border-box}.login-card{position:relative;background:#142036;border-radius:16px;padding:24px;box-shadow:none;border:1px solid #1E304D;overflow:visible}.card-glow{display:none}.card-content{position:relative;z-index:1}.login-logo{display:flex;justify-content:center;margin-bottom:24px}.login-logo svg{width:80px;height:80px;color:#29b6f6}.login-title{font-size:28px;font-weight:700;color:#fff;text-align:center;margin-bottom:16px;line-height:1.2}.login-subtitle{font-size:14px;color:#ffffffb3;text-align:center;margin-bottom:0}.message-placeholder{height:48px;margin-bottom:24px}.error-message{width:100%;padding:12px;margin-bottom:24px;box-sizing:border-box;background:#ff4d4d1a;border:1px solid rgba(255,77,77,.5);border-radius:8px;color:#ff4d4d;font-size:13px;font-weight:600;text-align:left;display:flex;align-items:flex-start;gap:8px}.error-message svg{flex-shrink:0;width:20px;height:20px;color:#ff4d4d}.error-message-text{flex:1;line-height:1.4}.success-message{width:100%;padding:12px;margin-bottom:24px;box-sizing:border-box;background:#22c55e1a;border:1px solid rgba(34,197,94,.5);border-radius:8px;color:#22c55e;font-size:13px;font-weight:600;text-align:left;display:flex;align-items:flex-start;gap:8px}.success-message svg{flex-shrink:0;width:20px;height:20px;color:#22c55e}.success-message-text{flex:1;line-height:1.4}.session-error-message{width:100%;padding:12px;margin-bottom:16px;box-sizing:border-box;background:#ff4d4d1a;border:1px solid rgba(255,77,77,.5);border-radius:8px}.session-error-text{font-size:14px;color:#ff4d4d;margin-bottom:12px;text-align:center}.session-error-actions{display:flex;gap:12px;justify-content:center}.session-error-btn{padding:8px 16px;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s ease}.session-error-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80}.session-error-btn:disabled{opacity:.5;cursor:not-allowed}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{position:relative;width:100%;box-sizing:border-box}.form-group input{width:100%;padding:14px 16px 14px 40px!important;background:#142036;border:1px solid #1E304D;border-radius:12px;color:#fff;font-size:16px;outline:none;transition:all .2s ease;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-group input::placeholder{color:#ffffff80}.form-group input:focus{border-color:#29b6f6;background:#142036;box-shadow:0 0 0 2px #29b6f633}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#29b6f6;font-size:18px;pointer-events:none;z-index:1}.password-input-wrapper{position:relative;width:100%;box-sizing:border-box}.password-input-wrapper input{width:100%;padding:14px 48px 14px 40px!important;background:#142036;border:1px solid #1E304D;border-radius:12px;color:#fff;font-size:16px;outline:none;transition:all .2s ease;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.password-input-wrapper input::placeholder{color:#ffffff80}.password-input-wrapper input:focus{border-color:#29b6f6;background:#142036;box-shadow:0 0 0 2px #29b6f633}.password-input-wrapper input:disabled{opacity:.5;cursor:not-allowed}.password-input-wrapper .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#29b6f6;font-size:18px;pointer-events:none;z-index:1}.password-toggle-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#ffffff80;cursor:pointer;padding:6px;font-size:18px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.password-toggle-btn:hover:not(:disabled){color:#fffc}.password-toggle-btn:disabled{opacity:.3;cursor:not-allowed}.capslock-warning{margin-top:4px;font-size:12px;color:#ffffffb3;padding-left:4px}.submit-btn{width:100%;height:50px;background:#29b6f6;border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.submit-btn:hover:not(:disabled){background:#38c7f7}.submit-btn:active:not(:disabled){background:#1aa8e8}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.submit-btn .loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.switch-mode{margin-top:12px;text-align:center;color:#ffffffb3;font-size:14px}.switch-btn{background:none;border:none;color:#ffffffb3;font-size:14px;font-weight:600;cursor:pointer;margin-left:4px;transition:color .2s ease;-webkit-tap-highlight-color:transparent}.switch-btn:hover:not(:disabled){color:#29b6f6}.switch-btn:disabled{opacity:.5;cursor:not-allowed}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-x:hidden;box-sizing:border-box}.login-modal{position:relative;background:#142036;border-radius:16px;padding:24px;max-width:400px;width:100%;box-shadow:0 8px 32px #00000080;border:1px solid #1E304D;overflow:visible}.login-modal-header{margin-bottom:16px}.login-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#ffffff80;font-size:20px;cursor:pointer;transition:color .2s ease;z-index:10}.login-modal-close:hover{color:#fffc}.login-modal-title{font-size:20px;font-weight:700;color:#fff;text-align:center;margin-bottom:8px;padding-right:32px}.login-modal-description{font-size:14px;color:#ffffffb3;text-align:center;line-height:1.5;margin-bottom:16px}.login-modal-body{position:relative;z-index:1}.login-modal-error{background:#ff4d4d1a;border:1px solid rgba(255,77,77,.5);border-radius:8px;color:#ff4d4d;padding:12px;margin-bottom:16px;font-size:14px;text-align:center}.login-modal-form{margin-bottom:24px}.login-modal-form-group{margin-bottom:16px}.login-modal-form-group:last-child{margin-bottom:0}.login-modal-form-group label{display:block;font-size:14px;font-weight:600;color:#ffffffe6;margin-bottom:8px}.login-modal-form-group input{width:100%;padding:14px 16px;background:#142036;border:1px solid #1E304D;border-radius:12px;color:#fff;font-size:16px;outline:none;transition:all .2s ease;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}.login-modal-form-group input::placeholder{color:#ffffff80}.login-modal-form-group input:focus{border-color:#29b6f6;background:#142036;box-shadow:0 0 0 2px #29b6f633}.login-modal-form-group input:disabled{opacity:.5;cursor:not-allowed}.login-modal-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.login-modal-btn{padding:12px 20px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;min-width:100px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.login-modal-btn-primary{background:#29b6f6;color:#fff}.login-modal-btn-primary:hover:not(:disabled){background:#38c7f7}.login-modal-btn-primary:active:not(:disabled){background:#1aa8e8}.login-modal-btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.3);color:#ffffffb3}.login-modal-btn-secondary:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80;color:#fff}.login-modal-btn:disabled{opacity:.5;cursor:not-allowed}.login-modal-btn .loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.field-error{margin-top:4px;font-size:12px;color:#ff4d4d;padding-left:4px}.form-group input:focus-visible,.password-input-wrapper input:focus-visible,.submit-btn:focus-visible,.switch-btn:focus-visible,.password-toggle-btn:focus-visible,.session-error-btn:focus-visible,.login-modal-form-group input:focus-visible,.login-modal-btn:focus-visible{outline:2px solid #29B6F6;outline-offset:2px}@media (max-width: 480px){.login-container{max-width:100%;padding:12px}.login-card{padding:20px 16px;border-radius:12px}.login-logo svg{width:64px;height:64px}.login-title{font-size:24px;margin-bottom:12px}.login-subtitle{font-size:13px;margin-bottom:0}.error-message,.success-message{padding:10px 12px;font-size:12px}.form-group input{padding:12px 14px 12px 40px!important;font-size:16px;border-radius:10px}.password-input-wrapper input{padding:12px 44px 12px 40px!important;font-size:16px;border-radius:10px}.form-group .input-icon,.password-input-wrapper .input-icon{left:12px;font-size:16px}.password-toggle-btn{right:8px;padding:4px;font-size:16px}.submit-btn{height:48px;font-size:15px;border-radius:10px}.switch-mode,.switch-btn{font-size:13px}.login-modal-overlay{padding:0;align-items:flex-end}.login-modal{max-width:100%;width:100%;margin:0;border-radius:16px 16px 0 0;max-height:85dvh;overflow-y:auto;padding:20px 16px max(16px,env(safe-area-inset-bottom)) 16px}.login-modal-title{font-size:18px}.login-modal-description{font-size:13px}.login-modal-actions{flex-direction:column;gap:10px}.login-modal-btn{width:100%;min-height:48px;padding:14px 20px}}@media (max-width: 320px){.login-card{padding:16px 12px}.login-title{font-size:22px}.form-group input{padding:10px 12px 10px 40px!important;font-size:16px!important;border-radius:10px}.password-input-wrapper input{padding:10px 40px!important;font-size:16px!important;border-radius:10px}.submit-btn{height:44px;font-size:14px}}@media (prefers-reduced-motion: reduce){.submit-btn .loading-spinner,.login-modal-btn .loading-spinner{animation:none}.submit-btn,.login-modal-btn,.form-group input,.password-input-wrapper input,.login-modal-form-group input,.session-error-btn,.switch-btn,.password-toggle-btn,.login-modal-close{transition:none}}.app-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;justify-content:center;align-items:center;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;padding:16px}.app-modal{--card: rgba(255, 255, 255, .09);--border: rgba(255, 255, 255, .14);--shadow: 0 20px 70px rgba(0, 0, 0, .5);--radius: 20px;--brand1: #4f46e5;--brand2: #06b6d4;--text: #eef2ff;--muted: rgba(238, 242, 255, .72);--inputBg: rgba(255, 255, 255, .08);--inputBd: rgba(255, 255, 255, .16);width:min(420px,calc(100vw - 32px));background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:24px!important;box-sizing:border-box;display:flex;flex-direction:column;max-height:calc(100vh - 32px)}.app-modal-header{position:relative;min-height:36px;margin-bottom:16px!important}.app-modal-title{position:absolute;left:50%;top:0;transform:translate(-50%);margin:0;font-size:22px;font-weight:900;letter-spacing:.2px;background:linear-gradient(90deg,var(--brand1),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}.app-modal-close{position:absolute;right:2px;top:2px;width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#ffffff1a;color:var(--text);display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;padding:0}.app-modal-close:hover:not(:disabled){background:#ffffff24}.app-modal-close:disabled{opacity:.6;cursor:not-allowed}.app-modal-body{position:relative;z-index:1;display:flex;flex-direction:column;gap:0}.app-modal-body.app-modal-body--scrollable{overflow-y:auto;padding-right:4px}.app-modal-description{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 12px!important}.app-modal-footer{display:flex;gap:12px;margin-top:20px!important;justify-content:center}.app-modal-footer.app-modal-footer--row{justify-content:flex-end;flex-wrap:nowrap}.app-modal-footer.app-modal-footer--row>button{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-modal-footer.app-modal-footer--row button.app-modal-primary-btn{width:auto;margin:0}.app-modal input.app-modal-input{display:block;width:100%;height:44px;margin:0;padding:0 12px;border-radius:12px;border:1px solid var(--inputBd);background:var(--inputBg);color:var(--text);font-size:16px;outline:none;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.app-modal input.app-modal-input::placeholder{color:#eef2ff80}.app-modal input.app-modal-input:focus{border-color:#06b6d48c;box-shadow:0 0 0 4px #06b6d42e}.app-modal input.app-modal-input:disabled{opacity:.6;cursor:not-allowed}.app-modal button.app-modal-primary-btn{display:block;height:44px;min-width:160px;margin:0 auto;border-radius:12px;padding:0 14px;border:1px solid transparent;font-weight:800;font-size:16px;line-height:44px;background:linear-gradient(90deg,var(--brand1),var(--brand2));color:#fff;box-shadow:0 12px 30px #06b6d433;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.app-modal button.app-modal-primary-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 34px #06b6d447}.app-modal button.app-modal-primary-btn:active:not(:disabled){transform:translateY(0)}.app-modal button.app-modal-primary-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.app-modal button.app-modal-secondary-btn{display:block;height:44px;min-width:160px;margin:0 auto;border-radius:12px;padding:0 14px;border:1px solid rgba(255,255,255,.18);font-weight:800;font-size:16px;line-height:44px;background:#ffffff1f;color:var(--text);cursor:pointer;transition:transform .15s ease,background-color .15s ease,border-color .15s ease}.app-modal button.app-modal-secondary-btn:hover:not(:disabled){transform:translateY(-1px);background:#ffffff29;border-color:#ffffff3d}.app-modal button.app-modal-secondary-btn:active:not(:disabled){transform:translateY(0)}.app-modal button.app-modal-secondary-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.app-modal button.app-modal-danger-btn{display:block;height:44px;min-width:160px;margin:0 auto;border-radius:12px;padding:0 14px;border:1px solid transparent;font-weight:800;font-size:16px;line-height:44px;background:linear-gradient(90deg,#ef4444,#f97316);color:#fff;box-shadow:0 12px 30px #ef444438;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.app-modal button.app-modal-danger-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 34px #ef44444d}.app-modal button.app-modal-danger-btn:active:not(:disabled){transform:translateY(0)}.app-modal button.app-modal-danger-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}body.new-home-scope .app-modal-footer.app-modal-footer--row{flex-wrap:nowrap}body.new-home-scope .app-modal-footer.app-modal-footer--row>button{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}body.new-home-scope .app-modal-footer.app-modal-footer--row button.app-modal-primary-btn{width:auto;margin:0}@media (max-width: 360px){body.new-home-scope .app-modal-footer.app-modal-footer--row{flex-wrap:wrap}body.new-home-scope .app-modal-footer.app-modal-footer--row>button{flex:1 1 45%}}@media (max-width: 420px){.app-modal-footer.app-modal-footer--row .app-modal-primary-btn,.app-modal-footer.app-modal-footer--row .app-modal-secondary-btn,.app-modal-footer.app-modal-footer--row .app-modal-danger-btn{min-width:0;flex:1}.app-modal-footer:not(.app-modal-footer--row) .app-modal-primary-btn{flex:0;width:min(240px,70%)}}.ui-page{width:100%;box-sizing:border-box;padding-left:16px;padding-right:16px;padding-top:0;flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow-y:visible;-webkit-overflow-scrolling:touch}.ui-k{font-size:var(--ui-font-md);color:var(--ui-text-primary);font-weight:var(--ui-font-normal)}.ui-v{font-size:var(--ui-font-md);color:var(--ui-text-secondary);font-weight:var(--ui-font-normal);text-align:right;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-word}.profile-page{background:#0a111f;padding-bottom:0;flex:1 1 auto;min-height:0;overflow-y:visible;--vip-badge-color: #FFAB40}.profile-wrap{width:100%;max-width:640px;margin:0 auto;padding-top:0;padding-bottom:calc(var(--app-footer-block-h) + 16px);box-sizing:border-box}.profile-main-card{overflow:hidden}.profile-main-card .profile-hero{display:flex;align-items:flex-start;gap:16px;padding:14px 16px}.profile-main-card .profile-hero-avatar{flex:0 0 64px;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#29b6f633,#0284c70d);border:1px solid rgba(41,182,246,.3);display:flex;align-items:center;justify-content:center}.profile-main-card .profile-hero-avatar-icon{width:36px;height:36px;color:#29b6f6;display:block}.profile-main-card .profile-hero-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.profile-main-card .profile-hero-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.profile-main-card .profile-hero-name{font-size:20px;font-weight:700;color:#e2e8f0;line-height:1.2;word-break:break-all}.profile-main-card .profile-vip-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:600;line-height:1.4;white-space:nowrap}.profile-main-card .profile-vip-badge.is-inactive{background:#94a3b833;color:#94a3b8}.profile-main-card .profile-vip-badge.is-active{color:var(--vip-badge-color, #FFAB40);background:color-mix(in srgb,var(--vip-badge-color, #FFAB40) 22%,transparent);border:1px solid color-mix(in srgb,var(--vip-badge-color, #FFAB40) 40%,transparent)}.profile-main-card .profile-vip-star{width:14px;height:14px;flex:0 0 auto;display:block}.profile-main-card .profile-hero-bottom-row{display:flex;align-items:flex-end;justify-content:space-between;gap:8px}.profile-main-card .profile-hero-expires-block{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.profile-main-card .profile-hero-expires-label{font-size:12px;color:#e2e8f08c;line-height:1;white-space:nowrap}.profile-main-card .profile-hero-expires-value{font-size:13px;color:#ef4444;line-height:1;white-space:nowrap}.profile-main-card .profile-hero-vip-btn{flex:0 0 auto;padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:600;line-height:1;cursor:pointer;white-space:nowrap;transition:opacity .2s}.profile-main-card .profile-hero-vip-btn:active{opacity:.75}.profile-main-card .profile-hero-vip-btn.is-activate{background:#29b6f6;color:#fff}.profile-main-card .profile-hero-vip-btn.is-renew{background:linear-gradient(135deg,#ffab40,#ff8f00);color:#fff}.profile-main-card-divider{height:1px;background:#94a3b82e;margin:0 16px}.profile-main-card .profile-partner-section{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:8px}.profile-main-card .profile-partner-section .profile-label{font-size:12px;color:var(--ui-text-secondary);flex:0 0 auto}.profile-main-card .profile-partner-section .profile-value-group{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1;min-width:0}.profile-row{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;gap:8px}.profile-row+.profile-row{border-top:1px solid rgba(148,163,184,.18)}.profile-label{font-size:12px;color:var(--ui-text-secondary);flex:0 0 auto}.profile-value-group{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:1;min-width:0}.profile-value{font-size:14px;color:var(--ui-text-primary);text-align:right;min-width:0;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-link-btn{font-size:12px;color:#38bdf8;border:1px solid rgba(56,189,248,.6);background:transparent;border-radius:10px;padding:6px 10px;line-height:1;cursor:pointer;white-space:nowrap}.profile-title-arrow{margin-left:6px;opacity:.7;line-height:1;font-size:20px}.profile-partner-link{display:inline-flex;align-items:center;font-size:14px;color:#38bdf8;text-decoration:none;min-width:0}.profile-partner-link:hover{text-decoration:underline}.profile-partner-link .profile-contact-icon{width:20px;height:20px;flex:0 0 auto;margin-right:8px}.profile-partner-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-partner-unset{font-size:14px;color:var(--ui-text-secondary);margin-right:4px}.profile-page .nh-ann-edit-btn{flex:0 0 auto;width:20px;height:20px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;padding:0;color:var(--ui-text-secondary);transition:color .2s}.profile-page .nh-ann-edit-btn:hover{color:var(--primary-color, #38bdf8)}.profile-affiliate-block{padding:14px 16px}.profile-affiliate-block-title{font-size:13px;font-weight:600;color:var(--ui-text-primary);margin-bottom:12px}.profile-affiliate-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-top:1px solid rgba(148,163,184,.12)}.profile-affiliate-label{font-size:12px;color:var(--ui-text-secondary);flex:0 0 auto}.profile-affiliate-value-group{flex:1;min-width:0;display:flex;justify-content:flex-end}.profile-affiliate-value{font-size:13px;color:var(--ui-text-primary);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.profile-affiliate-link{font-size:12px;color:#38bdf8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px;cursor:pointer}.profile-affiliate-link:hover{text-decoration:underline}.profile-affiliate-link-input{flex:1;padding:5px 10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:8px;font-size:12px;color:#38bdf8;cursor:text;font-family:inherit;min-width:0}.profile-affiliate-link-input:focus{outline:none;border-color:#38bdf866}.profile-affiliate-copy-btn{padding:5px 12px;background:linear-gradient(135deg,#38bdf8,#0ea5e9);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:opacity .2s;flex-shrink:0}.profile-affiliate-copy-btn:hover{opacity:.9}.profile-affiliate-redeem-btn{display:block;width:100%;margin-top:14px;padding:10px 0;border-radius:10px;border:none;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:15px;font-weight:700;cursor:pointer;letter-spacing:1px;transition:opacity .2s;box-shadow:0 2px 12px #22c55e59}.profile-affiliate-redeem-btn:hover{opacity:.9}.profile-affiliate-redeem-btn:active{opacity:.8}.profile-action-row{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:16px;padding-top:8px}.profile-change-pwd-btn{width:100%;max-width:320px;padding:12px 0;border-radius:10px;border:1px solid rgba(148,163,184,.25);background:#ffffff0d;color:var(--ui-text-secondary);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,background .2s}.profile-change-pwd-btn:hover{background:#ffffff14}.profile-change-pwd-btn:active{opacity:.75}@media (min-width: 640px){.profile-change-pwd-btn{width:auto;min-width:160px}}.profile-logout-btn{border-radius:10px;width:100%;max-width:320px}@media (min-width: 640px){.profile-logout-btn{width:auto;min-width:160px}}body.new-home-scope .new-home-root,body.new-home-scope .new-home-root *,body.new-home-scope .new-home-root *:before,body.new-home-scope .new-home-root *:after{box-sizing:border-box}body.new-home-scope .new-home-root h1,body.new-home-scope .new-home-root h2,body.new-home-scope .new-home-root h3,body.new-home-scope .new-home-root h4,body.new-home-scope .new-home-root h5,body.new-home-scope .new-home-root h6,body.new-home-scope .new-home-root p,body.new-home-scope .new-home-root ul,body.new-home-scope .new-home-root ol,body.new-home-scope .new-home-root figure{margin:0}body.new-home-scope .new-home-root ul,body.new-home-scope .new-home-root ol{padding-left:0;list-style:none}body.new-home-scope{--primary-color: #6366f1;--secondary-color: #8b5cf6;--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--text-primary: #1a1a1a;--text-secondary: #6b7280;--border-color: #e5e7eb;--accent-color: #f59e0b;--card-bg: #ffffff;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--nh-ann-top: 10px;--app-header-block-h: calc(env(safe-area-inset-top, 0px) + 52px + env(safe-area-inset-top, 0px)) ;--app-footer-block-h: calc(56px + env(safe-area-inset-bottom, 0px)) }body.new-home-scope{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .5s ease,color .5s ease;min-height:100vh;position:relative;overflow-x:hidden}body.new-home-scope .app-container{min-height:100vh;position:relative;z-index:1;display:flex;flex-direction:column}body.new-home-scope .app-header{position:fixed;top:0;left:0;right:0;z-index:100;background:#0a111f;border-bottom:1px solid #1E304D;padding:0 16px;padding-top:calc(12px + env(safe-area-inset-top));padding-bottom:calc(12px + env(safe-area-inset-top));height:calc(52px + env(safe-area-inset-top) + env(safe-area-inset-top));min-height:calc(52px + env(safe-area-inset-top) + env(safe-area-inset-top));max-height:calc(52px + env(safe-area-inset-top) + env(safe-area-inset-top));box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;overflow:hidden}body.new-home-scope .header-content{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;width:100%;height:100%;box-sizing:border-box}body.new-home-scope .header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}body.new-home-scope .main-content{max-width:1200px;margin:0 auto;padding-top:calc(var(--app-header-block-h) + 2px);padding-left:0;padding-right:0;padding-bottom:0;position:relative;z-index:1;display:flex;flex-direction:column;min-height:0;flex:1}body.new-home-scope .home-profile-shell{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}body.new-home-scope .home-profile-shell::-webkit-scrollbar{width:0;height:0;display:none}body.new-home-scope .top-fixed-zone{flex:0 0 auto;padding:4px 16px 0}body.new-home-scope .rooms-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px calc(var(--app-footer-block-h) + 16px)}body.new-home-scope .nh-announcement-row{width:100%;display:block;align-items:center;height:22px;background:none;border:none;box-shadow:none;margin:0;padding:0;position:relative}body.new-home-scope .nh-ann-shell{display:grid;grid-template-columns:1fr 5fr 1fr;align-items:center;width:100%;height:28px}body.new-home-scope .nh-ann-gutter{height:28px}body.new-home-scope .nh-ann-bar{display:flex;align-items:center;height:28px;width:100%;gap:8px}body.new-home-scope .nh-ann-icon{flex:0 0 auto;font-size:16px;line-height:28px}body.new-home-scope .nh-ann-icon svg{width:1em;height:1em;display:block}body.new-home-scope .nh-ann-clip{flex:1;overflow:hidden;white-space:nowrap;min-width:0}body.new-home-scope .nh-ann-track{display:inline-block;padding-left:100%;animation:nh-ann-marquee var(--dur, 16s) linear infinite;white-space:nowrap}body.new-home-scope .nh-ann-text{display:inline-block;padding-right:100%;font-size:15px;line-height:28px}@keyframes nh-ann-marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}body.new-home-scope .nh-ann-edit-btn{flex:0 0 auto;width:20px;height:20px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;padding:0;color:var(--text-secondary);transition:color .2s}body.new-home-scope .nh-ann-edit-btn:hover{color:var(--primary-color)}body.new-home-scope .nh-top-divider{height:1px;background:var(--border-color);margin-top:3px;margin-bottom:0;width:100%;position:relative}body.new-home-scope .nh-rooms-title{display:flex;align-items:center;gap:6px;height:28px;margin:8px 0;padding:0}body.new-home-scope .nh-rooms-title-dot{color:#29b6f6;flex:0 0 auto}body.new-home-scope .nh-rooms-title-dot svg{width:1em;height:1em;display:block}body.new-home-scope .nh-rooms-title-text{color:inherit;font-weight:600;letter-spacing:.2px;white-space:nowrap}body.new-home-scope .nh-live-count-badge{display:inline-flex;align-items:center;gap:4px;background:#69f0ae1a;border:1px solid rgba(105,240,174,.3);border-radius:12px;padding:2px 8px;color:#69f0ae;font-size:11px;font-weight:700;line-height:1;white-space:nowrap;flex-shrink:0}body.new-home-scope .nh-live-count-icon{flex-shrink:0;display:block}body.new-home-scope .nh-live-count-text{font-size:11px;font-weight:700;line-height:1}body.new-home-scope .live-rooms-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}body.new-home-scope .live-room-card{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);transition:all .3s ease;cursor:pointer;position:relative}body.new-home-scope .live-room-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}body.new-home-scope .room-thumbnail{position:relative;width:100%;padding-top:56.25%;background:var(--gradient-1);overflow:hidden;color:#fff}body.new-home-scope .room-cover-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}body.new-home-scope .room-thumbnail:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:var(--gradient-1);opacity:.9;z-index:0}body.new-home-scope .room-thumbnail.is-online{color:#fff}body.new-home-scope .room-thumbnail.is-offline{color:#ffffff8c}body.new-home-scope .room-cover-name{position:absolute;right:12px;bottom:10px;font-weight:800;font-size:14px;line-height:1.2;color:currentColor;text-shadow:0 2px 10px rgba(0,0,0,.55);max-width:calc(100% - 24px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;z-index:2}body.new-home-scope .room-thumbnail.is-online .room-cover-name{color:#fff}body.new-home-scope .room-thumbnail.is-offline .room-cover-name{color:#e2e8f0b3}body.new-home-scope .live-badge{position:absolute;top:8px;left:8px;background:#ef4444;color:#fff;padding:2px 8px;border-radius:12px;font-size:9px;font-weight:700;z-index:3;display:flex;align-items:center;gap:4px;line-height:1}body.new-home-scope .live-badge.is-online{background:#ef4444}body.new-home-scope .live-badge.is-offline{opacity:.65;filter:grayscale(1) contrast(.95)}body.new-home-scope .live-badge.pulse{animation:liveBadgePulse 2s infinite}body.new-home-scope .live-badge .live-text{text-transform:lowercase}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes liveBadgePulse{0%,to{box-shadow:0 2px 12px #4facfe66,0 0 #4facfeb3}50%{box-shadow:0 2px 12px #4facfe99,0 0 0 8px #4facfe00}}body.new-home-scope .room-lock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;pointer-events:none}body.new-home-scope .room-lock-icon{width:48px;height:auto;opacity:.95;filter:drop-shadow(0 10px 22px rgba(0,0,0,.28));display:block}body.new-home-scope .room-lock-text{font-size:11px;line-height:1.15;font-weight:800;letter-spacing:.2px;color:#ffffffe0;text-shadow:0 2px 10px rgba(0,0,0,.55)}body.new-home-scope .live-dot{display:inline-block;width:6px;height:6px;border-radius:999px;flex:0 0 auto}body.new-home-scope .live-dot.on{background:#22c55e}body.new-home-scope .live-dot.off{background:#9ca3af}body.new-home-scope .thumbnail-overlay{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);z-index:1}body.new-home-scope .nh-room-edit-btn{position:absolute;top:6px;right:6px;width:28px;height:28px;border:none;background:transparent;border-radius:0;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;z-index:3;transition:opacity .2s}body.new-home-scope .nh-room-edit-btn:hover{opacity:.9}body.new-home-scope .nh-room-edit-btn:active{opacity:.75}body.new-home-scope .nh-room-edit-btn svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:1.8}body.new-home-scope .app-footer{position:fixed;left:0;right:0;bottom:0;background:#142036;border-top:1px solid #1E304D;height:calc(56px + env(safe-area-inset-bottom));min-height:calc(56px + env(safe-area-inset-bottom));max-height:calc(56px + env(safe-area-inset-bottom));padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-top:0;padding-bottom:0;box-shadow:none;z-index:100;overflow:hidden}body.new-home-scope .footer-nav{display:flex;justify-content:space-around;max-width:1200px;margin:0 auto;height:100%;box-sizing:border-box;padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-top:0;padding-bottom:0}body.new-home-scope .footer-nav-icon{width:24px;height:24px;flex-shrink:0;display:block}body.new-home-scope .footer-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:#ffffff80;padding:8px 16px;position:relative;transition:all .2s ease;gap:4px;height:40px;box-sizing:border-box}body.new-home-scope .footer-nav-item.active,body.new-home-scope .footer-nav-item:hover{color:#29b6f6}body.new-home-scope .footer-nav-item:before{display:none}body.new-home-scope .nav-icon-line{width:24px;height:24px;stroke:currentColor;transition:all .3s ease}body.new-home-scope .footer-nav-item.active .nav-icon-line,body.new-home-scope .footer-nav-item:hover .nav-icon-line{stroke-width:2.5;filter:drop-shadow(0 0 4px currentColor)}@media (min-width: 1024px){body.new-home-scope .live-rooms-grid{grid-template-columns:repeat(3,1fr);max-width:1440px;margin:0 auto}}@media (min-width: 1440px){body.new-home-scope .live-rooms-grid{grid-template-columns:repeat(4,1fr)}}body.new-home-scope ::-webkit-scrollbar{width:6px;height:6px}body.new-home-scope ::-webkit-scrollbar-track{background:var(--bg-secondary)}body.new-home-scope ::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:3px}body.new-home-scope ::-webkit-scrollbar-thumb:hover{background:var(--primary-color)}@media (max-width: 768px){body.new-home-scope .app-container{height:100vh;height:100dvh;width:100%;max-width:100%;overflow:hidden;overflow-x:hidden;display:flex;flex-direction:column}body.new-home-scope .main-content{width:100%;max-width:100%;padding-top:calc(var(--app-header-block-h) + 2px);overflow:hidden;overflow-x:hidden}body.new-home-scope .app-header{padding-top:calc(12px + env(safe-area-inset-top))}body.new-home-scope .live-rooms-grid{box-sizing:border-box;width:100%;max-width:100%}body.new-home-scope .app-header .logo-text{display:inline!important;opacity:1!important;visibility:visible!important;font-size:18px!important;color:#fff!important;-webkit-text-fill-color:#ffffff!important}body.new-home-scope .app-header .logo-sub{font-size:14px!important;color:#29b6f6!important}body.new-home-scope .nh-announcement-row{margin-top:-5px;height:26px;position:relative}body.new-home-scope .nh-top-divider{position:relative}body.new-home-scope .top-fixed-zone{padding:10px 12px 0}body.new-home-scope .nh-ann-shell,body.new-home-scope .nh-ann-gutter,body.new-home-scope .nh-ann-bar{height:26px}body.new-home-scope .nh-ann-icon{font-size:14px;line-height:26px}body.new-home-scope .nh-ann-text{font-size:13px;line-height:26px}body.new-home-scope .nh-ann-edit-btn{width:18px;height:18px;font-size:12px}body.new-home-scope .rooms-scroll{padding:0 12px 100px;scrollbar-width:none;-ms-overflow-style:none}body.new-home-scope .rooms-scroll::-webkit-scrollbar{width:0;height:0;background:transparent}}body.new-home-scope .app-header-title-group{display:flex;align-items:center;gap:8px}body.new-home-scope .app-header-logo{display:inline-flex;align-items:center;justify-content:center;color:#29b6f6;flex-shrink:0}body.new-home-scope .app-header-logo svg{display:block}body.new-home-scope .app-header-title{font-size:18px;font-weight:700;color:#fff;white-space:nowrap;line-height:28px;height:28px;overflow:hidden}body.new-home-scope .header-download-dropdown{position:relative;z-index:1}body.new-home-scope .header-download-trigger{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid rgba(41,182,246,.5);border-radius:8px;color:#29b6f6;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s ease}body.new-home-scope .header-download-trigger:hover{background:#29b6f626;border-color:#29b6f6}body.new-home-scope .header-download-trigger:active{background:#29b6f640}body.new-home-scope .dropdown-arrow{transition:transform .2s ease}body.new-home-scope .dropdown-arrow.open{transform:rotate(180deg)}body.new-home-scope .header-download-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background:#142036;border:1px solid #1E304D;border-radius:12px;padding:8px;box-shadow:0 8px 24px #0006;z-index:9998;display:flex;flex-direction:column;gap:4px}body.new-home-scope .header-download-menu.header-download-menu-portal{position:fixed;z-index:2147483000}body.new-home-scope .header-download-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;text-align:left;transition:all .2s ease}body.new-home-scope .header-download-menu-item:hover{background:#29b6f626;color:#29b6f6}body.new-home-scope .header-download-menu-item:active{background:#29b6f640}body.new-home-scope .header-download-tip-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2147483001}body.new-home-scope .header-download-tip-modal{background:#142036;border:1px solid #1E304D;border-radius:16px;padding:24px;max-width:300px;text-align:center}body.new-home-scope .header-download-tip-modal p{color:#fff;font-size:15px;margin:0 0 16px}body.new-home-scope .header-download-tip-modal button{padding:10px 24px;background:#29b6f6;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease}body.new-home-scope .header-download-tip-modal button:hover{background:#38c7f7}body.new-home-scope .header-download-menu-row{display:flex;align-items:center;gap:0;position:relative}body.new-home-scope .header-download-menu-row .header-download-menu-item{flex:1}body.new-home-scope .header-download-edit-btn{flex:0 0 auto;width:22px;height:22px;border:none;border-radius:50%;background:#29b6f64d;color:#29b6f6;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;padding:0;line-height:1;margin-right:8px;transition:background .2s}body.new-home-scope .header-download-edit-btn:hover{background:#29b6f680}body.new-home-scope .header-download-edit-modal{background:#142036;border:1px solid #1E304D;border-radius:16px;padding:24px;width:340px;max-width:90vw}body.new-home-scope .header-download-edit-title{font-size:15px;font-weight:600;color:#fff;margin:0 0 16px;text-align:center}body.new-home-scope .header-download-edit-input{width:100%;padding:10px 12px;background:#ffffff0f;border:1px solid rgba(41,182,246,.3);border-radius:8px;color:#fff;font-size:13px;font-family:inherit;box-sizing:border-box;outline:none;transition:border-color .2s}body.new-home-scope .header-download-edit-input:focus{border-color:#29b6f6}body.new-home-scope .header-download-edit-input::placeholder{color:#ffffff59}body.new-home-scope .header-download-edit-hint{font-size:11px;color:#fff6;margin:8px 0 16px}body.new-home-scope .header-download-edit-actions{display:flex;gap:10px}body.new-home-scope .header-download-edit-cancel{flex:1;padding:10px 0;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff9;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}body.new-home-scope .header-download-edit-cancel:hover{border-color:#ffffff4d;color:#fff}body.new-home-scope .header-download-edit-save{flex:1;padding:10px 0;background:#29b6f6;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}body.new-home-scope .header-download-edit-save:hover{background:#38c7f7}body.new-home-scope .header-download-edit-save:disabled{opacity:.6;cursor:not-allowed}body.new-home-scope[data-theme=particle-system]{--primary-color: #06b6d4;--secondary-color: #3b82f6;--bg-primary: #0c1222;--bg-secondary: #1a1f35;--text-primary: #e0f2fe;--text-secondary: #7dd3fc;--border-color: #1e3a5f;--accent-color: #06b6d4;--card-bg: rgba(30, 41, 59, .9);--shadow: 0 8px 32px rgba(6, 182, 212, .3);--gradient-1: linear-gradient(135deg, #0c1222 0%, #1a1f35 100%);--gradient-2: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);--logo-gradient: linear-gradient(135deg, #06b6d4 0%, #3b82f6 50%, #8b5cf6 100%)}body.new-home-scope[data-theme=particle-system]:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(1px 1px at 10% 20%,#06b6d4,transparent),radial-gradient(1px 1px at 30% 40%,#3b82f6,transparent),radial-gradient(1px 1px at 50% 60%,#8b5cf6,transparent),radial-gradient(1px 1px at 70% 80%,#06b6d4,transparent),radial-gradient(1px 1px at 90% 10%,#3b82f6,transparent),radial-gradient(1px 1px at 20% 70%,#8b5cf6,transparent),radial-gradient(1px 1px at 60% 30%,#06b6d4,transparent),radial-gradient(1px 1px at 80% 90%,#3b82f6,transparent);background-size:200% 200%;background-position:0% 0%,25% 25%,50% 50%,75% 75%,100% 100%,0% 100%,100% 0%,50% 100%;animation:particleMove 20s linear infinite;z-index:0;pointer-events:none}@keyframes particleMove{0%{background-position:0% 0%,25% 25%,50% 50%,75% 75%,100% 100%,0% 100%,100% 0%,50% 100%;opacity:1}50%{background-position:100% 100%,75% 75%,50% 50%,25% 25%,0% 0%,100% 0%,0% 100%,50% 0%;opacity:.5}to{background-position:0% 0%,25% 25%,50% 50%,75% 75%,100% 100%,0% 100%,100% 0%,50% 100%;opacity:1}}body.new-home-scope[data-theme=particle-system] .live-rooms-grid{grid-template-columns:repeat(2,1fr);gap:20px}body.new-home-scope[data-theme=particle-system] .live-room-card{border-radius:20px;border:1px solid rgba(6,182,212,.3);background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #06b6d44d;position:relative;overflow:hidden}body.new-home-scope[data-theme=particle-system] .live-room-card:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(6,182,212,.5),transparent),radial-gradient(1px 1px at 60% 70%,rgba(59,130,246,.5),transparent);background-size:100% 100%;animation:particleFloat 10s ease-in-out infinite;z-index:1;pointer-events:none}@keyframes particleFloat{0%,to{transform:translateY(0);opacity:.5}50%{transform:translateY(-20px);opacity:1}}body.new-home-scope[data-theme=particle-system] .logo-text{text-shadow:0 0 20px rgba(6,182,212,.8);animation:particleGlow 3s ease-in-out infinite}@keyframes particleGlow{0%,to{text-shadow:0 0 20px rgba(6,182,212,.8);filter:brightness(1)}50%{text-shadow:0 0 30px rgba(6,182,212,1),0 0 40px rgba(59,130,246,.8);filter:brightness(1.2)}}body.new-home-scope[data-theme=particle-system] .app-header{background:#0c122266;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(6,182,212,.2);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff1a;overflow:visible}body.new-home-scope[data-theme=particle-system] .app-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:repeating-linear-gradient(0deg,rgba(0,0,0,.15) 0px,transparent 1px,transparent 2px,rgba(0,0,0,.15) 3px),repeating-linear-gradient(90deg,rgba(0,0,0,.15) 0px,transparent 1px,transparent 2px,rgba(0,0,0,.15) 3px);background-size:4px 4px;opacity:.4;mix-blend-mode:overlay;pointer-events:none;z-index:1}body.new-home-scope[data-theme=particle-system] .app-header:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 20% 30%,rgba(6,182,212,.1) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(0,0,0,.1) 0%,transparent 50%);background-size:200% 200%,150% 150%,100% 100%;animation:noiseMove 20s ease-in-out infinite;opacity:.3;mix-blend-mode:overlay;pointer-events:none;z-index:1}@keyframes noiseMove{0%,to{background-position:0% 0%,0% 0%,0% 0%}33%{background-position:100% 50%,50% 100%,25% 25%}66%{background-position:50% 100%,100% 0%,75% 75%}}body.new-home-scope[data-theme=particle-system] .app-header .header-content{position:relative;z-index:2}body.new-home-scope[data-theme=particle-system] .app-header .header-action-btn{color:#fff;background-color:#06b6d4;border:1px solid transparent}body.new-home-scope[data-theme=particle-system] .app-header .header-action-btn:hover{background-color:#0891b2}body.new-home-scope[data-theme=particle-system] .app-header .header-action-btn:active{background-color:#0e7490}body.new-home-scope[data-theme=particle-system] .app-header .header-action-btn:focus-visible{outline:2px solid #06b6d4;outline-offset:2px}body.new-home-scope[data-theme=particle-system] .app-header .logo-text{color:#06b6d4;animation:neonFlow 3s linear infinite;filter:drop-shadow(0 0 10px rgba(6,182,212,.5));text-shadow:none}@supports (-webkit-background-clip: text) or (background-clip: text){body.new-home-scope[data-theme=particle-system] .app-header .logo-text{background:linear-gradient(90deg,#06b6d4,#3b82f6,#8b5cf6,#06b6d4);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}}@keyframes neonFlow{0%{background-position:0% 50%}to{background-position:100% 50%}}@media (min-width: 768px){body.new-home-scope[data-theme=particle-system] .live-rooms-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){body.new-home-scope[data-theme=particle-system] .live-rooms-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){body.new-home-scope[data-theme=particle-system] .app-header .logo-text{display:inline!important;opacity:1!important;visibility:visible!important;font-size:24px!important;color:#06b6d4!important;-webkit-text-fill-color:#06b6d4!important}body.new-home-scope[data-theme=particle-system] .app-header .logo-sub{font-size:14px!important;color:#fff!important}}.layout-container{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298);padding-bottom:40px}.layout-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:20px 0;box-shadow:0 4px 20px #0000001a}.header-content{max-width:1400px;margin:0 auto;padding:0 40px;display:flex;justify-content:space-between;align-items:center}.header-title{font-size:28px;font-weight:700;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3);margin:0}.header-actions{display:flex;gap:12px;align-items:center}.user-info{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-name{font-weight:500}.logout-btn{padding:10px 24px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logout-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.layout-nav{max-width:1400px;margin:20px auto 30px;padding:0 40px 10px;display:flex;gap:20px;border-bottom:2px solid rgba(255,255,255,.2)}.nav-item{padding:12px 32px;background:transparent;border:none;border-bottom:3px solid transparent;color:#ffffffb3;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;bottom:-2px}.nav-item:hover{color:#fff}.nav-item.active{color:#fff;border-bottom-color:#4facfe}.nav-item.active:after{content:"";position:absolute;bottom:-3px;left:0;right:0;height:3px;background:linear-gradient(90deg,#4facfe,#00f2fe);box-shadow:0 0 10px #4facfe99}.layout-content{max-width:1400px;margin:0 auto;padding:0 40px}@media (max-width: 768px){.header-content{padding:0 16px;flex-wrap:wrap;gap:12px}.header-title{font-size:20px}.layout-nav{padding:0 16px;gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-item{padding:10px 20px;font-size:16px;white-space:nowrap;min-height:44px;-webkit-tap-highlight-color:transparent}.layout-content{padding:0 16px}.user-info{padding:6px 12px;font-size:13px}.logout-btn{padding:8px 16px;font-size:13px}}@media (max-width: 480px){.header-title{font-size:18px}.layout-nav{gap:8px}.nav-item{padding:8px 16px;font-size:15px}}.camera-view-page{padding:20px 0}.camera-view-loading,.camera-view-error{text-align:center;padding:100px 20px;color:#fffc;font-size:18px}.camera-view-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}.back-btn{padding:10px 20px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-btn:hover{background:#ffffff40;transform:translateY(-2px)}.camera-view-title{color:#fff;font-size:28px;font-weight:700;margin:0;text-shadow:0 2px 10px rgba(0,0,0,.3)}.camera-view-content{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:30px}.video-container{text-align:center;margin-bottom:20px}.camera-video{width:100%;max-width:1200px;background:#000;border-radius:12px;box-shadow:0 8px 32px #0000004d}.camera-description{color:#fffc;font-size:14px;text-align:center;margin-top:20px;padding:16px;background:#ffffff0d;border-radius:8px}@media (max-width: 768px){.camera-view-header{flex-direction:column;align-items:flex-start;gap:12px}.camera-view-title{font-size:22px}.camera-view-content{padding:20px}.camera-video{border-radius:8px}}.admin-content{padding:20px 0}.admin-panel{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:30px}.admin-panel h2{color:#fff;font-size:24px;margin-bottom:24px;font-weight:600}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background:#ffffff0d;border-radius:12px;overflow:hidden}.data-table thead{background:#ffffff1a}.data-table th{padding:12px;text-align:left;color:#fff;font-size:14px;font-weight:600;border-bottom:2px solid rgba(255,255,255,.2)}.data-table td{padding:12px;color:#ffffffe6;font-size:14px;border-bottom:1px solid rgba(255,255,255,.1)}.data-table tbody tr:hover{background:#ffffff0d}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.btn{padding:6px 12px;border:none;border-radius:6px;font-size:12px;cursor:pointer;transition:all .3s ease;font-weight:500}.btn-primary{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4facfe66}.btn-danger{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4)}.btn-danger:hover{background:#ef44444d}.btn-link{background:transparent;color:#4facfe;border:none;text-decoration:underline}.btn-link:hover{color:#00f2fe}.add-btn{padding:12px 24px;background:linear-gradient(135deg,#4facfe,#00f2fe);border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4facfe66;margin-bottom:20px}.add-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4facfe99}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}.status-online{background:#4ade8033;color:#4ade80;border:1px solid rgba(74,222,128,.4)}.status-offline{background:#9ca3af33;color:#9ca3af;border:1px solid rgba(156,163,175,.4)}.status-error{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4)}.status-connecting{background:#4facfe33;color:#4facfe;border:1px solid rgba(79,172,254,.4)}.status-no-video{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.4)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.modal-content{background:linear-gradient(135deg,#1e1e32f2,#141428f2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:30px;max-width:600px;width:100%;box-shadow:0 20px 60px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{color:#fff;font-size:24px;font-weight:600;margin:0}.close-btn{background:transparent;border:none;color:#ffffffb3;font-size:32px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#ffffff1a;color:#fff}.form-group{margin-bottom:20px}.form-group label{display:block;color:#fff;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px 16px;background:#0f172af2;border:2px solid rgba(148,163,184,.6);border-radius:10px;color:#fff;font-size:14px;transition:all .3s ease;outline:none}.form-group input:focus,.form-group textarea:focus{border-color:#4facfe;background:#0f172a;box-shadow:0 0 0 3px #4facfe33}.form-group textarea{resize:vertical;min-height:80px}.form-extra{color:#fff9;font-size:12px;margin-top:4px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-btn{padding:12px 24px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.modal-btn-cancel{background:#ffffff1a;color:#fffc}.modal-btn-cancel:hover{background:#fff3;color:#fff}.modal-btn-submit{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;box-shadow:0 4px 15px #4facfe66}.modal-btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4facfe99}@media (max-width: 768px){.admin-header-content{padding:0 16px;flex-wrap:wrap;gap:12px}.admin-title{font-size:24px}.admin-content{padding:20px 16px}.admin-panel{padding:20px}.table-container{overflow-x:scroll}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px 6px}.action-buttons{flex-direction:column}.btn{width:100%}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y pinch-zoom;-webkit-backface-visibility:hidden;backface-visibility:hidden}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text;font-size:16px}#root{width:100%;min-height:100vh;position:relative}button,a,[role=button]{touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1);cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}img{max-width:100%;height:auto;display:block}@media (max-width: 768px){body{font-size:14px}}@media (max-width: 480px){body{font-size:13px}}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-base{background:linear-gradient(90deg,#ffffff0f,#ffffff1f,#ffffff0f);background-size:800px 100%;animation:skeleton-shimmer 1.6s ease-in-out infinite;border-radius:6px}.home-skeleton{padding:68px 16px 16px;min-height:100vh;box-sizing:border-box}.home-skeleton-header{position:fixed;top:0;left:0;right:0;height:52px;background:#0a111f;border-bottom:1px solid #1E304D;padding:0 16px;padding-top:calc(12px + env(safe-area-inset-top));display:flex;align-items:center;justify-content:space-between;z-index:100}.home-skeleton-header-left{display:flex;align-items:center;gap:8px}.home-skeleton-logo{width:28px;height:28px;border-radius:50%}.home-skeleton-title{width:120px;height:20px}.home-skeleton-header-right{width:70px;height:30px;border-radius:8px}.home-skeleton-announcement{height:28px;margin-bottom:4px;display:flex;align-items:center;gap:8px}.home-skeleton-ann-icon{width:16px;height:16px;border-radius:4px;flex-shrink:0}.home-skeleton-ann-text{flex:1;height:16px;max-width:200px}.home-skeleton-divider{height:1px;background:#1e304d;margin:4px 0 12px}.home-skeleton-list-title{display:flex;align-items:center;gap:6px;height:28px;margin-bottom:8px}.home-skeleton-list-icon{width:14px;height:14px;border-radius:4px}.home-skeleton-list-text{width:80px;height:16px}.home-skeleton-badge{width:70px;height:18px;border-radius:12px;margin-left:auto}.home-skeleton-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding-bottom:80px}@media (min-width: 1024px){.home-skeleton-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1440px){.home-skeleton-grid{grid-template-columns:repeat(4,1fr)}}.home-skeleton-card{border-radius:12px;overflow:hidden;background:#142036;border:1px solid #1E304D}.home-skeleton-card-thumb{width:100%;padding-top:56.25%;position:relative}.home-skeleton-card-overlay{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(0,0,0,.3),transparent)}.home-skeleton-card-badge{position:absolute;top:8px;left:8px;width:40px;height:18px;border-radius:12px}.login-skeleton{width:100%;height:100vh;height:100dvh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:#0a111f;padding:16px;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.login-skeleton-card{width:100%;max-width:320px;padding:24px;background:#142036;border:1px solid #1E304D;border-radius:16px}.login-skeleton-logo{width:80px;height:80px;border-radius:50%;margin:0 auto 24px}.login-skeleton-title{width:160px;height:28px;margin:0 auto 16px}.login-skeleton-subtitle{width:100px;height:16px;margin:0 auto 48px}.login-skeleton-form{display:flex;flex-direction:column;gap:16px}.login-skeleton-input{width:100%;height:48px;border-radius:12px}.login-skeleton-btn{width:100%;height:50px;border-radius:12px;margin-top:8px}.player-skeleton{width:100%;height:100vh;height:100dvh;display:flex;flex-direction:column;background:#0a111f}.player-skeleton-header{height:52px;background:#0a111f;border-bottom:1px solid #1E304D;padding:0 16px;display:flex;align-items:center;gap:12px}.player-skeleton-back{width:32px;height:32px;border-radius:8px}.player-skeleton-back-text{width:60px;height:20px}.player-skeleton-video{flex:1;display:flex;align-items:center;justify-content:center;background:#000;position:relative}.player-skeleton-video-placeholder{width:80%;max-width:400px;aspect-ratio:16/9;border-radius:12px}.player-skeleton-controls{height:60px;background:#142036;padding:12px 16px;display:flex;align-items:center;gap:12px}.player-skeleton-play-btn{width:36px;height:36px;border-radius:50%}.player-skeleton-progress{flex:1;height:4px;border-radius:2px}.player-skeleton-time{width:80px;height:16px}.portal-skeleton{width:100%;min-height:100vh;background:#0a111f;display:flex;flex-direction:column}.portal-skeleton-header{height:52px;background:#0a111f;border-bottom:1px solid #1E304D;padding:0 16px;padding-top:env(safe-area-inset-top,0px);display:flex;align-items:center;justify-content:space-between}.portal-skeleton-header-title{width:80px;height:20px}.portal-skeleton-header-action{width:60px;height:30px;border-radius:8px}.portal-skeleton-sidebar{width:200px;background:#142036;border-right:1px solid #1E304D;padding:16px 0}.portal-skeleton-nav-item{height:40px;margin:4px 12px;border-radius:8px}.portal-skeleton-nav-item:first-child{margin-top:0}.portal-skeleton-content{flex:1;padding:20px}.portal-skeleton-card-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.portal-skeleton-card{padding:16px;border-radius:12px;background:#142036;border:1px solid #1E304D}.portal-skeleton-card-title{width:60%;height:20px;margin-bottom:12px}.portal-skeleton-card-desc{width:100%;height:14px;margin-bottom:8px}.portal-skeleton-card-desc:last-child{width:75%}.loading-placeholder{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#0a111f,#142036)}.loading-spinner-large{width:48px;height:48px;border:3px solid rgba(41,182,246,.2);border-top-color:#29b6f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-inline{display:inline-flex;align-items:center;gap:8px}.loading-inline-dot{width:8px;height:8px;border-radius:50%;background:#29b6f6;animation:loading-bounce 1.4s ease-in-out infinite}.loading-inline-dot:nth-child(2){animation-delay:.2s}.loading-inline-dot:nth-child(3){animation-delay:.4s}@keyframes loading-bounce{0%,80%,to{transform:scale(0);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.home-skeleton-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:0 12px 80px}.home-skeleton-header{padding:0 12px}.portal-skeleton-sidebar{display:none}.portal-skeleton-card-list{grid-template-columns:1fr}}@media (max-width: 480px){.login-skeleton-card{padding:20px 16px;border-radius:12px}.login-skeleton-logo{width:64px;height:64px}.login-skeleton-title{width:140px}}
