.calendar{width:100%}.cal-header{-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.cal-nav{border:1px solid var(--border);cursor:pointer;background:var(--bg-card);width:32px;height:32px;color:var(--text-secondary);border-radius:6px;justify-content:center;align-items:center;font-size:15px;transition:all .15s;display:flex}.cal-nav:hover{border-color:var(--primary);color:var(--primary)}.cal-title{font-family:var(--font-serif);color:var(--primary);font-size:15px;font-weight:600}.cal-weekdays{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px;display:grid}.cal-wd{text-align:center;color:var(--text-muted);padding:4px 0;font-size:11px;font-weight:600}.cal-days{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-day{text-align:center;cursor:pointer;color:var(--text-secondary);font-size:13px;font-family:var(--font-sans);background:0 0;border:none;border-radius:6px;padding:7px 0;transition:all .15s}.cal-day:hover{background:var(--bg)}.cal-day.selected{background:var(--primary);color:#fff;font-weight:600}.cal-day.today{border:1px solid var(--accent)}.cal-day.other{color:#ddd;cursor:default;pointer-events:none}.cal-day:disabled{color:#ddd;cursor:default}.tp-grid{grid-template-columns:repeat(8,1fr);gap:5px;max-height:200px;padding:2px;display:grid;overflow-y:auto}.tp-opt{text-align:center;cursor:pointer;border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-card);font-size:13px;font-family:var(--font-sans);border-radius:6px;padding:7px 4px;transition:all .15s}.tp-opt:hover{border-color:var(--accent)}.tp-opt.selected{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:500}@media (width<=768px){.tp-grid{grid-template-columns:repeat(5,1fr);max-height:180px}}.admin-root{min-height:100vh;display:flex}.admin-sidebar{background:var(--primary);flex-direction:column;flex-shrink:0;width:200px;height:100vh;padding:0;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid #ffffff14;align-items:center;gap:8px;padding:16px;display:flex}.sidebar-toggle{display:none}.sidebar-brand{font-family:var(--font-serif);color:#fff;letter-spacing:.04em;font-size:17px;font-weight:600}.sidebar-brand span{color:var(--accent)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.sidebar-item{color:#fff9;font-family:var(--font-sans);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.sidebar-item:hover{color:#fff;background:#ffffff14}.sidebar-item.active{color:#fff;background:#ffffff1f}.sidebar-icon{text-align:center;flex-shrink:0;width:20px;font-size:16px}.sidebar-label{white-space:nowrap}.sidebar-footer{color:#ffffff4d;border-top:1px solid #ffffff0f;padding:12px 20px;font-size:11px}.sidebar-admin{color:#ffffff80;margin-bottom:4px;font-size:12px}.sidebar-logout{color:#fff6;cursor:pointer;font-size:11px;font-family:var(--font-sans);background:0 0;border:1px solid #ffffff26;border-radius:4px;padding:3px 10px;transition:all .15s}.sidebar-logout:hover{color:#fff;border-color:#ffffff4d}.admin-main{flex-direction:column;flex:1;min-width:0;display:flex}.admin-topbar{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.topbar-title{font-family:var(--font-serif);color:var(--primary);font-size:18px;font-weight:600}.topbar-date{color:var(--text-muted);font-size:13px}.admin-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:24px}.dash-hdr{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:16px;font-size:14px;font-weight:600;display:flex}.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.stat-num{font-family:var(--font-serif);color:var(--primary);font-size:26px;font-weight:600;line-height:1.2}.stat-lbl{color:var(--text-secondary);margin-top:2px;font-size:12px}.stat-chg{color:var(--text-muted);margin-top:2px;font-size:11px}.dash-section{margin-bottom:24px}.ds-title{color:var(--text);margin-bottom:12px;font-size:15px;font-weight:600}.ds-cards{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.ds-card{border-radius:var(--radius);padding:18px 20px}.ds-card-label{opacity:.8;margin-bottom:4px;font-size:12px}.ds-card-value{font-family:var(--font-serif);font-size:24px;font-weight:600}.dash-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.dash-table{border-collapse:collapse;width:100%;font-size:14px}.dash-table th{text-align:left;color:var(--text-muted);letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.dash-table td{border-bottom:1px solid var(--border-light);color:var(--text-secondary);vertical-align:middle;padding:12px 14px}.dash-table tr:last-child td{border-bottom:none}.dash-table-compact th{padding:7px 10px;font-size:11px}.dash-table-compact td{padding:8px 10px;font-size:13px}.dash-summary td{background:var(--bg);font-weight:600}.state-box-sm{color:var(--text-muted);justify-content:center;align-items:center;padding:24px 16px;font-size:13px;display:flex}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.filter-tabs{background:var(--bg);border-radius:6px;gap:2px;padding:2px;display:flex;overflow-x:auto}.filter-tab{color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-sans);white-space:nowrap;background:0 0;border:none;border-radius:5px;padding:5px 12px;transition:all .15s}.filter-tab:hover{color:var(--text)}.filter-tab.active{color:var(--text);background:#fff;box-shadow:0 1px 2px #0000000f}.search-input{font-family:var(--font-sans);background:#fff;border:1px solid #d4d0cb;border-radius:6px;outline:none;padding:6px 12px;font-size:13px;transition:border-color .2s}.search-input:focus{border-color:var(--primary)}.booking-list{flex-direction:column;gap:6px;display:flex}.booking-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:16px;padding:14px 16px;transition:all .15s;display:flex}.booking-row:hover{border-color:var(--accent)}.br-main{flex-wrap:wrap;flex:1;align-items:center;gap:16px;min-width:0;display:flex}.br-client{min-width:120px}.br-name{color:var(--text);font-size:14px;font-weight:600}.br-phone{color:var(--text-muted);font-size:12px}.br-service{color:var(--text-secondary);min-width:80px;font-size:13px}.br-time{color:var(--text-secondary);min-width:60px;font-size:13px}.br-staff{color:var(--text-secondary);min-width:80px;font-size:13px}.unassigned{color:var(--text-muted)}.br-meta{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.br-ago{color:var(--text-muted);white-space:nowrap;font-size:11px}.drawer-overlay{z-index:300;background:#0000004d;position:fixed;inset:0}.drawer{background:var(--bg-card);z-index:400;flex-direction:column;width:520px;max-width:100vw;height:100%;transition:right .3s;display:flex;position:fixed;top:0;right:-520px;box-shadow:-4px 0 24px #00000014}.drawer.open{right:0}.drawer-hd{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.drawer-bd{flex:1;padding:24px;overflow-y:auto}.drawer-close{cursor:pointer;width:32px;height:32px;color:var(--text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:20px;transition:all .15s;display:flex}.drawer-close:hover{background:var(--bg);color:var(--text)}.dr-section{margin-bottom:20px}.dr-section:last-child{margin-bottom:0}.dr-section-title{color:var(--text-muted);letter-spacing:.03em;border-bottom:1px solid var(--border-light);margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:600}.dr-row{padding:5px 0;display:flex}.dr-lbl{width:72px;color:var(--text-muted);flex-shrink:0;font-size:13px}.dr-val{color:var(--text-secondary);font-size:14px}.dr-remark-block{color:var(--text-secondary);background:var(--bg);border-radius:6px;padding:10px 14px;font-size:14px}.staff-grid{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.staff-opt{border:1px solid var(--border);cursor:pointer;background:var(--bg-card);-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:8px;padding:8px 10px;transition:all .15s;display:flex}.staff-opt:hover{border-color:var(--accent)}.staff-opt.checked{border-color:var(--primary);background:#1a3c3408}.staff-cb{color:#0000;border:2px solid #d4d0cb;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;transition:all .15s;display:flex}.staff-opt.checked .staff-cb{background:var(--primary);border-color:var(--primary);color:#fff}.staff-info{flex:1}.staff-name{color:var(--text);font-size:13px;font-weight:500}.staff-skill{color:var(--text-muted);font-size:11px}.staff-tags{flex-wrap:wrap;gap:4px;min-height:24px;display:flex}.staff-tag{background:var(--primary);color:#fff;border-radius:4px;align-items:center;gap:3px;padding:3px 8px 3px 10px;font-size:12px;font-weight:500;display:inline-flex}.staff-tag-x{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:10px;display:flex}.footer,.app-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-light);padding:20px 24px;font-size:12px}.dash-grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.dash-grid-2{grid-template-columns:1fr;gap:12px}}.state-box{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;font-size:14px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite sp}@keyframes sp{to{transform:rotate(360deg)}}.modal-overlay{z-index:500;background:#0000004d;position:fixed;inset:0}.modal{background:var(--bg-card);z-index:600;border-radius:12px;width:90%;max-width:480px;max-height:80vh;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 8px 32px #0000001f}.modal-hd{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.modal-bd{padding:24px}.sidebar-overlay{display:none}@media (width<=900px){.sidebar-overlay{z-index:249;background:#0000004d;display:block;position:fixed;inset:0}.admin-sidebar{z-index:250;transition:width .2s,transform .2s}.admin-sidebar.expanded{width:200px}.admin-sidebar.expanded .sidebar-toggle{display:flex}.admin-sidebar.expanded .sidebar-brand{font-size:15px;display:inline}.admin-sidebar.expanded .sidebar-item{justify-content:flex-start;padding:10px 12px}.admin-sidebar.expanded .sidebar-label{font-size:13px;display:inline}.admin-sidebar.expanded .sidebar-footer{text-align:left;padding:12px 16px}.admin-sidebar.expanded .sidebar-admin{font-size:12px}.admin-sidebar.expanded .sidebar-logout{padding:3px 10px;font-size:11px}.admin-sidebar{width:56px}.sidebar-logo{justify-content:center;padding:10px 4px}.sidebar-toggle{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.sidebar-toggle:hover{color:#fff;background:#ffffff14}.sidebar-brand{display:none}.sidebar-nav{gap:1px;padding:2px 4px}.sidebar-item{justify-content:center;min-height:44px;padding:10px 2px}.sidebar-icon{font-size:20px}.sidebar-label{display:none}.sidebar-footer{text-align:center;padding:4px}.sidebar-admin{display:none}.sidebar-logout{justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:0;display:flex}.sidebar-logout:before{content:"⇥";font-size:16px}.admin-topbar{padding:12px 16px}.topbar-title{font-size:16px}.admin-content{max-width:none;padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:12px 14px}.stat-num{font-size:20px}.ds-title{font-size:14px}.ds-card{padding:14px 16px}.ds-card-value{font-size:20px}.ds-cards{grid-template-columns:1fr;gap:8px}.dash-table-compact th{padding:5px 8px;font-size:10px}.dash-table-compact td{padding:6px 8px;font-size:12px}.filter-bar{gap:8px}.filter-tabs{flex-shrink:0;overflow-x:auto}.search-input{width:120px!important}.booking-row{flex-wrap:wrap;padding:10px 12px}.br-main{gap:6px}.br-name{font-size:13px}.br-meta{border-top:1px solid var(--border-light);justify-content:flex-end;width:100%;margin-left:0;padding-top:6px}.drawer{width:100vw;right:-100vw}.drawer.open{right:0}.drawer-bd{padding:14px}.staff-grid{grid-template-columns:1fr}.modal{width:94%}.state-box{padding:32px 16px}.app-footer{padding:14px 16px;font-size:11px}.dash-grid-2{grid-template-columns:1fr;gap:12px}.stats-grid{margin-bottom:12px}.dash-section{margin-bottom:12px!important}}@media (width<=480px){.admin-sidebar{width:48px}.sidebar-logo{padding:6px 2px}.sidebar-toggle{width:32px;height:32px;font-size:16px}.sidebar-nav{padding:2px}.sidebar-item{min-height:40px;padding:8px 1px}.sidebar-icon{font-size:17px}.admin-content{padding:10px}.admin-topbar{padding:10px 12px}.topbar-title{font-size:14px}.topbar-date{font-size:11px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:4px}.stat-card{padding:8px 10px}.stat-num{font-size:16px}.stat-lbl{font-size:10px}.filter-tab{padding:4px 8px;font-size:11px}.btn{padding:7px 14px;font-size:12px}.btn-sm{padding:4px 10px;font-size:11px}.search-input{padding:5px 8px;font-size:11px;width:90px!important}.booking-row{padding:8px 10px}.br-name{font-size:12px}.br-phone{font-size:11px}.dash-table{min-width:440px;font-size:11px}.dash-table th,.dash-table td{padding:6px 8px}}.login-root{background:var(--primary);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 8px 32px #00000026}.login-logo{font-family:var(--font-serif);color:var(--primary);text-align:center;letter-spacing:.04em;font-size:24px;font-weight:600}.login-logo span{color:var(--accent)}.login-subtitle{text-align:center;color:var(--text-muted);margin-top:4px;margin-bottom:28px;font-size:14px}.login-error{color:#c62828;text-align:center;margin-bottom:12px;font-size:13px}.login-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-light);margin-top:24px;padding-top:16px;font-size:11px}:root{--primary:#1a3c34;--primary-light:#2a5c52;--primary-dark:#0f2b25;--accent:#c9a96e;--accent-light:#e0c88a;--bg:#f5f3f0;--bg-card:#fff;--text:#1a1a1a;--text-secondary:#5c5c5c;--text-muted:#999;--border:#ebe8e4;--border-light:#edeae6;--radius:8px;--shadow:0 1px 3px #00000008;--font-serif:"Playfair Display", "Noto Serif SC", serif;--font-sans:"Inter", "Noto Sans SC", -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-feature-settings:"cv02", "cv03", "cv04", "cv11";line-height:1.6}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ddd;border-radius:3px}::selection{background:var(--primary);color:#fff}.btn{font-family:var(--font-sans);cursor:pointer;letter-spacing:.01em;white-space:nowrap;border:none;border-radius:6px;justify-content:center;align-items:center;padding:9px 22px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.btn-secondary{color:var(--text-secondary);background:0 0;border:1px solid #d4d0cb}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.btn-danger{color:#c62828;background:0 0;border:1px solid #e8c8c4}.btn-danger:hover{background:#fff5f5}.btn-sm{padding:6px 14px;font-size:12px}.btn-xs{border-radius:4px;padding:4px 10px;font-size:11px}.btn-full{width:100%}.badge{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge-pending{color:#b8860b;background:#fff8e5}.badge-confirmed{color:#2e7d32;background:#e8f5e9}.badge-progress{color:#1565c0;background:#e3f2fd}.badge-completed{color:#999;background:#f5f5f5}.badge-cancelled{color:#c62828;background:#fbe9e7}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 3px #00000008}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-input,.form-textarea{width:100%;font-family:var(--font-sans);color:var(--text);background:#fff;border:1px solid #d4d0cb;border-radius:6px;outline:none;padding:9px 12px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-input:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1a3c3414}.form-error,.form-msg{color:#c62828;background:#fff5f5;border:1px solid #e8c8c4;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.form-msg.ok{color:#2e7d32;background:#e8f5e9;border-color:#c8e6c9}.form-textarea{resize:vertical;min-height:70px}.auto-grow{resize:none;overflow:hidden}.notice{color:#8b7a4a;background:#fffcf0;border:1px solid #f0e6c8;border-radius:6px;align-items:flex-start;gap:8px;padding:12px 16px;font-size:13px;line-height:1.5;display:flex}.timeline{padding-left:22px;position:relative}.timeline:before{content:"";background:var(--border);width:2px;position:absolute;top:4px;bottom:4px;left:6px}.timeline-item{padding-bottom:18px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{background:var(--border);border:3px solid var(--bg-card);z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:-22px}.timeline-dot.done{background:var(--primary)}.timeline-dot.current{background:var(--accent);box-shadow:0 0 0 3px #c9a96e40}.timeline-time{color:var(--text-muted);margin-bottom:1px;font-size:11px}.timeline-text{color:var(--text-secondary);font-size:13px}.page-customer{max-width:640px;margin:0 auto;padding:32px 24px}@media (width<=768px){.page-customer{padding:20px 16px}}
