@import"https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&family=Sora:wght@300;400;500;600;700&display=swap";:root{--bg-base: #f6f0e7;--bg-accent: #d8efe8;--ink: #173437;--ink-muted: #4a6366;--panel: rgba(255, 255, 255, .88);--panel-border: rgba(23, 52, 55, .16);--teal: #0d7a6a;--teal-dark: #095b4f;--orange: #e16b2f;--orange-dark: #983f17;--danger: #a81c2a;--shadow-soft: 0 18px 40px rgba(21, 40, 43, .14)}*{box-sizing:border-box}button,select,input{font:inherit}html,body,#app{width:100%;min-height:100%}body{margin:0;color:var(--ink);font-family:Sora,Trebuchet MS,sans-serif;background:radial-gradient(circle at 12% 18%,rgba(225,107,47,.18),transparent 28%),radial-gradient(circle at 86% 10%,rgba(13,122,106,.22),transparent 32%),radial-gradient(circle at 90% 85%,rgba(18,81,93,.12),transparent 30%),linear-gradient(160deg,var(--bg-base),var(--bg-accent))}.page-shell{width:min(1180px,92vw);margin:0 auto;padding:2.2rem 0 3rem}.headline{text-align:center;margin-bottom:1.4rem}.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-size:.75rem;color:var(--teal-dark);margin-bottom:.6rem}h1,h2,h3,h4{margin:0;font-family:Fraunces,Georgia,serif}h1{font-size:clamp(1.7rem,2.8vw,2.7rem);color:#102c2f}h2{font-size:clamp(1.35rem,2.1vw,2rem);color:#13383c}h3{font-size:1.1rem}.subtitle{margin:.6rem auto 0;max-width:68ch;color:var(--ink-muted)}.panel{background:var(--panel);border:1px solid var(--panel-border);border-radius:1.35rem;box-shadow:var(--shadow-soft);padding:clamp(1rem,2.4vw,2rem);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.panel.loading{opacity:.85}.error-banner{margin:0 0 .9rem;padding:.75rem .9rem;border-radius:.8rem;border:1px solid rgba(168,28,42,.25);background:#a81c2a14;color:var(--danger);font-weight:600}.info-banner{margin:0 0 .9rem;padding:.75rem .9rem;border-radius:.8rem;border:1px solid rgba(13,122,106,.24);background:#0d7a6a14;color:#0c5f53;font-weight:600}.stacked-section{display:grid;gap:1rem}.section-intro{display:grid;gap:.5rem}.section-intro p{margin:0;color:var(--ink-muted);line-height:1.55}.step-kicker{margin:0;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;color:var(--teal-dark);font-weight:700}.meta-strip{display:grid;gap:.85rem;grid-template-columns:repeat(3,minmax(0,1fr))}.meta-pill{display:grid;gap:.22rem;padding:.9rem 1rem;border-radius:.95rem;border:1px solid rgba(23,52,55,.12);background:#ffffffc2}.meta-pill strong{font-size:.84rem;color:#184145}.meta-pill span{color:var(--ink-muted);line-height:1.45}.instruction-box{border:1px solid rgba(13,122,106,.22);background:#0d7a6a0d;border-radius:.9rem;padding:.9rem 1rem}.instruction-box p{margin:0;color:#214144;line-height:1.55}.instruction-box p+p{margin-top:.7rem}.consent-list{margin:.55rem 0 .8rem;padding-left:1.2rem;color:#214144;line-height:1.5}.consent-list li+li{margin-top:.34rem}.checkbox-row{display:flex;align-items:center;gap:.65rem;font-weight:600}.form-card{border:1px solid rgba(23,52,55,.14);border-radius:1rem;background:#ffffffeb;padding:1rem;display:grid;gap:.9rem}.form-card>p{margin:0;color:var(--ink-muted);line-height:1.5}.form-grid{display:grid;gap:.9rem;grid-template-columns:repeat(2,minmax(0,1fr))}label{display:grid;gap:.35rem;color:#1f3b3f;font-size:.95rem;font-weight:500}select,input[type=checkbox],input[type=radio]{accent-color:var(--teal)}select{width:100%;border:1px solid rgba(23,52,55,.25);border-radius:.65rem;padding:.52rem .65rem;font-family:inherit;background:#fff;color:#122d31}select:invalid{color:#667e80}.matrix-heading{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;flex-wrap:wrap}.matrix-heading p{margin:.35rem 0 0;color:var(--ink-muted);line-height:1.5}.matrix-scale-hint{margin:0;padding:.55rem .75rem;border-radius:999px;background:#e16b2f1a;border:1px solid rgba(225,107,47,.2);color:#91502d;font-size:.88rem;font-weight:600}.matrix-scroll{overflow-x:auto;border:1px solid rgba(23,52,55,.12);border-radius:1rem;background:#fff}.likert-table{width:max(100%,920px);border-collapse:collapse}.likert-table thead th{background:#d8efe8ad;color:#173437;font-weight:700;text-align:center;padding:.85rem .75rem;border-bottom:1px solid rgba(23,52,55,.12)}.likert-table thead th:first-child{text-align:left;position:sticky;left:0;z-index:2}.likert-table thead th span,.likert-table thead th small{display:block}.likert-table thead th small{margin-top:.15rem;font-size:.74rem;font-weight:500;color:#507175}.likert-table tbody tr:nth-child(2n){background:#f6fcfa99}.likert-table tbody th,.likert-table tbody td{padding:.85rem .75rem;border-bottom:1px solid rgba(23,52,55,.08);vertical-align:top}.likert-table tbody th{min-width:280px;text-align:left;position:sticky;left:0;z-index:1;background:inherit}.factor-label,.factor-help{display:block}.factor-label{color:#173437;font-weight:700}.factor-help{margin-top:.2rem;color:#5a7578;font-size:.82rem;line-height:1.45;font-weight:400}.matrix-choice{display:grid;justify-items:center;gap:.35rem;min-width:54px}.matrix-choice input{margin:0}.matrix-choice span{font-size:.83rem;font-weight:700;color:#173437}.footnote{color:#2e4d51;font-size:.93rem;padding:.75rem .85rem;border-radius:.75rem;background:#e16b2f1a;border:1px solid rgba(225,107,47,.26)}.helper-text{margin:0;color:#476467;font-size:.92rem}.action-row{display:flex;justify-content:space-between;align-items:center;gap:.8rem;flex-wrap:wrap}.action-btn,.choice-btn,.secondary-btn{border:none;border-radius:999px;padding:.74rem 1.25rem;cursor:pointer;font-weight:600;transition:transform .22s ease,opacity .22s ease,box-shadow .22s ease}.action-btn{justify-self:start;background:linear-gradient(135deg,var(--teal),#0f8c78);color:#f7fffd;box-shadow:0 10px 26px #0d7a6a47}.secondary-btn{background:#1734370f;color:#173437;border:1px solid rgba(23,52,55,.14)}.choice-btn{margin-top:auto;background:linear-gradient(130deg,var(--orange),#e9873e);color:#fff9f6;box-shadow:0 10px 20px #e16b2f3d}.action-btn:hover,.choice-btn:hover,.secondary-btn:hover{transform:translateY(-2px)}.action-btn:disabled,.choice-btn:disabled,.secondary-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.comparison-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap}.instruction-text{color:var(--ink-muted);margin:0;line-height:1.5}.swipe-hint{display:none;margin:0;text-align:center;font-size:.85rem;font-weight:600;color:var(--teal-dark);padding:.55rem .9rem;border-radius:999px;background:#0d7a6a14;border:1px solid rgba(13,122,106,.2)}.swipe-hint-arrow{font-size:1rem}@media(hover:none)and (pointer:coarse){.swipe-hint{display:block}}.comparison-grid{display:grid;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr));touch-action:pan-y}.project-card{border:1px solid rgba(23,52,55,.17);border-radius:1rem;background:#fffffff5;padding:1rem;display:grid;gap:.85rem;min-height:320px;animation:rise-in .36s ease}.project-card p{margin:0;color:#204245;line-height:1.45}.summary-grid{display:grid;gap:1rem;grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card{border:1px solid rgba(23,52,55,.14);border-radius:1rem;background:#fffffff0;padding:1rem;display:grid;gap:.7rem}.summary-card p{margin:0;color:var(--ink-muted);line-height:1.5}.factor-summary-list{margin:0;padding:0;list-style:none;display:grid;gap:.65rem}.factor-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.factor-summary-list li{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:.72rem .8rem;border-radius:.85rem;border:1px solid rgba(23,52,55,.1);background:#f6fcfaeb}.factor-summary-list span{color:#173437}.factor-summary-list strong{color:#0d675a;white-space:nowrap}.factor-meta{display:block;margin-top:.22rem;color:#557173;font-size:.8rem;line-height:1.35}.confidence-line{font-weight:700}.confidence-high{color:#0f5f53}.confidence-medium{color:#8a5c2a}.confidence-low,.confidence-limited{color:#7a4e50}.factor-score-stack{display:grid;justify-items:end;gap:.28rem}.direction-chip{display:inline-block;font-size:.76rem;font-weight:700;line-height:1.2;padding:.2rem .5rem;border-radius:999px;border:1px solid transparent;white-space:nowrap}.direction-positive{color:#0f5f53;background:#0d7a6a24;border-color:#0d7a6a4d}.direction-negative{color:#92472a;background:#e16b2f26;border-color:#e16b2f4d}.direction-mixed{color:#4a6467;background:#4a64671f;border-color:#4a64673d}.direction-uncertain{opacity:.5;filter:saturate(.55)}.ess-line{color:#52737a}.ess-medium{color:#92620a}.ess-low{color:#b91c1c;font-weight:600}.model-note{margin:.85rem 0 0;color:#315154;line-height:1.5}.charts-grid{display:grid;gap:1rem;grid-template-columns:1fr}.chart-card{border:1px solid rgba(23,52,55,.16);border-radius:.95rem;background:#fff;padding:.9rem;display:grid;gap:.65rem;overflow:hidden}.radar-frame{position:relative;width:100%;height:clamp(300px,52vh,520px);max-height:520px}.radar-frame canvas{display:block;width:100%!important;height:100%!important}.top-projects{border:1px solid rgba(23,52,55,.16);border-radius:.95rem;padding:.9rem;background:#fffffff5}.results-supporting-text{margin:.35rem 0 0;color:var(--ink-muted);line-height:1.5}.top-projects ul{margin:.8rem 0 0;padding:0;list-style:none;display:grid;gap:.8rem}.top-projects li{border:1px solid rgba(23,52,55,.12);border-radius:.8rem;padding:.75rem;background:#f6fcfaf0}.project-title{display:flex;gap:.6rem;align-items:baseline;flex-wrap:wrap;color:#123336;margin-bottom:.35rem}.top-projects p{margin:0;color:#325255;font-size:.92rem;line-height:1.4}.expand-btn{margin-top:.45rem;border:1px solid rgba(13,122,106,.36);border-radius:999px;background:#0d7a6a14;color:#0d675a;font-family:inherit;font-size:.82rem;font-weight:600;padding:.3rem .7rem;cursor:pointer}.expand-btn:hover{background:#0d7a6a24}.fade-up{animation:fade-up .52s ease}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes rise-in{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:940px){.form-grid,.summary-grid,.comparison-grid,.factor-columns,.meta-strip{grid-template-columns:1fr}.action-row{flex-direction:column-reverse;align-items:stretch}.action-btn{width:100%;justify-self:stretch}.secondary-btn{width:100%}.project-card{min-height:unset}.radar-frame{height:clamp(260px,46vh,420px)}}@media(max-width:760px){.page-shell{width:100%;padding:1.5rem .9rem 2.5rem}.likert-table{width:820px}.likert-table tbody th,.likert-table thead th:first-child{min-width:240px}}.mobile-likert{display:none}.likert-card{border:1px solid rgba(23,52,55,.14);border-radius:.95rem;background:#fffffff5;padding:.9rem;display:grid;gap:.7rem;transition:border-color .2s ease}.likert-card--answered{border-color:#0d7a6a66;background:#ecf9f5cc}.likert-card-header{display:grid;gap:.2rem}.likert-btn-row{display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem}.likert-tap-btn{border:1.5px solid rgba(23,52,55,.18);border-radius:.65rem;background:#fff;color:#173437;cursor:pointer;padding:.6rem .25rem;display:flex;flex-direction:column;align-items:center;gap:.2rem;min-height:60px;transition:background .16s ease,border-color .16s ease,transform .12s ease}.likert-tap-btn:active{transform:scale(.96)}.likert-tap-btn--selected{background:linear-gradient(135deg,var(--teal),#0f8c78);border-color:var(--teal-dark);color:#f0faf8}.likert-tap-num{font-size:1.1rem;font-weight:700;line-height:1}.likert-tap-label{font-size:.62rem;font-weight:500;text-align:center;line-height:1.2;opacity:.85}@media(max-width:640px){.matrix-heading{flex-direction:column;align-items:stretch;gap:.65rem}.matrix-scale-hint{align-self:flex-start}.choice-btn{width:100%}.action-btn,.choice-btn,.secondary-btn{padding:.9rem 1.25rem;min-height:48px}.stacked-section{gap:.85rem}.likert-table{width:680px}.likert-table tbody th,.likert-table thead th:first-child{min-width:180px}.desktop-likert{display:none}.mobile-likert{display:grid;gap:.65rem}.matrix-scale-hint{font-size:.82rem}}@media(max-width:480px){.page-shell{padding:1rem .65rem 1.5rem}.subtitle,.section-intro>p{font-size:.9rem}.factor-summary-list li{flex-direction:column;align-items:flex-start;gap:.45rem}.factor-score-stack{display:flex;flex-direction:row;align-items:center;justify-items:unset;gap:.5rem}.comparison-header{flex-direction:column;align-items:flex-start;gap:.25rem}.meta-pill{padding:.75rem .85rem}.instruction-box,.form-card{padding:.85rem}}
