@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700&display=swap";@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700&display=swap";:root{--bg: #f4f6f9;--side: #0c1929;--card: #fff;--accent: #3ecfb4;--accent2: #2ba893;--text: #1a2332;--muted: #6b7a8d;--border: #e4e8ed;--red: #e86c6c;--orange: #f0a05e;--blue: #5b8def;--green: #3ecfb4;--purple: #9b7ee8}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-width:320px;min-height:100vh;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}.page-spinner{display:flex;align-items:center;justify-content:center;padding:80px 0}.spinner{width:36px;height:36px;border:3px solid var(--border, #e0e0e0);border-top-color:var(--accent, #3ecfb4);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.layout{display:flex;min-height:100vh}.shell{display:flex;min-height:100vh;width:100%}.sidebar{width:240px;background:var(--side);color:#fff;padding:24px 0;position:fixed;top:0;left:0;bottom:0;z-index:10;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;transition:width .25s ease;overflow:hidden}.sidebar-collapsed{width:68px}.sidebar-collapsed .sidebar-logo{padding:0 0 20px;justify-content:center}.sidebar-collapsed .sidebar-link{justify-content:center;padding:12px 0;gap:0;border-left:3px solid transparent}.sidebar-collapsed .sidebar-link.active{border-left-color:var(--accent)}.sidebar-collapsed .sidebar-link .sidebar-label{display:none}.sidebar-label{white-space:nowrap;overflow:hidden}.sidebar-collapse-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px 20px;background:none;border:none;color:#fff6;font-size:.78rem;font-family:inherit;cursor:pointer;transition:color .2s}.sidebar-collapse-btn:hover{color:#fffc}.sidebar-collapsed .sidebar-collapse-btn{justify-content:center;padding:10px 0}.sidebar-collapsed .sidebar-collapse-btn .sidebar-label{display:none}.sidebar-collapsed .sidebar-footer{padding:16px 0}.sidebar-collapsed .logo-text{display:none}.sidebar-logo{padding:0 20px 24px;font-size:1.1rem;font-weight:700;display:flex;justify-content:center;align-items:center;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:8px}.logo-container{display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer}.logo-image{width:48px;height:48px}.logo-text{font-family:Fraunces,Georgia,serif;font-size:1.3rem;font-weight:600;transition:color .35s ease}.logo-opti{color:#fff}.logo-clinic{color:var(--accent)}.sidebar-footer{padding:16px 20px;font-size:.72rem;color:#ffffff40;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}.sidebar-nav{flex:1;padding:8px 0}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 20px;width:100%;background:transparent;border:none;color:#ffffffb3;font-size:.9rem;font-family:inherit;cursor:pointer;transition:all .2s ease;text-align:left;border-left:3px solid transparent;white-space:nowrap;min-height:44px}.sidebar-link:hover{color:#ffffffe6;background:#ffffff0d}.sidebar-link.active{color:#fff;background:#3ecfb41f;border-left-color:var(--accent);font-weight:600}.sidebar-link svg{flex-shrink:0;width:18px;height:18px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;font-size:.88rem;color:#ffffff80;cursor:pointer;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{color:#ffffffd9;background:#ffffff0a}.nav-item.active{color:#fff;background:#3ecfb41a;border-left-color:var(--accent)}.nav-item .nav-icon{font-size:1rem;width:20px;text-align:center}.main{margin-left:240px;padding:24px 32px;flex:1;min-height:100vh;background:var(--bg);transition:margin-left .25s ease}.main-expanded{margin-left:68px}.page-header{margin-bottom:24px}.page-header h1{font-size:1.5rem;font-weight:700;margin-bottom:2px}.page-header p{font-size:.84rem;color:var(--muted)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:16px}.card{background:var(--card);border-radius:12px;padding:20px;border:1px solid var(--border)}.card-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:12px}.stat-val{font-size:1.8rem;font-weight:700}.stat-sub{font-size:.78rem;color:var(--muted);margin-top:2px}.badge{display:inline-block;padding:3px 10px;border-radius:50px;font-size:.72rem;font-weight:600}.badge-confirmed{background:#e8f8f4;color:#1a7a60}.badge-pending{background:#fff4e5;color:#a06520}.badge-cancelled{background:#fde8e8;color:#a02020}.badge-no-show{background:#f0e8fd;color:#6b3fa0}.badge-in-progress{background:#e8f0ff;color:#2a5bd7}.badge-checked-in{background:#fff8e1;color:#b8860b;border:1px solid #f0c040}.badge-completed{background:#e8f8f4;color:#1a7a60;border:1px solid #3ecfb4}table{width:100%;border-collapse:collapse;font-size:.84rem}table th{text-align:left;padding:10px 12px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);border-bottom:2px solid var(--border)}table td{padding:10px 12px;border-bottom:1px solid var(--border)}table tr:hover{background:#f8f9fb}.avatar{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;font-weight:700;flex-shrink:0}.toggle{width:40px;height:22px;border-radius:11px;background:#cdd5de;position:relative;cursor:pointer;transition:background .2s}.toggle.on{background:var(--accent)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px #00000026}.toggle.on:after{left:20px}.input{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:.84rem;outline:none;transition:border-color .2s;background:#fff;color:var(--text)}.input:focus{border-color:var(--accent)}input[type=time]{color:var(--text);background:#fff}.btn{padding:8px 20px;border-radius:8px;font-family:inherit;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-followup{background:var(--blue)}.btn-followup:hover{background:#4a7fe0}.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--accent)}.modal-actions-balanced{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.heatmap{display:grid;grid-template-columns:60px repeat(6,1fr);gap:2px;font-size:.72rem}.heatmap-cell{padding:8px 4px;text-align:center;border-radius:4px;font-weight:500}.heatmap-header{font-weight:700;color:var(--muted);padding:6px 4px;text-align:center}.heatmap-label{display:flex;align-items:center;font-weight:500;color:var(--muted)}.util-bar{height:8px;border-radius:4px;background:var(--border);overflow:hidden;margin-top:6px}.util-fill{height:100%;border-radius:4px;transition:width .5s}.search-box{position:relative;margin-bottom:16px}.search-box input{width:100%;padding:10px 12px 10px 36px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:.86rem;outline:none;background:#fff;color:var(--text)}.search-box input:focus{border-color:var(--accent)}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:.8rem;color:var(--muted)}.demo-banner{background:linear-gradient(135deg,#0c1929,#1a2d47);color:#fff;padding:12px 20px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;gap:12px;font-size:.84rem}.demo-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.mobile-topbar,.mobile-overlay{display:none}.mobile-hamburger{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.main-topbar{display:flex;justify-content:flex-end;align-items:center;margin-bottom:8px}.notif-bell-wrap{position:relative}.notif-bell-btn{position:relative;background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;color:var(--text, #1a2a3a);transition:background .15s;display:flex;align-items:center}.notif-bell-btn:hover{background:var(--accent-bg, #e8f8f4)}.mobile-topbar .notif-bell-btn{color:#ffffffd9}.mobile-topbar .notif-bell-btn:hover{background:#ffffff1a}.notif-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;background:#e53e3e;color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1;pointer-events:none}.notif-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:340px;max-height:420px;background:#fff;border:1px solid var(--border, #e2e8f0);border-radius:12px;box-shadow:0 8px 30px #0000001f;z-index:200;overflow:hidden;display:flex;flex-direction:column}.notif-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border, #e2e8f0)}.notif-dismiss-all{background:none;border:none;color:var(--accent, #1a7a60);font-size:.76rem;font-weight:600;cursor:pointer;padding:2px 6px;border-radius:6px}.notif-dismiss-all:hover{background:var(--accent-bg, #e8f8f4)}.notif-empty{padding:32px 16px;text-align:center;color:var(--muted, #6b7a8d);font-size:.84rem}.notif-list{overflow-y:auto;max-height:350px}.notif-item{display:block;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--border, #f0f2f5);padding:10px 16px;cursor:pointer;transition:background .12s}.notif-item:hover{background:var(--accent-bg, #e8f8f4)}.notif-item:last-child{border-bottom:none}.notif-item-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:2px}.notif-patient{font-weight:600;font-size:.84rem;color:var(--text, #1a2a3a);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-status{font-size:.68rem;font-weight:600;color:#f0a05e;background:#fef7ec;padding:2px 8px;border-radius:6px;white-space:nowrap}.notif-source{font-size:.68rem;font-weight:600;color:#5b8def;background:#eef3ff;padding:2px 8px;border-radius:6px;white-space:nowrap}.notif-item-detail{font-size:.76rem;color:var(--muted, #6b7a8d)}@media(max-width:768px){.mobile-topbar{display:flex;align-items:center;gap:10px;position:fixed;top:0;left:0;right:0;height:52px;background:var(--side, #0c1929);padding:0 16px;z-index:50}.mobile-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:55}.sidebar{width:260px;transform:translate(-100%);z-index:60;transition:transform .25s ease}.sidebar.sidebar-mobile-open{transform:translate(0)}.sidebar-collapsed{width:260px}.sidebar-collapsed .sidebar-label,.sidebar-collapsed .logo-text{display:inline}.sidebar-collapsed .sidebar-link{justify-content:flex-start;padding:12px 20px;gap:12px}.sidebar-collapse-btn{display:none}.main,.main-expanded{margin-left:0;padding:68px 14px 16px}.main-topbar{display:none}.notif-dropdown{width:calc(100vw - 24px);right:-12px}.grid2,.grid3,.grid4,.modal-actions-balanced{grid-template-columns:1fr}.page-header h1{font-size:1.2rem}.page-header p{font-size:.78rem}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -14px;padding:0 14px}.table-scroll table{min-width:560px}table th,table td{padding:8px;font-size:.76rem}.stat-val{font-size:1.3rem}.card{padding:14px}.btn{padding:8px 14px;font-size:.8rem}.drawer-panel{width:100vw;max-width:100vw}.drawer-header{padding:16px 16px 12px}.drawer-summary{padding:14px 16px}.drawer-bookings{padding:8px 16px}.drawer-section-title{padding:12px 16px 4px}.heatmap{grid-template-columns:50px repeat(6,1fr);font-size:.62rem}.dash-stats,.dash-staff-grid{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}.dash-tickets{grid-template-columns:1fr!important}.ticket-inner{padding:10px 12px!important}.ticket-top{flex-wrap:wrap;gap:6px!important}.progress-dots{transform:scale(.85);transform-origin:left center}.ticket-timestamps,.ticket-payment{flex-wrap:wrap;gap:6px!important;font-size:.72rem!important}.ticket-actions{flex-wrap:wrap;gap:6px!important}.staff-chip{padding:5px 10px!important;font-size:.74rem!important}.filter-bar{flex-wrap:wrap;gap:8px!important}.filter-bar .input,.filter-bar input,.filter-bar select{width:auto!important;min-width:0!important;flex:1 1 120px;font-size:.78rem}.day-timeline{overflow-x:auto;-webkit-overflow-scrolling:touch}.day-timeline-inner{min-width:500px}.day-nav{gap:8px!important}.day-nav input[type=date]{width:140px!important}.day-nav-label{font-size:.76rem!important;width:100%}}.drawer-backdrop{position:fixed;inset:0;background:#00000040;z-index:900;animation:drawerFadeIn .2s ease}.drawer-panel{position:fixed;top:0;right:0;width:520px;max-width:90vw;height:100vh;background:var(--card);box-shadow:-4px 0 24px #0000001f;z-index:910;display:flex;flex-direction:column;animation:drawerSlideIn .25s ease}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes drawerFadeIn{0%{opacity:0}to{opacity:1}}.drawer-header{display:flex;align-items:flex-start;gap:12px;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.drawer-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:1rem;color:var(--muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.drawer-close:hover{background:var(--border);color:var(--text)}.drawer-summary{display:flex;gap:10px;padding:18px 24px;border-bottom:1px solid var(--border);flex-wrap:wrap}.drawer-stat{flex:1;min-width:80px;padding:10px 14px;background:var(--bg);border-radius:10px;border-left:3px solid var(--primary, #1a7a60)}.drawer-stat-value{font-size:.92rem;font-weight:700;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-stat-label{font-size:.66rem;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.drawer-section-title{padding:14px 24px 6px;font-size:.76rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.drawer-body{flex:1;overflow-y:auto;padding-bottom:24px}.drawer-bookings{display:flex;flex-direction:column;gap:8px;padding:8px 24px}.drawer-booking-card{padding:12px 16px;background:var(--bg);border-radius:10px;border:1px solid var(--border);transition:border-color .15s}.drawer-booking-card:hover{border-color:var(--accent)}@media(max-width:640px){.drawer-panel{width:100vw;max-width:100vw}}.auth-page{display:flex;min-height:100vh}.auth-brand{width:42%;min-height:100vh;background:linear-gradient(160deg,#0a1520,#0f2235 40%,#122c42,#0c1929);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.auth-brand-inner{position:relative;z-index:2;text-align:center;padding:40px}.auth-brand-glow{position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(62,207,180,.15) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.auth-brand-logo{width:72px;height:72px;margin-bottom:20px}.auth-brand-name{font-family:Fraunces,serif;font-size:2.2rem;font-weight:600;color:#ffffffe0;letter-spacing:-.5px}.auth-brand-name span{color:var(--accent)}.auth-brand-tagline{margin-top:16px;font-size:1.05rem;color:#ffffff73;line-height:1.6;font-weight:400}.auth-brand-dots{display:flex;gap:8px;justify-content:center;margin-top:40px}.auth-brand-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.3;animation:authDotPulse 1.8s ease-in-out infinite}@keyframes authDotPulse{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.auth-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}.auth-form-wrapper{width:100%;max-width:400px}.auth-mobile-logo{display:none;align-items:center;gap:10px;margin-bottom:32px}.auth-form-header{margin-bottom:32px}.auth-form-header h1{font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.3px}.auth-form-header p{font-size:.88rem;color:var(--muted);line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-field label{display:block;font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:.2px}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:14px;width:16px;height:16px;color:var(--muted);pointer-events:none;opacity:.5}.auth-input-wrap input{width:100%;padding:11px 14px 11px 42px;font-size:.88rem;font-family:inherit;border:1.5px solid var(--border);border-radius:10px;background:var(--card);color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s}.auth-input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3ecfb41f}.auth-input-wrap input::placeholder{color:var(--muted);opacity:.5}.auth-pwd-toggle{position:absolute;right:10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:6px;color:var(--muted);transition:color .15s,background .15s}.auth-pwd-toggle svg{width:16px;height:16px}.auth-pwd-toggle:hover{color:var(--text);background:var(--bg)}.auth-match-hint{margin-top:6px;font-size:.76rem;color:var(--accent);font-weight:500}.auth-error{font-size:.82rem;color:var(--red);background:#fef5f5;padding:10px 14px;border-radius:10px;border:1px solid rgba(232,108,108,.15);line-height:1.4}.auth-submit{width:100%;padding:12px 0;font-size:.9rem;font-weight:600;font-family:inherit;color:#fff;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);border:none;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .2s,transform .1s,box-shadow .2s;box-shadow:0 2px 8px #3ecfb440;margin-top:4px}.auth-submit:hover:not(:disabled){opacity:.92;box-shadow:0 4px 16px #3ecfb459}.auth-submit:active:not(:disabled){transform:scale(.985)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:900px){.auth-brand{display:none}.auth-mobile-logo{display:flex}.auth-form-side{padding:32px 24px}}.upgrade-gate{position:relative;min-height:400px}.upgrade-gate-content{filter:blur(3px);opacity:.55;pointer-events:none;-webkit-user-select:none;user-select:none}.upgrade-gate-overlay{position:absolute;inset:0;display:flex;align-items:flex-start;padding-top:120px;justify-content:center;z-index:10}.upgrade-gate-card{text-align:center;max-width:320px;padding:24px 24px 20px;background:var(--card);border-radius:12px;box-shadow:0 4px 20px #0000001a;border:1px solid var(--border)}.upgrade-gate-icon{width:40px;height:40px;margin:0 auto 12px;background:linear-gradient(135deg,#3ecfb41f,#5b8def1f);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--accent)}.upgrade-gate-icon svg{width:20px;height:20px}.upgrade-gate-card h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:6px}.upgrade-gate-card p{font-size:.78rem;color:var(--muted);line-height:1.5;margin-bottom:16px}.upgrade-gate-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 22px;font-size:.8rem;font-weight:600;font-family:inherit;color:#fff;background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);border:none;border-radius:8px;text-decoration:none;cursor:pointer;transition:opacity .2s,box-shadow .2s;box-shadow:0 2px 8px #3ecfb440}.upgrade-gate-btn:hover{opacity:.9;box-shadow:0 4px 12px #3ecfb459}.pb-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fc,#eef1f6);display:flex;justify-content:center;padding:32px 16px;font-family:DM Sans,sans-serif}.pb-wrap{width:100%;max-width:640px;display:flex;flex-direction:column;gap:24px}.pb-loading,.pb-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:300px;color:var(--muted);font-size:.92rem}.pb-header{text-align:center;padding-top:8px}.pb-logo{font-family:Fraunces,serif;font-size:1.6rem;font-weight:700;color:var(--text)}.pb-subtitle{font-size:.88rem;color:var(--muted);margin-top:2px}.pb-progress{display:flex;justify-content:center;gap:8px}.pb-step{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--muted);font-weight:500}.pb-step.active{color:var(--pb-accent);font-weight:600}.pb-step.done{color:var(--pb-accent)}.pb-step-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;background:var(--border);color:var(--muted);flex-shrink:0}.pb-step.active .pb-step-dot{background:var(--pb-accent);color:#fff}.pb-step.done .pb-step-dot{background:var(--pb-accent);color:#fff;font-size:.72rem}.pb-step span{display:none}.pb-step.active span{display:inline}.pb-body{background:#fff;border-radius:16px;padding:28px 24px;box-shadow:0 2px 12px #0000000f}.pb-title{font-size:1.1rem;font-weight:700;margin-bottom:20px;color:var(--text)}.pb-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pb-grid-scroll{max-height:400px;overflow-y:auto;padding-right:4px}.pb-grid-scroll::-webkit-scrollbar{width:4px}.pb-grid-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.pb-search{position:relative;margin-bottom:14px}.pb-search input{width:100%;padding:9px 14px 9px 36px;border-radius:10px;border:1.5px solid var(--border);font-family:inherit;font-size:.86rem;outline:none;transition:border-color .15s;background:#fff}.pb-search input:focus{border-color:var(--pb-accent)}.pb-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.pb-search-count{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.72rem;color:var(--muted);font-weight:500}.pb-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:1.5px solid var(--border);background:#fff;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;font-family:inherit;font-size:inherit;width:100%}.pb-card:hover{border-color:var(--pb-accent);box-shadow:0 2px 8px #0000000a}.pb-card.selected{border-color:var(--pb-accent);background:color-mix(in srgb,var(--pb-accent) 6%,#fff)}.pb-card-colour{width:10px;height:36px;border-radius:6px;flex-shrink:0}.pb-card-info{flex:1;min-width:0}.pb-card-name{font-weight:600;font-size:.92rem}.pb-card-meta{font-size:.78rem;color:var(--muted);margin-top:2px}.pb-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.92rem;flex-shrink:0}.pb-empty{text-align:center;padding:32px;color:var(--muted);font-size:.88rem;grid-column:1 / -1}.pb-datetime{display:grid;grid-template-columns:1fr 1fr;gap:20px}.pb-calendar{border:1px solid var(--border);border-radius:12px;padding:16px}.pb-cal-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600;font-size:.88rem}.pb-cal-nav button{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--text);display:flex;align-items:center}.pb-cal-nav button:hover{background:var(--bg)}.pb-cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:.68rem;color:var(--muted);font-weight:600;margin-bottom:6px;text-transform:uppercase}.pb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.pb-cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:8px;border:none;background:none;font-size:.8rem;font-weight:500;cursor:pointer;color:var(--text);font-family:inherit}.pb-cal-day:hover:not(:disabled){background:var(--bg)}.pb-cal-day.selected{background:var(--pb-accent);color:#fff;font-weight:700}.pb-cal-day.past{color:var(--border);cursor:default}.pb-slots{display:flex;flex-direction:column}.pb-slots-hint{display:flex;align-items:center;justify-content:center;gap:8px;height:100%;color:var(--muted);font-size:.84rem;text-align:center}.pb-slots-label{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:var(--muted);margin-bottom:10px}.pb-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:260px;overflow-y:auto}.pb-slot{padding:8px 4px;border-radius:8px;border:1.5px solid var(--border);background:#fff;font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;text-align:center;transition:border-color .15s}.pb-slot:hover{border-color:var(--pb-accent)}.pb-slot.selected{background:var(--pb-accent);color:#fff;border-color:var(--pb-accent);font-weight:700}.pb-summary-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;font-size:.78rem}.pb-summary-bar span{padding:4px 12px;border-radius:20px;background:var(--bg);color:var(--text);font-weight:500}.pb-form{display:flex;flex-direction:column;gap:16px;position:relative}.pb-field label{display:block;font-size:.78rem;font-weight:600;margin-bottom:6px;color:var(--text)}.pb-field input,.pb-field textarea,.pb-field select{width:100%;padding:10px 14px;border-radius:10px;border:1.5px solid var(--border);font-family:inherit;font-size:.88rem;outline:none;transition:border-color .15s;background:#fff}.pb-field input:focus,.pb-field textarea:focus,.pb-field select:focus{border-color:var(--pb-accent)}.pb-field textarea{resize:vertical}.pb-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pb-form-err{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--red);font-weight:500}.pb-confirmed{text-align:center;padding:40px 24px}.pb-confirm-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.pb-confirm-sub{color:var(--muted);font-size:.88rem;margin-bottom:24px}.pb-confirm-details{text-align:left;background:var(--bg);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:8px;font-size:.88rem;margin-bottom:24px}.pb-confirm-details strong{color:var(--muted);font-weight:600;margin-right:6px}.pb-footer{display:flex;justify-content:space-between;align-items:center;margin-top:20px}.pb-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:10px;border:none;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s,box-shadow .15s}.pb-btn.primary{background:var(--pb-accent);color:#fff}.pb-btn.primary:hover:not(:disabled){opacity:.9;box-shadow:0 4px 14px #0000001f}.pb-btn.primary:disabled{opacity:.45;cursor:default}.pb-btn.ghost{background:none;color:var(--muted)}.pb-btn.ghost:hover{color:var(--text)}.pb-about{border-top:1px solid var(--border);margin-top:16px;padding:16px 24px;text-align:center}.pb-about-title{font-size:.85rem;font-weight:600;color:var(--text);margin:0 0 8px}.pb-about-items{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 24px}.pb-about-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted)}.pb-about-item a{color:var(--muted);text-decoration:none}.pb-about-item a:hover{color:var(--pb-accent);text-decoration:underline}.pb-about-content{display:flex;flex-direction:column;align-items:center;gap:14px}.pb-map{width:100%;max-width:480px;border-radius:10px;overflow:hidden;border:1px solid var(--border)}.pb-map iframe{width:100%;height:180px;border:0;display:block}.pb-manage-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg);border-radius:10px;padding:4px}.pb-manage-tab{flex:1;padding:10px 0;background:none;border:none;cursor:pointer;font-size:.86rem;font-weight:500;color:var(--muted);border-radius:8px;transition:all .15s}.pb-manage-tab.active{background:#fff;color:var(--pb-accent);font-weight:600;box-shadow:0 1px 4px #00000014}.pb-manage-tab:hover:not(.active){color:var(--text)}.pb-powered{text-align:center;font-size:.72rem;color:var(--muted);padding-bottom:16px}.pb-powered a{color:var(--pb-accent);text-decoration:none;font-weight:600}.pb-powered a:hover{text-decoration:underline}@media(max-width:600px){.pb-page{padding:12px 8px}.pb-wrap{gap:16px}.pb-logo{font-size:1.3rem}.pb-subtitle{font-size:.8rem}.pb-body{padding:18px 14px;border-radius:12px}.pb-title{font-size:1rem;margin-bottom:14px}.pb-progress{gap:4px}.pb-step{font-size:.68rem;gap:4px}.pb-step-dot{width:20px;height:20px;font-size:.62rem}.pb-datetime{grid-template-columns:1fr;gap:16px}.pb-calendar{padding:12px}.pb-cal-day{font-size:.82rem}.pb-slots-grid{grid-template-columns:repeat(3,1fr);gap:8px}.pb-slot{padding:10px 4px;font-size:.82rem}.pb-card{padding:12px 14px;gap:10px}.pb-card-name{font-size:.86rem}.pb-card-meta{font-size:.74rem}.pb-grid{grid-template-columns:1fr}.pb-grid-scroll{max-height:360px}.pb-search input{font-size:.84rem}.pb-field-row{grid-template-columns:1fr}.pb-field input,.pb-field textarea,.pb-field select{font-size:.86rem;padding:10px 12px}.pb-summary-bar{font-size:.72rem}.pb-btn{padding:11px 16px;font-size:.84rem}.pb-confirm-details{padding:16px;font-size:.84rem}.pb-about{padding:14px 12px}.pb-about-items{flex-direction:column;gap:8px;align-items:center}.pb-map iframe{height:150px}}
