@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;1,9..40,400&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;0,6..72,700;1,6..72,400&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--teal:#0d9488;--teal-light:#14b8a6;--teal-dark:#0f766e;--teal-wash:#f0fdfa;--teal-glow:#0d94881f;--stone-50:#fafaf9;--stone-100:#f5f5f4;--stone-200:#e7e5e4;--stone-300:#d6d3d1;--stone-400:#a8a29e;--stone-500:#78716c;--stone-600:#57534e;--stone-700:#44403c;--stone-800:#292524;--stone-900:#1c1917;--bg:#f7f6f4;--card:#fff;--border:var(--stone-200);--text:var(--stone-900);--text-secondary:var(--stone-600);--text-muted:var(--stone-400);--success:#059669;--warning:#d97706;--danger:#dc2626;--font-display:"Newsreader", Georgia, serif;--font-body:"DM Sans", -apple-system, sans-serif;--radius:14px;--radius-sm:10px;--radius-lg:20px;--shadow:0 1px 2px #1c19170a, 0 1px 3px #1c19170f;--shadow-md:0 4px 12px #1c19170f, 0 1px 3px #1c19170a;--shadow-lg:0 8px 24px #1c191714, 0 2px 6px #1c19170a;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{background:var(--bg);flex-direction:column;min-height:100dvh;display:flex;position:relative}.app:before{content:"";z-index:-1;background:radial-gradient(ellipse 80% 50% at 50% -20%, var(--teal-glow), transparent), var(--bg);pointer-events:none;position:fixed;inset:0}.main{flex:1;width:100%;max-width:540px;margin:0 auto;padding:20px 16px 96px}.topbar{z-index:50;padding:calc(14px + env(safe-area-inset-top)) 16px 14px;background:var(--stone-800);color:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar h1{font-family:var(--font-display);letter-spacing:-.01em;font-size:17px;font-weight:600}.topbar-user{color:var(--stone-400);font-size:11px;font-weight:400}.topbar-btn{color:var(--stone-300);font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease-out);background:#ffffff14;border:1px solid #ffffff1a;border-radius:8px;padding:5px 12px;font-size:11px;font-weight:500}.topbar-btn:hover{background:#ffffff24}.bottom-nav{z-index:50;-webkit-backdrop-filter:blur(20px)saturate(1.5);padding:8px 0 calc(8px + env(safe-area-inset-bottom));background:#ffffffeb;border-top:1px solid #0000000f;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--stone-400);letter-spacing:.02em;transition:color .2s var(--ease-out), transform .15s var(--ease-out);border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:4px 16px;font-size:10px;font-weight:500;text-decoration:none;display:flex}.nav-item:active{transform:scale(.92)}.nav-item.active{color:var(--teal)}.nav-item svg{stroke-width:1.8px;width:21px;height:21px}.page-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--stone-800);margin-bottom:4px;font-size:24px;font-weight:600}.page-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:13px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .2s var(--ease-out);border:1px solid #00000008;margin-bottom:12px;padding:16px}.card-header{font-family:var(--font-body);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:11px;font-weight:600}.metrics{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px;display:grid}.metric{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;border:1px solid #00000008;padding:16px 14px;position:relative;overflow:hidden}.metric:after{content:"";background:var(--stone-200);border-radius:0 2px 2px 0;width:3px;height:100%;position:absolute;top:0;left:0}.metric-value{font-family:var(--font-display);letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1.1}.metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;font-size:10px;font-weight:600}.metric.highlight{background:linear-gradient(135deg, var(--teal), var(--teal-dark));border-color:#0000}.metric.highlight:after{background:#fff3}.metric.highlight .metric-value{color:#fff}.metric.highlight .metric-label{color:#ffffffb3}.cal-header{justify-content:space-between;align-items:center;margin-bottom:14px;padding:0 2px;display:flex}.cal-header h2{font-family:var(--font-display);letter-spacing:-.01em;font-size:17px;font-weight:600}.cal-nav{cursor:pointer;color:var(--text-secondary);transition:all .15s var(--ease-out);background:0 0;border:none;border-radius:8px;padding:6px}.cal-nav:hover{background:var(--stone-100)}.cal-nav:active{transform:scale(.9)}.cal-grid{text-align:center;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:16px;display:grid}.cal-dow{color:var(--stone-400);text-transform:uppercase;letter-spacing:.06em;padding:6px 0;font-size:10px;font-weight:600}.cal-day{aspect-ratio:1;cursor:pointer;transition:all .15s var(--ease-out);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;font-size:14px;font-weight:400;display:flex;position:relative}.cal-day:hover{background:var(--stone-100)}.cal-day:active{transform:scale(.9)}.cal-day.today{color:var(--teal);font-weight:700}.cal-day.selected{background:var(--teal);color:#fff;font-weight:600;box-shadow:0 2px 8px #0d94884d}.cal-day.selected:hover{background:var(--teal-dark)}.cal-day.other-month{color:var(--stone-300)}.cal-dot{background:var(--teal);border-radius:50%;width:4px;height:4px;transition:background .15s;position:absolute;bottom:5px}.cal-day.selected .cal-dot{background:#ffffffb3}.appt-list{flex-direction:column;gap:8px;display:flex}.appt-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;color:inherit;transition:all .15s var(--ease-out);border:1px solid #00000008;gap:14px;padding:14px;text-decoration:none;display:flex}.appt-item:hover{box-shadow:var(--shadow-md)}.appt-item:active{box-shadow:var(--shadow-md);transform:scale(.98)}.appt-time{font-family:var(--font-display);color:var(--teal);min-width:48px;padding-top:1px;font-size:15px;font-weight:600}.appt-info{flex:1;min-width:0}.appt-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.appt-chinese{color:var(--text-secondary);margin-top:1px;font-size:12px}.appt-doctor{color:var(--text-muted);margin-top:3px;font-size:11px}.appt-remarks{color:var(--stone-500);white-space:nowrap;text-overflow:ellipsis;margin-top:5px;font-size:11px;font-style:italic;overflow:hidden}.appt-badge{letter-spacing:.02em;border-radius:99px;padding:2px 9px;font-size:10px;font-weight:600;display:inline-block}.badge-scheduled{background:var(--teal-wash);color:var(--teal-dark)}.badge-done{color:#065f46;background:#ecfdf5}.search-input{border:1.5px solid var(--stone-200);border-radius:var(--radius);width:100%;font-family:var(--font-body);background:var(--card);color:var(--text);transition:all .2s var(--ease-out);outline:none;padding:11px 16px;font-size:14px}.search-input::placeholder{color:var(--stone-400)}.search-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}.patient-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;color:inherit;transition:all .15s var(--ease-out);border:1px solid #00000008;align-items:center;gap:14px;margin-bottom:8px;padding:14px;text-decoration:none;display:flex}.patient-item:hover{box-shadow:var(--shadow-md)}.patient-item:active{transform:scale(.98)}.avatar{background:linear-gradient(135deg, var(--teal), var(--teal-dark));color:#fff;width:42px;height:42px;font-size:14px;font-weight:700;font-family:var(--font-body);letter-spacing:.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.avatar.lg{width:68px;height:68px;font-size:24px}.patient-info{flex:1;min-width:0}.patient-name{font-size:14px;font-weight:600}.patient-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.tabs{background:var(--stone-100);border-radius:var(--radius-sm);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:3px;margin-bottom:18px;padding:3px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{text-align:center;cursor:pointer;min-width:0;color:var(--text-muted);white-space:nowrap;transition:all .2s var(--ease-out);font-size:11px;font-weight:600;font-family:var(--font-body);letter-spacing:.01em;background:0 0;border:none;border-radius:8px;flex:1;padding:9px 4px}.tab.active{background:var(--card);color:var(--text);box-shadow:0 1px 3px #0000000f}.rev-row{border-bottom:1px solid var(--stone-100);align-items:center;gap:10px;padding:10px 0;display:flex}.rev-date{color:var(--text-muted);min-width:52px;font-size:12px;font-weight:500}.rev-amount{font-family:var(--font-display);text-align:right;min-width:72px;font-size:14px;font-weight:600}.rev-bar-wrap{flex:1}.rev-bar{background:linear-gradient(90deg, var(--teal), var(--teal-light));min-width:4px;height:16px;transition:width .4s var(--ease-out);border-radius:4px}.img-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.img-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:all .15s var(--ease-out);border:1px solid #00000008;overflow:hidden}.img-card:active{transform:scale(.97)}.img-card-body{padding:10px}.img-card-title{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.img-card-sub{color:var(--text-muted);margin-top:2px;font-size:10px}.img-preview{aspect-ratio:4/3;object-fit:cover;background:var(--stone-100);width:100%;color:var(--stone-400);justify-content:center;align-items:center;font-size:12px;font-weight:500;display:flex}.login-page{background:var(--stone-900);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(60% 40% at 30% 20%,#0d948826,#0000),radial-gradient(50% 30% at 70% 80%,#0d948814,#0000);position:absolute;inset:0}.login-card{border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);z-index:1;animation:loginSlide .5s var(--ease-out);background:#fff;padding:36px 28px;position:relative}@keyframes loginSlide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-title{font-family:var(--font-display);letter-spacing:-.02em;text-align:center;color:var(--text);margin-bottom:2px;font-size:26px;font-weight:600}.login-subtitle{color:var(--text-muted);text-align:center;margin-bottom:28px;font-size:13px;font-weight:400}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.form-input{border:1.5px solid var(--stone-200);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text);transition:all .2s var(--ease-out);background:var(--stone-50);outline:none;padding:11px 14px;font-size:14px}.form-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow);background:#fff}.form-error{color:var(--danger);text-align:center;margin-bottom:14px;font-size:12px;font-weight:500}.btn-primary{width:100%;font-family:var(--font-body);background:linear-gradient(135deg, var(--teal), var(--teal-dark));color:#fff;border-radius:var(--radius-sm);letter-spacing:.01em;cursor:pointer;transition:all .2s var(--ease-out);border:none;padding:13px;font-size:14px;font-weight:600;box-shadow:0 2px 8px #0d94884d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0d948859}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.back-btn{color:var(--teal-dark);cursor:pointer;background:var(--teal-wash);font-size:13px;font-weight:600;font-family:var(--font-body);transition:all .15s var(--ease-out);letter-spacing:.01em;border:1px solid #0d948826;border-radius:20px;align-items:center;gap:4px;margin-bottom:16px;padding:7px 14px 7px 8px;text-decoration:none;display:inline-flex}.back-btn svg{flex-shrink:0}.back-btn:hover{background:#0d94881f}.back-btn:active{transform:scale(.95)}.quick-link{color:inherit;border-bottom:1px solid var(--stone-100);align-items:center;gap:10px;padding:12px 0;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.quick-link:last-child{border-bottom:none}.quick-link:active{color:var(--teal)}.quick-link-icon{background:var(--teal-wash);width:32px;height:32px;color:var(--teal);border-radius:8px;justify-content:center;align-items:center;display:flex}.quick-link-icon svg{width:16px;height:16px}.date-input{border:1.5px solid var(--stone-200);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text);background:var(--card);outline:none;flex:1;padding:9px 12px;font-size:13px;transition:border-color .2s}.date-input:focus{border-color:var(--teal)}.loading{text-align:center;color:var(--text-muted);padding:48px 20px;font-size:14px}.empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px;font-style:italic}.info-row{border-bottom:1px solid var(--stone-100);padding:10px 0;font-size:13px;display:flex}.info-row:last-child{border-bottom:none}.info-label{width:90px;color:var(--text-muted);flex-shrink:0;font-size:12px;font-weight:500}.info-value{color:var(--text);word-break:break-word;font-weight:500}.section-between{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text);font-size:14px;font-weight:600}.section-count{color:var(--text-muted);font-size:12px;font-weight:400}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.card,.metric,.patient-item,.appt-item{animation:fadeUp .35s var(--ease-out) both}.metrics .metric:nth-child(2){animation-delay:40ms}.metrics .metric:nth-child(3){animation-delay:80ms}.metrics .metric:nth-child(4){animation-delay:.12s}.settings-row{border-bottom:1px solid var(--stone-100);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-row svg{flex-shrink:0;margin-top:2px}.settings-info{flex:1}.settings-label{color:var(--text-muted);font-size:11px;font-weight:500}.settings-value{margin-top:2px;font-size:14px;font-weight:500}.signout-btn{border:1.5px solid var(--danger);width:100%;color:var(--danger);border-radius:var(--radius);font-family:var(--font-body);cursor:pointer;transition:all .15s var(--ease-out);background:0 0;justify-content:center;align-items:center;gap:8px;margin-top:24px;padding:14px;font-size:14px;font-weight:600;display:flex}.signout-btn:active{background:#dc26260d;transform:scale(.98)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}@media (width>=768px){.main{max-width:640px;padding:28px 20px 96px}.metrics{grid-template-columns:repeat(4,1fr)}.img-grid{grid-template-columns:repeat(3,1fr)}}
