*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f2f1ef;--surface: #ffffff;--surface-2: #f9f8f7;--border: #e8e6e3;--border-strong: #d4d1cd;--text: #1a1917;--text-muted: #706c67;--text-light: #a39f9a;--primary: rgb(93, 0, 150);--primary-hover: rgb(72, 0, 117);--primary-light: rgb(245, 230, 255);--danger: #dc2626;--danger-light: #fef2f2;--success: #16a34a;--success-light: #f0fdf4;--warning: #d97706;--warning-light: #fffbeb;--radius: 12px;--radius-sm: 7px;--radius-lg: 16px;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.06), 0 2px 8px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);--shadow-hover: 0 8px 28px rgba(0,0,0,.1), 0 2px 8px rgba(0,0,0,.06);--t: .15s cubic-bezier(.4, 0, .2, 1)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.layout{display:flex;flex-direction:column;min-height:100vh}.topbar{display:flex;align-items:center;background:#ffffffd9;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:0 28px;height:56px;position:sticky;top:0;z-index:100;flex-shrink:0}.topbar-logo{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--text);letter-spacing:-.02em;text-decoration:none;margin-right:20px;flex-shrink:0}.topbar-logo-icon{width:28px;height:28px;background:var(--text);border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.topbar-divider{width:1px;height:16px;background:var(--border);margin:0 6px;flex-shrink:0}.topbar-nav{display:flex;align-items:center;gap:2px}.nav-item{display:flex;align-items:center;gap:7px;padding:6px 12px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:13.5px;font-weight:500;text-decoration:none;cursor:pointer;white-space:nowrap;transition:color var(--t),background var(--t);border:none;background:none}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-item svg{flex-shrink:0;transition:transform var(--t)}.nav-item:hover svg{transform:scale(1.1)}.main{flex:1;min-width:0;padding:32px 36px;width:100%;animation:fadeUp .3s ease both}.page-header{margin-bottom:28px}.page-header h1{font-size:20px;font-weight:600;letter-spacing:-.03em}.page-header p{color:var(--text-muted);margin-top:4px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:22px}.stats-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:130px 78px;gap:14px;margin-bottom:28px}.stat-bento-total{grid-column:1;grid-row:1 / 3}.stat-bento-booking{grid-column:2 / 5;grid-row:2}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;display:flex;flex-direction:column;justify-content:space-between;transition:box-shadow var(--t),transform var(--t),border-color var(--t)}.stat-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.stat-card-dark{background:var(--text);border-color:transparent}.stat-card-dark .stat-label{color:#ffffff73}.stat-card-dark .stat-value{color:#fff}.stat-card-dark .stat-sub{color:#ffffff59;font-size:12px}.stat-icon-wrap{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:14px}.stat-icon-dark{background:#ffffff1f;color:#ffffffbf}.stat-icon-available{background:var(--success-light);color:var(--success)}.stat-icon-inuse{background:var(--primary-light);color:var(--primary)}.stat-icon-maintenance{background:var(--warning-light);color:var(--warning)}.stat-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.07em}.stat-value{font-size:28px;font-weight:600;letter-spacing:-.04em;margin-top:4px;line-height:1.1}.stat-sub{font-size:11.5px;color:var(--text-light)}.stat-card-link{text-decoration:none;color:inherit;cursor:pointer}.stat-lab-usage{display:flex;align-items:center;justify-content:space-between;height:100%;gap:20px}.stat-usage-counts{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;margin-top:5px}.stat-usage-dot{color:var(--border)}.stat-lab-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.stat-lab-dot-busy{background:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.stat-lab-dot-free{background:var(--success);box-shadow:0 0 0 2px var(--success-light)}.stat-lab-slot{font-size:13px;font-weight:600;color:var(--primary);background:var(--primary-light);padding:4px 10px;border-radius:99px;flex-shrink:0}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}th{text-align:left;padding:10px 16px;font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);background:var(--surface-2)}td{padding:11px 16px;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2);transition:background .1s}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.01em}.badge-available{background:var(--success-light);color:var(--success)}.badge-in_use{background:var(--primary-light);color:var(--primary)}.badge-maintenance{background:var(--warning-light);color:var(--warning)}.badge-retired{background:var(--surface-2);color:var(--text-muted)}.badge-outside{background:#f5f0ff;color:#7c3aed}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--t);text-decoration:none;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:#5d009699;color:#fff;border:none}.btn-primary:hover{background:#5d0096d9}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--surface-2)}.btn-danger{background:var(--danger-light);color:var(--danger);border-color:#fecaca}.btn-danger:hover{background:#fee2e2}.btn-sm{padding:4px 10px;font-size:12px}.btn-ghost{background:none;border-color:transparent;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--bg)}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}label{display:block;font-size:11.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px;letter-spacing:.02em}input,select,textarea{width:100%;padding:8px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:border-color var(--t),box-shadow var(--t)}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}textarea{resize:vertical;min-height:72px}.form-hint{font-size:11.5px;color:var(--text-light);margin-top:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a090847;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #00000026,0 4px 16px #00000012;animation:fadeUp .2s ease both;border:1px solid var(--border)}.modal-header{padding:22px 24px 0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:15.5px;font-weight:600;letter-spacing:-.02em}.modal-body{padding:20px 24px}.modal-footer{padding:0 24px 22px;display:flex;justify-content:flex-end;gap:10px}.empty{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty svg{opacity:.25;margin-bottom:12px;display:block;margin-left:auto;margin-right:auto}.empty p{font-size:13.5px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.mb-4{margin-bottom:16px}.text-muted{color:var(--text-muted)}.text-sm{font-size:12.5px}.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:#fff;padding:11px 18px;border-radius:var(--radius);font-size:13.5px;z-index:200;box-shadow:var(--shadow-md);animation:slideUp .2s ease}.section-title{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.detail-item label{font-size:10.5px;color:var(--text-muted);font-weight:600;margin-bottom:3px;text-transform:uppercase;letter-spacing:.06em}.detail-item p{font-size:13.5px;color:var(--text)}.lab-booking-page{width:100%;height:calc(100vh - 120px);display:flex;flex-direction:column}.lab-booking-layout{flex:1;min-height:0;display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:stretch}.lab-calendar-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;min-height:0}.cal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.cal-month-label{font-size:14px;font-weight:600;letter-spacing:-.02em}.cal-nav-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);width:30px;height:30px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:all var(--t)}.cal-nav-btn:hover{background:var(--bg);color:var(--text);border-color:var(--border-strong)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto repeat(6,1fr);padding:10px;gap:4px;flex:1;min-height:0}.cal-dow{text-align:center;font-size:10px;font-weight:600;color:var(--text-light);padding:4px 0 6px;text-transform:uppercase;letter-spacing:.06em;align-self:start}.cal-empty{background:none;border:none;cursor:default}.cal-cell{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:6px 7px;border-radius:var(--radius-sm);cursor:pointer;border:none;background:none;text-align:left;overflow:hidden;min-height:0;transition:background var(--t),box-shadow var(--t)}.cal-cell:hover{background:var(--bg);box-shadow:var(--shadow-xs)}.cal-cell:hover .cal-day-num{color:var(--primary)}.cal-has-bookings{background:var(--surface-2)}.cal-has-bookings:hover{background:var(--bg)}.cal-day-num{font-size:12px;font-weight:500;color:var(--text-muted);line-height:1;margin-bottom:4px;flex-shrink:0}.cal-today-num{width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff!important;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;margin-bottom:4px}.cal-cell-chip{display:block;width:100%;font-size:10px;font-weight:500;background:var(--primary-light);color:var(--primary);border-radius:3px;padding:2px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;flex-shrink:0}.cal-cell-more{font-size:9.5px;color:var(--text-light);font-weight:500;padding-left:2px}.lab-form-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;display:flex;flex-direction:column;overflow-y:auto}.lab-form-title{font-size:15px;font-weight:600;margin-bottom:18px;letter-spacing:-.02em;flex-shrink:0}.lab-form{display:flex;flex-direction:column;gap:14px}.form-field{display:flex;flex-direction:column;gap:5px}.form-field label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.form-field input,.form-field textarea{padding:8px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color var(--t),box-shadow var(--t);outline:none;resize:vertical}.form-field input:focus,.form-field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-error{font-size:11.5px;color:var(--danger)}.time-select{display:flex;align-items:center;gap:4px}.time-select select{flex:1;padding:8px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color var(--t),box-shadow var(--t);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.time-select select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.time-sep{font-size:15px;font-weight:600;color:var(--text-muted)}.lab-submit-btn{width:100%;padding:10px;margin-top:4px;justify-content:center}.lab-error-banner{background:var(--danger-light, #fee2e2);color:var(--danger, #dc2626);border:1px solid #fca5a5;border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;margin-bottom:14px}.lab-success-banner{display:flex;align-items:center;gap:8px;background:var(--success-light);color:var(--success);border:1px solid #bbf7d0;border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;margin-bottom:14px;animation:fadeUp .2s ease;flex-shrink:0}.cal-modal{max-width:440px}.cal-modal-date{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px}.cal-no-bookings{font-size:13px;color:var(--text-muted);padding:8px 0}.cal-modal-list{display:flex;flex-direction:column;gap:10px}.cal-modal-item{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;animation:fadeUp .15s ease}.cal-modal-item-time{display:flex;align-items:center;gap:6px;padding:7px 12px;background:var(--primary-light);font-size:12px;font-weight:600;color:var(--primary);border-bottom:1px solid var(--border)}.cal-modal-item-body{padding:10px 12px}.cal-modal-item-name{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}.cal-modal-item-purpose{font-size:12.5px;color:var(--text-muted);line-height:1.4}
