:root{--primary: #15803D;--primary-d: color-mix(in srgb, var(--primary), #000 16%);--primary-dd: color-mix(in srgb, var(--primary), #000 30%);--primary-tint: color-mix(in srgb, var(--primary) 12%, #fff);--primary-tint-2: color-mix(in srgb, var(--primary) 22%, #fff);--on-primary: #FFFFFF;--accent: #C2613B;--accent-tint: #F8ECE4;--bg: #FAF7F2;--surface: #FFFFFF;--surface-2: #F5F1E9;--surface-3: #EFEADF;--text: #2C2823;--text-2: #6E665B;--text-3: #9A9183;--border: # EAE4D8;--border: #EAE4D8;--border-strong: #DCD4C4;--success: #15803D;--success-tint: #E8F5EC;--warning: #B5781A;--warning-tint: #FBF0DA;--danger: #BC3B2C;--danger-tint: #FAE9E6;--info: #2563A8;--info-tint: #E7F0F9;--radius: 14px;--radius-sm: 10px;--radius-lg: 20px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(70,52,30,.06), 0 1px 3px rgba(70,52,30,.05);--shadow: 0 2px 6px rgba(70,52,30,.05), 0 8px 24px rgba(70,52,30,.06);--shadow-lg: 0 12px 40px rgba(50,38,22,.16);--shadow-focus: 0 0 0 3px color-mix(in srgb, var(--primary) 26%, transparent);--font: -apple-system, BlinkMacSystemFont, "PingFang TC", "Microsoft JhengHei", "Noto Sans TC", "Helvetica Neue", "Segoe UI", sans-serif;--fs: 16px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);color:var(--text);background:#ece7dc;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}h1,h2,h3,h4,p,dl,dd,dt,ul,ol{margin:0}ul{list-style:none;padding:0}:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:6px}.shell{min-height:100vh;display:flex;flex-direction:column}.shell-toolbar{flex:0 0 auto;display:flex;align-items:center;gap:16px;padding:10px 20px;background:#ffffffdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-strong);position:sticky;top:0;z-index:50;flex-wrap:wrap}.shell-toolbar-left{display:flex;align-items:center;gap:11px;flex:1 1 200px;min-width:0}.shell-mark{width:36px;height:36px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.shell-title{display:flex;flex-direction:column;line-height:1.2;min-width:0}.shell-title-main{font-weight:700;font-size:15px;color:var(--text)}.shell-title-sub{font-size:12px;color:var(--text-3)}.shell-toolbar-center{display:flex;align-items:center;gap:8px;flex:0 1 auto}.shell-toolbar-right{display:flex;align-items:center;gap:10px;flex:1 1 200px;justify-content:flex-end}.preset-select-wrap{position:relative;display:flex;align-items:center}.preset-select-icon{position:absolute;left:11px;color:var(--text-3);pointer-events:none}.preset-select-chev{position:absolute;right:9px;color:var(--text-3);pointer-events:none}.preset-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--text);padding:9px 32px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-pill);min-width:200px;cursor:pointer}.preset-select:hover{border-color:var(--primary)}.device-switch{display:flex;gap:3px;padding:3px;background:var(--surface-3);border-radius:var(--radius-pill)}.device-btn{display:flex;align-items:center;gap:6px;padding:7px 13px;border:none;background:transparent;border-radius:var(--radius-pill);color:var(--text-2);font-size:13px;font-weight:600;transition:all .15s}.device-btn:hover{color:var(--text)}.device-active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.theme-wrap{position:relative}.theme-btn{display:flex;align-items:center;gap:6px;padding:8px 13px;border:1px solid var(--border-strong);background:var(--surface);border-radius:var(--radius-pill);color:var(--text-2);font-size:13px;font-weight:600}.theme-btn:hover{border-color:var(--primary);color:var(--primary)}.theme-btn-on{border-color:var(--primary);color:var(--primary);background:var(--primary-tint)}.theme-panel{position:absolute;top:calc(100% + 10px);right:0;z-index:80;width:264px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:16px;animation:pop .16s ease}.theme-panel-head{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:14px;margin-bottom:14px}.theme-group{margin-bottom:15px}.theme-group-label{font-size:12px;font-weight:600;color:var(--text-3);margin-bottom:8px}.theme-swatches{display:flex;gap:6px}.swatch{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;border:none;background:transparent;padding:2px}.swatch-dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:inset 0 0 0 2px #ffffff73;transition:transform .12s}.swatch:hover .swatch-dot{transform:scale(1.08)}.swatch-on .swatch-dot{box-shadow:0 0 0 2px var(--surface),0 0 0 4px currentColor}.swatch-label{font-size:11px;color:var(--text-2);font-weight:600}.swatch-on .swatch-label{color:var(--text)}.theme-seg{display:flex;gap:4px;padding:3px;background:var(--surface-3);border-radius:10px}.theme-seg-item{flex:1;padding:8px;border:none;background:transparent;border-radius:7px;font-size:13px;font-weight:600;color:var(--text-2)}.theme-seg-item:hover{color:var(--text)}.theme-seg-on{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.theme-reset{width:100%;margin-top:4px;padding:9px;border:1px solid var(--border-strong);background:transparent;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-2)}.theme-reset:hover{border-color:var(--text-3);color:var(--text)}.shell-stage{flex:1 1 auto;min-height:0;display:flex;align-items:flex-start;justify-content:center;padding:36px 24px 60px;overflow:auto;background:radial-gradient(1200px 600px at 50% -10%,#F2EDE2 0%,transparent 60%),#e7e1d4}.frame-scaler{transform-origin:top center;flex:0 0 auto}.frame{position:relative;flex:0 0 auto;background:var(--surface)}.frame-screen{overflow:hidden;background:var(--bg);position:relative;display:flex;flex-direction:column}.frame-desktop{border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border-strong)}.browser-chrome{height:44px;display:flex;align-items:center;gap:14px;padding:0 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}.browser-dots{display:flex;gap:7px}.browser-dots span{width:12px;height:12px;border-radius:50%;background:#d8cfbe}.browser-dots span:nth-child(1){background:#e3897b}.browser-dots span:nth-child(2){background:#e5be73}.browser-dots span:nth-child(3){background:#8fc79a}.browser-url{flex:1;max-width:520px;height:28px;display:flex;align-items:center;gap:7px;padding:0 14px;background:var(--surface);border-radius:var(--radius-pill);font-size:12.5px;color:var(--text-2)}.frame-desktop .frame-screen{height:760px}.frame-tablet{border-radius:30px;padding:16px;background:#2c2823;box-shadow:var(--shadow-lg)}.frame-tablet .frame-screen{height:1040px;border-radius:16px}.frame-phone{border-radius:46px;padding:13px;background:#2c2823;box-shadow:var(--shadow-lg)}.frame-phone .frame-screen{height:818px;border-radius:34px}.phone-notch{position:absolute;top:13px;left:50%;transform:translate(-50%);width:130px;height:30px;background:#2c2823;border-radius:0 0 18px 18px;z-index:30}.phone-statusbar{flex:0 0 auto;height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 26px 0 28px;background:var(--surface);position:relative;z-index:25}.sb-time{font-size:13px;font-weight:700;color:var(--text);letter-spacing:.3px}.sb-right{display:flex;align-items:center;gap:7px}.sb-bars{display:inline-flex;align-items:flex-end;gap:2px;height:11px}.sb-bars i{width:3px;background:var(--text);border-radius:1px}.sb-bars i:nth-child(1){height:4px}.sb-bars i:nth-child(2){height:6px}.sb-bars i:nth-child(3){height:8px}.sb-bars i:nth-child(4){height:11px}.sb-batt{width:22px;height:11px;border:1.5px solid var(--text);border-radius:3px;position:relative}.sb-batt:before{content:"";position:absolute;top:1.5px;bottom:1.5px;left:1.5px;right:6px;background:var(--text);border-radius:1px}.sb-batt:after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:var(--text);border-radius:0 1px 1px 0}.app-container{container-type:inline-size;container-name:app;flex:1 1 auto;min-height:0;position:relative}.clinic-app{height:100%;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font-size:var(--fs);line-height:1.5}.app-scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.app-page{min-height:100%}.only-wide{display:none}.only-narrow{display:block}.only-wide-inline{display:none}@container app (min-width: 640px){.only-wide{display:block}.only-narrow{display:none}.only-wide-inline{display:inline}}.topbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:relative;z-index:20}.topbar-brand{display:flex;align-items:center;gap:10px;border:none;background:transparent;padding:4px;border-radius:10px}.topbar-brand:hover{background:var(--surface-2)}.topbar-brand-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15}.topbar-clinic{font-weight:700;font-size:16px;color:var(--text)}.topbar-sub{font-size:11.5px;color:var(--text-3)}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-user{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-2);font-weight:500;padding:5px 10px;background:var(--surface-2);border-radius:var(--radius-pill)}@container app (max-width: 639px){.topbar-user span{display:none}}.clinic-mark{border-radius:13px;display:grid;place-items:center;flex:0 0 auto;background:linear-gradient(150deg,var(--primary) 0%,var(--primary-d) 100%);color:#fff;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 34%,transparent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;border-radius:var(--radius-sm);font-weight:600;font-family:inherit;line-height:1;transition:background .15s,border-color .15s,color .15s,transform .05s;white-space:nowrap;text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{font-size:13px;padding:8px 13px;min-height:36px}.btn-md{font-size:14.5px;padding:10px 17px;min-height:42px}.btn-lg{font-size:16px;padding:13px 22px;min-height:50px;border-radius:var(--radius)}.btn-block{width:100%}.btn-label{display:inline-block}.btn-primary{background:var(--primary);color:var(--on-primary);box-shadow:0 1px 2px #1450282e}.btn-primary:hover:not(:disabled){background:var(--primary-d)}.btn-primary:active{background:var(--primary-dd)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-2);border-color:var(--text-3)}.btn-ghost{background:transparent;color:var(--text-2)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-ghost-danger{background:transparent;color:var(--danger)}.btn-ghost-danger:hover:not(:disabled){background:var(--danger-tint)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#a4332589;background:#a43325}.icon-btn{display:inline-grid;place-items:center;border:none;background:transparent;border-radius:10px;color:var(--text-2);transition:background .15s,color .15s}.icon-btn-sm{width:36px;height:36px}.icon-btn-md{width:42px;height:42px}.icon-btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.icon-btn-soft{background:var(--surface);border:1px solid var(--border-strong)}.icon-btn-soft:hover{border-color:var(--primary);color:var(--primary)}.icon-btn-ghost-danger{color:var(--danger)}.icon-btn-ghost-danger:hover:not(:disabled){background:var(--danger-tint)}.icon-btn:disabled{opacity:.4;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13.5px;font-weight:600;color:var(--text)}.field-label-note{font-weight:500;color:var(--text-3);font-size:12.5px}.req{color:var(--danger)}.input-wrap{position:relative;display:flex;align-items:center}.input{width:100%;font-family:inherit;font-size:15.5px;color:var(--text);padding:12px 14px;min-height:46px;background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--text-3)}.input:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.input-readonly{background:var(--surface-2);color:var(--text-2)}.input-affix{position:absolute;display:flex;align-items:center;color:var(--text-3);pointer-events:none}.input-prefix{left:13px}.input-prefix~.input,.input-wrap .input-prefix+.input{padding-left:42px}.input-suffix{right:13px}.field-error .input{border-color:var(--danger)}.field-error .input:focus{box-shadow:0 0 0 3px var(--danger-tint)}.field-msg{display:flex;align-items:center;gap:5px;font-size:12.5px;line-height:1.4}.field-msg-error{color:var(--danger)}.field-msg-hint{color:var(--text-3)}.select-wrap{position:relative;display:flex;align-items:center}.select{width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;font-family:inherit;font-size:15.5px;color:var(--text);padding:12px 40px 12px 14px;min-height:46px;background:var(--surface);border:1.5px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer}.select:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-focus)}.select-chevron{position:absolute;right:13px;color:var(--text-3);pointer-events:none}.segmented{display:flex;gap:3px;padding:4px;background:var(--surface-3);border-radius:var(--radius);width:100%}.seg-item{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:none;background:transparent;color:var(--text-2);font-size:14px;font-weight:600;border-radius:10px;transition:all .15s;white-space:nowrap}.seg-item:hover{color:var(--text)}.seg-active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}.segbtns{display:flex;gap:8px}.segbtn{flex:1;padding:11px;min-height:46px;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--text-2);font-weight:600;font-size:15px;border-radius:var(--radius-sm);transition:all .15s}.segbtn:hover{border-color:var(--text-3)}.segbtn-active{border-color:var(--primary);background:var(--primary-tint);color:var(--primary-dd)}.chip{display:inline-flex;align-items:center;gap:5px;border-radius:var(--radius-pill);font-weight:600;white-space:nowrap}.chip-sm{font-size:12.5px;padding:4px 10px}.chip-md{font-size:13.5px;padding:6px 12px}.chip-neutral{background:var(--surface-3);color:var(--text-2)}.chip-primary{background:var(--primary-tint);color:var(--primary-dd)}.chip-accent{background:var(--accent-tint);color:var(--accent)}.chip-success{background:var(--success-tint);color:var(--success)}.chip-blue{background:#e7eef8;color:#2d5f9a}.chip-pink{background:#f8e9ee;color:#b14b72}.chip-x{display:inline-grid;place-items:center;border:none;background:transparent;color:inherit;opacity:.6;padding:0;margin-right:-3px}.chip-x:hover{opacity:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-interactive{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .1s;text-align:left}.card-interactive:hover{border-color:color-mix(in srgb,var(--primary) 40%,var(--border));box-shadow:var(--shadow)}.card-interactive:active{transform:translateY(1px)}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;border-bottom:1px solid var(--border)}.section-title{display:flex;align-items:center;gap:9px}.section-title h3{font-size:15.5px;font-weight:700;color:var(--text)}.section-title-icon{color:var(--primary)}.section-count{font-size:13px;color:var(--text-3);font-weight:600}.section-body{padding:18px}.banner{display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:var(--radius-sm);margin-bottom:14px;border:1px solid transparent}.banner-icon{flex:0 0 auto;margin-top:1px}.banner-content{flex:1;min-width:0}.banner-title{font-weight:700;font-size:14px;margin-bottom:2px}.banner-text{font-size:13px;line-height:1.5}.banner-info{background:var(--info-tint);color:var(--info);border-color:color-mix(in srgb,var(--info) 18%,transparent)}.banner-warning{background:var(--warning-tint);color:var(--warning);border-color:color-mix(in srgb,var(--warning) 22%,transparent)}.banner-danger{background:var(--danger-tint);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 18%,transparent)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 24px;gap:6px}.empty-icon{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:var(--surface-2);color:var(--text-3);margin-bottom:8px}.empty-title{font-size:16px;font-weight:700;color:var(--text)}.empty-desc{font-size:14px;color:var(--text-2);max-width:360px;line-height:1.55;text-wrap:pretty}.empty-action{margin-top:12px}.skel{background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 37%,var(--surface-2) 63%);background-size:400% 100%;animation:skel 1.4s ease infinite}@keyframes skel{0%{background-position:100% 0}to{background-position:-100% 0}}.spinner{display:inline-block;border-radius:50%;border:2.5px solid currentColor;border-top-color:transparent;animation:spin .7s linear infinite;vertical-align:middle}.btn-primary .spinner,.btn-danger .spinner{color:#fff}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-md{width:22px;height:22px}.spinner-lg{width:34px;height:34px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.toast-viewport{position:absolute;left:0;right:0;bottom:18px;z-index:200;display:flex;flex-direction:column;align-items:center;gap:8px;padding:0 16px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;pointer-events:auto;padding:12px 14px;border-radius:var(--radius-sm);max-width:440px;width:100%;background:#2c2823;color:#fff;box-shadow:var(--shadow-lg);animation:toastIn .26s cubic-bezier(.2,.9,.3,1.2)}@keyframes toastIn{0%{opacity:0;transform:translateY(14px) scale(.96)}}.toast-icon{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;flex:0 0 auto}.toast-success .toast-icon{background:var(--primary)}.toast-danger .toast-icon{background:var(--danger)}.toast-warning .toast-icon{background:var(--warning)}.toast-info .toast-icon{background:var(--info)}.toast-msg{flex:1;font-size:14px;font-weight:500}.toast-x{border:none;background:transparent;color:#fff9;display:grid;place-items:center;padding:2px}.toast-x:hover{color:#fff}.modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:300;background:#2c282373;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;padding:24px;animation:fade .18s ease}@keyframes fade{0%{opacity:0}}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:400px;width:100%;animation:pop .22s cubic-bezier(.2,.9,.3,1.15)}@keyframes pop{0%{opacity:0;transform:scale(.94)}}.confirm{padding:26px 24px 22px;text-align:center}.confirm-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;margin:0 auto 14px}.confirm-icon-danger{background:var(--danger-tint);color:var(--danger)}.confirm-icon-primary{background:var(--primary-tint);color:var(--primary)}.confirm-title{font-size:18px;font-weight:700;margin-bottom:7px;text-wrap:balance}.confirm-msg{font-size:14px;color:var(--text-2);line-height:1.55;margin-bottom:6px;text-wrap:pretty}.confirm-warn{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--danger);font-weight:600;margin-bottom:18px}.confirm-actions{display:flex;gap:10px;margin-top:14px}.login-screen{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 22px;gap:20px;background:radial-gradient(680px 380px at 50% -8%,var(--primary-tint) 0%,transparent 62%),var(--bg)}.login-card{width:100%;max-width:392px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:30px 28px}.login-brand{display:flex;flex-direction:column;align-items:center;gap:13px;margin-bottom:24px;text-align:center}.login-clinic{font-size:22px;font-weight:800;letter-spacing:.5px}.login-sub{font-size:13.5px;color:var(--text-2);margin-top:2px}.login-form{display:flex;flex-direction:column;gap:15px}.login-error{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--danger);background:var(--danger-tint);padding:11px 13px;border-radius:var(--radius-sm);font-weight:500}.login-foot{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);font-size:12px;color:var(--text-3)}.login-credit{font-size:12px;color:var(--text-3)}.lockout-screen{min-height:100%;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:var(--bg)}.lockout-card{max-width:420px;width:100%;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:38px 30px;display:flex;flex-direction:column;align-items:center;gap:8px}.lockout-icon{width:76px;height:76px;border-radius:24px;display:grid;place-items:center;background:var(--warning-tint);color:var(--warning);margin-bottom:8px}.lockout-title{font-size:21px;font-weight:800}.lockout-msg{font-size:14.5px;color:var(--text-2);line-height:1.6;text-wrap:pretty}.lockout-note{display:flex;align-items:flex-start;gap:8px;text-align:left;font-size:13px;color:var(--text-2);background:var(--surface-2);padding:12px 14px;border-radius:var(--radius-sm);margin:14px 0 20px;line-height:1.5}.lockout-note svg{flex:0 0 auto;margin-top:1px;color:var(--info)}.search-screen{display:flex;flex-direction:column;min-height:100%}.search-panel{position:sticky;top:0;z-index:15;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 2px 8px #46341e08}.search-panel-inner{padding:16px;max-width:1180px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:14px}.search-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.search-heading h2{font-size:19px;font-weight:800}.search-heading p{font-size:13.5px;color:var(--text-2);margin-top:2px}.add-owner-btn{flex:0 0 auto}.type-switch{width:100%}.input-row{display:flex;flex-direction:column;gap:10px}.input-row-field{flex:1}.search-go{flex:0 0 auto}.range-row{display:flex;flex-direction:column;gap:12px}.range-inputs{display:flex;align-items:flex-end;gap:10px}.range-inputs .field{flex:1}.range-dash{color:var(--text-3);font-weight:700;padding-bottom:12px}.results-area{flex:1;padding:16px;max-width:1180px;margin:0 auto;width:100%}.results-meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.results-count{font-size:15px;color:var(--text)}.results-count b{color:var(--primary);font-size:17px}.results-query{font-size:13px;color:var(--text-3)}.results-grid{display:grid;grid-template-columns:1fr;gap:10px}.result-card{display:flex;align-items:center;gap:12px;padding:14px 15px;width:100%}.result-main{display:flex;align-items:center;gap:13px;flex:1;min-width:0}.result-avatar{width:46px;height:46px;border-radius:14px;flex:0 0 auto;display:grid;place-items:center;background:var(--primary-tint);color:var(--primary)}.result-info{flex:1;min-width:0}.result-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:7px}.result-name{font-size:16.5px;font-weight:700;color:var(--text)}.result-oid{display:inline-flex;align-items:center;gap:3px;font-size:12px;color:var(--text-3);font-weight:600}.result-chips{display:flex;flex-wrap:wrap;gap:6px}.result-go{color:var(--text-3);flex:0 0 auto}.card-interactive:hover .result-go{color:var(--primary)}.skel-card{pointer-events:none}.idle-state{padding:48px 28px;text-align:center;display:flex;flex-direction:column;align-items:center}.idle-icon{width:72px;height:72px;border-radius:22px;display:grid;place-items:center;background:var(--primary-tint);color:var(--primary);margin-bottom:16px}.idle-title{font-size:17px;font-weight:700;margin-bottom:6px}.idle-desc{font-size:14px;color:var(--text-2);max-width:400px;line-height:1.6;margin-bottom:18px;text-wrap:pretty}.idle-tips{display:flex;flex-direction:column;gap:9px;align-items:flex-start}.idle-tip{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2)}.idle-tip svg{color:var(--primary);flex:0 0 auto}.state-block{padding-top:12px}.detail-screen{padding:16px;max-width:1180px;margin:0 auto;width:100%}.detail-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.detail-topbar-actions{display:flex;gap:8px}.detail-grid{display:grid;grid-template-columns:1fr;gap:16px;align-items:start}.detail-col{display:flex;flex-direction:column;gap:16px}.owner-hero{display:flex;align-items:center;gap:15px;padding:18px;background:linear-gradient(140deg,var(--primary-tint) 0%,var(--surface) 100%);border:1px solid var(--border);border-radius:var(--radius)}.owner-hero-avatar{width:60px;height:60px;border-radius:18px;flex:0 0 auto;display:grid;place-items:center;background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.owner-hero-name{font-size:22px;font-weight:800;margin-bottom:7px}.owner-hero-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.owner-hero-pets{font-size:13px;color:var(--text-2)}.info-list{display:flex;flex-direction:column;gap:2px}.info-row{display:flex;align-items:flex-start;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}.info-row:last-child{border-bottom:none}.info-label{display:flex;align-items:center;gap:7px;font-size:13.5px;color:var(--text-2);width:92px;flex:0 0 auto;font-weight:500}.info-label svg{color:var(--text-3)}.info-value{font-size:14.5px;color:var(--text);flex:1;font-weight:500;word-break:break-all}.info-empty{color:var(--text-3)}.phone-chips{display:flex;flex-wrap:wrap;gap:6px}.pets-grid{display:grid;grid-template-columns:1fr;gap:12px}.pet-card{padding:15px}.pet-card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.pet-avatar{width:44px;height:44px;border-radius:13px;flex:0 0 auto;display:grid;place-items:center}.pet-avatar-cat{background:#f4e9df;color:#b5733a}.pet-avatar-dog{background:#e5eef0;color:#2e7a86}.pet-avatar-other{background:var(--surface-3);color:var(--text-2)}.pet-name{font-size:16.5px;font-weight:700}.pet-sub{font-size:13px;color:var(--text-2);margin-top:1px}.pet-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.pet-note{display:flex;align-items:flex-start;gap:6px;font-size:12.5px;color:var(--accent);background:var(--accent-tint);padding:8px 10px;border-radius:9px;line-height:1.45;margin-bottom:10px}.pet-note svg{flex:0 0 auto;margin-top:1px}.pet-birth{font-size:12.5px;color:var(--text-3)}.visit-list{display:flex;flex-direction:column}.visit-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}.visit-row:last-child{border-bottom:none}.visit-date{flex:0 0 auto;width:116px}.visit-date-main{font-size:15px;font-weight:700;color:var(--text)}.visit-date-sub{font-size:12px;color:var(--text-3);margin-top:2px}.visit-mid{flex:1;min-width:0}.visit-pet{display:flex;align-items:center;gap:6px;font-size:14.5px;font-weight:600}.visit-pet svg{color:var(--accent)}.visit-rel{font-size:12px;color:var(--text-3);margin-top:2px}.visit-actions{display:flex;gap:2px;flex:0 0 auto}.load-more{width:100%;margin-top:12px;padding:11px;border:1px dashed var(--border-strong);background:transparent;border-radius:var(--radius-sm);color:var(--text-2);font-weight:600;font-size:13.5px;display:flex;align-items:center;justify-content:center;gap:6px}.load-more:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-tint)}.visit-end{text-align:center;font-size:12.5px;color:var(--text-3);padding:14px 0 4px}.form-screen{padding:16px;max-width:760px;margin:0 auto;width:100%;display:flex;flex-direction:column;min-height:100%}.form-header{display:flex;align-items:center;gap:12px;margin-bottom:18px}.form-header-text h2{font-size:20px;font-weight:800}.form-header-text p{font-size:13px;color:var(--text-2);margin-top:2px}.form-body{display:flex;flex-direction:column;gap:18px;flex:1}.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.form-section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;margin-bottom:16px}.form-section-title svg{color:var(--primary)}.pets-section-title{justify-content:space-between}.pets-section-title>span:first-child{display:flex;align-items:center;gap:8px}.form-fields{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.form-fields:last-child{margin-bottom:0}.phones-block{margin-bottom:14px}.phones-block>.field-label{margin-bottom:8px;display:block}.phones-list{display:flex;flex-direction:column;gap:9px}.phone-input-row{display:flex;align-items:center;gap:8px}.phone-input-row .field{flex:1}.phone-spacer{width:36px;flex:0 0 auto}.add-row-btn{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;border:none;background:transparent;color:var(--primary);font-weight:600;font-size:13.5px;padding:6px 2px}.add-row-btn:hover{text-decoration:underline}.pets-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:26px;color:var(--text-3);text-align:center}.pets-empty p{font-size:13.5px;color:var(--text-2);max-width:300px;line-height:1.5}.pet-forms{display:flex;flex-direction:column;gap:12px}.pet-subcard{border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden}.pet-subcard-error{border-color:var(--danger)}.pet-subcard-head{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface-2)}.pet-subcard-toggle{flex:1;display:flex;align-items:center;gap:10px;border:none;background:transparent;padding:4px;min-width:0}.pet-subcard-avatar{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:var(--surface);color:var(--primary);flex:0 0 auto}.pet-subcard-name{font-weight:700;font-size:15px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pet-subcard-errflag{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;color:var(--danger);font-weight:600;flex:0 0 auto}.pet-subcard-chev{margin-left:auto;color:var(--text-3);display:grid;place-items:center}.pet-subcard-body{padding:16px;display:flex;flex-direction:column;gap:14px}.visit-owner-banner{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--primary-tint);border-radius:var(--radius-sm);margin-bottom:18px}.visit-owner-avatar{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--primary);color:#fff;flex:0 0 auto}.visit-owner-label{font-size:12px;color:var(--primary-dd);font-weight:600}.visit-owner-name{font-size:16px;font-weight:700;color:var(--text)}.visit-owner-banner .chip{margin-left:auto}.visit-auto-note{display:flex;align-items:flex-start;gap:7px;font-size:12.5px;color:var(--text-2);margin-top:14px;line-height:1.5}.visit-auto-note svg{flex:0 0 auto;margin-top:1px;color:var(--info)}.form-actions{display:flex;gap:12px;padding:16px 0 4px;position:sticky;bottom:0;background:linear-gradient(to top,var(--bg) 72%,transparent);margin-top:8px}.form-cancel{flex:0 0 auto;min-width:96px}.form-save{flex:1}@container app (min-width: 640px){.search-head-row{align-items:center}.input-row{flex-direction:row;align-items:stretch}.input-row .search-go{align-self:stretch}.results-grid,.pets-grid,.form-fields.two-col{grid-template-columns:1fr 1fr}.detail-grid{grid-template-columns:300px 1fr}.search-panel-inner,.results-area,.detail-screen,.form-screen{padding-left:24px;padding-right:24px}.form-actions{justify-content:flex-end}.form-save{flex:0 0 auto;min-width:180px}}@container app (min-width: 1024px){.search-panel-inner{padding-top:22px;padding-bottom:18px}.input-row .input-row-field{max-width:620px}.results-grid{grid-template-columns:1fr 1fr 1fr}.detail-grid{grid-template-columns:340px 1fr}.detail-col-main{display:grid;grid-template-columns:1fr;gap:16px}.pets-grid{grid-template-columns:1fr 1fr 1fr}.topbar{padding:13px 28px}.owner-hero-name{font-size:24px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}.device-btn,.theme-btn,.preset-select,.shell-title-main,.shell-title-sub{white-space:nowrap}.shell-toolbar-left,.shell-toolbar-right{flex-shrink:0}.shell-toolbar-center{flex:1 1 auto;justify-content:center;min-width:0}@media (max-width: 1180px){.shell-title-sub,.theme-btn-label{display:none}.theme-btn{padding:9px}}@media (max-width: 1000px){.device-label{display:none}.device-btn{padding:8px 11px}.shell-toolbar{gap:10px;padding:9px 14px}}@media (max-width: 760px){.shell-toolbar{flex-wrap:wrap}.shell-toolbar-left{flex:1 1 100%;order:1}.shell-toolbar-center{order:3;flex:1 1 100%}.shell-toolbar-right{order:2}.preset-select{min-width:0;width:100%}.preset-select-wrap{flex:1}}html,body,#root{height:100%;margin:0}#root{display:flex;flex-direction:column;background:var(--bg)}#root>.app-container{flex:1 1 auto;min-height:0;width:100%}
