:root{--text:#5c6470;--text-h:#152033;--bg:#eef4fa;--border:#b4c6dc73;--code-bg:#f7fafdfa;--civic-blue:#1a4d8f;--civic-blue-soft:#1a4d8f1a;--civic-gold:#c9a227;--civic-gold-soft:#c9a22724;--surface-glass:#ffffffd1;--sans:"Plus Jakarta Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--heading:"Plus Jakarta Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"SFMono-Regular", ui-monospace, Consolas, monospace;color:var(--text);background:var(--bg);font:18px/1.6 var(--sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100dvh;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);background:radial-gradient(circle at 0 0,#d6e6f8e6,#0000 32%),radial-gradient(circle at 85% 12%,#fff4dc8c,#0000 22%),radial-gradient(circle at 100% 100%,#c4dceca6,#0000 28%),linear-gradient(#f3f8fc 0%,#eef4fa 52%,#e9f0f7 100%);margin:0}#root{min-height:100vh}h1,h2{color:var(--text-h);font-family:var(--heading);margin:0;line-height:1.1}h1{letter-spacing:-.06em;font-size:clamp(2.8rem,5vw,4.9rem)}h2{letter-spacing:-.03em;font-size:clamp(1.6rem,2.4vw,2.25rem)}p{margin:0}a{color:inherit}code{background:var(--code-bg);color:var(--text-h);font-family:var(--mono);border-radius:.5rem;padding:.15rem .42rem;font-size:.92em}.skip-link{z-index:100;background:var(--civic-blue);color:#fff;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:700;text-decoration:none;position:absolute;top:-48px;left:16px}.skip-link:focus{top:16px}.app-shell{flex-direction:column;gap:16px;width:min(1180px,100% - 40px);min-height:100vh;margin:0 auto;padding:14px 0 22px;display:flex}.topbar{justify-content:space-between;align-items:center;padding:6px 4px;display:flex}.brand{align-items:center;gap:14px;display:flex}.brand strong{color:#201520;font-size:15px;display:block}.brand-overline{color:var(--civic-blue);letter-spacing:.18em;text-transform:uppercase;margin-bottom:3px;font-size:10px;font-weight:800;display:block}.brand-logo{border-radius:12px;width:36px;height:36px;box-shadow:0 8px 24px #5c4c7024}.ghost-link{color:#5c4560;font-size:14px;font-weight:600;text-decoration:none}.topbar-mascot{background:#ffffffdb;border:1px solid #d4ccd3cc;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;padding:6px;display:flex}.chat-shell{background:var(--surface-glass);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid #b4c6dc8c;border-radius:24px;box-shadow:0 24px 80px #15305214}.chat-toolbar{justify-content:flex-end;padding-bottom:4px;display:flex}.primary-action,.feedback-button{cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:0 20px;font-size:15px;font-weight:700;text-decoration:none;transition:transform .16s,box-shadow .16s,opacity .16s;display:inline-flex}.primary-action{color:#fff;background:linear-gradient(135deg,#123f75 0%,#1a5ea8 100%);box-shadow:0 16px 28px #123f7538}.feedback-button{color:#4f4555;background:#ffffffe6;border:1px solid #c9bdc6cc}.primary-action:hover,.feedback-button:hover{transform:translateY(-1px)}.primary-action:disabled,.feedback-button:disabled{cursor:not-allowed;opacity:.6}.citation-list{margin:0;padding:0;list-style:none}.sidebar-card{text-align:left;background:radial-gradient(circle at 0 0,#fffdfff2,#faf1f6d9),linear-gradient(#f5edf2 0%,#f7f2f5 100%);width:100%;padding:18px 18px 20px}.sidebar-card-header,.section-kicker{align-items:center;gap:8px;display:flex}.section-kicker{color:#7f5d72;letter-spacing:.12em;text-transform:uppercase;background:#fcf4f8f5;border-radius:999px;margin-bottom:10px;padding:7px 12px;font-size:11px;font-weight:700;display:inline-flex}.hero-card-title{color:#554a59;margin-left:8px;font-size:14px;font-weight:700}.signal{border-radius:999px;width:10px;height:10px}.signal-pink{background:#e5a8c2}.signal-cream{background:#f0d0aa}.signal-red{background:#8fc9d7}.torogoz-video-shell{justify-items:center;gap:10px;width:100%;max-width:280px;margin:0 auto;display:grid}.torogoz-video-frame{aspect-ratio:1;background:radial-gradient(circle at top,#ffffffe6,#f7eff5b8),linear-gradient(#ffffffeb,#f7f1f7e0);border:1px solid #d9ced6c7;border-radius:28px;width:min(100%,240px);position:relative;overflow:hidden;box-shadow:0 20px 50px #5c4c7024}.torogoz-video{object-fit:cover;width:100%;height:100%;display:block}.torogoz-video-label{color:#746879;letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.torogoz-compact{max-width:60px}.torogoz-compact .torogoz-video-frame{border-radius:18px;width:60px;box-shadow:0 10px 24px #5c4c701a}.torogoz-subtle{opacity:.92;max-width:220px}.torogoz-subtle .torogoz-video-frame{border-radius:30px;width:min(100%,200px)}.mascot-status{color:#5a5060;background:#ffffffeb;border-radius:999px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;font-weight:700;display:inline-flex}.status-dot{border-radius:999px;width:11px;height:11px}.status-idle{background:#7fcad4}.status-thinking{background:#f7bb58}.status-answer{background:#7b8ef4}.status-warning{background:#f18989}.mascot-caption{color:#655768;margin-top:16px;font-size:15px}.chat-shell{flex:auto;grid-template-rows:auto minmax(0,1fr) auto auto auto;gap:10px;min-height:calc(100dvh - 120px);padding:16px 18px 14px;display:grid}.chat-shell-active{align-content:start}.app-footer{text-align:center;padding:8px 12px 0}.app-footer p{color:#8a7f8f;margin:0;font-size:13px;line-height:1.5}.prompt-suggestions{flex-wrap:wrap;justify-content:flex-start;gap:10px;max-width:760px;display:flex}.prompt-chip{color:#4f4555;cursor:pointer;background:#ffffffeb;border:1px solid #d0c8cee6;border-radius:999px;justify-content:center;align-items:center;padding:10px 14px;font-size:14px;font-weight:600;transition:transform .16s,box-shadow .16s,border-color .16s;display:inline-flex}.prompt-chip:hover:not(:disabled){background:#fff;border-color:#1a4d8f59;transform:translateY(-1px);box-shadow:0 10px 24px #15305214}.prompt-chip:disabled{cursor:not-allowed;opacity:.6}.ghost-button{color:#5c4560;cursor:pointer;background:#ffffffeb;border:1px solid #d4ccd3f2;border-radius:999px;flex-shrink:0;padding:8px 14px;font-size:13px;font-weight:600}.ghost-button:hover:not(:disabled){background:#fff;border-color:#c9b8c8}.ghost-button:disabled{opacity:.55;cursor:not-allowed}.response-institution{color:#7a6880;font-weight:600}.chat-thread{scroll-behavior:smooth;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;gap:14px;min-height:0;padding:4px 2px 8px 0;display:grid;overflow:auto}.chat-bubble{text-align:left;border-radius:22px;gap:10px;max-width:88%;padding:16px 18px;display:grid}.chat-bubble-user{color:#f7fbff;background:linear-gradient(135deg,#123f75 0%,#1a5ea8 100%);justify-self:end}.chat-bubble-assistant{background:#fffffff5;border:1px solid #dcd6dce0;justify-self:start}.chat-bubble-assistant.status-grounded{border-color:#7b8ef459}.chat-bubble-assistant.status-handoff{background:#fffcf7fa;border-color:#d6a46273}.chat-bubble-assistant.status-clarify{border-color:#7fcad473}.chat-bubble.is-pending{border-style:dashed}.chat-bubble-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.copy-button{color:#6d6572;cursor:pointer;background:#ffffffeb;border:1px solid #c9bdc6cc;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.copy-button:hover{color:#4f4555;border-color:#b9a8b8}.chat-role{text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700}.response-meta{gap:8px;display:grid}.response-status{border-radius:999px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:700;display:inline-flex}.response-status.status-grounded{color:#4a5f9f;background:#7b8ef41f}.response-status.status-handoff{color:#8a5d1e;background:#d6a46229}.response-status.status-clarify{color:#3d7280;background:#7fcad429}.response-status.status-neutral{color:#6d6572;background:#f8f7f9f5}.citation-list{gap:8px;display:grid}.citation-list li{background:#f8f7f9f5;border:1px solid #e1dae0e6;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:12px 14px;display:flex}.citation-copy{gap:2px;min-width:0;display:grid}.citation-source{color:#4f4555;font-size:14px;font-weight:700}.citation-page{color:#7a7080;font-size:13px}.citation-link{color:var(--civic-blue);flex-shrink:0;align-items:center;gap:4px;font-size:13px;font-weight:700;text-decoration:none;display:inline-flex}.citation-link-icon{font-size:12px;line-height:1}.citation-link:hover{text-decoration:underline}.citation-link:focus-visible{outline-offset:3px;border-radius:6px;outline:2px solid #1a4d8f73}.citation-origin{opacity:.78;font-size:12px}.follow-up-suggestions{margin-top:4px}.chat-form{gap:12px;padding-top:6px;display:grid}.chat-form-sticky{z-index:2;background:linear-gradient(#fffdff00,#fffdfff0 24%);padding-top:10px;position:sticky;bottom:0}.chat-form textarea{resize:vertical;width:100%;min-height:74px;max-height:180px;color:var(--text-h);font-size:16px;font:inherit;box-sizing:border-box;background:#fffffff5;border:1px solid #d4ccd3eb;border-radius:28px;padding:16px 18px;box-shadow:inset 0 1px #fffc}.chat-form textarea:focus-visible{outline-offset:2px;outline:2px solid #547f9a59}.chat-form-row,.feedback-row,.feedback-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.chat-form-row{justify-content:flex-end}.disclaimer,.feedback-confirmation{color:#736974;font-size:14px}.disclaimer{margin-right:auto}.chat-message-text{white-space:pre-wrap}.formatted-message{gap:10px;display:grid}.formatted-paragraph,.formatted-mixed p,.formatted-step{margin:0;line-height:1.55}.formatted-list{gap:8px;margin:0;padding-left:1.2rem;display:grid}.formatted-list li{line-height:1.5}.formatted-step{padding-left:.2rem}.pending-copy{align-items:center;gap:10px;margin:0;display:inline-flex}.typing-indicator{align-items:center;gap:4px;display:inline-flex}.typing-indicator span{background:#9a8aa8;border-radius:999px;width:7px;height:7px;animation:1.2s ease-in-out infinite typing-bounce}.typing-indicator span:nth-child(2){animation-delay:.15s}.typing-indicator span:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%,80%,to{opacity:.45;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.escalation-card{background:#fff8f0f2;border:1px solid #d6a46259;border-radius:16px;margin-top:12px;padding:12px 14px}.escalation-card ul{gap:8px;margin:8px 0 0;padding:0;list-style:none;display:grid}.escalation-card li{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.escalation-card a{color:#8a5d1e;font-size:13px;font-weight:700;text-decoration:none}.escalation-card a:hover{text-decoration:underline}.negative-feedback-panel{gap:10px;margin-top:12px;display:grid}.negative-feedback-panel label{color:#5f5664;font-size:14px}.negative-feedback-panel textarea{resize:vertical;border:1px solid #c9bdc6cc;border-radius:16px;width:100%;padding:12px 14px}.honeypot-field{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute;left:-10000px}.error-banner{color:#7f4450;background:#fff0f0f0;border-radius:16px;margin:0;padding:12px 14px;font-size:14px;font-weight:700}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1100px){.topbar-mascot{display:none}.chat-bubble{max-width:100%}}@media (width<=720px){.app-shell{width:min(100% - 20px,1240px);padding:calc(12px + env(safe-area-inset-top,0)) 0 calc(14px + env(safe-area-inset-bottom,0))}.sidebar-card,.chat-shell,.topbar{padding:16px}.chat-shell{min-height:calc(100dvh - 96px);padding-bottom:calc(10px + env(safe-area-inset-bottom,0))}.chat-form-sticky{bottom:env(safe-area-inset-bottom,0);padding-bottom:calc(8px + env(safe-area-inset-bottom,0))}.chat-form textarea,.negative-feedback-panel textarea{font-size:16px}.chat-bubble{max-width:100%}.chat-form-row,.feedback-row{flex-direction:column;align-items:stretch}.feedback-actions{justify-content:stretch;width:100%}.feedback-button,.primary-action{width:100%;min-height:44px}.topbar{flex-direction:column;align-items:flex-start;gap:12px;padding-left:0;padding-right:0}.prompt-suggestions{justify-content:stretch}.prompt-chip{justify-content:flex-start;width:100%;min-height:44px}.citation-list li{flex-direction:column;align-items:flex-start}.citation-link{word-break:break-word;min-height:44px}.disclaimer{margin-right:0;font-size:13px;line-height:1.45}}
