.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:width var(--transition-slow);position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:hidden}.collapsed .sidebar{width:var(--sidebar-collapsed)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border);min-height:var(--header-height)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:var(--radius-md);color:#fff;flex-shrink:0;box-shadow:0 2px 8px #04adef33}.logo-text{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);white-space:nowrap}.sidebar-toggle{padding:var(--space-1);flex-shrink:0;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.sidebar-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.property-switcher{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);position:relative}.property-switcher-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.property-switcher-btn:hover{border-color:var(--color-border-hover);background:var(--color-bg-secondary)}.property-switcher-btn.add-first{justify-content:center;color:var(--color-primary);border-style:dashed;gap:var(--space-2)}.property-switcher-current{display:flex;align-items:center;gap:var(--space-2);min-width:0}.property-switcher-current span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.switcher-chevron{flex-shrink:0;transition:transform var(--transition-fast)}.switcher-chevron.open{transform:rotate(180deg)}.property-switcher-dropdown{position:absolute;left:var(--space-3);right:var(--space-3);top:100%;margin-top:var(--space-1);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:240px;overflow-y:auto;animation:slideUp var(--transition-fast)}.property-switcher-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:none;color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition-fast);text-align:left}.property-switcher-option:hover{background:var(--color-bg-tertiary)}.property-switcher-option.active{background:var(--color-brand-light);color:var(--color-primary);font-weight:var(--font-medium)}.property-switcher-code{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono)}.property-switcher-add{border-top:1px solid var(--color-border);color:var(--color-primary);font-weight:var(--font-medium);gap:var(--space-2);justify-content:flex-start}.sidebar-nav{flex:1;padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.nav-section-label{font-size:10px;font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-3) var(--space-1)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);text-decoration:none;white-space:nowrap}.nav-item:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.nav-item.active{background:var(--color-brand-light);color:var(--color-primary);box-shadow:inset 3px 0 0 var(--color-primary)}.nav-icon{flex-shrink:0;width:24px;display:flex;align-items:center;justify-content:center;color:inherit}.nav-label{white-space:nowrap}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.user-info{display:flex;align-items:center;gap:var(--space-3);min-width:0}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-sm);color:#fff;flex-shrink:0}.user-details{min-width:0;overflow:hidden}.user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap}.main-content{flex:1;margin-left:var(--sidebar-width);transition:margin-left var(--transition-slow);min-height:100vh}.collapsed .main-content{margin-left:var(--sidebar-collapsed)}.fnb-layout{display:flex;min-height:100vh}.fnb-sidebar{width:230px;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:hidden}.fnb-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border);min-height:var(--header-height)}.fnb-sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.fnb-logo-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:var(--radius-md);color:#fff;flex-shrink:0;box-shadow:0 2px 8px #f9731640}.fnb-logo-text{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);white-space:nowrap}.fnb-outlet-selector{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);position:relative}.fnb-outlet-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.fnb-outlet-btn:hover{border-color:var(--color-border-hover);background:var(--color-bg-secondary)}.fnb-outlet-current{display:flex;align-items:center;gap:var(--space-2);min-width:0}.fnb-outlet-current span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fnb-outlet-chevron{flex-shrink:0;transition:transform var(--transition-fast)}.fnb-outlet-chevron.open{transform:rotate(180deg)}.fnb-outlet-dropdown{position:absolute;left:var(--space-3);right:var(--space-3);top:100%;margin-top:var(--space-1);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:220px;overflow-y:auto;animation:slideUp var(--transition-fast)}.fnb-outlet-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:transparent;border:none;color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition-fast);text-align:left}.fnb-outlet-option:hover{background:var(--color-bg-tertiary)}.fnb-outlet-option.active{background:#f9731614;color:#ea580c;font-weight:var(--font-medium)}.fnb-outlet-code{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono)}.fnb-outlet-empty{padding:var(--space-3);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.fnb-sidebar-nav{flex:1;padding:var(--space-2);display:flex;flex-direction:column;gap:1px;overflow-y:auto}.fnb-nav-section-label{font-size:10px;font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-3) var(--space-1)}.fnb-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:7px var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:13px;font-weight:var(--font-medium);transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;position:relative}.fnb-nav-item:hover:not(.disabled){background:var(--color-bg-tertiary);color:var(--color-text)}.fnb-nav-item.active{background:#f9731614;color:#ea580c;box-shadow:inset 3px 0 #f97316}.fnb-nav-item.disabled{opacity:.4;cursor:not-allowed}.fnb-nav-icon{flex-shrink:0;width:22px;display:flex;align-items:center;justify-content:center;color:inherit}.fnb-nav-label{white-space:nowrap;flex:1}.fnb-nav-badge{font-size:9px;color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:1px 6px;border-radius:8px;font-weight:500;white-space:nowrap}.fnb-sidebar-footer{padding:var(--space-3);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-2)}.fnb-back-btn{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.fnb-back-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text);border-color:var(--color-border-hover)}.fnb-user-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3)}.fnb-user-avatar{width:24px;height:24px;border-radius:var(--radius-full);background:linear-gradient(135deg,#f97316,#ea580c);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:10px;color:#fff;flex-shrink:0}.fnb-user-name{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fnb-main{flex:1;margin-left:230px;min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#f0f9ff,#e8f7fe 30%,#f8fafb 70%,#f0fdf4)}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0}.login-orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.35}.login-orb-1{width:500px;height:500px;background:#04adef;top:-150px;right:-100px;animation:float 8s ease-in-out infinite}.login-orb-2{width:400px;height:400px;background:#a78bfa;bottom:-100px;left:-80px;animation:float 10s ease-in-out infinite reverse}.login-orb-3{width:300px;height:300px;background:#34d399;top:50%;left:50%;transform:translate(-50%,-50%);animation:float 12s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0)}25%{transform:translate(30px,-30px)}50%{transform:translate(-20px,20px)}75%{transform:translate(10px,-10px)}}.login-container{position:relative;z-index:1;display:flex;gap:var(--space-6);align-items:stretch;animation:slideUp var(--transition-slow);max-width:780px;width:95%}.login-card{background:#ffffffd9;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-12);flex:1;min-width:340px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);border-radius:var(--radius-lg);color:#fff;margin:0 auto var(--space-4);box-shadow:0 4px 12px #04adef40}.login-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text);margin-bottom:var(--space-2)}.login-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.login-error{padding:var(--space-3) var(--space-4);background:var(--color-danger-soft);border:1px solid #fecaca;border-radius:var(--radius-md);color:#dc2626;font-size:var(--text-sm);text-align:center}.quick-login-panel{background:#ffffffbf;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-6);width:300px;flex-shrink:0;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.quick-login-header{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.quick-login-grid{display:flex;flex-direction:column;gap:var(--space-2);flex:1;overflow-y:auto}.quick-login-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left;position:relative}.quick-login-btn:hover:not(:disabled){background:var(--color-brand-light);border-color:#04adef4d;transform:translate(4px)}.quick-login-btn:active:not(:disabled){transform:translate(2px)}.quick-login-btn.loading{background:var(--color-brand-light);border-color:#04adef4d}.quick-login-btn:disabled{opacity:.5;cursor:not-allowed}.quick-login-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-sm);color:var(--color-primary);flex-shrink:0}.quick-login-label{flex:1;font-weight:var(--font-medium)}.quick-login-spinner{width:14px;height:14px;flex-shrink:0}@media(max-width:768px){.login-container{flex-direction:column;max-width:420px}.login-card{min-width:unset}.quick-login-panel{width:100%}.quick-login-grid{display:grid;grid-template-columns:repeat(2,1fr)}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-6)}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;align-items:center;gap:var(--space-4);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--color-border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-lg);color:var(--color-primary);flex-shrink:0}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--space-1)}.branding-section{margin-bottom:var(--space-8)}.branding-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.branding-identity-row{display:flex;align-items:flex-end;gap:var(--space-6)}.branding-preview-badge{padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);color:#fff;font-weight:var(--font-bold);font-size:var(--text-sm);white-space:nowrap;height:fit-content;box-shadow:var(--shadow-sm)}.branding-color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4)}.branding-color-card{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);align-items:center;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.branding-color-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.branding-color-preview-container{flex-shrink:0}.branding-color-preview{width:48px;height:48px;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.branding-color-info{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.branding-color-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.branding-color-input-row{display:flex;align-items:center;gap:var(--space-2)}.branding-color-picker{width:32px;height:32px;border:none;border-radius:var(--radius-sm);cursor:pointer;padding:0;background:transparent;flex-shrink:0}.branding-color-picker::-webkit-color-swatch-wrapper{padding:2px}.branding-color-picker::-webkit-color-swatch{border-radius:var(--radius-sm);border:1px solid var(--color-border)}.branding-hex-input{font-family:var(--font-mono);font-size:var(--text-xs)!important;max-width:120px;text-transform:uppercase}.branding-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.branding-preview-card{padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;box-shadow:var(--shadow-sm)}.branding-mini-sidebar{width:100%;border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-1)}.branding-mini-nav-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);transition:all var(--transition-fast)}.branding-toast{padding:var(--space-3) var(--space-4);background:var(--color-success-soft);border:1px solid #a7f3d0;border-radius:var(--radius-md);color:#059669;font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-6);animation:slideUp var(--transition-slow)}.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.property-card{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-base);position:relative}.property-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.property-card.property-active{border-color:var(--color-primary);box-shadow:0 0 0 3px #04adef1a}.property-active-badge{position:absolute;bottom:var(--space-3);right:var(--space-3);font-size:10px;font-weight:var(--font-bold);color:var(--color-primary);background:var(--color-brand-light);padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.property-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.property-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-lg);color:var(--color-primary)}.card-action-btn{opacity:0;transition:opacity var(--transition-fast)}.property-card:hover .card-action-btn{opacity:1}.property-card-name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.property-card-code{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-mono);margin-bottom:var(--space-3)}.property-card-location{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.property-card-stars{display:flex;gap:2px;margin-bottom:var(--space-3)}.property-card-stats{display:flex;gap:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.modal-lg{max-width:640px}.room-filters{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.room-search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px;color:var(--color-text-muted)}.room-search input{border:none;background:transparent;font-family:var(--font-family);font-size:var(--text-sm);color:var(--color-text);outline:none;width:100%}.view-toggle{display:flex;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.view-toggle-btn{padding:var(--space-2) var(--space-4);border:none;background:transparent;font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.view-toggle-btn.active{background:var(--color-primary);color:#fff}.view-toggle-btn:hover:not(.active){background:var(--color-bg-secondary)}.floor-section{margin-bottom:var(--space-6)}.floor-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.floor-count{font-weight:var(--font-normal);color:var(--color-text-muted);margin-left:auto;font-size:var(--text-xs)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:var(--space-3)}.room-cell{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;transition:all var(--transition-fast);position:relative}.room-cell:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.room-cell.room-selected{border-color:var(--color-primary);box-shadow:0 0 0 3px #04adef26}.room-hk-dirty{border-left:4px solid #ef4444}.room-hk-cleaning{border-left:4px solid #f59e0b}.room-hk-clean{border-left:4px solid #04adef}.room-hk-inspected{border-left:4px solid #10b981}.room-unavailable{opacity:.5;background:var(--color-bg-tertiary)}.room-cell-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-1)}.room-cell-name{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.room-cell-status{width:8px;height:8px;border-radius:50%;flex-shrink:0}.room-cell-type{font-size:10px;color:var(--color-text-muted);font-family:var(--font-mono);letter-spacing:.05em;margin-bottom:var(--space-1)}.room-cell-hk{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--color-text-secondary)}.room-detail-panel{position:fixed;right:0;top:0;bottom:0;width:340px;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);box-shadow:var(--shadow-lg);z-index:90;display:flex;flex-direction:column;animation:slideInRight .2s ease}.room-detail-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border)}.room-detail-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.room-detail-body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto;flex:1}.room-detail-row{display:flex;flex-direction:column;gap:var(--space-1)}.room-detail-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.room-detail-value{font-size:var(--text-sm);color:var(--color-text);font-weight:var(--font-medium)}.room-detail-tabs{display:flex;border-bottom:1px solid var(--color-border)}.room-detail-tab{flex:1;padding:var(--space-3);border:none;background:transparent;font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);text-align:center}.room-detail-tab:hover{color:var(--color-text);background:var(--color-bg-tertiary)}.room-detail-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.room-detail-tab-count{display:inline-flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);color:var(--color-text-muted);font-size:10px;font-weight:var(--font-bold);min-width:18px;height:18px;border-radius:var(--radius-full);margin-left:var(--space-1);padding:0 4px}.room-detail-tab.active .room-detail-tab-count{background:var(--color-brand-light);color:var(--color-primary)}.asset-tab{display:flex;flex-direction:column;gap:var(--space-3)}.asset-tab-header{display:flex;align-items:center;justify-content:space-between}.asset-tab-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.asset-add-form{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.input-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.asset-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6);color:var(--color-text-muted);font-size:var(--text-sm)}.asset-list{display:flex;flex-direction:column;gap:var(--space-2)}.asset-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);transition:border-color var(--transition-fast)}.asset-card:hover{border-color:var(--color-primary)}.asset-card-top{display:flex;align-items:center;gap:var(--space-2)}.asset-card-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-sm);color:var(--color-primary);flex-shrink:0}.asset-card-info{flex:1;min-width:0}.asset-card-name{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-card-cat{display:block;font-size:10px;color:var(--color-text-muted)}.asset-delete-btn{opacity:0;transition:opacity var(--transition-fast);color:var(--color-danger)}.asset-card:hover .asset-delete-btn{opacity:1}.asset-card-bottom{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-2)}.asset-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.select-xs{padding:2px var(--space-2);font-size:var(--text-xs);min-width:0}.asset-tag-label{font-size:10px;font-family:var(--font-mono);color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:1px 5px;border-radius:var(--radius-sm);margin-left:auto}.asset-card-notes{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:var(--space-1);padding-top:var(--space-1);border-top:1px solid var(--color-border);line-height:1.4}.space-tree-container{padding:var(--space-4)}.tree-branch{position:relative}.tree-node{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);margin-bottom:1px}.tree-node:hover{background:var(--color-bg-tertiary)}.tree-node.depth-1{padding-left:calc(var(--space-3) + 20px)}.tree-node.depth-2{padding-left:calc(var(--space-3) + 40px)}.tree-node.depth-3{padding-left:calc(var(--space-3) + 60px)}.tree-expand{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm)}.tree-expand:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.tree-type-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-sm);color:var(--color-primary)}.tree-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.tree-code{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono)}.tree-hk{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-xs);font-weight:var(--font-medium);padding:2px 6px;border-radius:var(--radius-full)}.tree-hk.room-hk-dirty{background:var(--color-danger-soft);color:#dc2626}.tree-hk.room-hk-cleaning{background:var(--color-warning-soft);color:#d97706}.tree-hk.room-hk-clean{background:var(--color-info-soft);color:#0284c7}.tree-hk.room-hk-inspected{background:var(--color-success-soft);color:#059669}.tree-add-btn{margin-left:auto;opacity:0;transition:opacity var(--transition-fast)}.tree-node:hover .tree-add-btn{opacity:1}.tree-children{position:relative}.tree-children:before{content:"";position:absolute;left:22px;top:0;bottom:8px;width:1px;background:var(--color-border)}.bulk-instructions{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text-secondary)}.bulk-instructions p{margin-bottom:var(--space-2)}.bulk-columns{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.bulk-columns code{background:var(--color-bg-card);border:1px solid var(--color-border);padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-primary)}.bulk-notes{margin:0;padding-left:var(--space-5);font-size:var(--text-xs);line-height:1.8}.bulk-preview-header{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary)}.bulk-preview-table-wrap{max-height:300px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.bulk-preview-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.bulk-preview-table th{position:sticky;top:0;background:var(--color-bg-tertiary);padding:var(--space-2) var(--space-3);text-align:left;font-weight:var(--font-semibold);font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.bulk-preview-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);color:var(--color-text)}.bulk-preview-table tr:last-child td{border-bottom:none}.bulk-preview-table code{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--color-bg-tertiary);padding:1px 5px;border-radius:var(--radius-sm)}.bulk-result{display:flex;flex-direction:column;gap:var(--space-4)}.bulk-result-summary{display:flex;gap:var(--space-6)}.bulk-stat{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.bulk-stat-num{font-size:var(--text-xl);font-weight:var(--font-bold)}.bulk-stat-success{color:var(--color-success)}.bulk-stat-warning{color:var(--color-warning)}.bulk-result-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-danger-soft);color:var(--color-danger);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium)}.bulk-errors{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3)}.bulk-errors h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.bulk-error-row{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);padding:var(--space-1) 0;border-bottom:1px solid var(--color-border)}.bulk-error-row:last-child{border-bottom:none}.bulk-error-row code{font-family:var(--font-mono);background:var(--color-bg-tertiary);padding:1px 5px;border-radius:var(--radius-sm)}.rt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6)}.rt-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.rt-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.rt-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.rt-card-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-light);border-radius:var(--radius-lg);color:var(--color-primary)}.rt-card-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.rt-card-code{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono);letter-spacing:.1em;margin-bottom:var(--space-2)}.rt-card-desc{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.5}.rt-card-occupancy{display:flex;gap:var(--space-4);padding:var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.rt-occ-item{display:flex;flex-direction:column;align-items:center;flex:1}.rt-occ-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.rt-occ-value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.rt-card-footer{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.settings-tabs{display:flex;gap:var(--space-1);margin-bottom:var(--space-6);border-bottom:2px solid var(--color-border);padding-bottom:0;overflow-x:auto}.settings-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;white-space:nowrap;transition:all .2s ease}.settings-tab:hover{color:var(--color-text);background:var(--color-bg-tertiary);border-radius:var(--radius-md) var(--radius-md) 0 0}.settings-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-semibold)}.settings-tab.active svg{color:var(--color-primary)}.settings-tab-content{min-height:300px}.settings-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm)}.settings-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.settings-section-title svg{color:var(--color-primary)}.settings-subsection{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4)}.settings-subsection-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.settings-subsection-title svg{color:var(--color-text-muted)}.settings-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-3);line-height:1.5}.settings-fields{display:flex;flex-direction:column;gap:var(--space-4)}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4)}.form-hint{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.input-with-suffix{display:flex;align-items:center;gap:0}.input-with-suffix .input{border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.input-suffix{display:flex;align-items:center;padding:0 var(--space-3);height:36px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em}.sla-label{display:flex;align-items:center;gap:var(--space-2)}.sla-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.sla-dot.critical{background:#ef4444}.sla-dot.high{background:#f97316}.sla-dot.medium{background:#eab308}.sla-dot.low{background:#22c55e}.settings-saved-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-success);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.gst-slab-table{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.gst-slab-header{display:grid;grid-template-columns:1fr 120px;gap:var(--space-4);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.gst-slab-row{display:grid;grid-template-columns:1fr 120px;gap:var(--space-4);padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border);align-items:center}.gst-slab-range{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.gst-slab-rate{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.input-inline{width:80px;padding:var(--space-1) var(--space-2);font-size:var(--text-sm)}@media(max-width:768px){.form-row-2,.form-row-3{grid-template-columns:1fr}.settings-tabs{gap:0}.settings-tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}}.pref-filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.pref-filter-chip{padding:5px 14px;border-radius:20px;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--text-xs);cursor:pointer;transition:all .2s ease;font-weight:500}.pref-filter-chip:hover{background:var(--color-bg-hover);border-color:var(--color-primary);color:var(--color-primary)}.pref-filter-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pref-group{margin-bottom:var(--space-5)}.pref-group-header{display:flex;align-items:center;gap:8px;font-weight:600;font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-3);padding-bottom:6px;border-bottom:2px solid var(--color-border)}.pref-rules-grid{display:flex;flex-direction:column;gap:10px}.pref-rule-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px 16px;transition:all .2s ease}.pref-rule-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #6366f114}.pref-rule-card.inactive{opacity:.55;background:var(--color-bg)}.pref-rule-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.pref-rule-trigger{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pref-chip{display:inline-block;padding:3px 10px;border-radius:6px;background:linear-gradient(135deg,#fef9c3,#fef08a);color:#92400e;font-size:var(--text-xs);font-weight:600;border:1px solid #fbbf2440}.pref-arrow{color:var(--color-text-secondary);font-size:var(--text-sm)}.pref-task-title{font-weight:600;font-size:var(--text-sm);color:var(--color-text)}.pref-rule-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s ease}.pref-rule-card:hover .pref-rule-actions{opacity:1}.pref-rule-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}.pref-toggle{padding:2px 10px;border-radius:10px;font-size:.65rem;font-weight:600;cursor:pointer;border:1px solid;transition:all .2s ease;margin-left:auto}.pref-toggle.on{background:#dcfce7;color:#166534;border-color:#86efac}.pref-toggle.off{background:#fee2e2;color:#991b1b;border-color:#fca5a5}.pref-toggle:hover{filter:brightness(.95)}.modal .form-row{display:flex;gap:12px}.modal .form-row .form-group{flex:1}.inv-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.inv-stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-1)}.inv-stat-warn{border-color:var(--color-warning);background:var(--color-warning-soft)}.inv-stat-danger{border-color:var(--color-danger);background:var(--color-danger-soft)}.inv-stat-num{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.inv-stat-danger .inv-stat-num{color:var(--color-danger)}.inv-stat-warn .inv-stat-num{color:var(--color-warning)}.inv-stat-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.inv-filters{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.inv-table-wrap{overflow-x:auto}.inv-table{width:100%;border-collapse:collapse}.inv-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);white-space:nowrap}.inv-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text);white-space:nowrap}.inv-table tbody tr:hover{background:var(--color-bg-tertiary)}.inv-row-low{background:var(--color-warning-soft)}.inv-row-out{background:var(--color-danger-soft)}.inv-item-name{font-weight:var(--font-medium)}.inv-item-unit{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-2)}.inv-stock-cell{display:flex;align-items:center;gap:var(--space-2)}.inv-stock-num{font-weight:var(--font-bold);font-size:var(--text-base);display:flex;align-items:center;gap:var(--space-1);min-width:40px}.inv-stock-low{color:var(--color-warning)}.inv-stock-out{color:var(--color-danger)}.inv-adjust-btns{display:flex;align-items:center;gap:2px;opacity:0;transition:opacity var(--transition-fast)}.inv-table tbody tr:hover .inv-adjust-btns{opacity:1}.inv-adjust-custom{font-size:var(--text-xs)!important;font-weight:var(--font-bold)!important}.inv-adjust-inline{display:flex;align-items:center;gap:var(--space-1)}.inv-adjust-inline input{width:60px}.btn-xs{padding:2px 6px;font-size:var(--text-xs)}.justify-end{justify-content:flex-end}.guest-search-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-5)}.guest-table-wrap{overflow-x:auto}.guest-table{width:100%;border-collapse:collapse}.guest-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);white-space:nowrap}.guest-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text);white-space:nowrap}.guest-row{cursor:pointer;transition:background var(--transition-fast)}.guest-row:hover{background:var(--color-bg-tertiary)}.guest-name{font-weight:var(--font-semibold);color:var(--color-text)}.guest-contact{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);color:var(--color-text-secondary)}.guest-booking-count{font-weight:var(--font-bold);color:var(--color-primary)}.guest-pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-5)}.guest-pagination-info{font-size:var(--text-sm);color:var(--color-text-muted)}.duplicate-warning{border:1px solid var(--color-warning);border-radius:var(--radius-md);background:var(--color-warning-soft);overflow:hidden}.duplicate-warning-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-warning)}.duplicate-list{border-top:1px solid var(--color-warning)}.duplicate-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background var(--transition-fast);font-size:var(--text-sm)}.duplicate-item:hover{background:#0000000d}.duplicate-item+.duplicate-item{border-top:1px solid var(--color-border)}.duplicate-name{font-weight:var(--font-medium);color:var(--color-text)}.guest-profile-grid{display:grid;grid-template-columns:280px 1fr;gap:var(--space-6);align-items:start}@media(max-width:900px){.guest-profile-grid{grid-template-columns:1fr}}.guest-sidebar{display:flex;flex-direction:column;gap:var(--space-4);position:sticky;top:var(--space-4)}.guest-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.guest-card-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.guest-avatar{width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-brand-light);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);font-weight:var(--font-bold);flex-shrink:0}.guest-card-name{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);line-height:1.2}.guest-card-sub{font-size:var(--text-sm);color:var(--color-text-muted)}.guest-info-list{display:flex;flex-direction:column;gap:var(--space-3)}.guest-info-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.guest-info-item svg{color:var(--color-text-muted);flex-shrink:0}.dnr-banner{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-danger-soft);border:1px solid var(--color-danger);border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--text-sm);font-weight:var(--font-semibold)}.guest-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-5)}.guest-tab{padding:var(--space-3) var(--space-5);border:none;background:transparent;font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast)}.guest-tab:hover{color:var(--color-text)}.guest-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.booking-card-list{display:flex;flex-direction:column;gap:var(--space-3)}.booking-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast)}.booking-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.booking-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-2)}.booking-conf-num{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-primary)}.booking-card-dates{font-size:var(--text-sm);color:var(--color-text-secondary)}.booking-card-rooms{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-2)}.avail-search-bar{display:flex;align-items:flex-end;gap:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}.avail-search-field{display:flex;flex-direction:column;gap:4px}.avail-search-field label{font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.avail-search-field input[type=date]{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px 12px;font-size:.82rem;font-family:var(--font-family);color:var(--color-text);background:var(--color-bg-secondary);outline:none;transition:border-color .15s}.avail-search-field input[type=date]:focus{border-color:var(--color-primary)}.avail-search-counter{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-bg-secondary)}.avail-search-counter button{width:32px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:600;color:var(--color-primary);transition:background .12s}.avail-search-counter button:hover:not(:disabled){background:var(--color-brand-light)}.avail-search-counter button:disabled{opacity:.3;cursor:not-allowed}.avail-search-counter span{min-width:28px;text-align:center;font-size:.88rem;font-weight:600;color:var(--color-text)}.avail-search-btn{height:36px;white-space:nowrap;margin-left:auto}.avail-results-panel{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}.avail-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.avail-results-header h3{font-size:var(--text-base);font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:var(--space-2);margin:0}.avail-results-dates{font-size:.75rem;font-weight:500;color:var(--color-text-muted);margin-left:var(--space-2)}.avail-results-empty{text-align:center;padding:var(--space-6) 0;color:var(--color-text-muted);font-size:var(--text-sm)}.avail-results-grid{display:flex;flex-direction:column;gap:var(--space-3)}.avail-result-card{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-4);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s,box-shadow .15s}.avail-result-card:hover:not(.sold-out){border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f114}.avail-result-card.sold-out{opacity:.55}.avail-result-info{min-width:180px}.avail-result-name{font-weight:600;font-size:var(--text-sm);color:var(--color-text);margin-bottom:2px}.avail-result-meta{display:flex;gap:var(--space-2);font-size:.72rem;color:var(--color-text-muted)}.avail-result-stats{display:flex;gap:var(--space-5);flex:1}.avail-result-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.avail-result-stat-val{font-size:var(--text-lg);font-weight:700}.avail-result-stat-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.avail-result-action{margin-left:auto}.avail-sold-out-badge{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;color:var(--color-danger);background:var(--color-danger-soft)}.bookings-header-actions{display:flex;align-items:center;gap:var(--space-2);min-width:0;overflow:hidden}.bookings-header-search{width:180px;min-width:0;flex:0 1 180px}.bookings-header-search input{font-size:var(--text-sm)}.bookings-header-actions .select-sm{min-width:0;width:120px;flex:0 0 auto}.bookings-header-actions .booking-view-toggle{flex:0 0 auto}.bookings-header-actions .btn-primary{flex:0 0 auto;white-space:nowrap}.select-sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);min-width:120px}.booking-table-wrap{overflow-x:auto}.booking-table{width:100%;border-collapse:collapse}.booking-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);white-space:nowrap}.booking-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text);white-space:nowrap}.booking-row{cursor:pointer;transition:background var(--transition-fast)}.booking-row:hover{background:var(--color-bg-tertiary)}.booking-conf{font-family:var(--font-mono);font-weight:var(--font-bold);font-size:var(--text-sm);color:var(--color-primary)}.booking-guest-cell{display:flex;align-items:center;gap:var(--space-1)}.booking-guest-name{font-weight:var(--font-medium)}.booking-rooms-cell{display:flex;gap:var(--space-1);flex-wrap:wrap}.booking-status-pill{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.02em}.booking-amount{font-weight:var(--font-semibold);font-family:var(--font-mono);font-size:var(--text-sm)}.booking-wizard{max-width:780px;margin:0 auto}.wizard-steps{display:flex;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6)}.wizard-step{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid transparent;transition:all var(--transition-fast)}.wizard-step.active{color:var(--color-primary);background:var(--color-brand-light);border-color:var(--color-primary)}.wizard-step.done{color:var(--color-success);background:var(--color-success-soft)}.wizard-step-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-bold);background:var(--color-bg-card);border:1px solid var(--color-border)}.wizard-step.active .wizard-step-num{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.wizard-step.done .wizard-step-num{background:var(--color-success);color:#fff;border-color:var(--color-success)}.wizard-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm)}.wizard-card h3{font-size:var(--text-lg);font-weight:var(--font-bold);margin-bottom:var(--space-5);color:var(--color-text)}.wizard-actions{display:flex;justify-content:space-between;margin-top:var(--space-6)}.guest-autocomplete{position:relative}.guest-autocomplete-list{position:absolute;top:100%;left:0;right:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:240px;overflow-y:auto;margin-top:var(--space-1)}.guest-autocomplete-item{padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);display:flex;align-items:center;justify-content:space-between;font-size:var(--text-sm)}.guest-autocomplete-item:hover{background:var(--color-bg-tertiary)}.guest-autocomplete-item+.guest-autocomplete-item{border-top:1px solid var(--color-border)}.avail-grid{display:flex;flex-direction:column;gap:var(--space-3)}.avail-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.avail-row:hover{border-color:var(--color-primary)}.avail-row.selected{border-color:var(--color-primary);background:var(--color-brand-light);box-shadow:0 0 0 2px var(--color-primary-alpha)}.avail-row.unavailable{opacity:.5;cursor:not-allowed}.avail-name{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--color-text);min-width:160px}.avail-stats{display:flex;gap:var(--space-4);flex:1}.avail-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.avail-stat-val{font-size:var(--text-lg);font-weight:var(--font-bold)}.avail-stat-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase}.avail-qty-controls{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.avail-qty-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg-card);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-bold);transition:all var(--transition-fast)}.avail-qty-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.avail-qty-btn:disabled{opacity:.3;cursor:not-allowed}.avail-qty-val{font-size:var(--text-lg);font-weight:var(--font-bold);min-width:24px;text-align:center;color:var(--color-primary)}.review-section{margin-bottom:var(--space-5)}.review-section h4{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-3)}.review-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}.review-row:last-child{border-bottom:none}.review-label{color:var(--color-text-muted)}.review-value{font-weight:var(--font-medium);color:var(--color-text)}.review-total{display:flex;justify-content:space-between;padding:var(--space-3) 0;font-size:var(--text-lg);font-weight:var(--font-bold);border-top:2px solid var(--color-border);margin-top:var(--space-3)}.booking-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--space-6)}@media(max-width:900px){.booking-detail-grid{grid-template-columns:1fr}}.booking-detail-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.booking-detail-card-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4)}.booking-detail-conf{font-family:var(--font-mono);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-primary);margin-bottom:var(--space-1)}.booking-room-card{padding:var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2)}.booking-room-card-name{font-weight:var(--font-semibold);font-size:var(--text-sm);margin-bottom:var(--space-1)}.booking-room-card-meta{font-size:var(--text-xs);color:var(--color-text-muted);display:flex;gap:var(--space-3)}.audit-log-list{display:flex;flex-direction:column;gap:var(--space-2)}.audit-log-item{font-size:var(--text-xs);color:var(--color-text-secondary);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);line-height:1.5}.audit-log-item:last-child{border-bottom:none}.audit-field{font-weight:var(--font-semibold);color:var(--color-text)}.booking-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.booking-view-toggle button{display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;background:var(--color-bg-card);cursor:pointer;font-size:.78rem;font-weight:600;color:var(--color-text-muted);transition:all .15s}.booking-view-toggle button+button{border-left:1px solid var(--color-border)}.booking-view-toggle button.active{background:var(--color-primary);color:#fff}.booking-view-toggle button:hover:not(.active){background:var(--color-bg-tertiary)}.timeline-container{width:100%}.timeline-controls{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4);flex-wrap:wrap}.timeline-nav{display:flex;align-items:center;gap:var(--space-2)}.timeline-nav-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);cursor:pointer;transition:all .12s}.timeline-nav-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.timeline-date-input{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:5px 10px;font-size:.82rem;font-family:var(--font-family);background:var(--color-bg-card);color:var(--color-text)}.timeline-today-btn{font-weight:600!important;color:var(--color-primary)!important}.timeline-zoom{display:flex;align-items:center;gap:6px;margin-left:auto}.timeline-zoom-btn{padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-bg-card);font-size:.72rem;font-weight:600;cursor:pointer;color:var(--color-text-muted);transition:all .12s}.timeline-zoom-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.timeline-zoom-btn:hover:not(.active){border-color:var(--color-primary);color:var(--color-primary)}.timeline-filter-checkbox{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 12px;border:1px solid var(--color-border);border-radius:var(--radius-full);transition:all .15s}.timeline-filter-checkbox:hover{border-color:var(--color-primary);color:var(--color-primary)}.timeline-filter-checkbox input[type=checkbox]{accent-color:var(--color-primary);width:14px;height:14px;cursor:pointer}.timeline-room-count{font-size:.78rem;color:var(--color-text-muted);font-weight:600}.timeline-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-8) 0;color:var(--color-primary)}.timeline-grid-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);box-shadow:var(--shadow-sm)}.timeline-grid{display:grid;min-width:100%}.timeline-header-cell{padding:6px 4px;text-align:center;font-size:.68rem;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary);position:sticky;top:0;z-index:10}.timeline-room-header{display:flex;align-items:center;gap:6px;justify-content:flex-start;padding-left:12px;font-size:.72rem;font-weight:700;color:var(--color-text);position:sticky;left:0;background:var(--color-bg-tertiary);z-index:11}.timeline-date-header{display:flex;flex-direction:column;align-items:center;gap:2px;border-left:1px solid var(--color-border)}.timeline-date-header.sunday{background:#00000005}.timeline-date-header.today{background:var(--color-brand-light)}.timeline-date-day{font-size:.6rem;letter-spacing:.03em}.timeline-date-num{font-size:.82rem;font-weight:700;color:var(--color-text)}.timeline-date-num.today-num{background:var(--color-primary);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem}.timeline-month-label{padding:3px 12px;font-size:.65rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.05em;text-align:center;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.timeline-type-header{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);position:sticky;left:0}.timeline-type-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary)}.timeline-type-name{font-size:.75rem;font-weight:700;text-transform:uppercase;color:var(--color-text);letter-spacing:.03em}.timeline-type-count{font-size:.72rem;color:var(--color-text-muted);font-weight:500}.timeline-room-label{padding:8px 12px;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);background:var(--color-bg-card);position:sticky;left:0;z-index:5;display:flex;flex-direction:column;justify-content:center}.timeline-room-label.ooo{background:repeating-linear-gradient(-45deg,var(--color-bg-card),var(--color-bg-card) 5px,rgba(239,68,68,.05) 5px,rgba(239,68,68,.05) 10px)}.timeline-room-name{font-weight:700;font-size:.82rem;color:var(--color-text)}.timeline-room-meta{font-size:.65rem;color:var(--color-text-muted);margin-top:1px}.timeline-room-cells{border-bottom:1px solid var(--color-border);min-height:44px}.timeline-cell-grid{display:grid;height:100%}.timeline-cell{border-left:1px solid var(--color-border);cursor:pointer;transition:background .1s;min-height:44px}.timeline-cell:hover:not(.ooo){background:#3b82f60f}.timeline-cell.today{background:#3b82f60a;border-left:2px solid var(--color-primary)}.timeline-cell.sunday{background:#00000004}.timeline-cell.ooo{cursor:not-allowed;background:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(239,68,68,.06) 4px,rgba(239,68,68,.06) 8px)}.timeline-booking-block{position:absolute;top:4px;bottom:4px;border-radius:5px;border:1.5px solid;display:flex;align-items:center;padding:0 8px;font-size:.72rem;font-weight:600;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;z-index:3;transition:transform .1s,box-shadow .1s}.timeline-booking-block:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001f;z-index:4}.timeline-booking-name{overflow:hidden;text-overflow:ellipsis}.timeline-ooo-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(239,68,68,.08) 4px,rgba(239,68,68,.08) 8px);z-index:2;pointer-events:none}.timeline-legend{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) 0;margin-top:var(--space-3);flex-wrap:wrap}.timeline-legend-item{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:500;color:var(--color-text-muted)}.timeline-legend-swatch{width:16px;height:10px;border-radius:2px;border:1.5px solid}.timeline-legend-ooo{background:repeating-linear-gradient(-45deg,transparent,transparent 2px,rgba(239,68,68,.15) 2px,rgba(239,68,68,.15) 4px);border-color:#ef44444d}.timeline-legend-today{background:var(--color-brand-light);border-color:var(--color-primary)}.timeline-legend-hint{margin-left:auto;font-size:.7rem;font-style:italic;color:var(--color-text-muted);opacity:.7}.fd-board{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}@media(max-width:1100px){.fd-board{grid-template-columns:1fr}}.fd-column{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.fd-column-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary)}.fd-column-title{font-size:var(--text-sm);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:var(--space-2)}.fd-column-count{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-bold);color:#fff}.fd-column-count.arrivals{background:var(--color-primary)}.fd-column-count.in-house{background:var(--color-success)}.fd-column-count.departures{background:var(--color-warning)}.fd-card-list{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);max-height:70vh;overflow-y:auto}.fd-card{padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.fd-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.fd-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-1)}.fd-card-guest{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--color-text)}.fd-card-conf{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-primary);font-weight:var(--font-bold)}.fd-card-meta{font-size:var(--text-xs);color:var(--color-text-muted);display:flex;gap:var(--space-3);flex-wrap:wrap}.fd-card-rooms{display:flex;gap:var(--space-1);flex-wrap:wrap;margin-top:var(--space-2)}.fd-card-balance{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-bold)}.fd-card-balance.positive{color:var(--color-danger)}.fd-card-balance.zero{color:var(--color-success)}.checkin-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.checkin-section-title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-4)}.room-picker{display:flex;flex-direction:column;gap:var(--space-3)}.room-picker-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.room-picker-type{font-weight:var(--font-semibold);font-size:var(--text-sm);min-width:140px}.room-picker-select{flex:1}.stay-layout{display:grid;grid-template-columns:1fr 340px;gap:var(--space-6)}@media(max-width:960px){.stay-layout{grid-template-columns:1fr}}.stay-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.stay-card+.stay-card{margin-top:var(--space-4)}.stay-card-title{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-4)}.stay-room-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-brand-light);color:var(--color-primary);border-radius:var(--radius-md);font-weight:var(--font-bold);font-size:var(--text-lg)}.folio-table{width:100%;border-collapse:collapse}.folio-table th{padding:var(--space-2) var(--space-3);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);background:var(--color-bg-tertiary)}.folio-table td{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}.folio-table tr.voided td{text-decoration:line-through;opacity:.5}.folio-amount{font-family:var(--font-mono);font-weight:var(--font-medium)}.folio-amount.debit{color:var(--color-text)}.folio-amount.credit{color:var(--color-success)}.folio-summary{display:flex;justify-content:flex-end;gap:var(--space-6);padding:var(--space-4);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-top:var(--space-4)}.folio-summary-item{text-align:right}.folio-summary-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase}.folio-summary-value{font-size:var(--text-lg);font-weight:var(--font-bold);font-family:var(--font-mono)}.folio-summary-value.balance-positive{color:var(--color-danger)}.folio-summary-value.balance-zero{color:var(--color-success)}.payment-methods{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.payment-method-btn{flex:1;padding:var(--space-3);border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);cursor:pointer;text-align:center;font-size:var(--text-sm);font-weight:var(--font-medium);transition:all var(--transition-fast);font-family:var(--font-family);color:var(--color-text)}.payment-method-btn:hover{border-color:var(--color-primary)}.payment-method-btn.active{border-color:var(--color-primary);background:var(--color-brand-light);color:var(--color-primary)}.room-history-list{display:flex;flex-direction:column;gap:var(--space-2)}.room-history-item{font-size:var(--text-xs);color:var(--color-text-secondary);padding:var(--space-2);background:var(--color-bg-tertiary);border-radius:var(--radius-md);line-height:1.5}.journey-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:20px}.journey-timeline:before{content:"";position:absolute;left:8px;top:12px;bottom:12px;width:2px;background:var(--color-border)}.journey-stage{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2);background:var(--color-bg-card);transition:all var(--transition-fast)}.journey-stage.active{border-color:#6366f1;box-shadow:0 0 0 1px #6366f133}.journey-stage.completed{border-color:var(--color-success);opacity:.85}.journey-stage.pending{opacity:.6}.journey-stage-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.journey-stage-header:hover{background:var(--color-bg-tertiary)}.journey-stage-indicator{display:flex;align-items:center;justify-content:center;flex-shrink:0}.journey-stage.completed .journey-stage-indicator{color:var(--color-success)}.journey-stage.active .journey-stage-indicator{color:#6366f1}.journey-stage.pending .journey-stage-indicator{color:var(--color-text-muted)}.journey-stage-info{flex:1;min-width:0}.journey-stage-info h4{font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0 0 2px}.journey-stage-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.journey-status-badge{font-size:.65rem;font-weight:var(--font-semibold);padding:1px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.04em}.journey-status-badge.active{background:#6366f11f;color:#6366f1}.journey-status-badge.completed{background:#10b9811f;color:#10b981}.journey-status-badge.pending{background:var(--color-bg-tertiary);color:var(--color-text-muted)}.journey-task-count{font-size:var(--text-xs);color:var(--color-text-muted)}.journey-time{font-size:var(--text-xs);color:var(--color-text-muted);display:flex;align-items:center;gap:3px}.journey-stage-actions{display:flex;gap:var(--space-2);flex-shrink:0}.journey-stage-tasks{border-top:1px solid var(--color-border);padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);background:var(--color-bg-tertiary)}.journey-task{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-card);overflow:hidden;transition:all var(--transition-fast)}.journey-task:hover{box-shadow:var(--shadow-sm)}.journey-task.sla-breached{border-color:#ef4444;background:#ef44440a}.journey-task-priority{width:3px;flex-shrink:0}.journey-task-body{flex:1;padding:var(--space-2) var(--space-3);min-width:0}.journey-task-top{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.journey-task-top strong{font-size:var(--text-sm)}.journey-checklist{margin-top:var(--space-2);display:flex;flex-direction:column;gap:2px}.journey-checklist-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);cursor:pointer;padding:2px 0}.journey-checklist-item.done span{text-decoration:line-through;color:var(--color-text-muted)}.journey-checklist-item input[type=checkbox]{width:14px;height:14px;accent-color:#6366f1}.journey-task-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-2);gap:var(--space-2)}.journey-sla{font-size:.65rem;display:flex;align-items:center;gap:3px;color:var(--color-text-muted)}.journey-sla.breached{color:#ef4444;font-weight:var(--font-bold)}.jcc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-5);gap:var(--space-4)}.jcc-header-left{display:flex;align-items:center;gap:var(--space-3)}.jcc-header-left .page-title{margin-bottom:0}.jcc-header-right{display:flex;gap:var(--space-2);flex-shrink:0}.jcc-stats{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.jcc-stat{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:140px}.jcc-stat.breached{border-color:#ef44444d;background:#ef44440a}.jcc-stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);display:block;line-height:1}.jcc-stat-label{font-size:var(--text-xs);color:var(--color-text-muted);display:block;margin-top:2px}.jcc-filters{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.jcc-search{display:flex;align-items:center;gap:var(--space-2);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);flex:1;max-width:360px;color:var(--color-text-muted)}.jcc-search input{border:none;background:transparent;outline:none;font-size:var(--text-sm);color:var(--color-text);width:100%;font-family:var(--font-family)}.jcc-toggle{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.jcc-toggle input[type=checkbox]{accent-color:#6366f1}.jcc-board{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-4);-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;max-width:calc(100vw - var(--sidebar-width) - var(--space-8) - var(--space-8))}.collapsed .jcc-board{max-width:calc(100vw - var(--sidebar-collapsed) - var(--space-8) - var(--space-8))}.jcc-board::-webkit-scrollbar{height:6px}.jcc-board::-webkit-scrollbar-track{background:var(--color-bg-tertiary);border-radius:3px}.jcc-board::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.jcc-column{min-width:300px;max-width:340px;flex-shrink:0;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;scroll-snap-align:start;display:flex;flex-direction:column}.jcc-column-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-top:3px solid #6b7280;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.jcc-column-title{font-size:var(--text-sm);font-weight:var(--font-bold);text-transform:uppercase;letter-spacing:.05em}.jcc-column-counts{display:flex;gap:var(--space-1)}.jcc-count{min-width:22px;height:22px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:var(--font-bold);color:#fff}.jcc-count.done{background:#10b981}.jcc-column-body{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);max-height:65vh;overflow-y:auto;flex:1}.jcc-empty{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-4)}.jcc-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);transition:all var(--transition-fast)}.jcc-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.jcc-card.completed{opacity:.6}.jcc-card.has-breach{border-color:#ef444466}.jcc-card-top{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);cursor:pointer;gap:var(--space-2)}.jcc-card-guest{display:flex;align-items:center;gap:var(--space-3);min-width:0}.jcc-card-room{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-2);border:2px solid;border-radius:var(--radius-sm);font-weight:var(--font-bold);font-size:var(--text-xs);flex-shrink:0;min-width:40px;text-align:center}.jcc-card-guest strong{font-size:var(--text-sm);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jcc-card-meta{display:flex;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);margin-top:1px}.jcc-card-progress{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-3) var(--space-2);cursor:pointer}.jcc-progress-bar{flex:1;height:4px;background:var(--color-bg-tertiary);border-radius:2px;overflow:hidden}.jcc-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.jcc-progress-label{font-size:.65rem;color:var(--color-text-muted);white-space:nowrap;display:flex;align-items:center;gap:var(--space-1)}.jcc-breach-badge{display:inline-flex;align-items:center;gap:2px;color:#ef4444;font-weight:var(--font-bold)}.jcc-card-tasks{border-top:1px solid var(--color-border);padding:var(--space-2) var(--space-3) var(--space-3);display:flex;flex-direction:column;gap:4px;background:var(--color-bg-tertiary);max-height:500px;overflow-y:auto;border-radius:0 0 var(--radius-md) var(--radius-md)}.jcc-task{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--color-bg-card);border:1px solid var(--color-border);transition:all var(--transition-fast)}.jcc-task:hover{border-color:var(--color-primary)}.jcc-task.breached{border-color:#ef444466;background:#ef444408}.jcc-task.done{opacity:.5}.jcc-task-indicator{width:3px;height:20px;border-radius:2px;flex-shrink:0}.jcc-task-info{flex:1;min-width:0}.jcc-task-title{font-size:var(--text-xs);font-weight:var(--font-medium);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jcc-task-meta{display:flex;gap:var(--space-2);align-items:center;margin-top:1px}.jcc-task-dept{font-size:.6rem;color:var(--color-primary);background:var(--color-brand-light);padding:0 4px;border-radius:3px;font-weight:var(--font-medium)}.jcc-task-sla{font-size:.6rem;color:var(--color-text-muted);display:flex;align-items:center;gap:2px}.jcc-task-sla.breached{color:#ef4444;font-weight:var(--font-bold)}.jcc-task.scheduled{opacity:.55;border-style:dashed}.jcc-task-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast);flex-shrink:0}.jcc-task-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-brand-light)}.jcc-task-btn.blocked,.jcc-task-btn:disabled{opacity:.35;cursor:not-allowed;border-color:var(--color-border);color:var(--color-text-muted);background:var(--color-bg-tertiary)}.jcc-empty-state{text-align:center;padding:var(--space-8) var(--space-4)}.jcc-empty-state h3{margin-top:var(--space-4);font-weight:var(--font-semibold);color:var(--color-text)}.jcc-empty-state p{color:var(--color-text-muted);font-size:var(--text-sm);max-width:400px;margin:var(--space-2) auto 0}.jcc-card.expanded{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.jcc-card-task-pip{font-size:.65rem;font-weight:var(--font-bold);white-space:nowrap}.jcc-task-wrapper{border-radius:var(--radius-sm);overflow:hidden}.jcc-task-wrapper.task-expanded{border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-bg)}.jcc-task-wrapper.task-expanded .jcc-task{border:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.jcc-task.has-checklist{cursor:pointer}.jcc-task.has-checklist:hover{background:#6366f10a}.jcc-checklist-pip{display:inline-flex;align-items:center;gap:2px;font-size:.6rem;color:var(--color-text-muted);background:#6366f114;padding:1px 5px;border-radius:8px;font-weight:var(--font-medium);white-space:nowrap}.jcc-checklist{padding:var(--space-1) var(--space-2) var(--space-2);display:flex;flex-direction:column;gap:2px;background:var(--color-bg);border-top:1px solid var(--color-border)}.jcc-checklist-item{display:flex;align-items:center;gap:var(--space-2);padding:4px 6px;border-radius:var(--radius-xs);cursor:pointer;transition:background var(--transition-fast);font-size:var(--text-xs);color:var(--color-text)}.jcc-checklist-item:hover{background:#6366f10a}.jcc-checklist-item.checked{color:var(--color-text-muted)}.jcc-checklist-item.checked .jcc-checklist-text{text-decoration:line-through;opacity:.6}.jcc-checklist-check{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;flex-shrink:0}.jcc-checklist-text{flex:1;line-height:1.3}.jcc-checklist-req{color:#ef4444;font-weight:var(--font-bold);font-size:.7rem;flex-shrink:0}.jcc-no-tasks{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);padding:var(--space-2) 0}.jcc-view-stay{display:flex;align-items:center;justify-content:center;gap:var(--space-1);width:100%;padding:var(--space-2);margin-top:var(--space-1);border:1px dashed var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.jcc-view-stay:hover{background:var(--color-brand-light);border-color:var(--color-primary)}@media(max-width:768px){.jcc-stats,.jcc-board{flex-direction:column}.jcc-column{min-width:100%;max-width:100%}}.ttc-stages{display:flex;flex-direction:column;gap:var(--space-2)}.ttc-stage-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);overflow:hidden}.ttc-stage-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition-fast);-webkit-user-select:none;user-select:none}.ttc-stage-header:hover{background:var(--color-bg-tertiary)}.ttc-stage-left{display:flex;align-items:center;gap:var(--space-2)}.ttc-stage-left h3{font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.ttc-template-count{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-2)}.ttc-template-list{border-top:1px solid var(--color-border);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);background:var(--color-bg-tertiary)}.ttc-empty{display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm)}.ttc-template{display:flex;align-items:center;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-card);overflow:hidden;transition:all var(--transition-fast)}.ttc-template:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.ttc-template.inactive{opacity:.5}.ttc-template-priority{width:4px;align-self:stretch;flex-shrink:0}.ttc-template-body{flex:1;padding:var(--space-3);min-width:0}.ttc-template-top{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.ttc-template-top strong{font-size:var(--text-sm)}.ttc-template-meta{display:flex;align-items:center;gap:var(--space-2);margin-top:4px;flex-wrap:wrap}.ttc-meta-tag{font-size:.65rem;display:inline-flex;align-items:center;gap:3px;color:var(--color-text-muted)}.ttc-meta-tag.dept{color:var(--color-primary);background:var(--color-brand-light);padding:0 5px;border-radius:3px;font-weight:var(--font-medium)}.ttc-template-actions{display:flex;gap:var(--space-1);padding:var(--space-2);flex-shrink:0}.ttc-checklist-editor{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.ttc-checklist-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border);font-size:var(--text-sm)}.ttc-checklist-num{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-bold);min-width:18px}.ttc-checklist-text{flex:1}.ttc-checklist-add{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary)}.ttc-checklist-add input{flex:1;border:none;background:transparent;font-size:var(--text-sm);font-family:var(--font-family);color:var(--color-text);outline:none}.ttc-checkbox-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);cursor:pointer;-webkit-user-select:none;user-select:none}.ttc-checkbox-label input[type=checkbox]{accent-color:#6366f1;width:16px;height:16px}.jcc-card.virtual-booking{border-left:3px solid var(--color-primary);border-style:dashed;border-left-style:solid}.jcc-booking-status{padding:1px 6px;border-radius:4px;font-size:.6rem;font-weight:600;white-space:nowrap}.jcc-card-room.booking-badge{letter-spacing:.3px}.jcc-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;margin-left:auto}.jcc-view-toggle button{padding:6px 14px;font-size:.78rem;font-weight:500;border:none;background:none;cursor:pointer;color:var(--color-text-muted);transition:all .15s}.jcc-view-toggle button:not(:last-child){border-right:1px solid var(--color-border)}.jcc-view-toggle button.active{background:var(--color-primary);color:#fff}.jcc-list-view{overflow-x:auto}.jcc-list-view table{width:100%;border-collapse:collapse;font-size:.82rem}.jcc-list-view thead th{text-align:left;padding:10px 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);border-bottom:2px solid var(--color-border);font-weight:600;white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer}.jcc-list-view tbody tr{border-bottom:1px solid var(--color-border);transition:background .1s;cursor:pointer}.jcc-list-view tbody tr:hover{background:var(--color-bg-secondary)}.jcc-list-view td{padding:10px 12px;vertical-align:middle}.jcc-list-stage-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.7rem;font-weight:600;white-space:nowrap}.jcc-list-vip{display:inline-flex;align-items:center;gap:2px;color:#f59e0b;font-size:.7rem;font-weight:600}.jcc-list-task-progress{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text-muted)}.jcc-list-task-bar{width:48px;height:4px;background:var(--color-border);border-radius:2px;overflow:hidden}.jcc-list-task-bar-fill{height:100%;border-radius:2px;transition:width .3s}.tasks-page{padding:24px 32px;max-width:1600px;margin:0 auto}.tasks-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px;color:var(--color-text-muted)}.spinner{width:40px;height:40px;border:3px solid rgba(99,102,241,.2);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.tasks-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.tasks-header-left{display:flex;align-items:center;gap:12px}.tasks-header-left svg{color:#6366f1}.tasks-header-left h1{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0}.tasks-count{background:#6366f11a;color:#6366f1;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.btn-new-task{display:flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.btn-new-task:hover{transform:translateY(-1px);box-shadow:0 4px 15px #6366f166}.tasks-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-card{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-icon.pending{background:#6b72801a;color:#6b7280}.stat-icon.progress{background:#3b82f61a;color:#3b82f6}.stat-icon.completed{background:#10b9811a;color:#10b981}.stat-icon.breached{background:#ef44441a;color:#ef4444}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.4rem;font-weight:700;color:var(--color-text)}.stat-label{font-size:.75rem;color:var(--color-text-muted)}.tasks-filters{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;flex:1;min-width:200px}.search-box svg{color:var(--color-text-muted)}.search-box input{background:none;border:none;color:var(--color-text);outline:none;width:100%;font-size:.875rem}.tasks-filters select{padding:8px 12px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.875rem;cursor:pointer}.view-toggle{display:flex;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.view-toggle button{padding:8px 16px;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s}.view-toggle button.active{background:#6366f11a;color:#6366f1}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;min-height:500px}.kanban-column{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.kanban-column-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-top:3px solid #6b7280;font-weight:600;font-size:.85rem;color:var(--color-text)}.column-count{margin-left:auto;background:var(--color-bg-tertiary);padding:2px 8px;border-radius:10px;font-size:.75rem;color:var(--color-text-muted)}.kanban-column-body{flex:1;padding:8px 12px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;max-height:calc(100vh - 350px)}.kanban-empty{text-align:center;padding:24px;color:var(--color-text-muted);font-size:.85rem}.task-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;transition:all .2s;cursor:pointer}.task-card:hover{border-color:#6366f14d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.task-card.sla-breached{border-color:#ef444466;background:#ef44440a}.task-card.sla-warning{border-color:#f59e0b66;background:#f59e0b0a}.task-card-header{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;cursor:pointer}.task-card-priority{width:4px;min-height:24px;border-radius:2px;flex-shrink:0;margin-top:2px}.task-card-info{flex:1;min-width:0}.task-card-info h4{margin:0 0 4px;font-size:.85rem;font-weight:600;color:var(--color-text);line-height:1.3}.task-card-meta{display:flex;flex-wrap:wrap;gap:4px}.meta-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:500}.meta-tag.dept{background:#6366f11a;color:#6366f1}.meta-tag.stage{background:#10b9811a;color:#10b981}.task-card-compact{display:flex;flex-wrap:wrap;gap:8px;padding:0 14px 8px}.compact-info{display:inline-flex;align-items:center;gap:4px;font-size:.73rem;color:var(--color-text-muted)}.compact-info.sla{font-weight:600}.compact-info.sla.sla-ok{color:#10b981}.compact-info.sla.sla-warning{color:#f59e0b}.compact-info.sla.sla-breached{color:#ef4444}.task-card-checklist-progress{display:flex;align-items:center;gap:8px;padding:0 14px 8px;font-size:.7rem;color:var(--color-text-muted)}.progress-bar{flex:1;height:4px;background:var(--color-bg-tertiary);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:2px;transition:width .3s ease}.task-card-action{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px;background:#6366f10a;border:none;border-top:1px solid var(--color-border);color:#6366f1;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s}.task-card-action:hover{background:#6366f11a}.task-card-expanded{padding:12px 14px;border-top:1px solid var(--color-border);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.task-description{font-size:.8rem;color:var(--color-text-secondary);margin:0 0 10px;line-height:1.5}.task-checklist h5{margin:0 0 8px;font-size:.75rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.checklist-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.8rem;color:var(--color-text);cursor:pointer}.checklist-item.completed span{text-decoration:line-through;color:var(--color-text-muted)}.checklist-item input[type=checkbox]{accent-color:#6366f1;width:16px;height:16px}.task-status-controls{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.status-btn{padding:5px 12px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.72rem;cursor:pointer;transition:all .2s}.status-btn:hover{background:#6366f114;border-color:#6366f14d}.tasks-list{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.tasks-list table{width:100%;border-collapse:collapse}.tasks-list th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.tasks-list td{padding:12px 16px;font-size:.85rem;color:var(--color-text);border-bottom:1px solid var(--color-border)}.tasks-list tr:hover td{background:#6366f10a}.sla-breached-row td{background:#ef44440a!important}.selected-row td{background:#6366f114!important}.task-title-cell{display:flex;align-items:center;gap:8px}.task-title-cell strong{font-weight:600}.task-type-badge{padding:2px 6px;background:#6366f11a;color:#6366f1;border-radius:4px;font-size:.65rem;font-weight:500;white-space:nowrap}.priority-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:.75rem;font-weight:600}.sla-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:.73rem;font-weight:600}.sla-badge.sla-ok{color:#10b981;background:#10b9811a}.sla-badge.sla-warning{color:#f59e0b;background:#f59e0b1a}.sla-badge.sla-breached{color:#ef4444;background:#ef44441a}.status-select{padding:4px 8px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.8rem;cursor:pointer}.btn-icon{padding:6px;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:6px}.btn-icon:hover{background:var(--color-bg-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:16px;padding:28px 32px;width:90%;max-width:500px;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content h2{display:flex;align-items:center;gap:8px;margin:0 0 20px;font-size:1.2rem;color:var(--color-text)}.modal-content h2 svg{color:#6366f1}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 14px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.875rem;box-sizing:border-box}.form-group textarea{resize:vertical}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-cancel{padding:10px 20px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text);cursor:pointer;font-weight:500}.btn-primary{padding:10px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:10px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 15px #6366f166}.btn-primary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:1200px){.kanban-board,.tasks-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.tasks-page{padding:16px}.kanban-board{grid-template-columns:1fr}.tasks-stats{grid-template-columns:1fr 1fr}.tasks-filters{flex-direction:column}}.td-page{padding:24px 32px;max-width:1200px;margin:0 auto}.td-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:12px;color:#94a3b8}.td-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px}.td-btn-back{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#475569;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.td-btn-back:hover{background:#f1f5f9;color:#1e293b}.td-breadcrumb-sep{color:#cbd5e1}.td-breadcrumb-current{color:#94a3b8;font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.td-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}@media(max-width:900px){.td-layout{grid-template-columns:1fr}}.td-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px;margin-bottom:16px}.td-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.td-card-header h3{font-size:.9rem;font-weight:600;color:#1e293b;margin:0;display:flex;align-items:center;gap:8px}.td-card-header h3 svg{color:#6366f1}.td-header-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:24px;margin-bottom:16px}.td-header-top{display:flex;gap:16px;margin-bottom:16px}.td-priority-bar{width:4px;border-radius:4px;flex-shrink:0;min-height:48px}.td-header-content{flex:1}.td-title{font-size:1.35rem;font-weight:700;color:#0f172a;margin:0 0 10px;line-height:1.3}.td-meta-tags{display:flex;flex-wrap:wrap;gap:6px}.td-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;white-space:nowrap}.td-type-tag{color:#7c3aed;background:#7c3aed14}.td-dept-tag{color:#0891b2;background:#0891b214}.td-description{padding:14px 16px;background:#f8fafc;border-radius:10px;color:#475569;font-size:.875rem;line-height:1.6;margin-bottom:16px}.td-sla-banner{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-size:.82rem;font-weight:600;margin-bottom:16px}.td-sla-banner.ok{background:#10b98114;color:#059669}.td-sla-banner.warning{background:#f59e0b1a;color:#d97706}.td-sla-banner.breached{background:#ef444414;color:#dc2626;animation:slaPulse 2s ease-in-out infinite}@keyframes slaPulse{0%,to{opacity:1}50%{opacity:.75}}.td-sla-deadline{margin-left:auto;font-weight:500;font-size:.75rem;opacity:.8}.td-actions{display:flex;gap:8px;flex-wrap:wrap}.td-action-primary{display:flex;align-items:center;gap:6px;padding:9px 20px;border:none;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.td-action-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.td-action-primary:disabled{opacity:.6;cursor:not-allowed}.td-action-secondary{display:flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#475569;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.td-action-secondary:hover:not(:disabled){border-color:#f59e0b;color:#d97706;background:#f59e0b0d}.td-action-danger{display:flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid #fecaca;border-radius:10px;background:#ef44440a;color:#dc2626;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.td-action-danger:hover:not(:disabled){background:#ef44441a;border-color:#ef4444}.td-checklist-progress{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:#64748b}.td-progress-bar{width:80px;height:6px;background:#e2e8f0;border-radius:6px;overflow:hidden}.td-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#10b981);border-radius:6px;transition:width .3s}.td-checklist{display:flex;flex-direction:column;gap:2px}.td-checklist-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .1s}.td-checklist-item:hover{background:#f8fafc}.td-checkbox{width:20px;height:20px;border:2px solid #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;margin-top:1px;transition:all .15s}.td-checkbox.checked{background:#6366f1;border-color:#6366f1;color:#fff}.td-checklist-text{display:flex;flex-direction:column;gap:2px;flex:1}.td-checklist-text span:first-child{font-size:.85rem;color:#1e293b;line-height:1.4}.td-checklist-item.completed .td-checklist-text span:first-child{text-decoration:line-through;color:#94a3b8}.td-required-badge{font-size:.65rem;font-weight:600;color:#ef4444;text-transform:uppercase;letter-spacing:.5px}.td-completed-info{font-size:.7rem;color:#94a3b8}.td-notes-input{width:100%;padding:12px 14px;border:1px solid #e2e8f0;border-radius:10px;font-size:.85rem;color:#1e293b;font-family:inherit;resize:vertical;min-height:80px;outline:none;transition:border-color .15s;background:#fff}.td-notes-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.td-save-notes{display:flex;align-items:center;gap:6px;margin-top:10px;padding:7px 16px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.td-save-notes:hover:not(:disabled){background:#4f46e5}.td-save-notes:disabled{opacity:.6;cursor:not-allowed}.td-sidebar-title{font-size:.85rem;font-weight:600;color:#1e293b;margin:0 0 14px;display:flex;align-items:center;gap:6px}.td-sidebar-title svg{color:#6366f1}.td-info-grid{display:flex;flex-direction:column;gap:14px}.td-info-item{display:flex;flex-direction:column;gap:3px}.td-info-label{display:flex;align-items:center;gap:5px;font-size:.72rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.td-info-label svg{color:#94a3b8}.td-info-value{font-size:.85rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:6px}.td-info-link{font-size:.85rem;font-weight:600;color:#6366f1;text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .15s}.td-info-link:hover{color:#4f46e5;text-decoration:underline}.td-vip-badge{font-size:.6rem;font-weight:700;padding:1px 6px;border-radius:4px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;text-transform:uppercase;letter-spacing:.5px}.td-room-code{font-size:.72rem;color:#94a3b8;font-weight:400}.td-stage-value{color:#7c3aed}.td-sr-card{border-color:#fed7aa;background:#ffedd54d}.td-sr-link{display:block;text-decoration:none;padding:12px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;transition:all .15s}.td-sr-link:hover{border-color:#6366f1;box-shadow:0 2px 8px #6366f11a}.td-sr-number{font-size:.78rem;font-weight:700;color:#6366f1;font-family:SF Mono,JetBrains Mono,monospace;margin-bottom:4px}.td-sr-subject{font-size:.85rem;font-weight:600;color:#1e293b;margin-bottom:8px}.td-sr-meta{display:flex;align-items:center;gap:8px}.td-sr-status{font-size:.68rem;font-weight:600;padding:2px 8px;border-radius:10px}.td-sr-status.open{color:#3b82f6;background:#3b82f61a}.td-sr-status.inprogress{color:#f59e0b;background:#f59e0b1a}.td-sr-status.resolved{color:#10b981;background:#10b9811a}.td-sr-status.closed{color:#6b7280;background:#6b72801a}.td-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:16px}.td-timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:2px;background:#e2e8f0;border-radius:2px}.td-timeline-item{display:flex;align-items:flex-start;gap:12px;padding:8px 0;position:relative}.td-timeline-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px;position:relative;left:-16px;z-index:1}.td-timeline-dot.created{background:#6b7280}.td-timeline-dot.started{background:#3b82f6}.td-timeline-dot.breached{background:#ef4444}.td-timeline-dot.completed{background:#10b981}.td-timeline-content{display:flex;flex-direction:column;gap:1px;margin-left:-12px}.td-timeline-label{font-size:.8rem;font-weight:600;color:#1e293b}.td-timeline-time{font-size:.72rem;color:#94a3b8}.mt-page{padding:24px 32px;max-width:1100px;margin:0 auto}.mt-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:12px;color:#94a3b8}.mt-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.mt-header-left{display:flex;align-items:center;gap:12px}.mt-header-left svg{color:#6366f1}.mt-header-left h1{font-size:1.4rem;font-weight:700;color:#0f172a;margin:0}.mt-subtitle{font-size:.82rem;color:#94a3b8;margin:2px 0 0}.mt-subtitle strong{color:#6366f1}.mt-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.mt-summary-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;transition:all .15s}.mt-summary-card svg{color:#94a3b8;flex-shrink:0}.mt-summary-card.alert{border-color:#fecaca;background:#ef444408}.mt-summary-card.alert svg{color:#ef4444}.mt-summary-count{display:block;font-size:1.3rem;font-weight:700;color:#0f172a;line-height:1}.mt-summary-card.alert .mt-summary-count{color:#ef4444}.mt-summary-label{display:block;font-size:.72rem;color:#94a3b8;font-weight:500;margin-top:2px}.mt-filters{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.mt-search-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex:1;min-width:200px;max-width:340px;transition:border-color .15s}.mt-search-wrap:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f10f}.mt-search-wrap svg{color:#94a3b8;flex-shrink:0}.mt-search-wrap input{border:none;outline:none;font-size:.85rem;color:#1e293b;width:100%;background:transparent}.mt-filter-group{display:flex;align-items:center;gap:8px}.mt-select-wrap{display:flex;align-items:center;gap:6px;padding:7px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;position:relative}.mt-select-wrap svg{color:#94a3b8;flex-shrink:0}.mt-select-wrap select{border:none;outline:none;font-size:.82rem;color:#475569;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:4px}.mt-show-completed{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#64748b;cursor:pointer;padding:7px 12px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;white-space:nowrap}.mt-show-completed input{accent-color:#6366f1}.mt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:10px;color:#94a3b8}.mt-empty h3{font-size:1.1rem;color:#64748b;margin:0}.mt-empty p{font-size:.85rem;margin:0}.mt-empty svg{color:#10b981;margin-bottom:4px}.mt-list{display:flex;flex-direction:column;gap:4px}.mt-section-divider{padding:14px 0 6px;display:flex;align-items:center;gap:12px}.mt-section-divider span{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.mt-section-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.mt-task-row{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:all .15s}.mt-task-row:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #6366f10f}.mt-task-row.sla-breached{border-left:3px solid #ef4444}.mt-task-row.sla-warning{border-left:3px solid #f59e0b}.mt-task-row.completed{opacity:.65}.mt-task-main{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer}.mt-task-priority{width:4px;height:36px;border-radius:4px;flex-shrink:0}.mt-task-status-icon{flex-shrink:0}.mt-task-content{flex:1;min-width:0}.mt-task-title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.mt-task-title{font-size:.9rem;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mt-task-row.completed .mt-task-title{text-decoration:line-through;color:#94a3b8}.mt-task-badges{display:flex;gap:4px;flex-shrink:0}.mt-badge{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:10px;white-space:nowrap;display:inline-flex;align-items:center;gap:3px}.mt-badge.dept{color:#0891b2;background:#0891b214}.mt-badge.stage{color:#7c3aed;background:#7c3aed14}.mt-task-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.mt-meta-item{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#94a3b8}.mt-meta-item svg{color:#94a3b8}.mt-sla-breached{color:#ef4444!important;font-weight:600}.mt-sla-breached svg{color:#ef4444!important}.mt-sla-warning{color:#d97706!important;font-weight:600}.mt-sla-warning svg{color:#d97706!important}.mt-sla-ok{color:#059669!important}.mt-task-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.mt-quick-action{display:flex;align-items:center;gap:5px;padding:6px 14px;border:none;border-radius:8px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.mt-quick-action:hover{transform:translateY(-1px);box-shadow:0 3px 10px #6366f14d}.mt-open-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid #e2e8f0;color:#94a3b8;text-decoration:none;transition:all .15s}.mt-open-btn:hover{border-color:#6366f1;color:#6366f1;background:#6366f10a}.mt-task-expanded{padding:0 16px 14px 44px;border-top:1px solid #f1f5f9}.mt-expanded-progress{display:flex;align-items:center;gap:10px;padding:10px 0 8px;font-size:.75rem;color:#64748b;font-weight:500}.mt-progress-bar{flex:1;height:5px;background:#e2e8f0;border-radius:5px;overflow:hidden;max-width:200px}.mt-progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#10b981);border-radius:5px;transition:width .3s}.mt-checklist{display:flex;flex-direction:column;gap:2px}.mt-checklist-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:.82rem;color:#1e293b;transition:background .1s}.mt-checklist-item:hover{background:#f8fafc}.mt-checklist-item.done span:first-of-type{text-decoration:line-through;color:#94a3b8}.mt-checklist-item input[type=checkbox]{accent-color:#6366f1;width:16px;height:16px}.mt-required{font-size:.6rem;font-weight:700;color:#ef4444;text-transform:uppercase;letter-spacing:.5px;margin-left:auto}@media(max-width:768px){.mt-summary{grid-template-columns:repeat(2,1fr)}.mt-filters{flex-direction:column;align-items:stretch}.mt-search-wrap{max-width:none}.mt-filter-group{flex-wrap:wrap}.mt-task-badges{display:none}}.hk-page{padding:24px 32px;max-width:1600px;margin:0 auto}.hk-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px;color:var(--color-text-muted)}.hk-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.hk-header-left{display:flex;align-items:center;gap:12px}.hk-header-left svg{color:#10b981}.hk-header-left h1{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0}.btn-refresh{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.85rem;cursor:pointer;transition:all .2s}.btn-refresh:hover{background:var(--color-bg-card-hover)}.hk-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}.hk-summary-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;transition:all .2s;color:var(--accent)}.hk-summary-card:hover{border-color:var(--accent);transform:translateY(-1px)}.hk-summary-card.active{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 20px var(--accent-bg)}.summary-info{display:flex;flex-direction:column}.summary-count{font-size:1.4rem;font-weight:700}.summary-label{font-size:.75rem;opacity:.8}.hk-filters{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.hk-filters .search-box{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;min-width:200px}.hk-filters .search-box svg{color:var(--color-text-muted)}.hk-filters .search-box input{background:none;border:none;color:var(--color-text);outline:none;width:100%;font-size:.875rem}.hk-filters select{padding:8px 12px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-size:.875rem;cursor:pointer}.bulk-actions{display:flex;align-items:center;gap:8px;margin-left:auto;padding:6px 12px;background:#6366f10f;border:1px solid rgba(99,102,241,.2);border-radius:10px}.bulk-count{font-size:.8rem;font-weight:600;color:#6366f1;margin-right:4px}.bulk-btn{padding:4px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:.72rem;font-weight:600;cursor:pointer;background:var(--color-bg-tertiary);transition:all .2s}.bulk-btn.dirty{color:#ef4444;border-color:#ef44444d}.bulk-btn.dirty:hover{background:#ef444414}.bulk-btn.cleaning{color:#f59e0b;border-color:#f59e0b4d}.bulk-btn.cleaning:hover{background:#f59e0b14}.bulk-btn.clean{color:#10b981;border-color:#10b9814d}.bulk-btn.clean:hover{background:#10b98114}.bulk-btn.inspected{color:#6366f1;border-color:#6366f14d}.bulk-btn.inspected:hover{background:#6366f114}.bulk-btn.cancel{color:var(--color-text-muted)}.hk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.hk-room-card{position:relative;padding:14px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;transition:all .2s;border-left:3px solid var(--room-accent, #6b7280)}.hk-room-card:hover{border-color:var(--room-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.hk-room-card.selected{border-color:#6366f1;background:#6366f10d}.hk-room-card.departure{box-shadow:inset 0 0 0 1px #f59e0b33}.room-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.room-code{font-size:1.1rem;font-weight:700;color:var(--color-text)}.room-hk-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:.65rem;font-weight:600}.room-type{font-size:.73rem;color:var(--color-text-muted);margin-bottom:6px}.room-guest{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text);margin-bottom:4px}.room-guest svg{color:#3b82f6}.departure-badge{padding:1px 5px;background:#f59e0b1a;color:#f59e0b;border-radius:4px;font-size:.6rem;font-weight:700;letter-spacing:.5px}.room-floor{display:flex;align-items:center;gap:4px;font-size:.65rem;color:var(--color-text-muted);margin-bottom:6px}.room-actions{margin-top:8px}.action-btn{display:flex;align-items:center;gap:4px;width:100%;padding:6px 0;background:none;border:1px solid var(--color-border);border-radius:6px;font-size:.72rem;font-weight:600;cursor:pointer;justify-content:center;transition:all .2s}.action-btn.cleaning{color:#f59e0b;border-color:#f59e0b33}.action-btn.cleaning:hover{background:#f59e0b14}.action-btn.clean{color:#10b981;border-color:#10b98133}.action-btn.clean:hover{background:#10b98114}.action-btn.inspected{color:#6366f1;border-color:#6366f133}.action-btn.inspected:hover{background:#6366f114}.action-ready{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.72rem;color:#10b981;font-weight:600;padding:4px 0}.selected-overlay{position:absolute;top:8px;right:8px;color:#6366f1}.hk-empty{text-align:center;padding:40px;color:var(--color-text-muted)}@media(max-width:1200px){.hk-summary{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.hk-page{padding:16px}.hk-summary{grid-template-columns:repeat(2,1fr)}.hk-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.sr-page{padding:24px 32px;max-width:1440px;margin:0 auto}.sr-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.sr-header-left{display:flex;align-items:center;gap:12px}.sr-header-left svg{color:#e11d48}.sr-header-left h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.sr-count{background:#e11d481a;color:#e11d48;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.btn-new-sr{display:flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,#e11d48,#be123c);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;font-size:.875rem;transition:all .2s;box-shadow:0 2px 8px #e11d4840}.btn-new-sr:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e11d4859}.sr-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:16px;color:#94a3b8}.sr-pill-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;border-radius:12px;margin-bottom:20px;overflow-x:auto}.sr-pill{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;font-size:.82rem;font-weight:500;border-radius:20px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;white-space:nowrap;transition:all .15s ease}.sr-pill:hover{border-color:#6366f1;color:#6366f1}.sr-pill.active{background:#6366f1;color:#fff;border-color:#6366f1;font-weight:600;box-shadow:0 2px 6px #6366f140}.sr-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.sr-search-box{position:relative;flex:1;min-width:200px}.sr-search-box svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.sr-search-box input{width:100%;padding:10px 12px 10px 38px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1e293b;font-size:.875rem}.sr-search-box input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sr-filter-select{padding:10px 14px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1e293b;font-size:.875rem;cursor:pointer;min-width:130px}.sr-filter-select:focus{outline:none;border-color:#6366f1}.sr-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.sr-table{width:100%;border-collapse:collapse}.sr-table th{text-align:left;padding:12px 16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;background:#f8fafc;border-bottom:1px solid #e2e8f0}.sr-table td{padding:14px 16px;font-size:.875rem;color:#1e293b;border-bottom:1px solid #f1f5f9;vertical-align:middle}.sr-table tr:last-child td{border-bottom:none}.sr-table tr{cursor:pointer;transition:background .15s}.sr-table tbody tr:hover{background:#6366f10a}.sr-number{font-family:SF Mono,Fira Code,monospace;font-size:.8rem;color:#6366f1;font-weight:600}.sr-guest-info{display:flex;flex-direction:column;gap:2px}.sr-guest-name{font-weight:600;color:#1e293b}.sr-guest-room{font-size:.75rem;color:#94a3b8}.sr-subject{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.sr-status-badge.open{background:#3b82f61f;color:#2563eb}.sr-status-badge.in-progress{background:#f59e0b1f;color:#d97706}.sr-status-badge.pending-guest{background:#8b5cf61f;color:#7c3aed}.sr-status-badge.resolved{background:#10b9811f;color:#059669}.sr-status-badge.closed{background:#6b72801f;color:#6b7280}.sr-priority-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase}.sr-priority-badge.critical{background:#ef44441f;color:#dc2626}.sr-priority-badge.high{background:#f973161f;color:#ea580c}.sr-priority-badge.medium{background:#3b82f61f;color:#2563eb}.sr-priority-badge.low{background:#6b72801f;color:#6b7280}.sr-category-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:500;background:#6366f114;color:#475569}.sr-time-ago{font-size:.8rem;color:#94a3b8;white-space:nowrap}.sr-sla-indicator{display:flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600}.sr-sla-indicator.ok{color:#10b981}.sr-sla-indicator.warning{color:#f59e0b}.sr-sla-indicator.breached{color:#ef4444}.sr-empty{text-align:center;padding:60px 20px;color:#94a3b8}.sr-empty svg{color:#cbd5e1;margin-bottom:12px}.sr-empty h3{margin:0 0 6px;font-size:1.1rem;color:#475569}.sr-empty p{font-size:.875rem;margin:0}.sr-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.sr-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #0000004d;animation:srModalIn .2s ease-out}@keyframes srModalIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.sr-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e2e8f0}.sr-modal-header-left{display:flex;flex-direction:column;gap:8px}.sr-modal-sr-number{font-family:SF Mono,Fira Code,monospace;font-size:.85rem;color:#6366f1;font-weight:600}.sr-modal-header h2{margin:0;font-size:1.2rem;font-weight:700;color:#1e293b}.sr-modal-badges{display:flex;gap:8px;flex-wrap:wrap}.sr-modal-close{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:8px;transition:all .15s}.sr-modal-close:hover{background:#f1f5f9;color:#1e293b}.sr-modal-body{padding:20px 24px}.sr-modal-section{margin-bottom:20px}.sr-modal-section h4{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#94a3b8;margin:0 0 10px}.sr-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.sr-detail-item{display:flex;flex-direction:column;gap:3px}.sr-detail-item.full-width{grid-column:1 / -1}.sr-detail-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8}.sr-detail-value{font-size:.875rem;color:#1e293b;font-weight:500}.sr-description-block{background:#f8fafc;border-radius:10px;padding:14px 16px;font-size:.875rem;color:#475569;line-height:1.5;white-space:pre-wrap}.sr-task-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.sr-task-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sr-task-title{font-weight:600;font-size:.875rem;color:#1e293b}.sr-task-status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:6px;font-size:.7rem;font-weight:600}.sr-task-status.pending{background:#6b72801f;color:#6b7280}.sr-task-status.inprogress{background:#3b82f61f;color:#2563eb}.sr-task-status.completed{background:#10b9811f;color:#059669}.sr-task-status.cancelled{background:#ef44441f;color:#dc2626}.sr-task-meta{display:flex;gap:16px;font-size:.8rem;color:#94a3b8}.sr-task-meta span{display:flex;align-items:center;gap:4px}.sr-modal-actions{padding:16px 24px;border-top:1px solid #e2e8f0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sr-action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#1e293b;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.sr-action-btn:hover{border-color:#6366f1;background:#6366f10a}.sr-action-btn.primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:transparent}.sr-action-btn.primary:hover{box-shadow:0 2px 8px #10b9814d}.sr-action-btn.danger{color:#ef4444;border-color:#ef44444d}.sr-action-btn.danger:hover{background:#ef44440f}.sr-rating{display:flex;align-items:center;gap:2px}.sr-rating-star{color:#d1d5db;transition:color .15s}.sr-rating-star.filled{color:#f59e0b}.sr-guest-search-wrapper{position:relative}.sr-guest-search-input{position:relative;display:flex;align-items:center}.sr-guest-search-input svg{position:absolute;left:12px;color:#94a3b8;pointer-events:none}.sr-guest-search-input input{width:100%;padding:10px 14px 10px 38px;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#1e293b;font-size:.875rem;outline:none;transition:border-color .15s}.sr-guest-search-input input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sr-guest-results{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f;max-height:220px;overflow-y:auto;z-index:10}.sr-guest-result-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;transition:background .1s;border-bottom:1px solid #f1f5f9}.sr-guest-result-item:last-child{border-bottom:none}.sr-guest-result-item:hover{background:#f0f0ff}.sr-guest-result-name{font-size:.875rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:6px}.sr-guest-result-room{font-size:.75rem;color:#64748b;font-weight:500;background:#f1f5f9;padding:2px 8px;border-radius:6px;white-space:nowrap}.sr-guest-result-empty{padding:16px;text-align:center;font-size:.85rem;color:#94a3b8}.sr-vip-tag{font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:4px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;text-transform:uppercase;letter-spacing:.5px}.sr-guest-selected{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f0f0ff;border:1px solid #c7d2fe;border-radius:10px}.sr-guest-selected-info{display:flex;flex-direction:column;gap:2px}.sr-guest-selected-name{font-weight:600;font-size:.9rem;color:#1e293b;display:flex;align-items:center;gap:6px}.sr-guest-selected-room{font-size:.8rem;color:#6366f1;font-weight:500}.sr-guest-clear{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:6px;transition:all .15s}.sr-guest-clear:hover{background:#e2e8f0;color:#1e293b}.sr-common-subjects{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;max-height:140px;overflow-y:auto;padding:2px 0}.sr-common-subject-chip{padding:5px 12px;border:1px solid #e2e8f0;border-radius:20px;background:#f8fafc;color:#475569;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.sr-common-subject-chip:hover{border-color:#6366f1;background:#f0f0ff;color:#4338ca}.sr-common-subject-chip.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 1px 4px #6366f140}.rp-page{padding:28px 32px;max-width:1400px;margin:0 auto}.rp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.rp-header-left{display:flex;align-items:center;gap:12px}.rp-header-left svg{color:var(--primary, #6366f1);background:#6366f11a;padding:8px;border-radius:10px;width:38px;height:38px}.rp-header h1{font-size:1.35rem;font-weight:700;color:var(--text, #1e293b);margin:0}.rp-subtitle{font-size:.82rem;color:var(--text-secondary, #64748b);margin:0}.rp-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--primary, #6366f1);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.rp-btn-primary:hover{background:#4f46e5}.rp-btn-primary:disabled{opacity:.5;cursor:default}.rp-btn-secondary{padding:9px 18px;background:transparent;color:var(--text-secondary, #64748b);border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer}.rp-btn-secondary:hover{background:var(--bg-hover, #f8fafc)}.rp-filters{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap}.rp-search-wrap{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:8px;flex:1;min-width:200px}.rp-search-wrap svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.rp-search-wrap input{border:none;outline:none;width:100%;font-size:.85rem;background:transparent;color:var(--text, #1e293b)}.rp-dropdown{position:relative}.rp-dropdown-trigger{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:8px;cursor:pointer;white-space:nowrap;font-size:.82rem;color:var(--text, #1e293b);transition:border-color .15s}.rp-dropdown-trigger:hover,.rp-dropdown.open .rp-dropdown-trigger{border-color:var(--primary, #6366f1)}.rp-dropdown-trigger svg:first-child{color:var(--text-secondary, #94a3b8);flex-shrink:0}.rp-dropdown-trigger svg:last-child{color:var(--text-secondary, #94a3b8);flex-shrink:0;margin-left:4px;transition:transform .2s}.rp-dropdown.open .rp-dropdown-trigger svg:last-child{transform:rotate(180deg)}.rp-dropdown-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.rp-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:100%;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:10px;box-shadow:0 8px 24px #0000001a;padding:4px;z-index:100;animation:rp-dropdown-in .12s ease-out}@keyframes rp-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.rp-dropdown-item{display:block;width:100%;padding:7px 12px;font-size:.82rem;color:var(--text, #1e293b);background:none;border:none;border-radius:6px;cursor:pointer;text-align:left;white-space:nowrap;transition:background .1s}.rp-dropdown-item:hover{background:var(--bg-hover, #f1f5f9)}.rp-dropdown-item.active{background:#6366f114;color:var(--primary, #6366f1);font-weight:600}.rp-loading,.rp-empty{text-align:center;padding:60px 20px;color:var(--text-secondary, #64748b)}.rp-loading p,.rp-empty p{margin:8px 0;font-size:.9rem}.rp-empty h3{font-size:1.1rem;color:var(--text, #1e293b);margin:12px 0 4px}.rp-empty svg{color:var(--text-secondary, #94a3b8)}.rp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(370px,1fr));gap:16px}.rp-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:18px 20px;transition:box-shadow .15s,border-color .15s}.rp-card:hover{border-color:var(--primary, #6366f1);box-shadow:0 2px 12px #6366f114}.rp-card.inactive{opacity:.55}.rp-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.rp-card-title-row{display:flex;align-items:center;gap:8px}.rp-card-code{font-size:.7rem;font-weight:700;background:#6366f11a;color:var(--primary, #6366f1);padding:2px 8px;border-radius:4px;letter-spacing:.5px}.rp-card h3{font-size:.95rem;font-weight:600;color:var(--text, #1e293b);margin:0}.rp-card-actions{display:flex;gap:2px}.rp-icon-btn{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:6px;color:var(--text-secondary, #64748b);transition:all .15s}.rp-icon-btn:hover{background:var(--bg-hover, #f1f5f9);color:var(--primary, #6366f1)}.rp-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}.rp-card-rate{display:flex;align-items:baseline;gap:2px;margin-bottom:14px}.rp-card-currency{font-size:1rem;font-weight:600;color:var(--text-secondary, #64748b)}.rp-card-amount{font-size:1.6rem;font-weight:800;color:var(--text, #1e293b);letter-spacing:-.5px}.rp-card-per{font-size:.78rem;color:var(--text-secondary, #94a3b8);margin-left:2px}.rp-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.rp-card-tag{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:500;padding:3px 8px;border-radius:5px;background:var(--bg-hover, #f1f5f9);color:var(--text-secondary, #64748b)}.rp-card-tag.room{background:#3b82f614;color:#3b82f6}.rp-card-tag.meal{background:#f59e0b14;color:#d97706}.rp-card-tag.cancel{background:#10b98114;color:#059669}.rp-card-tag.private{background:#ef444414;color:#ef4444}.rp-card-supplements{display:flex;flex-wrap:wrap;gap:10px;font-size:.75rem;color:var(--text-secondary, #64748b);padding-top:8px;border-top:1px solid var(--border, #f1f5f9);margin-top:8px}.rp-card-dow,.rp-card-seasons,.rp-card-los{display:flex;align-items:center;flex-wrap:wrap;gap:5px;font-size:.72rem;color:var(--text-secondary, #64748b);padding-top:8px;border-top:1px solid var(--border, #f1f5f9);margin-top:8px}.rp-card-dow svg,.rp-card-seasons svg,.rp-card-los svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.rp-dow-chip{background:#6366f10f;padding:2px 7px;border-radius:4px;font-weight:500}.rp-season-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;border:1px solid;font-weight:500;background:#6366f10a}.rp-season-dot-sm{width:6px;height:6px;border-radius:50%;flex-shrink:0}.rp-los-chip{background:#10b9810f;padding:2px 7px;border-radius:4px;font-weight:500;color:#059669}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center}.modal-content{background:var(--bg-card, #fff);border-radius:16px;box-shadow:0 20px 60px #00000026;max-height:90vh;overflow-y:auto}.rp-modal{width:600px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column}.rp-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.rp-modal-header h2{font-size:1.15rem;font-weight:700;margin:0;color:var(--text, #1e293b)}.rp-modal-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--text-secondary, #64748b)}.rp-modal-close:hover{background:var(--bg-hover, #f1f5f9)}.rp-modal-tabs{display:flex;gap:2px;padding:14px 24px 0;border-bottom:1px solid var(--border, #e2e8f0)}.rp-tab{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-size:.82rem;font-weight:500;border:none;background:none;cursor:pointer;color:var(--text-secondary, #64748b);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.rp-tab.active{color:var(--primary, #6366f1);border-bottom-color:var(--primary, #6366f1)}.rp-tab:hover{color:var(--text, #1e293b)}.rp-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.rp-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border, #e2e8f0)}.rp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.rp-field{display:flex;flex-direction:column;gap:4px}.rp-field.full{grid-column:1/-1}.rp-field label{font-size:.78rem;font-weight:600;color:var(--text-secondary, #64748b)}.rp-field input,.rp-field select{padding:8px 10px;border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;color:var(--text, #1e293b);background:var(--bg, #fff);transition:border-color .15s}.rp-field input:focus,.rp-field select:focus{border-color:var(--primary, #6366f1);outline:none}.rp-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem!important;font-weight:500!important;color:var(--text, #1e293b)!important;margin-top:18px}.rp-section{margin-bottom:24px}.rp-section h4{display:flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600;color:var(--text, #1e293b);margin:0 0 4px}.rp-help{font-size:.76rem;color:var(--text-secondary, #94a3b8);margin:0 0 12px}.rp-dow-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.rp-dow-item{display:flex;flex-direction:column;gap:3px}.rp-dow-item label{font-size:.72rem;font-weight:600;color:var(--text-secondary, #64748b);text-align:center}.rp-dow-item input{padding:6px 4px;border:1px solid var(--border, #e2e8f0);border-radius:6px;font-size:.8rem;text-align:center;width:100%;background:var(--bg, #fff);color:var(--text, #1e293b)}.rp-dow-item input:focus{border-color:var(--primary, #6366f1);outline:none}.rp-los-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.82rem;color:var(--text-secondary, #64748b)}.rp-los-row input{width:60px;padding:5px 8px;border:1px solid var(--border, #e2e8f0);border-radius:6px;font-size:.82rem;text-align:center;color:var(--text, #1e293b);background:var(--bg, #fff)}.rp-los-row input:focus{border-color:var(--primary, #6366f1);outline:none}.rp-los-remove{background:none;border:none;cursor:pointer;color:#ef4444;padding:2px}.rp-add-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;font-size:.78rem;font-weight:500;border:1px dashed var(--border, #cbd5e1);border-radius:6px;background:none;color:var(--text-secondary, #64748b);cursor:pointer}.rp-add-btn:hover{background:var(--bg-hover, #f8fafc);color:var(--primary, #6366f1);border-color:var(--primary, #6366f1)}.rp-no-seasons{text-align:center;padding:30px 20px;color:var(--text-secondary, #94a3b8)}.rp-no-seasons svg{margin-bottom:8px}.rp-season-list{display:flex;flex-direction:column;gap:10px}.rp-season-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--bg-hover, #f8fafc);border-radius:8px}.rp-season-info{display:flex;align-items:center;gap:8px}.rp-season-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.rp-season-info strong{font-size:.85rem;color:var(--text, #1e293b);display:block}.rp-season-dates{font-size:.72rem;color:var(--text-secondary, #94a3b8)}.rp-season-rate-input{display:flex;align-items:center;gap:4px;font-size:.85rem;color:var(--text-secondary, #64748b)}.rp-season-rate-input input{width:100px;padding:5px 8px;border:1px solid var(--border, #e2e8f0);border-radius:6px;font-size:.85rem;text-align:right;color:var(--text, #1e293b);background:var(--bg, #fff)}.rp-season-rate-input input:focus{border-color:var(--primary, #6366f1);outline:none}@media(max-width:768px){.rp-page{padding:16px}.rp-grid,.rp-form-grid{grid-template-columns:1fr}.rp-dow-grid{grid-template-columns:repeat(4,1fr)}.rp-modal{width:95vw}}.rpd-page{padding:32px;max-width:1100px;margin:0 auto}.rpd-back{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--color-text-secondary);text-decoration:none;margin-bottom:16px;cursor:pointer;transition:color .15s}.rpd-back:hover{color:var(--color-brand, #04adef)}.rpd-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:28px}.rpd-header h1{font-size:1.5rem;font-weight:700;color:var(--color-text);display:flex;align-items:center;gap:10px}.rpd-header .rpd-code{font-size:.78rem;font-weight:600;background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary);padding:3px 10px;border-radius:6px;letter-spacing:.5px}.rpd-header-meta{display:flex;gap:8px;flex-wrap:wrap}.rpd-meta-badge{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:8px;font-size:.78rem;font-weight:500;background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-secondary)}.rpd-meta-badge.active{background:var(--color-success-soft, #ecfdf5);color:var(--color-success, #10b981)}.rpd-meta-badge.inactive{background:var(--color-danger-soft, #fef2f2);color:var(--color-danger, #ef4444)}.rpd-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border, #e2e8f0);margin-bottom:24px}.rpd-tab{padding:10px 20px;font-size:.84rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;border:none;background:none;position:relative;transition:all .15s}.rpd-tab:hover{color:var(--color-text)}.rpd-tab.active{color:var(--color-brand, #04adef)}.rpd-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--color-brand, #04adef);border-radius:2px 2px 0 0}.rpd-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.rpd-stat-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #0000000a}.rpd-stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted, #94a3b8);margin-bottom:6px}.rpd-stat-value{font-size:1.3rem;font-weight:700;color:var(--color-text)}.rpd-section-title{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.rpd-tiers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:28px}.rpd-tier-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:16px;transition:all .15s;box-shadow:0 1px 3px #0000000a}.rpd-tier-card:hover{border-color:var(--color-brand, #04adef)}.rpd-tier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.rpd-tier-season{font-weight:600;font-size:.88rem;color:var(--color-text);display:flex;align-items:center;gap:6px}.rpd-tier-dot{width:8px;height:8px;border-radius:50%}.rpd-tier-rate{font-size:1.1rem;font-weight:700;color:var(--color-brand, #04adef)}.rpd-tier-details{display:flex;flex-direction:column;gap:4px}.rpd-tier-detail{display:flex;justify-content:space-between;font-size:.78rem;color:var(--color-text-secondary)}.rpd-tier-detail .val{font-weight:600;color:var(--color-text)}.rpd-tier-dates{font-size:.72rem;color:var(--color-text-muted);margin-top:6px}.rpd-restrictions-table{width:100%;border-collapse:collapse;margin-bottom:24px}.rpd-restrictions-table th{background:var(--color-bg-tertiary, #f1f5f9);padding:8px 14px;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);text-align:left;border-bottom:1px solid var(--color-border, #e2e8f0)}.rpd-restrictions-table td{padding:10px 14px;font-size:.82rem;border-bottom:1px solid var(--color-border, #e2e8f0);color:var(--color-text)}.rpd-restriction-type{font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:.72rem;text-transform:uppercase;letter-spacing:.3px}.rpd-restriction-type.stopSell{background:#fef2f2;color:#ef4444}.rpd-restriction-type.CTA,.rpd-restriction-type.CTD{background:#fffbeb;color:#f59e0b}.rpd-restriction-type.minLOS,.rpd-restriction-type.maxLOS{background:#e8f7fe;color:#04adef}.rpd-restriction-type.bookingWindow{background:#f0fdf4;color:#22c55e}.rpd-restriction-val{font-weight:600;font-variant-numeric:tabular-nums}.rpd-restriction-dates{font-size:.78rem;color:var(--color-text-secondary)}.rpd-actions-bar{display:flex;gap:8px;justify-content:flex-end;margin-bottom:16px}.rpd-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay, rgba(15, 23, 42, .5));z-index:1000;display:flex;align-items:center;justify-content:center}.rpd-modal{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:28px;width:480px;max-width:90vw;box-shadow:0 20px 60px #00000026;max-height:80vh;overflow-y:auto}.rpd-modal h2{font-size:1.1rem;font-weight:700;color:var(--color-text);margin-bottom:20px}.rpd-form-group{margin-bottom:16px}.rpd-form-group label{display:block;font-size:.78rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px}.rpd-form-group input,.rpd-form-group select{width:100%;padding:8px 12px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.84rem;background:var(--color-bg-card, #fff);color:var(--color-text);transition:border-color .15s}.rpd-form-group input:focus,.rpd-form-group select:focus{outline:none;border-color:var(--color-brand, #04adef)}.rpd-form-row{display:flex;gap:12px}.rpd-form-row .rpd-form-group{flex:1}.rpd-modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.rpd-cp-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000000a}.rpd-cp-name{font-weight:600;font-size:.92rem;color:var(--color-text);margin-bottom:4px}.rpd-cp-desc{font-size:.82rem;color:var(--color-text-secondary);margin-bottom:12px}.rpd-cp-rules{display:flex;flex-direction:column;gap:6px}.rpd-cp-rule{display:flex;justify-content:space-between;font-size:.78rem;background:var(--color-bg-tertiary, #f1f5f9);padding:6px 12px;border-radius:6px}.rpd-cp-rule .label{color:var(--color-text-secondary)}.rpd-cp-rule .val{font-weight:600;color:var(--color-text)}.rpd-btn{padding:8px 18px;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid var(--color-border, #e2e8f0);background:var(--color-bg-card, #fff);color:var(--color-text);display:inline-flex;align-items:center;gap:6px;transition:all .15s}.rpd-btn:hover{border-color:var(--color-brand, #04adef)}.rpd-btn.primary{background:var(--color-brand-gradient, linear-gradient(135deg, #04adef, #0295d6));color:#fff;border:none}.rpd-btn.primary:hover{opacity:.9}.rpd-btn.danger{color:var(--color-danger, #ef4444)}.rpd-btn.danger:hover{background:var(--color-danger-soft, #fef2f2);border-color:var(--color-danger, #ef4444)}.rpd-empty{text-align:center;padding:32px;color:var(--color-text-secondary);font-size:.88rem}.rpd-loading{text-align:center;padding:48px;color:var(--color-text-secondary)}.rpd-dow-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:24px}.rpd-dow-cell{text-align:center;padding:8px 4px;border-radius:8px;background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0)}.rpd-dow-cell .day{font-size:.68rem;text-transform:uppercase;color:var(--color-text-muted);letter-spacing:.3px}.rpd-dow-cell .rate{font-size:.88rem;font-weight:700;color:var(--color-text);margin-top:2px}.rpd-dow-cell .rate.override{color:var(--color-brand, #04adef)}.rpd-los-list{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.rpd-los-badge{padding:6px 14px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:20px;font-size:.78rem;font-weight:600;color:var(--color-text)}.rpd-los-badge .pct{color:var(--color-success, #10b981)}.rs-page{padding:28px 32px;max-width:1200px;margin:0 auto}.rs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.rs-header-left{display:flex;align-items:center;gap:12px}.rs-header-left>svg{color:#f59e0b;background:#f59e0b1a;padding:8px;border-radius:10px;width:38px;height:38px}.rs-header h1{font-size:1.35rem;font-weight:700;color:var(--text, #1e293b);margin:0}.rs-subtitle{font-size:.82rem;color:var(--text-secondary, #64748b);margin:0}.rs-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--primary, #6366f1);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.rs-btn-primary:hover{background:#4f46e5}.rs-btn-primary:disabled{opacity:.5;cursor:default}.rs-btn-secondary{padding:9px 18px;background:transparent;color:var(--text-secondary, #64748b);border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer}.rs-btn-secondary:hover{background:var(--bg-hover, #f8fafc)}.rs-loading,.rs-empty{text-align:center;padding:60px 20px;color:var(--text-secondary, #64748b)}.rs-loading p,.rs-empty p{margin:8px 0;font-size:.9rem}.rs-empty h3{font-size:1.1rem;color:var(--text, #1e293b);margin:12px 0 4px}.rs-empty svg{color:var(--text-secondary, #94a3b8)}.rs-timeline-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:20px 24px;margin-bottom:24px}.rs-timeline-card h3{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:600;color:var(--text, #1e293b);margin:0 0 16px}.rs-timeline{position:relative;min-height:80px;padding-top:28px;padding-bottom:12px}.rs-timeline-months{position:absolute;top:0;left:0;right:0;height:20px;font-size:.68rem;font-weight:600;color:var(--text-secondary, #94a3b8)}.rs-timeline-months span{position:absolute;transform:translate(-50%)}.rs-timeline-today{position:absolute;top:20px;bottom:0;width:2px;background:var(--primary, #6366f1);z-index:2}.rs-timeline-today span{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.62rem;font-weight:700;color:var(--primary, #6366f1);background:#6366f11a;padding:1px 6px;border-radius:3px;white-space:nowrap}.rs-timeline-bars{position:relative;display:flex;flex-direction:column;gap:4px}.rs-timeline-bar{position:relative;height:22px;border-radius:4px;opacity:.85;transition:opacity .15s;overflow:hidden}.rs-timeline-bar:hover{opacity:1}.rs-timeline-bar-label{position:absolute;left:6px;top:50%;transform:translateY(-50%);font-size:.68rem;font-weight:600;color:#fff;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.3)}.rs-section{margin-bottom:24px}.rs-section-title{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--text-secondary, #64748b);margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px}.rs-section-title.active{color:#10b981}.rs-section-title.upcoming{color:#3b82f6}.rs-dot-active{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.rs-cards{display:flex;flex-direction:column;gap:8px}.rs-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:14px 18px;transition:border-color .15s,box-shadow .15s}.rs-card:hover{border-color:var(--primary, #6366f1);box-shadow:0 2px 10px #6366f10f}.rs-card.active{border-left:3px solid #10b981}.rs-card.past{opacity:.55}.rs-card-left{display:flex;align-items:center;gap:14px;flex:1}.rs-card-color{width:8px;height:44px;border-radius:4px;flex-shrink:0}.rs-card-info{flex:1}.rs-card-name-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}.rs-card-name-row h4{font-size:.92rem;font-weight:600;color:var(--text, #1e293b);margin:0}.rs-badge{font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.rs-badge.active{background:#10b9811a;color:#059669}.rs-badge.upcoming{background:#3b82f61a;color:#2563eb}.rs-badge.past{background:var(--bg-hover, #f1f5f9);color:var(--text-secondary, #94a3b8)}.rs-card-dates{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary, #64748b);margin-bottom:4px}.rs-card-dates svg{color:var(--text-secondary, #94a3b8)}.rs-card-days{background:var(--bg-hover, #f1f5f9);padding:1px 6px;border-radius:3px;font-size:.72rem;font-weight:500}.rs-card-rates{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.rs-rate-chip{font-size:.7rem;font-weight:500;padding:2px 7px;border-radius:4px;background:#6366f10f;color:var(--primary, #6366f1)}.rs-rate-more{font-size:.7rem;color:var(--text-secondary, #94a3b8);padding:2px 4px}.rs-priority-badge{display:inline-block;font-size:.68rem;font-weight:600;color:var(--text-secondary, #94a3b8);margin-top:4px}.rs-card-actions{display:flex;gap:2px;flex-shrink:0}.rs-icon-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--text-secondary, #64748b);transition:all .15s}.rs-icon-btn:hover{background:var(--bg-hover, #f1f5f9);color:var(--primary, #6366f1)}.rs-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}.rs-modal{width:520px;max-width:95vw}.rs-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.rs-modal-header h2{font-size:1.15rem;font-weight:700;margin:0;color:var(--text, #1e293b)}.rs-modal-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--text-secondary, #64748b)}.rs-modal-close:hover{background:var(--bg-hover, #f1f5f9)}.rs-modal-body{padding:20px 24px}.rs-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border, #e2e8f0)}.rs-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.rs-field{display:flex;flex-direction:column;gap:4px}.rs-field label{font-size:.78rem;font-weight:600;color:var(--text-secondary, #64748b);display:flex;align-items:center;gap:4px}.rs-field input{padding:8px 10px;border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;color:var(--text, #1e293b);background:var(--bg, #fff);transition:border-color .15s}.rs-field input:focus{border-color:var(--primary, #6366f1);outline:none}.rs-field-hint{font-size:.7rem;color:var(--text-secondary, #94a3b8)}.rs-color-picker{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.rs-color-swatch{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .15s}.rs-color-swatch:hover{transform:scale(1.15)}.rs-color-swatch.selected{border-color:var(--text, #1e293b);box-shadow:0 0 0 2px #0000001a;transform:scale(1.1)}.rs-preview{margin-top:20px;padding:14px;background:var(--bg-hover, #f8fafc);border-radius:8px}.rs-preview-bar{height:26px;border-radius:5px;display:flex;align-items:center;padding:0 10px;margin-bottom:8px}.rs-preview-bar span{font-size:.76rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.rs-preview-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-secondary, #64748b)}@media(max-width:768px){.rs-page{padding:16px}.rs-form-grid{grid-template-columns:1fr}.rs-modal{width:95vw}.rs-card{flex-direction:column;align-items:flex-start;gap:10px}.rs-card-actions{align-self:flex-end}}.pkg-page{padding:28px 32px;max-width:1400px;margin:0 auto}.pkg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.pkg-header-left{display:flex;align-items:center;gap:12px}.pkg-header-left>svg{color:#f59e0b;background:#f59e0b1a;padding:8px;border-radius:10px;width:38px;height:38px}.pkg-header h1{font-size:1.35rem;font-weight:700;color:var(--text, #1e293b);margin:0}.pkg-subtitle{font-size:.82rem;color:var(--text-secondary, #64748b);margin:0}.pkg-btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--primary, #6366f1);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.pkg-btn-primary:hover{background:#4f46e5}.pkg-btn-primary:disabled{opacity:.5;cursor:default}.pkg-btn-secondary{padding:9px 18px;background:transparent;color:var(--text-secondary, #64748b);border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer}.pkg-btn-secondary:hover{background:var(--bg-hover, #f8fafc)}.pkg-filters{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap}.pkg-search-wrap{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:8px;flex:1;min-width:200px}.pkg-search-wrap svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.pkg-search-wrap input{border:none;outline:none;width:100%;font-size:.85rem;background:transparent;color:var(--text, #1e293b)}.pkg-select-wrap{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:8px}.pkg-select-wrap svg{color:var(--text-secondary, #94a3b8)}.pkg-select-wrap select{border:none;outline:none;background:transparent;font-size:.82rem;color:var(--text, #1e293b);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:16px}.pkg-loading,.pkg-empty{text-align:center;padding:60px 20px;color:var(--text-secondary, #64748b)}.pkg-loading p,.pkg-empty p{margin:8px 0;font-size:.9rem}.pkg-empty h3{font-size:1.1rem;color:var(--text, #1e293b);margin:12px 0 4px}.pkg-empty svg{color:var(--text-secondary, #94a3b8)}.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:16px}.pkg-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:12px;padding:18px 20px;transition:box-shadow .15s,border-color .15s}.pkg-card:hover{border-color:#f59e0b;box-shadow:0 2px 12px #f59e0b14}.pkg-card.inactive{opacity:.55}.pkg-card.expired{border-color:#fecaca}.pkg-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.pkg-card-title-row{display:flex;align-items:center;gap:8px}.pkg-card-code{font-size:.7rem;font-weight:700;background:#f59e0b1a;color:#d97706;padding:2px 8px;border-radius:4px;letter-spacing:.5px}.pkg-card h3{font-size:.95rem;font-weight:600;color:var(--text, #1e293b);margin:0}.pkg-card-actions{display:flex;gap:2px}.pkg-icon-btn{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:6px;color:var(--text-secondary, #64748b);transition:all .15s}.pkg-icon-btn:hover{background:var(--bg-hover, #f1f5f9);color:var(--primary, #6366f1)}.pkg-icon-btn.danger:hover{background:#fef2f2;color:#ef4444}.pkg-card-desc{font-size:.78rem;color:var(--text-secondary, #64748b);margin:0 0 10px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pkg-card-pricing{display:flex;align-items:center;gap:10px;margin-bottom:12px}.pkg-card-price{display:flex;align-items:baseline;gap:2px}.pkg-card-currency{font-size:1rem;font-weight:600;color:var(--text-secondary, #64748b)}.pkg-card-amount{font-size:1.5rem;font-weight:800;color:var(--text, #1e293b);letter-spacing:-.5px}.pkg-card-per{font-size:.78rem;color:var(--text-secondary, #94a3b8);margin-left:2px}.pkg-savings-badge{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:4px;background:#10b9811a;color:#059669}.pkg-card-rp{display:flex;align-items:center;gap:6px;font-size:.76rem;color:var(--text-secondary, #64748b);padding:6px 10px;background:var(--bg-hover, #f8fafc);border-radius:6px;margin-bottom:10px}.pkg-card-rp strong{color:var(--text, #1e293b)}.pkg-card-services{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.pkg-svc-chip{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:500;padding:3px 8px;border-radius:5px;background:#6366f10f;color:var(--primary, #6366f1)}.pkg-svc-qty{font-size:.65rem;font-weight:700;color:#d97706}.pkg-svc-sched{display:inline-flex;align-items:center;gap:2px;font-size:.65rem;color:var(--text-secondary, #94a3b8);margin-left:2px}.pkg-card-footer{display:flex;flex-wrap:wrap;gap:6px;padding-top:8px;border-top:1px solid var(--border, #f1f5f9)}.pkg-card-tag{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:500;padding:2px 7px;border-radius:4px;background:var(--bg-hover, #f1f5f9);color:var(--text-secondary, #64748b)}.pkg-card-tag.validity{color:#3b82f6;background:#3b82f60f}.pkg-card-tag.private{color:#ef4444;background:#ef44440f}.pkg-card-tag.expired{color:#ef4444;background:#fef2f2}.pkg-modal{width:660px;max-width:95vw}.pkg-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.pkg-modal-header h2{font-size:1.15rem;font-weight:700;margin:0;color:var(--text, #1e293b)}.pkg-modal-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--text-secondary, #64748b)}.pkg-modal-close:hover{background:var(--bg-hover, #f1f5f9)}.pkg-modal-tabs{display:flex;gap:2px;padding:14px 24px 0;border-bottom:1px solid var(--border, #e2e8f0)}.pkg-tab{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;font-size:.82rem;font-weight:500;border:none;background:none;cursor:pointer;color:var(--text-secondary, #64748b);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.pkg-tab.active{color:var(--primary, #6366f1);border-bottom-color:var(--primary, #6366f1)}.pkg-tab:hover{color:var(--text, #1e293b)}.pkg-tab-badge{font-size:.65rem;font-weight:700;background:var(--primary, #6366f1);color:#fff;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}.pkg-modal-body{padding:20px 24px;max-height:55vh;overflow-y:auto}.pkg-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border, #e2e8f0)}.pkg-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.pkg-field{display:flex;flex-direction:column;gap:4px}.pkg-field.full{grid-column:1/-1}.pkg-field label{font-size:.78rem;font-weight:600;color:var(--text-secondary, #64748b)}.pkg-field input,.pkg-field select,.pkg-field textarea{padding:8px 10px;border:1px solid var(--border, #e2e8f0);border-radius:8px;font-size:.85rem;color:var(--text, #1e293b);background:var(--bg, #fff);transition:border-color .15s;font-family:inherit}.pkg-field input:focus,.pkg-field select:focus,.pkg-field textarea:focus{border-color:var(--primary, #6366f1);outline:none}.pkg-field textarea{resize:vertical}.pkg-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem!important;font-weight:500!important;color:var(--text, #1e293b)!important;margin-top:12px}.pkg-help{font-size:.76rem;color:var(--text-secondary, #94a3b8);margin:0 0 14px}.pkg-no-services{text-align:center;padding:24px;color:var(--text-secondary, #94a3b8)}.pkg-no-services svg{margin-bottom:6px}.pkg-service-list{display:flex;flex-direction:column;gap:10px}.pkg-service-card{background:var(--bg-hover, #f8fafc);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:12px 14px}.pkg-svc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pkg-svc-num{font-size:.72rem;font-weight:700;color:var(--text-secondary, #94a3b8)}.pkg-svc-remove{background:none;border:none;cursor:pointer;padding:2px;color:#ef4444;border-radius:4px}.pkg-svc-remove:hover{background:#fef2f2}.pkg-svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pkg-add-svc-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;font-size:.82rem;font-weight:500;border:1px dashed var(--border, #cbd5e1);border-radius:8px;background:none;color:var(--text-secondary, #64748b);cursor:pointer;margin-top:12px;transition:all .15s}.pkg-add-svc-btn:hover{background:var(--bg-hover, #f8fafc);color:var(--primary, #6366f1);border-color:var(--primary, #6366f1)}.pkg-value-summary{margin-top:16px;padding:12px 14px;background:var(--bg-card, #fff);border:1px solid var(--border, #e2e8f0);border-radius:8px}.pkg-value-row{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-secondary, #64748b);padding:3px 0}.pkg-value-row.savings{color:#059669;font-weight:700;border-top:1px solid var(--border, #e2e8f0);padding-top:6px;margin-top:4px}@media(max-width:768px){.pkg-page{padding:16px}.pkg-grid,.pkg-form-grid,.pkg-svc-grid{grid-template-columns:1fr}.pkg-modal{width:95vw}}.night-audit-page{padding:32px;max-width:1200px;margin:0 auto}.night-audit-page h1{font-size:1.7rem;font-weight:700;color:var(--color-text);margin-bottom:4px;display:flex;align-items:center;gap:10px}.night-audit-page .subtitle{color:var(--color-text-secondary);font-size:.88rem;margin-bottom:28px}.na-run-panel{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:28px 32px;margin-bottom:28px;display:flex;justify-content:space-between;align-items:center;gap:24px}.na-run-info h2{font-size:1.15rem;font-weight:600;color:var(--color-text);margin:0 0 6px}.na-run-info p{color:var(--color-text-secondary);font-size:.85rem;margin:0}.na-run-status{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--color-text-secondary);margin-top:10px}.na-run-status .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.na-run-status .status-dot.completed{background:#22c55e}.na-run-status .status-dot.pending{background:#f59e0b}.na-run-btn{padding:14px 32px;background:var(--color-brand-gradient, linear-gradient(135deg, #04adef, #0295d6));color:#fff;border:none;border-radius:12px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;white-space:nowrap}.na-run-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #04adef4d}.na-run-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none;background:var(--color-text-muted, #94a3b8)}.na-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:36px}.na-stat-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:14px;padding:20px 22px;box-shadow:0 1px 3px #0000000a;transition:all .2s}.na-stat-card:hover{border-color:var(--color-brand, #04adef);box-shadow:0 2px 8px #0000000f}.na-stat-card .stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-secondary);margin-bottom:8px;font-weight:600}.na-stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text)}.na-stat-card .stat-value.green{color:var(--color-success, #10b981)}.na-stat-card .stat-value.amber{color:var(--color-warning, #f59e0b)}.na-stat-card .stat-value.red{color:var(--color-danger, #ef4444)}.na-stat-card .stat-value.muted{color:var(--color-text-muted, #94a3b8)}.na-section-divider{border:none;border-top:1px solid var(--color-border, #e2e8f0);margin:0 0 24px}.na-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.na-history-header h2{font-size:1.05rem;font-weight:600;color:var(--color-text);margin:0}.na-history-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:14px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.na-history-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);background:var(--color-bg-tertiary, #f1f5f9);padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border, #e2e8f0);font-weight:600}.na-history-table td{padding:14px 16px;font-size:.86rem;color:var(--color-text);border-bottom:1px solid var(--color-border, #e2e8f0)}.na-history-table tr:last-child td{border-bottom:none}.na-history-table tr:hover td{background:var(--color-bg-card-hover, #fafbfc)}.na-status-badge{font-size:.74rem;font-weight:600;padding:4px 10px;border-radius:8px;display:inline-flex;align-items:center;gap:4px}.na-status-badge.completed{background:var(--color-success-soft, #ecfdf5);color:var(--color-success, #10b981)}.na-status-badge.failed{background:var(--color-danger-soft, #fef2f2);color:var(--color-danger, #ef4444)}.na-status-badge.running{background:var(--color-info-soft, #e8f7fe);color:var(--color-info, #04adef)}.na-result-panel{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:16px;padding:28px;margin-bottom:32px;box-shadow:0 1px 3px #0000000a}.na-result-panel h3{font-size:1rem;font-weight:600;margin:0 0 16px;color:var(--color-text);display:flex;align-items:center;gap:8px}.na-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.na-result-item{padding:14px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:10px}.na-result-item .rl{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.na-result-item .rv{font-size:1.3rem;font-weight:700;color:var(--color-text);margin-top:4px}.na-empty{text-align:center;padding:48px;color:var(--color-text-secondary);font-size:.9rem}.na-error{color:var(--color-danger, #ef4444);font-size:.85rem;margin-bottom:16px;padding:10px 14px;background:var(--color-danger-soft, #fef2f2);border-radius:10px;border:1px solid rgba(239,68,68,.15)}.cancel-pol-page{padding:32px;max-width:1100px;margin:0 auto}.cancel-pol-page h1{font-size:1.7rem;font-weight:700;color:var(--color-text);margin-bottom:4px;display:flex;align-items:center;gap:10px}.cancel-pol-page .subtitle{color:var(--color-text-secondary);font-size:.88rem;margin-bottom:28px}.cp-header-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cp-add-btn{padding:10px 20px;background:var(--color-brand-gradient, linear-gradient(135deg, #04adef, #0295d6));color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.85rem;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.cp-add-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #04adef4d}.cp-grid{display:flex;flex-direction:column;gap:16px}.cp-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:14px;padding:24px;transition:all .2s;box-shadow:0 1px 3px #0000000a}.cp-card:hover{border-color:var(--color-brand, #04adef)}.cp-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}.cp-card-title{display:flex;align-items:center;gap:10px}.cp-card-title h3{font-size:1.05rem;font-weight:600;color:var(--color-text);margin:0}.cp-default-badge{font-size:.7rem;padding:2px 8px;border-radius:6px;background:var(--color-primary-soft, rgba(4, 173, 239, .08));color:var(--color-brand, #04adef);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.cp-card-actions{display:flex;gap:6px}.cp-card-actions button{background:none;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:6px 8px;cursor:pointer;color:var(--color-text-secondary);transition:all .15s}.cp-card-actions button:hover{border-color:var(--color-brand, #04adef);color:var(--color-text)}.cp-card-actions button.delete:hover{border-color:var(--color-danger, #ef4444);color:var(--color-danger, #ef4444)}.cp-desc{color:var(--color-text-secondary);font-size:.85rem;margin-bottom:14px}.cp-no-show{font-size:.82rem;color:var(--color-text-secondary);margin-bottom:12px}.cp-no-show strong{color:var(--color-text)}.cp-rules{display:flex;flex-direction:column;gap:6px}.cp-rule{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--color-text);padding:8px 12px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:8px}.cp-rule-icon{color:var(--color-warning, #f59e0b);flex-shrink:0}.cp-rule-text span{color:var(--color-text-secondary)}.cp-linked{font-size:.78rem;color:var(--color-text-secondary);margin-top:14px}.cp-linked strong{color:var(--color-text)}.cp-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay, rgba(15, 23, 42, .3));z-index:1000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cp-modal{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:18px;padding:32px;width:90%;max-width:580px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.cp-modal h2{font-size:1.2rem;font-weight:700;margin:0 0 24px;color:var(--color-text)}.cp-form-group{margin-bottom:16px}.cp-form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:6px}.cp-form-group input,.cp-form-group textarea,.cp-form-group select{width:100%;padding:10px 14px;background:var(--color-bg-input, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:10px;font-size:.88rem;color:var(--color-text);outline:none;box-sizing:border-box}.cp-form-group input:focus,.cp-form-group textarea:focus{border-color:var(--color-border-focus, rgba(4, 173, 239, .45));box-shadow:0 0 0 3px var(--color-primary-soft, rgba(4, 173, 239, .08))}.cp-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cp-checkbox{display:flex;align-items:center;gap:8px;font-size:.88rem;color:var(--color-text);cursor:pointer}.cp-checkbox input{width:auto;accent-color:var(--color-brand, #04adef)}.cp-rules-builder{margin-bottom:16px}.cp-rules-builder h4{font-size:.88rem;font-weight:600;color:var(--color-text);margin:0 0 10px}.cp-rule-row{display:grid;grid-template-columns:100px 120px 80px 32px;gap:8px;align-items:center;margin-bottom:8px}.cp-rule-row input,.cp-rule-row select{padding:8px 10px;background:var(--color-bg-input, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.82rem;color:var(--color-text)}.cp-rule-remove{background:none;border:none;color:var(--color-danger, #ef4444);cursor:pointer;padding:4px;border-radius:6px}.cp-rule-remove:hover{background:var(--color-danger-soft, #fef2f2)}.cp-add-rule-btn{padding:6px 14px;background:var(--color-bg-tertiary, #f1f5f9);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.82rem;cursor:pointer;color:var(--color-text)}.cp-add-rule-btn:hover{border-color:var(--color-brand, #04adef)}.cp-modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.cp-save-btn{padding:10px 24px;background:var(--color-brand-gradient, linear-gradient(135deg, #04adef, #0295d6));color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.88rem;cursor:pointer}.cp-save-btn:disabled{opacity:.5;cursor:not-allowed}.cp-cancel-btn{padding:10px 24px;background:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text);border:1px solid var(--color-border, #e2e8f0);border-radius:10px;font-size:.88rem;cursor:pointer}.cp-empty{text-align:center;padding:48px;color:var(--color-text-secondary);font-size:.9rem}.rate-cal-page{padding:32px;max-width:1400px;margin:0 auto}.rate-cal-page h1{font-size:1.7rem;font-weight:700;color:var(--color-text);margin-bottom:4px;display:flex;align-items:center;gap:10px}.rate-cal-page .subtitle{color:var(--color-text-secondary);font-size:.88rem;margin-bottom:28px}.rc-controls{display:flex;gap:16px;align-items:center;margin-bottom:24px;flex-wrap:wrap}.rc-month-nav{display:flex;align-items:center;gap:12px}.rc-month-label{font-size:1.05rem;font-weight:600;color:var(--color-text);min-width:160px;text-align:center}.rc-nav-btn{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);color:var(--color-text);border-radius:8px;padding:8px 10px;cursor:pointer;display:flex;align-items:center;transition:all .15s}.rc-nav-btn:hover{border-color:var(--color-brand, #04adef)}.rc-scroll{overflow-x:auto;position:relative;border-radius:14px;mask-image:linear-gradient(to right,black calc(100% - 24px),transparent 100%);-webkit-mask-image:linear-gradient(to right,black calc(100% - 24px),transparent 100%)}.rc-scroll:hover{mask-image:none;-webkit-mask-image:none}.rc-grid{display:grid;gap:0;border:1px solid var(--color-border, #e2e8f0);border-radius:14px;overflow:hidden;min-width:900px}.rc-header-cell{background:var(--color-bg-tertiary, #f1f5f9);padding:10px 4px;text-align:center;border-bottom:1px solid var(--color-border, #e2e8f0);border-right:1px solid var(--color-border, #e2e8f0)}.rc-header-cell.room-type-col{text-align:left;padding-left:16px;font-weight:600;font-size:.82rem;color:var(--color-text);position:sticky;left:0;z-index:2;background:var(--color-bg-tertiary, #f1f5f9)}.rc-header-cell .day-num{font-size:.82rem;font-weight:600;color:var(--color-text);line-height:1.2}.rc-header-cell .day-name{font-size:.62rem;text-transform:uppercase;color:var(--color-text-muted, #94a3b8);letter-spacing:.3px;line-height:1.2}.rc-header-cell.weekend .day-num{color:var(--color-warning, #f59e0b)}.rc-header-cell.today{background:var(--color-primary-soft, rgba(4, 173, 239, .08))}.rc-header-cell.today .day-num{color:var(--color-brand, #04adef);font-weight:700}.rc-row-label{padding:10px 16px;font-weight:600;font-size:.82rem;color:var(--color-text);background:var(--color-bg-card, #fff);border-right:1px solid var(--color-border, #e2e8f0);border-bottom:1px solid var(--color-border, #e2e8f0);position:sticky;left:0;z-index:2;white-space:nowrap;display:flex;align-items:center}.rc-cell{padding:6px 2px;text-align:center;background:var(--color-bg-card, #fff);border-right:1px solid var(--color-border, #e2e8f0);border-bottom:1px solid var(--color-border, #e2e8f0);font-size:.78rem;font-weight:600;color:var(--color-text);position:relative;min-height:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:background .1s;cursor:default}.rc-cell:hover{background:var(--color-bg-card-hover, #fafbfc)}.rc-cell[data-season]{border-bottom:2px solid transparent}.rc-cell .rc-rate{font-size:.78rem;line-height:1.3}.rc-cell .rc-season-tag{font-size:.55rem;font-weight:600;letter-spacing:.3px;padding:1px 4px;border-radius:3px;margin-top:2px;white-space:nowrap;text-transform:uppercase}.rc-cell.today{background:var(--color-primary-soft, rgba(4, 173, 239, .06))}.rc-legend{display:flex;gap:18px;margin-top:16px;flex-wrap:wrap;padding-left:4px}.rc-legend-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--color-text-secondary);font-weight:500}.rc-legend-dot{width:10px;height:10px;border-radius:3px}.rc-empty{text-align:center;padding:48px;color:var(--color-text-secondary);font-size:.9rem}.refund-page{padding:32px;max-width:1200px;margin:0 auto}.refund-page h1{font-size:1.7rem;font-weight:700;color:var(--color-text);margin-bottom:4px;display:flex;align-items:center;gap:10px}.refund-page .subtitle{color:var(--color-text-secondary);font-size:.88rem;margin-bottom:28px}.ref-filters{display:flex;gap:8px;margin-bottom:20px}.ref-filter-pill{padding:8px 18px;border-radius:20px;border:1px solid var(--color-border, #e2e8f0);background:var(--color-bg-card, #fff);color:var(--color-text-secondary);font-size:.82rem;cursor:pointer;font-weight:500;transition:all .2s}.ref-filter-pill:hover{border-color:var(--color-brand, #04adef)}.ref-filter-pill.active{background:var(--color-brand-gradient, linear-gradient(135deg, #04adef, #0295d6));color:#fff;border-color:transparent}.ref-filter-pill .count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;background:#ffffff40;font-size:.72rem;margin-left:6px;padding:0 5px}.ref-list{display:flex;flex-direction:column;gap:12px}.ref-card{background:var(--color-bg-card, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:14px;padding:20px 24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;transition:all .2s;box-shadow:0 1px 3px #0000000a}.ref-card:hover{border-color:var(--color-brand, #04adef)}.ref-card-left{display:flex;flex-direction:column;gap:6px;flex:1;min-width:200px}.ref-card-guest{font-size:1rem;font-weight:600;color:var(--color-text)}.ref-card-booking{font-size:.82rem;color:var(--color-text-secondary)}.ref-card-reason{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg-tertiary, #f1f5f9);border-radius:8px;font-size:.78rem;color:var(--color-text);width:fit-content}.ref-card-desc{font-size:.84rem;color:var(--color-text-secondary)}.ref-card-date{font-size:.78rem;color:var(--color-text-muted)}.ref-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.ref-card-amount{font-size:1.3rem;font-weight:700;color:var(--color-text)}.ref-status-badge{font-size:.72rem;font-weight:600;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.ref-status-badge.pendingapproval{background:var(--color-warning-soft, #fffbeb);color:var(--color-warning, #f59e0b)}.ref-status-badge.approved{background:var(--color-success-soft, #ecfdf5);color:var(--color-success, #10b981)}.ref-status-badge.rejected{background:var(--color-danger-soft, #fef2f2);color:var(--color-danger, #ef4444)}.ref-status-badge.processed{background:var(--color-info-soft, #e8f7fe);color:var(--color-info, #04adef)}.ref-card-actions{display:flex;gap:6px}.ref-action-btn{padding:6px 14px;border-radius:8px;border:1px solid var(--color-border, #e2e8f0);background:var(--color-bg-card, #fff);font-size:.78rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s}.ref-action-btn.approve{color:var(--color-success, #10b981)}.ref-action-btn.approve:hover{background:var(--color-success-soft, #ecfdf5);border-color:var(--color-success, #10b981)}.ref-action-btn.reject{color:var(--color-danger, #ef4444)}.ref-action-btn.reject:hover{background:var(--color-danger-soft, #fef2f2);border-color:var(--color-danger, #ef4444)}.ref-action-btn.process{color:var(--color-brand, #04adef)}.ref-action-btn.process:hover{background:var(--color-info-soft, #e8f7fe);border-color:var(--color-brand, #04adef)}.ref-empty{text-align:center;padding:48px;color:var(--color-text-secondary);font-size:.9rem}.acc-page{padding:28px 32px;max-width:1400px;margin:0 auto}.acc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.acc-header-left{display:flex;align-items:center;gap:12px}.acc-header-left h1{font-size:1.35rem;font-weight:700;color:#1e293b;margin:0}.acc-header-left svg{color:#6366f1}.acc-count{background:#f1f5f9;color:#64748b;font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:12px}.acc-btn-new{display:flex;align-items:center;gap:6px;padding:9px 18px;background:#6366f1;color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.acc-btn-new:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.acc-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:#94a3b8}.acc-pill-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;border-radius:12px;margin-bottom:20px;overflow-x:auto}.acc-pill{display:inline-flex;align-items:center;gap:4px;padding:7px 16px;font-size:.82rem;font-weight:500;border-radius:20px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;white-space:nowrap;transition:all .15s ease}.acc-pill:hover{border-color:#6366f1;color:#6366f1}.acc-pill.active{background:#6366f1;color:#fff;border-color:#6366f1;font-weight:600;box-shadow:0 2px 6px #6366f140}.acc-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px}.acc-search-box{flex:1;display:flex;align-items:center;gap:8px;padding:9px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;transition:border-color .15s}.acc-search-box:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.acc-search-box svg{color:#94a3b8;flex-shrink:0}.acc-search-box input{border:none;outline:none;background:transparent;font-size:.85rem;color:#1e293b;width:100%}.acc-filter-select{padding:9px 28px 9px 14px;font-size:.82rem;color:#1e293b;border:1px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;outline:none;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.acc-filter-select:focus{border-color:#6366f1}.acc-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 0;color:#94a3b8}.acc-empty h3{color:#475569;margin:0;font-size:1.1rem}.acc-empty p{margin:0;font-size:.85rem}.acc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.acc-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:14px}.acc-card:hover{border-color:#6366f1;box-shadow:0 4px 16px #0000000f;transform:translateY(-2px)}.acc-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.acc-card-title-row{display:flex;align-items:flex-start;gap:10px}.acc-type-emoji{font-size:1.5rem;line-height:1}.acc-type-emoji.lg{font-size:2rem}.acc-card-titles{display:flex;flex-direction:column;gap:2px}.acc-card-name{font-size:.95rem;font-weight:700;color:#1e293b;margin:0;line-height:1.3}.acc-card-code{font-size:.72rem;color:#94a3b8;font-weight:500;font-family:SF Mono,monospace}.acc-status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.acc-status-badge.sm{padding:2px 8px;font-size:.65rem}.acc-status-badge.prospect{background:#6366f11a;color:#6366f1}.acc-status-badge.active{background:#10b9811a;color:#059669}.acc-status-badge.suspended{background:#f59e0b1a;color:#d97706}.acc-status-badge.inactive{background:#6b72801a;color:#6b7280}.acc-card-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:.78rem;color:#64748b}.acc-card-meta span{display:flex;align-items:center;gap:4px}.acc-card-type{font-weight:600}.acc-credit-section{display:flex;flex-direction:column;gap:6px}.acc-credit-section.modal{margin-top:12px}.acc-credit-header{display:flex;align-items:center;justify-content:space-between}.acc-credit-label{font-size:.72rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px}.acc-credit-values{font-size:.78rem;font-weight:600;color:#475569}.acc-credit-bar{width:100%;height:6px;background:#f1f5f9;border-radius:4px;overflow:hidden}.acc-credit-bar.lg{height:8px;border-radius:6px}.acc-credit-fill{height:100%;border-radius:4px;transition:width .4s ease;min-width:2px}.acc-credit-fill.ok{background:linear-gradient(90deg,#10b981,#34d399)}.acc-credit-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.acc-credit-fill.danger{background:linear-gradient(90deg,#ef4444,#f87171)}.acc-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid #f1f5f9}.acc-card-stat{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#94a3b8}.acc-card-terms{font-size:.72rem;font-weight:600;color:#6366f1;background:#6366f114;padding:2px 8px;border-radius:6px}.acc-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:accFadeIn .15s ease}@keyframes accFadeIn{0%{opacity:0}to{opacity:1}}.acc-modal{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 48px #00000026;animation:accSlideUp .2s ease}.acc-modal.form{max-width:720px}.acc-modal form{display:flex;flex-direction:column;overflow:hidden;flex:1;min-height:0}@keyframes accSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.acc-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #f1f5f9}.acc-modal-header-left{display:flex;align-items:flex-start;gap:14px;flex:1}.acc-modal-header h2{font-size:1.15rem;font-weight:700;color:#1e293b;margin:0}.acc-modal-badges{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.acc-modal-code{font-size:.72rem;font-weight:600;color:#94a3b8;font-family:SF Mono,monospace;background:#f8fafc;padding:2px 8px;border-radius:6px;border:1px solid #e2e8f0}.acc-type-badge{font-size:.7rem;font-weight:600;color:#475569;background:#f1f5f9;padding:2px 8px;border-radius:6px}.acc-modal-actions-top{display:flex;align-items:center;gap:8px}.acc-modal-edit-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:8px;font-size:.78rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s}.acc-modal-edit-btn:hover{border-color:#6366f1;color:#6366f1}.acc-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:#f1f5f9;border-radius:8px;cursor:pointer;color:#64748b;transition:all .15s}.acc-modal-close:hover{background:#e2e8f0;color:#1e293b}.acc-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.acc-modal-section{margin-bottom:20px}.acc-modal-section h4{font-size:.78rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.acc-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.acc-detail-item{display:flex;flex-direction:column;gap:3px}.acc-detail-label{display:flex;align-items:center;gap:4px;font-size:.72rem;font-weight:500;color:#94a3b8}.acc-detail-value{font-size:.85rem;color:#1e293b;font-weight:500}.acc-detail-value.danger{color:#ef4444;font-weight:600}.acc-sub-list{display:flex;flex-direction:column;gap:8px}.acc-sub-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9}.acc-sub-name{font-size:.85rem;font-weight:600;color:#1e293b;flex:1}.acc-sub-code{font-size:.72rem;color:#94a3b8;font-family:SF Mono,monospace}.acc-notes-block{padding:12px 14px;background:#f8fafc;border-radius:8px;font-size:.85rem;color:#475569;line-height:1.6;border:1px solid #f1f5f9}.acc-rateplan-list{display:flex;flex-direction:column;gap:8px}.acc-rateplan-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#f8fafc;border-radius:8px;border:1px solid #f1f5f9;transition:border-color .15s}.acc-rateplan-item:hover{border-color:#e2e8f0}.acc-rateplan-info{display:flex;flex-direction:column;gap:2px}.acc-rateplan-name{font-size:.85rem;font-weight:600;color:#1e293b}.acc-rateplan-room{font-size:.72rem;color:#94a3b8}.acc-rateplan-details{display:flex;align-items:center;gap:8px}.acc-rateplan-rate{font-size:.82rem;font-weight:700;color:#6366f1}.acc-rateplan-meal{font-size:.68rem;font-weight:600;background:#10b9811a;color:#059669;padding:2px 8px;border-radius:6px}.acc-contracted-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:16px;margin-bottom:12px}.acc-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #f1f5f9}.acc-action-btn{display:flex;align-items:center;gap:6px;padding:9px 18px;border:1px solid #e2e8f0;background:#fff;border-radius:10px;font-size:.82rem;font-weight:600;color:#475569;cursor:pointer;transition:all .15s}.acc-action-btn:hover{border-color:#94a3b8}.acc-action-btn.primary{background:#6366f1;border-color:#6366f1;color:#fff}.acc-action-btn.primary:hover{background:#4f46e5}.acc-action-btn.primary:disabled{opacity:.6;cursor:not-allowed}.acc-action-btn.warning{background:#f59e0b;border-color:#f59e0b;color:#fff}.acc-action-btn.warning:hover{background:#d97706}.acc-action-btn.danger{background:#ef4444;border-color:#ef4444;color:#fff}.acc-action-btn.danger:hover{background:#dc2626}.acc-form-error{background:#ef444414;color:#dc2626;padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:.85rem;border:1px solid rgba(239,68,68,.15)}.acc-form-section{margin-bottom:20px}.acc-form-section h4{font-size:.78rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.acc-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.acc-form-field{display:flex;flex-direction:column;gap:5px}.acc-form-field.full{grid-column:1 / -1}.acc-form-field label{font-size:.75rem;font-weight:600;color:#64748b}.acc-form-field input,.acc-form-field select{padding:9px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;color:#1e293b;outline:none;transition:border-color .15s;background:#fff}.acc-form-field input:focus,.acc-form-field select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.acc-form-textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;color:#1e293b;outline:none;transition:border-color .15s;resize:vertical;font-family:inherit;box-sizing:border-box}.acc-form-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.spin{animation:spin 1s linear infinite}.invoices-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);flex-wrap:wrap;gap:var(--space-3)}.invoices-header h1{font-size:var(--text-xl);font-weight:var(--font-bold);display:flex;align-items:center;gap:var(--space-2)}.invoices-filters{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap}.invoices-table{width:100%;border-collapse:separate;border-spacing:0;font-size:var(--text-sm)}.invoices-table th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:var(--font-semibold);color:var(--color-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);position:sticky;top:0;z-index:1}.invoices-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);vertical-align:middle}.invoices-table tr:hover td{background:var(--color-bg-secondary)}.invoices-table tr{cursor:pointer;transition:background .15s}.invoice-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:.68rem;font-weight:600;letter-spacing:.02em}.invoice-status-badge.draft{background:var(--color-bg-tertiary);color:var(--color-text-muted)}.invoice-status-badge.issued{background:var(--color-brand-light);color:var(--color-primary)}.invoice-status-badge.paid{background:var(--color-success-soft);color:var(--color-success)}.invoice-status-badge.partiallypaid{background:var(--color-warning-soft);color:var(--color-warning)}.invoice-status-badge.void,.invoice-status-badge.overdue{background:var(--color-danger-soft);color:var(--color-danger)}.invoice-mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-primary);font-weight:600}.invoice-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);margin-bottom:var(--space-5)}.invoice-detail-block h5{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-2);font-weight:var(--font-semibold)}.invoice-detail-block p{font-size:var(--text-sm);color:var(--color-text-primary);line-height:1.5;margin:0}.invoice-items-table{width:100%;border-collapse:collapse;font-size:var(--text-sm);margin-bottom:var(--space-4)}.invoice-items-table th{text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);border-bottom:2px solid var(--color-border);font-weight:var(--font-semibold)}.invoice-items-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border-light)}.invoice-items-table .text-right{text-align:right}.invoice-totals{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:2px solid var(--color-border)}.invoice-total-row{display:flex;gap:var(--space-6);font-size:var(--text-sm)}.invoice-total-row .label{color:var(--color-text-muted);min-width:100px;text-align:right}.invoice-total-row .value{font-family:var(--font-mono);font-weight:var(--font-semibold);min-width:100px;text-align:right}.invoice-total-row.grand{font-size:var(--text-base);font-weight:var(--font-bold)}.invoice-total-row.grand .label,.invoice-total-row.grand .value{color:var(--color-text-primary)}.invoice-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border);justify-content:flex-end}.payment-form{display:flex;gap:var(--space-3);align-items:flex-end;margin-top:var(--space-3);padding:var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.payment-form .form-group{flex:1;margin-bottom:0}.payer-info{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm);border-left:3px solid var(--color-primary)}:root{--portal-primary: #6366f1;--portal-primary-dark: #4f46e5;--portal-primary-light: #818cf8;--portal-bg: #0f1117;--portal-surface: #1a1d27;--portal-surface-2: #22252f;--portal-border: rgba(255, 255, 255, .08);--portal-text: #e2e8f0;--portal-text-muted: #94a3b8;--portal-success: #10b981;--portal-warning: #f59e0b;--portal-danger: #ef4444;--portal-radius: 12px;--portal-radius-sm: 8px}.portal-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--portal-bg);background-image:radial-gradient(at 20% 50%,rgba(99,102,241,.12) 0%,transparent 50%),radial-gradient(at 80% 20%,rgba(139,92,246,.08) 0%,transparent 50%);padding:20px}.portal-login-card{width:100%;max-width:420px;background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:20px;padding:40px;box-shadow:0 20px 60px #0006}.portal-login-card .portal-logo{text-align:center;margin-bottom:32px}.portal-login-card .portal-logo h1{font-size:24px;color:#fff;margin:0;font-weight:700;letter-spacing:-.5px}.portal-login-card .portal-logo p{font-size:13px;color:var(--portal-text-muted);margin:6px 0 0}.portal-login-card .portal-logo .logo-icon{display:inline-flex;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--portal-primary),#8b5cf6);align-items:center;justify-content:center;margin-bottom:16px;color:#fff}.portal-field{margin-bottom:20px}.portal-field label{display:block;font-size:12px;font-weight:600;color:var(--portal-text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.portal-field input{width:100%;padding:12px 16px;background:var(--portal-surface-2);border:1px solid var(--portal-border);border-radius:var(--portal-radius-sm);color:var(--portal-text);font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.portal-field input:focus{border-color:var(--portal-primary);box-shadow:0 0 0 3px #6366f126}.portal-login-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--portal-primary),var(--portal-primary-dark));color:#fff;border:none;border-radius:var(--portal-radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.portal-login-btn:hover{opacity:.92;transform:translateY(-1px)}.portal-login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.portal-login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--portal-radius-sm);padding:10px 14px;color:var(--portal-danger);font-size:13px;margin-bottom:16px}.portal-shell{min-height:100vh;background:var(--portal-bg);color:var(--portal-text)}.portal-topbar{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:64px;background:var(--portal-surface);border-bottom:1px solid var(--portal-border);position:sticky;top:0;z-index:100}.portal-topbar-left{display:flex;align-items:center;gap:12px}.portal-topbar-left .topbar-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--portal-primary),#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff}.portal-topbar-left h2{font-size:16px;margin:0;color:#fff;font-weight:600}.portal-topbar-left span{font-size:11px;color:var(--portal-text-muted)}.portal-nav{display:flex;gap:4px}.portal-nav a{padding:8px 16px;font-size:13px;font-weight:500;color:var(--portal-text-muted);text-decoration:none;border-radius:var(--portal-radius-sm);transition:all .2s;display:flex;align-items:center;gap:6px}.portal-nav a:hover{color:#fff;background:var(--portal-surface-2)}.portal-nav a.active{color:#fff;background:#6366f126}.portal-topbar-right{display:flex;align-items:center;gap:12px}.portal-user-badge{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--portal-text-muted)}.portal-user-badge .avatar{width:32px;height:32px;border-radius:50%;background:var(--portal-surface-2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--portal-primary-light)}.portal-logout-btn{padding:6px 12px;background:transparent;border:1px solid var(--portal-border);border-radius:6px;color:var(--portal-text-muted);font-size:12px;cursor:pointer;transition:all .2s}.portal-logout-btn:hover{color:var(--portal-danger);border-color:var(--portal-danger)}.portal-content{padding:32px;max-width:1200px;margin:0 auto}.portal-property-selector{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--portal-surface-2);border:1px solid var(--portal-border);border-radius:var(--portal-radius-sm);position:relative;transition:border-color .2s}.portal-property-selector:hover,.portal-property-selector:focus-within{border-color:var(--portal-primary)}.portal-property-dropdown{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:none;color:var(--portal-text);font-size:13px;font-weight:500;outline:none;cursor:pointer;padding-right:16px;max-width:220px}.portal-property-dropdown option{background:var(--portal-surface);color:var(--portal-text)}.portal-property-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--portal-surface-2);border:1px solid var(--portal-border);border-radius:var(--portal-radius-sm);font-size:13px;color:var(--portal-text-muted)}.portal-dash-welcome{margin-bottom:32px}.portal-dash-welcome h1{font-size:28px;margin:0;color:#fff;font-weight:700}.portal-dash-welcome p{font-size:14px;color:var(--portal-text-muted);margin:6px 0 0}.portal-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:32px}.portal-stat-card{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius);padding:20px;transition:border-color .2s}.portal-stat-card:hover{border-color:var(--portal-primary)}.portal-stat-card .stat-label{font-size:11px;color:var(--portal-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.portal-stat-card .stat-value{font-size:28px;font-weight:700;color:#fff}.portal-stat-card .stat-value.money{font-family:JetBrains Mono,monospace;font-size:22px}.portal-stat-card .stat-value.success{color:var(--portal-success)}.portal-stat-card .stat-value.warning{color:var(--portal-warning)}.portal-stat-card .stat-value.danger{color:var(--portal-danger)}.portal-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.portal-section-header h2{font-size:18px;margin:0;color:#fff}.portal-card{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius);overflow:hidden}.portal-table{width:100%;border-collapse:collapse}.portal-table th{padding:12px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--portal-text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--portal-border);background:var(--portal-surface-2)}.portal-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--portal-border)}.portal-table tbody tr{transition:background .15s;cursor:pointer}.portal-table tbody tr:hover{background:var(--portal-surface-2)}.portal-table tbody tr:last-child td{border-bottom:none}.portal-mono{font-family:JetBrains Mono,monospace;font-size:12px}.portal-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.portal-badge.confirmed{background:#10b9811f;color:var(--portal-success)}.portal-badge.checkedin{background:#6366f11f;color:var(--portal-primary-light)}.portal-badge.checkedout{background:#94a3b81f;color:var(--portal-text-muted)}.portal-badge.cancelled{background:#ef44441f;color:var(--portal-danger)}.portal-badge.noshow{background:#f59e0b1f;color:var(--portal-warning)}.portal-badge.issued{background:#6366f11f;color:var(--portal-primary-light)}.portal-badge.paid{background:#10b9811f;color:var(--portal-success)}.portal-badge.overdue{background:#ef44441f;color:var(--portal-danger)}.portal-badge.draft{background:#94a3b81f;color:var(--portal-text-muted)}.portal-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--portal-radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.portal-btn-primary{background:linear-gradient(135deg,var(--portal-primary),var(--portal-primary-dark));color:#fff}.portal-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.portal-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.portal-btn-secondary{background:var(--portal-surface-2);color:var(--portal-text);border:1px solid var(--portal-border)}.portal-btn-secondary:hover{border-color:var(--portal-primary)}.portal-btn-sm{padding:6px 14px;font-size:12px}.portal-booking-form{display:flex;flex-direction:column;gap:24px}.portal-form-section{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius);padding:24px}.portal-form-section h3{font-size:15px;margin:0 0 16px;color:#fff;display:flex;align-items:center;gap:8px}.portal-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.portal-form-row:last-child{margin-bottom:0}.portal-form-group{display:flex;flex-direction:column;gap:6px}.portal-form-group label{font-size:12px;font-weight:600;color:var(--portal-text-muted);text-transform:uppercase;letter-spacing:.5px}.portal-form-group input,.portal-form-group select,.portal-form-group textarea{padding:10px 14px;background:var(--portal-surface-2);border:1px solid var(--portal-border);border-radius:8px;color:var(--portal-text);font-size:13px;outline:none;transition:border-color .2s}.portal-form-group input:focus,.portal-form-group select:focus,.portal-form-group textarea:focus{border-color:var(--portal-primary)}.portal-room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.portal-room-card{background:var(--portal-surface-2);border:2px solid var(--portal-border);border-radius:var(--portal-radius);padding:20px;transition:all .2s;cursor:pointer}.portal-room-card:hover{border-color:var(--portal-primary)}.portal-room-card.selected{border-color:var(--portal-primary);background:#6366f114}.portal-room-card.unavailable{opacity:.4;cursor:not-allowed}.portal-room-card h4{font-size:16px;margin:0 0 8px;color:#fff}.portal-room-card .room-rate{font-size:22px;font-weight:700;color:var(--portal-primary-light);font-family:JetBrains Mono,monospace}.portal-room-card .room-rate span{font-size:13px;color:var(--portal-text-muted);font-weight:400;font-family:inherit}.portal-room-card .room-meta{display:flex;gap:12px;margin-top:10px;font-size:12px;color:var(--portal-text-muted)}.portal-room-card .contracted-tag{display:inline-flex;padding:2px 8px;background:#10b9811f;color:var(--portal-success);border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;margin-top:8px}.portal-empty{text-align:center;padding:60px 20px;color:var(--portal-text-muted)}.portal-empty svg{margin-bottom:16px;opacity:.3}.portal-empty h3{color:#fff;margin:0 0 8px}.portal-empty p{font-size:14px}.portal-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--portal-text-muted);gap:12px}.portal-summary{background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius);padding:24px}.portal-summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px}.portal-summary-row .label{color:var(--portal-text-muted)}.portal-summary-row .value{color:#fff;font-weight:600}.portal-summary-row.grand{border-top:2px solid var(--portal-border);margin-top:8px;padding-top:16px;font-size:18px}.portal-summary-row.grand .value{color:var(--portal-primary-light);font-family:JetBrains Mono,monospace}.portal-filters{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.portal-search{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius-sm);flex:1;min-width:200px}.portal-search input{background:transparent;border:none;color:var(--portal-text);font-size:13px;outline:none;width:100%}.portal-filter-select{padding:8px 14px;background:var(--portal-surface);border:1px solid var(--portal-border);border-radius:var(--portal-radius-sm);color:var(--portal-text);font-size:13px;outline:none}@keyframes portal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portal-spin{animation:portal-spin 1s linear infinite}@media(max-width:768px){.portal-topbar{padding:0 16px}.portal-nav{display:none}.portal-content{padding:16px}.portal-stats{grid-template-columns:repeat(2,1fr)}.portal-form-row,.portal-room-grid{grid-template-columns:1fr}}.fnb-outlets-page{padding:0}.fnb-outlets-page .page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.fnb-outlets-page .page-header h1{font-size:1.6rem;font-weight:700;display:flex;align-items:center;gap:.5rem;color:var(--color-text)}.fnb-outlets-page .outlet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}.outlet-card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;transition:transform .2s,box-shadow .2s;cursor:pointer;box-shadow:var(--shadow-sm)}.outlet-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border-hover)}.outlet-card-header{padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--color-border)}.outlet-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.outlet-icon.restaurant{background:linear-gradient(135deg,#f97316,#ea580c)}.outlet-icon.bar{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.outlet-icon.lounge{background:linear-gradient(135deg,#06b6d4,#0891b2)}.outlet-icon.cafe{background:linear-gradient(135deg,#d97706,#b45309)}.outlet-icon.roomservice{background:linear-gradient(135deg,#10b981,#059669)}.outlet-icon.banquet{background:linear-gradient(135deg,#ec4899,#db2777)}.outlet-icon.poolbar{background:linear-gradient(135deg,#3b82f6,#2563eb)}.outlet-card-info h3{font-size:1.05rem;font-weight:600;margin:0 0 .25rem;color:var(--color-text)}.outlet-card-info .code-badge,.code-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-bg-tertiary);color:var(--color-text-secondary);letter-spacing:.5px;font-family:var(--font-mono)}.outlet-card-body{padding:1rem 1.5rem}.outlet-stat-row{display:flex;gap:1.5rem;margin-bottom:.75rem}.outlet-stat{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--color-text-secondary)}.outlet-stat .num{font-weight:600;color:var(--color-text)}.outlet-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.outlet-tag{font-size:.72rem;padding:3px 10px;border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-weight:500}.outlet-tag.active{background:var(--color-success-soft);color:#059669}.outlet-tag.inactive{background:var(--color-danger-soft);color:#dc2626}.outlet-card-actions{padding:.75rem 1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.5rem}.fnb-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}.fnb-modal{background:var(--color-bg-secondary);border-radius:var(--radius-xl);border:1px solid var(--color-border);width:90%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .25s}.fnb-modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.fnb-modal-header h2{font-size:1.15rem;font-weight:600;margin:0;color:var(--color-text)}.fnb-modal-body{padding:1.5rem}.fnb-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.75rem}.fnb-form-group{margin-bottom:1.15rem}.fnb-form-group label{display:block;font-size:var(--text-xs);font-weight:var(--font-semibold);margin-bottom:.4rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.fnb-form-group input,.fnb-form-group select,.fnb-form-group textarea{width:100%;padding:.6rem .85rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-input);color:var(--color-text);font-size:.9rem;font-family:var(--font-family);transition:border-color var(--transition-fast)}.fnb-form-group input:focus,.fnb-form-group select:focus,.fnb-form-group textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-soft)}.fnb-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.fnb-form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}.btn-fnb{padding:.55rem 1.15rem;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-semibold);border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:all var(--transition-fast);font-family:var(--font-family)}.btn-fnb.primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-fnb.primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-fnb.secondary{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-fnb.secondary:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-hover);color:var(--color-text)}.btn-fnb.danger{background:var(--color-danger-soft);color:var(--color-danger)}.btn-fnb.danger:hover{background:#fecaca}.btn-fnb.sm{padding:.35rem .75rem;font-size:var(--text-xs)}.btn-fnb.icon-only{padding:.4rem;border-radius:var(--radius-sm)}.fnb-tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1.5rem}.fnb-tab{padding:.75rem 1.25rem;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast);background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font-family);display:inline-flex;align-items:center;gap:.4rem}.fnb-tab:hover{color:var(--color-text)}.fnb-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.table-card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1rem;text-align:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast);position:relative;box-shadow:var(--shadow-sm)}.table-card:hover{transform:scale(1.03);box-shadow:var(--shadow-md)}.table-card .table-number{font-size:1.3rem;font-weight:700;margin-bottom:.5rem;color:var(--color-text)}.table-card .table-capacity{font-size:.78rem;color:var(--color-text-secondary);margin-bottom:.5rem}.table-status-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.table-status-badge.available{background:var(--color-success-soft);color:#059669}.table-status-badge.occupied{background:var(--color-danger-soft);color:#dc2626}.table-status-badge.reserved{background:var(--color-warning-soft);color:#d97706}.table-status-badge.blocked{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.table-card-actions{margin-top:.75rem;display:flex;justify-content:center;gap:.4rem}.fnb-empty{text-align:center;padding:3rem 1.5rem;color:var(--color-text-secondary)}.fnb-empty .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.4}.fnb-empty h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text)}.fnb-empty p{font-size:var(--text-sm);max-width:320px;margin:0 auto 1.25rem}.fnb-item-card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1rem 1.25rem;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.fnb-item-card:hover{box-shadow:var(--shadow-md)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.fnb-stat-card{display:flex;align-items:center;gap:.85rem;padding:1rem 1.15rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .15s}.fnb-stat-card:hover{box-shadow:var(--shadow-md)}.fnb-stat-icon{width:42px;height:42px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.fnb-stat-value{font-size:1.35rem;font-weight:800;line-height:1.1}.fnb-stat-label{font-size:.72rem;color:var(--color-text-secondary);font-weight:500;margin-top:2px}.kds-container{display:flex;flex-direction:column;height:100vh;background:#0f0f13;color:#e4e4e7;overflow:hidden}.kds-topbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#18181b;border-bottom:1px solid #27272a;flex-shrink:0;gap:.5rem}.kds-topbar-left,.kds-topbar-right{display:flex;align-items:center;gap:.5rem}.kds-topbar-center{display:flex;align-items:center;gap:4px;background:#27272a;border-radius:8px;padding:3px}.kds-title{font-size:.95rem;font-weight:700;color:#fafafa;white-space:nowrap}.kds-badge{font-size:.68rem;font-weight:600;background:#f9731626;color:#fb923c;padding:2px 8px;border-radius:10px;white-space:nowrap}.kds-icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid #3f3f46;border-radius:6px;color:#a1a1aa;cursor:pointer;transition:all .15s}.kds-icon-btn:hover{background:#27272a;color:#fafafa;border-color:#52525b}.kds-filter-btn{padding:4px 10px;border:none;background:transparent;color:#71717a;font-size:.72rem;font-weight:600;font-family:var(--font-family);border-radius:6px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:4px;white-space:nowrap}.kds-filter-btn:hover{color:#d4d4d8}.kds-filter-btn.active{background:#3f3f46;color:#fafafa}.kds-filter-count{font-size:.62rem;background:#f9731640;color:#fb923c;padding:0 5px;border-radius:8px;min-width:16px;text-align:center}.kds-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#52525b}.kds-empty p{font-size:1rem;font-weight:500}.kds-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.65rem;padding:.65rem;overflow-y:auto;align-content:start}.kds-ticket{border-radius:10px;border:1px solid #27272a;border-top:4px solid #52525b;display:flex;flex-direction:column;overflow:hidden;transition:transform .12s;animation:kdsSlideIn .2s ease-out}@keyframes kdsSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.kds-ticket-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem .7rem}.kds-ticket-id{display:flex;align-items:baseline;gap:.4rem}.kds-order-num{font-size:1.1rem;font-weight:800;color:#fafafa;font-family:var(--font-mono, monospace)}.kds-order-label{font-size:.72rem;color:#a1a1aa;font-weight:600}.kds-ticket-timer{display:flex;align-items:center;gap:3px;font-size:.75rem;font-weight:700;font-family:var(--font-mono, monospace)}.kds-status-ribbon{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;text-align:center;padding:2px 0}.kds-ticket-items{padding:0 .5rem;flex:1}.kds-item{padding:.4rem .25rem;border-bottom:1px solid #27272a;cursor:pointer;transition:background .12s;position:relative}.kds-item:last-child{border-bottom:none}.kds-item:hover:not(.done){background:#ffffff08}.kds-item.done{opacity:.4;text-decoration:line-through;cursor:default}.kds-item-main{display:flex;align-items:baseline;gap:.35rem}.kds-item-qty{font-size:1rem;font-weight:800;color:#fafafa;min-width:24px;font-family:var(--font-mono, monospace)}.kds-item-name{font-size:.82rem;font-weight:600;color:#e4e4e7}.kds-item-portion{font-size:.65rem;color:#71717a;font-weight:500}.kds-item-mods{display:flex;flex-wrap:wrap;gap:3px;padding-left:28px;margin-top:2px}.kds-mod{font-size:.62rem;background:#6366f126;color:#a5b4fc;padding:1px 5px;border-radius:4px;font-weight:500}.kds-item-note{font-size:.68rem;color:#fbbf24;padding-left:28px;margin-top:2px;font-weight:500}.kds-item-check{position:absolute;right:4px;top:50%;transform:translateY(-50%);color:#22c55e}.kds-order-note{padding:.35rem .7rem;font-size:.7rem;color:#fbbf24;background:#fbbf240f;border-top:1px solid #27272a;font-weight:500}.kds-bump-btn{display:block;width:100%;padding:.55rem;border:none;color:#fff;font-size:.78rem;font-weight:700;font-family:var(--font-family);text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:all .12s}.kds-bump-btn:hover{filter:brightness(1.15)}.kds-bump-btn:active{transform:scale(.98)}:root{--gp-primary: #c8a97e;--gp-primary-dark: #b08d60;--gp-primary-light: #dfc9a8;--gp-accent: #8b7355;--gp-bg: #0c0e14;--gp-surface: #161821;--gp-surface-2: #1e2130;--gp-surface-3: #262938;--gp-border: rgba(200, 169, 126, .12);--gp-border-light: rgba(255, 255, 255, .06);--gp-text: #e8e4dd;--gp-text-muted: #9a9590;--gp-text-bright: #fff;--gp-success: #6bc9a6;--gp-warning: #e5b567;--gp-danger: #e07070;--gp-info: #7ba4db;--gp-radius: 16px;--gp-radius-sm: 10px;--gp-radius-xs: 6px;--gp-font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--gp-mono: "JetBrains Mono", monospace}.gp-auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gp-bg);background-image:radial-gradient(at 30% 60%,rgba(200,169,126,.08) 0%,transparent 50%),radial-gradient(at 70% 30%,rgba(139,115,85,.06) 0%,transparent 50%);padding:24px;font-family:var(--gp-font)}.gp-auth-card{text-align:center;max-width:400px;width:100%}.gp-auth-card .gp-logo-mark{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--gp-primary),var(--gp-accent));display:inline-flex;align-items:center;justify-content:center;color:#0c0e14;margin-bottom:20px}.gp-auth-card h1{font-size:24px;color:var(--gp-text-bright);margin:0 0 6px;font-weight:700;letter-spacing:-.5px}.gp-auth-card p{color:var(--gp-text-muted);font-size:14px;margin:0 0 24px;line-height:1.5}.gp-auth-spinner{display:flex;flex-direction:column;align-items:center;gap:16px;color:var(--gp-text-muted);font-size:14px}.gp-auth-error{background:#e070701a;border:1px solid rgba(224,112,112,.2);border-radius:var(--gp-radius-sm);padding:16px;color:var(--gp-danger);margin-top:16px;font-size:14px;line-height:1.5}.gp-shell{min-height:100vh;background:var(--gp-bg);color:var(--gp-text);font-family:var(--gp-font);display:flex;flex-direction:column}.gp-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:60px;background:var(--gp-surface);border-bottom:1px solid var(--gp-border-light);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.gp-header-left{display:flex;align-items:center;gap:10px}.gp-header-logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--gp-primary),var(--gp-accent));display:flex;align-items:center;justify-content:center;color:#0c0e14}.gp-header-info h3{font-size:14px;margin:0;color:var(--gp-text-bright);font-weight:600}.gp-header-info span{font-size:11px;color:var(--gp-text-muted)}.gp-header-room{display:flex;align-items:center;gap:6px;padding:5px 12px;background:#c8a97e1a;border:1px solid var(--gp-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--gp-primary-light)}.gp-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--gp-surface);border-top:1px solid var(--gp-border-light);z-index:100;padding:6px 8px env(safe-area-inset-bottom,8px)}.gp-bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;text-decoration:none;font-size:10px;font-weight:500;color:var(--gp-text-muted);transition:all .2s;border-radius:8px}.gp-bottom-nav a.active{color:var(--gp-primary-light)}.gp-bottom-nav a.active svg{color:var(--gp-primary)}.gp-content{flex:1;padding:20px 20px 90px;max-width:680px;margin:0 auto;width:100%;box-sizing:border-box}.gp-page-title{margin-bottom:20px}.gp-page-title h1{font-size:22px;color:var(--gp-text-bright);margin:0 0 4px;font-weight:700;letter-spacing:-.3px}.gp-page-title p{font-size:13px;color:var(--gp-text-muted);margin:0}.gp-welcome-card{background:linear-gradient(135deg,#c8a97e1f,#8b73550f);border:1px solid var(--gp-border);border-radius:var(--gp-radius);padding:24px;margin-bottom:24px}.gp-welcome-card h1{font-size:24px;color:var(--gp-text-bright);margin:0 0 4px;font-weight:700}.gp-welcome-card .gp-welcome-subtitle{color:var(--gp-primary-light);font-size:14px;margin:0 0 16px}.gp-welcome-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.gp-welcome-meta-item{text-align:center}.gp-welcome-meta-item .label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--gp-text-muted);margin-bottom:4px}.gp-welcome-meta-item .value{font-size:14px;font-weight:600;color:var(--gp-text-bright)}.gp-quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.gp-quick-action{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 12px;background:var(--gp-surface);border:1px solid var(--gp-border-light);border-radius:var(--gp-radius);text-decoration:none;color:var(--gp-text);transition:all .2s;cursor:pointer}.gp-quick-action:hover{border-color:var(--gp-border);transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.gp-quick-action .icon-wrap{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.gp-quick-action .icon-wrap.gold{background:#c8a97e1f;color:var(--gp-primary)}.gp-quick-action .icon-wrap.green{background:#6bc9a61f;color:var(--gp-success)}.gp-quick-action .icon-wrap.blue{background:#7ba4db1f;color:var(--gp-info)}.gp-quick-action .icon-wrap.amber{background:#e5b5671f;color:var(--gp-warning)}.gp-quick-action span{font-size:13px;font-weight:600}.gp-card{background:var(--gp-surface);border:1px solid var(--gp-border-light);border-radius:var(--gp-radius);overflow:hidden;margin-bottom:16px}.gp-card-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--gp-border-light)}.gp-card-header h3{font-size:15px;margin:0;color:var(--gp-text-bright);font-weight:600;display:flex;align-items:center;gap:8px}.gp-card-body{padding:20px}.gp-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--gp-border-light)}.gp-detail-row:last-child{border-bottom:none}.gp-detail-row .label{font-size:13px;color:var(--gp-text-muted)}.gp-detail-row .value{font-size:13px;color:var(--gp-text-bright);font-weight:500;text-align:right}.gp-detail-row .value.mono{font-family:var(--gp-mono);letter-spacing:-.5px}.gp-detail-row.total{border-top:2px solid var(--gp-border);padding-top:14px;margin-top:4px}.gp-detail-row.total .label,.gp-detail-row.total .value{font-size:16px;font-weight:700;color:var(--gp-primary-light)}.gp-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.gp-badge.placed,.gp-badge.open{background:#7ba4db1f;color:var(--gp-info)}.gp-badge.confirmed{background:#c8a97e1f;color:var(--gp-primary)}.gp-badge.preparing{background:#e5b5671f;color:var(--gp-warning)}.gp-badge.ready{background:#6bc9a626;color:var(--gp-success)}.gp-badge.delivered,.gp-badge.resolved,.gp-badge.closed{background:#6bc9a61f;color:var(--gp-success)}.gp-badge.cancelled{background:#e070701f;color:var(--gp-danger)}.gp-badge.inprogress{background:#e5b5671f;color:var(--gp-warning)}.gp-badge.settled{background:#94a3b81f;color:var(--gp-text-muted)}.gp-categories{display:flex;gap:8px;overflow-x:auto;padding-bottom:12px;margin-bottom:16px;-webkit-overflow-scrolling:touch}.gp-categories::-webkit-scrollbar{display:none}.gp-category-chip{padding:8px 16px;background:var(--gp-surface);border:1px solid var(--gp-border-light);border-radius:20px;font-size:12px;font-weight:600;color:var(--gp-text-muted);white-space:nowrap;cursor:pointer;transition:all .2s}.gp-category-chip:hover{border-color:var(--gp-border)}.gp-category-chip.active{background:#c8a97e1f;border-color:var(--gp-primary);color:var(--gp-primary-light)}.gp-menu-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--gp-border-light);align-items:flex-start}.gp-menu-item:last-child{border-bottom:none}.gp-menu-item-info{flex:1;min-width:0}.gp-menu-item-info h4{font-size:14px;margin:0 0 4px;color:var(--gp-text-bright);font-weight:600}.gp-menu-item-info .desc{font-size:12px;color:var(--gp-text-muted);margin:0 0 6px;line-height:1.4}.gp-menu-item-tags{display:flex;gap:4px;flex-wrap:wrap}.gp-diet-tag{display:inline-flex;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.gp-diet-tag.veg{background:#6bc9a626;color:var(--gp-success)}.gp-diet-tag.non-veg{background:#e0707026;color:var(--gp-danger)}.gp-diet-tag.vegan{background:#6bc9a633;color:#4ade80}.gp-diet-tag.jain{background:#e5b56726;color:var(--gp-warning)}.gp-diet-tag.gf{background:#7ba4db26;color:var(--gp-info)}.gp-menu-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.gp-menu-item-price{font-size:14px;font-weight:700;color:var(--gp-primary-light);font-family:var(--gp-mono)}.gp-add-btn{width:32px;height:32px;border-radius:8px;background:#c8a97e1f;border:1px solid var(--gp-border);color:var(--gp-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:18px;font-weight:600}.gp-add-btn:hover{background:#c8a97e33;transform:scale(1.05)}.gp-qty-control{display:flex;align-items:center;gap:0;border-radius:8px;overflow:hidden;border:1px solid var(--gp-border)}.gp-qty-control button{width:30px;height:30px;background:var(--gp-surface-2);border:none;color:var(--gp-primary);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.gp-qty-control span{width:28px;text-align:center;font-size:13px;font-weight:600;color:var(--gp-text-bright);background:var(--gp-surface-3)}.gp-cart-bar{position:fixed;bottom:70px;left:16px;right:16px;max-width:648px;margin:0 auto;background:var(--gp-primary);color:#0c0e14;border-radius:14px;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;box-shadow:0 8px 32px #c8a97e4d;z-index:90;transition:transform .2s}.gp-cart-bar:hover{transform:translateY(-2px)}.gp-cart-bar .cart-info{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px}.gp-cart-bar .cart-count{width:24px;height:24px;background:#0003;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.gp-cart-bar .cart-total{font-size:16px;font-weight:700;font-family:var(--gp-mono)}.gp-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--gp-radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-family:var(--gp-font)}.gp-btn-primary{background:linear-gradient(135deg,var(--gp-primary),var(--gp-primary-dark));color:#0c0e14;width:100%}.gp-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.gp-btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.gp-btn-ghost{background:transparent;border:1px solid var(--gp-border);color:var(--gp-text)}.gp-btn-ghost:hover{border-color:var(--gp-primary);color:var(--gp-primary-light)}.gp-form-group{margin-bottom:16px}.gp-form-group label{display:block;font-size:11px;font-weight:600;color:var(--gp-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.gp-form-group select,.gp-form-group textarea,.gp-form-group input{width:100%;padding:12px 14px;background:var(--gp-surface-2);border:1px solid var(--gp-border-light);border-radius:var(--gp-radius-xs);color:var(--gp-text);font-size:14px;font-family:var(--gp-font);outline:none;transition:border-color .2s;box-sizing:border-box}.gp-form-group select:focus,.gp-form-group textarea:focus,.gp-form-group input:focus{border-color:var(--gp-primary)}.gp-form-group textarea{min-height:100px;resize:vertical}.gp-order-card{background:var(--gp-surface);border:1px solid var(--gp-border-light);border-radius:var(--gp-radius);padding:16px;margin-bottom:12px;transition:border-color .2s}.gp-order-card:hover{border-color:var(--gp-border)}.gp-order-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.gp-order-card-header .order-num{font-size:13px;font-weight:600;color:var(--gp-text-bright);font-family:var(--gp-mono)}.gp-order-items-summary{font-size:12px;color:var(--gp-text-muted);margin-bottom:8px;line-height:1.5}.gp-order-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--gp-text-muted)}.gp-order-footer .total{font-family:var(--gp-mono);color:var(--gp-primary-light);font-weight:600}.gp-sr-card{background:var(--gp-surface);border:1px solid var(--gp-border-light);border-radius:var(--gp-radius);padding:16px;margin-bottom:12px}.gp-sr-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.gp-sr-card-header .sr-num{font-size:12px;font-family:var(--gp-mono);color:var(--gp-text-muted)}.gp-sr-card h4{font-size:14px;margin:0 0 6px;color:var(--gp-text-bright)}.gp-sr-card p{font-size:13px;color:var(--gp-text-muted);margin:0;line-height:1.5}.gp-pref-section{margin-bottom:24px}.gp-pref-section h3{font-size:14px;color:var(--gp-text-bright);margin:0 0 12px;display:flex;align-items:center;gap:8px}.gp-pref-tags{display:flex;flex-wrap:wrap;gap:8px}.gp-pref-tag{padding:6px 14px;background:var(--gp-surface-2);border:1px solid var(--gp-border-light);border-radius:20px;font-size:12px;color:var(--gp-text);cursor:pointer;transition:all .2s}.gp-pref-tag.selected{background:#c8a97e1f;border-color:var(--gp-primary);color:var(--gp-primary-light)}.gp-empty{text-align:center;padding:48px 20px;color:var(--gp-text-muted)}.gp-empty svg{margin-bottom:12px;opacity:.3}.gp-empty h3{color:var(--gp-text-bright);margin:0 0 6px;font-size:16px}.gp-empty p{font-size:13px;margin:0}.gp-loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--gp-text-muted);gap:10px}@keyframes gp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gp-spin{animation:gp-spin 1s linear infinite}.gp-expired-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--gp-bg);color:var(--gp-text);font-family:var(--gp-font);text-align:center;padding:24px}.gp-expired-page svg{opacity:.3;margin-bottom:16px}.gp-expired-page h2{font-size:20px;margin:0 0 8px;color:var(--gp-text-bright)}.gp-expired-page p{font-size:14px;color:var(--gp-text-muted);max-width:360px;line-height:1.6}@media(min-width:768px){.gp-content{padding:28px 32px 100px}.gp-quick-actions,.gp-welcome-meta{grid-template-columns:repeat(4,1fr)}}:root{--color-brand: #04adef;--color-brand-hover: #039ad6;--color-brand-light: #e8f7fe;--color-brand-soft: rgba(4, 173, 239, .08);--color-brand-gradient: linear-gradient(135deg, #04adef 0%, #0295d6 100%);color-scheme:light;--color-bg: #f8fafb;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f9;--color-bg-card: #ffffff;--color-bg-card-hover: #fafbfc;--color-bg-input: #ffffff;--color-bg-overlay: rgba(15, 23, 42, .3);--color-border: #e2e8f0;--color-border-hover: #cbd5e1;--color-border-focus: rgba(4, 173, 239, .45);--color-text: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-text-inverse: #ffffff;--color-primary: #04adef;--color-primary-hover: #039ad6;--color-primary-soft: rgba(4, 173, 239, .08);--color-primary-gradient: linear-gradient(135deg, #04adef 0%, #0295d6 100%);--color-success: #10b981;--color-success-soft: #ecfdf5;--color-warning: #f59e0b;--color-warning-soft: #fffbeb;--color-danger: #ef4444;--color-danger-soft: #fef2f2;--color-info: #04adef;--color-info-soft: #e8f7fe;--font-family: "Inter", -apple-system, system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--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;--space-20: 5rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(4, 173, 239, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;background-color:transparent}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text);line-height:var(--leading-normal);font-size:var(--text-base);min-height:100vh}#root{background-color:var(--color-bg);min-height:100vh}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}input,select,textarea,button{color-scheme:light;color:var(--color-text)}input,select,textarea{background-color:var(--color-bg-input)}.form-input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--text-sm);color:var(--color-text);background:var(--color-bg-input);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-soft)}.form-input::placeholder{color:var(--color-text-muted)}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.03em;font-size:var(--text-xs)}.form-group{display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-tight);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-card-hover);border-color:var(--color-border-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-primary-soft);color:var(--color-primary)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-md)}.input,.select,.textarea{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-family);font-size:var(--text-sm);transition:all var(--transition-fast);outline:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-soft)}.input::placeholder{color:var(--color-text-muted)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-hover)}.table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-card);box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse}th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);border-bottom:1px solid var(--color-border)}tr:hover td{background:var(--color-bg-tertiary)}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.02em}.badge-success{background:var(--color-success-soft);color:#059669}.badge-warning{background:var(--color-warning-soft);color:#d97706}.badge-danger{background:var(--color-danger-soft);color:#dc2626}.badge-info{background:var(--color-info-soft);color:#0284c7}.badge-neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast)}.modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);max-width:520px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-slow)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6)}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text)}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:2000;display:flex;flex-direction:column;gap:var(--space-2)}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);box-shadow:var(--shadow-lg);animation:slideIn var(--transition-base);max-width:400px;display:flex;align-items:center;gap:var(--space-3)}.toast-success{background:var(--color-success-soft);border:1px solid #a7f3d0;color:#059669}.toast-error{background:var(--color-danger-soft);border:1px solid #fecaca;color:#dc2626}.toast-info{background:var(--color-info-soft);border:1px solid #bae6fd;color:#0284c7}.page{padding:var(--space-8);overflow-x:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);min-width:0;gap:var(--space-3)}.page-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text)}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-secondary)}.text-sm{font-size:var(--text-sm)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.spin{animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);color:var(--color-text-muted);text-align:center;gap:var(--space-4)}.empty-state-icon{opacity:.4}
