:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--border:#94a3b83d;--surface:#ffffffd1;--muted:#64748b;--shadow:0 18px 50px #0f172a14;background:radial-gradient(circle at top,#749dff29,#0000 36%),linear-gradient(#f4f7fb 0%,#eef2f7 100%);font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100vh}body{margin:0}h1{letter-spacing:-.03em;margin:0;font-size:clamp(2rem,4vw,3rem);line-height:1.1}p{margin:0}button,input,textarea,select{font:inherit}.app-page{min-height:100dvh;padding:24px 16px 40px}.phone-shell{background:linear-gradient(#fffffff5 0%,#f6f9fcfa 100%);border:1px solid #e2e8f0f2;border-radius:34px;flex-direction:column;width:min(100%,420px);height:calc(100dvh - 64px);min-height:calc(100dvh - 64px);margin:0 auto;display:flex;overflow:hidden;box-shadow:0 34px 90px #0f172a24}.status-bar{color:#111827;justify-content:space-between;align-items:center;padding:14px 20px 0;font-size:.72rem;font-weight:700;display:flex}.status-bar__icons{gap:4px;display:flex}.status-bar__icons span{background:linear-gradient(135deg,#cbd5e1,#94a3b8);border-radius:999px;width:16px;height:8px}.top-nav{z-index:6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid #e2e8f0d9;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;min-height:72px;padding:12px 18px;display:flex}.top-nav__side{align-items:center;width:96px;min-width:96px;display:flex}.top-nav__side--right{justify-content:flex-end}.top-nav__center{text-align:center;flex:1;min-width:0}.top-nav__subtitle,.profile-card__eyebrow{letter-spacing:.14em;text-transform:uppercase;color:#2563eb;margin:0 0 4px;font-size:.68rem;font-weight:800}.top-nav__title,.form-section__title h2,.hero-card h2,.resident-card h2,.profile-card h2,.empty-card h2{margin:0}.top-nav__title{color:#0f172a;font-size:1.05rem;font-weight:900;line-height:1.2}.top-nav__actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.top-nav__back,.top-nav__placeholder{flex-shrink:0;width:40px;height:40px}.top-nav__back{color:#0f172a;font:inherit;background:#f1f5f9f5;border:0;border-radius:999px;font-size:1.8rem;line-height:1}.content-area{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;min-height:0;scroll-padding-top:18px;scroll-padding-bottom:calc(140px + env(safe-area-inset-bottom));background:radial-gradient(circle at 100% 0,#60a5fa1f,#0000 30%),linear-gradient(#f8fafc 0%,#eef4f8 100%);flex:1;padding:14px 14px 20px;overflow-y:auto}.notice-banner{border-radius:18px;margin-bottom:12px;padding:12px 14px;font-size:.82rem;line-height:1.45}.notice-banner.is-success{color:#166534;background:#f0fdf4eb;border:1px solid #4ade8059}.notice-banner.is-error{color:#b91c1c;background:#fef2f2f5;border:1px solid #f8717159}.entry-view,.detail-view,.profile-view,.resident-list-view{flex-direction:column;gap:14px;min-height:100%;display:flex}.hero-card,.form-section,.summary-card,.resident-card,.empty-card,.profile-card{background:#fffffff0;border:1px solid #e2e8f0eb;border-radius:24px;box-shadow:0 16px 40px #0f172a0f}.hero-card{gap:14px;padding:16px;display:flex}.hero-card.is-hidden{display:none}.hero-card__photo{color:#64748b;background:linear-gradient(#eff6ff,#f8fafc);border:2px dashed #94a3b866;border-radius:22px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:6px;width:94px;height:122px;display:flex;overflow:hidden}.hero-card__photo img{object-fit:cover;width:100%;height:100%}.hero-card__camera{color:#2563eb;font-size:1.6rem}.hero-card__content{flex:1}.hero-card__content h2{color:#0f172a;margin-bottom:8px;font-size:1rem;font-weight:800}.hero-card__content p{color:#64748b;margin-bottom:12px;font-size:.78rem;line-height:1.5}.hero-card__content input,.field input,.field select,.field textarea,.field-set input,.field-set select,.searchbox input{box-sizing:border-box;color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1f2;border-radius:16px;width:100%;height:44px;min-height:44px}.hero-card__content input,.field input,.field select,.field textarea,.field-set input,.field-set select{appearance:none;padding:0 14px;line-height:1.4}.field textarea{resize:vertical;height:auto;padding-top:12px;padding-bottom:12px}.form-section{overflow:hidden}.form-section__title{border-bottom:1px solid #e2e8f0bf;padding:12px 16px}.form-section__title h2{font-size:.96rem;font-weight:800}.form-section__title.is-blue{color:#1d4ed8;background:linear-gradient(90deg,#dbeafecc,#ffffffe6)}.form-section__title.is-indigo{color:#4338ca;background:linear-gradient(90deg,#e0e7ffcc,#ffffffe6)}.form-section__title.is-emerald{color:#047857;background:linear-gradient(90deg,#d1fae5cc,#ffffffe6)}.form-section__title.is-slate{color:#334155;background:linear-gradient(90deg,#e2e8f0f2,#ffffffeb)}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:16px;display:grid}.field{flex-direction:column;gap:6px;display:flex}.field span,.field-set strong{color:#64748b;font-size:.76rem;font-weight:700}.field--full,.toggle-row{grid-column:1/-1}.toggle-row{background:#f8fafc;border:1px solid #e2e8f0d9;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;display:flex}.toggle-row strong{color:#1f2937;margin-bottom:4px;font-size:.88rem;display:block}.toggle-row p{color:#64748b;font-size:.72rem}.switch{flex-shrink:0;width:52px;height:30px;position:relative}.switch input{opacity:0;position:absolute;inset:0}.switch span{background:#cbd5e1;border-radius:999px;transition:background .2s;position:absolute;inset:0}.switch span:after{content:"";background:#fff;border-radius:50%;width:24px;height:24px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 3px 10px #0f172a2e}.switch input:checked+span{background:#2563eb}.switch input:checked+span:after{transform:translate(22px)}.field-set{background:#f8fafc;border:1px solid #e2e8f0d9;border-radius:18px;flex-direction:column;gap:8px;padding:14px;display:flex}.submit-panel{text-align:center;padding:4px 4px 14px}.submit-panel p{color:#94a3b8;margin-top:10px;font-size:.7rem}.primary-submit,.secondary-submit,.ghost-button,.quick-tag{font:inherit;cursor:pointer;border:0}.primary-submit,.secondary-submit{border-radius:18px;width:100%;min-height:48px;font-weight:800}.primary-submit{color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e);box-shadow:0 20px 35px #2563eb40}.primary-submit:disabled{opacity:.7}.secondary-submit{color:#334155;background:#e2e8f0;margin-top:10px}.ghost-button{color:#2563eb;background:#f1f5f9f5;border-radius:14px;min-height:38px;padding:0 14px;font-size:.8rem;font-weight:700}.summary-panel{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.summary-card{padding:14px}.summary-card span{color:#64748b;margin-bottom:8px;font-size:.72rem;display:block}.summary-card strong{color:#0f172a;font-size:1.15rem}.searchbox{display:block;position:relative}.searchbox span{color:#94a3b8;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.searchbox input{padding:0 14px 0 36px}.quick-tags{scrollbar-width:none;gap:8px;display:flex;overflow-x:auto}.quick-tag{color:#475569;white-space:nowrap;background:#f1f5f9f5;border-radius:999px;min-width:64px;min-height:34px;padding:0 14px;font-size:.75rem;font-weight:700}.quick-tag.is-active{color:#fff;background:#2563eb}.list-meta{color:#64748b;justify-content:space-between;align-items:center;gap:12px;font-size:.75rem;display:flex}.resident-list{flex-direction:column;flex:1;gap:12px;display:flex}.list-toolbar{gap:10px;display:flex}.list-toolbar__filter-button,.list-toolbar__reset-button{min-height:44px;font:inherit;border:0;border-radius:16px;font-weight:700}.list-toolbar__filter-button{color:#1d4ed8;background:#dbeafe;flex:1}.list-toolbar__reset-button{color:#475569;background:#f1f5f9;min-width:96px;padding:0 14px}.active-filters{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.active-filters__label{color:#475569;font-size:.78rem;font-weight:700}.active-filters__chips{flex-wrap:wrap;gap:8px;display:flex}.active-filters__chip{color:#1d4ed8;background:#e0ecff;border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:600;line-height:1.2}.advanced-filter{background:#fffffff5;border:1px solid #e2e8f0eb;border-radius:24px;overflow:hidden;box-shadow:0 16px 40px #0f172a0f}.advanced-filter__header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd1;border-bottom:1px solid #f1f5f9f5;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px;display:flex}.advanced-filter__header h2{color:#1e293b;margin:0;font-size:1rem;font-weight:800}.advanced-filter__header p{color:#64748b;margin-top:4px;font-size:.75rem;line-height:1.5}.advanced-filter__toggle{color:#2563eb;background:#eff6ff;border:0;border-radius:999px;min-height:36px;padding:0 14px;font-size:.78rem;font-weight:700}.advanced-filter__body{flex-direction:column;gap:14px;padding:14px;display:flex}.filter-page{flex-direction:column;min-height:100%;display:flex}.filter-page__main{padding-bottom:calc(136px + env(safe-area-inset-bottom));flex-direction:column;gap:14px;display:flex}.filter-page__footer{padding:14px 0 calc(14px + env(safe-area-inset-bottom));background:linear-gradient(#eef4f800,#fffffff5 28%);margin-top:auto;position:sticky;bottom:0}.filter-group{background:#fff;border:1px solid #f1f5f9;border-radius:18px;margin-bottom:0;padding:16px}.filter-label{color:#1e293b;margin-bottom:12px;font-size:.875rem;font-weight:700;display:block}.filter-input{color:#0f172a;appearance:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;width:100%;min-height:48px;padding:0 14px;font-size:1rem;transition:all .2s}.filter-input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.filter-input--center{text-align:center}.filter-input--compact{min-height:38px;font-size:.88rem}.range-container,.filter-grid-two,.date-range-grid,.filter-subsection{align-items:center;gap:10px;display:grid}.range-container,.date-range-grid{grid-template-columns:1fr auto 1fr}.filter-grid-two{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:10px}.filter-divider{color:#9ca3af;text-align:center;font-weight:700}.filter-radio-group{gap:12px;display:flex}.filter-radio{color:#475569;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;flex:1;min-height:46px;font-size:.9rem;font-weight:600;transition:all .2s}.filter-radio.is-active{color:#2563eb;background:#eff6ff;border-color:#3b82f6}.advanced-filter__more-button{color:#2563eb;background:#eff6ff;border:0;border-radius:16px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:46px;font-size:.9rem;font-weight:600;display:flex}.advanced-filter__arrow{transition:transform .2s}.advanced-filter__arrow.is-open{transform:rotate(180deg)}.advanced-filter__more-fields{flex-direction:column;gap:14px;display:flex}.filter-subsection{grid-template-columns:auto 1fr;margin-top:10px}.filter-subsection__label{color:#64748b;width:44px;font-size:.72rem}.advanced-filter__footer{padding:14px 16px calc(14px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-top:1px solid #e2e8f0;position:sticky;bottom:0}.advanced-filter__actions{gap:12px;margin-bottom:10px;display:flex}.advanced-filter__reset,.advanced-filter__submit{min-height:52px;font:inherit;border:0;border-radius:18px;font-size:1rem;font-weight:800}.advanced-filter__reset{color:#6b7280;background:#f3f4f6;flex:1}.advanced-filter__submit{color:#fff;background:#2563eb;flex:2;box-shadow:0 20px 25px -5px #3b82f638,0 8px 10px -6px #3b82f62e}.advanced-filter__sync-time{text-align:center;letter-spacing:.05em;color:#9ca3af;font-size:10px}.fade-in{animation:.3s ease-out forwards fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.resident-card{cursor:pointer;padding:16px}.resident-card--skeleton{background:linear-gradient(90deg,#f1f5f9e6,#fffffff2,#f1f5f9e6);min-height:120px}.resident-card__header{align-items:flex-start;gap:12px;display:flex}.resident-card__avatar{color:#1d4ed8;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-weight:900;display:flex}.resident-card__identity{flex:1;min-width:0}.resident-card__headline{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:4px;display:flex}.resident-card__identity h2{color:#1f2937;font-size:1rem;font-weight:900}.resident-card__identity p{color:#64748b;font-size:.76rem}.resident-card__chevron{color:#cbd5e1;padding-top:4px;font-size:1.3rem}.resident-card__meta,.resident-card__footer{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.resident-card__meta span,.resident-card__footer span,.badge{border-radius:999px;align-items:center;min-height:26px;padding:0 10px;font-size:.72rem;font-weight:700;display:inline-flex}.resident-card__meta span{color:#475569;background:#f8fafc}.resident-card__footer span{color:#1d4ed8;background:#eff6ff}.badge.is-green{color:#15803d;background:#dcfce7}.badge.is-amber{color:#b45309;background:#fef3c7}.empty-card,.profile-card{padding:18px}.empty-card p,.profile-card li,.profile-card dd{color:#64748b}.detail-view{gap:0;min-height:100%;position:relative}.global-toast{z-index:1000;visibility:hidden;color:#fff;text-align:center;opacity:0;pointer-events:none;background:#000c;border-radius:999px;min-width:160px;max-width:min(100% - 32px,360px);padding:10px 16px;font-size:.75rem;transition:opacity .2s,transform .2s,visibility .2s;position:fixed;top:20px;left:50%;transform:translate(-50%,-8px)}.global-toast.is-visible{visibility:visible;opacity:1;transform:translate(-50%)}.detail-main{flex-direction:column;gap:14px;display:flex}.detail-hero,.detail-section{background:#fffffff5;border:1px solid #e2e8f0eb;border-radius:24px;box-shadow:0 16px 40px #0f172a0f}.detail-hero{text-align:center;flex-direction:column;align-items:center;padding:24px 20px;display:flex}.detail-hero__photo-wrap{margin-bottom:16px;position:relative}.detail-hero__photo-wrap.is-hidden{display:none}.detail-hero__photo{object-fit:cover;background:linear-gradient(135deg,#dbeafe,#e2e8f0);border:4px solid #fff;border-radius:18px;width:96px;height:128px;display:block;box-shadow:0 12px 28px #0f172a24}.detail-hero__photo--empty{color:#1d4ed8;justify-content:center;align-items:center;font-size:2rem;font-weight:900;display:flex}.detail-hero__badge{color:#fff;background:#2563eb;border:2px solid #fff;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.9rem;display:flex;position:absolute;bottom:-6px;right:-4px;box-shadow:0 10px 20px #2563eb3d}.detail-hero h3{color:#111827;margin:0;font-size:1.25rem;font-weight:900}.detail-hero__copy-trigger{color:#6b7280;font:inherit;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;margin-top:6px;padding:0;font-size:.84rem;display:inline-flex}.detail-hero__tags{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:14px;display:flex}.detail-hero__note{text-align:left;background:linear-gradient(#f8fafc,#f1f5f9);border:1px solid #e2e8f0eb;border-radius:18px;width:100%;margin-top:14px;padding:12px 14px}.detail-hero__note-label{color:#64748b;margin-bottom:6px;font-size:.72rem;font-weight:800;display:block}.detail-hero__note p{color:#334155;white-space:pre-wrap;margin:0;font-size:.84rem;line-height:1.6}.detail-pill{color:#1d4ed8;background:#dbeafe;border-radius:999px;align-items:center;min-height:28px;padding:0 12px;font-size:.75rem;font-weight:700;display:inline-flex}.detail-pill.is-muted{color:#64748b;background:#f1f5f9}.detail-pill--current{color:#047857;background:#d1fae5;min-height:24px;padding:0 10px;font-size:.68rem}.detail-section{overflow:hidden}.detail-section__header{background:#f8fafc;border-bottom:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.detail-section__header span{letter-spacing:.12em;text-transform:uppercase;color:#6b7280;font-size:.72rem;font-weight:800}.detail-section__header small{color:#9ca3af;font-size:.65rem}.detail-section__body{flex-direction:column;display:flex}.detail-row{text-align:left;background:#fff;border:0;border-top:1px solid #f8fafcf5;justify-content:space-between;align-items:center;gap:14px;width:100%;padding:16px;display:flex}.detail-row:first-child{border-top:0}.detail-row:active{background:#f9fafb}.detail-row--multiline{flex-direction:column;align-items:flex-start}.detail-row__label{color:#6b7280;flex-shrink:0;font-size:.86rem}.detail-row__value{text-align:right;color:#111827;justify-content:flex-end;align-items:center;gap:8px;font-size:.86rem;font-weight:600;display:inline-flex}.detail-row--multiline .detail-row__value{text-align:left;justify-content:flex-start}.detail-row__value.is-emphasize{color:#2563eb;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace}.detail-row__copy{color:#cbd5e1;font-size:.68rem;font-weight:700}.detail-household-member{background:#fff;border-top:1px solid #f8fafcf5;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:10px;padding:16px;display:flex}.detail-household-member:first-child{border-top:0}.detail-household-member__name{color:#111827;font-size:.9rem;font-weight:700}.detail-household-member__relation{color:#6b7280;font-size:.82rem}.detail-footer{padding:14px 0 calc(8px + env(safe-area-inset-bottom));background:linear-gradient(#eef4f800,#eef4f8f2 28%);gap:12px;display:flex;position:sticky;bottom:0}.detail-footer__edit,.detail-footer__delete{min-height:48px;font:inherit;border:0;border-radius:16px;font-weight:800}.detail-footer__edit{color:#374151;background:#e5e7eb;flex:1}.detail-footer__delete{color:#b91c1c;background:#fee2e2;width:72px}.profile-card dl{flex-direction:column;gap:12px;margin:0;display:flex}.profile-card dl div{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile-card dt{color:#334155;font-size:.78rem;font-weight:700}.profile-card dd{text-align:right;margin:0}.profile-card ul{flex-direction:column;gap:8px;margin:0;padding-left:18px;display:flex}@media (width<=480px){.app-page{height:100dvh;min-height:100dvh;padding:0;overflow:hidden}.phone-shell{border:0;border-radius:0;width:100%;height:100%;min-height:100%}.form-grid,.filter-grid-two{grid-template-columns:1fr}.filter-radio-group{flex-direction:column}}
