:root{--bg:#eef3f8;--ink:#0b1628;--muted:#64748b;--line:#d5dde8;--card:#fff;--nav:#0f1a2d;--blue:#2563eb;--red:#bd1b1b;--green:#078660;--teal:#0f99b5;--purple:#6d52d9;--shadow:0 10px 28px rgba(15,26,45,.08);--radius:16px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:"Noto Sans TC","Microsoft JhengHei",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:15px}.topbar{height:54px;background:var(--nav);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 22px;box-shadow:0 2px 10px rgba(0,0,0,.18);position:sticky;top:0;z-index:10}.brand{font-weight:800;font-size:18px}.brand small{display:block;font-size:12px;font-weight:500;opacity:.85}.nav{display:flex;gap:10px;align-items:center}.nav a,.nav-button{color:#fff;background:transparent;border:0;text-decoration:none;font-weight:700;font-size:15px;padding:8px 10px;border-radius:10px;cursor:pointer}.nav a:hover,.nav-button:hover,.nav-button.active{background:#1d2b44}.nav-button small{font-size:10px}.danger-link{color:#ffd0d0}.hidden{display:none!important}.app{width:min(1360px,calc(100vw - 40px));margin:18px auto}.page-head{display:flex;align-items:end;justify-content:space-between;margin:0 0 10px}.page-head h1{margin:0;font-size:28px}.hint{color:var(--muted);font-size:13px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.card.compact{padding:12px}.grid{display:grid;gap:12px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.admin-page{height:calc(100vh - 76px);overflow:hidden}.two-col{display:grid;grid-template-columns:1.1fr .9fr;gap:12px}.profile-layout{display:grid;grid-template-columns:1.35fr .9fr;gap:12px}.right-stack{display:grid;grid-template-columns:1fr;gap:12px;align-content:start}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.stat{background:#fff;border:1px solid var(--line);border-left:6px solid var(--blue);border-radius:14px;padding:10px 12px;box-shadow:var(--shadow)}.stat small{color:var(--muted);display:block}.stat b{font-size:24px}.stat.teal{background:#e9fbff;border-left-color:var(--teal)}.stat.green{background:#ebfff7;border-left-color:var(--green)}.stat.purple{background:#f2efff;border-left-color:var(--purple)}.stat.red{background:#fff1f1;border-left-color:var(--red)}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--line);padding:8px 9px;text-align:left;vertical-align:top}th{background:#f7f9fc;font-weight:800}.kv th{width:130px}.table-tight th,.table-tight td{padding:6px 8px}.scroll-card{max-height:calc(100vh - 220px);overflow:auto}.profile-main{height:calc(100vh - 122px);overflow:hidden}.profile-main .card{box-shadow:none}.profile-table{min-height:0}.profile-note{background:#fff2f2;border-left:7px solid var(--red)}.allergy{font-size:24px;color:var(--red);font-weight:900}.big{font-size:22px;font-weight:900}.muted{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 13px;border-radius:10px;font-weight:800;cursor:pointer;text-decoration:none}.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn.danger{background:#fee2e2;border-color:#fecaca;color:var(--red)}.btn.full{width:100%}.btn.small{font-size:13px;padding:5px 9px}input,select,textarea{width:100%;border:1px solid #cfd8e6;border-radius:10px;padding:10px 12px;font:inherit;background:#fff}textarea{min-height:70px;resize:vertical}label{font-weight:800;display:block;margin:7px 0 5px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.login{width:min(460px,calc(100vw - 32px));margin:90px auto}.login h1{font-size:30px;margin:0 0 8px}.notice{border-radius:12px;padding:12px;border:1px solid #bfdbfe;background:#eff6ff;color:#123b72}.warn{border-left:7px solid var(--red);background:#fff2f2}.ok{border-left:7px solid var(--green);background:#eefdf6}.expense-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:12px;height:calc(100vh - 168px)}.expense-list,.expense-right{height:100%;overflow:hidden}.expense-table-wrap{max-height:calc(100vh - 270px);overflow:auto}.expense-right .card{box-shadow:none}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:6px 0}.settings-layout{display:grid;grid-template-columns:.78fr 1.22fr;gap:12px;height:calc(100vh - 128px)}.setting-stack{display:flex;flex-direction:column;gap:10px}.contact-item{background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px}.contact-grid{display:grid;grid-template-columns:1.2fr .9fr 1.1fr 1.1fr .55fr auto auto;gap:8px;align-items:end}.contact-grid .wide{grid-column:1 / span 5}.contact-scroll{max-height:calc(100vh - 170px);overflow:auto;padding-right:4px}.file-grid{display:grid;grid-template-columns:.6fr 1.4fr;gap:12px}.pill{display:inline-block;border-radius:999px;background:#e8eef8;padding:4px 9px;font-size:12px;font-weight:800}.danger-text{color:var(--red);font-weight:900}.care-page{height:calc(100vh - 74px);overflow:hidden}.care-grid{display:grid;grid-template-columns:.48fr 1fr;gap:12px}.task-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.task{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:#f8fafc;border-radius:12px;padding:10px;font-weight:800}.task input{width:22px;height:22px}.care-form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.care-card{max-height:calc(100vh - 135px);overflow:auto}.meal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.allow{background:#eefdf6;border-left:7px solid var(--green)}.deny{background:#fff8f8;border-left:7px solid var(--red)}.floating{position:fixed;right:18px;bottom:18px;z-index:30}.float-btn{border:0;background:#ef4444;color:#fff;border-radius:999px;width:58px;height:58px;font-size:26px;box-shadow:var(--shadow);cursor:pointer}.float-panel{width:330px;max-width:calc(100vw - 32px);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.22);padding:14px;margin-bottom:10px}.float-panel.hidden{display:none}.contact-call{display:flex;justify-content:space-between;gap:10px;border-top:1px solid var(--line);padding:8px 0}.nowrap{white-space:nowrap}.truncate{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast{position:fixed;right:18px;top:70px;background:#111827;color:#fff;border-radius:12px;padding:10px 14px;z-index:40;box-shadow:var(--shadow)}@media(max-width:900px){.topbar{height:auto;min-height:54px;padding:10px 14px;align-items:flex-start}.nav{gap:5px;flex-wrap:wrap}.app{width:calc(100vw - 22px);margin:12px auto}.admin-page,.care-page,.settings-layout,.expense-layout,.profile-main{height:auto;overflow:visible}.grid-2,.grid-3,.grid-4,.two-col,.profile-layout,.expense-layout,.settings-layout,.care-grid,.meal-grid,.file-grid,.summary-row{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}.scroll-card,.contact-scroll,.care-card,.expense-table-wrap{max-height:none;overflow:visible}.form-row,.form-row-3,.care-form-grid,.task-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr 1fr}.contact-grid .wide{grid-column:1 / span 2}.right-stack{display:block}.card{padding:14px}.page-head{display:block}.page-head h1{font-size:24px}.topbar .brand{margin-bottom:8px}.care-topbar{position:sticky}.kv th{width:98px}.allergy{font-size:20px}}

/* v0.2.1 Cloudflare layout parity with local one-page prototype */
html,body{min-height:100%;}
body{overflow-y:auto;}
.app.admin-page{height:calc(100vh - 68px);margin:10px auto 0;overflow:hidden;}
.compact-head{margin-bottom:8px}.compact-head h1{font-size:26px}.compact-head .hint{font-size:12px}
.card.compact h2{margin:0 0 8px;font-size:20px}.card h3{margin:4px 0 6px}

.profile-main{height:calc(100vh - 68px);overflow:hidden}.profile-layout-v2{display:grid;grid-template-columns:1.25fr .85fr;gap:10px;height:calc(100vh - 114px);align-items:start}.profile-left-stack,.profile-right-stack{display:grid;gap:10px;min-height:0}.profile-left-stack{grid-template-rows:auto auto}.profile-right-stack{grid-template-rows:auto auto}.profile-layout-v2 .card{box-shadow:var(--shadow);min-height:0}.profile-layout-v2 .profile-table th,.profile-layout-v2 .profile-table td{padding:5px 8px}.profile-layout-v2 .caregiver-card th,.profile-layout-v2 .caregiver-card td{padding:5px 8px}.profile-layout-v2 .contacts-card table th,.profile-layout-v2 .contacts-card table td{padding:6px 8px}.profile-layout-v2 .handoff-card{max-height:none}.profile-layout-v2 .handoff-card ul{margin:0 0 0 18px;padding:0;line-height:1.45}.profile-layout-v2 .handoff-card li{margin:3px 0}.profile-layout-v2 .allergy{font-size:23px}.profile-layout-v2 .big{font-size:21px}.profile-layout-v2 .kv th{width:115px}.profile-note{background:#fff2f2;border-left:7px solid var(--red)}

.daily-onepage{height:calc(100vh - 68px);overflow:hidden}.daily-layout-v2{display:grid;grid-template-columns:1.05fr .95fr;gap:10px;height:calc(100vh - 114px)}.daily-layout-v2 .card{min-height:0}.daily-form-card,.daily-recent-card{overflow:auto}.daily-form-v2 label{margin:4px 0 4px}.daily-task-section{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:6px 0}.family-task-grid{grid-template-columns:1fr}.family-task-grid .task{padding:8px 10px}.family-task-grid .task input{width:20px;height:20px;flex:0 0 auto}.daily-form-v2 textarea{min-height:58px}.daily-form-v2 .btn{margin-top:6px}.daily-recent-card table th,.daily-recent-card table td{padding:6px 8px}

.expense-layout{height:calc(100vh - 190px)}.summary-row{margin:4px 0 8px}.summary-row .stat{padding:8px 10px}.summary-row .stat b{font-size:22px}.expense-table-wrap{max-height:calc(100vh - 312px)}.expense-right>.card{padding:12px}.expense-right input,.expense-right select,.expense-right textarea{padding:8px 10px}.expense-right label{margin:4px 0 3px}.expense-right textarea{min-height:48px}.expense-right .hint{font-size:12px}.expense-right .btn{padding:8px 10px}.expense-table-wrap .truncate{max-width:170px}

.settings-layout{height:calc(100vh - 116px);grid-template-columns:.75fr 1.25fr;gap:10px}.setting-stack{gap:8px}.setting-stack .card{padding:12px}.setting-stack input{padding:8px 10px}.setting-stack label{margin:4px 0 3px}.contact-scroll{max-height:calc(100vh - 160px);overflow:auto}.contact-item{padding:8px;margin-bottom:8px}.contact-grid{grid-template-columns:1fr .85fr 1.05fr 1fr .45fr auto auto;gap:6px}.contact-grid input{padding:7px 8px}.contact-grid label{font-size:12px;margin:2px 0}.contact-grid .wide{grid-column:1 / span 5}.contact-grid .btn.small{padding:6px 8px}.contact-grid [data-del]{align-self:end}

.task-grid .task{cursor:pointer}.task-grid .task:hover{background:#eef6ff;border-color:#bfdbfe}input[type="checkbox"]{accent-color:#2563eb}.nav a.active{outline:1px solid #fff;background:#1d2b44}

@media(max-width:1100px){.app.admin-page,.profile-main,.daily-onepage,.settings-layout,.expense-layout,.profile-layout-v2,.daily-layout-v2{height:auto;overflow:visible}.profile-layout-v2,.daily-layout-v2,.daily-task-section,.settings-layout{grid-template-columns:1fr}.contact-scroll,.daily-form-card,.daily-recent-card,.expense-table-wrap{max-height:none;overflow:visible}.contact-grid{grid-template-columns:1fr 1fr}.contact-grid .wide{grid-column:1/-1}.summary-row{grid-template-columns:1fr 1fr}}


/* v0.2.3 Login router + settings compact polish */
.settings-page{height:calc(100vh - 66px);overflow:hidden;margin-top:8px}
.settings-layout-v2{grid-template-columns:.72fr 1.28fr;gap:10px;height:calc(100vh - 118px)}
.settings-layout-v2 .card{box-shadow:var(--shadow)}
.settings-layout-v2 h2{font-size:19px;margin:0 0 7px}
.settings-layout-v2 h3{font-size:16px;margin:8px 0 6px}
.settings-layout-v2 label{font-size:13px;margin:4px 0 3px}
.settings-layout-v2 input,.settings-layout-v2 select,.settings-layout-v2 textarea{padding:7px 9px;border-radius:9px}
.settings-layout-v2 .setting-stack{gap:8px;min-height:0}
.settings-layout-v2 .card.compact{padding:12px}
.settings-care-card,.settings-password-card{min-height:0}.settings-note-card{padding:10px 12px!important}.settings-note-card ul{margin:4px 0 0 18px;padding:0}.settings-note-card li{margin:2px 0}.setting-links{margin-top:7px;padding:9px}.setting-links input{margin:4px 0 5px;font-size:13px}.compact-btn{margin-top:7px!important;padding:8px 12px!important}.contacts-manager-card{min-height:0;overflow:hidden}.contacts-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.contacts-header h2{margin:0}.contact-scroll-v2{max-height:calc(100vh - 178px);overflow:auto;padding-right:5px}.contact-scroll-v2 hr.thin{border:0;border-top:1px solid var(--line);margin:8px 0}.contact-scroll-v2 .contact-item{padding:8px;margin-bottom:8px;border-radius:12px}.contact-scroll-v2 .contact-grid{grid-template-columns:1.05fr .85fr 1fr 1fr .5fr .45fr auto;gap:6px;align-items:end}.contact-scroll-v2 .contact-grid .wide{grid-column:1 / span 6}.contact-scroll-v2 .contact-grid label{margin:2px 0}.contact-scroll-v2 .contact-grid .btn.small{padding:6px 9px}.new-contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.new-contact-form .btn{margin-top:8px}.contact-scroll-v2::-webkit-scrollbar{width:8px}.contact-scroll-v2::-webkit-scrollbar-thumb{background:#9aa6b7;border-radius:999px}
@media(max-width:900px){.settings-page,.settings-layout-v2{height:auto;overflow:visible}.settings-layout-v2{grid-template-columns:1fr}.contact-scroll-v2{max-height:none;overflow:visible}.new-contact-grid{grid-template-columns:1fr}.contacts-header{display:block}.contact-scroll-v2 .contact-grid{grid-template-columns:1fr 1fr}.contact-scroll-v2 .contact-grid .wide{grid-column:1 / span 2}}


/* v0.2.4 care one-page polish */
html,body{min-height:100%;}
.app.care-page{margin:10px auto 0;height:calc(100vh - 64px);overflow:hidden;}
.care-page .page-head{margin-bottom:8px;align-items:center;}
.care-page .page-head h1{font-size:28px;line-height:1.15;}
.care-page .card{padding:16px;}
.care-page .card h2{margin:0 0 10px;font-size:23px;line-height:1.2;}
.care-grid{align-items:start;grid-template-columns:.42fr 1fr;}
.care-reminder{align-self:start;min-height:auto!important;max-height:calc(100vh - 150px);overflow:auto;padding:16px 18px!important;}
.care-reminder ul{margin:0 0 0 18px;padding:0;line-height:1.55;}
.care-card{max-height:calc(100vh - 132px);overflow:auto;}
.care-card .task{padding:9px 10px;min-height:44px;}
.care-card textarea{min-height:58px;}
.care-form-grid{gap:7px;}
.care-form-grid label{margin:5px 0 4px;}
.care-form-grid input,.care-form-grid select{padding:9px 10px;}
.care-today-page .btn.full{margin-top:8px!important;}
.care-meal-page{font-size:16px;}
.care-meal-page .page-head{margin-bottom:8px;}
.care-meal-page .meal-remember{padding:14px 16px;}
.care-meal-page .meal-remember p{margin:0;line-height:1.45;}
.care-meal-page .meal-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px!important;margin-top:10px!important;align-items:stretch;}
.care-meal-page .meal-grid .card{padding:16px 18px;min-height:0;}
.care-meal-page .meal-grid h2{font-size:23px;margin-bottom:10px;}
.care-meal-page .meal-grid ul{columns:2;column-gap:32px;margin:0;padding-left:22px;line-height:1.55;font-size:16px;}
.care-meal-page .meal-menu{margin-top:10px!important;padding:14px 18px;}
.care-meal-page .meal-menu h2{font-size:22px;margin-bottom:8px;}
.care-meal-page .meal-menu table{font-size:15.5px;}
.care-meal-page .meal-menu th,.care-meal-page .meal-menu td{padding:6px 8px;line-height:1.35;}
.care-medicine-page .card,.care-emergency-page .card{padding:16px 18px;}
.care-medicine-page .card[style],.care-emergency-page .card[style]{margin-top:10px!important;}
.care-medicine-page .notice{padding:12px;}
.care-emergency-page textarea{min-height:58px;}
.care-medicine-page,.care-emergency-page{overflow:hidden;}
@media(min-width:901px){
  body:has(.care-page){overflow:hidden;}
}
@media(max-width:900px){
  .app.care-page{height:auto;overflow:visible;margin:10px auto;}
  .care-reminder,.care-card{max-height:none;overflow:visible;}
  .care-grid{grid-template-columns:1fr;}
  .care-meal-page .meal-grid ul{columns:1;}
}

/* v0.2.6 Expense edit + subsidy add polish */
.expense-edit-table input,.expense-edit-table select{padding:6px 7px;border-radius:8px;font-size:14px;min-width:0}.expense-edit-table td{padding:5px 6px}.expense-edit-table th:nth-child(1){width:18%}.expense-edit-table th:nth-child(2){width:13%}.expense-edit-table th:nth-child(3){width:13%}.expense-edit-table th:nth-child(4){width:15%}.expense-edit-table th:nth-child(5){width:28%}.expense-edit-table th:nth-child(6){width:13%}.expense-actions{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.expense-actions .hint{font-size:12px}.subsidy-add-form{margin-top:4px}.expense-right hr.thin{border:0;border-top:1px solid var(--line);margin:10px 0}.expense-right h3{font-size:17px;margin:6px 0}.new-contact-grid input[readonly]{background:#f3f6fb;color:#334155}
@media(max-width:1100px){.expense-edit-table{min-width:860px}.expense-table-wrap{overflow:auto}}

/* v0.2.8 Expense subsidy form visibility fix */
.expenses-page{height:calc(100vh - 66px);overflow:hidden;margin-top:8px}
.expenses-page .page-head{margin-bottom:6px}
.expenses-page .summary-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;margin:4px 0 7px}
.expenses-page .summary-row .stat{padding:7px 10px;min-height:52px}
.expenses-page .summary-row .stat b{font-size:21px;line-height:1.1}
.expense-layout{height:calc(100vh - 176px);grid-template-columns:1.12fr .88fr;gap:10px;align-items:stretch}
.expense-list,.expense-right{min-height:0;overflow:hidden}
.expense-table-wrap{max-height:calc(100vh - 270px);overflow:auto}
.expense-right{display:grid;grid-template-rows:auto 1fr;gap:10px}
.expense-right>.card{margin-top:0!important;min-height:0;overflow:hidden}
.expense-right h2{font-size:20px;margin:0 0 8px}
.expense-right h3{font-size:16px;margin:6px 0 5px}
.expense-right label{font-size:13px;margin:3px 0 2px}
.expense-right input,.expense-right select{padding:7px 9px;border-radius:9px}
.expense-right .btn{padding:8px 10px}
.expense-right .hint{font-size:11px;line-height:1.25}
.expense-right hr.thin{margin:7px 0;border:0;border-top:1px solid var(--line)}
.expense-add-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 8px;align-items:end}
.expense-add-grid .wide-2{grid-column:1 / span 2}
.expense-add-grid .add-row-btn{grid-column:1 / span 2;margin-top:2px!important}
.subsidy-setting-grid{display:grid;grid-template-columns:1fr 1fr .95fr;gap:7px;align-items:end}
.subsidy-setting-grid .btn{height:38px}
.compact-hint{margin:5px 0 0}
.subsidy-add-grid{display:grid;grid-template-columns:1.1fr .8fr .65fr;gap:6px 8px;align-items:end}
.subsidy-add-grid .wide-2{grid-column:1 / span 2}
.subsidy-add-grid .subsidy-add-btn{height:38px;align-self:end;margin-top:0!important}
.subsidy-add-form{margin-top:2px}
@media(max-width:1100px){.expenses-page,.expense-layout{height:auto;overflow:visible}.expense-layout{grid-template-columns:1fr}.expense-right{display:block}.expense-right>.card{overflow:visible}.expense-table-wrap{max-height:none;overflow:auto}.subsidy-setting-grid,.subsidy-add-grid{grid-template-columns:1fr}.subsidy-add-grid .wide-2,.expense-add-grid .wide-2,.expense-add-grid .add-row-btn{grid-column:auto}}

/* v0.2.10: inline subsidy helper to save one vertical line */
.inline-help-label{display:flex;align-items:baseline;gap:8px;white-space:nowrap}
.inline-help-label .inline-hint{font-weight:600;font-size:11px;color:var(--muted)}

/* v0.2.10: batch expense actions, no per-row operation column */
.expense-bulkbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:0 0 7px}
.expense-batch-table th.select-col,.expense-batch-table td.select-col{width:52px;text-align:center}
.expense-batch-table .select-col input[type="checkbox"]{width:18px;height:18px;padding:0}
.expense-batch-table th:nth-child(2){width:18%}
.expense-batch-table th:nth-child(3){width:12%}
.expense-batch-table th:nth-child(4){width:12%}
.expense-batch-table th:nth-child(5){width:14%}
.expense-batch-table th:nth-child(6){width:44%}
.expense-batch-table .note-col input{min-width:220px}
.expense-batch-table .expense-total-row td{background:#fff;font-weight:800}
.expense-batch-table .expense-total-row td:first-child{border-bottom:1px solid var(--line)}
@media(max-width:1100px){.expense-batch-table{min-width:880px}}
