:root{--bg:#f4f6fb;--panel:#ffffff;--panel-border:#dde4f0;--text:#1c2434;--muted:#667085;--accent:#2457d6;--accent-light:#edf3ff;--danger:#b42318;--success:#027a48;--warning:#b54708;--shadow:0 16px 40px rgba(15,23,42,0.08);--radius:18px}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.file-picker,.secondary-button,button{border:none;border-radius:14px;padding:.8rem 1rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.file-picker:hover,.secondary-button:hover,button:hover{transform:translateY(-1px)}.file-picker:disabled,.secondary-button:disabled,button:disabled{cursor:not-allowed;opacity:.7;transform:none}button{background:var(--accent);color:white;box-shadow:0 10px 20px rgba(36,87,214,.18)}.file-picker,.secondary-button{background:var(--panel);color:var(--text);border:1px solid var(--panel-border);display:inline-flex;align-items:center;justify-content:center;box-shadow:none}.secondary-button.active-soft{background:var(--accent-light);color:var(--accent);border-color:#c9d9ff}.danger-button{background:#fff1f0;color:var(--danger);border:1px solid #f7c0bc;box-shadow:none}input,select,textarea{width:100%;border:1px solid var(--panel-border);border-radius:14px;padding:.9rem 1rem;background:white;color:var(--text)}textarea{resize:vertical}label{display:grid;grid-gap:.45rem;gap:.45rem;font-size:.95rem}label span{color:var(--muted)}h1,h2,h3,p{margin-top:0}.muted{color:var(--muted)}.success-text{color:var(--success)}.error-text{color:var(--danger)}.fullscreen-center{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.auth-card,.modal-card,.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);box-shadow:var(--shadow)}.auth-card{width:min(460px,100%);padding:2rem}.narrow-panel{width:min(420px,100%);padding:1.5rem}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{padding:1.5rem;background:#0f1728;color:white;display:grid;grid-template-rows:auto 1fr auto;grid-gap:2rem;gap:2rem}.brand{font-size:1.35rem;font-weight:700}.nav-list{display:grid;grid-gap:.75rem;gap:.75rem;align-content:start}.nav-link{padding:.9rem 1rem;border-radius:14px;color:rgba(255,255,255,.85);background:rgba(255,255,255,.04)}.nav-link.active{color:white;background:rgba(255,255,255,.16)}.sidebar-footer{display:grid;grid-gap:.9rem;gap:.9rem}.user-chip{display:grid;grid-gap:.2rem;gap:.2rem;padding:1rem;border-radius:14px;background:rgba(255,255,255,.08)}.user-chip small,.user-chip span{color:rgba(255,255,255,.72)}.main-content{padding:2rem;display:grid;align-content:start;grid-gap:1.25rem;gap:1.25rem}.page-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.app-header-extended{align-items:center}.header-shortcuts{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:flex-end}.modal-card,.panel{padding:1.3rem}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1.25rem;gap:1.25rem}.grid-three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:1rem;gap:1rem}.inline-form{display:flex;gap:.75rem;align-items:stretch}.list-stack,.stack{display:grid;grid-gap:1rem;gap:1rem}.top-gap{margin-top:1rem}.search-result-card{text-align:left;display:grid;grid-gap:.2rem;gap:.2rem;background:var(--accent-light);color:var(--text);box-shadow:none;border:1px solid #d9e4ff}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:1rem;gap:1rem}.full-span{grid-column:1/-1}.actions-row,.badge-row,.photo-actions,.photo-links,.tag-row,.visit-links{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.stats-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:.8rem;gap:.8rem}.stat-card{padding:1rem;border-radius:16px;background:var(--accent-light);border:1px solid #d9e4ff}.stat-card strong{display:block;font-size:1.15rem;margin-top:.5rem}table{width:100%;border-collapse:collapse;font-size:.96rem}td,th{text-align:left;padding:.85rem .6rem;border-bottom:1px solid var(--panel-border);vertical-align:top}th{color:var(--muted);font-weight:600}.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.35rem .75rem;font-size:.84rem;font-weight:600;background:#eef2ff;color:#3730a3;text-transform:capitalize}.status-badge.status-completed{background:#e8fbf1;color:#027a48}.status-badge.status-uploading{background:#fff3e0;color:#b54708}.status-badge.status-archived{background:#f2f4f7;color:#344054}.dropzone{border:2px dashed #c5d0e6;border-radius:20px;padding:2rem;background:#fcfdff;text-align:center;display:grid;grid-gap:.9rem;gap:.9rem;justify-items:center}.dropzone-active{border-color:var(--accent);background:var(--accent-light)}.dropzone-title{font-size:1.1rem;font-weight:700}.upload-stack{display:grid;grid-gap:1rem;gap:1rem}.upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.editor-card,.photo-card,.template-editor-item,.template-item,.upload-card{background:white;border:1px solid var(--panel-border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}.photo-card img,.upload-preview{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;background:#e7edf8}.photo-card-body,.upload-body{padding:.95rem;display:grid;grid-gap:.6rem;gap:.6rem}.progress-track{width:100%;height:8px;border-radius:999px;background:#e4e7ec;overflow:hidden}.progress-track-tall{height:12px}.progress-bar{height:100%;border-radius:999px;background:var(--accent)}.link-button{color:var(--accent);font-weight:600}.bulk-editor,.panel-muted-block,.visit-summary{display:grid;grid-gap:.65rem;gap:.65rem;background:var(--accent-light);border-radius:16px;padding:1rem;border:1px solid #d9e4ff}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.photo-grid-rich{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.photo-card-rich{display:grid}.photo-card-selected{border-color:#8db0ff;box-shadow:0 0 0 2px rgba(36,87,214,.12),var(--shadow)}.photo-card-topline{display:flex;justify-content:space-between;gap:.75rem;align-items:center;padding:.75rem .9rem 0}.photo-preview-button{border:none;background:transparent;padding:0;cursor:pointer;box-shadow:none}.photo-preview-button:hover{transform:none}.photo-card-heading{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.photo-card-heading strong{display:block;overflow-wrap:anywhere}.mini-tag{display:inline-flex;align-items:center;gap:.25rem;background:var(--accent-light);color:var(--accent);border:1px solid #d9e4ff;border-radius:999px;padding:.25rem .55rem;font-size:.82rem;font-weight:600}.mini-tag-success{background:#e8fbf1;color:var(--success);border-color:#b7ebcf}.admin-grid-2,.gallery-toolbar-grid,.photo-meta-grid,.template-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem;gap:.75rem}.gallery-toolbar-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.gallery-toolbar-grid.compact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-placeholder{width:100%;aspect-ratio:4/3;display:grid;place-items:center;background:#eef2f7;color:var(--muted);padding:1rem;text-align:center}.compact-button{padding:.7rem .85rem;font-size:.92rem}.admin-columns{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:1rem;gap:1rem}.checkbox-grid{grid-gap:.6rem;gap:.6rem}.checkbox-item{display:flex;gap:.6rem;color:var(--text)}.checkbox-line{justify-content:flex-start}.inline-end{display:flex;align-items:flex-end;justify-content:flex-end}.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.62);display:grid;place-items:center;padding:1.25rem;z-index:50}.compare-modal-card,.crop-modal-card,.palette-card{width:min(1100px,100%);max-height:calc(100vh - 2rem);overflow:auto}.compare-modal-card{display:grid;grid-gap:1rem;gap:1rem}.crop-stage{position:relative;display:inline-block;width:100%;max-height:72vh;overflow:auto;border-radius:18px;background:#0f1728;touch-action:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.crop-stage img{width:100%;height:auto;display:block}.crop-selection{position:absolute;border:2px solid #ffffff;background:rgba(36,87,214,.28);box-shadow:0 0 0 9999px rgba(15,23,42,.35);pointer-events:none}.crop-footer{margin-top:1rem;display:flex;justify-content:space-between;gap:1rem;align-items:center}.crop-hint{min-height:1.2rem}.template-checklist{display:grid;grid-gap:1rem;gap:1rem}.template-checklist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:.85rem;gap:.85rem}.template-item{display:grid;grid-gap:.65rem;gap:.65rem;padding:1rem;box-shadow:none}.template-item-done{background:#f3fbf6;border-color:#b7ebcf}.template-item-head{display:flex;gap:.75rem;justify-content:space-between;align-items:flex-start}.template-item-meta{display:flex;flex-wrap:wrap;gap:.45rem .8rem;font-size:.88rem}.editor-card,.template-editor-item{padding:1rem;background:#fbfcff;box-shadow:none}.checkbox-inline{align-content:start}.template-editor-grid{grid-template-columns:120px 1.3fr 1fr 1fr;gap:.8rem}.compare-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.compare-stage-wrap{display:grid;grid-gap:.8rem;gap:.8rem}.compare-single-stage,.compare-stage{position:relative;border-radius:18px;overflow:hidden;background:#0f1728}.compare-overlay img,.compare-single-stage img,.compare-stage>img{width:100%;display:block}.compare-overlay{position:absolute;inset:0;height:100%;overflow:hidden}.compare-divider{position:absolute;top:0;bottom:0;width:2px;background:white;transform:translateX(-1px);box-shadow:0 0 0 9999px rgba(255,255,255,.04)}.compare-label{position:absolute;top:12px;padding:.3rem .6rem;border-radius:999px;background:rgba(15,23,42,.8);color:white;font-size:.8rem;font-weight:700}.compare-label-left{left:12px}.compare-label-right{right:12px}.missing-list{display:grid;grid-gap:.5rem;gap:.5rem}.palette-backdrop{align-items:start;padding-top:8vh}.palette-card{display:grid;grid-gap:1rem;gap:1rem;width:min(760px,100%)}.palette-list{display:grid;grid-gap:.75rem;gap:.75rem}.palette-item{width:100%;text-align:left;border:1px solid var(--panel-border);background:#fbfcff;box-shadow:none;display:grid;grid-gap:.25rem;gap:.25rem}.palette-item span{color:var(--muted)}.palette-item-active{border-color:#b7c9ff;background:var(--accent-light)}.toast-stack{position:fixed;right:1rem;bottom:1rem;z-index:120;display:grid;grid-gap:.75rem;gap:.75rem;width:min(420px,calc(100vw - 2rem))}.toast{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:.95rem 1rem;border-radius:16px;border:1px solid var(--panel-border);background:white;box-shadow:var(--shadow)}.toast-success{border-color:#b7ebcf;background:#f3fbf6}.toast-error{border-color:#f7c0bc;background:#fff7f6}.toast-info{border-color:#cfe0ff;background:#f7faff}.toast-body{display:grid;grid-gap:.25rem;gap:.25rem}.toast-close{background:transparent;color:var(--muted);padding:.15rem .4rem;box-shadow:none}@media (max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{grid-template-rows:auto auto auto}.admin-columns,.admin-grid-2,.form-grid,.gallery-toolbar-grid,.gallery-toolbar-grid.compact-grid,.grid-three,.grid-two,.photo-meta-grid,.stats-row,.template-editor-grid{grid-template-columns:1fr}}@media (max-width:720px){.compare-modal-card,.crop-modal-card,.main-content,.palette-card,.sidebar{padding:1rem}.app-header-extended,.crop-footer,.inline-form,.page-header{flex-direction:column}.header-shortcuts,.visit-links{justify-content:flex-start}table{font-size:.9rem}}.before-after-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem}.assistant-suggestion-card,.before-after-card,.chairside-slot,.handoff-qr-card,.tethered-log-item{border:1px solid var(--panel-border);border-radius:18px;background:#fff;box-shadow:var(--shadow)}.assistant-suggestion-card,.before-after-card,.chairside-slot{padding:1rem}.before-after-head,.chairside-slot-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.before-after-thumb-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.75rem;gap:.75rem;margin:.75rem 0}.before-after-thumb-grid img,.chairside-slot-preview img{width:100%;border-radius:14px;border:1px solid var(--panel-border);background:#f7f8fb}.chairside-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:1rem;gap:1rem}.chairside-slot-active{border-color:#9cc6ff;box-shadow:0 0 0 3px rgba(59,130,246,.12)}.chairside-slot-preview{margin:.85rem 0}.chairside-slot-empty{min-height:180px;display:grid;place-items:center;border:1px dashed var(--panel-border);border-radius:14px;background:#fafbff}.handoff-grid{display:grid;grid-template-columns:220px 1fr;grid-gap:1rem;gap:1rem;align-items:center}.handoff-qr-card{padding:1rem;display:grid;place-items:center}.handoff-qr{width:180px;height:180px;object-fit:contain}.code-block{display:block;padding:.75rem;border-radius:12px;border:1px solid var(--panel-border);background:#f8fafc;overflow-wrap:anywhere;font-size:.85rem}.tethered-log{display:grid;grid-gap:.5rem;gap:.5rem}.tethered-log-item{padding:.75rem .9rem}.assistant-suggestion-list{display:grid;grid-gap:.75rem;gap:.75rem}.assistant-reason-list{margin:.6rem 0 0;padding-left:1.2rem;color:var(--muted)}.compact-header{align-items:center}@media (max-width:960px){.before-after-thumb-grid,.handoff-grid{grid-template-columns:1fr}}.nav-link-strong{background:rgba(36,87,214,.22);border:1px solid rgba(255,255,255,.12);color:white;font-weight:700}.primary-button-emphasis{min-width:220px;font-weight:700;font-size:1rem;box-shadow:0 16px 32px rgba(36,87,214,.24)}.selected-patient-card{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:1rem 1.1rem;border:1px solid var(--panel-border);border-radius:16px;background:var(--accent-light)}.new-visit-hero{border:1px solid #c9d9ff}.template-progress-sticky{position:-webkit-sticky;position:sticky;top:1rem;z-index:15;padding:.9rem 1rem;border-radius:16px;border:1px solid var(--panel-border);background:rgba(255,255,255,.96);box-shadow:var(--shadow)}.template-progress-sticky-compact{gap:.65rem}.template-progress-main{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.top-gap-xs{margin-top:.35rem}.admin-summary-grid .stat-card{min-height:110px}.stat-card-emphasis{border:1px solid #c9d9ff;background:var(--accent-light)}.checkbox-large{padding:.6rem 0}.admin-main-grid{align-items:start}.admin-list{display:grid;grid-gap:.55rem;gap:.55rem;max-height:280px;overflow:auto}.admin-list-item{width:100%;text-align:left;background:var(--panel);color:var(--text);border:1px solid var(--panel-border);box-shadow:none;display:grid;grid-gap:.2rem;gap:.2rem}.admin-list-item-active{background:var(--accent-light);border-color:#c9d9ff}.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.5rem .75rem;gap:.5rem .75rem}.checkbox-item{display:inline-flex;align-items:center;gap:.5rem}.checkbox-item input{width:auto}.checkbox-line{width:-moz-fit-content;width:fit-content}.admin-template-grid{align-items:start}.compact-template-list-panel{min-width:0}.compact-template-list{display:grid;grid-gap:.4rem;gap:.4rem;max-height:520px;overflow:auto}.compact-template-row{width:100%;text-align:left;background:var(--panel);color:var(--text);border:1px solid var(--panel-border);box-shadow:none}.compact-template-row-active{background:var(--accent-light);border-color:#c9d9ff}.compact-template-item-editor{border:1px solid var(--panel-border);border-radius:14px;padding:.85rem;background:white}.audit-log-list{display:grid;grid-gap:.55rem;gap:.55rem;max-height:360px;overflow:auto}.audit-log-row{display:grid;grid-gap:.15rem;gap:.15rem;padding:.8rem .9rem;border-radius:14px;border:1px solid var(--panel-border);background:white}.compact-metrics-list{display:grid;grid-gap:.55rem;gap:.55rem}.compact-metric-row{display:flex;justify-content:space-between;gap:1rem;padding:.7rem .8rem;border:1px solid var(--panel-border);border-radius:14px;background:white}.compact-metric-row-multiline{align-items:center}.compact-metric-row-multiline div{display:grid;grid-gap:.15rem;gap:.15rem}.visit-links{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:flex-end}.compact-metric-row span,.compact-template-row span,.selected-patient-card strong{word-break:break-word}@media (max-width:960px){.compact-metric-row,.selected-patient-card,.template-progress-main{flex-direction:column;align-items:flex-start}.checkbox-grid{grid-template-columns:1fr}}.app-shell{align-items:start}.sidebar{position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto;scrollbar-width:thin}.brand-stack,.sidebar-top{display:grid;grid-gap:1rem;gap:1rem}.brand-logo{max-width:170px;width:100%;height:auto}.brand-subtitle{max-width:16rem}.main-content{min-width:0;padding-bottom:3rem}.login-screen{background:radial-gradient(circle at top left,rgba(36,87,214,.09),transparent 28%),linear-gradient(180deg,#f7f8fc,#eef2fb)}.login-card-enhanced{width:min(520px,100%)}.login-brand-block{display:grid;grid-gap:1rem;gap:1rem;margin-bottom:1.5rem}.login-brand-logo{width:96px;height:auto}.brand-loading-screen{background:radial-gradient(circle at top left,rgba(36,87,214,.09),transparent 28%),linear-gradient(180deg,#f7f8fc,#eef2fb)}.brand-loading-card{width:min(560px,100%);padding:2rem;border-radius:22px;border:1px solid var(--panel-border);background:rgba(255,255,255,.96);box-shadow:var(--shadow);display:grid;grid-gap:1rem;gap:1rem;text-align:center;justify-items:center}.loading-brand-logo{width:112px;height:auto}.loading-dots{display:inline-flex;gap:.5rem;align-items:center}.loading-dots span{width:.75rem;height:.75rem;border-radius:999px;background:var(--accent);animation:loading-bounce .9s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.12s}.loading-dots span:nth-child(3){animation-delay:.24s}@keyframes loading-bounce{0%,80%,to{transform:translateY(0);opacity:.45}40%{transform:translateY(-6px);opacity:1}}.upload-actions-cluster{flex-wrap:wrap}.queue-hint{margin:0}.upload-card-actions{display:flex;flex-wrap:wrap;gap:.55rem}@media (max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.brand-logo{max-width:140px}}