:root{--color-bg: #030307;--color-surface: #0A0A12;--color-surface-elevated: #151520;--color-surface-hover: #1E1E2D;--color-border: #2A2A3C;--color-border-hover: #3A3A50;--color-text: #F0F0F5;--color-text-secondary: #A0A0B0;--color-text-muted: #6E6E80;--color-accent: #FFD93D;--color-accent-hover: #FFE066;--color-accent-alpha: rgba(255, 217, 61, .15);--color-success: #22C55E;--color-success-hover: #34D399;--color-success-alpha: rgba(34, 197, 94, .15);--color-error: #EF4444;--color-error-hover: #F87171;--color-error-alpha: rgba(239, 68, 68, .15);--color-warning: #F59E0B;--color-warning-hover: #FBBF24;--color-warning-alpha: rgba(245, 158, 11, .15);--color-info: #3B82F6;--color-info-hover: #60A5FA;--color-info-alpha: rgba(59, 130, 246, .15);--font-primary: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Be Vietnam Pro", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", Consolas, monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px rgba(255, 217, 61, .35);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--z-sidebar: 40;--z-topbar: 30;--z-modal: 50;--z-toast: 60}:root{--color-primary: var(--color-bg);--color-surface-alt: var(--color-surface-elevated)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:240px;height:100vh;position:fixed;left:0;top:0;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:var(--space-6) var(--space-4);z-index:var(--z-sidebar);transition:width var(--transition-base);overflow-y:auto}.sidebar.collapsed{width:72px}.sidebar.collapsed .nav-label{display:none}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);font-size:1.25rem;font-weight:700;color:var(--color-text)}.sidebar-nav{list-style:none;display:flex;flex-direction:column;gap:var(--space-1)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-sm, .875rem);font-weight:500;transition:all var(--transition-fast);cursor:pointer;text-decoration:none}.nav-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-item.active{background:var(--color-accent-alpha);color:var(--color-accent);font-weight:600;border-left:3px solid var(--color-accent);margin-left:-3px}.nav-item.active .nav-icon{color:var(--color-accent)}.sidebar-footer{margin-top:auto;padding-top:var(--space-6);border-top:1px solid var(--color-border)}.admin-lang-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-muted);font-size:var(--text-xs, .75rem);font-weight:600;cursor:pointer;transition:all var(--transition-fast);letter-spacing:.05em}.admin-lang-toggle:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-accent)}.admin-lang-toggle .lang-label{text-transform:uppercase}.admin-lang-toggle .lang-arrow{font-size:.625rem;opacity:.5}.main-content{flex:1;margin-left:240px;padding:var(--space-8);min-height:100vh;background:var(--color-bg);transition:margin-left var(--transition-base)}.sidebar.collapsed~.main-content{margin-left:72px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.page-title{font-size:1.75rem;font-weight:700;color:var(--color-text)}.header-actions{display:flex;gap:var(--space-3);align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;cursor:pointer;border:none;transition:all var(--transition-fast);white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,var(--color-accent),#FFC107);color:#000}.btn--primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #ffd93d4d}.btn--secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border);padding:var(--space-3) var(--space-5)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover)}.btn--danger{background:var(--color-error);color:#fff}.btn--danger:hover:not(:disabled){background:var(--color-error-hover)}.btn--ghost{background:transparent;color:var(--color-text-muted)}.btn--ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn--sm{padding:var(--space-2) var(--space-3);font-size:.75rem}.btn--lg{padding:var(--space-4) var(--space-6);font-size:1rem}.btn-primary{background:linear-gradient(135deg,var(--color-accent),#FFC107);color:#000;border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);font-weight:600}.btn-primary:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #ffd93d4d}.btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5)}.btn-secondary:hover{background:var(--color-surface-hover)}.btn-outline{background:transparent;border:2px solid var(--color-accent);color:var(--color-accent);border-radius:var(--radius-lg)}.btn-outline:hover,.btn-outline.selected{background:var(--color-accent);color:#000}.card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.stat-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card__header{display:flex;justify-content:space-between;align-items:center}.stat-card__label{font-size:.875rem;color:var(--color-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-card__trend{display:inline-flex;align-items:center;gap:var(--space-1);font-size:.875rem;font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.stat-card__trend--up{color:var(--color-success);background:var(--color-success-alpha)}.stat-card__trend--down{color:var(--color-error);background:var(--color-error-alpha)}.stat-value{font-size:2rem;font-weight:800;color:var(--color-accent);line-height:1.2}.stat-value--accent{color:var(--color-accent)}.stat-label{color:var(--color-text-muted);font-size:.875rem}.stat-subtitle{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-1)}.stat-icon{font-size:2rem;margin-bottom:var(--space-2)}.data-table__container{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.data-table__toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background:var(--color-surface)}.data-table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);border-bottom:1px solid var(--color-border)}.data-table th:hover{color:var(--color-text)}.data-table th[aria-sort=ascending]:after{content:" ▲";color:var(--color-accent)}.data-table th[aria-sort=descending]:after{content:" ▼";color:var(--color-accent)}.data-table td{padding:var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border)}.table th{color:var(--color-text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.table tr:hover{background:var(--color-surface-hover)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1}.badge--warning{background:var(--color-warning-alpha);color:var(--color-warning)}.badge--error{background:var(--color-error-alpha);color:var(--color-error)}.badge--info{background:var(--color-info-alpha);color:var(--color-info)}.badge--dot:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background:currentColor}.badge-success{background:var(--color-success-alpha);color:var(--color-success)}.badge-warning{background:var(--color-warning-alpha);color:var(--color-warning)}.badge-error{background:var(--color-error-alpha);color:var(--color-error)}.badge-info{background:var(--color-info-alpha);color:var(--color-info)}.badge-pending{background:var(--color-warning-alpha);color:var(--color-warning)}.badge-completed{background:var(--color-success-alpha);color:var(--color-success)}.badge-failed{background:var(--color-error-alpha);color:var(--color-error)}.form-group{margin-bottom:var(--space-5)}.form-group label,.form-label{display:block;margin-bottom:var(--space-2);font-size:.875rem;font-weight:500;color:var(--color-text)}.form-label__required:after{content:" *";color:var(--color-error)}.form-input,.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input::placeholder,.form-group input::placeholder{color:var(--color-text-muted);opacity:.6}.form-input:hover,.form-group input:hover,.form-group select:hover{border-color:var(--color-border-hover)}.form-input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-alpha)}.form-input:disabled{opacity:.5;cursor:not-allowed;background:var(--color-surface-elevated)}.form-input--error{border-color:var(--color-error)}.form-input--error:focus{box-shadow:0 0 0 3px var(--color-error-alpha)}.form-error{font-size:.875rem;color:var(--color-error);margin-top:var(--space-2)}.form-hint{display:block;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-1)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4);animation:fadeIn var(--transition-fast)}.modal{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalSlideIn var(--transition-base)}.modal--large{max-width:720px}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal__title{font-size:1.25rem;font-weight:600}.modal__close{background:none;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:var(--space-2);line-height:1;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal__close:hover{background:var(--color-surface-hover);color:var(--color-text)}.modal__body{padding:var(--space-6)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background:var(--color-surface);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:var(--space-1);line-height:1;transition:color .2s}.modal-close:hover{color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-lg{max-width:600px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.5}.empty-state__title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-2)}.empty-state__message{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-6);max-width:400px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--color-bg)}.login-card{background:var(--color-surface-elevated);padding:var(--space-8);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border)}.login-brand{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-6);font-size:1.5rem;font-weight:800;color:var(--color-text)}.login-brand .brand-icon{font-size:2rem}.login-brand .brand-accent{color:var(--color-accent)}.login-title{font-size:1.25rem;text-align:center;margin-bottom:var(--space-6);color:var(--color-text-muted);font-weight:500}.login-error{background:var(--color-error-alpha);border:1px solid var(--color-error);color:var(--color-error);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:none;font-size:.875rem}.login-error.show{display:block}.login-success{background:var(--color-success-alpha, rgba(34, 197, 94, .1));border:1px solid var(--color-success, #22c55e);color:var(--color-success, #22c55e);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);display:none;font-size:.875rem}.login-success.show{display:block}.forgot-password-row{text-align:right;margin-top:var(--space-2);margin-bottom:var(--space-3)}.forgot-link{font-size:.875rem;color:var(--color-accent);text-decoration:none}.forgot-link:hover{text-decoration:underline}.login-subtitle{text-align:center;color:var(--color-text-muted);margin-bottom:var(--space-6);font-size:.875rem}.auth-success-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:var(--color-bg)}.auth-success-card{background:var(--color-surface-elevated);padding:var(--space-8);border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);text-align:center}.auth-success-card h1{margin-bottom:var(--space-4);color:var(--color-text)}.auth-success-card p{color:var(--color-text-muted);margin-bottom:var(--space-6);line-height:1.6}.checkbox-group{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.checkbox-group input[type=checkbox]{margin-top:3px;width:16px;height:16px;cursor:pointer;accent-color:var(--color-accent)}.checkbox-group label{font-size:.875rem;color:var(--color-text-muted);cursor:pointer;line-height:1.5}.checkbox-group label a{color:var(--color-accent);text-decoration:none}.checkbox-group label a:hover{text-decoration:underline}#toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border-left:4px solid;color:var(--color-text);min-width:320px;max-width:480px;pointer-events:auto;animation:toastSlideIn var(--transition-base)}.toast--success{border-left-color:var(--color-success)}.toast--error{border-left-color:var(--color-error)}.toast--warning{border-left-color:var(--color-warning)}.toast--info{border-left-color:var(--color-info)}.toast__icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:14px;flex-shrink:0}.toast--success .toast__icon{background:var(--color-success-alpha);color:var(--color-success)}.toast--error .toast__icon{background:var(--color-error-alpha);color:var(--color-error)}.toast--warning .toast__icon{background:var(--color-warning-alpha);color:var(--color-warning)}.toast--info .toast__icon{background:var(--color-info-alpha);color:var(--color-info)}.toast__message{flex:1;font-weight:500;font-size:.875rem}.toast__close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:color var(--transition-fast)}.toast__close:hover{color:var(--color-text)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}.spinner-sm{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.packages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.package-card{background:var(--color-surface-elevated);border-radius:var(--radius-xl);padding:var(--space-6);text-align:center;transition:all var(--transition-base);position:relative;border:2px solid transparent}.package-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.package-card.recommended{border-color:var(--color-accent);background:linear-gradient(135deg,var(--color-surface-elevated),var(--color-surface-hover))}.recommended-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--color-accent);color:#000;padding:var(--space-1) var(--space-4);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.package-card h3{font-size:1.25rem;margin-bottom:var(--space-3);color:var(--color-text)}.package-credits{margin-bottom:var(--space-4)}.credits-number{font-size:2.5rem;font-weight:700;color:var(--color-accent);line-height:1}.bonus-badge{display:inline-block;background:var(--color-success-alpha);color:var(--color-success);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;margin-left:var(--space-2)}.package-price{font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:var(--space-4)}.package-card .btn{width:100%}.package-selection{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.package-option{display:flex;align-items:center;padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;border:2px solid transparent;transition:all var(--transition-fast)}.package-option:hover{background:var(--color-surface-hover)}.package-option input[type=radio]{display:none}.package-option input[type=radio]:checked+.package-option-content{border-color:var(--color-accent);background:var(--color-accent-alpha)}.package-option.recommended-option{border-color:var(--color-accent);background:var(--color-accent-alpha)}.package-option-content{flex:1}.package-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.package-option-name{font-weight:600;font-size:1rem}.recommended-tag{background:var(--color-accent);color:#000;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;text-transform:uppercase}.package-option-details{display:flex;justify-content:space-between;align-items:center}.package-option-credits{color:var(--color-text-muted);font-size:.875rem}.package-option-price{font-weight:700;color:var(--color-accent)}.bonus-badge-small{background:var(--color-success-alpha);color:var(--color-success);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;margin-left:var(--space-2)}.order-summary{background:var(--color-surface);margin-bottom:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md)}.order-summary h3{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4)}.summary-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--color-border)}.summary-row:last-of-type{border-bottom:none}.summary-total{display:flex;justify-content:space-between;padding-top:var(--space-4);margin-top:var(--space-4);border-top:2px solid var(--color-accent)}.summary-total strong{font-size:1.25rem;color:var(--color-accent)}.form-actions{display:flex;gap:var(--space-4);justify-content:flex-end;margin-top:var(--space-6)}.field-error{color:var(--color-error);font-size:.875rem;margin-top:var(--space-1);display:none}.field-error.show{display:block}.password-strength{margin-top:var(--space-2)}.strength-bar{height:4px;background:var(--color-border);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--space-1)}.strength-fill{height:100%;transition:width .3s ease,background-color .3s ease}.strength-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.text-muted{color:var(--color-text-muted)}.data-table__wrapper{overflow-x:auto}.pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);flex-wrap:wrap}.pagination--compact{justify-content:center}.pagination__info{font-size:.875rem;color:var(--color-text-muted);white-space:nowrap}.pagination__controls{display:flex;align-items:center;gap:2px}.pagination__btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--space-2);border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit;line-height:1}.pagination__btn:hover:not(:disabled):not(.pagination__btn--active){background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-hover)}.pagination__btn--active{background:var(--color-accent);color:#000;border-color:var(--color-accent);font-weight:600}.pagination__btn:disabled{opacity:.3;cursor:not-allowed}.pagination__btn--nav{font-size:1.1rem}.pagination__ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;color:var(--color-text-muted);font-size:.875rem;-webkit-user-select:none;user-select:none}.pagination--sm .pagination__btn{min-width:28px;height:28px;font-size:.75rem;padding:0 var(--space-1)}.pagination--lg .pagination__btn{min-width:44px;height:44px;font-size:1rem;padding:0 var(--space-3)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.sidebar{display:none}.main-content{margin-left:0;padding:var(--space-4)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.header-actions{width:100%}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.analytics-page{padding:0}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.metric-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.metric-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.metric-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-alpha);border-radius:var(--radius-lg)}.metric-content{flex:1}.metric-label{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.75rem;font-weight:700;color:var(--color-text);opacity:1;transition:opacity .3s}.metric-trend{font-size:.875rem;margin-top:var(--space-1);font-weight:600}.metric-trend.up{color:var(--color-success)}.metric-trend.down{color:var(--color-error)}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6);margin-bottom:var(--space-6)}.chart-container{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column}.chart-container h3{margin-bottom:var(--space-4);font-size:1.125rem;color:var(--color-text);font-weight:600}#trend-chart{width:100%;height:300px;border-radius:var(--radius-md)}.events-list{display:flex;flex-direction:column;gap:var(--space-3)}.event-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-md);transition:background var(--transition-fast)}.event-item:hover{background:var(--color-surface-hover)}.event-rank{font-weight:700;color:var(--color-accent);font-size:1.125rem;width:30px;text-align:center}.event-info{flex:1}.event-name{font-weight:600;color:var(--color-text);margin-bottom:2px}.event-stats,.event-photos{font-size:.875rem;color:var(--color-text-muted)}.stats-section{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5)}.stats-section h3{margin-bottom:var(--space-4);font-size:1.125rem;color:var(--color-text);font-weight:600}.table-container{overflow-x:auto}.quick-actions{display:flex;flex-direction:column;gap:var(--space-3)}.quick-action-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-align:left;font-family:inherit;font-size:.875rem}.quick-action-btn:hover{background:var(--color-surface-hover);border-color:var(--color-accent);transform:translate(4px)}.quick-action-btn .action-icon{font-size:1.25rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-alpha);border-radius:var(--radius-md)}.activity-feed{display:flex;flex-direction:column;gap:var(--space-3)}.activity-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.activity-item:hover{background:var(--color-surface-hover)}.activity-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-alpha);border-radius:var(--radius-md);font-size:1rem;flex-shrink:0}.activity-content{flex:1}.activity-title{font-weight:500;color:var(--color-text);font-size:.875rem}.activity-time{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.balance-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.balance-info{display:flex;flex-direction:column;gap:var(--space-2)}.balance-label{font-size:.875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.balance-value{font-size:2.5rem;font-weight:800;color:var(--color-accent)}.balance-subtitle{font-size:.875rem;color:var(--color-text-muted)}.progress-bar{width:100%;height:8px;background:var(--color-surface);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-2)}.progress-bar__fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width var(--transition-base)}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.metrics-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.header-actions{width:100%}#period-selector,#export-btn{flex:1}}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top:4px solid var(--color-accent);border-radius:50%;animation:spin 1s linear infinite;margin:20px auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.design-studio-hub{padding:0}.studio-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4);margin-top:var(--space-4)}.studio-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast);cursor:default;position:relative;overflow:hidden}.studio-card--active{cursor:pointer}.studio-card--active:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--color-accent)}.studio-card--active:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.studio-card--disabled{opacity:.6}.studio-card__icon{font-size:2.25rem;margin-bottom:var(--space-3);width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-accent-alpha);border-radius:var(--radius-lg)}.studio-card--disabled .studio-card__icon{background:var(--color-surface);border:1px solid var(--color-border)}.studio-card__body{flex:1;margin-bottom:var(--space-3)}.studio-card__title{font-size:1.125rem;font-weight:700;color:var(--color-text);margin-bottom:var(--space-2)}.studio-card__desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.5}.studio-card__footer{display:flex;align-items:center;justify-content:flex-start}.studio-card__badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em}.studio-card__badge--active{background:var(--color-accent-alpha);color:var(--color-accent)}.studio-card__badge--soon{background:var(--color-info-alpha);color:var(--color-info)}.studio-card__badge--cloud{background:var(--color-warning-alpha);color:var(--color-warning)}@media (max-width: 768px){.studio-cards-grid{grid-template-columns:1fr}}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.theme-card{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast),transform var(--transition-fast);cursor:pointer}.theme-card:hover{border-color:var(--color-accent);transform:translateY(-2px)}.theme-card--active{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.theme-card--skeleton{pointer-events:none}.theme-card__preview{height:120px;position:relative;overflow:hidden}.theme-card__swatches{display:flex;gap:4px;padding:var(--space-2)}.theme-card__swatch{width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1)}.theme-card__mini-text{position:absolute;bottom:var(--space-2);right:var(--space-2);padding:2px 8px;border-radius:var(--radius-sm);font-size:14px;opacity:.8}.theme-card__info{padding:var(--space-3);display:flex;align-items:center;justify-content:space-between}.theme-card__name{font-weight:600;font-size:.9rem;color:var(--color-text)}.theme-card__badge{font-size:.75rem;color:var(--color-accent);font-weight:600}.theme-card__actions{padding:0 var(--space-3) var(--space-3);display:flex;gap:var(--space-2);position:relative}.theme-card__menu-dropdown{display:none;position:absolute;top:100%;right:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;min-width:140px;padding:var(--space-1)}.theme-card__menu-dropdown.visible{display:block}.theme-card__menu-dropdown button{display:block;width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--color-text);font-size:.875rem;text-align:left;cursor:pointer;border-radius:var(--radius-sm);font-family:inherit}.theme-card__menu-dropdown button:hover{background:var(--color-surface-hover)}.theme-card--add{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;border-style:dashed;cursor:pointer}.theme-card--add:hover{background:var(--color-surface-hover)}.theme-card__add-icon{font-size:2rem;color:var(--color-text-muted);margin-bottom:var(--space-2)}.theme-card__add-label{color:var(--color-text-muted);font-size:.9rem}.starter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--space-3)}.starter-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;text-align:center;transition:border-color var(--transition-fast)}.starter-card:hover{border-color:var(--color-accent)}.starter-card__swatches{display:flex;gap:3px;justify-content:center;margin-bottom:var(--space-2)}.starter-card__swatches span{width:20px;height:20px;border-radius:50%;border:1px solid rgba(255,255,255,.1)}.starter-card__name{font-size:.8rem;font-weight:600;color:var(--color-text)}.theme-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#000c;display:flex}.theme-editor{width:100%;height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.theme-editor__header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.theme-editor__name-input{flex:1;background:none;border:1px solid transparent;color:var(--color-text);font-size:1.25rem;font-weight:600;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-family:inherit}.theme-editor__name-input:focus{outline:none;border-color:var(--color-accent);background:var(--color-surface-hover)}.theme-editor__header-actions{display:flex;gap:var(--space-3)}.theme-editor__body{display:grid;grid-template-columns:1fr 1fr;flex:1;overflow:hidden}.theme-editor__left{overflow-y:auto;padding:var(--space-6);border-right:1px solid var(--color-border)}.theme-editor__right{display:flex;flex-direction:column;overflow:hidden}.theme-editor__section{margin-bottom:var(--space-8)}.theme-editor__section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-3);font-weight:600}.theme-editor__colors{display:flex;flex-direction:column;gap:var(--space-2)}.color-picker-row{display:flex;align-items:center;gap:var(--space-3)}.color-picker-label{width:100px;font-size:.85rem;color:var(--color-text-secondary);flex-shrink:0}.color-picker-input{width:40px;height:40px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:none}.color-picker-input::-webkit-color-swatch-wrapper{padding:2px}.color-picker-input::-webkit-color-swatch{border:none;border-radius:2px}.color-hex{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.toggle-group{display:flex;gap:2px;background:var(--color-surface);border-radius:var(--radius-md);padding:2px;border:1px solid var(--color-border)}.toggle-btn{flex:1;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-family:inherit}.toggle-btn.active{background:var(--color-accent);color:#000;font-weight:600}.theme-editor__preview-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-4);font-size:.85rem;color:var(--color-text-muted)}.preview-tabs{display:flex;gap:var(--space-2)}.preview-tab{padding:var(--space-1) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.8rem;cursor:pointer;font-family:inherit}.preview-tab.active{background:var(--color-accent);color:#000;border-color:var(--color-accent);font-weight:600}.theme-editor__preview{flex:1;padding:var(--space-6);display:flex;align-items:center;justify-content:center;overflow:auto}.theme-preview-box{width:100%;max-width:360px;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.theme-preview-inner{transition:all var(--transition-base)}.skeleton-block{background:linear-gradient(90deg,var(--color-surface-hover) 25%,var(--color-surface-elevated) 50%,var(--color-surface-hover) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 768px){.theme-editor__body{grid-template-columns:1fr}.theme-editor__right{display:none}}.sessions-page{padding:0}.sessions-page .filter-bar{display:flex;gap:var(--space-3);align-items:center;margin-bottom:var(--space-4)}.status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em;text-transform:capitalize}.status-active{background:var(--color-success-alpha);color:var(--color-success)}.status-completed{background:var(--color-info-alpha);color:var(--color-info)}.status-expired{background:var(--color-warning-alpha);color:var(--color-warning)}.status-pending,.status-default{background:var(--color-surface-hover);color:var(--color-text-muted)}.clickable-row{cursor:pointer;transition:background var(--transition-fast)}.clickable-row:hover{background:var(--color-surface-hover)}.event-name-cell{font-weight:500;color:var(--color-text)}.mono{font-family:var(--font-mono);font-size:.85em}.muted{color:var(--color-text-muted)}.detail-grid{display:flex;flex-direction:column;gap:var(--space-4)}.detail-field{display:flex;flex-direction:column;gap:var(--space-1)}.detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.detail-value{font-size:.9rem;color:var(--color-text)}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-4)}.pagination-info{font-size:.85rem;color:var(--color-text-muted)}.detail-actions{display:flex;justify-content:flex-end}.sessions-detail-modal .modal-body{max-height:70vh;overflow-y:auto}.confirm-modal .modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.search-container{display:flex;flex-direction:column;gap:var(--space-4);max-width:960px}.search-input-wrapper{position:relative;display:flex;align-items:center;gap:var(--space-2);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-2) var(--space-3);box-shadow:var(--shadow-sm)}.search-input-icon{flex:0 0 auto;color:var(--color-text-muted)}.search-input{flex:1;min-width:0;border:0;outline:0;background:transparent;color:var(--color-text);font-size:1rem;padding:var(--space-2) 0}.search-input::placeholder{color:var(--color-text-muted)}.search-filters{display:flex;flex-wrap:wrap;gap:var(--space-2)}.search-filter-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.search-filter-chip:hover,.search-filter-chip.active{background:var(--color-accent-alpha);color:var(--color-accent);border-color:var(--color-accent)}.search-results{display:flex;flex-direction:column;gap:var(--space-4)}.search-summary{color:var(--color-text-muted);font-size:.9rem}.search-loading,.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;padding:var(--space-8);border:1px dashed var(--color-border);border-radius:var(--radius-xl);background:var(--color-surface);text-align:center}.search-empty-icon{font-size:2.5rem;margin-bottom:var(--space-3)}.search-empty-hint{color:var(--color-text-muted);margin-top:var(--space-2)}.search-error{border-color:var(--color-error)}.search-result-group{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.search-group-title{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);font-size:1rem;color:var(--color-text)}.search-group-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 var(--space-2);border-radius:var(--radius-full);background:var(--color-accent-alpha);color:var(--color-accent);font-size:.75rem}.search-result-list{display:flex;flex-direction:column}.search-result-item{display:flex;gap:var(--space-3);padding:var(--space-4) var(--space-5);color:inherit;text-decoration:none;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.search-result-item:last-child{border-bottom:0}.search-result-item:hover,.search-result-item:focus-visible{background:var(--color-surface-hover)}.search-result-icon{flex:0 0 auto;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--color-surface)}.search-result-body{flex:1;min-width:0}.search-result-title{font-weight:600;color:var(--color-text);overflow-wrap:anywhere}.search-result-subtitle{color:var(--color-text-muted);font-size:.875rem;margin-top:var(--space-1)}.search-result-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.search-meta{color:var(--color-text-muted);font-size:.8rem}@media (max-width: 768px){.search-container{max-width:none}.search-filter-chip{flex:1 1 calc(50% - var(--space-2));justify-content:center}.search-result-item{padding:var(--space-3)}}.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-5)}.tab-btn{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--color-text-muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);font-family:inherit;display:inline-flex;align-items:center;gap:var(--space-2)}.tab-btn:hover{color:var(--color-text);border-bottom-color:var(--color-text-muted)}.tab-btn.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:600}.tab-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.notif-page{display:flex;flex-direction:column;gap:var(--space-4)}.notif-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.notif-filter-bar{display:flex;gap:var(--space-2);flex-wrap:wrap}.notif-filter-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.notif-filter-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.notif-filter-btn.active{background:var(--color-accent-alpha);border-color:var(--color-accent);color:var(--color-accent);font-weight:600}.notif-unread-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--space-1);background:var(--color-accent);color:#000;border-radius:var(--radius-full);font-size:.7rem;font-weight:700}.notif-total-muted{font-size:.85rem;color:var(--color-text-muted)}.sidebar-notif-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;margin-left:auto;background:var(--color-accent);color:#000;border-radius:var(--radius-full);font-size:.6rem;font-weight:700;line-height:1}.notif-list{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.notif-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);position:relative}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--color-surface-hover)}.notif-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.notif-item--unread{background:var(--color-accent-alpha)}.notif-item--unread:hover{background:#ffd93d1a}.notif-item-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px;background:transparent}.notif-dot-unread{background:var(--color-accent);box-shadow:0 0 4px var(--color-accent)}.notif-item-icon{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border-radius:var(--radius-md);font-size:1.1rem}.notif-item--unread .notif-item-icon{background:var(--color-accent-alpha)}.notif-item-body{flex:1;min-width:0}.notif-item-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);flex-wrap:wrap}.notif-item-time{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.notif-item-title{font-weight:600;color:var(--color-text);font-size:.9rem;line-height:1.4;word-wrap:break-word}.notif-item-body-text{margin-top:var(--space-1);font-size:.8rem;color:var(--color-text-secondary);line-height:1.4}.notif-item-mark{width:8px;height:8px;border-radius:50%;background:var(--color-accent);flex-shrink:0;margin-top:6px}.notif-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-16)}.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center}.notif-empty-icon{font-size:2.5rem;margin-bottom:var(--space-4);opacity:.5}.notif-empty-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-2)}.notif-empty-msg{font-size:.875rem;color:var(--color-text-muted);max-width:400px;line-height:1.5}.notif-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);background:var(--color-surface-elevated);border:1px solid var(--color-error);border-radius:var(--radius-xl);text-align:center}.notif-error-icon{font-size:2.5rem;margin-bottom:var(--space-4)}.notif-error-title{font-size:1.125rem;font-weight:600;color:var(--color-error);margin-bottom:var(--space-2)}.notif-error-msg{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-6)}.notif-sse-status{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--color-text-muted)}.notif-sse-dot{width:6px;height:6px;border-radius:50%;background:var(--color-success)}.notif-sse-dot--disconnected{background:var(--color-error)}.activity-log-page{padding:0}.activity-log-filters{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-6);align-items:center}.activity-log-filters .form-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--color-text);font-size:.875rem;font-family:inherit}.activity-log-filters .form-input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 2px var(--color-accent-alpha)}.action-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.action-user{background:var(--color-info-alpha);color:var(--color-info)}.action-login{background:var(--color-success-alpha);color:var(--color-success)}.action-session{background:var(--color-accent-alpha);color:var(--color-accent)}.action-photo{background:var(--color-info-alpha);color:var(--color-info)}.action-print{background:var(--color-warning-alpha);color:var(--color-warning)}.action-credit,.action-payment{background:var(--color-success-alpha);color:var(--color-success)}.action-event{background:var(--color-accent-alpha);color:var(--color-accent)}.action-tenant{background:var(--color-warning-alpha);color:var(--color-warning)}.action-frame{background:var(--color-info-alpha);color:var(--color-info)}.action-settings{background:var(--color-warning-alpha);color:var(--color-warning)}.badge{display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full)}.badge--success{background:var(--color-success-alpha);color:var(--color-success)}.badge--muted{background:#6e6e8033;color:var(--color-text-muted)}.resource-cell{display:flex;flex-direction:column;gap:2px}.resource-type{font-weight:500;font-size:.8125rem}.resource-id-mono{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-muted)}.date-cell{white-space:nowrap;font-size:.8125rem}.changes-cell-wrapper{max-width:280px}.changes-cell{font-size:.75rem;line-height:1.4}.change-json{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2);margin-top:2px;max-height:100px;overflow-y:auto;font-family:var(--font-mono);font-size:.6875rem;white-space:pre-wrap;word-break:break-all}.change-divider{margin:var(--space-2) 0;border:none;border-top:1px solid var(--color-border)}.text-center{text-align:center}.cal-container{display:flex;flex-direction:column;gap:var(--space-4)}.cal-header-actions{display:flex;align-items:center;gap:var(--space-3)}.cal-view-toggle{display:flex;gap:2px;background:var(--color-surface);border-radius:var(--radius-md);padding:2px;border:1px solid var(--color-border)}.cal-view-btn{padding:var(--space-1) var(--space-3);background:none;border:none;color:var(--color-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);font-family:inherit}.cal-view-btn:hover{color:var(--color-text)}.cal-view-btn.active{background:var(--color-accent);color:#000;font-weight:600}.cal-view-header{display:flex;align-items:center;justify-content:space-between}.cal-view-title{font-size:1.25rem;font-weight:700;color:var(--color-text)}.cal-month-table{width:100%;border-collapse:collapse;table-layout:fixed;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.cal-month-header-cell{padding:var(--space-2) var(--space-2);text-align:center;font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.cal-month-cell{height:100px;vertical-align:top;padding:var(--space-1);border:1px solid var(--color-border);background:var(--color-surface-elevated);cursor:pointer;transition:background var(--transition-fast);position:relative}.cal-month-cell:hover{background:var(--color-surface-hover)}.cal-month-cell--empty{background:var(--color-surface);cursor:default}.cal-month-cell--today{background:var(--color-accent-alpha);border-color:var(--color-accent)}.cal-month-cell--busy{border-left:3px solid var(--color-error)}.cal-month-day-num{font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-1)}.cal-month-cell--today .cal-month-day-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-accent);color:#000;border-radius:50%;font-size:.8rem}.cal-month-event{display:flex;align-items:center;gap:var(--space-1);padding:1px 0;font-size:.7rem;color:var(--color-text);overflow:hidden;white-space:nowrap}.cal-month-event:hover{color:var(--color-accent)}.cal-month-event-name{overflow:hidden;text-overflow:ellipsis}.cal-month-more{font-size:.7rem;color:var(--color-accent);font-weight:600;padding:1px 0;cursor:pointer}.cal-month-empty{font-size:.7rem;color:var(--color-text-muted);padding:1px 0}.cal-month-availability{position:absolute;bottom:2px;right:2px}.cal-week-grid{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.cal-week-header-row{display:flex;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.cal-week-time-gutter{width:60px;flex-shrink:0;padding:var(--space-2);font-size:.75rem;color:var(--color-text-muted);text-align:right;border-right:1px solid var(--color-border);display:flex;align-items:flex-start;justify-content:flex-end}.cal-week-header-cell{flex:1;padding:var(--space-2);text-align:center;border-right:1px solid var(--color-border)}.cal-week-header-cell:last-child{border-right:none}.cal-week-header-cell--today{background:var(--color-accent-alpha)}.cal-week-day-name{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase}.cal-week-day-num{font-size:1rem;font-weight:700;color:var(--color-text)}.cal-week-day-num--today{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-accent);color:#000;border-radius:50%}.cal-week-row{display:flex;border-bottom:1px solid var(--color-border);min-height:36px}.cal-week-row:last-child{border-bottom:none}.cal-week-cell{flex:1;padding:2px;border-right:1px solid var(--color-border);min-height:36px;display:flex;flex-direction:column;gap:1px}.cal-week-cell:last-child{border-right:none}.cal-week-cell--today{background:var(--color-accent-alpha)}.cal-week-cell--has-events{background:var(--color-surface-elevated)}.cal-week-event{font-size:.65rem;padding:1px 2px;background:var(--color-accent-alpha);color:var(--color-accent);border-radius:2px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:default}.cal-day-view{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.cal-day-header{padding:var(--space-3) var(--space-4);background:var(--color-surface);border-bottom:1px solid var(--color-border)}.cal-day-header--today{background:var(--color-accent-alpha)}.cal-day-header-date{font-size:1rem;font-weight:600;color:var(--color-text)}.cal-day-grid{display:flex;flex-direction:column}.cal-day-row{display:flex;border-bottom:1px solid var(--color-border);min-height:48px}.cal-day-row:last-child{border-bottom:none}.cal-day-time-gutter{width:60px;flex-shrink:0;padding:var(--space-1) var(--space-2);font-size:.75rem;color:var(--color-text-muted);text-align:right;border-right:1px solid var(--color-border);display:flex;align-items:flex-start;justify-content:flex-end;padding-top:var(--space-2)}.cal-day-time-gutter--now{color:var(--color-accent);font-weight:700}.cal-day-cell{flex:1;padding:var(--space-1) var(--space-2);display:flex;flex-direction:column;gap:2px}.cal-day-cell--now{background:var(--color-accent-alpha)}.cal-day-cell--has-events{background:var(--color-surface-elevated)}.cal-day-event{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-accent-alpha);border-radius:var(--radius-sm);font-size:.8rem}.cal-day-event-name{font-weight:600;color:var(--color-text)}.cal-day-event-time{font-size:.7rem;color:var(--color-text-muted);margin-left:auto}.cal-availability-bar{display:flex;height:8px;border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.cal-avail-seg{transition:flex .3s}.cal-avail-seg--free{background:var(--color-success)}.cal-avail-seg--prebooked{background:var(--color-warning)}.cal-avail-seg--busy{background:var(--color-error)}.cal-avail-seg--offline{background:var(--color-text-muted)}.cal-avail-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:.75rem;color:var(--color-text-muted)}.cal-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.cal-dot--event{background:var(--color-accent)}.cal-dot--free{background:var(--color-success)}.cal-dot--prebooked{background:var(--color-warning)}.cal-dot--busy{background:var(--color-error)}.cal-dot--offline{background:var(--color-text-muted)}.cal-footer{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.cal-availability{flex:1}.cal-sse-status{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}@media (max-width: 768px){.cal-header-actions{flex-wrap:wrap}.cal-month-cell{height:60px;padding:2px}.cal-month-event,.cal-month-more,.cal-month-empty{display:none}.cal-month-day-num{font-size:.75rem}.cal-week-time-gutter,.cal-day-time-gutter{width:40px;font-size:.65rem}.cal-week-event{font-size:.6rem}.cal-sse-status{font-size:.65rem}}#toast-container{position:fixed;top:var(--space-6, 1.5rem);right:var(--space-6, 1.5rem);z-index:9999;display:flex;flex-direction:column;gap:var(--space-3, .75rem);pointer-events:none;max-width:100vw;padding:0 var(--space-4, 1rem)}.toast{display:flex;align-items:center;gap:var(--space-3, .75rem);padding:var(--space-4, 1rem) var(--space-5, 1.25rem);background:var(--color-surface, #16213e);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .4));border-left:4px solid;color:var(--color-text, #e2e8f0);min-width:300px;max-width:450px;pointer-events:auto;transform:translate(120%);opacity:0;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s ease;font-family:inherit;font-size:.9375rem;line-height:1.4}.toast-enter{transform:translate(0);opacity:1}.toast-exit{transform:translate(120%);opacity:0}.toast-success{border-left-color:var(--color-success, #10b981)}.toast-error{border-left-color:var(--color-error, #ef4444)}.toast-warning{border-left-color:var(--color-warning, #f59e0b)}.toast-info{border-left-color:var(--color-info, #3b82f6)}.toast-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;flex-shrink:0}.toast-success .toast-icon{background:#10b98133;color:var(--color-success, #10b981)}.toast-error .toast-icon{background:#ef444433;color:var(--color-error, #ef4444)}.toast-warning .toast-icon{background:#f59e0b33;color:var(--color-warning, #f59e0b)}.toast-info .toast-icon{background:#3b82f633;color:var(--color-info, #3b82f6)}.toast-message{flex:1;font-weight:500;word-break:break-word}.toast-close{background:none;border:none;color:var(--color-text-muted, #94a3b8);font-size:20px;line-height:1;padding:0;margin-left:var(--space-2, .5rem);cursor:pointer;transition:color .2s ease;flex-shrink:0}.toast-close:hover{color:var(--color-text, #e2e8f0)}@media (max-width: 480px){#toast-container{left:0;right:0;top:auto;bottom:var(--space-4, 1rem);align-items:center}.toast{min-width:auto;width:100%;max-width:calc(100vw - 2rem);transform:translateY(120%)}.toast-enter{transform:translateY(0)}.toast-exit{transform:translateY(120%);opacity:0}}#error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:var(--space-6, 1.5rem);background:var(--pc-bg, #030307);color:var(--pc-text, #ffffff);font-family:inherit;animation:error-fade-in .3s ease}.error-boundary-content{text-align:center;max-width:600px;width:100%}.error-icon{font-size:4rem;margin-bottom:var(--space-4, 1rem);line-height:1}#error-boundary h1{font-size:1.75rem;font-weight:700;margin-bottom:var(--space-3, .75rem);color:var(--pc-text, #ffffff)}#error-boundary p{font-size:1.125rem;color:var(--pc-text-muted, #64748B);margin-bottom:var(--space-6, 1.5rem)}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md, 8px);padding:var(--space-4, 1rem);margin-bottom:var(--space-4, 1rem);color:var(--pc-error, #ef4444);font-weight:500;word-break:break-word}.error-stack{background:var(--pc-card, #0E0E18);border-radius:var(--radius-md, 8px);padding:var(--space-4, 1rem);margin-bottom:var(--space-4, 1rem);text-align:left;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:.8125rem;line-height:1.5;color:var(--pc-text-muted, #64748B);overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:40vh;overflow-y:auto}.error-actions{display:flex;gap:var(--space-4, 1rem);justify-content:center;flex-wrap:wrap}.error-actions .btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3, .75rem) var(--space-6, 1.5rem);border-radius:var(--radius-md, 8px);font-weight:600;cursor:pointer;border:none;transition:all .15s ease;font-size:1rem;min-width:120px}.error-actions .btn-retry{background:var(--pc-accent, #FFD93D);color:#030307}.error-actions .btn-retry:hover{filter:brightness(1.1)}.error-actions .btn-secondary{background:var(--pc-card, #0E0E18);color:var(--pc-text, #ffffff);border:1px solid var(--pc-border, #1E1E2E)}.error-actions .btn-secondary:hover{background:var(--pc-bg-alt, #0A0A12)}.error-boundary-kiosk .error-icon{font-size:6rem}.error-boundary-kiosk h1{font-size:2.5rem}.error-boundary-kiosk p{font-size:1.5rem}.error-boundary-kiosk .btn-retry{font-size:1.25rem;padding:1rem 2rem;min-width:180px}@keyframes error-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.error-boundary-kiosk h1{font-size:1.75rem}.error-boundary-kiosk p{font-size:1.125rem}.error-actions{flex-direction:column;align-items:stretch}.error-actions .btn{width:100%}}
