:root{--bg-primary: #0d1117;--bg-secondary: #121820;--bg-elevated: #3f2a21;--bg-hover: #1d2535;--text-primary: #f8fafc;--text-secondary: #e2ecf7;--text-muted: #c6cfd6;--accent: #e8820c;--accent-dim: #a85e08;--accent-glow: rgba(232, 130, 12, .12);--border: #1e2530;--border-accent: #2a3545;--success: #4ec994;--warning: #e6a547;--error: #d45656;--font-mono: "IBM Plex Mono", monospace;--font-body: "IBM Plex Sans", sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition: .2s ease}[data-theme=light]{--bg-primary: #f5f6f8;--bg-secondary: #ffffff;--bg-elevated: #eef0f3;--bg-hover: #e4e7ec;--text-primary: #1a1f2e;--text-secondary: #2d3748;--text-muted: #5a6778;--accent: #c96c00;--accent-dim: #a85800;--accent-glow: rgba(201, 108, 0, .1);--border: #dde1e8;--border-accent: #c8cdd6;--success: #1e9e68;--warning: #b07a1a;--error: #b03030}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.65;min-height:100vh}body:before{content:"";position:fixed;inset:0;background-image:linear-gradient(rgba(232,130,12,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(232,130,12,.02) 1px,transparent 1px);background-size:64px 64px;pointer-events:none;z-index:0}#root{position:relative;z-index:1}h1,h2,h3,h4{font-family:var(--font-mono);font-weight:500;letter-spacing:-.02em;line-height:1.3}h1{font-size:2rem}h2{font-size:1.35rem;color:var(--text-primary)}h3{font-size:1.05rem;color:var(--text-secondary)}p{color:var(--text-secondary);max-width:65ch}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--text-primary)}code,pre{font-family:var(--font-mono);font-size:.875rem}.container{max-width:860px;margin:0 auto;padding:0 24px}.section{padding:48px 0;border-bottom:1px solid var(--border)}.section:last-child{border-bottom:none}.section-label{font-family:var(--font-mono);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:20px;display:flex;align-items:center;gap:10px}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;transition:border-color var(--transition),background var(--transition)}.card:hover{border-color:var(--border-accent)}.btn{font-family:var(--font-mono);font-size:.8rem;font-weight:500;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;gap:8px}.btn:hover{border-color:var(--accent-dim);color:var(--text-primary);background:var(--bg-hover)}.btn-accent{border-color:var(--accent);background:var(--accent);color:#0d1117;font-weight:600}.btn-accent:hover{background:#f09535;border-color:#f09535;color:#0d1117}.btn-ghost{border-color:var(--accent-dim);color:var(--accent)}.btn-ghost:hover{border-color:var(--accent);background:var(--accent-glow);color:var(--text-primary)}.tag{display:inline-block;font-family:var(--font-mono);font-size:.7rem;font-weight:500;padding:3px 10px;border-radius:2px;background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.tag-accent{color:var(--accent);border-color:var(--accent-dim);background:var(--accent-glow)}.expandable{overflow:hidden;transition:max-height .4s ease,opacity .3s ease}.expandable.collapsed{max-height:0;opacity:0}.expandable.expanded{max-height:2000px;opacity:1}.context-trigger{font-family:var(--font-mono);font-size:.75rem;color:var(--accent-dim);cursor:pointer;background:none;border:none;padding:4px 0;transition:color var(--transition);display:inline-flex;align-items:center;gap:6px}.context-trigger:hover{color:var(--accent)}.context-trigger .arrow{display:inline-block;transition:transform var(--transition);font-size:.6rem}.context-trigger .arrow.open{transform:rotate(90deg)}.context-content{margin-top:12px;padding:16px;background:var(--bg-primary);border-left:2px solid var(--accent-dim);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.9rem;line-height:1.7;color:var(--text-secondary)}.chat-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.chat-container{width:min(680px,95vw);max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-accent);border-radius:var(--radius-lg);display:flex;flex-direction:column;animation:slideUp .3s ease;box-shadow:0 24px 80px #00000080}.chat-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.chat-header h3{font-size:.85rem;color:var(--text-primary)}.chat-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.2rem;padding:4px;transition:color var(--transition)}.chat-close:hover{color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-message{max-width:85%;padding:12px 16px;border-radius:var(--radius-md);font-size:.9rem;line-height:1.6}.chat-message.user{align-self:flex-end;background:var(--accent-glow);border:1px solid var(--accent-dim);color:var(--text-primary)}.chat-message.assistant{align-self:flex-start;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary)}.chat-message.system{align-self:center;font-size:.8rem;color:var(--text-muted);font-style:italic}.chat-input-area{padding:16px 20px;border-top:1px solid var(--border);display:flex;gap:10px}.chat-input{flex:1;font-family:var(--font-body);font-size:.9rem;padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;transition:border-color var(--transition)}.chat-input:focus{border-color:var(--accent-dim)}.chat-input::placeholder{color:var(--text-muted)}.chat-send{font-family:var(--font-mono);font-size:.8rem;padding:10px 16px;background:var(--accent-glow);border:1px solid var(--accent-dim);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;transition:all var(--transition)}.chat-send:hover:not(:disabled){background:#e8820c33;color:var(--text-primary)}.chat-send:disabled{opacity:.4;cursor:not-allowed}.fit-textarea{width:100%;min-height:160px;font-family:var(--font-body);font-size:.875rem;padding:14px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);resize:vertical;outline:none;transition:border-color var(--transition);line-height:1.6}.fit-textarea:focus{border-color:var(--accent-dim)}.fit-textarea::placeholder{color:var(--text-muted)}.fit-result{margin-top:20px;padding:20px;background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border)}.fit-score{font-family:var(--font-mono);font-size:.85rem;font-weight:600;padding:6px 14px;border-radius:var(--radius-sm);display:inline-block;margin-bottom:12px}.fit-score.strong{background:#4ec9941a;color:var(--success);border:1px solid rgba(78,201,148,.3)}.fit-score.moderate{background:#e6a5471a;color:var(--warning);border:1px solid rgba(230,165,71,.3)}.fit-score.weak{background:#d456561a;color:var(--error);border:1px solid rgba(212,86,86,.3)}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:640px){.skills-grid{grid-template-columns:1fr}}.skill-column h3{font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.skill-column.strong h3{color:var(--success)}.skill-column.moderate h3{color:var(--warning)}.skill-column.gaps h3{color:var(--text-muted)}.skill-item{font-size:.85rem;padding:6px 0;color:var(--text-secondary)}.typing-indicator{display:inline-flex;gap:4px;padding:4px 0}.typing-indicator span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typing 1.2s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes typing{0%,60%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-accent);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.page-layout{max-width:1200px;margin:0 auto;padding:48px 24px 80px;display:grid;grid-template-columns:minmax(0,1fr) 336px;gap:0 48px;align-items:start}.main-column{min-width:0}.sidebar-column{position:sticky;top:24px}@media(max-width:1100px){.page-layout{grid-template-columns:1fr;max-width:860px}.sidebar-column{position:static}}.wibu-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.wibu-header{font-family:var(--font-mono);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:16px}.wibu-intro{font-size:.82rem;color:var(--text-secondary);line-height:1.6;max-width:none}.wibu-intro strong{color:var(--text-primary);font-weight:600}.wibu-block{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.wibu-subtitle{font-family:var(--font-mono);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:10px}.wibu-diagram{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);line-height:1.7;white-space:pre;background:var(--bg-primary);padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border)}.wibu-tech-item{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-bottom:1px solid var(--border)}.wibu-tech-item:last-child{border-bottom:none;padding-bottom:0}.wibu-tech-name{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);font-weight:600}.wibu-tech-reason{font-size:.78rem;color:var(--text-muted);line-height:1.5}.wibu-cost-total{font-family:var(--font-mono);font-size:1.6rem;font-weight:600;color:var(--accent);margin-bottom:10px}.wibu-cost-breakdown{display:flex;flex-direction:column;gap:4px}.wibu-cost-line{display:flex;justify-content:space-between;font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}.wibu-cost-line span:last-child{color:var(--text-secondary)}.admin-login{max-width:360px;margin:80px auto}.admin-input{width:100%;font-family:var(--font-mono);font-size:.85rem;padding:10px 14px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;margin-bottom:12px}.admin-input:focus{border-color:var(--accent-dim)}.log-table{width:100%;border-collapse:collapse;font-size:.8rem}.log-table th{font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.log-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:top}.log-table tr:hover td{background:var(--bg-hover)}.log-expand{max-width:400px;white-space:pre-wrap;word-break:break-word}
