:root{--bg: #f5f6f8;--card: #ffffff;--text: #111827;--sub: #6b7280;--line: #e5e7eb;--brand: #2563eb;--brand-soft: #dbeafe;--danger: #dc2626;--ok: #16a34a;--radius: 14px;font-family:system-ui,-apple-system,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--text)}button{font:inherit;cursor:pointer}a{color:var(--brand)}.page{min-height:100%;max-width:560px;margin:0 auto;padding:20px 18px 40px}.h1{font-size:2rem;font-weight:800;margin:0 0 8px;letter-spacing:-.02em}.h2{font-size:1.35rem;font-weight:800;margin:0 0 8px}.muted{color:var(--sub);font-size:1rem;line-height:1.55;margin:0 0 20px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:14px}.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;border:none;border-radius:var(--radius);padding:16px 18px;font-size:1.1rem;font-weight:700}.btn-primary{background:var(--brand);color:#fff}.btn-primary:disabled{opacity:.65}.btn-secondary{background:#fff;color:var(--text);border:2px solid var(--line)}.btn-ghost{background:transparent;color:var(--brand);border:none;width:auto;padding:10px 0;font-weight:700}.btn-danger-outline{background:#fff;color:var(--danger);border:2px solid #fecaca}.input{width:100%;padding:14px 16px;font-size:1.05rem;border:1px solid var(--line);border-radius:12px;background:#fff}.label{display:block;font-weight:700;margin:14px 0 8px;font-size:.95rem;color:var(--text)}.pill{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:.85rem;font-weight:700;background:var(--brand-soft);color:#1e3a8a}.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}.topbar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.topbar-actions button{font-size:.95rem;font-weight:700;padding:8px 12px;border-radius:10px;border:1px solid var(--line);background:#fff}.record-card{border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:12px;background:#fff}.record-title{font-size:1.25rem;font-weight:800;margin:0 0 6px}.record-meta{color:var(--sub);margin:0 0 14px;font-size:1rem}.record-actions .btn{flex:1;min-width:140px;padding:14px}.tag{border:1px solid var(--line);background:#fff;padding:8px 12px;border-radius:999px;font-weight:700;font-size:.9rem}.tag.active{border-color:var(--brand);background:var(--brand-soft)}.ad-box{margin-top:18px;padding:14px;border-radius:var(--radius);background:#e5e7eb;border:1px dashed #9ca3af}.ad-box small{display:block;color:var(--sub);margin-top:6px}.cal-day{border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;background:#fff}.cal-day h4{margin:0 0 8px;font-size:1rem}.cal-item{font-size:.95rem;color:var(--text);margin:4px 0}:root{--bg0: #eef2ff;--bg1: #f8fafc;--surface: #ffffff;--text: #0f172a;--text2: #475569;--muted: #64748b;--line: #e2e8f0;--brand: #4f46e5;--brand2: #6366f1;--brand-soft: #e0e7ff;--brand-ink: #312e81;--ok: #059669;--ok-soft: #d1fae5;--warn: #d97706;--warn-soft: #ffedd5;--danger: #dc2626;--danger-soft: #fee2e2;--shadow: 0 12px 42px rgba(15, 23, 42, .09);--shadow-sm: 0 2px 10px rgba(15, 23, 42, .06);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .72);--r12: 12px;--r16: 16px;--r20: 20px;--maxw: 520px;--bottom-nav-h: 64px}html{-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:linear-gradient(168deg,#eef2ff,#f8fafc 38%,#f1f5f9);background-attachment:fixed;color:var(--text)}#root{min-height:100%}.page{max-width:var(--maxw);margin:0 auto;padding:20px 18px 28px;min-height:100%}.page--tabbed{padding-bottom:calc(156px + var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}.today-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px;padding:12px 16px;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:var(--r16);border:1px solid rgba(199,210,254,.45);box-shadow:var(--shadow-sm),var(--shadow-inset)}.today-strip__left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}.today-strip__badge{font-size:.68rem;font-weight:900;letter-spacing:.08em;color:var(--brand-ink);background:linear-gradient(135deg,var(--brand-soft) 0%,#e0e7ff 100%);padding:5px 11px;border-radius:999px;border:1px solid rgba(129,140,248,.35)}.today-strip__week{font-size:1.08rem;font-weight:900;color:var(--text);letter-spacing:-.02em}.today-strip__cal{font-size:.86rem;font-weight:700;color:var(--muted);white-space:nowrap}.week-strip{margin-bottom:16px;padding:12px 12px 14px;background:linear-gradient(180deg,#fff,#f8fafc);border-radius:var(--r20);border:1px solid rgba(199,210,254,.45);box-shadow:var(--shadow-sm),var(--shadow-inset)}.week-strip__toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.week-strip__hint{flex:1;text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);line-height:1.35}.week-strip__month-btn{flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:8px 10px;border-radius:14px;border:1px solid rgba(199,210,254,.55);background:linear-gradient(180deg,#fff,#eef2ff);font-size:.88rem;font-weight:900;color:var(--brand-ink);cursor:pointer;box-shadow:var(--shadow-sm)}.week-strip__month-btn-icon{font-size:1.1rem;line-height:1}.week-strip__month-btn-text{letter-spacing:.02em}.month-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4000;background:#0f172a7a;display:flex;align-items:flex-end;justify-content:center;padding:10px;padding-bottom:max(10px,env(safe-area-inset-bottom,0px))}.month-modal-card{width:100%;max-width:var(--maxw);max-height:min(92vh,720px);overflow:auto;background:var(--surface);border-radius:var(--r20) var(--r20) 0 0;border:1px solid var(--line);box-shadow:var(--shadow);padding:14px 16px 18px}.month-modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.month-modal-close{width:40px;height:40px;border:none;border-radius:12px;background:var(--bg1);font-size:1.35rem;line-height:1;cursor:pointer;color:var(--text2)}.week-strip__nav{flex-shrink:0;width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:var(--surface);font-size:1.35rem;font-weight:800;color:var(--brand2);line-height:1;cursor:pointer;box-shadow:var(--shadow-sm)}.week-strip__nav:disabled{opacity:.35;cursor:not-allowed}.week-strip__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.week-strip__cell{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:2px;padding:8px 4px 10px;border:1px solid transparent;border-radius:14px;background:transparent;cursor:pointer;min-height:72px;color:var(--text)}.week-strip__cell:disabled,.week-strip__cell--muted{opacity:.35;cursor:not-allowed}.week-strip__cell--today:not(.week-strip__cell--selected){border-color:#818cf873;background:#eef2ffa6}.week-strip__cell--selected{background:linear-gradient(160deg,var(--brand2) 0%,var(--brand) 100%);color:#fff;border-color:transparent;box-shadow:0 6px 18px #4f46e547}.week-strip__cell--selected .week-strip__dow{color:#ffffffeb}.week-strip__cell--selected .week-strip__num{color:#fff}.week-strip__dow{font-size:.72rem;font-weight:800;color:var(--muted)}.week-strip__num{font-size:1.12rem;font-weight:900;letter-spacing:-.02em}.week-strip__dot{width:6px;height:6px;border-radius:999px;margin-top:2px}.week-strip__dot--none{background:transparent}.week-strip__dot--miss{background:var(--danger);box-shadow:0 0 0 2px #dc262633}.week-strip__dot--pending{background:var(--warn)}.week-strip__dot--ok{background:var(--ok)}.week-strip__cell--selected .week-strip__dot--miss{background:#fecaca;box-shadow:none}.week-strip__cell--selected .week-strip__dot--pending{background:#fde68a}.week-strip__cell--selected .week-strip__dot--ok{background:#bbf7d0}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.app-brand{display:flex;align-items:center;gap:10px}.app-logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand2) 100%);color:#fff;font-weight:900;font-size:1rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.app-brand-text strong{display:block;font-size:1.05rem;font-weight:800;letter-spacing:.02em}.app-brand-text small{display:block;font-size:.78rem;color:var(--muted);margin-top:2px}.icon-btn{border:1px solid var(--line);background:var(--surface);border-radius:var(--r12);padding:10px 14px;font-weight:700;font-size:.9rem;color:var(--text2);box-shadow:var(--shadow-sm)}.icon-btn:hover{border-color:#cbd5e1;color:var(--text)}.icon-btn:active{transform:scale(.98)}.h1{font-size:1.85rem;font-weight:900;letter-spacing:-.03em;margin:0 0 10px;line-height:1.2;color:var(--text)}.h2{font-size:1.12rem;font-weight:800;margin:0 0 8px;color:var(--text)}.muted{color:var(--muted);font-size:1rem;line-height:1.6;margin:0 0 18px}.legal-note{font-size:.82rem;color:var(--muted);line-height:1.5;margin-top:20px;padding:12px 14px;background:#ffffffa6;border-radius:var(--r12);border:1px solid var(--line)}.card{background:linear-gradient(180deg,#fff,#fafbfc);border-radius:var(--r20);padding:18px;margin-bottom:14px;border:1px solid rgba(226,232,240,.85);box-shadow:var(--shadow-sm),var(--shadow-inset)}.card--elevate{box-shadow:var(--shadow)}.card-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.card-kicker{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--brand);margin-bottom:6px}.hero-panel{border-radius:var(--r20);padding:22px 20px;margin-bottom:20px;background:linear-gradient(135deg,#4f46e5,#7c3aed 55%,#9333ea);color:#fff;box-shadow:var(--shadow)}.hero-panel h1{margin:0 0 10px;font-size:1.65rem;font-weight:900;line-height:1.25}.hero-panel p{margin:0;opacity:.92;font-size:1rem;line-height:1.55}.role-path-stack{display:flex;flex-direction:column;gap:18px}.role-path-card .role-path-title{margin:4px 0 8px;font-size:1.25rem;font-weight:900;color:var(--text);letter-spacing:-.02em}.role-path-lead{margin:0 0 14px;font-size:.98rem;line-height:1.55}.role-path-secondary{margin-top:12px}.role-path-ghost{margin-top:10px;width:100%;font-weight:700}.role-path-card--family{border-color:#818cf859;background:linear-gradient(180deg,#fff,#f8fafc)}.role-path-details{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}.role-path-details summary{cursor:pointer;font-size:.9rem;font-weight:800;color:var(--text2);list-style:none}.role-path-details summary::-webkit-details-marker{display:none}.role-path-details summary:after{content:" ▾";font-weight:700;color:var(--muted)}.role-path-details[open] summary:after{content:" ▴"}.bullet-list{margin:16px 0 0;padding:0;list-style:none}.bullet-list li{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:.95rem;line-height:1.45;opacity:.95}.bullet-list li:before{content:"✓";font-weight:900;flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;border:none;border-radius:var(--r16);padding:16px 18px;font-size:1.08rem;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.btn:active:not(:disabled){transform:scale(.99)}.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,#7c3aed 100%);color:#fff;box-shadow:0 8px 24px #4f46e559}.btn-primary:disabled{opacity:.55;box-shadow:none}.btn-secondary{background:var(--surface);color:var(--text);border:2px solid var(--line);box-shadow:var(--shadow-sm)}.btn-ghost{background:transparent;color:var(--brand-ink);border:none;width:auto;padding:8px 0;font-weight:700;font-size:.95rem;box-shadow:none}.btn-danger-outline{background:var(--surface);color:var(--danger);border:2px solid #fecaca}.btn--compact{width:auto;padding:10px 16px;font-size:.95rem}.reminder-shell{max-width:var(--maxw);margin:0 auto;min-height:100vh;padding:20px 18px calc(28px + env(safe-area-inset-bottom,0px));box-sizing:border-box}.reminder-shell--pulse{animation:reminder-pulse 2.2s ease-in-out infinite}@keyframes reminder-pulse{0%,to{filter:none}50%{filter:brightness(.97)}}.reminder-back{margin-bottom:12px}.reminder-bell{width:72px;height:72px;margin:8px auto 16px;border-radius:50%;background:linear-gradient(135deg,var(--brand-soft) 0%,#c7d2fe 100%);color:var(--brand-ink);font-weight:900;font-size:1.6rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}.reminder-title{text-align:center;font-size:1.75rem;font-weight:900;margin:0 0 12px;line-height:1.25}.reminder-lead{text-align:center;font-size:1.12rem;line-height:1.55;margin:0 0 18px;color:var(--text)}.reminder-medlist{list-style:none;padding:0;margin:0 0 20px;background:var(--surface);border-radius:var(--r16);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.reminder-medlist li{padding:14px 16px;font-weight:700;font-size:1.02rem;border-bottom:1px solid var(--line)}.reminder-medlist li:last-child{border-bottom:none}.reminder-hint{font-size:.85rem;text-align:center;margin:0 0 20px}.reminder-actions{display:flex;flex-direction:column;gap:12px}.reminder-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}.reminder-row:last-child{border-bottom:none;padding-bottom:0}.reminder-row:first-child{padding-top:0}.link-inline{border:none;background:none;padding:0;margin:0;font:inherit;font-weight:800;color:var(--brand);text-decoration:underline;cursor:pointer}.record-card--group{border-left:4px solid var(--brand-soft)}.group-med-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}.group-med-list__row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.group-med-list__row:last-child{border-bottom:none}.group-med-list__main{min-width:0;display:flex;flex-direction:column;gap:2px}.group-med-list__name{font-weight:800;font-size:1rem}.group-med-list__dose{font-size:.88rem;color:var(--muted)}.segment{display:flex;padding:4px;border-radius:14px;background:#e2e8f0;margin-bottom:16px;gap:4px}.segment button{flex:1;border:none;border-radius:11px;padding:12px 10px;font-weight:800;font-size:.95rem;color:var(--text2);background:transparent;cursor:pointer}.segment button.seg-active{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}.input{width:100%;padding:15px 16px;font-size:1.05rem;border:1.5px solid var(--line);border-radius:var(--r12);background:#f8fafc;color:var(--text)}.input:focus{outline:none;border-color:var(--brand2);background:#fff;box-shadow:0 0 0 3px var(--brand-soft)}.label{display:block;font-weight:800;margin:14px 0 8px;font-size:.88rem;color:var(--text2)}.hero-today{border-radius:var(--r20);padding:18px 18px 16px;margin-bottom:16px;background:linear-gradient(148deg,#fff,#eef2ff 52%,#f8fafc);border:1px solid rgba(199,210,254,.4);box-shadow:var(--shadow-sm),var(--shadow-inset)}.hero-today__top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.hero-today__label{font-size:.8rem;font-weight:800;color:var(--muted);letter-spacing:.04em}.hero-today__stat{font-size:1.45rem;font-weight:900;color:var(--text);letter-spacing:-.02em}.hero-today__next{margin-top:10px;padding-top:12px;border-top:1px dashed var(--line);font-size:.98rem;color:var(--text2);line-height:1.45}.hero-today__next strong{color:var(--text)}.summary-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}.summary-cell{background:var(--surface);border-radius:var(--r16);padding:12px 10px;text-align:center;border:1px solid var(--line);box-shadow:var(--shadow-sm)}.summary-cell span{display:block;font-size:.72rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.summary-cell strong{font-size:1.25rem;font-weight:900;color:var(--text)}.record-card{border-radius:var(--r20);padding:16px 16px 14px;margin-bottom:12px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.record-title{font-size:1.22rem;font-weight:900;margin:0 0 6px;color:var(--text)}.record-meta{color:var(--muted);margin:0 0 14px;font-size:.98rem;line-height:1.45}.record-actions{display:flex;gap:10px;flex-wrap:wrap}.record-actions .btn{flex:1;min-width:138px;padding:14px;font-size:1rem}.pill{display:inline-flex;align-items:center;padding:6px 11px;border-radius:999px;font-size:.78rem;font-weight:800;white-space:nowrap}.settings-section-title{font-size:.72rem;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:22px 0 8px 4px}.settings-section-title:first-of-type{margin-top:6px}.settings-group{background:var(--surface);border-radius:var(--r20);border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:4px}.settings-row{display:flex;align-items:center;width:100%;gap:12px;padding:14px 16px;border:none;background:transparent;text-align:left;cursor:pointer;border-bottom:1px solid var(--line);font:inherit}.settings-row:last-child{border-bottom:none}.settings-row:active{background:#f8fafc}.settings-row-icon{width:40px;height:40px;border-radius:12px;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}.settings-row-body{flex:1;min-width:0}.settings-row-title{display:block;font-weight:800;font-size:1.02rem;color:var(--text)}.settings-row-sub{display:block;font-size:.86rem;color:var(--muted);margin-top:3px;line-height:1.35}.settings-row-chevron{color:#cbd5e1;font-size:1.35rem;font-weight:300;flex-shrink:0}.profile-card{display:flex;align-items:center;gap:14px;padding:4px 2px 16px;margin-bottom:8px}.profile-avatar{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,var(--brand-soft),#ddd6fe);color:var(--brand-ink);font-size:1.35rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-meta strong{display:block;font-size:1.15rem;font-weight:900}.profile-meta span{display:block;font-size:.88rem;color:var(--muted);margin-top:4px}.profile-chips{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px}.role-chip{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:800;background:var(--brand-soft);color:var(--brand-ink)}.vip-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:800;letter-spacing:.02em;background:linear-gradient(135deg,#fef9c3,#fde047);color:#713f12;border:1px solid rgba(180,83,9,.22);box-shadow:0 1px 2px #0f172a0f}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:100;display:flex;justify-content:center;padding:10px 12px calc(24px + env(safe-area-inset-bottom,0px));pointer-events:none}.page-tail-safe{margin-bottom:132px}.bottom-nav-inner{pointer-events:auto;width:100%;max-width:var(--maxw);display:flex;gap:8px;padding:6px 8px;background:#ffffffeb;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(226,232,240,.95);border-radius:18px;box-shadow:0 -4px 28px #0f172a1a}.bottom-nav a{flex:1;text-align:center;text-decoration:none;padding:11px 8px;border-radius:14px;font-weight:800;font-size:.88rem;color:var(--muted);transition:background .15s ease,color .15s ease}.bottom-nav a.active{color:var(--brand);background:var(--brand-soft)}.bottom-nav a:not(.active):hover{color:var(--text2);background:#f1f5f9}.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tag{border:1.5px solid var(--line);background:#f8fafc;padding:9px 13px;border-radius:999px;font-weight:800;font-size:.88rem;color:var(--text2);cursor:pointer}.tag.active{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-ink)}.ad-box{margin-top:16px;padding:16px;border-radius:var(--r16);background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border:1px dashed #94a3b8}.ad-box small{display:block;color:var(--muted);margin-top:8px;line-height:1.45}.cal-day{border-radius:var(--r16);padding:14px;margin-bottom:10px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.cal-day h4{margin:0 0 10px;font-size:.95rem;font-weight:900;color:var(--text2)}.cal-item{font-size:.92rem;color:var(--text);margin:5px 0;line-height:1.4}.select-wrap{position:relative}.select-wrap select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:40px;background-color:#f8fafc;font-weight:700}.select-wrap:after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.85rem;pointer-events:none}.help-step{display:flex;gap:14px;margin-bottom:18px}.help-step-num{width:36px;height:36px;border-radius:12px;background:var(--brand);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.help-step-body strong{display:block;font-size:1.02rem;margin-bottom:4px}.help-step-body p{margin:0;color:var(--muted);font-size:.95rem;line-height:1.55}.alert{border-radius:var(--r16);padding:14px 16px;margin-bottom:14px;font-size:.95rem;line-height:1.5}.alert--error{background:var(--danger-soft);color:#991b1b;border:1px solid #fecaca}.alert--ok{background:var(--ok-soft);color:#065f46;border:1px solid #a7f3d0}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.modal-card{width:100%;max-width:400px;background:var(--surface);border-radius:var(--r20);padding:22px 20px 18px;box-shadow:var(--shadow);border:1px solid var(--line)}.modal-card__title{margin:0 0 10px;font-size:1.2rem;font-weight:900;color:var(--text)}.modal-card__body{margin:0 0 18px;font-size:.95rem;line-height:1.55;color:var(--text2)}.modal-card__actions{display:flex;flex-direction:column;gap:10px}.tone-picker__row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}.tone-picker__row:last-child{border-bottom:none;padding-bottom:0}.tone-picker__label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;flex:1;min-width:0}.tone-picker__label input{margin-top:4px;flex-shrink:0}.tone-picker__text{display:flex;flex-direction:column;gap:2px;min-width:0}.tone-picker__text strong{font-size:.95rem}.tone-picker__hint{font-size:.8rem;color:var(--muted);font-weight:600;line-height:1.35}.tone-picker__preview{flex-shrink:0}html[data-app-mode=family]{--maxw: 580px;--bottom-nav-h: 56px}html[data-app-mode=family] .page{padding:14px 14px 22px}html[data-app-mode=family] .page--tabbed{padding-bottom:calc(172px + var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}html[data-app-mode=family] .app-header{margin-bottom:12px}html[data-app-mode=family] .app-logo{width:36px;height:36px;border-radius:12px;font-size:.88rem}html[data-app-mode=family] .app-brand-text strong{font-size:.98rem}html[data-app-mode=family] .app-brand-text small{font-size:.72rem}html[data-app-mode=family] .icon-btn{padding:8px 12px;font-size:.82rem}html[data-app-mode=family] .h1{font-size:1.38rem;margin:0 0 8px}html[data-app-mode=family] .h2{font-size:1rem;margin:0 0 6px}html[data-app-mode=family] .muted{font-size:.88rem;margin:0 0 12px}html[data-app-mode=family] .card{padding:14px;margin-bottom:10px}html[data-app-mode=family] .card-title-row{margin-bottom:8px}html[data-app-mode=family] .btn{padding:12px 14px;font-size:.98rem}html[data-app-mode=family] .btn--compact{padding:8px 12px;font-size:.88rem}html[data-app-mode=family] .label{margin:10px 0 6px;font-size:.8rem}html[data-app-mode=family] .input{padding:11px 12px;font-size:.92rem}html[data-app-mode=family] .segment{margin-bottom:12px}html[data-app-mode=family] .segment button{padding:9px 8px;font-size:.86rem}html[data-app-mode=family] .hero-today{padding:12px 14px 10px;margin-bottom:12px}html[data-app-mode=family] .hero-today__stat{font-size:1.15rem}html[data-app-mode=family] .hero-today__next{margin-top:8px;padding-top:10px;font-size:.88rem}html[data-app-mode=family] .today-strip{margin-bottom:12px;padding:10px 12px;gap:8px}html[data-app-mode=family] .today-strip__badge{font-size:.62rem;padding:4px 9px}html[data-app-mode=family] .today-strip__week{font-size:.95rem}html[data-app-mode=family] .today-strip__cal{font-size:.8rem}html[data-app-mode=family] .week-strip{padding:10px 8px 12px;margin-bottom:12px}html[data-app-mode=family] .week-strip__hint{font-size:.65rem}html[data-app-mode=family] .week-strip__month-btn{font-size:.78rem;padding:6px 8px;gap:6px}html[data-app-mode=family] .week-strip__nav{width:34px;height:34px;font-size:1.15rem}html[data-app-mode=family] .week-strip__cell{min-height:62px;padding:6px 2px 8px}html[data-app-mode=family] .week-strip__dow{font-size:.65rem}html[data-app-mode=family] .week-strip__num{font-size:.95rem}html[data-app-mode=family] .summary-strip{gap:8px;margin-bottom:12px}html[data-app-mode=family] .summary-cell{padding:8px}html[data-app-mode=family] .summary-cell strong{font-size:1.05rem}html[data-app-mode=family] .record-card{padding:12px 12px 10px;margin-bottom:10px}html[data-app-mode=family] .record-title{font-size:1.02rem}html[data-app-mode=family] .record-meta{font-size:.84rem;margin:0 0 10px}html[data-app-mode=family] .group-med-list__name{font-size:.92rem}html[data-app-mode=family] .group-med-list__dose{font-size:.8rem}html[data-app-mode=family] .bottom-nav-inner{padding:4px 6px;border-radius:16px}html[data-app-mode=family] .bottom-nav a{padding:8px 6px;font-size:.78rem}html[data-app-mode=family] .alert{padding:10px 12px;margin-bottom:10px;font-size:.86rem}html[data-app-mode=family] .modal-card{padding:16px 16px 14px}html[data-app-mode=family] .modal-card__title{font-size:1.05rem}html[data-app-mode=family] .modal-card__body{font-size:.88rem}html[data-app-mode=taker]{--bottom-nav-h: 72px}html[data-app-mode=taker] .page{padding:22px 18px 30px}html[data-app-mode=taker] .page--tabbed{padding-bottom:calc(182px + var(--bottom-nav-h) + env(safe-area-inset-bottom,0px))}html[data-app-mode=taker] .app-logo{width:46px;height:46px;border-radius:15px;font-size:1.08rem}html[data-app-mode=taker] .app-brand-text strong{font-size:1.12rem}html[data-app-mode=taker] .icon-btn{padding:11px 16px;font-size:.95rem}html[data-app-mode=taker] .h1{font-size:2rem}html[data-app-mode=taker] .h2{font-size:1.22rem}html[data-app-mode=taker] .muted{font-size:1.06rem}html[data-app-mode=taker] .card{padding:20px 18px}html[data-app-mode=taker] .btn{padding:18px 20px;font-size:1.14rem}html[data-app-mode=taker] .label{font-size:.92rem}html[data-app-mode=taker] .input{padding:17px 16px;font-size:1.12rem}html[data-app-mode=taker] .segment button{padding:14px 10px;font-size:1rem}html[data-app-mode=taker] .hero-today{padding:20px 18px 18px}html[data-app-mode=taker] .hero-today__stat{font-size:1.58rem}html[data-app-mode=taker] .hero-today__next{font-size:1.05rem}html[data-app-mode=taker] .today-strip{margin-bottom:18px;padding:14px 18px}html[data-app-mode=taker] .today-strip__badge{font-size:.76rem;padding:6px 12px}html[data-app-mode=taker] .today-strip__week{font-size:1.22rem}html[data-app-mode=taker] .today-strip__cal{font-size:.98rem}html[data-app-mode=taker] .week-strip{padding:14px 12px 16px;margin-bottom:18px}html[data-app-mode=taker] .week-strip__hint{font-size:.78rem}html[data-app-mode=taker] .week-strip__month-btn{font-size:1rem;padding:10px 14px}html[data-app-mode=taker] .week-strip__nav{width:46px;height:46px;font-size:1.45rem}html[data-app-mode=taker] .week-strip__cell{min-height:82px;padding:10px 4px 12px}html[data-app-mode=taker] .week-strip__dow{font-size:.78rem}html[data-app-mode=taker] .week-strip__num{font-size:1.22rem}html[data-app-mode=taker] .week-strip__dot{width:7px;height:7px}html[data-app-mode=taker] .summary-cell strong,html[data-app-mode=taker] .record-title{font-size:1.32rem}html[data-app-mode=taker] .record-meta{font-size:1.05rem}html[data-app-mode=taker] .group-med-list__name{font-size:1.08rem}html[data-app-mode=taker] .bottom-nav a{padding:13px 8px;font-size:.92rem}html[data-app-mode=taker] .reminder-bell{width:80px;height:80px;font-size:1.75rem}html[data-app-mode=taker] .reminder-title{font-size:1.95rem}html[data-app-mode=taker] .reminder-lead{font-size:1.18rem}html[data-app-mode=taker] .reminder-medlist li{padding:16px 18px;font-size:1.1rem}html[data-app-mode=taker] .reminder-hint{font-size:.92rem}.page-state{margin:14px 0 18px}.page-state--inline{display:flex;align-items:center;gap:10px;color:var(--muted);font-weight:700;font-size:.92rem}.page-state--block{display:block}.page-state__caption{margin:10px 0 0;text-align:center;font-size:.88rem;color:var(--muted);font-weight:700}.page-state__spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid var(--line);border-top-color:var(--brand);animation:page-spin .75s linear infinite;flex-shrink:0}@keyframes page-spin{to{transform:rotate(360deg)}}.page-skeleton-stack{display:flex;flex-direction:column;gap:12px}.page-skeleton{border-radius:var(--r16);background:var(--surface);border:1px solid var(--line);padding:14px 16px;overflow:hidden;position:relative}.page-skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.55) 45%,rgba(255,255,255,.85) 50%,rgba(255,255,255,.55) 55%,transparent 100%);transform:translate(-100%);animation:page-shimmer 1.35s ease-in-out infinite}@keyframes page-shimmer{to{transform:translate(100%)}}.page-skeleton--hero{padding:18px 16px}.page-skeleton__line{height:12px;border-radius:6px;background:#e2e8f0;margin-bottom:10px}.page-skeleton__line:last-child{margin-bottom:0}.page-skeleton__line--lg{width:55%;height:14px}.page-skeleton__line--md{width:80%}.page-skeleton__line--sm{width:65%}.page-skeleton__line--xs{width:40%;margin-bottom:0}.page-error-panel__msg{margin:0 0 12px;line-height:1.5}.fam-month-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;flex-wrap:wrap}.fam-month-title{font-weight:900;font-size:1.1rem;color:var(--text)}.fam-month-nav{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:10px 14px;font-weight:800;font-size:.92rem;cursor:pointer;color:var(--text2)}.fam-month-nav:disabled{opacity:.4;cursor:not-allowed}.fam-month-cal{margin-top:16px;padding:12px;background:var(--surface);border-radius:var(--r20);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.fam-month-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}.fam-month-dow__cell{text-align:center;font-size:.75rem;font-weight:800;color:var(--muted);padding:6px 0}.fam-month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.fam-month-cell{aspect-ratio:1;min-height:40px;border-radius:12px;border:1px solid var(--line);background:#f8fafc;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;font:inherit}.fam-month-cell__num{font-weight:900;font-size:.98rem;color:var(--text)}.fam-month-cell--muted .fam-month-cell__num{color:var(--muted);font-weight:700}.fam-month-cell--miss{background:var(--danger-soft);border-color:#dc262659}.fam-month-cell--miss .fam-month-cell__num{color:var(--danger)}.fam-month-cell--ok{background:var(--ok-soft);border-color:#05966959}.fam-month-cell--ok .fam-month-cell__num{color:var(--ok)}.fam-month-cell--warn{background:var(--warn-soft);border-color:#d9770659}.fam-month-cell--warn .fam-month-cell__num{color:var(--warn)}.fam-month-cell--selected{outline:3px solid var(--brand);outline-offset:1px}.fam-month-cell--disabled{opacity:.35;cursor:not-allowed}.fam-day-detail-list{list-style:none;margin:0;padding:0}.fam-day-detail-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.fam-day-detail-row:last-child{border-bottom:none}.fam-day-status{flex-shrink:0;font-size:.82rem;font-weight:800;padding:6px 10px;border-radius:999px}.fam-day-status--ok{background:var(--ok-soft);color:var(--ok)}.fam-day-status--miss{background:var(--danger-soft);color:var(--danger)}.fam-day-status--warn{background:var(--warn-soft);color:var(--warn)}
