.layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-glass-heavy);border-right:.5px solid var(--border-hairline);-webkit-backdrop-filter:blur(24px)saturate(180%);flex-direction:column;flex-shrink:0;width:236px;padding:20px 0;transition:background .3s,border-color .3s;display:flex}.sidebar-header{border-bottom:.5px solid var(--border-hairline);align-items:center;gap:10px;margin-bottom:8px;padding:0 18px 20px;display:flex}.sidebar-logo svg{display:block}.sidebar-title{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:700;line-height:1.2}.sidebar-subtitle{color:var(--text-tertiary);letter-spacing:.3px;font-size:11px;font-weight:500}.sidebar-nav{flex:1;margin:0;padding:4px 12px;list-style:none}.nav-item{color:var(--text-secondary);border-radius:var(--r-sm);letter-spacing:-.1px;align-items:center;gap:10px;margin-bottom:1px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .18s;display:flex}.nav-item:hover{background:var(--accent-subtle);color:var(--accent)}.nav-item.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.nav-icon-svg{opacity:.75;flex-shrink:0}.nav-item.active .nav-icon-svg{opacity:1}.nav-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;padding:12px 14px 6px;font-size:10px;font-weight:650}.nav-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.sidebar-footer{border-top:.5px solid var(--border-hairline);align-items:center;gap:8px;padding:12px 18px;display:flex}.theme-toggle{border-radius:var(--r-sm);background:var(--bg-elevated);width:36px;height:32px;color:var(--text-secondary);cursor:pointer;border:none;justify-content:center;align-items:center;transition:all .18s;display:flex}.theme-toggle:hover{background:var(--accent-subtle);color:var(--accent)}.logout-btn{border-radius:var(--r-sm);background:var(--bg-elevated);width:36px;height:32px;color:var(--text-secondary);cursor:pointer;border:none;justify-content:center;align-items:center;transition:all .18s;display:flex}.logout-btn:hover{color:var(--red);background:#ff3b301a}.main-content{background:var(--bg-primary);flex-direction:column;flex:1;min-width:0;padding:36px 40px;transition:background .3s;display:flex}.main-footer{color:var(--text-tertiary);letter-spacing:.2px;text-align:center;margin-top:auto;padding-top:24px;font-size:11px}@media (width<=768px){.layout{flex-direction:column;padding-bottom:64px}.sidebar{display:none}.main-content{width:100%;padding:16px 12px}}.tabbar{display:none}@media (width<=768px){.tabbar{background:var(--bg-surface);border-top:.5px solid var(--border-hairline);-webkit-backdrop-filter:blur(20px)saturate(180%);z-index:50;height:60px;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}}.tabbar-item{color:var(--text-tertiary);font-size:10px;font-weight:500;font-family:var(--font-ui);cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:56px;min-height:44px;padding:6px 12px;text-decoration:none;transition:color .15s;display:flex}.tabbar-item.active{color:var(--accent)}.tabbar-sub-overlay{display:none}@media (width<=768px){.tabbar-sub-overlay{z-index:60;will-change:opacity;contain:layout style paint;background:#0000004d;align-items:flex-end;padding-bottom:70px;animation:.18s overlayIn;display:flex;position:fixed;inset:0;transform:translateZ(0)}}.tabbar-sub{background:var(--bg-surface);border-radius:var(--r-lg) var(--r-lg) 0 0;will-change:transform;width:100%;max-width:500px;margin:0 auto;padding:16px 20px 24px;animation:.22s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.tabbar-sub-item{color:var(--text-primary);border-radius:var(--r-sm);align-items:center;gap:10px;padding:14px 16px;font-size:15px;font-weight:550;text-decoration:none;transition:background .12s;display:flex}.tabbar-sub-item:hover{background:var(--accent-subtle)}.theme-toggle-mobile{border:.5px solid var(--border-default);border-radius:var(--r-sm);background:var(--bg-elevated);width:100%;color:var(--text-secondary);font-size:14px;font-family:var(--font-ui);cursor:pointer;text-align:center;margin-top:10px;padding:12px;display:block}.logout-mobile{border-radius:var(--r-sm);background:var(--bg-elevated);width:100%;color:var(--red);font-size:14px;font-family:var(--font-ui);cursor:pointer;text-align:center;border:none;margin-top:6px;padding:12px;display:block}.login-page{background:var(--bg-primary);min-height:100dvh;font-family:var(--font-ui);justify-content:center;align-items:center;padding:24px;display:flex}.login-card{background:var(--bg-surface);border-radius:var(--r-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-hairline);text-align:center;padding:48px 40px 36px}.login-brand{margin-bottom:36px}.login-brand svg{margin-bottom:16px}.login-brand h1{color:var(--text-primary);letter-spacing:-.3px;margin:0 0 6px;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-secondary);margin:0;font-size:14px}.login-form{text-align:left}.login-field{margin-bottom:16px}.login-field label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.login-field input{border:1.5px solid var(--border-default);border-radius:var(--r-sm);width:100%;font-size:16px;font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-primary);outline:none;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.login-field input:focus{border-color:var(--accent);box-shadow:var(--shadow-ring)}.login-field input::placeholder{color:var(--text-tertiary)}.login-error{color:var(--red);border-radius:var(--r-sm);background:#ff3b300f;margin-bottom:12px;padding:8px 12px;font-size:13px;animation:.4s login-shake}@keyframes login-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-4px)}}.login-btn{width:100%;margin-top:4px;padding:12px 0;font-size:15px}.login-footer{color:var(--text-tertiary);margin-top:28px;font-size:12px}@media (width<=480px){.login-card{border-radius:var(--r-lg);padding:36px 24px 28px}.login-brand h1{font-size:22px}}.purchase-form{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-md);border:.5px solid var(--border-hairline);margin-bottom:24px;padding:24px 28px;animation:.35s cubic-bezier(.16,1,.3,1) formSlideIn}@keyframes formSlideIn{0%{opacity:0;transform:translateY(-6px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}.purchase-form h3{color:var(--text-primary);letter-spacing:-.2px;margin:0 0 20px;font-size:15px;font-weight:700}.form-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.form-field{flex-direction:column;gap:5px;display:flex}.form-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.form-field input,.form-field select{border:.5px solid var(--border-default);border-radius:var(--r-sm);font-size:13.5px;font-family:var(--font-ui);background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-xs);padding:9px 12px;transition:all .15s}.form-field input::placeholder{color:var(--text-tertiary)}.form-field input:hover,.form-field select:hover{border-color:var(--border-strong)}.form-field input:focus,.form-field select:focus{border-color:var(--accent);box-shadow:var(--shadow-ring);background:var(--bg-surface);outline:none}.form-field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236e6e73'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.form-actions{gap:10px;margin-top:20px;display:flex}@media (width<=1024px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.form-grid{grid-template-columns:1fr}.purchase-form{padding:18px 16px}}.purchases-page{max-width:1320px}.header-btns{gap:8px;display:flex}.week-cell{color:var(--text-secondary);white-space:normal;word-break:keep-all;max-width:220px;font-size:12px}.toolbar{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.filter-group{align-items:center;gap:8px;display:flex}.filter-group label{color:var(--text-tertiary);white-space:nowrap;text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.filter-group select{border:.5px solid var(--border-default);border-radius:var(--r-sm);font-size:13px;font-family:var(--font-ui);background:var(--bg-surface);color:var(--text-primary);cursor:pointer;appearance:none;min-width:140px;box-shadow:var(--shadow-xs);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236e6e73'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding:7px 30px 7px 12px;transition:all .15s}.filter-group select:hover{border-color:var(--border-strong)}.filter-group select:focus{border-color:var(--accent);box-shadow:var(--shadow-ring);outline:none}.table-wrapper{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:.5px solid var(--border-hairline);overflow:hidden}.purchases-table{border-collapse:collapse;width:100%;font-size:13px}.purchases-table th{background:var(--bg-elevated);text-align:left;text-transform:uppercase;letter-spacing:.4px;color:var(--text-tertiary);border-bottom:.5px solid var(--border-hairline);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}.purchases-table td{border-bottom:.5px solid var(--border-hairline);color:var(--text-secondary);padding:11px 16px;font-size:13.5px;font-weight:400;transition:background .12s}.purchases-table tbody tr:last-child td{border-bottom:none}.purchases-table tbody tr{transition:background .12s}.purchases-table tbody tr:hover{background:var(--accent-subtle)}.group-tag{background:var(--accent-subtle);color:var(--accent);letter-spacing:.5px;white-space:nowrap;border-radius:20px;min-width:fit-content;padding:3px 12px;font-size:13px;font-weight:600;display:inline-block}.price-cell{font-family:var(--font-mono);color:var(--accent);letter-spacing:-.3px;font-size:13px;font-weight:500}.empty-cell{text-align:center;color:var(--text-tertiary);padding:44px 16px;font-size:14px}.status-badge{letter-spacing:.2px;white-space:nowrap;vertical-align:middle;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.status-pending{color:var(--orange);background:#ff95001f}.status-approved{color:var(--green);background:#34c7591f}.status-rejected{color:var(--red);background:#ff3b301a}.review-info{color:var(--text-tertiary);white-space:nowrap;margin-left:6px;font-size:11px;display:inline}.status-cell,.orderer-cell,.action-cell{white-space:nowrap}.action-cell .btn-review-sm,.action-cell .btn-danger-sm,.action-cell .reviewed-text{vertical-align:middle}.action-cell .btn-review-sm+.btn-danger-sm,.action-cell .reviewed-text+.btn-danger-sm{margin-left:6px}.btn-review-sm{background:var(--accent-subtle);color:var(--accent);cursor:pointer;border:none;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:550;transition:all .15s}.btn-review-sm:hover{background:var(--accent);color:#fff}.reviewed-text{color:var(--text-tertiary);font-size:11px}.batch-bar{background:var(--bg-elevated);border-radius:var(--r-sm);border:.5px solid var(--border-hairline);color:var(--text-secondary);align-items:center;gap:12px;margin-bottom:8px;padding:8px 16px;font-size:13px;display:flex}.batch-bar .btn-review-sm{background:var(--accent);color:#fff;padding:5px 14px}.batch-bar .btn-review-sm:hover{opacity:.88}.col-check{text-align:center;width:36px}.col-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}.calendar-page{max-width:1320px}.header-btns{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.month-hint{color:var(--text-tertiary);margin-bottom:14px;font-size:12px;font-weight:450}.month-tabs{gap:0;margin-bottom:14px;display:flex}.month-tab{border:.5px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);font-size:14px;font-weight:600;font-family:var(--font-ui);cursor:pointer;padding:9px 22px;transition:all .18s}.month-tab:first-child{border-radius:var(--r-sm) 0 0 var(--r-sm)}.month-tab:last-child{border-radius:0 var(--r-sm) var(--r-sm) 0}.month-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);z-index:1}.month-tab.locked{opacity:.45;cursor:not-allowed}.lock-icon{font-size:12px}.calendar-table-wrapper{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:.5px solid var(--border-hairline);margin-bottom:8px}.month-grid{border-radius:var(--r-lg);border-collapse:collapse;table-layout:fixed;width:100%;min-width:700px;overflow:hidden}.month-grid th{background:var(--bg-elevated);text-align:center;letter-spacing:.4px;color:var(--text-tertiary);border-bottom:.5px solid var(--border-hairline);padding:10px 8px 8px;font-size:12px;font-weight:650}.month-cell{vertical-align:top;border:.5px solid var(--border-hairline);cursor:pointer;width:14.2857%;min-height:104px;padding:6px;transition:background .12s;position:relative}.month-cell:hover{background:var(--accent-subtle)}.month-cell.empty-cell{background:var(--bg-elevated);cursor:default}.month-cell.past{background:var(--bg-elevated);opacity:.45;cursor:default;pointer-events:none}.month-cell.today{box-shadow:inset 0 0 0 2px var(--accent)}.cell-date{color:var(--text-secondary);margin-bottom:3px;font-size:13px;font-weight:650}.month-cell.today .cell-date{color:var(--accent);font-weight:700}.month-cell.past .cell-date{color:var(--text-tertiary)}.cell-bookings{flex-direction:column;gap:3px;display:flex}.cell-booking{background:var(--bg-elevated);cursor:pointer;border-left:3px solid;border-radius:6px;padding:5px 24px 5px 7px;font-size:13px;line-height:1.4;transition:all .15s;position:relative}.cell-booking:hover{box-shadow:var(--shadow-sm);transform:translate(1px)}.cell-booking-row{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.cell-booking-device{color:var(--text-primary);font-size:12.5px;font-weight:650}.cell-booking-member{color:var(--accent);font-size:12.5px;font-weight:600}.cell-booking-batch{color:var(--orange);background:#ff950026;border-radius:3px;padding:1px 5px;font-size:11px;font-weight:600}.cell-booking-note{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:11px;overflow:hidden}.cell-booking-x{width:20px;height:20px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:all .15s;display:flex;position:absolute;top:2px;right:3px}.cell-booking:hover .cell-booking-x{opacity:1}.cell-booking-x:hover{background:var(--red);color:#fff}.add-hint{color:var(--text-tertiary);text-align:center;opacity:0;pointer-events:none;padding:8px;font-size:13px;transition:opacity .15s;position:absolute;bottom:0;left:0;right:0}.month-cell:hover .add-hint{opacity:.4}.mi-cards{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=768px){.mi-cards{grid-template-columns:1fr}}.mi-card{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);border:.5px solid var(--border-hairline);overflow:hidden}.mi-card-head{border-bottom:2.5px solid var(--mi-color,var(--accent));background:var(--bg-elevated);align-items:center;gap:8px;padding:14px 18px;display:flex}.mi-card-icon{font-size:18px}.mi-card-title{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:700}.mi-card-body{max-height:65vh;overflow-y:auto}.mi-table{border-collapse:collapse;width:100%}.mi-th-date{text-transform:uppercase;letter-spacing:.4px;width:72px;color:var(--text-tertiary);border-bottom:.5px solid var(--border-hairline);text-align:left;padding:8px 6px 8px 12px;font-size:10px;font-weight:650}.mi-th-period{color:var(--text-secondary);text-align:center;border-bottom:.5px solid var(--border-hairline);min-width:64px;padding:8px 4px;font-size:11px;font-weight:650}.mi-th-am{border-right:2px solid var(--border-strong)}.mi-row{transition:background .12s}.mi-row-open:hover{background:var(--accent-subtle)}.mi-row-past{opacity:.28;pointer-events:none;background:var(--bg-elevated)}.mi-row-locked{background:#00000005}[data-theme=dark] .mi-row-locked{background:#ffffff04}.mi-td-date{border-bottom:.5px solid var(--border-hairline);white-space:nowrap;padding:6px 8px 6px 12px;font-size:12px;position:relative}.mi-date-short{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:550}.mi-date-dow{color:var(--text-tertiary);margin-left:4px;font-size:10.5px;font-weight:450}.mi-today .mi-date-short{color:var(--accent);font-weight:700}.mi-lock{margin-left:3px;font-size:10px}.mi-td-slot{text-align:center;border-bottom:.5px solid var(--border-hairline);vertical-align:middle;min-height:36px;padding:4px 6px;transition:background .12s;position:relative}.mi-td-slot:nth-child(3){border-left:2px solid var(--border-strong)}.mi-slot-open{cursor:pointer}.mi-slot-open:hover{background:var(--accent-subtle)}.mi-slot-disabled{cursor:default}.mi-plus{color:var(--text-tertiary);opacity:0;font-size:16px;font-weight:300;transition:opacity .15s}.mi-slot-open:hover .mi-plus{opacity:.5}.mi-booking-info{background:var(--mi-color,var(--accent));color:#fff;cursor:pointer;text-align:left;border-radius:6px;padding:5px 20px 5px 7px;transition:all .15s;position:relative}.mi-booking-info:hover{filter:brightness(.9);box-shadow:var(--shadow-sm)}.mi-booking-name{font-size:12px;font-weight:700;line-height:1.2}.mi-booking-purpose{opacity:.85;font-size:10px;font-weight:500;line-height:1.3}.mi-booking-note{opacity:.7;margin-top:1px;font-size:9px;font-weight:400;line-height:1.3}.mi-booking-x{text-align:center;opacity:0;background:#fff3;border-radius:4px;width:16px;height:16px;font-size:11px;line-height:16px;transition:opacity .15s;position:absolute;top:2px;right:2px}.mi-booking-info:hover .mi-booking-x{opacity:1}.mi-booking-x:hover{background:#fff6}.mi-modal-info{color:var(--text-secondary);margin-bottom:18px;font-size:13px;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:100;background:#00000052;justify-content:center;align-items:center;animation:.2s overlayIn;display:flex;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-surface);border-radius:var(--r-xl);width:440px;max-width:90vw;box-shadow:var(--shadow-lg);border:.5px solid var(--border-hairline);padding:28px 32px;animation:.35s cubic-bezier(.16,1,.3,1) modalIn}@keyframes modalIn{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-sm{width:380px}.modal h3{color:var(--text-primary);letter-spacing:-.3px;margin:0 0 22px;font-size:17px;font-weight:700}.modal-sm p{color:var(--text-secondary);margin-bottom:6px;font-size:13.5px;line-height:1.6}.delete-warning-text{font-weight:550;color:var(--red)!important;margin-top:14px!important}.period-options{gap:8px;display:flex}.period-btn{border:.5px solid var(--border-default);border-radius:var(--r-sm);cursor:pointer;font-size:13px;font-weight:550;font-family:var(--font-ui);color:var(--text-secondary);background:var(--bg-elevated);letter-spacing:-.1px;padding:8px 18px;transition:all .15s}.period-btn input{display:none}.period-btn:hover{border-color:var(--border-strong)}.period-btn.active{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent);font-weight:650}.conflict-warning{border-radius:var(--r-sm);color:var(--orange);background:#ff95000f;border:.5px solid #ff950033;margin:16px 0;padding:12px 14px;font-size:12px;line-height:1.65}.conflict-warning ul{margin:6px 0 0;padding-left:18px}.conflict-warning li{margin-bottom:2px}.modal .form-field{margin-bottom:14px}.modal .form-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-size:11px;font-weight:650;display:block}.modal .form-field input,.modal .form-field select{border:.5px solid var(--border-default);border-radius:var(--r-sm);width:100%;font-size:13.5px;font-family:var(--font-ui);background:var(--bg-elevated);color:var(--text-primary);box-sizing:border-box;box-shadow:var(--shadow-xs);padding:9px 12px;transition:all .15s}.modal .form-field input:hover,.modal .form-field select:hover{border-color:var(--border-strong)}.modal .form-field input:focus,.modal .form-field select:focus{border-color:var(--accent);box-shadow:var(--shadow-ring);background:var(--bg-surface);outline:none}.modal .form-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236e6e73'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.modal .form-actions{gap:10px;margin-top:20px;display:flex}.checkbox-group{flex-wrap:wrap;gap:6px;display:flex}.checkbox-label{border:.5px solid var(--border-default);border-radius:var(--r-sm);cursor:pointer;color:var(--text-secondary);background:var(--bg-elevated);font-size:13px;font-family:var(--font-ui);align-items:center;gap:5px;padding:7px 14px;font-weight:500;transition:all .15s;display:flex}.checkbox-label input{accent-color:var(--accent)}.checkbox-label:has(input:checked){border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.mobile-date-list{display:none}@media (width<=640px){.calendar-table-wrapper{display:none}.month-tabs{z-index:10;position:sticky;top:0}.mobile-date-list{display:block}.mobile-day{background:var(--bg-surface);border-radius:var(--r-md);border:.5px solid var(--border-hairline);box-shadow:var(--shadow-xs);cursor:pointer;margin-bottom:8px;padding:12px 14px;transition:background .12s}.mobile-day:hover{background:var(--accent-subtle)}.mobile-day.today{box-shadow:inset 0 0 0 2px var(--accent)}.mobile-day.past{opacity:.35;pointer-events:none;background:var(--bg-elevated)}.mobile-day-head{align-items:center;gap:6px;margin-bottom:6px;display:flex}.mobile-day-date{color:var(--text-primary);font-size:16px;font-weight:700}.mobile-day.today .mobile-day-date{color:var(--accent)}.mobile-day-weekday{color:var(--text-tertiary);font-size:12px}.mobile-day-bookings{flex-direction:column;gap:6px;display:flex}.mobile-booking{background:var(--bg-elevated);cursor:pointer;border-left:3px solid;border-radius:5px;padding:8px 10px;transition:all .12s}.mobile-booking:active{transform:scale(.98)}.mobile-booking-row{flex-wrap:wrap;align-items:center;gap:8px;font-size:13.5px;display:flex}.mobile-booking-device{color:var(--text-primary);font-weight:650}.mobile-booking-member{color:var(--accent);font-weight:600}.mobile-booking-batch{color:var(--orange);background:#ff950026;border-radius:3px;padding:1px 6px;font-size:11px;font-weight:600}.mobile-booking-period{color:var(--text-tertiary);font-size:11px}.mobile-booking-note{color:var(--text-tertiary);margin-top:3px;font-size:11px}.mobile-day-empty{color:var(--text-tertiary);padding:4px 0;font-size:13px}.mi-cards{grid-template-columns:1fr;gap:14px}.mi-card-body{max-height:none;overflow:hidden}.mi-table{table-layout:fixed;width:100%}.mi-th-date,.mi-td-date{width:25%;padding-left:6px!important}.mi-th-period,.mi-td-slot{width:37.5%;min-width:0;padding:4px 2px!important}.mi-td-slot{min-height:42px}.mi-booking-name{font-size:11px}.mi-booking-purpose{font-size:9px}.mi-th-period{font-size:10px}.modal{border-radius:var(--r-lg) var(--r-lg) 0 0;width:95vw;max-width:100vw;margin:0 auto;padding:20px 16px;animation:.3s cubic-bezier(.16,1,.3,1) modalUp;position:fixed;bottom:0;left:0;right:0}@keyframes modalUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-overlay{align-items:flex-end}.modal h3{margin-bottom:14px;font-size:16px}.modal .form-field input,.modal .form-field select{padding:10px 12px;font-size:16px}.modal .form-actions{flex-direction:column}.modal .form-actions .btn{width:100%;padding:12px;font-size:15px}}.cb-page{max-width:1400px}.cb-error{color:var(--red);border-radius:var(--r-sm);background:#ff3b3014;margin-bottom:16px;padding:10px 16px;font-size:13px;font-weight:500}.cb-status-board{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;display:grid}.cb-status-card{border-radius:var(--r-md);background:var(--bg-surface);box-shadow:var(--shadow-xs);border:.5px solid var(--border-hairline);padding:18px 20px;transition:all .25s}.cb-status-occupied{box-shadow:var(--shadow-sm)}.cb-status-free{opacity:.65;border-style:dashed}.cb-status-pos{text-transform:uppercase;letter-spacing:.6px;color:var(--text-tertiary);margin-bottom:6px;font-size:11px;font-weight:600}.cb-status-user{letter-spacing:-.3px;font-size:22px;font-weight:700;line-height:1.2}.cb-status-time{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:500}.cb-status-idle{color:var(--text-tertiary);margin-top:2px;font-size:15px;font-weight:500}.cb-form-panel{background:var(--bg-surface);border-radius:var(--r-md);border:.5px solid var(--border-hairline);box-shadow:var(--shadow-xs);margin-bottom:24px;padding:20px 24px}.cb-form-row{flex-wrap:wrap;gap:24px;margin-bottom:16px;display:flex}.cb-form-group{flex:1;min-width:200px}.cb-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.cb-radio-group{gap:6px;display:flex}.cb-radio-btn{border-radius:var(--r-sm);border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;white-space:nowrap;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .18s}.cb-radio-btn:hover{border-color:var(--border-strong);color:var(--text-primary)}.cb-radio-active{box-shadow:var(--shadow-sm);color:var(--accent);background:var(--accent-subtle);font-weight:600;border-color:var(--accent)!important}.cb-select{border-radius:var(--r-sm);border:.5px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);cursor:pointer;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='%236e6e73' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;padding:8px 30px 8px 12px;font-family:inherit;font-size:14px;transition:border-color .18s}.cb-select:focus{border-color:var(--accent);box-shadow:var(--shadow-ring)}.cb-select option:disabled{color:var(--text-tertiary);font-style:italic}.cb-duration-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.cb-dur-btn{border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .18s}.cb-dur-btn:hover{border-color:var(--accent);color:var(--accent)}.cb-dur-active{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle);font-weight:600}.cb-dur-input{border:.5px solid var(--border-default);background:var(--bg-elevated);width:60px;color:var(--text-primary);text-align:center;border-radius:6px;outline:none;padding:6px 8px;font-family:inherit;font-size:13px;transition:border-color .18s}.cb-dur-input:focus{border-color:var(--accent);box-shadow:var(--shadow-ring)}.cb-dur-unit{color:var(--text-tertiary);font-size:12px}.cb-input{border-radius:var(--r-sm);border:.5px solid var(--border-default);background:var(--bg-elevated);width:100%;color:var(--text-primary);outline:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .18s}.cb-input:focus{border-color:var(--accent);box-shadow:var(--shadow-ring)}.cb-end-preview{border-radius:var(--r-sm);background:var(--bg-elevated);border:.5px solid var(--border-hairline);flex-wrap:wrap;align-items:center;gap:10px;min-height:38px;padding:8px 12px;display:flex}.cb-end-time{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:16px;font-weight:700}.cb-hint-ok{color:var(--green);font-size:12px;font-weight:500}.cb-hint-danger{color:var(--red);font-size:12px;font-weight:500}.cb-hint-muted{color:var(--text-tertiary);font-size:12px}.cb-hint-warn{color:var(--orange);font-size:13px;font-weight:500}.cb-submit{margin-top:4px;padding:10px 28px;font-size:14px}.cb-dual-calendar{grid-template-columns:1fr 1fr;gap:16px;display:grid}.cb-calendar{background:var(--bg-surface);border-radius:var(--r-md);border:.5px solid var(--border-hairline);box-shadow:var(--shadow-xs);overflow:hidden}.cb-cal-header{color:var(--text-primary);border-bottom:.5px solid var(--border-hairline);letter-spacing:-.2px;padding:14px 20px;font-size:15px;font-weight:700}.cb-cal-date{color:var(--text-secondary);margin-left:4px;font-size:13px;font-weight:500}.cb-cal-body{max-height:80vh;display:flex;position:relative;overflow-y:auto}.cb-time-axis{flex-shrink:0;width:54px;padding-top:32px}.cb-time-tick{border-top:.5px solid var(--border-hairline);justify-content:flex-end;align-items:flex-start;height:60px;padding-right:8px;display:flex}.cb-time-label{color:var(--text-tertiary);font-variant-numeric:tabular-nums;font-size:10px;font-weight:500;position:relative;top:-7px}.cb-lane{border-left:.5px solid var(--border-hairline);flex:1;min-width:0}.cb-lane-label{height:32px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;border-bottom:.5px solid var(--border-hairline);background:var(--bg-elevated);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.cb-lane-track{height:1440px;position:relative}.cb-now-line{background:var(--red);opacity:.7;z-index:5;pointer-events:none;height:2px;position:absolute;left:0;right:0;box-shadow:0 0 4px #ff3b304d}.cb-card{cursor:default;z-index:2;border-left:3px solid;border-radius:6px;padding:4px 6px;transition:box-shadow .15s;position:absolute;left:3px;right:3px;overflow:hidden}.cb-card:hover{box-shadow:var(--shadow-md);z-index:10}.cb-card-past{opacity:.45}.cb-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;line-height:1.2;overflow:hidden}.cb-card-time{color:var(--text-secondary);white-space:nowrap;font-size:10px;font-weight:500;line-height:1.3}.cb-card-dur{color:var(--text-tertiary);font-size:9px;font-weight:500}.cb-card-cross{color:var(--accent);opacity:.85;margin-left:4px;font-size:9px;font-weight:600}.cb-card-del{width:18px;height:18px;color:var(--text-tertiary);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:all .15s;display:flex;position:absolute;top:2px;right:2px}.cb-card:hover .cb-card-del{opacity:1}.cb-card-del:hover{background:var(--red);color:#fff}.cb-modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:100;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.cb-modal{background:var(--bg-surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);border:.5px solid var(--border-hairline);width:100%;max-width:420px;padding:28px 30px}.cb-modal h3{color:var(--text-primary);letter-spacing:-.2px;margin:0 0 6px;font-size:18px;font-weight:700}.cb-modal-desc{color:var(--text-secondary);margin:0 0 18px;font-size:13px;line-height:1.5}.cb-modal-field{margin-bottom:14px}.cb-modal-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.cb-modal-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.cb-loading{text-align:center;color:var(--text-tertiary);padding:40px;font-size:14px}@media (width<=900px){.cb-dual-calendar,.cb-status-board{grid-template-columns:1fr}.cb-form-row{flex-direction:column;gap:12px}}@media (width<=640px){.cb-page{padding-bottom:16px}.cb-status-card{padding:12px 14px}.cb-status-user{font-size:18px}.cb-form-panel{padding:14px 16px}.cb-cal-body{max-height:50vh}.cb-time-axis{width:40px}.cb-time-label{font-size:9px}.cb-lane-label{height:28px;font-size:10px}.cb-card-name{font-size:10px}.cb-card-time{font-size:9px}.cb-card{padding:2px 4px;left:1px;right:1px}.cb-modal{max-width:95vw;padding:20px}}.home-page{max-width:800px;margin:0 auto}.home-hero{text-align:center;margin-bottom:28px}.home-hero h1{letter-spacing:-.6px;color:var(--text-primary);margin:0 0 4px;font-size:32px;font-weight:800}.home-sub{color:var(--text-tertiary);margin:0;font-size:14px;font-weight:450}.home-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px;display:grid}.home-stat-card{background:var(--bg-surface);border-radius:var(--r-md);text-align:center;border:.5px solid var(--border-hairline);box-shadow:var(--shadow-xs);cursor:pointer;padding:16px 12px;transition:all .18s}.home-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.home-stat-card:active{transform:scale(.97)}.home-stat-icon{margin-bottom:4px;font-size:24px}.home-stat-num{letter-spacing:-.4px;color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:28px;font-weight:800}.home-stat-label{color:var(--text-tertiary);margin-top:2px;font-size:11px;font-weight:500}.home-cards{flex-direction:column;gap:12px;display:flex}.home-card{background:var(--bg-surface);border-radius:var(--r-md);border:.5px solid var(--border-hairline);border-left:4px solid var(--card-color,var(--accent));box-shadow:var(--shadow-xs);cursor:pointer;align-items:center;gap:16px;padding:20px 24px;transition:all .2s;display:flex}.home-card:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.home-card:active{transform:scale(.985)}.home-card-icon{text-align:center;flex-shrink:0;width:48px;font-size:32px}.home-card-body{flex:1;min-width:0}.home-card-title{color:var(--text-primary);letter-spacing:-.2px;margin-bottom:2px;font-size:17px;font-weight:700}.home-card-desc{color:var(--text-tertiary);font-size:12.5px;line-height:1.4}.home-card-arrow{color:var(--text-tertiary);flex-shrink:0;font-size:18px}@media (width<=640px){.home-hero h1{font-size:26px}.home-stats{grid-template-columns:repeat(2,1fr);gap:8px}.home-stat-card{padding:12px 8px}.home-stat-num{font-size:24px}.home-card{padding:16px 18px}.home-card-icon{width:40px;font-size:28px}.home-card-title{font-size:15px}}:root,[data-theme=light]{--bg-primary:#f5f5f7;--bg-surface:#fff;--bg-elevated:#fafafa;--bg-glass:#ffffffb8;--bg-glass-heavy:#ffffffe0;--text-primary:#1d1d1f;--text-secondary:#6e6e73;--text-tertiary:#aeaeb2;--text-inverse:#fff;--accent:#007aff;--accent-hover:#0066d6;--accent-subtle:#007aff14;--accent-glow:#007aff26;--red:#ff3b30;--orange:#ff9500;--green:#34c759;--border-hairline:#0000000f;--border-default:#0000001a;--border-strong:#00000029;--shadow-xs:0 .5px 1px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f, 0 2px 4px #0000000a;--shadow-lg:0 12px 36px #00000014, 0 4px 8px #0000000a;--shadow-ring:0 0 0 4px #007aff1f;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--font-ui:-apple-system, "SF Pro Display", "SF Pro Text", "Helvetica Neue", "PingFang SC", sans-serif;--font-mono:"SF Mono", "Menlo", "Monaco", "Courier New", monospace}[data-theme=dark]{--bg-primary:#1c1c1e;--bg-surface:#2c2c2e;--bg-elevated:#3a3a3c;--bg-glass:#2c2c2eb8;--bg-glass-heavy:#2c2c2ee0;--text-primary:#f5f5f7;--text-secondary:#98989d;--text-tertiary:#636366;--text-inverse:#1d1d1f;--accent:#0a84ff;--accent-hover:#409cff;--accent-subtle:#0a84ff1f;--accent-glow:#0a84ff33;--red:#ff453a;--orange:#ff9f0a;--green:#30d158;--border-hairline:#ffffff0f;--border-default:#ffffff1a;--border-strong:#ffffff29;--shadow-xs:0 .5px 1px #0003;--shadow-sm:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 12px #00000059, 0 2px 4px #0003;--shadow-lg:0 12px 36px #0006, 0 4px 8px #0003;--shadow-ring:0 0 0 4px #0a84ff2e}*{box-sizing:border-box;margin:0;padding:0}img,svg{max-width:100%;height:auto}html{background:var(--bg-primary)}body{font-family:var(--font-ui);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s,color .3s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}::selection{background:var(--accent-subtle);color:var(--accent)}.btn{border-radius:var(--r-sm);font-family:var(--font-ui);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:var(--bg-elevated);color:var(--text-primary);letter-spacing:-.1px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;justify-content:center;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn:hover{transform:translateY(-.5px)}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff;font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-surface);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{opacity:.88}.btn-danger-sm{color:var(--red);cursor:pointer;background:0 0;border:none;border-radius:5px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.btn-danger-sm:hover{background:var(--red);color:#fff}.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h2{color:var(--text-primary);letter-spacing:-.4px;margin:0;font-size:26px;font-weight:700;line-height:1.15}@media (width<=640px){body{overflow-x:hidden}.main-content{width:100%;max-width:100vw;padding:14px 10px;overflow-x:hidden}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-header h2{font-size:20px}.btn{min-width:44px;min-height:44px;padding:10px 16px;font-size:14px}table{-webkit-overflow-scrolling:touch;max-width:100%;display:block;overflow-x:auto}input,select,textarea{font-size:16px!important}}
