:root{--bg:#f6f7f4;--panel:#fff;--text:#16201d;--muted:#65716d;--line:#dce4df;--accent:#176b5c;--accent-strong:#0e4b41;--amber:#a15d00;--red:#9d2a24;--blue:#315b8d;--coral:#b34b3e;--green-soft:#e8f4ef;--blue-soft:#edf4fb;--amber-soft:#fff2dd;--coral-soft:#faecea}*{box-sizing:border-box}html{background:var(--bg);min-height:100%}body{min-height:100%;color:var(--text);background:var(--bg);letter-spacing:0;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{border:0}:focus-visible{outline-offset:2px;outline:3px solid #176b5c57}.app-shell{grid-template-columns:248px minmax(0,1fr);min-height:100vh;display:grid}.auth-shell{grid-template-rows:auto 1fr;min-height:100vh;padding:28px;display:grid}.auth-brand{align-items:center;gap:10px;width:max-content;font-weight:780;display:inline-flex}.auth-card{grid-template-columns:minmax(0,360px) minmax(320px,420px);place-self:center;align-items:center;gap:28px;width:min(860px,100%);display:grid}.auth-copy{gap:12px;display:grid}.auth-copy h1{margin:0;font-size:32px;line-height:1.12}.auth-copy p{margin:0}.sidebar{border-right:1px solid var(--line);background:#fff;padding:22px 18px}.brand{align-items:center;gap:10px;margin-bottom:24px;font-weight:780;display:flex}.brand-mark{background:var(--accent);color:#fff;border-radius:8px;place-items:center;width:34px;height:34px;font-weight:800;display:grid}.nav{gap:6px;display:grid}.nav a{min-height:38px;color:var(--muted);border-radius:8px;align-items:center;gap:10px;padding:9px 10px;font-size:14px;display:flex}.nav a:hover,.nav a.active{color:var(--accent-strong);background:#eef5f2}.main{min-width:0}.topbar{border-bottom:1px solid var(--line);z-index:5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f6f7f4e6;justify-content:space-between;align-items:center;min-height:66px;padding:0 28px;display:flex;position:sticky;top:0}.topbar h1{margin:0;font-size:18px}.content{width:min(1180px,100%);padding:28px}.grid{gap:16px;display:grid}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.panel{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:18px}.panel h2,.panel h3{margin:0 0 10px}.section-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.section-heading h2{align-items:center;gap:8px;display:inline-flex}.muted{color:var(--muted)}.kpi{gap:8px;display:grid}.kpi strong{font-size:28px;line-height:1.1}.checklist{gap:10px;display:grid}.status-row{border-top:1px solid var(--line);grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:12px;padding-top:12px;display:grid}.status-row p,.action-panel p,.wizard-step p{margin:4px 0 0}.action-panel{grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.access-banner{background:linear-gradient(135deg, #176b5c0f, #315b8d0a), var(--panel);justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.access-banner h2,.access-banner p{margin:0}.access-banner>div{gap:8px;display:grid}.admin-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.fit{width:fit-content}.wizard-steps{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.wizard-step{border:1px solid var(--line);background:#fbfcfa;border-radius:8px;min-height:136px;padding:12px;position:relative}.step-index{width:22px;height:22px;color:var(--accent-strong);background:#e8f4ef;border-radius:999px;place-items:center;font-size:12px;font-weight:800;display:grid;position:absolute;top:10px;right:10px}.progress{background:#e9eee9;border-radius:999px;width:100%;height:9px;overflow:hidden}.progress span{border-radius:inherit;background:var(--accent);height:100%;display:block}.button{background:var(--accent);color:#fff;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:10px 14px;font-weight:700;display:inline-flex}.button.secondary{border:1px solid var(--line);color:var(--text);background:#fff}.button.warning{background:var(--amber)}.button:disabled{cursor:not-allowed;opacity:.48}.field{gap:7px;display:grid}.field label{color:var(--muted);font-size:13px}.input,.select,.textarea{border:1px solid var(--line);width:100%;color:var(--text);background:#fff;border-radius:8px;padding:10px 11px}.textarea{resize:vertical;min-height:94px}.option-row{gap:8px;display:grid}.segmented{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.segment{border:1px solid var(--line);min-height:44px;color:var(--text);cursor:pointer;background:#fff;border-radius:8px;padding:8px}.segment.active{border-color:var(--accent);color:var(--accent-strong);background:#e8f4ef;font-weight:700}.badge{min-height:24px;color:var(--accent-strong);background:#edf3f0;border-radius:999px;align-items:center;padding:3px 9px;font-size:12px;font-weight:700;display:inline-flex}.badge.red{color:var(--red);background:#faecea}.badge.amber{color:var(--amber);background:#fff2dd}.table{border-collapse:collapse;width:100%;font-size:14px}.table th,.table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:11px 8px}.table th{color:var(--muted);font-weight:700}.code{border:1px solid var(--line);color:#f4fbf7;background:#15211d;border-radius:8px;padding:14px;font-size:13px;overflow:auto}.wellness-note{border-left:4px solid var(--blue);color:#1e426f;background:#edf4fb;padding:12px 14px}.eyebrow{color:var(--accent-strong);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:800}.survey-shell,.survey-module-flow{gap:18px;display:grid}.survey-hero{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:stretch;gap:18px;display:grid}.survey-hero-copy,.survey-summary,.survey-consent,.survey-unavailable,.survey-complete,.module-focus,.question-stage,.survey-empty-state{border:1px solid var(--line);background:var(--panel);border-radius:8px}.survey-hero-copy,.survey-consent,.survey-unavailable,.survey-complete,.module-focus,.question-stage{padding:20px}.survey-hero-copy{background:linear-gradient(135deg, #176b5c14, #315b8d0d), var(--panel);align-content:center;gap:14px;min-height:240px;display:grid}.survey-hero-copy h2,.survey-consent h2,.survey-unavailable h2,.survey-complete h2,.module-focus h2,.survey-hero-copy p,.survey-consent p,.survey-unavailable p,.survey-complete p,.module-focus p{margin:0}.survey-hero-actions{flex-wrap:wrap;gap:10px;display:flex}.survey-summary{gap:13px;padding:18px;display:grid}.survey-summary>div:first-child{gap:7px;display:grid}.survey-summary strong{font-size:26px;line-height:1.1}.survey-summary-row{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding-top:12px;display:flex}.survey-summary-row span{color:var(--muted)}.survey-module-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px;display:grid}.survey-module-card{border:1px solid var(--line);background:var(--panel);border-top-width:4px;border-radius:8px;grid-template-rows:auto auto auto 1fr auto;gap:10px;min-height:214px;padding:16px;transition:border-color .16s,transform .16s,box-shadow .16s;display:grid;position:relative}.survey-module-card:hover{border-color:#176b5c6b;transform:translateY(-2px);box-shadow:0 14px 36px #16201d14}.survey-module-card h3,.survey-empty-state h3{margin:0}.survey-module-card p,.survey-empty-state p{color:var(--muted);margin:0;font-size:14px}.tone-green{border-top-color:var(--accent)}.tone-blue{border-top-color:var(--blue)}.tone-amber{border-top-color:var(--amber)}.tone-coral{border-top-color:var(--coral)}.module-icon{border-radius:8px;place-items:center;width:36px;height:36px;display:grid}.module-icon.tone-green{background:var(--green-soft);color:var(--accent-strong)}.module-icon.tone-blue{background:var(--blue-soft);color:var(--blue)}.module-icon.tone-amber{background:var(--amber-soft);color:var(--amber)}.module-icon.tone-coral{background:var(--coral-soft);color:var(--coral)}.module-status{border-radius:999px;padding:4px 9px;font-size:12px;font-weight:800;position:absolute;top:14px;right:14px}.status-not_started{color:var(--muted);background:#eef1ef}.status-in_progress{background:var(--blue-soft);color:var(--blue)}.status-completed{background:var(--green-soft);color:var(--accent-strong)}.status-refresh_due{background:var(--amber-soft);color:var(--amber)}.module-progress{gap:7px;font-size:13px;font-weight:800;display:grid}.survey-empty-state{grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:14px;padding:16px;display:grid}.survey-consent,.survey-unavailable,.survey-complete{gap:16px;display:grid}.survey-complete{align-content:center;justify-items:start;min-height:360px}.complete-mark{background:var(--green-soft);width:62px;height:62px;color:var(--accent-strong);border-radius:8px;place-items:center;display:grid}.module-focus{gap:16px;display:grid}.module-focus-heading{grid-template-columns:auto auto minmax(0,1fr);align-items:start;gap:12px;display:grid}.icon-link{border:1px solid var(--line);width:36px;height:36px;color:var(--muted);background:#fff;border-radius:8px;place-items:center;display:grid}.module-focus-progress{color:var(--muted);grid-template-columns:auto minmax(180px,1fr) auto;align-items:center;gap:12px;font-size:13px;font-weight:700;display:grid}.question-stage{gap:18px;display:grid}.question-stepper{flex-wrap:wrap;gap:7px;display:flex}.question-dot{border:1px solid var(--line);width:30px;height:30px;color:var(--muted);cursor:pointer;background:#fff;border-radius:999px;place-items:center;display:grid}.question-dot.done{background:var(--green-soft);color:var(--accent-strong);border-color:#176b5c4d}.question-dot.active{border-color:var(--accent);box-shadow:0 0 0 3px #176b5c1f}.question-card{gap:18px;min-height:300px;display:grid}.question-meta{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;font-size:13px;font-weight:800;display:flex}.question-ready{color:var(--accent-strong)}.question-pending{color:var(--amber)}.survey-question-field{gap:12px}.survey-question-field label{color:var(--text);font-size:22px;font-weight:800;line-height:1.18}.survey-number-input{max-width:280px;min-height:48px;font-size:18px;font-weight:700}.survey-options{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.survey-option{text-align:center;min-height:58px;padding:12px}.survey-text-answer{gap:10px;display:grid}.quick-options{flex-wrap:wrap;gap:8px;display:flex}.quick-option{border:1px solid var(--line);min-height:36px;color:var(--text);cursor:pointer;background:#fff;border-radius:8px;padding:7px 10px;font-weight:700}.quick-option.active{border-color:var(--accent);background:var(--green-soft);color:var(--accent-strong)}.survey-actions{z-index:4;border-top:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;justify-content:space-between;gap:12px;padding-top:14px;display:flex;position:sticky;bottom:0}.survey-actions-right{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}@media (max-width:860px){.app-shell{grid-template-columns:1fr}.auth-shell{padding:18px}.auth-card{grid-template-columns:1fr;align-self:start;padding-top:48px}.auth-copy h1{font-size:26px}.sidebar{border-right:0;border-bottom:1px solid var(--line);position:static}.nav{grid-template-columns:repeat(2,minmax(0,1fr))}.content,.topbar{padding-left:16px;padding-right:16px}.grid.two,.grid.three,.segmented,.wizard-steps,.survey-hero,.module-focus-progress,.survey-empty-state{grid-template-columns:1fr}.survey-hero-copy{min-height:auto}.survey-module-grid,.survey-options{grid-template-columns:1fr}.survey-question-field label{font-size:19px}.module-focus-heading{grid-template-columns:auto auto minmax(0,1fr)}.question-card{min-height:auto}.survey-actions{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;flex-direction:column;align-items:stretch;position:static}.survey-actions-right{justify-content:stretch}.survey-actions .button,.survey-actions-right .button,.survey-hero-actions .button{width:100%}.section-heading,.status-row,.action-panel{grid-template-columns:1fr}.section-heading{flex-direction:column}}
