@import"https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700&family=Noto+Sans+Thai:wght@300;400;500;600;700&family=Noto+Serif+Thai:wght@400;600;700&display=swap";:root{--color-primary: #0b1b2b;--color-primary-light: #1d3557;--color-primary-dark: #07121c;--color-secondary: #c9a14a;--color-secondary-light: #e3c37c;--color-secondary-dark: #9b7b34;--color-accent: #e07a5f;--color-success: #2f9e6f;--color-warning: #d9a441;--color-danger: #d65b5b;--color-info: #3d8ccf;--color-white: #ffffff;--color-gray-50: #f8f5ef;--color-gray-100: #f1ece4;--color-gray-200: #e4ddcf;--color-gray-300: #d2c8ba;--color-gray-400: #b5a895;--color-gray-500: #8c7f6f;--color-gray-600: #6c5f52;--color-gray-700: #4c4238;--color-gray-800: #2a231f;--color-gray-900: #1a1512;--status-available: #2f9e6f;--status-occupied: #d65b5b;--status-maintenance: #d9a441;--status-reserved: #7b83a6;--surface: #ffffff;--surface-muted: #fdfaf4;--surface-raised: #ffffff;--surface-glass: rgba(255, 255, 255, .72);--border-subtle: rgba(11, 27, 43, .12);--border-strong: rgba(11, 27, 43, .22);--shadow-sm: 0 6px 16px rgba(11, 27, 43, .08);--shadow-md: 0 16px 32px rgba(11, 27, 43, .12);--shadow-lg: 0 28px 56px rgba(11, 27, 43, .18);--shadow-xl: 0 40px 100px rgba(11, 27, 43, .22);--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;--font-body: "Manrope", "Noto Sans Thai", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Noto Serif Thai", "Noto Sans Thai", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--sidebar-width: 270px}[data-theme=dark]{--color-primary: #cdd9e5;--color-primary-light: #e6eef7;--color-primary-dark: #8aa0b3;--color-secondary: #e0c178;--color-secondary-light: #f0d7a1;--color-secondary-dark: #b89445;--color-accent: #f0a37a;--color-success: #63c69a;--color-warning: #f0c36a;--color-danger: #f29a9a;--color-info: #7dc1ff;--color-white: #0b1118;--color-gray-50: #0f1720;--color-gray-100: #131d28;--color-gray-200: #1b2633;--color-gray-300: #2b3a4b;--color-gray-400: #3d4c5d;--color-gray-500: #9aa9b6;--color-gray-600: #b8c6d1;--color-gray-700: #d6e0ea;--color-gray-800: #eef4f8;--color-gray-900: #f8fbff;--status-available: #63c69a;--status-occupied: #f29a9a;--status-maintenance: #f0c36a;--status-reserved: #9aa5d6;--surface: #111a22;--surface-muted: #0f1820;--surface-raised: #16212b;--surface-glass: rgba(18, 27, 36, .7);--border-subtle: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .22)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background-color:var(--color-gray-50);background-image:radial-gradient(900px 400px at 10% -10%,rgba(201,161,74,.18),transparent 60%),radial-gradient(800px 400px at 90% 0%,rgba(11,27,43,.12),transparent 65%),linear-gradient(180deg,var(--color-gray-50) 0%,var(--color-gray-100) 100%);min-height:100vh}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(circle at 20% 20%,rgba(201,161,74,.12) 0,transparent 55%),radial-gradient(circle at 80% 10%,rgba(11,27,43,.08) 0,transparent 60%),repeating-linear-gradient(120deg,rgba(11,27,43,.03) 0,rgba(11,27,43,.03) 1px,transparent 1px,transparent 12px);opacity:.7;z-index:0}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:.02em}#root{min-height:100vh;position:relative;z-index:1}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-secondary)}img{max-width:100%;height:auto}.app-layout{display:flex;min-height:100vh;position:relative}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,#0b1b2bf5,#07121cfa),radial-gradient(circle at 20% 0%,rgba(201,161,74,.25),transparent 55%);color:var(--color-white);position:fixed;top:0;left:0;height:100vh;padding:calc(var(--space-5) + env(safe-area-inset-top)) var(--space-5) calc(var(--space-5) + env(safe-area-inset-bottom));display:flex;flex-direction:column;z-index:100;transition:transform .22s ease;overscroll-behavior:contain;border-right:1px solid rgba(255,255,255,.08);box-shadow:12px 0 40px #07121c59}.sidebar-header{margin-bottom:var(--space-8);text-align:center;padding-bottom:var(--space-6);border-bottom:1px solid rgba(255,255,255,.12)}.sidebar-logo{font-size:var(--font-size-xl);font-weight:700;color:var(--color-white);display:flex;align-items:center;justify-content:center;gap:var(--space-2);text-transform:uppercase;letter-spacing:.08em}.sidebar-logo-text{font-family:var(--font-display);font-weight:600}.sidebar-logo svg{width:32px;height:32px}.sidebar-nav{flex:1;overflow-y:auto;scroll-behavior:smooth;padding-right:var(--space-2);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.4) transparent;-webkit-overflow-scrolling:touch}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background-color:#ffffff59;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-overlay{position:fixed;inset:0;background-color:#07121cb3;z-index:90;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .2s ease}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:#ffffffc7;border-radius:var(--radius-lg);margin-bottom:var(--space-1);transition:all var(--transition-fast);font-weight:500;border:1px solid transparent}.nav-item:hover,.nav-item.active{background:linear-gradient(90deg,#c9a14a38,#c9a14a0d);color:var(--color-white);border-color:#c9a14a66}.nav-item svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.12)}.user-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:#ffffff14;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.12)}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light));color:#1b1612;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.user-details{flex:1}.user-name{font-weight:600;font-size:var(--font-size-sm)}.user-role{font-size:var(--font-size-xs);color:#ffffffb3}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-8);min-height:100vh;position:relative;z-index:1}.top-actions{position:fixed;top:calc(max(0px,env(safe-area-inset-top)) + 8px);right:calc(max(0px,env(safe-area-inset-right)) + 8px);display:flex;gap:var(--space-2);z-index:210}.top-action{width:36px;height:36px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--surface-glass);color:var(--color-primary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.top-action svg{width:16px;height:16px}.top-action:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.top-action.active{background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light));color:#1b1612;border-color:#c9a14a80}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.page-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary)}.card{background-color:var(--surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);padding:var(--space-6);transition:box-shadow var(--transition-fast),transform var(--transition-fast);border:1px solid var(--border-subtle)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-800)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.stat-card{background:linear-gradient(135deg,var(--surface) 0%,var(--surface-muted) 100%);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;gap:var(--space-4);transition:transform var(--transition-fast),box-shadow var(--transition-fast);border:1px solid var(--border-subtle);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(201,161,74,.18),transparent 55%);opacity:.5;pointer-events:none}.stats-grid>.stat-card{animation:rise .45s ease both}.stats-grid>.stat-card:nth-child(2){animation-delay:80ms}.stats-grid>.stat-card:nth-child(3){animation-delay:.16s}.stats-grid>.stat-card:nth-child(4){animation-delay:.24s}.stats-grid>.stat-card:nth-child(5){animation-delay:.32s}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm)}.stat-icon svg{width:24px;height:24px;color:var(--color-white)}.stat-icon.primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light))}.stat-icon.secondary{background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light))}.stat-icon.success{background:linear-gradient(135deg,var(--color-success),#48bb78)}.stat-icon.warning{background:linear-gradient(135deg,var(--color-warning),#f6d365)}.stat-icon.danger{background:linear-gradient(135deg,var(--color-danger),#f68f8f)}.stat-content{flex:1;position:relative;z-index:1}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-gray-800);line-height:1.2}.stat-label{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--space-1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:inherit;font-size:var(--font-size-sm);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn svg{width:18px;height:18px}.btn-primary{background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light));color:#1b1612;box-shadow:0 8px 20px #c9a14a40}.btn-primary:hover{box-shadow:0 12px 26px #c9a14a59;transform:translateY(-1px)}.btn-secondary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-white)}.btn-secondary:hover{box-shadow:0 10px 24px #0b1b2b59;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,var(--color-success),#48bb78);color:var(--color-white)}.btn-warning{background:linear-gradient(135deg,var(--color-warning),#f6d365);color:#2a231f}.btn-info{background:linear-gradient(135deg,var(--color-info),#7dc1ff);color:#08131c}.btn-danger{background:linear-gradient(135deg,var(--color-danger),#f68f8f);color:var(--color-white)}.btn-outline{background:transparent;border:1px solid var(--border-strong);color:var(--color-gray-700)}.btn-outline:hover{border-color:var(--color-secondary);color:var(--color-secondary)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-700);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea,.filter-input{width:100%;padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--font-size-base);color:var(--color-gray-800);background-color:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus,.filter-input:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #c9a14a2e}.form-input::placeholder{color:var(--color-gray-400)}.form-input.error{border-color:var(--color-danger)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-1)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.table-container{overflow-x:auto;border-radius:var(--radius-xl);background-color:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-4);text-align:left;border-bottom:1px solid var(--border-subtle)}.table th{background-color:var(--surface-muted);font-weight:600;color:var(--color-gray-700);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:#c9a14a14}.table-actions{display:flex;gap:var(--space-2)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:700;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;border:1px solid transparent}.badge-available{background-color:#2f9e6f26;color:var(--status-available);border-color:#2f9e6f59}.badge-occupied{background-color:#d65b5b26;color:var(--status-occupied);border-color:#d65b5b59}.badge-maintenance{background-color:#d9a44126;color:#b27622;border-color:#d9a44159}.badge-reserved{background-color:#7b83a626;color:var(--status-reserved);border-color:#7b83a659}.badge-success{background-color:#2f9e6f26;color:var(--color-success);border-color:#2f9e6f59}.badge-warning{background-color:#d9a4412e;color:#b27622;border-color:#d9a44159}.badge-danger{background-color:#d65b5b26;color:var(--color-danger);border-color:#d65b5b59}.badge-info{background-color:#3d8ccf26;color:var(--color-info);border-color:#3d8ccf59}.badge-primary{background-color:#0b1b2b1f;color:var(--color-primary);border-color:#0b1b2b40}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:var(--space-4)}.room-card{position:relative;overflow:hidden;padding:var(--space-4);border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--room-accent-bg, rgba(11, 27, 43, .04)) 0%,var(--surface) 58%);border:1px solid var(--room-accent-border, var(--border-subtle));box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3);min-height:120px;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.room-card:before{content:"";position:absolute;inset:0;background:radial-gradient(120px 80px at 100% 0%,var(--room-accent-glow, rgba(11, 27, 43, .08)),transparent 60%);opacity:.7;pointer-events:none}.room-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.room-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2)}.room-card-head{display:grid;gap:2px}.room-number{font-weight:700;font-size:var(--font-size-2xl);color:var(--room-accent, var(--color-primary))}.room-type{font-size:var(--font-size-xs);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.room-status-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;background-color:var(--room-accent-bg, rgba(11, 27, 43, .08));color:var(--room-accent, var(--color-primary));border:1px solid var(--room-accent-border, var(--border-subtle))}.room-status-dot{width:8px;height:8px;border-radius:var(--radius-full);background-color:var(--room-accent, var(--color-primary));box-shadow:0 0 0 3px #0b1b2b14}.room-resident{font-size:var(--font-size-sm);color:var(--color-gray-700);display:grid;gap:4px}.room-resident-name{font-weight:600}.room-resident-phone{font-size:var(--font-size-xs);color:var(--color-gray-500)}.room-resident.is-empty{color:var(--color-gray-400)}.room-resident.is-empty .room-resident-name{font-weight:600;color:var(--color-gray-500)}.room-card-available{--room-accent: var(--status-available);--room-accent-bg: rgba(47, 158, 111, .12);--room-accent-border: rgba(47, 158, 111, .35);--room-accent-glow: rgba(47, 158, 111, .18)}.room-card-occupied{--room-accent: var(--status-occupied);--room-accent-bg: rgba(214, 91, 91, .12);--room-accent-border: rgba(214, 91, 91, .35);--room-accent-glow: rgba(214, 91, 91, .18)}.room-card-maintenance{--room-accent: #b27622;--room-accent-bg: rgba(217, 164, 65, .16);--room-accent-border: rgba(217, 164, 65, .4);--room-accent-glow: rgba(217, 164, 65, .2)}.room-card-reserved{--room-accent: var(--status-reserved);--room-accent-bg: rgba(123, 131, 166, .12);--room-accent-border: rgba(123, 131, 166, .35);--room-accent-glow: rgba(123, 131, 166, .18)}.split-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6);margin-bottom:var(--space-6)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);animation:fadeIn .2s ease}.modal{background-color:var(--surface);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;border:1px solid var(--border-subtle)}.modal-lg{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6);border-bottom:1px solid var(--border-subtle)}.modal-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-gray-800)}.modal-close{background:none;border:none;cursor:pointer;padding:var(--space-2);color:var(--color-gray-500);transition:color var(--transition-fast)}.modal-close:hover{color:var(--color-gray-800)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-subtle)}.toast-container{position:fixed;top:var(--space-6);right:var(--space-6);z-index:1100;display:flex;flex-direction:column;gap:var(--space-3)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;animation:slideIn .3s ease;border:1px solid var(--border-subtle)}.toast-success{border-left:4px solid var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-icon{width:24px;height:24px;flex-shrink:0}.toast-message{flex:1;font-size:var(--font-size-sm)}.toast-close{background:none;border:none;cursor:pointer;padding:var(--space-1);color:var(--color-gray-400)}.search-bar{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.search-input-wrapper{position:relative;flex:1;min-width:220px;max-width:420px}.search-input-wrapper svg{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--color-gray-400)}.search-input{width:100%;padding:var(--space-3) var(--space-4) var(--space-3) var(--space-12);font-family:inherit;font-size:var(--font-size-base);border:1px solid var(--border-subtle);border-radius:var(--radius-full);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background-color:var(--surface)}.search-input:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #c9a14a2e}.filter-group{display:flex;gap:var(--space-3);flex-wrap:wrap}.filter-select{padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--font-size-sm);border:1px solid var(--border-subtle);border-radius:var(--radius-md);background-color:var(--surface);cursor:pointer}.tabs{display:flex;gap:var(--space-2);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-5);font-weight:600;color:var(--color-gray-500);background:none;border:none;cursor:pointer;position:relative;transition:color var(--transition-fast)}.tab:hover{color:var(--color-gray-700)}.tab.active{color:var(--color-primary)}.tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-secondary),transparent)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 20%,rgba(201,161,74,.35),transparent 55%),radial-gradient(circle at 80% 0%,rgba(11,27,43,.35),transparent 60%),linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:var(--space-4)}.login-card{background-color:var(--surface-glass);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-10);width:100%;max-width:440px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:var(--color-white)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-white);margin-bottom:var(--space-2);display:flex;align-items:center;justify-content:center;gap:var(--space-3);letter-spacing:.08em;text-transform:uppercase}.login-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-lg);background:#ffffff26;color:var(--color-secondary-light)}.login-subtitle{color:#ffffffbf;font-size:var(--font-size-sm)}.login-error{margin-bottom:var(--space-4);text-align:center}.login-submit{width:100%}.login-hint{margin-top:var(--space-6);padding:var(--space-4);background-color:#ffffff1f;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.2)}.login-hint p{margin-bottom:var(--space-2);color:#ffffffbf}.login-hint p:last-child{margin-bottom:0}.login-card .form-label{color:#ffffffd9}.login-card .form-input,.login-card .form-select,.login-card .form-textarea{background-color:#fffffff2}.empty-state{text-align:center;padding:var(--space-12);color:var(--color-gray-500)}.empty-state svg{width:64px;height:64px;margin-bottom:var(--space-4);color:var(--color-gray-300)}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-gray-600);margin-bottom:var(--space-2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.mobile-toggle{display:none;position:fixed;top:var(--space-4);left:var(--space-4);z-index:200;background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light));color:#1b1612;border:none;border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;box-shadow:var(--shadow-sm)}.mobile-toggle svg{width:24px;height:24px}@media(max-width:1024px){.main-content{padding:var(--space-6)}}@media(max-width:768px){.sidebar{transform:translate(-100%);width:min(90vw,340px)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:var(--space-4);padding-top:var(--space-16)}.mobile-toggle{display:flex}.page-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.stats-grid,.form-row{grid-template-columns:1fr}.modal{margin:var(--space-4)}.table th,.table td{padding:var(--space-3);font-size:var(--font-size-sm)}.split-grid{grid-template-columns:1fr}}@media(max-width:480px){.card,.stat-card{padding:var(--space-4)}.login-card{padding:var(--space-6)}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}}.text-center{text-align:center}.text-right{text-align:right}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-muted{color:var(--color-gray-500)}.font-bold{font-weight:700}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.gap-4{gap:var(--space-4)}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.grid{display:grid}.hidden{display:none}
