:root{--bg:#f4f6f9;--surface:#fff;--surface2:#f0f3f7;--surface3:#e8ecf2;--border:#e5e9f0;--border2:#ced5e0;--text:#111827;--muted:#6b7280;--muted2:#9ca3af;--blue:#2563eb;--blue-l:#eff4ff;--blue-m:#2563eb1a;--green:#15803d;--green-l:#f0fdf4;--green-m:#15803d1a;--orange:#b45309;--orange-l:#fffbeb;--orange-m:#b4530914;--red:#dc2626;--red-l:#fef2f2;--red-m:#dc262617;--purple:#7c3aed;--purple-l:#f5f3ff;--purple-m:#7c3aed1a;--sh:0 1px 3px #00000012, 0 1px 2px #0000000a;--sh-md:0 4px 16px #00000014, 0 2px 4px #0000000a;--r:12px;--r-sm:8px;--t:all .15s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,sans-serif;font-size:14px}h1,h2,h3{letter-spacing:.04em;font-family:Bebas Neue,sans-serif}a{color:inherit;text-decoration:none}.app{height:100vh;display:flex;overflow:hidden}.main{background:var(--bg);flex:1;overflow-y:auto}@media (max-width:767px){.main{padding-top:0}}.page{max-width:1400px;padding:24px 16px;animation:.18s fadeIn}@media (min-width:1024px){.page{padding:32px 36px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.topbar{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.pg-title{font-size:28px}@media (min-width:1024px){.pg-title{font-size:32px}}.pg-sub{color:var(--muted);margin-top:3px;font-size:12px}.topbar-r{align-items:center;gap:8px;margin-top:4px;display:flex}.btn{border-radius:var(--r-sm);cursor:pointer;transition:var(--t);border:none;align-items:center;gap:6px;min-height:44px;padding:8px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;line-height:1.4;display:inline-flex}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{box-shadow:var(--sh-md);background:#1d50c8}.btn-ghost{color:var(--muted);border:1px solid var(--border2);background:0 0}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--red-l);color:var(--red);border:1px solid #dc262633}.btn-danger:hover{background:var(--red);color:#fff}.btn-green{background:var(--green-l);color:var(--green);border:1px solid #15803d33}.btn-green:hover{background:var(--green);color:#fff}.btn-sm{min-height:36px;padding:5px 10px;font-size:12px}.btn-xs{min-height:32px;padding:3px 8px;font-size:11px}.btn:disabled{opacity:.5;cursor:not-allowed}.stat-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px;display:grid}@media (min-width:1024px){.stat-grid{grid-template-columns:repeat(4,1fr);gap:14px}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh);padding:16px 18px}@media (min-width:1024px){.stat-card{padding:18px 20px}}.stat-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:5px;font-size:11px;font-weight:400}.stat-val{color:var(--text);font-family:Bebas Neue,sans-serif;font-size:36px;line-height:1}.stat-val.blue{color:var(--blue)}.stat-val.green{color:var(--green)}.stat-val.orange{color:var(--orange)}.stat-val.red{color:var(--red)}.stat-sub{color:var(--muted);margin-top:4px;font-size:11px;font-weight:400}.sec-hdr{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.sec-title{font-family:Bebas Neue,sans-serif;font-size:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.card-pad{padding:18px 20px}.tbl-hdr{border-bottom:1px solid var(--border);letter-spacing:.07em;text-transform:uppercase;color:var(--muted);background:var(--surface2);padding:10px 18px;font-size:11px;font-weight:400;display:grid}.tbl-row{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;padding:12px 18px;transition:background .12s;display:grid}.tbl-row:last-child{border-bottom:none}.tbl-row:hover{background:var(--surface2)}.name-cell{align-items:center;gap:10px;display:flex}.av-sm{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.av-md{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:700;display:flex}.av-lg{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:58px;height:58px;font-family:Bebas Neue,sans-serif;font-size:22px;font-weight:700;display:flex}.c-name{font-size:13px;font-weight:500}.c-since{color:var(--muted);font-size:11px}.c-zac{color:#3730a3;background:#e0e7ff}.c-david{color:#166534;background:#dcfce7}.c-martin{color:#713f12;background:#fef9c3}.c-rosa{color:#9d174d;background:#fce7f3}.c-alex{color:#5b21b6;background:#ede9fe}.c-paul{color:#065f46;background:#d1fae5}.c-andrew{color:#92400e;background:#fef3c7}.pill{border-radius:20px;align-items:center;gap:4px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.pill-green{background:var(--green-l);color:var(--green)}.pill-orange{background:var(--orange-l);color:var(--orange)}.pill-red{background:var(--red-l);color:var(--red)}.pill-grey{background:var(--surface2);color:var(--muted)}.pill-blue{background:var(--blue-l);color:var(--blue)}.pill-purple{background:var(--purple-l);color:var(--purple)}.tag{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:5px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.sess-list{flex-direction:column;gap:8px;display:flex}.sess-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:var(--t);box-shadow:var(--sh);align-items:center;gap:12px;padding:11px 14px;display:flex}.sess-card:hover{border-color:var(--border2);box-shadow:var(--sh-md)}.sess-time{color:var(--blue);min-width:40px;font-family:DM Mono,monospace;font-size:13px;font-weight:500}.sess-div{background:var(--border);flex-shrink:0;width:1px;height:30px}.sess-info{flex:1}.sess-client{font-size:13px;font-weight:500}.sess-type{color:var(--muted);font-size:11px}.ss{border-radius:20px;padding:3px 8px;font-size:11px;font-weight:500}.ss-confirmed{background:var(--green-l);color:var(--green)}.ss-pending{background:var(--orange-l);color:var(--orange)}.ss-done{background:var(--surface2);color:var(--muted)}.ss-cancelled{background:var(--red-l);color:var(--red)}.ss-waived{background:var(--purple-l);color:var(--purple)}.ss-charged{background:var(--orange-l);color:var(--orange)}.prog{background:var(--surface3);border-radius:3px;height:4px;overflow:hidden}.prog-fill{background:var(--blue);border-radius:3px;height:100%}.two-col{grid-template-columns:1fr;gap:20px;display:grid}@media (min-width:1024px){.two-col{grid-template-columns:1fr 320px}}.notice{border-radius:var(--r-sm);align-items:flex-start;gap:8px;padding:10px 14px;font-size:12px;line-height:1.5;display:flex}.notice-orange{background:var(--orange-l);color:var(--orange);border:1px solid #b4530933}.notice-green{background:var(--green-l);color:var(--green);border:1px solid #15803d33}.notice-blue{background:var(--blue-l);color:var(--blue);border:1px solid #2563eb26}.notice-red{background:var(--red-l);color:var(--red);border:1px solid #dc262626}.notice-purple{background:var(--purple-l);color:var(--purple);border:1px solid #7c3aed2e}.form-group{margin-bottom:16px}.form-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px;font-size:11px;font-weight:400;display:block}.form-input{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-sm);width:100%;color:var(--text);outline:none;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-input::placeholder{color:var(--muted2)}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.form-select{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-sm);width:100%;color:var(--text);appearance:none;cursor:pointer;outline:none;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:13px;transition:border-color .15s}.form-select:focus{border-color:var(--blue)}textarea.form-input{resize:vertical;min-height:80px}.toggle-sw{align-items:center;gap:10px;display:flex}.sw{background:var(--surface3);border:1px solid var(--border2);cursor:pointer;width:40px;height:22px;transition:var(--t);border-radius:11px;flex-shrink:0;position:relative}.sw:after{content:"";width:16px;height:16px;box-shadow:var(--sh);background:#fff;border-radius:50%;transition:transform .15s;position:absolute;top:2px;left:2px}.sw.on{background:var(--blue);border-color:var(--blue)}.sw.on:after{transform:translate(18px)}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;background:#0000004d;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);width:100%;max-width:480px;box-shadow:var(--sh-md);padding:24px;position:relative}@media (max-width:639px){.modal-panel{border-radius:16px 16px 0 0;max-width:100%;position:fixed;bottom:0;left:0;right:0}.modal-overlay{align-items:flex-end}}.modal-title{margin-bottom:4px;font-family:Bebas Neue,sans-serif;font-size:24px}.modal-sub{color:var(--muted);margin-bottom:20px;font-size:13px}.modal-close{background:var(--surface2);border:1px solid var(--border);width:28px;height:28px;color:var(--muted);cursor:pointer;transition:var(--t);border-radius:6px;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--text)}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.toast-container{z-index:100;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);box-shadow:var(--sh-md);align-items:center;gap:10px;max-width:340px;padding:12px 16px;font-size:13px;font-weight:500;animation:.2s slideIn;display:flex}.toast.s{border-left:3px solid var(--green)}.toast.e{border-left:3px solid var(--red)}.toast.i{border-left:3px solid var(--blue)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:24px;display:flex}.tab{color:var(--muted);cursor:pointer;transition:var(--t);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500}.tab:hover{color:var(--text)}.tab.active{color:var(--blue);border-bottom-color:var(--blue)}.client-link{color:var(--text);transition:var(--t);font-weight:500;text-decoration:none}.client-link:hover{color:var(--blue);text-decoration:underline}.clickable-row{cursor:pointer;transition:var(--t)}.clickable-row:hover{background:var(--surface2)}.approval-list{flex-direction:column;gap:8px;display:flex}.approval-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);transition:var(--t);padding:14px 16px}.approval-card:hover{border-color:var(--border2);box-shadow:var(--sh)}.approval-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.approval-datetime{color:var(--orange);margin-bottom:2px;font-family:DM Mono,monospace;font-size:12px;font-weight:500}.approval-meta{color:var(--muted);margin-bottom:10px;font-size:12px}.approval-actions{gap:8px;display:flex}.appSidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:232px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}@media (max-width:767px){.appSidebar{display:none}}.sidebarLogoBlock{border-bottom:1px solid var(--border);color:var(--text);transition:var(--t);align-items:center;gap:10px;padding:20px 16px;text-decoration:none;display:flex}.sidebarLogoBlock:hover{background:var(--surface2)}.sidebarLogoIcon{background:var(--text);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.sidebarLogoName{letter-spacing:.1em;font-family:Bebas Neue,sans-serif;font-size:22px;line-height:1}.sidebarLogoSub{text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-top:2px;font-size:10px}.sidebarUserBlock{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:12px 16px;display:flex}.sidebarNav{flex:1;padding:8px 0}.sidebarSection{text-transform:uppercase;letter-spacing:.1em;color:var(--muted2);padding:12px 12px 4px;font-size:10px;font-weight:400}.sidebarItem{color:var(--muted);transition:var(--t);cursor:pointer;border-radius:8px;align-items:center;gap:8px;margin:1px 6px;padding:8px 12px;font-size:13px;font-weight:500;text-decoration:none;display:flex}.sidebarItem:hover{background:var(--surface2);color:var(--text)}.sidebarItem.active{background:var(--blue-l);color:var(--blue)}.sidebarBadge{background:var(--red);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:auto;padding:0 6px;font-size:10px;font-weight:700;display:flex}.sidebarBadge.blue{background:var(--blue)}.sidebarBottom{border-top:1px solid var(--border);padding:12px}.sidebarBottomBtn{cursor:pointer;color:var(--muted);transition:var(--t);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;text-decoration:none;display:flex}.sidebarBottomBtn:hover{background:var(--surface2);color:var(--text)}.modal-client-link{letter-spacing:.05em;color:var(--text);transition:var(--t);font-family:Bebas Neue,sans-serif;font-size:22px;text-decoration:none}.modal-client-link:hover{color:var(--blue)}.mobileTopBar{display:none}@media (max-width:767px){.mobileTopBar{background:var(--surface);border-bottom:1px solid var(--border);z-index:40;justify-content:space-between;align-items:center;height:52px;padding:0 16px;display:flex;position:sticky;top:0}}.mobileTopBarLogo{color:var(--text);align-items:center;gap:8px;text-decoration:none;display:flex}.mobileTopBarLogoIcon{background:var(--text);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.mobileTopBarLogoText{letter-spacing:.1em;font-family:Bebas Neue,sans-serif;font-size:20px}.mobileTopBarMenuBtn{cursor:pointer;width:40px;height:40px;color:var(--text);transition:var(--t);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;display:flex}.mobileTopBarMenuBtn:hover{background:var(--surface2)}.mobileMenuOverlay{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.mobileMenuPanel{background:var(--surface);z-index:60;flex-direction:column;width:280px;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 24px #0000001f}.mobileMenuPanel.open{transform:translate(0)}.mobileMenuHeader{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;display:flex}.mobileMenuUser{align-items:center;gap:10px;display:flex}.mobileMenuAvatar{background:var(--text);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:flex}.mobileMenuName{color:var(--text);font-size:14px;font-weight:500}.mobileMenuRole{color:var(--muted);font-size:11px}.mobileMenuClose{background:var(--surface2);cursor:pointer;width:32px;height:32px;color:var(--muted);transition:var(--t);border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex}.mobileMenuClose:hover{color:var(--text)}.mobileMenuNav{flex:1;padding:8px 0;overflow-y:auto}.mobileMenuItem{color:var(--text);transition:var(--t);justify-content:space-between;align-items:center;padding:14px 16px;font-size:15px;font-weight:500;text-decoration:none;display:flex}.mobileMenuItem:hover{background:var(--surface2)}.mobileMenuBadge{background:var(--red);color:#fff;border-radius:10px;padding:2px 7px;font-size:11px;font-weight:700}.mobileMenuArrow{color:var(--muted);font-size:14px}.mobileMenuFooter{border-top:1px solid var(--border);padding:12px 16px}.mobileMenuSignOut{color:var(--red);cursor:pointer;background:0 0;border:none;padding:8px 0;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500}.divider{background:var(--border);height:1px;margin:20px 0}.back-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:16px;font-family:DM Sans,sans-serif;font-size:13px;transition:color .12s;display:inline-flex}.back-btn:hover{color:var(--text)}.empty-state{text-align:center;color:var(--muted);padding:40px 20px;font-size:13px}.cancel-breakdown{gap:6px;font-size:11px;font-weight:500;display:flex}.cancel-waived{color:var(--purple)}.cancel-charged{color:var(--orange)}.btnSpinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.formError{color:var(--red);margin-top:4px;font-size:11px;display:block}.skeleton{background:var(--surface3);border-radius:4px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-state{text-align:center;background:var(--red-l);border-radius:var(--r);color:var(--red);border:1px solid #dc262626;padding:40px 20px}.error-state p{margin-bottom:12px;font-size:14px}@media print{.main{padding:0;overflow:visible}.page{padding:0}nav,.topbar-r,.btn,.modal-overlay,.toast-container{display:none!important}}
