:root{--bg:#eef6f7;--bg-2:#dceff2;--surface:#fff;--surface-soft:#f7fbfc;--surface-strong:#e8f5f7;--text:#122a33;--muted:#5d737b;--line:#d5e6ea;--primary:#0b5d7a;--primary-strong:#084c63;--primary-soft:#e2f3f7;--accent:#1f9d8a;--accent-soft:#dcf7f2;--danger:#b42318;--danger-soft:#fff0ed;--shadow:0 24px 70px #0a354524;--radius-lg:28px;--radius-md:18px;--radius-sm:12px;color:var(--text);background:var(--bg);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:radial-gradient(circle at top left, #1f9d8a38, transparent 34rem), radial-gradient(circle at 85% 15%, #0b5d7a2e, transparent 28rem), linear-gradient(135deg, var(--bg), var(--bg-2));min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}.app-shell{grid-template-columns:360px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:linear-gradient(180deg, #084c63fa, #052c3afa), var(--primary-strong);color:#fff;height:100vh;padding:28px;position:sticky;top:0;overflow-y:auto}.brand{align-items:center;gap:14px;margin-bottom:28px;display:flex}.brand-mark{width:46px;height:46px;color:var(--primary-strong);background:linear-gradient(135deg,#fff,#bcebe3);border-radius:16px;place-items:center;font-weight:900;display:grid;box-shadow:0 12px 30px #0000002e}.brand strong{letter-spacing:-.02em;display:block}.brand span{color:#ffffffb8;margin-top:2px;font-size:.88rem;display:block}.sidebar-panel{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff14;border:1px solid #ffffff24;border-radius:24px;padding:20px}.metric-label{color:#ffffffb8;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem}.progress-number{letter-spacing:-.04em;margin:8px 0 12px;font-size:1.6rem;font-weight:800}.progress-track{background:#ffffff24;border-radius:999px;height:9px;overflow:hidden}.progress-fill{border-radius:inherit;background:linear-gradient(90deg,#87f2df,#fff);height:100%;transition:width .22s}.step-list{gap:10px;margin:28px 0;display:grid}.step-item{color:#ffffffb8;border-radius:16px;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:12px;padding:10px 12px;transition:all .15s;display:grid}.step-item span{background:#ffffff1a;border-radius:12px;place-items:center;width:34px;height:34px;font-size:.9rem;font-weight:800;display:grid}.step-item p{margin:0;font-size:.91rem;line-height:1.25}.step-item--current{color:#fff;background:#ffffff1f}.step-item--done span{background:var(--accent);color:#fff}.sidebar-footer{color:#fffc;margin-top:auto;padding-top:10px}.status-line{align-items:center;gap:9px;font-size:.9rem;font-weight:650;display:flex}.status-dot{background:#ffffff80;border-radius:999px;width:10px;height:10px}.status-dot--saving{background:#ffd166;box-shadow:0 0 0 5px #ffd16629}.status-dot--saved{background:#87f2df;box-shadow:0 0 0 5px #87f2df29}.status-dot--error{background:#ffb4a8;box-shadow:0 0 0 5px #ffb4a829}.status-text{font-size:.88rem}.content{padding:36px}.hero{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px;display:flex}.hero-kicker{color:var(--primary);text-transform:uppercase;letter-spacing:.14em;margin:0 0 10px;font-size:.82rem;font-weight:800}.hero h1{letter-spacing:-.03em;max-width:880px;margin:0;font-size:clamp(1.35rem,1.8vw,2rem);line-height:1.2}.hero p{max-width:760px;color:var(--muted);margin:10px 0 0;font-size:.92rem;line-height:1.6}.hero-actions{display:none}.form-card,.completion-panel{border-radius:var(--radius-lg);max-width:1100px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd1;border:1px solid #ffffffbd}.form-card{padding:32px}.page-heading{border-bottom:1px solid var(--line);padding-bottom:24px}.eyebrow{background:var(--accent-soft);color:#087967;text-transform:uppercase;letter-spacing:.08em;border-radius:999px;align-items:center;margin-bottom:12px;padding:6px 10px;font-size:.78rem;font-weight:800;display:inline-flex}.page-heading h2{letter-spacing:-.025em;margin:0;font-size:clamp(1.2rem,1.6vw,1.65rem)}.page-heading p{max-width:820px;color:var(--muted);margin:10px 0 0;line-height:1.6}.privacy-note{color:#234a50;background:linear-gradient(135deg,#edfbf8,#f8ffff);border:1px solid #bde5df;border-radius:18px;margin:22px 0;padding:16px 18px;line-height:1.55}.form-error{background:var(--danger-soft);color:var(--danger);border:1px solid #b4231838;border-radius:18px;margin:0 0 18px;padding:14px 18px;font-size:.95rem;line-height:1.5}.question-list{gap:20px;display:grid}.question-block{border:1px solid var(--line);background:var(--surface);border-radius:22px;padding:22px}.question-title-row{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:6px;display:flex}.question-title-row h3{letter-spacing:-.01em;margin:0;font-size:.97rem}.required-pill{background:var(--danger-soft);color:var(--danger);border-radius:999px;flex:none;padding:4px 9px;font-size:.75rem;font-weight:800}.question-description{color:var(--muted);margin:0 0 14px;line-height:1.55}.text-input{border:1px solid var(--line);width:100%;color:var(--text);background:#fbfeff;border-radius:16px;outline:none;padding:14px 16px;transition:all .14s}.text-input:focus{border-color:#0b5d7a85;box-shadow:0 0 0 4px #0b5d7a17}.textarea{resize:vertical;min-height:128px}.option-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px;display:grid}.choice-card{border:1px solid var(--line);background:#fbfeff;border-radius:16px;align-items:flex-start;gap:10px;min-height:54px;padding:14px;transition:all .14s;display:flex}.choice-card input{accent-color:var(--primary);margin-top:2px}.choice-card span{line-height:1.35}.choice-card--selected{background:var(--primary-soft);border-color:#0b5d7a73;box-shadow:inset 0 0 0 1px #0b5d7a29}.choice-card--disabled{opacity:.5}.selection-hint{color:var(--muted);margin-bottom:10px;font-size:.9rem}.scale-wrap{gap:12px;display:grid}.scale-labels{color:var(--muted);justify-content:space-between;gap:16px;font-size:.9rem;display:flex}.scale-options{grid-template-columns:repeat(5,minmax(44px,1fr));gap:10px;display:grid}.scale-button,.mini-scale-button{border:1px solid var(--line);color:var(--text);background:#fbfeff;border-radius:14px;font-weight:800;transition:all .14s}.scale-button{min-height:48px}.scale-button--selected,.mini-scale-button--selected{border-color:var(--primary);background:var(--primary);color:#fff}.matrix-shell{border:1px solid var(--line);border-radius:18px;width:100%;overflow-x:auto}.matrix-table{border-collapse:collapse;background:#fff;width:100%;min-width:760px}.matrix-table th,.matrix-table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;padding:13px 12px}.matrix-table th{background:var(--surface-strong);color:#264a52;font-size:.84rem;position:sticky;top:0}.matrix-table th:not(:first-child),.matrix-table td:not(:first-child){text-align:center}.matrix-table tr:last-child td{border-bottom:none}.matrix-radio{place-items:center;display:inline-grid}.matrix-radio input{width:18px;height:18px;accent-color:var(--primary)}.matrix-radio span{clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.score-table{min-width:980px}.mini-scale{gap:4px;display:inline-flex}.mini-scale-button{width:30px;height:30px;padding:0;font-size:.8rem}.form-actions{border-top:1px solid var(--line);align-items:center;gap:14px;margin-top:28px;padding-top:24px;display:flex}.action-spacer{flex:1}.primary-button,.secondary-button,.ghost-button{border:0;border-radius:14px;padding:13px 18px;font-weight:800;transition:all .14s}.primary-button{background:linear-gradient(135deg, var(--primary), var(--accent));color:#fff;box-shadow:0 16px 36px #0b5d7a40}.primary-button:hover{transform:translateY(-1px);box-shadow:0 18px 42px #0b5d7a4d}.secondary-button,.ghost-button{border:1px solid var(--line);color:var(--primary-strong);background:#ffffffb8}.ghost-button.danger{color:var(--danger)}.muted{color:#ffffffb3}.small{font-size:.82rem;line-height:1.4}.completion-panel{text-align:center;place-items:center;padding:60px 32px;display:grid}.success-icon{background:linear-gradient(135deg, var(--accent), #74e3d1);color:#fff;border-radius:26px;place-items:center;width:74px;height:74px;margin-bottom:18px;font-size:2rem;font-weight:900;display:grid;box-shadow:0 16px 42px #1f9d8a47}.completion-panel h2{letter-spacing:-.02em;margin:0;font-size:1.45rem}.completion-panel p{max-width:620px;color:var(--muted);line-height:1.65}.submission-id-box{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-soft);flex-direction:column;align-items:center;gap:6px;margin:4px 0 8px;padding:14px 24px;display:flex}.submission-id-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.75rem;font-weight:700}.submission-id-value{color:var(--primary);word-break:break-all;-webkit-user-select:all;user-select:all;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88rem}.completion-note{color:var(--muted);font-size:.9rem}.reset-button{margin-top:8px}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;position:static}.step-list{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}.content{padding:24px}.hero{flex-direction:column}.hero-actions{justify-content:flex-start}}@media (width<=640px){.sidebar,.content,.form-card{padding:18px}.question-block{padding:16px}.form-actions{flex-direction:column;align-items:stretch}.action-spacer{display:none}.option-grid{grid-template-columns:1fr}.scale-labels{flex-direction:column;gap:4px}}
