:root{color-scheme:light;--bg-canvas: #f7f8f8;--bg-surface: #ffffff;--bg-subtle: #f4f6f7;--fg-base: #131214;--fg-muted: #6e7375;--fg-subtle: #898d8f;--border: #e6e9eb;--border-strong: #daddde;--accent: #7257ff;--accent-bold: #5336e2;--accent-subtle: #f0edff;--error: #ff9175;--error-bg: #fff3f0;--warning-bg: #fff6d8;--warning-fg: #745000;--green-bg: #bdffdb;--green-border: #8fdcb2;--green-fg: #2c5a41;--blue-bg: #dbe9ff;--blue-border: #a9c7ff;--blue-fg: #1b4c96;--purple-bg: #ede7ff;--purple-border: #cabdff;--purple-fg: #5336e2;--amber-bg: #fff0bd;--amber-border: #e3c979;--amber-fg: #644800;--red-bg: #ffcec2;--red-border: #ff9175;--red-fg: #8a1700;--shadow-low: 0 0 .5px rgba(20, 20, 20, .12), 0 1px 8px rgba(20, 20, 20, .08);--sticky-offset: 108px;font-family:Plus Jakarta Sans,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;background:var(--bg-canvas);color:var(--fg-base)}body.overlay-open{overflow:hidden;touch-action:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:268px minmax(0,1fr);transition:grid-template-columns .18s ease}.app-shell--sidebar-collapsed{grid-template-columns:88px minmax(0,1fr)}.pull-refresh{position:fixed;top:max(10px,env(safe-area-inset-top));left:50%;z-index:80;display:inline-flex;align-items:center;gap:8px;min-height:38px;border:1px solid var(--border);border-radius:999px;padding:0 14px;background:var(--bg-surface);box-shadow:var(--shadow-low);color:var(--fg-muted);font-size:12px;font-weight:700;opacity:0;translate:-50% 0;transition:opacity .16s ease,transform .16s ease;pointer-events:none}.pull-refresh--visible{opacity:1}.spin{animation:spin .9s linear infinite}@keyframes spin{to{rotate:360deg}}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:28px;padding:24px;background:var(--bg-surface);border-right:1px solid var(--border);transition:width .18s ease,padding .18s ease;overflow:hidden}.sidebar__brand,.sidebar__footer{display:flex;align-items:center;gap:12px}.sidebar__brand{position:relative}.sidebar__brand-copy{min-width:0;flex:1}.sidebar__brand strong,.sidebar__brand span,.sidebar__footer span{display:block}.sidebar__brand span,.sidebar__footer span{color:var(--fg-muted);font-size:12px}.brand-mark{width:40px;height:40px;border-radius:16px;display:grid;place-items:center;background:var(--accent);color:#fff;box-shadow:var(--shadow-low)}.sidebar__toggle{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--border);border-radius:999px;background:var(--bg-surface);color:var(--fg-muted)}.sidebar__toggle:hover{color:var(--accent-bold);border-color:var(--accent)}.sidebar__nav{display:grid;gap:6px}.nav-item,.sidebar__footer button,.bottom-tabs__item{border:0;background:transparent;color:var(--fg-muted)}.nav-item{height:44px;border-radius:999px;display:flex;align-items:center;gap:12px;padding:0 14px;font-weight:700}.nav-item svg,.sidebar__footer svg{flex:0 0 auto}.nav-item:hover,.nav-item--active{background:var(--accent-subtle);color:var(--accent-bold)}.sidebar__footer{margin-top:auto;justify-content:space-between}.sidebar__footer button{display:inline-flex;align-items:center;gap:6px}.sidebar--collapsed{padding-inline:18px}.sidebar--collapsed .sidebar__brand{display:grid;justify-items:center}.sidebar--collapsed .sidebar__brand-copy,.sidebar--collapsed .nav-item__label,.sidebar--collapsed .sidebar__email,.sidebar--collapsed .sidebar__logout-label{display:none}.sidebar--collapsed .sidebar__toggle{margin-top:8px}.sidebar--collapsed .nav-item{justify-content:center;padding:0}.sidebar--collapsed .sidebar__footer{justify-content:center}.workspace{min-width:0;padding:28px 28px 110px;overflow:clip}.sticky-header{position:sticky;top:0;z-index:30;display:grid;gap:14px;margin:-28px -28px 16px;padding:28px 28px 16px;background:color-mix(in srgb,var(--bg-canvas) 94%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(230,233,235,.72)}.topbar{display:flex;align-items:center;justify-content:flex-start;gap:18px}.topbar h1,.auth-card h1,.detail-panel h2,.calendar-toolbar h2{margin:0;line-height:1;letter-spacing:0}.eyebrow{margin:0 0 8px;color:var(--fg-muted);font-size:12px;font-weight:700;text-transform:uppercase}.actionbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:18px}.actionbar__search{flex:1;min-width:0}.search-field{width:min(620px,100%);height:40px;display:flex;align-items:center;gap:10px;border:1px solid var(--border);border-radius:999px;padding:0 14px;background:var(--bg-surface);color:var(--fg-muted)}.search-field input{min-width:0;flex:1;border:0;outline:0;background:transparent}.pc-button{border:0;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;line-height:1;min-height:40px;padding:0 20px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.pc-button:hover{transform:translateY(-1px)}.pc-button--primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-low)}.pc-button--secondary{background:var(--accent-subtle);color:var(--accent-bold)}.pc-button--ghost{background:var(--bg-subtle);color:var(--fg-base)}.pc-button--danger{background:var(--error-bg);color:var(--red-fg)}.pc-button--sm{min-height:32px;padding:0 14px;font-size:13px}.metric-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:20px}.metric{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:14px}.metric span{display:block;color:var(--fg-muted);font-size:12px;margin-bottom:8px}.metric strong{font-size:26px;line-height:1}.metric--warning{background:var(--warning-bg);color:var(--warning-fg);border-color:#ecd386}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.summary-card{min-width:0;border:1px solid var(--border);border-radius:8px;padding:12px 14px;background:var(--bg-surface)}.summary-card span,.summary-card strong{display:block}.summary-card span{color:var(--fg-muted);font-size:12px;font-weight:700;margin-bottom:6px}.summary-card strong{font-size:20px;line-height:1.1;white-space:nowrap}.summary-card--warning{background:var(--warning-bg);border-color:var(--amber-border)}.summary-card--success{background:var(--green-bg);border-color:var(--green-border)}.summary-card--danger{background:var(--error-bg);border-color:var(--red-border)}.split-layout,.patients-layout,.calendar-layout,.payments-layout{display:grid;grid-template-columns:minmax(280px,380px) minmax(0,1fr);gap:16px;align-items:start}.patients-layout{grid-template-columns:minmax(0,720px)}.list-surface,.detail-panel,.content-stack,.day-drawer{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px}.list-surface{overflow:hidden}.patient-row{width:100%;min-height:72px;display:flex;align-items:center;gap:14px;border:0;border-bottom:1px solid var(--border);background:transparent;padding:12px 16px;text-align:left;touch-action:pan-y}.patient-row:hover,.patient-row--active{background:var(--accent-subtle)}.patient-row span:not(.avatar){min-width:0}.patient-row strong,.patient-row small{display:block}.patient-row small{margin-top:5px;color:var(--fg-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--border);color:var(--fg-base);font-weight:700;flex:0 0 auto}.detail-panel,.content-stack,.day-drawer{padding:18px}.payments-page{display:grid;gap:16px}.detail-panel__header,.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}.form-grid--compact{grid-template-columns:repeat(3,minmax(0,1fr))}.field{display:grid;gap:7px;min-width:0}.field__label{font-size:12px;color:var(--fg-muted);font-weight:700}.field__control{min-width:0;width:100%;min-height:48px;border:1px solid var(--border);border-radius:8px;padding:0 14px;color:var(--fg-base);background:var(--bg-surface);outline:0}.field__control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.field__control--error{border:2px solid var(--error);background:var(--error-bg)}.field__control--area{min-height:92px;padding-block:12px;resize:vertical}.field__caption{color:var(--fg-muted);font-size:12px}.field__caption--error{color:var(--red-fg)}.patient-detail .field__control--area{grid-column:1 / -1}.detail-grid,.payments-layout{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;gap:14px;margin-top:22px}.detail-grid h3,.content-stack h2{margin:0 0 10px;font-size:16px}.stack,.content-stack{display:grid;gap:10px}.filters-panel{display:grid;gap:12px;border:1px solid var(--border);border-radius:8px;padding:14px;background:var(--bg-surface)}.filters-panel__title,.result-count{display:inline-flex;align-items:center;gap:8px;color:var(--fg-muted);font-size:12px}.filters-panel__title strong{color:var(--fg-base)}.filters-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.compact-row,.payment-row,.appointment-row{display:flex;align-items:center;gap:10px;min-width:0;border:1px solid var(--border);border-radius:8px;padding:12px;background:var(--bg-surface)}.compact-row--button{width:100%;text-align:left;cursor:pointer}.compact-row--button:hover{border-color:var(--accent);background:var(--accent-subtle)}.compact-row>div,.payment-row>div,.appointment-row__main{min-width:0;flex:1}.compact-row strong,.compact-row small,.payment-row strong,.payment-row span,.payment-row small,.appointment-row__main strong,.appointment-row__main span{display:block;overflow:hidden;text-overflow:ellipsis}.compact-row small,.payment-row span,.payment-row small,.appointment-row__main span{margin-top:4px;color:var(--fg-muted);font-size:12px}.segmented{display:inline-grid;grid-auto-flow:column;align-items:center;background:var(--bg-subtle);padding:2px;border-radius:999px;width:min(100%,540px);min-height:34px}.segmented__item{border:0;min-height:30px;border-radius:999px;background:transparent;color:var(--fg-subtle);font-size:12px;font-weight:700;padding:0 12px}.segmented__item--active{background:var(--bg-surface);color:var(--accent);box-shadow:var(--shadow-low)}.group-section h2{position:sticky;top:var(--sticky-offset);z-index:12;margin:14px 0 8px;padding:8px 0;background:var(--bg-canvas);font-size:18px;line-height:1.15}.appointment-list{display:grid;gap:8px}.appointment-row{display:grid;grid-template-columns:120px minmax(0,1fr) minmax(230px,auto) minmax(170px,auto);align-items:center}.appointment-row__badges{min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.appointment-row__date strong,.appointment-row__date small{display:block}.appointment-row__date small{color:var(--fg-muted);margin-top:4px}.event-pill,.payment-badge,.status-badge{display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid;border-radius:999px;min-height:26px;padding:0 10px;font-family:Poppins,var(--font-family, sans-serif);font-size:11px;font-weight:700;white-space:nowrap}.event-pill--compact{min-height:22px;padding:0 8px;font-size:10px}.event-pill--green{background:var(--green-bg);border-color:var(--green-border);color:var(--green-fg)}.event-pill--blue{background:var(--blue-bg);border-color:var(--blue-border);color:var(--blue-fg)}.event-pill--purple{background:var(--purple-bg);border-color:var(--purple-border);color:var(--purple-fg)}.event-pill--amber{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber-fg)}.event-pill--red{background:var(--red-bg);border-color:var(--red-border);color:var(--red-fg)}.payment-badge--paid{background:var(--green-bg);border-color:var(--green-border);color:var(--green-fg)}.payment-badge--unpaid{background:var(--error-bg);border-color:var(--red-border);color:var(--red-fg)}.payment-badge--partial{background:var(--warning-bg);border-color:var(--amber-border);color:var(--warning-fg)}.payment-badge--not_due,.status-badge{background:var(--bg-subtle);border-color:var(--border-strong);color:var(--fg-muted)}.status-badge--completed{background:var(--green-bg);border-color:var(--green-border);color:var(--green-fg)}.status-badge--cancelled{background:var(--error-bg);border-color:var(--red-border);color:var(--red-fg)}.payment-group{display:grid;gap:8px}.payment-group+.payment-group{margin-top:8px}.payment-group__head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:4px 2px}.payment-group__head strong{font-size:15px}.payment-group__head span,.row-amount{color:var(--fg-muted);font-size:12px;white-space:nowrap}.row-amount{color:var(--fg-base);font-size:14px}.calendar-layout{grid-template-columns:minmax(0,1fr) 320px}.calendar-toolbar{grid-column:1 / -1;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:12px;margin:0}.calendar-toolbar h2{text-transform:capitalize}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.calendar-grid__head{padding:12px;border-bottom:1px solid var(--border);color:var(--fg-muted);font-size:12px;font-weight:700}.calendar-cell{min-height:126px;border:0;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-surface);padding:10px;text-align:left;overflow:hidden}.calendar-cell:nth-child(7n+7){border-right:0}.calendar-cell--muted{background:var(--bg-subtle);color:var(--fg-subtle)}.calendar-cell--active{outline:2px solid var(--accent);outline-offset:-2px}.calendar-cell__day{display:block;font-weight:700;margin-bottom:8px}.calendar-cell__events,.calendar-event-line{display:grid;gap:5px}.calendar-event-line{grid-template-columns:auto minmax(0,1fr);align-items:center;cursor:pointer;border-radius:4px}.calendar-event-line:hover{background:var(--accent-subtle)}.calendar-event-line em{min-width:0;color:var(--fg-muted);font-size:11px;font-style:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-drawer{position:sticky;top:20px}.day-drawer h3{margin:0 0 14px;text-transform:capitalize}.empty-state{display:grid;place-items:center;min-height:120px;border:1px dashed var(--border-strong);border-radius:8px;padding:20px;text-align:center;color:var(--fg-muted)}.empty-state strong{color:var(--fg-base)}.empty-state p{margin:8px 0 0;max-width:32rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:18px;background:#1312145c;z-index:50;overscroll-behavior:contain;touch-action:none}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;display:grid;align-items:end;justify-items:center;padding:18px;background:#13121447;overscroll-behavior:contain;touch-action:none}.bottom-sheet{position:relative;width:min(920px,100%);max-height:min(820px,calc(100vh - 42px));overflow:auto;border:1px solid var(--border);border-radius:18px 18px 8px 8px;padding:10px 20px 20px;background:var(--bg-surface);box-shadow:0 24px 80px #13121433;overscroll-behavior:contain;touch-action:pan-y}.sheet-handle{width:42px;height:4px;border-radius:999px;margin:2px auto 14px;background:var(--border-strong)}.modal{position:relative;width:min(620px,100%);max-height:min(860px,calc(100vh - 36px));overflow:auto;background:var(--bg-surface);border-radius:16px;padding:20px;box-shadow:0 24px 80px #13121433;overscroll-behavior:contain;touch-action:pan-y}.modal__x{position:sticky;top:0;left:100%;z-index:5;width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--border);border-radius:999px;margin:0 0 -36px auto;background:var(--bg-surface);color:var(--fg-muted);box-shadow:var(--shadow-low)}.modal__x:hover{color:var(--fg-base);border-color:var(--border-strong)}.modal__header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 44px 16px 0}.modal__header h2{margin:0}.form-stack{display:grid;gap:12px}.form-actions{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:20px;background:var(--bg-canvas)}.auth-card{width:min(420px,100%);display:grid;gap:16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;padding:22px;box-shadow:var(--shadow-low)}.error-banner{padding:12px 14px;border:1px solid var(--error);border-radius:8px;background:var(--error-bg);color:var(--red-fg);margin-bottom:14px}.bottom-tabs{display:none}@media(max-width:980px){:root{--sticky-offset: 126px}.app-shell{display:block}.sidebar{display:none}.workspace{padding:max(16px,env(safe-area-inset-top)) 14px calc(92px + env(safe-area-inset-bottom));overflow:visible}.sticky-header{top:0;margin:calc(-1*max(16px,env(safe-area-inset-top))) -14px 16px;padding:max(16px,env(safe-area-inset-top)) 14px 14px}.topbar{align-items:flex-start}.actionbar{align-items:center;margin-bottom:16px}.search-field{width:100%}.metric-strip,.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-layout,.patients-layout,.calendar-layout,.payments-layout,.detail-grid{grid-template-columns:1fr}.list-surface{overflow:visible}.appointment-row{grid-template-columns:1fr;align-items:start}.payment-row{align-items:flex-start;flex-wrap:wrap}.row-amount{margin-left:0}.appointment-row__badges{width:100%}.calendar-cell{min-height:94px;padding:8px}.calendar-event-line{grid-template-columns:minmax(0,1fr)}.calendar-event-line em,.calendar-event-line .event-pill span{display:none}.day-drawer{position:static}.filters-grid{grid-template-columns:1fr}.bottom-sheet{max-height:calc(92vh - env(safe-area-inset-bottom));border-radius:18px 18px 0 0;padding-inline:16px;padding-bottom:calc(20px + env(safe-area-inset-bottom))}.bottom-tabs{position:fixed;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));background:var(--bg-surface);border-top:1px solid var(--border);padding:6px 8px calc(6px + env(safe-area-inset-bottom));z-index:20}.bottom-tabs__item{min-height:56px;display:grid;place-items:center;gap:3px;border-radius:12px;font-size:11px}.bottom-tabs__item--active{color:var(--accent);background:var(--accent-subtle);font-weight:700}}@media(max-width:640px){:root{--sticky-offset: 126px}.topbar{display:grid}.topbar h1{font-size:28px}.form-grid,.form-grid--compact{grid-template-columns:1fr}.metric strong{font-size:22px}.summary-card strong{font-size:18px}.actionbar{display:flex;gap:8px}.actionbar .pc-button{flex:0 0 auto;padding-inline:16px}.search-field{min-width:0;height:42px;padding-inline:12px}.calendar-grid__head{padding:8px 4px;text-align:center}.calendar-cell{min-height:72px}}
