:root{--color-bg: #f4f6fb;--color-surface: #ffffff;--color-text-primary: #0f172a;--color-text-secondary: #64748b;--color-border: #e2e8f0;--color-primary: #2563eb;--color-primary-dark: #1e40af;--color-success: #059669;--color-warning: #d97706;--color-danger: #dc2626;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 16px rgba(15, 23, 42, .07);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;color:var(--color-text-primary);background:var(--color-bg);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(1200px 400px at 50% -100px,rgba(37,99,235,.12),transparent 70%),var(--color-bg)}.shell{max-width:1040px;margin:0 auto 64px;padding:28px 20px 0}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px}.brand{display:flex;align-items:center;gap:14px}.brand-mark{width:48px;height:48px;flex-shrink:0;display:grid;place-items:center;border-radius:14px;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;box-shadow:0 6px 16px #2563eb59}h1{margin:0;font-size:26px;font-weight:800;letter-spacing:-.02em}.topbar p{margin:2px 0 0;color:var(--color-text-secondary);font-size:14px}.pill{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.pill:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}.pill-online{background:#0596691f;color:var(--color-success)}.pill-online:before{box-shadow:0 0 0 3px #0596692e}.pill-offline{background:#dc26261a;color:var(--color-danger)}.wake-banner{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;border-radius:var(--radius-md);background:linear-gradient(90deg,#2563eb14,#2563eb08);border:1px solid rgba(37,99,235,.25);color:var(--color-primary-dark);font-size:14px;font-weight:500}.wake-banner[hidden]{display:none}.spinner{width:18px;height:18px;flex-shrink:0;border:2.5px solid rgba(37,99,235,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px;padding:6px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;box-shadow:var(--shadow-sm);width:fit-content}.tab-link{text-decoration:none;color:var(--color-text-secondary);border:none;background:transparent;border-radius:999px;padding:9px 18px;font-size:13.5px;font-weight:600;transition:color .15s ease,background .15s ease}.tab-link:hover{color:var(--color-primary);background:#2563eb12}.tab-link-active,.tab-link-active:hover{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 3px 10px #2563eb59}.layout{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}.single-column{grid-template-columns:1fr}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-md);margin-bottom:20px;transition:box-shadow .2s ease,transform .2s ease}.layout .card{margin-bottom:0}.card:hover{box-shadow:var(--shadow-lg)}.card h2{margin:0 0 14px;font-size:17px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card h2:before{content:"";width:4px;height:18px;border-radius:4px;background:linear-gradient(180deg,#2563eb,#60a5fa)}.score-box{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;background:linear-gradient(135deg,#f8fafc,#eef2ff);text-align:center}.score-value{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--color-primary);margin-top:4px}.summary-list .score-value{font-size:20px}.score-red{color:var(--color-danger)}.score-amber{color:var(--color-warning)}.score-green{color:var(--color-success)}.weakest-member{border:2px solid var(--color-danger);background:#dc262608}.progress-wrap{margin-top:14px}.progress-label{display:flex;justify-content:space-between;font-size:14px;margin-bottom:8px;color:var(--color-text-secondary)}.progress-track{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#2563eb,#059669);transition:width .4s cubic-bezier(.4,0,.2,1)}.bag-category h3{margin:4px 0 12px;font-size:15px;font-weight:700;color:var(--color-primary-dark);text-transform:uppercase;letter-spacing:.04em}.bag-list{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}.bag-item{display:flex;align-items:center;gap:12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:12px 14px;background:var(--color-surface);cursor:pointer;transition:border-color .15s ease,background .15s ease;font-size:14.5px}.bag-item:hover{border-color:#2563eb73;background:#2563eb08}.bag-item:has(input:checked){border-color:#05966966;background:#0596690d}.bag-item:has(input:checked) span{color:var(--color-text-secondary);text-decoration:line-through}.bag-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-success);cursor:pointer}.family-score-label{margin-left:8px}.guide-tab{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-weight:600;font-size:13px;border-radius:999px;padding:8px 14px;cursor:pointer;min-height:40px;transition:all .15s ease}.guide-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.guide-tab-active,.guide-tab-active:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 3px 10px #2563eb4d}.form{display:grid;gap:10px}.form label{font-size:13px;font-weight:600;color:var(--color-text-secondary);margin-bottom:-4px}input,select,button{font:inherit}input,select{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:11px 14px;background:#fbfcfe;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26;background:#fff}.btn-primary{margin-top:6px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:600;padding:11px 18px;cursor:pointer;min-height:42px;box-shadow:0 3px 10px #2563eb4d;transition:transform .12s ease,box-shadow .15s ease,opacity .15s ease}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #2563eb66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.btn-danger{min-height:40px;padding:9px 14px;border:1px solid rgba(220,38,38,.3);border-radius:var(--radius-sm);background:#dc26260f;color:var(--color-danger);font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:#fff}.summary-list{margin:0 0 12px;padding:0;list-style:none;display:grid;gap:8px}.summary-list li{padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:#fbfcfe;font-size:14px}.muted{color:var(--color-text-secondary);font-size:13.5px}.task-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.task-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:14px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);transition:border-color .15s ease,box-shadow .15s ease}.task-item:hover{border-color:#2563eb59;box-shadow:var(--shadow-sm)}.task-title{font-weight:600;margin-bottom:6px}.task-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.status-select{min-width:130px}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11.5px;font-weight:700;letter-spacing:.02em}.badge-todo{background:#d9770621;color:var(--color-warning)}.badge-in_progress{background:#2563eb21;color:var(--color-primary)}.badge-done{background:#05966921;color:var(--color-success)}.toast{position:fixed;right:20px;bottom:20px;background:#0f172a;color:#fff;border-radius:var(--radius-md);padding:13px 18px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(14px);transition:opacity .18s ease,transform .18s ease;pointer-events:none;max-width:340px;z-index:50}.toast-visible{opacity:1;transform:translateY(0)}.disabled-form{opacity:.55;pointer-events:none}@media(max-width:860px){.layout{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;white-space:nowrap}.task-item{flex-direction:column;align-items:flex-start}h1{font-size:22px}}.topbar-actions{display:flex;align-items:center;gap:10px}.lang-toggle{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-weight:700;font-size:12px;letter-spacing:.05em;border-radius:999px;padding:8px 14px;cursor:pointer;box-shadow:var(--shadow-sm);transition:color .15s ease,border-color .15s ease}.lang-toggle:hover{color:var(--color-primary);border-color:var(--color-primary)}.btn-small{margin-top:0;min-height:34px;padding:7px 14px;font-size:13px}.rec-done{opacity:.75;background:#0596690a;border-color:#0596694d}.rec-done .task-title{text-decoration:line-through;color:var(--color-text-secondary)}.score-breakdown{margin:4px 0 12px;display:grid;gap:10px}.breakdown-heading{font-weight:600;margin-bottom:2px}.breakdown-row{display:grid;gap:5px}.breakdown-label{display:flex;justify-content:space-between;align-items:baseline;font-size:13px}.progress-track.slim{height:8px}
