:root{color:#16211c;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f6f2e9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}button,a,textarea,input{font:inherit}button,a.primary-action{color:#fdfbf4;cursor:pointer;background:#184a3a;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-weight:750;text-decoration:none;transition:transform .16s,background .16s,box-shadow .16s;display:inline-flex}button:hover,a.primary-action:hover{background:#0f3529;transform:translateY(-1px);box-shadow:0 10px 24px #16211c24}button:disabled{cursor:wait;opacity:.72}.app-shell{width:min(1180px,100% - 32px);margin:0 auto;padding:28px 0 48px}.hero-panel{color:#fdfbf4;background:linear-gradient(105deg,#0b1a16e6,#0f3429c7),url(https://images.unsplash.com/photo-1516321318423-f06f85e504b3?auto=format&fit=crop&w=1600&q=82) 50%/cover;border-radius:8px;grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);align-items:center;gap:32px;min-height:480px;padding:clamp(28px,5vw,64px);display:grid;overflow:hidden}.hero-copy{max-width:760px}.eyebrow{color:#d9a441;letter-spacing:0;text-transform:uppercase;margin:0 0 10px;font-size:.78rem;font-weight:850}h1,h2,h3,p{margin-top:0}h1{letter-spacing:0;max-width:820px;margin-bottom:18px;font-size:clamp(2.3rem,6vw,5.4rem);line-height:.96}.hero-copy>p:not(.eyebrow){color:#edf2e8;max-width:720px;font-size:1.12rem;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;margin-top:26px;display:flex}.hero-actions button{color:#16211c;background:#f4cf62}.hero-actions button:hover{background:#e8bd3d}.score-orbit{aspect-ratio:1;text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fdfbf424;border:1px solid #fdfbf44d;border-radius:50%;place-items:center;width:min(100%,310px);margin-left:auto;display:grid}.score-orbit span{font-size:clamp(4rem,10vw,7rem);font-weight:900;line-height:.9;display:block}.score-orbit small{color:#f4cf62;margin-top:10px;font-weight:800;display:block}.criteria-strip{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:18px 0;display:grid}.criteria-strip article,.panel-card,.builder-panel,.output-panel{background:#fffaf0;border:1px solid #dfd5c0;border-radius:8px;box-shadow:0 14px 40px #23312b14}.criteria-strip article{flex-direction:column;justify-content:space-between;min-height:86px;padding:16px;display:flex}.criteria-strip strong{font-size:.9rem}.criteria-strip span{color:#b05c2b;font-size:1.35rem;font-weight:900}.workspace-grid{grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);align-items:start;gap:18px;display:grid}.builder-panel,.panel-card,.output-panel{padding:22px}.section-heading{align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.section-heading h2{margin-bottom:0;font-size:1.35rem;line-height:1.2}.section-heading.compact{align-items:center;margin-bottom:16px}.section-heading.between{justify-content:space-between}.inline-title{align-items:center;gap:10px;display:inline-flex}label{margin-bottom:14px;display:block}label span{color:#3c4d44;margin-bottom:7px;font-size:.88rem;font-weight:800;display:block}textarea,input{color:#16211c;background:#fdfbf4;border:1px solid #cfc3ac;border-radius:8px;outline:none;width:100%}textarea{resize:vertical;min-height:92px;padding:12px;line-height:1.55}input{min-height:44px;padding:0 12px}textarea:focus,input:focus{border-color:#184a3a;box-shadow:0 0 0 3px #184a3a29}.insight-stack{gap:18px;display:grid;position:sticky;top:18px}.score-list{gap:10px;display:grid}.score-list article{background:#fdfbf4;border:1px solid #e4d9c6;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:14px;display:grid}.score-list p{color:#5c6a61;margin:5px 0 0;font-size:.9rem;line-height:1.5}.score-list span{color:#b05c2b;font-size:1.6rem;font-weight:900}.api-field{margin-bottom:12px}.wide-button{width:100%}.mentor-note,.error-text{border-radius:8px;margin:14px 0 0;padding:12px;font-size:.92rem;line-height:1.55}.mentor-note{color:#1e4638;background:#e8f3ec}.error-text{color:#7b241c;background:#f8ded8;flex-wrap:wrap;align-items:center;gap:8px;display:flex}.retry-button{color:#fff;cursor:pointer;background:#7b241c;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-size:.8rem;transition:opacity .2s;display:inline-flex}.retry-button:hover{opacity:.85}.retry-button:disabled{opacity:.5;cursor:not-allowed}.feedback-row{align-items:flex-start;gap:8px;margin-top:10px;display:flex}.feedback-row .mentor-note{flex:1;margin-top:0}.feedback-buttons{flex-direction:column;gap:6px;padding-top:4px;display:flex}.feedback-buttons .icon-button{cursor:pointer;background:#e8f3ec;border:1px solid #c8e0d0;border-radius:6px;padding:6px;transition:background .2s}.feedback-buttons .icon-button:hover{background:#d0ebd6}.chat-thread{background:#f0ede5;border-radius:8px;flex-direction:column;gap:8px;max-height:320px;margin-top:14px;padding:8px;display:flex;overflow-y:auto}.chat-bubble{word-wrap:break-word;border-radius:12px;max-width:85%;padding:10px 14px;font-size:.88rem;line-height:1.5}.chat-bubble.user{color:#fff;background:#1e4638;align-self:flex-end}.chat-bubble.assistant{color:#16211c;background:#fff;border:1px solid #e0dccc;align-self:flex-start}.chat-input-row{gap:8px;margin-top:10px;display:flex}.chat-input-row input{background:#fff;border:1px solid #d4cfc0;border-radius:8px;flex:1;padding:10px 12px;font-size:.88rem}.chat-input-row input:focus{outline-offset:-1px;outline:2px solid #1e4638}.chat-input-row button{color:#fff;cursor:pointer;background:#1e4638;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0 14px;transition:opacity .2s;display:flex}.chat-input-row button:hover:not(:disabled){opacity:.85}.chat-input-row button:disabled{opacity:.4;cursor:not-allowed}.cache-info{color:#5a6b62;align-items:center;gap:4px;margin-top:10px;font-size:.8rem;display:flex}.cache-clear{color:#5a6b62;cursor:pointer;background:0 0;border:1px solid #d4cfc0;border-radius:6px;align-items:center;gap:4px;margin-top:8px;padding:4px 10px;font-size:.78rem;transition:background .2s;display:inline-flex}.cache-clear:hover{background:#f0ede5}.output-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px;display:grid}.output-panel.wide{grid-column:1/-1}.roadmap-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.roadmap-list.four-column{grid-template-columns:repeat(4,minmax(0,1fr))}.roadmap-list section{background:#fdfbf4;border:1px solid #e4d9c6;border-radius:8px;padding:16px}.roadmap-list h3{color:#184a3a;margin-bottom:12px;font-size:1rem}.roadmap-list p{color:#4a5d52;align-items:flex-start;gap:8px;margin-bottom:9px;font-size:.92rem;line-height:1.45;display:flex}.roadmap-list svg{color:#b05c2b;flex:none;margin-top:2px}.generated-text{color:#31423a;margin:0;line-height:1.7}.compact-list{gap:10px;display:grid}.compact-list p{color:#31423a;background:#fdfbf4;border-left:3px solid #d9a441;margin:0;padding:10px 0 10px 12px;line-height:1.6}.prewrap{white-space:pre-wrap;font-family:inherit}.icon-button{color:#184a3a;background:#eadfc8;width:42px;min-height:42px;padding:0}.icon-button:hover{background:#ddcfb5}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=980px){.hero-panel,.workspace-grid{grid-template-columns:1fr}.score-orbit{margin:0}.criteria-strip,.roadmap-list,.roadmap-list.four-column{grid-template-columns:repeat(2,minmax(0,1fr))}.insight-stack{position:static}}@media (width<=680px){.app-shell{width:min(100% - 20px,1180px);padding-top:10px}.hero-panel{min-height:auto;padding:24px}.criteria-strip,.output-grid,.roadmap-list,.roadmap-list.four-column{grid-template-columns:1fr}.hero-actions,.hero-actions a,.hero-actions button{width:100%}.builder-panel,.panel-card,.output-panel{padding:18px}}.metrics-dashboard{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%);border:1px solid #bae6fd;border-radius:12px;margin:32px 0;padding:24px}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:16px;display:grid}.metric-card{background:#fff;border-radius:8px;flex-direction:column;gap:8px;padding:16px;display:flex;box-shadow:0 2px 4px #0000000d}.metric-label{color:#64748b;font-size:.85rem;font-weight:500}.metric-value{color:#0369a1;font-size:1.5rem;font-weight:700}.quality-evaluation{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:1px solid #fcd34d;border-radius:12px;margin:32px 0;padding:24px}.quality-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px;display:grid}.quality-card{background:#fff;border-radius:8px;flex-direction:column;gap:8px;padding:16px;display:flex;box-shadow:0 2px 4px #0000000d}.quality-card.overall{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:2px solid #f59e0b}.quality-label{color:#78350f;font-size:.85rem;font-weight:600}.quality-bar{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.quality-fill{background:linear-gradient(90deg,#f59e0b 0%,#d97706 100%);height:100%;transition:width .3s}.quality-score{color:#92400e;font-size:1.1rem;font-weight:700}.validation-errors{background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border:1px solid #fca5a5;border-radius:12px;margin:32px 0;padding:24px}.error-list{margin:16px 0 0;padding-left:20px;list-style:none}.error-list li{color:#991b1b;padding:8px 0;font-weight:500;position:relative}.error-list li:before{content:"⚠️";position:absolute;left:-20px}.connection-status{border-radius:20px;align-items:center;gap:6px;margin-left:auto;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.connection-status.disconnected{color:#6b7280;background:#f3f4f6}.connection-status.disconnected .status-dot{background:#9ca3af}.connection-status.connecting{color:#92400e;background:#fef3c7}.connection-status.connecting .status-dot{background:#f59e0b;animation:1s ease-in-out infinite pulse-dot}.connection-status.connected{color:#065f46;background:#d1fae5}.connection-status.connected .status-dot{background:#10b981;animation:2s ease-in-out infinite pulse-dot}.connection-status.error{color:#991b1b;background:#fee2e2}.connection-status.error .status-dot{background:#ef4444}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.streaming-response{background:linear-gradient(135deg,#f0fdf4 0%,#ecfdf5 100%);border:1px solid #86efac;border-radius:12px;margin:16px 0;padding:16px;position:relative}.streaming-header{color:#166534;align-items:center;gap:8px;margin-bottom:12px;font-size:.8rem;font-weight:600;display:flex}.typing-cursor{color:#184a3a;font-weight:700;animation:.8s step-end infinite blink-cursor;display:inline-block}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.rendered-markdown{line-height:1.7}.rendered-markdown h1,.rendered-markdown h2,.rendered-markdown h3{color:#184a3a;margin:16px 0 8px}.rendered-markdown h1{font-size:1.3rem}.rendered-markdown h2{font-size:1.15rem}.rendered-markdown h3{font-size:1.05rem}.rendered-markdown p{margin:8px 0}.rendered-markdown ul{margin:8px 0;padding-left:24px}.rendered-markdown li{margin:4px 0}.rendered-markdown strong{color:#0f3529}.rendered-markdown code{background:#e8f5e9;border-radius:4px;padding:2px 6px;font-family:Fira Code,monospace;font-size:.9em}.rendered-markdown pre{color:#e2e8f0;background:#1e293b;border-radius:8px;margin:12px 0;padding:16px;overflow-x:auto}.rendered-markdown pre code{color:inherit;background:0 0;padding:0}.quick-actions{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin:12px 0;padding:12px;display:flex}.quick-label{color:#64748b;font-size:.78rem;font-weight:600}.quick-action-btn{color:#0369a1;cursor:pointer;background:#e0f2fe;border:1px solid #bae6fd;border-radius:16px;min-height:32px;padding:4px 12px;font-size:.78rem;font-weight:600;transition:all .16s}.quick-action-btn:hover{background:#bae6fd;transform:translateY(-1px);box-shadow:0 4px 12px #0369a11f}.coach-actions-row{gap:8px;margin-top:12px;display:flex}.chat-bubble.streaming{border-left:3px solid #10b981;animation:.3s fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.error-boundary{text-align:center;background:#fef2f2;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;margin:24px;padding:48px 24px;display:flex}.error-boundary h2{color:#dc2626;margin:16px 0 8px;font-size:1.5rem}.error-boundary p{color:#7f1d1d;max-width:480px;margin:0 0 24px}.error-boundary button{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;padding:12px 24px;font-weight:600;transition:background .16s}.error-boundary button:hover{background:#b91c1c}.api-key-status{color:#10b981;margin-top:4px;font-size:.75rem;font-weight:500;display:block}.api-key-status.warning{color:#f59e0b}.rate-limit-warning{color:#92400e;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;align-items:center;gap:8px;margin:12px 0;padding:12px 16px;font-size:.875rem;animation:.3s slide-down;display:flex}.rate-limit-warning svg{color:#f59e0b;flex-shrink:0}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.coach-mode-select{color:#16211c;width:100%;min-height:44px;font:inherit;cursor:pointer;appearance:auto;background:#fdfbf4;border:1px solid #cfc3ac;border-radius:8px;outline:none;padding:0 12px;font-size:.88rem}.coach-mode-select:focus{border-color:#184a3a;box-shadow:0 0 0 3px #184a3a29}.settings-toggle{color:#5a6b62;cursor:pointer;background:0 0;border:1px dashed #d4cfc0;border-radius:6px;justify-content:center;align-items:center;gap:6px;width:100%;min-height:36px;margin:4px 0 10px;padding:0 12px;font-size:.78rem;font-weight:600;transition:background .16s,border-color .16s;display:inline-flex}.settings-toggle:hover{color:#184a3a;background:#f0ede5;border-color:#184a3a}.llm-settings-panel{background:#f8f6f0;border:1px solid #e4d9c6;border-radius:8px;margin:4px 0 12px;padding:14px;animation:.25s slide-down}.llm-slider{appearance:none;cursor:pointer;background:#dfd5c0;border-radius:3px;outline:none;width:100%;height:6px;margin:8px 0}.llm-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#184a3a;border-radius:50%;width:18px;height:18px;transition:transform .12s}.llm-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.slider-hint{color:#8c9d93;margin-top:2px;font-size:.72rem;display:block}.llm-settings-panel .api-field{margin-bottom:10px}.llm-settings-panel .api-field span{align-items:center;gap:4px;font-size:.8rem;display:flex}.coach-mode-badge{color:#184a3a;background:#e8f3ec;border:1px solid #c8e0d0;border-radius:12px;align-items:center;gap:4px;margin-bottom:8px;padding:2px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.eval-test-panel{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%);border:1px solid #bae6fd;border-radius:8px;margin:16px 0;padding:16px}.eval-results{gap:8px;margin-top:10px;display:grid}.eval-result-row{background:#fff;border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.82rem;display:flex}.eval-pass{color:#065f46;font-weight:700}.eval-fail{color:#991b1b;font-weight:700}@media (width<=680px){.llm-settings-panel{padding:10px}}
