*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a2e;--bg-chat:#0f0f1a;--border:#2a2a3e;--border-glow:#00d4ff33;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#00d4ff;--accent-dim:#00d4ff22;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--purple:#8b5cf6;--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}.landing{max-width:1000px;margin:0 auto;padding:2rem 1.5rem 4rem}.hero{text-align:center;padding:3rem 0 2rem}.hero-badge{display:inline-block;padding:.35rem 1rem;border-radius:999px;background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1.25rem}.hero h1{font-size:2.75rem;font-weight:800;line-height:1.15;margin-bottom:1rem;background:linear-gradient(135deg,#fff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{font-size:1.15rem;color:var(--text-secondary);max-width:600px;margin:0 auto}.levels-grid{display:grid;grid-gap:1rem;gap:1rem;margin-top:2.5rem}.level-card{display:flex;align-items:stretch;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s,transform .2s;cursor:pointer;text-decoration:none;color:inherit}.level-card:hover{border-color:var(--accent);transform:translateY(-2px)}.level-number{display:flex;align-items:center;justify-content:center;width:80px;min-height:100%;font-size:2rem;font-weight:800;color:var(--text-muted);background:var(--bg-secondary);border-right:1px solid var(--border);flex-shrink:0}.level-info{flex:1 1;padding:1.25rem 1.5rem}.level-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.4rem}.level-title{font-size:1.15rem;font-weight:700}.difficulty-badge{font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.level-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.level-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.chat-page{display:flex;flex-direction:column;height:100vh;max-width:900px;margin:0 auto}.chat-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.chat-header-top{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.back-link{color:var(--accent);text-decoration:none;font-size:.9rem;font-weight:600;padding:.3rem .6rem;border-radius:6px;border:1px solid var(--border);transition:background .2s}.back-link:hover{background:var(--accent-dim)}.chat-level-title{font-size:1.1rem;font-weight:700}.chat-meta{display:flex;gap:1.5rem;font-size:.8rem;color:var(--text-muted)}.chat-meta span{display:flex;align-items:center;gap:.3rem}.info-panels{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;padding:.75rem 1.5rem;background:var(--bg-primary);border-bottom:1px solid var(--border);flex-shrink:0}.info-panel{padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-card)}.info-panel-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.3rem}.info-panel-value{font-size:.85rem;color:var(--text-secondary)}.messages-area{flex:1 1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg-chat)}.message{max-width:80%;padding:.85rem 1.1rem;border-radius:12px;font-size:.9rem;line-height:1.55;word-wrap:break-word;white-space:pre-wrap}.message-user{align-self:flex-end;background:#1a3a5c;border:1px solid #2a4a6c;color:var(--text-primary);border-bottom-right-radius:4px}.message-assistant{align-self:flex-start;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px}.message-system{align-self:center;background:transparent;border:1px dashed var(--green);color:var(--green);text-align:center;max-width:90%;font-weight:600}.message-loading{align-self:flex-start;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);font-style:italic}.success-banner{padding:1rem 1.5rem;background:linear-gradient(135deg,#10b98122,#10b98108);border:1px solid var(--green);border-radius:10px;margin:.5rem 1.5rem;text-align:center;flex-shrink:0}.success-banner h3{color:var(--green);margin-bottom:.3rem}.success-banner p{font-size:.85rem;color:var(--text-secondary)}.chat-input-area{padding:1rem 1.5rem;border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.chat-input-form{display:flex;gap:.75rem}.chat-input{flex:1 1;padding:.75rem 1rem;border-radius:10px;border:1px solid var(--border);background:var(--bg-chat);color:var(--text-primary);font-family:var(--font);font-size:.9rem;outline:none;transition:border-color .2s;resize:none;min-height:44px;max-height:120px}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--text-muted)}.send-btn{padding:.75rem 1.5rem;border-radius:10px;border:none;background:var(--accent);color:#000;font-family:var(--font);font-size:.9rem;font-weight:700;cursor:pointer;transition:opacity .2s;white-space:nowrap}.send-btn:hover{opacity:.9}.send-btn:disabled{opacity:.4;cursor:not-allowed}.hint-toggle{margin-top:.5rem;text-align:center}.hint-btn{background:none;border:1px dashed var(--yellow);color:var(--yellow);padding:.4rem 1rem;border-radius:8px;font-family:var(--font);font-size:.8rem;cursor:pointer;transition:background .2s}.hint-btn:hover{background:#f59e0b11}.hint-text{font-size:.85rem;color:var(--yellow);margin-top:.5rem;padding:.5rem 1rem;background:#f59e0b0a;border-radius:8px;border:1px solid #f59e0b33}.api-key-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-top:2rem}.api-key-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.api-key-icon{font-size:1.2rem}.api-key-header h3{font-size:1rem;font-weight:700;color:var(--text-primary)}.api-key-desc{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.5}.api-key-desc a{color:var(--accent);text-decoration:none}.api-key-desc a:hover{text-decoration:underline}.api-key-input-row{display:flex;gap:.75rem;align-items:center}.api-key-input-wrapper{flex:1 1;position:relative}.api-key-input{width:100%;padding:.65rem 2.5rem .65rem 1rem;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85rem;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;outline:none;transition:border-color .2s}.api-key-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.api-key-input::placeholder{color:var(--text-muted)}.api-key-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;line-height:1}.api-key-save-btn{padding:.65rem 1.25rem;background:var(--accent);color:var(--bg-primary);border:none;border-radius:8px;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.api-key-save-btn:hover{background:#3df}.api-key-save-btn:disabled{opacity:.4;cursor:not-allowed}.api-key-clear-btn{padding:.65rem 1.25rem;background:transparent;color:var(--text-muted);border:1px solid var(--border);border-radius:8px;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.api-key-clear-btn:hover{border-color:var(--red);color:var(--red)}.api-key-status{margin-top:.75rem;font-size:.85rem;color:var(--green);font-weight:500}.api-key-tips{background:var(--bg-primary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:.85rem 1rem;margin-top:.75rem;margin-bottom:.25rem}.api-key-tips h4{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.api-key-tips ul{list-style:none;padding:0;margin:0}.api-key-tips li{font-size:.8rem;color:var(--text-secondary);line-height:1.5;padding:.15rem 0 .15rem 1.1rem;position:relative}.api-key-tips li:before{content:"→";position:absolute;left:0;color:var(--accent);font-size:.75rem}.api-key-tips a{color:var(--accent);text-decoration:none}.api-key-tips a:hover{text-decoration:underline}.api-key-tips code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;background:var(--bg-card);border:1px solid var(--border);padding:.1rem .35rem;border-radius:4px;color:var(--yellow)}.level-card-disabled{opacity:.4;cursor:not-allowed!important}.level-card-disabled:hover{border-color:var(--border)!important;transform:none!important}@media (max-width:640px){.api-key-input-row{flex-direction:column}.api-key-clear-btn,.api-key-save-btn{width:100%}}.footer{text-align:center;padding:2rem;border-top:1px solid var(--border);margin-top:3rem}.footer-links{display:flex;justify-content:center;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.footer-links a{color:var(--accent);text-decoration:none;font-size:.85rem;opacity:.7;transition:opacity .15s}.footer-links a:hover{opacity:1}.footer-sep{color:var(--text-muted);font-size:.7rem}.footer-tagline{font-size:.8rem;color:var(--text-muted)}.footer-tagline a{color:var(--accent);text-decoration:none;opacity:.7}.footer-tagline a:hover{opacity:1}.warning-box{background:#f59e0b0a;border:1px solid #f59e0b44;border-radius:10px;padding:1.25rem 1.5rem;margin-top:2rem;text-align:center}.warning-box h3{color:var(--yellow);font-size:1rem;margin-bottom:.4rem}.warning-box p{font-size:.85rem;color:var(--text-secondary)}.breakdown-toggle-btn{background:none;border:1px solid var(--accent);color:var(--accent);padding:.4rem 1rem;border-radius:8px;font-family:var(--font);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.breakdown-toggle-btn:hover{background:var(--accent-dim)}.breakdown-panel{margin:0 1.5rem .5rem;border:1px solid var(--border);border-radius:12px;background:var(--bg-secondary);overflow:hidden;flex-shrink:0}.breakdown-section{padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.breakdown-section:last-child{border-bottom:none}.breakdown-section h4{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.breakdown-label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.breakdown-code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem;line-height:1.6;color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:1rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;max-height:300px;overflow-y:auto}.breakdown-section p{font-size:.85rem;color:var(--text-secondary);line-height:1.55}.breakdown-secret{font-family:SF Mono,Fira Code,Consolas,monospace;color:var(--red)!important;font-weight:600}@media (max-width:640px){.hero h1{font-size:1.75rem}.level-number{width:50px;font-size:1.5rem}.level-info{padding:1rem}.info-panels{grid-template-columns:1fr}.message{max-width:90%}}