@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg:#08080f;--bg-elevated:#0e0e1a;--bg-card:#121223b3;--bg-card-hover:#1c1c32cc;--bg-glass:#ffffff08;--text:#a0a0b8;--text-h:#eeeef4;--text-muted:#5a5a72;--accent:#6c63ff;--accent-light:#9d96ff;--accent-glow:#6c63ff59;--accent2:#00d4aa;--accent2-glow:#00d4aa4d;--success:#00d4aa;--warning:#fbbf24;--danger:#f43f5e;--border:#ffffff0f;--border-light:#ffffff1a;--radius:16px;--radius-sm:10px;--radius-xs:6px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 32px #0006;--shadow-glow:0 0 30px var(--accent-glow);--font:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"Cascadia Code", "Fira Code", Consolas, monospace;font:16px/1.5 var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;overflow-x:hidden}#root{min-height:100vh;position:relative}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}button{font-family:var(--font);cursor:pointer;border:none;outline:none;transition:all .2s}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea,select{font-family:var(--font);color:var(--text-h);background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-xs);outline:none;padding:10px 14px;font-size:1rem;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.app{min-height:100vh;position:relative}.app:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#6c63ff14 0%,#0000 50%),radial-gradient(at 80% 80%,#00d4aa0f 0%,#0000 50%);width:200%;height:200%;position:fixed;top:-50%;left:-50%}.app>*{z-index:1;position:relative}.nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:20;background:#08080fd9;align-items:center;gap:12px;padding:14px 28px;display:flex;position:sticky;top:0}.nav-brand{letter-spacing:-.5px;background:linear-gradient(135deg, var(--accent-light), var(--accent2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-right:auto;font-size:1.2rem;font-weight:800;text-decoration:none}.nav-btn{background:var(--bg-glass);color:var(--text-muted);border:1px solid #0000;border-radius:20px;padding:8px 18px;font-size:.85rem;font-weight:500;text-decoration:none}.nav-btn:hover{color:var(--text-h);background:var(--accent-glow);border-color:var(--accent)}.page{width:100%;max-width:960px;margin:0 auto;padding:32px 28px 60px;animation:.3s fadeIn}.back-btn{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;margin-bottom:20px;padding:8px 18px;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.back-btn:hover{background:var(--bg-card-hover);border-color:var(--border-light)}.section-title{letter-spacing:-1px;color:var(--text-h);font-size:2rem;font-weight:800}.hero-subtitle{color:var(--text-muted);margin-top:6px;font-size:.95rem}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;box-shadow:0 4px 15px var(--accent-glow);border-radius:10px;padding:10px 24px;font-size:.9rem;font-weight:600}.btn-primary:hover{box-shadow:0 6px 25px var(--accent-glow);transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-glass);color:var(--text);border:1px solid var(--border-light);border-radius:10px;padding:10px 24px;font-size:.9rem;font-weight:500}.btn-secondary:hover{background:var(--bg-card);border-color:var(--accent)}.analysis-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px;animation:.3s fadeIn}.analysis-card h4{color:var(--text-h);margin-bottom:8px;font-size:1rem;font-weight:600}.analysis-card p{font-size:.9rem;line-height:1.6}.rating-badge{text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-radius:20px;padding:3px 10px;font-size:.7rem;font-weight:700}.badge-strong{color:var(--success);background:#00d4aa1f}.badge-medium{color:var(--warning);background:#fbbf241f}.badge-weak{color:var(--danger);background:#f43f5e1f}.badge-missing{color:var(--text-muted);background:#ffffff0d}.badge-high{color:var(--success);background:#00d4aa1f}.badge-critical{color:var(--danger);background:#f43f5e26}.badge-significant{color:var(--warning);background:#fbbf241f}.badge-moderate{color:var(--accent-light);background:#6c63ff1f}.badge-minor{color:var(--text-muted);background:#ffffff0d}.tab-bar{border-bottom:1px solid var(--border);gap:4px;margin-bottom:24px;display:flex}.tab-btn{color:var(--text-muted);background:0 0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:.9rem;font-weight:500}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent-light);border-bottom-color:var(--accent)}.phase-indicator{justify-content:center;align-items:center;gap:0;margin-bottom:28px;padding:16px 0;display:flex}.phase-step{flex-direction:column;align-items:center;gap:6px;min-width:100px;display:flex}.phase-circle{background:var(--bg-card);width:32px;height:32px;color:var(--text-muted);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;transition:all .3s;display:flex}.phase-step.active .phase-circle{border-color:var(--accent);color:var(--accent-light);box-shadow:0 0 16px var(--accent-glow);animation:2s infinite pulse}.phase-step.completed .phase-circle{border-color:var(--success);background:var(--success);color:#000}.phase-label{color:var(--text-muted);text-align:center;font-size:.75rem}.phase-step.active .phase-label{color:var(--accent-light)}.phase-step.completed .phase-label{color:var(--success)}.phase-connector{background:var(--border);width:40px;height:2px;margin:0 4px 20px}@keyframes pulse{0%,to{box-shadow:0 0 16px var(--accent-glow)}50%{box-shadow:0 0 28px var(--accent-glow)}}.input-textarea{border-radius:var(--radius-sm);width:100%;min-height:220px;padding:16px;font-size:.95rem;line-height:1.6}.context-fields{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:12px;display:grid}@media (width<=640px){.context-fields{grid-template-columns:1fr}}.canvas-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=768px){.canvas-grid{grid-template-columns:1fr}}.streaming-text{font-family:var(--font-mono);color:var(--text-muted);white-space:pre-wrap;word-break:break-word;background:var(--bg-card);border-radius:var(--radius-xs);border:1px solid var(--border);max-height:200px;margin-bottom:16px;padding:12px;font-size:.8rem;overflow-y:auto}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;margin:0 auto 12px;animation:.8s linear infinite spin}.loading-label{text-align:center;color:var(--text-muted);font-size:.9rem}.error-banner{border-radius:var(--radius-xs);color:var(--danger);background:#f43f5e1a;border:1px solid #f43f5e4d;margin-bottom:16px;padding:12px 16px;font-size:.9rem}.warning-banner{border-radius:var(--radius-xs);color:var(--warning);text-align:center;background:#fbbf2414;border:1px solid #fbbf2433;margin-bottom:16px;padding:12px 16px;font-size:.85rem}.warning-banner a{color:var(--accent-light)}.score-bar-row{align-items:center;gap:8px;margin-bottom:6px;font-size:.8rem;display:flex}.score-bar-row span:first-child{text-align:right;width:120px;color:var(--text-muted);text-transform:capitalize}.score-bar-bg{background:var(--border);border-radius:3px;flex:1;height:6px;overflow:hidden}.score-bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:3px;height:100%;transition:width .5s}.score-bar-row span:last-child{text-align:center;width:24px;color:var(--text-h);font-weight:600;font-family:var(--font-mono)}.maturity-score{font-size:3rem;font-weight:800;font-family:var(--font-mono);background:linear-gradient(135deg, var(--accent-light), var(--accent2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:8px 0 16px}.evidence-quote{color:var(--text-muted);border-left:2px solid var(--border);margin:6px 0;padding-left:10px;font-size:.8rem;font-style:italic}.timeline{border-left:2px solid var(--border);flex-direction:column;gap:16px;padding-left:20px;display:flex}.timeline-item{position:relative}.timeline-item:before{content:"";background:var(--accent);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;left:-25px}.drop-zone{border:2px dashed var(--border-light);border-radius:var(--radius-sm);text-align:center;color:var(--text-muted);cursor:pointer;background:var(--bg-card);padding:24px;font-size:.9rem;transition:all .2s}.drop-zone:hover{border-color:var(--accent);background:#6c63ff0d}.drop-zone.drag-over{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);background:#6c63ff1a}.btn-export{background:linear-gradient(135deg, var(--accent2), #00b894);color:#000;border-radius:10px;padding:10px 24px;font-size:.9rem;font-weight:600}.btn-export:hover{box-shadow:0 4px 20px var(--accent2-glow);transform:translateY(-1px)}.btn-export:disabled{opacity:.4;cursor:not-allowed;transform:none}
