*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111111;--bg-card: #1a1a1a;--bg-elevated: #222222;--accent: #2d5a27;--accent-hover: #3a7232;--text: #ffffff;--text-muted: #888888;--border: #2a2a2a;--danger: #e05252;--warning: #e09a52;--radius: 12px}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100dvh;-webkit-font-smoothing:antialiased;overscroll-behavior:none}.top-nav,.bottom-nav{display:none}.page{padding:20px 24px;animation:slideUp .2s ease;overflow-y:auto;height:100dvh}.page-title{font-size:22px;font-weight:700;margin-bottom:16px}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:16px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;font-weight:600;cursor:pointer;border:none;padding:12px 20px;font-size:15px;transition:opacity .15s,background .15s;-webkit-tap-highlight-color:transparent}.btn:active{opacity:.8}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#2d5a27;color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:#3a7232}.btn-outline{background:transparent;color:#2d5a27;border:1.5px solid #2d5a27}.btn-ghost{background:transparent;color:#888}.btn-danger{background:#e05252;color:#fff}.btn-sm{padding:7px 12px;font-size:13px;border-radius:8px;width:auto}.btn-icon{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:8px;color:#888;display:flex;align-items:center;transition:color .15s}.btn-icon:hover{color:#fff}.form-group{margin-bottom:14px}.label{display:block;font-size:12px;color:#888;margin-bottom:5px;font-weight:500}.input{width:100%;background:#222;border:1.5px solid #2a2a2a;border-radius:10px;color:#fff;padding:12px 14px;font-size:15px;outline:none;transition:border-color .15s;-webkit-appearance:none}.input:focus{border-color:#2d5a27}.input::placeholder{color:#555}.badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}.badge-green{background:#2d5a2740;color:#6abf5e}.badge-blue{background:#1e64a040;color:#60a8e0}.badge-gray{background:#64646433;color:#888}.badge-red{background:#c83c3c33;color:#e07070}.status-completed{opacity:.75}.status-no_show{opacity:.8}.status-cancelled{opacity:.45}.badge-confirmed{background:#2d5a2740;color:#6abf5e}.badge-checked_in{background:#1a5a7a4d;color:#60c0e0}.badge-completed{background:#50505033;color:#aaa}.badge-no_show{background:#b4323233;color:#e07070}.badge-cancelled{background:#28282866;color:#555}.teesheet-outer{overflow:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}.teesheet-inner{display:flex;width:100%;min-width:100%}.teesheet-time-col{width:48px;flex-shrink:0;padding-top:40px;position:relative}.teesheet-sim-col{flex:1;min-width:80px;border-left:1px solid #1e1e1e}.teesheet-sim-header{height:40px;position:sticky;top:0;z-index:10;background:#1c1c1c;border-bottom:1px solid #2a2a2a;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;text-align:center;padding:0 4px;line-height:1.3;letter-spacing:.04em;text-transform:uppercase;color:#888}.teesheet-body{height:1344px;position:relative}.tab-bar{display:flex;border-bottom:1px solid #2a2a2a;margin-bottom:20px;overflow-x:auto}.tab{padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;color:#888;border-bottom:2px solid transparent;border-top:none;border-left:none;border-right:none;background:none;white-space:nowrap;transition:all .15s}.tab.active{color:#2d5a27;border-bottom-color:#2d5a27}.section-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:10px;font-weight:600}.divider{height:1px;background:#2a2a2a;margin:16px 0}.error-msg{color:#e05252;font-size:13px;margin-top:6px}.empty-state{text-align:center;padding:40px 16px;color:#888}.empty-state h3{color:#fff;margin-bottom:8px;font-size:18px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid #2a2a2a;border-top-color:#2d5a27;border-radius:50%;animation:spin .7s linear infinite}.spinner-center{display:flex;align-items:center;justify-content:center;padding:40px}.booking-block{border-radius:6px;overflow:hidden;display:flex;flex-direction:column;gap:1px;user-select:none;-webkit-user-select:none;transition:opacity .15s,filter .15s;z-index:2;position:absolute;cursor:pointer}.booking-block:hover{filter:brightness(1.15)}.booking-block.dragging{opacity:.6;cursor:grabbing;z-index:50;filter:none}.booking-block-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking-block-meta{font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checkin-btn{margin-top:3px;background:#4ade8033;border:1px solid rgba(74,222,128,.4);border-radius:4px;color:#4ade80;font-size:9px;font-weight:700;padding:2px 7px;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;align-self:flex-start;transition:background .15s}.checkin-btn:hover{background:#4ade8059}.checkin-btn:active{opacity:.7}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}[data-font-size=sm]{zoom:.88}[data-font-size=lg]{zoom:1.1}[data-font-size=xl]{zoom:1.22}[data-theme=light]{--bg: #f4f5f7;--bg-card: #ffffff;--bg-elevated: #eaecef;--text: #111111;--text-muted: #5e6472;--border: #d8dae0;--danger: #d93025}[data-theme=light] body{background:var(--bg);color:var(--text)}[data-theme=light] .input{background:#f0f1f4;border-color:#d0d3db;color:#111}[data-theme=light] .input:focus{border-color:#2d5a27}[data-theme=light] .input::placeholder{color:#aaa}[data-theme=light] .card{background:var(--bg-card);border-color:var(--border)}[data-theme=light] .tab-bar{border-bottom-color:var(--border)}[data-theme=light] .tab{color:#666}[data-theme=light] .tab.active{color:#2d5a27;border-bottom-color:#2d5a27}[data-theme=light] .section-title{color:#6b7280}[data-theme=light] .divider{background:var(--border)}[data-theme=light] .empty-state{color:#666}[data-theme=light] .empty-state h3{color:#111}[data-theme=light] .btn-ghost{color:#555}[data-theme=light] .btn-icon{color:#666}[data-theme=light] .btn-icon:hover{color:#111}[data-theme=light] .btn-outline{color:#2d5a27;border-color:#2d5a27}[data-theme=light] .teesheet-sim-header{background:#f0f2f5;border-bottom-color:var(--border);color:#555}[data-theme=light] .teesheet-sim-col{border-left-color:#d8dae0}[data-theme=light] .teesheet-time-col{color:#888}[data-theme=light] .booking-block{box-shadow:0 1px 4px #00000014!important;border-color:#00000014!important;background:#fffffff2!important}[data-theme=light] .booking-block-name{color:#222!important}[data-theme=light] .booking-block-meta{color:#666!important}[data-theme=light] .status-completed{background:#b0b8c4}[data-theme=light] .status-cancelled{background:#d0d4da;opacity:.7}[data-theme=light] .spinner{border-color:#e0e0e0;border-top-color:#2d5a27}@media (max-width: 1024px){.page{padding:16px 20px}}@media (max-width: 768px){.sidebar-nav{width:60px!important}.sidebar-nav .nav-label,.sidebar-nav .logo-text{display:none}.main-content{margin-left:60px!important}}@media (max-width: 480px){.page{padding:12px 16px}.page-title{font-size:18px}.teesheet-sim-col{min-width:60px}.teesheet-sim-header{font-size:9px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
