@import"https://fonts.googleapis.com/css2?family=Prompt:wght@300;400;500;600;700&family=Noto+Sans+Thai:wght@300;400;500;600;700&display=swap";:root{--color-primary: #1a365d;--color-primary-light: #2c5282;--color-primary-dark: #0f2744;--color-secondary: #319795;--color-secondary-light: #38b2ac;--color-secondary-dark: #285e5d;--color-accent: #ed8936;--color-success: #38a169;--color-warning: #ecc94b;--color-danger: #e53e3e;--color-info: #3182ce;--color-white: #ffffff;--color-gray-50: #f7fafc;--color-gray-100: #edf2f7;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e0;--color-gray-400: #a0aec0;--color-gray-500: #718096;--color-gray-600: #4a5568;--color-gray-700: #2d3748;--color-gray-800: #1a202c;--color-gray-900: #171923;--status-available: #38a169;--status-occupied: #e53e3e;--status-maintenance: #ecc94b;--status-reserved: #805ad5;--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-family: "Prompt", "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-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-800);background-color:var(--color-gray-50);min-height:100vh}#root{min-height:100vh}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}img{max-width:100%;height:auto}.app-layout{display:flex;min-height:100vh}.sidebar{width:250px;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);position:fixed;top:0;left:0;height:100vh;padding:var(--space-6);display:flex;flex-direction:column;z-index:100;transition:transform var(--transition-normal)}.sidebar-header{margin-bottom:var(--space-8);text-align:center;padding-bottom:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1)}.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)}.sidebar-logo svg{width:32px;height:32px}.sidebar-nav{flex:1}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:#fffc;border-radius:var(--radius-md);margin-bottom:var(--space-1);transition:all var(--transition-fast);font-weight:500}.nav-item:hover,.nav-item.active{background-color:#ffffff26;color:var(--color-white)}.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,.1)}.user-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:#ffffff1a;border-radius:var(--radius-md)}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-secondary);display:flex;align-items:center;justify-content:center;font-weight:600;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:250px;padding:var(--space-6);min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.page-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary)}.card{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-6);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-lg)}.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(--color-gray-200)}.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:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md);display:flex;align-items:flex-start;gap:var(--space-4);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.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),#f6e05e)}.stat-icon.danger{background:linear-gradient(135deg,var(--color-danger),#fc8181)}.stat-content{flex: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:500;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-primary),var(--color-primary-light));color:var(--color-white)}.btn-primary:hover{box-shadow:0 4px 12px #1a365d66;transform:translateY(-1px)}.btn-secondary{background:linear-gradient(135deg,var(--color-secondary),var(--color-secondary-light));color:var(--color-white)}.btn-secondary:hover{box-shadow:0 4px 12px #31979566;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,var(--color-success),#48bb78);color:var(--color-white)}.btn-danger{background:linear-gradient(135deg,var(--color-danger),#fc8181);color:var(--color-white)}.btn-outline{background:transparent;border:2px solid var(--color-gray-300);color:var(--color-gray-700)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.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:500;color:var(--color-gray-700);margin-bottom:var(--space-2)}.form-input,.form-select,.form-textarea{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(--color-white);border:2px solid var(--color-gray-200);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{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a365d1a}.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-lg);background-color:var(--color-white);box-shadow:var(--shadow-md)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--space-4);text-align:left;border-bottom:1px solid var(--color-gray-100)}.table th{background-color:var(--color-gray-50);font-weight:600;color:var(--color-gray-700);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--color-gray-50)}.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:600;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge-available{background-color:#38a16926;color:var(--status-available)}.badge-occupied{background-color:#e53e3e26;color:var(--status-occupied)}.badge-maintenance{background-color:#ecc94b26;color:#b7791f}.badge-reserved{background-color:#805ad526;color:var(--status-reserved)}.badge-success{background-color:#38a16926;color:var(--color-success)}.badge-warning{background-color:#ecc94b26;color:#b7791f}.badge-danger{background-color:#e53e3e26;color:var(--color-danger)}.badge-info{background-color:#3182ce26;color:var(--color-info)}.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(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.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(--color-gray-200)}.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(--color-gray-200)}.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(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:300px;animation:slideIn .3s ease}.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)}.search-input-wrapper{position:relative;flex:1;max-width:400px}.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:2px solid var(--color-gray-200);border-radius:var(--radius-full);transition:border-color var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary)}.filter-group{display:flex;gap:var(--space-3)}.filter-select{padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--font-size-sm);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);background-color:var(--color-white);cursor:pointer}.tabs{display:flex;gap:var(--space-1);border-bottom:2px solid var(--color-gray-200);margin-bottom:var(--space-6)}.tab{padding:var(--space-3) var(--space-5);font-weight:500;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-color:var(--color-primary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);padding:var(--space-4)}.login-card{background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-10);width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-2)}.login-subtitle{color:var(--color-gray-500);font-size:var(--font-size-sm)}.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)}}.mobile-toggle{display:none;position:fixed;top:var(--space-4);left:var(--space-4);z-index:200;background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer}.mobile-toggle svg{width:24px;height:24px}@media(max-width:768px){.sidebar{transform:translate(-100%)}.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}.search-bar{flex-direction:column;align-items:stretch}.search-input-wrapper{max-width:100%}.filter-group{flex-wrap:wrap}.modal{margin:var(--space-4)}.table th,.table td{padding:var(--space-3);font-size:var(--font-size-sm)}}@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-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)}.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}
