@import "https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800&family=Noto+Sans:wght@400;500;700&display=swap";
:root{--primary:#0284c7;--primary-dark:#0369a1;--secondary:#0ea5e9;--sky-soft:#bae6fd;--cta:#059669;--cta-dark:#047857;--ink:#0f172a;--muted:#5b7185;--faint:#8fa6b8;--bg:#eff7fc;--card:#fff;--border:#dfeaf2;--danger:#dc2626;--danger-soft:#fee2e2;--warning:#b45309;--warning-soft:#fde68a;--navy-0:#03101d;--navy-1:#062138;--navy-2:#0a3354;--font-display:"Figtree", system-ui, sans-serif;--font-body:"Noto Sans", system-ui, sans-serif;--shadow-card:0 6px 24px #06213812;--shadow-raised:0 14px 44px #06213829}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.6}h1,h2,h3,h4,button{font-family:var(--font-display);letter-spacing:-.01em}a{color:inherit}button{cursor:pointer}:focus-visible{outline:3px solid var(--secondary);outline-offset:2px;border-radius:6px}.topbar{background:linear-gradient(120deg, var(--navy-0), var(--navy-1) 60%, var(--navy-2));color:#fff;padding:14px 0}.topbar-inner{align-items:center;gap:18px;max-width:1120px;margin:0 auto;padding:0 22px;display:flex}.brand{font-family:var(--font-display);align-items:center;gap:10px;font-size:1.15rem;font-weight:800;text-decoration:none;display:flex}.brand-mark{background:linear-gradient(140deg, var(--primary), var(--secondary));border-radius:10px;place-items:center;width:34px;height:34px;display:grid}.brand-mark svg{width:20px;height:20px}.topbar .spacer{flex:1}.topbar a.link{color:#b6d9ee;font-size:.92rem;font-weight:600;text-decoration:none}.topbar a.link:hover{color:#fff}.shell{max-width:1120px;margin:0 auto;padding:34px 22px 80px}.shell.narrow{max-width:660px}.page-title{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800}.page-sub{color:var(--muted);margin-top:4px;margin-bottom:26px}.card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:18px;margin-bottom:16px;padding:22px}.btn{min-height:48px;font-family:var(--font-display);border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 26px;font-size:.98rem;font-weight:700;text-decoration:none;transition:transform .15s,box-shadow .15s,opacity .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;box-shadow:0 8px 22px #0284c74d}.btn-cta{background:linear-gradient(135deg, var(--cta), #0ba77a);color:#fff;box-shadow:0 8px 22px #0596694d}.btn-ghost{background:var(--card);color:var(--prim-dark,var(--primary-dark));border:1.5px solid var(--border)}.btn-danger-ghost{background:var(--card);color:var(--danger);border:1.5px solid #fecaca}.btn:hover:not(:disabled){transform:translateY(-2px)}.btn.small{min-height:40px;padding:0 18px;font-size:.88rem}.input,textarea.input,select.input{background:var(--card);border:1.5px solid var(--border);width:100%;font-size:.98rem;font-family:var(--font-body);color:var(--ink);border-radius:12px;margin-bottom:12px;padding:12px 15px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #0284c71f}.label{font-family:var(--font-display);color:var(--muted);margin-bottom:6px;font-size:.84rem;font-weight:700;display:block}.badge{font-size:.74rem;font-weight:800;font-family:var(--font-display);border-radius:999px;padding:4px 12px;display:inline-block}.badge.booked{color:var(--primary-dark);background:#e0f2fe}.badge.completed{color:var(--cta);background:#dcfce7}.badge.cancelled,.badge.emergency{background:var(--danger-soft);color:var(--danger)}.error-text{color:var(--danger);margin:4px 0 10px;font-size:.88rem;font-weight:600}.hint{color:var(--muted);font-size:.85rem;line-height:1.5}.steps{align-items:center;gap:8px;margin-bottom:26px;display:flex}.step-dot{background:var(--border);width:30px;height:30px;color:var(--muted);font-family:var(--font-display);border-radius:50%;flex:none;place-items:center;font-size:.82rem;font-weight:800;display:grid}.step-dot.active{background:var(--primary);color:#fff}.step-dot.done{background:var(--cta);color:#fff}.step-line{background:var(--border);border-radius:2px;flex:1;height:3px}.step-line.done{background:var(--cta)}.odo-wrap{justify-content:center;display:flex}.odo-wrap svg{width:min(380px,100%);height:auto}.odo-tooth{cursor:pointer}.odo-caption{text-align:center;font-family:var(--font-display);color:var(--primary-dark);margin-top:8px;font-weight:700}.choice-row{flex-wrap:wrap;gap:10px;display:flex}.chip{border:1.5px solid var(--border);background:var(--card);color:var(--muted);font-weight:700;font-family:var(--font-display);border-radius:999px;min-height:44px;padding:10px 18px;font-size:.9rem}.chip.on{background:var(--primary);border-color:var(--primary);color:#fff}.chip.slot.on{background:var(--cta);border-color:var(--cta)}.day-chip{border:1.5px solid var(--border);background:var(--card);text-align:center;width:66px;font-family:var(--font-display);border-radius:13px;padding:9px 0}.day-chip small{color:var(--muted);font-size:.72rem;font-weight:600;display:block}.day-chip b{font-size:1.2rem}.day-chip.on{background:var(--primary);border-color:var(--primary);color:#fff}.day-chip.on small{color:#d6ecfb}.day-strip{gap:9px;padding-bottom:8px;display:flex;overflow-x:auto}.dentist-pick{text-align:left;background:var(--card);border:1.5px solid var(--border);border-radius:16px;align-items:center;gap:16px;width:100%;margin-bottom:11px;padding:15px 18px;transition:border-color .15s,background .15s;display:flex}.dentist-pick.on{border-color:var(--primary);background:#f2faff}.avatar{background:var(--primary);color:#fff;width:50px;height:50px;font-family:var(--font-display);border-radius:50%;flex:none;place-items:center;font-weight:800;display:grid}.dentist-pick b{font-family:var(--font-display);font-size:1.02rem;display:block}.dentist-pick .spec{color:var(--muted);font-size:.86rem}.star{color:#f59e0b;font-size:.88rem;font-weight:800}.emg-row{border:1.5px solid var(--border);background:var(--card);border-radius:16px;align-items:center;gap:14px;margin-top:16px;padding:15px 18px;display:flex}.emg-row.on{background:#fef2f2;border-color:#fecaca}.emg-row b{font-family:var(--font-display)}.clinic-shell{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, var(--navy-0), var(--navy-1) 60%, var(--navy-2));color:#fff;flex-direction:column;gap:6px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.sidebar .s-brand{font-family:var(--font-display);align-items:center;gap:10px;padding:6px 10px 16px;font-size:1.1rem;font-weight:800;display:flex}.sidebar .s-brand .brand-mark{width:34px;height:34px}.sidebar .s-clinic{color:#8fb8d4;padding:0 12px 14px;font-size:.78rem}.side-nav{flex-direction:column;flex:1;gap:4px;display:flex}.side-nav button{text-align:left;color:#b6d9ee;width:100%;font-family:var(--font-display);background:0 0;border:none;border-radius:12px;align-items:center;gap:11px;padding:11px 14px;font-size:.95rem;font-weight:600;transition:background .15s,color .15s;display:flex}.side-nav button svg{width:19px;height:19px}.side-nav button:hover{color:#fff;background:#ffffff0f}.side-nav button.on{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff}.side-foot{border-top:1px solid #bae6fd1f;padding-top:12px}.clinic-main{max-width:1080px;padding:30px 34px 60px}.clinic-main h2.section-h{margin-bottom:4px;font-size:1.5rem;font-weight:800}.clinic-main p.section-sub{color:var(--muted);margin-bottom:22px}.scan-wrap{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.scan-box{aspect-ratio:4/3;background:#04101e;border-radius:18px;place-items:center;display:grid;position:relative;overflow:hidden}.scan-box video{object-fit:cover;width:100%;height:100%}.scan-box .scan-hint{color:#8fb8d4;text-align:center;padding:20px;font-size:.85rem;position:absolute}.scan-frame{pointer-events:none;border:3px solid #5eead4b3;border-radius:16px;position:absolute;inset:18%}.checkin-result{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;padding:20px}.checkin-result .big-name{font-family:var(--font-display);font-size:1.3rem;font-weight:800}@media (max-width:860px){.clinic-shell{grid-template-columns:1fr}.sidebar{flex-flow:wrap;align-items:center;height:auto;padding:12px;position:static}.sidebar .s-brand{padding:6px 8px}.sidebar .s-clinic{display:none}.side-nav{flex-flow:wrap;flex:1}.side-nav button{width:auto;padding:9px 13px}.side-foot{border-top:none;padding-top:0}.clinic-main{padding:20px}.scan-wrap{grid-template-columns:1fr}}.dash-hero{background:radial-gradient(700px 320px at 85% 0%, #0ea5e938, transparent 60%), linear-gradient(125deg, var(--navy-0), var(--navy-1) 55%, var(--navy-2));color:#fff;border-radius:0 0 30px 30px;padding:34px 0 36px}.dash-hero-inner{max-width:1120px;margin:0 auto;padding:0 22px}.dash-hero h1{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:800}.dash-hero .sub{color:#a8cce3;margin-top:3px;font-size:.92rem}.live-dot{color:#34d399;font-family:var(--font-display);vertical-align:3px;background:#34d39924;border:1px solid #34d39959;border-radius:999px;align-items:center;gap:7px;margin-left:12px;padding:5px 13px;font-size:.76rem;font-weight:700;display:inline-flex}.live-dot i{background:#34d399;border-radius:50%;width:8px;height:8px;animation:2s ease-out infinite livePulse}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.35}}.glass-stats{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:22px;display:grid}.glass-stat{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #bae6fd29;border-radius:16px;padding:15px 18px}.glass-stat b{font-family:var(--font-display);font-size:1.5rem;font-weight:800;display:block}.glass-stat small{color:#8fb8d4;font-size:.78rem}.glass-stat b.ok{color:#34d399}.glass-stat b.alert{color:#f87171}.dash-body{max-width:1120px;margin:26px auto 0;padding:0 22px 80px}.dash-tabs{background:var(--card);border:1px solid var(--border);width:max-content;box-shadow:var(--shadow-card);border-radius:999px;gap:6px;margin-bottom:22px;padding:6px;display:flex}.dash-tab{color:var(--muted);font-family:var(--font-display);background:0 0;border:none;border-radius:999px;min-height:42px;padding:10px 22px;font-size:.92rem;font-weight:700;transition:background .18s,color .18s}.dash-tab.on{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff}.dash-tab:not(.on):hover{color:var(--primary-dark)}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar .search{flex:1;min-width:220px;margin-bottom:0}.two-col{grid-template-columns:1.6fr 1fr;align-items:start;gap:18px;display:grid}@media (max-width:920px){.two-col{grid-template-columns:1fr}}.patient-row{text-align:left;background:var(--card);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-card);border-radius:16px;align-items:center;gap:16px;margin-bottom:10px;padding:14px 18px;transition:border-color .15s;display:flex}.patient-row:hover{border-color:var(--primary)}.patient-row b{font-family:var(--font-display);display:block}.patient-row .pmeta{color:var(--muted);font-size:.84rem}.pill-count{font-family:var(--font-display);color:var(--primary-dark);background:#e0f2fe;border-radius:999px;padding:4px 12px;font-size:.76rem;font-weight:800}.plan-box{border:1px solid var(--border);background:var(--bg);border-radius:14px;margin-top:10px;padding:14px 16px}.plan-box .head{justify-content:space-between;gap:10px;display:flex}.plan-box .head b{font-family:var(--font-display);font-size:.95rem}.plan-price{color:var(--cta-dark);font-family:var(--font-display);font-weight:800}.progress-track{background:var(--border);border-radius:4px;height:8px;margin-top:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--cta));border-radius:4px;height:100%;transition:width .4s}.plan-foot{justify-content:space-between;align-items:center;margin-top:9px;display:flex}.plan-foot small{color:var(--muted);font-weight:600}.hx-row{border-bottom:1px solid var(--border);gap:10px;padding:9px 0;display:flex}.hx-row:last-child{border-bottom:none}.hx-row .dot{background:var(--primary);border-radius:50%;flex:none;width:10px;height:10px;margin-top:7px}.hx-row b{font-family:var(--font-display);font-size:.93rem}.hx-row .hmeta{color:var(--muted);font-size:.8rem}.toast{z-index:80;background:var(--navy-1);color:#fff;box-shadow:var(--shadow-raised);border-radius:14px;align-items:center;gap:12px;max-width:360px;padding:14px 18px;animation:.35s cubic-bezier(.2,.9,.3,1.2) toastIn;display:flex;position:fixed;bottom:22px;right:22px}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}}.toast b{font-family:var(--font-display);font-size:.92rem;display:block}.toast small{color:#a8cce3;font-size:.8rem}.toast .t-ic{background:linear-gradient(140deg, var(--cta), #10b981);border-radius:10px;flex:none;place-items:center;width:36px;height:36px;display:grid}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.stat{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;padding:16px 18px}.stat b{font-family:var(--font-display);font-size:1.55rem;font-weight:800;display:block}.stat small{color:var(--muted);font-size:.8rem}.stat b.ok{color:var(--cta)}.stat b.alert{color:var(--danger)}.appt{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:16px;grid-template-columns:86px 1fr auto;align-items:start;gap:18px;margin-bottom:12px;padding:18px 20px;display:grid}.appt.emergency{border-left:4px solid var(--danger)}.appt .when{font-family:var(--font-display);color:var(--primary-dark);font-weight:800}.appt .when small{color:var(--muted);font-size:.78rem;font-weight:600;display:block}.appt .who b{font-family:var(--font-display);font-size:1.05rem}.appt .meta{color:var(--muted);margin-top:2px;font-size:.88rem}.appt .issue{color:var(--ink);margin-top:6px;font-size:.92rem}.appt .photo-thumb{object-fit:cover;cursor:zoom-in;border-radius:10px;width:64px;height:64px;margin-top:8px}.appt-actions{flex-direction:column;align-items:stretch;gap:8px;min-width:150px;display:flex}.filter-row{flex-wrap:wrap;gap:10px;margin-bottom:18px;display:flex}.weekbar{align-items:flex-end;gap:10px;height:110px;padding-top:8px;display:flex}.weekbar .col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;height:100%;display:flex}.weekbar .bar{background:linear-gradient(180deg, var(--secondary), var(--primary));border-radius:7px 7px 3px 3px;width:70%;max-width:34px;min-height:4px}.weekbar .bar.zero{background:var(--border)}.weekbar small{color:var(--muted);font-size:.74rem;font-weight:600}.weekbar .val{font-family:var(--font-display);color:var(--primary-dark);font-size:.8rem;font-weight:800}.scrim{z-index:50;background:#0621388c;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--card);width:100%;max-width:520px;max-height:88vh;box-shadow:var(--shadow-raised);border-radius:20px;padding:26px;overflow-y:auto}.modal h3{margin-bottom:4px;font-size:1.25rem}.modal .sub{color:var(--muted);margin-bottom:16px;font-size:.9rem}.photo-zoom{border-radius:14px;max-width:92vw;max-height:88vh}.success-icon{background:linear-gradient(135deg, var(--cta), #0ba77a);color:#fff;border-radius:50%;place-items:center;width:86px;height:86px;margin:0 auto 18px;display:grid;box-shadow:0 14px 36px #05966959}@media (max-width:760px){.stats-row{grid-template-columns:repeat(2,1fr)}.appt{grid-template-columns:1fr}.appt-actions{flex-flow:wrap}}@media (max-width:560px){.shell{padding:22px 14px 64px}.card{padding:18px 16px}.topbar{padding:12px 0}.topbar-inner{flex-wrap:wrap;gap:10px 14px;padding:0 14px}.brand{font-size:1.04rem}.topbar a.link{font-size:.86rem}.page-sub{margin-bottom:18px}.steps{gap:6px;margin-bottom:20px}.dentist-pick{gap:12px;padding:13px 14px}.dentist-pick .avatar{width:44px;height:44px}.emg-row{padding:13px 14px}.btn{min-height:46px;padding:0 18px}.btn.small{padding:0 14px}}@media (max-width:380px){.choice-row .btn,.choice-row .chip{flex:auto}}
