.admin-dashboard{padding:1.5rem;max-width:1280px;margin:0 auto;background:var(--bg-base);min-height:100vh;color:var(--text-primary)}.demo-banner{background:var(--accent-subtle);border:1px solid var(--border-accent);color:#a5b4fc;padding:.625rem .875rem;border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1.25rem 1.5rem;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.dashboard-header h1{margin:0;font-size:1.375rem;font-weight:600;letter-spacing:-.025em;color:var(--text-primary)}.controls{display:flex;gap:.75rem;align-items:center}.controls label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--text-secondary);font-size:.8125rem;font-weight:500}.controls select{padding:.375rem .625rem;border:1px solid var(--border);border-radius:var(--radius-md);font-size:.8125rem;background:var(--bg-elevated);color:var(--text-primary);font-family:var(--font-sans);outline:none;transition:border-color var(--transition)}.controls select:focus{border-color:var(--accent)}.refresh-btn{padding:.5rem .875rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.8125rem;font-weight:500;transition:background var(--transition);font-family:var(--font-sans)}.refresh-btn:hover{background:var(--accent-hover)}.overview-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:.875rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-surface);padding:1.25rem;border-radius:var(--radius-lg);border:1px solid var(--border);border-left:2px solid;min-height:110px;display:flex;flex-direction:column;justify-content:center;transition:background var(--transition),border-color var(--transition)}.stat-card:hover{background:var(--bg-elevated)}.stat-card.primary{border-left-color:var(--accent)}.stat-card.success{border-left-color:var(--success)}.stat-card.danger{border-left-color:var(--error)}.stat-card.info{border-left-color:var(--info)}.stat-card h3{margin:0 0 .625rem;font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.stat-value{font-size:1.625rem;font-weight:600;color:var(--text-primary);line-height:1.2;white-space:normal;overflow:visible;word-break:break-all;text-align:left;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stat-subtitle{margin-top:.375rem;font-size:.8125rem;color:var(--text-muted)}.layer-performance{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.5rem;overflow-x:auto}.layer-performance h2{margin:0 0 1.25rem;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.performance-table{width:100%;border-collapse:collapse}.performance-table th{text-align:left;padding:.625rem .75rem;border-bottom:1px solid var(--border);font-size:.6875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.performance-table td{padding:.875rem .75rem;border-bottom:1px solid var(--border);color:var(--text-primary);font-size:.875rem}.performance-table tr:last-child td{border-bottom:none}.performance-table tr:hover{background:var(--accent-subtle)}.layer-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.04em}.layer-badge.layer-1{background:#4caf6e26;color:#34d399}.layer-badge.layer-2{background:#4a9eff26;color:#60a5fa}.layer-badge.layer-3{background:#8b5cf626;color:#a78bfa}.progress-bar{position:relative;width:120px;height:18px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.progress-fill{height:100%;background:var(--success);transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.6875rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.latency{font-family:var(--font-mono);color:var(--text-secondary);font-size:.8125rem}.flow-visualization{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.5rem}.flow-visualization h2{margin:0 0 1.5rem;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.flow-diagram{display:flex;align-items:center;justify-content:space-between;gap:.75rem;overflow-x:auto;padding:.75rem 0}.flow-node{flex-shrink:0;min-width:130px;padding:1.125rem;border-radius:var(--radius-lg);text-align:center;border:1px solid;background:var(--bg-elevated)}.flow-node.incoming{border-color:var(--border-accent);color:#a5b4fc}.flow-node.layer1{border-color:#4caf6e4d;color:#6ee7b7}.flow-node.layer2{border-color:#4a9eff4d;color:#93c5fd}.flow-node.layer3{border-color:#8b5cf64d;color:#c4b5fd}.flow-node.miss{border-color:#e5484d4d;color:#fca5a5}.node-label{font-size:.6875rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}.node-value{font-size:1.375rem;font-weight:600;margin-bottom:.25rem;white-space:normal;word-break:break-all;color:var(--text-primary);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.node-subtitle{font-size:.6875rem;opacity:.75}.flow-arrow{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--text-muted);font-size:1.25rem}.flow-arrow.miss{color:var(--error)}.arrow-value{font-size:.8125rem;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums}.arrow-label{font-size:.6875rem;color:var(--text-muted)}.layer-details{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.5rem}.layer-details h2{margin:0 0 1.25rem;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.layer-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem}.layer-card{padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius-lg);transition:background var(--transition),border-color var(--transition);background:var(--bg-elevated);min-width:0}.layer-card:hover{border-color:var(--border-accent);background:var(--bg-hover)}.layer-card h3{margin:0 0 .875rem;font-size:.9375rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.layer-info{display:flex;flex-direction:column;gap:.5rem}.layer-info p{margin:0;font-size:.8125rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:.5rem}.layer-info strong{color:var(--text-muted);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.layer-info span{color:var(--text-primary);word-break:break-word}.smart-matching{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.5rem}.smart-matching h2{margin:0 0 1.25rem;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.smart-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem}.smart-card{padding:1.25rem;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-elevated)}.smart-card h3{margin:0 0 .5rem;font-size:.9375rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.smart-card p{margin:0 0 .875rem;font-size:.8125rem;color:var(--text-secondary);line-height:1.55}.smart-card pre{background:var(--bg-base);border:1px solid var(--border);padding:.875rem;border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.75rem;overflow-x:auto;max-height:200px;overflow-y:auto;color:var(--text-primary);line-height:1.5}.system-info{background:var(--bg-surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border)}.system-info h2{margin:0 0 1.25rem;font-size:1.0625rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.info-item{padding:.875rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center}.info-item strong{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.info-item span{color:var(--text-primary);font-size:.8125rem;font-weight:500;font-variant-numeric:tabular-nums}.admin-dashboard.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--text-secondary)}@media (max-width: 1024px){.overview-cards,.layer-cards,.info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.admin-dashboard{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem;align-items:flex-start}.overview-cards,.layer-cards,.smart-cards,.info-grid{grid-template-columns:1fr}.flow-diagram{flex-direction:column}.flow-arrow{transform:rotate(90deg)}.performance-table{font-size:.8125rem}.performance-table th,.performance-table td{padding:.5rem}}.cache-simulation{min-height:100vh;background:var(--bg-base);color:var(--text-primary);padding:1.25rem;font-family:var(--font-sans)}.sim-header{display:flex;justify-content:space-between;align-items:center;padding:1.125rem 1.5rem;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);margin-bottom:1.25rem}.sim-title h1{margin:0;font-size:1.375rem;font-weight:600;letter-spacing:-.025em;color:var(--text-primary)}.sim-title p{margin:.375rem 0 0;color:var(--text-secondary);font-size:.8125rem}.sim-controls{display:flex;gap:.75rem;align-items:center}.control-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition);font-family:var(--font-sans)}.control-btn.stopped{background:var(--success);color:#fff}.control-btn.stopped:hover{background:#5cba7e}.control-btn.running{background:var(--warning);color:#fff;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 #f59f0b00}50%{box-shadow:0 0 0 4px #f59f0b40}}.speed-control{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md)}.speed-control label{font-size:.8125rem;color:var(--text-secondary)}.speed-control input[type=range]{width:80px;accent-color:var(--accent)}.speed-control span{font-weight:600;color:var(--accent);min-width:30px;font-variant-numeric:tabular-nums;font-size:.8125rem}.reset-btn{padding:.5rem .875rem;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition),border-color var(--transition);font-size:.8125rem;font-weight:500;font-family:var(--font-sans)}.reset-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.sim-main{display:grid;grid-template-columns:240px 1fr 280px;gap:1rem;margin-bottom:1.25rem}.stats-panel{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.125rem}.stats-panel h2{margin:0 0 1.125rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-group{margin-bottom:1.25rem}.stat-item{padding:.875rem;border-radius:var(--radius-md);margin-bottom:.625rem;background:var(--bg-elevated);border:1px solid var(--border)}.stat-item.total{background:var(--accent-subtle);border-color:var(--border-accent)}.stat-item.hit-rate{background:var(--success-subtle);border-color:#4caf6e4d}.stat-label{display:block;font-size:.6875rem;color:var(--text-secondary);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.stat-item .stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.hit-rate-bar{height:4px;background:#ffffff0f;border-radius:2px;margin-top:.5rem;overflow:hidden}.hit-rate-fill{height:100%;background:var(--success);border-radius:2px;transition:width .5s ease}.layer-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.layer-stat{display:grid;grid-template-columns:32px 1fr;grid-template-rows:auto auto;gap:.25rem .625rem;padding:.625rem;border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border)}.layer-stat.l1{border-left:2px solid var(--success)}.layer-stat.l2{border-left:2px solid var(--warning)}.layer-stat.l3{border-left:2px solid var(--info)}.layer-stat.miss{border-left:2px solid var(--error)}.layer-icon{grid-row:span 2;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;width:32px;height:32px;border-radius:var(--radius-sm);background:#ffffff0f}.layer-stat.l1 .layer-icon{background:var(--success-subtle);color:var(--success)}.layer-stat.l2 .layer-icon{background:var(--warning-subtle);color:var(--warning)}.layer-stat.l3 .layer-icon{background:var(--info-subtle);color:var(--info)}.layer-stat.miss .layer-icon{background:var(--error-subtle);color:var(--error);font-size:.9375rem}.layer-info{display:flex;justify-content:space-between;align-items:center}.layer-name{font-size:.75rem;color:var(--text-secondary);font-weight:500}.layer-hits{font-size:.75rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.layer-bar{grid-column:2;height:3px;background:#ffffff0f;border-radius:2px;overflow:hidden}.layer-stat.l1 .layer-fill{background:var(--success)}.layer-stat.l2 .layer-fill{background:var(--warning)}.layer-stat.l3 .layer-fill{background:var(--info)}.layer-stat.miss .layer-fill{background:var(--error)}.layer-fill{height:100%;transition:width .5s ease}.latency-stat,.cache-size{padding:.75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:.5rem;display:flex;justify-content:space-between;font-size:.8125rem}.latency-stat .stat-value,.cache-size .stat-value{font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}.flow-container{display:flex;align-items:stretch;gap:.5rem;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.125rem;overflow-x:auto}.flow-stage{flex:1;min-width:140px;padding:1rem;border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border);display:flex;flex-direction:column;transition:border-color var(--transition),box-shadow var(--transition)}.flow-stage.active{box-shadow:0 0 0 1px #ffffff1a}.flow-stage.pulse{animation:layer-pulse .5s ease}@keyframes layer-pulse{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.flow-stage.l1{border-color:#4caf6e40}.flow-stage.l1.active{box-shadow:0 0 0 1px #4caf6e80,0 0 24px #4caf6e33;border-color:#4caf6e80}.flow-stage.l1.pulse{animation:l1-pulse .5s ease}@keyframes l1-pulse{0%,to{box-shadow:0 0 #4caf6e4d}50%{box-shadow:0 0 0 6px #4caf6e26}}.flow-stage.l2{border-color:#f59f0b40}.flow-stage.l2.active{box-shadow:0 0 0 1px #f59f0b80,0 0 24px #f59f0b33;border-color:#f59f0b80}.flow-stage.l2.pulse{animation:l2-pulse .5s ease}@keyframes l2-pulse{0%,to{box-shadow:0 0 #f59f0b4d}50%{box-shadow:0 0 0 6px #f59f0b26}}.flow-stage.l3{border-color:#4a9eff40}.flow-stage.l3.active{box-shadow:0 0 0 1px #4a9eff80,0 0 24px #4a9eff33;border-color:#4a9eff80}.flow-stage.l3.pulse{animation:l3-pulse .5s ease}@keyframes l3-pulse{0%,to{box-shadow:0 0 #4a9eff4d}50%{box-shadow:0 0 0 6px #4a9eff26}}.flow-stage.miss-stage{border-color:#e5484d40}.stage-header{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:.75rem}.stage-icon{font-size:1.375rem}.stage-label{font-size:.75rem;font-weight:600;text-align:center;color:var(--text-primary);letter-spacing:-.01em}.stage-speed{font-size:.625rem;color:var(--text-muted);background:var(--bg-base);border:1px solid var(--border);padding:.125rem .5rem;border-radius:var(--radius-sm);font-family:var(--font-mono)}.layer-visual{flex:1;display:flex;align-items:center;justify-content:center;min-height:80px;margin-bottom:.75rem}.hash-table{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.hash-slot{width:20px;height:20px;border-radius:var(--radius-sm);background:#ffffff0f;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.hash-slot.filled{background:var(--success-subtle);border-color:#4caf6e66}.slot-key{font-size:.625rem;color:var(--success);font-family:var(--font-mono)}.normalize-steps{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}.step{font-size:.5625rem;padding:3px 6px;background:var(--warning-subtle);border-radius:var(--radius-sm);color:var(--warning);font-family:var(--font-mono)}.step-arrow{color:var(--text-muted);font-size:.625rem}.embedding-visual{width:100%;height:80px}.vector-space{position:relative;width:100%;height:100%;background:radial-gradient(circle at center,rgba(74,158,255,.08),transparent 70%);border-radius:var(--radius-md);border:1px dashed rgba(74,158,255,.25)}.vector-point{position:absolute;width:6px;height:6px;background:var(--info);border-radius:50%;box-shadow:0 0 8px #4a9eff80;animation:float 3s ease-in-out infinite}.vector-point:nth-child(odd){animation-delay:-1.5s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.query-vector{position:absolute;left:50%;top:50%;width:10px;height:10px;background:#f472b6;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px #f472b699;animation:pulse-query 1.5s ease-in-out infinite}@keyframes pulse-query{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.3)}}.llm-visual{display:flex;flex-direction:column;align-items:center;gap:.5rem}.llm-icon{font-size:1.75rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.llm-label{font-size:.6875rem;color:var(--text-secondary)}.llm-time{font-size:.625rem;color:var(--error);background:var(--error-subtle);padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-mono)}.layer-queries{min-height:40px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.query-particle{padding:3px 9px;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;animation:particle-enter .3s ease;position:relative;font-family:var(--font-mono)}@keyframes particle-enter{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.query-particle.entering{background:var(--accent);color:#fff}.query-particle.l1-check,.query-particle.l1-hit{background:var(--success);color:#fff}.query-particle.l2-check,.query-particle.l2-hit{background:var(--warning);color:#fff}.query-particle.l3-check,.query-particle.l3-hit{background:var(--info);color:#fff}.query-particle.miss{background:var(--error);color:#fff}.hit-badge,.miss-badge{font-size:.5625rem;font-weight:700;animation:badge-pop .3s ease}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.layer-description{text-align:center;font-size:.5625rem;color:var(--text-muted);margin-top:auto}.flow-connector{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:32px;position:relative}.connector-line{width:24px;height:1px;background:var(--border-strong);position:relative}.connector-line:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);border:3px solid transparent;border-left-color:var(--border-strong)}.connector-arrow{font-size:.875rem;color:var(--text-muted)}.connector-label{font-size:.5625rem;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}.miss-line{background:#e5484d66}.miss-line:after{border-left-color:#e5484d66}.miss-label{color:var(--error)}.event-log{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1rem;display:flex;flex-direction:column}.event-log h2{margin:0 0 .75rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.events-container{flex:1;overflow-y:auto;max-height:400px}.event-item{padding:.5rem .75rem;margin-bottom:.375rem;border-radius:var(--radius-md);font-size:.6875rem;animation:event-slide .3s ease;border-left:2px solid;font-family:var(--font-mono)}@keyframes event-slide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.event-item.hit{background:var(--success-subtle);border-left-color:var(--success);color:#6ee7b7}.event-item.miss{background:var(--error-subtle);border-left-color:var(--error);color:#fca5a5}.event-item.check{background:var(--info-subtle);border-left-color:var(--info);color:#93c5fd}.event-item.info{background:var(--accent-subtle);border-left-color:var(--accent);color:#a5b4fc}.no-events{color:var(--text-muted);font-style:normal;text-align:center;padding:1.25rem;font-size:.8125rem}.cache-contents{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.125rem;margin-bottom:1.25rem}.cache-contents h2{margin:0 0 1rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.cache-entries{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.5rem}.cache-entry{display:flex;justify-content:space-between;align-items:center;padding:.625rem .875rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);animation:entry-appear .3s ease}@keyframes entry-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.entry-query{font-size:.75rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;font-family:var(--font-mono)}.entry-hits{font-size:.6875rem;color:var(--success);background:var(--success-subtle);padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap;font-weight:600;font-variant-numeric:tabular-nums}.no-cache{color:var(--text-muted);font-style:normal;text-align:center;padding:1.25rem;grid-column:1 / -1;font-size:.8125rem}.sim-legend{display:flex;justify-content:center;gap:1.75rem;padding:.875rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-secondary);font-weight:500}.legend-color{width:8px;height:8px;border-radius:50%}.legend-item.l1 .legend-color{background:var(--success)}.legend-item.l2 .legend-color{background:var(--warning)}.legend-item.l3 .legend-color{background:var(--info)}.legend-item.miss .legend-color{background:var(--error)}.query-queue{min-height:50px;display:flex;flex-direction:column;gap:6px;padding:8px}.query-text{font-size:.625rem}.input-stage{border-color:var(--border-accent)}.output-stage{border-color:#e5484d40}@media (max-width: 1200px){.sim-main{grid-template-columns:1fr}.stats-panel{order:-1}.event-log{max-height:200px}.flow-container{flex-wrap:wrap;justify-content:center}.flow-connector{display:none}}@media (max-width: 768px){.sim-header{flex-direction:column;gap:1rem;text-align:center}.sim-controls{flex-wrap:wrap;justify-content:center}.sim-legend{flex-wrap:wrap;gap:1rem}}.cross-user-simulation{background:var(--bg-base);color:var(--text-primary);padding:1.5rem;font-family:var(--font-sans)}.simulation-header{text-align:center;margin-bottom:1.75rem}.simulation-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem;font-weight:600;letter-spacing:-.03em}.subtitle{color:var(--text-secondary);font-size:1rem;margin-bottom:1.5rem}.hero-stats{display:flex;gap:2.5rem;justify-content:center;margin:1.5rem 0;flex-wrap:wrap}.hero-stat{text-align:center;padding:.75rem}.hero-stat-value{font-size:2.25rem;font-weight:600;color:var(--success);margin-bottom:.375rem;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.hero-stat-label{color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.simulation-divider{text-align:center;margin:3rem 0 1.75rem;padding:1.75rem 0;border-top:1px solid var(--border)}.simulation-divider h2{font-size:1.625rem;color:var(--text-primary);font-weight:600;margin-bottom:.625rem;letter-spacing:-.025em}.divider-subtitle{color:var(--text-secondary);font-size:.9375rem;max-width:600px;margin:0 auto;line-height:1.55}.controls{display:flex;justify-content:center;align-items:center;gap:.875rem;margin-bottom:1.75rem;flex-wrap:wrap}.control-btn{padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--transition);font-family:var(--font-sans);color:#fff}.control-btn.start{background:var(--success)}.control-btn.start:hover{background:#5cba7e}.control-btn.stop{background:var(--warning)}.control-btn.stop:hover{background:#f5a93b}.control-btn.reset{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary)}.control-btn.reset:hover{background:var(--bg-hover);border-color:var(--border-strong)}.speed-control{display:flex;align-items:center;gap:.625rem;color:var(--text-secondary);font-size:.8125rem}.speed-control input{width:100px;accent-color:var(--accent)}.visualization-container{display:grid;grid-template-columns:280px 1fr 300px;gap:1.25rem;margin-bottom:1.75rem;min-height:400px}.users-panel{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.25rem;border:1px solid var(--border)}.users-panel h3{margin-bottom:.875rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.users-grid{display:flex;flex-direction:column;gap:.5rem}.user-card{display:flex;align-items:center;gap:.625rem;padding:.625rem;background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);transition:background var(--transition),border-color var(--transition);position:relative;overflow:hidden}.user-card.active{border-color:var(--user-color);background:var(--bg-hover)}.user-card.hit{animation:hitPulse .5s ease}.user-card.hit:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(76,175,110,.18),transparent);animation:hitSweep .5s ease}.user-card.miss{animation:missGlow 1s ease infinite}@keyframes hitPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes hitSweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes missGlow{0%,to{box-shadow:0 0 #f59f0b33}50%{box-shadow:0 0 0 4px #f59f0b26}}.user-avatar{font-size:1.25rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff0f;border-radius:50%}.user-info{flex:1}.user-name{font-weight:600;color:var(--user-color);font-size:.875rem;letter-spacing:-.01em}.user-role{font-size:.6875rem;color:var(--text-muted)}.user-status{font-size:.625rem;padding:.125rem .5rem;border-radius:var(--radius-sm);background:var(--bg-base);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.status-hit{color:var(--success)}.status-miss{color:var(--warning)}.status-processing{color:var(--info)}.cache-visualization{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.central-cache{width:200px;height:200px;background:var(--accent-subtle);border:2px solid var(--border-accent);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;animation:cacheGlow 3s ease-in-out infinite}@keyframes cacheGlow{0%,to{box-shadow:0 0 0 1px #5e6ad233,0 0 32px #5e6ad226}50%{box-shadow:0 0 0 1px #5e6ad266,0 0 48px #5e6ad240}}.cache-icon{font-size:2.5rem;margin-bottom:.5rem}.cache-label{font-size:.8125rem;color:var(--text-secondary);text-align:center;font-weight:500}.cache-count{font-size:1.0625rem;font-weight:600;color:var(--success);margin-top:.25rem;font-variant-numeric:tabular-nums}.connections-svg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.connection-line{stroke-width:2;stroke-dasharray:5,5;opacity:0;transition:opacity .3s ease}.connection-line.active{opacity:.8;animation:connectionPulse .5s ease}@keyframes connectionPulse{0%{stroke-dashoffset:20;opacity:0}50%{opacity:1}to{stroke-dashoffset:0;opacity:0}}.query-bubbles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.query-bubble{position:absolute;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-surface);border:1px solid var(--user-color);border-radius:var(--radius-md);font-size:.75rem;white-space:nowrap;animation:bubbleFloat 1s ease-out;opacity:.95}.query-bubble.sending{left:10%;top:50%;transform:translateY(-50%)}.query-bubble.processing{left:35%;top:50%;transform:translateY(-50%);animation:bubbleProcess .5s ease}.query-bubble.hit{left:50%;top:30%;transform:translate(-50%,-50%);background:var(--success-subtle);border-color:var(--success);animation:bubbleHit .5s ease}.query-bubble.miss{left:50%;top:70%;transform:translate(-50%,-50%);background:var(--warning-subtle);border-color:var(--warning)}.query-bubble.complete{opacity:0;transition:opacity .3s ease}@keyframes bubbleFloat{0%{opacity:0;transform:translateY(-50%) scale(.8)}to{opacity:.95;transform:translateY(-50%) scale(1)}}@keyframes bubbleProcess{0%,to{transform:translateY(-50%) scale(1)}50%{transform:translateY(-50%) scale(1.05)}}@keyframes bubbleHit{0%{transform:translate(-50%,-50%) scale(.8)}50%{transform:translate(-50%,-50%) scale(1.1)}to{transform:translate(-50%,-50%) scale(1)}}.bubble-avatar{font-size:1rem}.bubble-text{color:var(--text-primary)}.bubble-hit-from{color:var(--success);font-weight:600}.stats-panel{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.25rem;border:1px solid var(--border)}.stats-panel h3{margin-bottom:.875rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.stat-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem;text-align:center;margin-bottom:.75rem}.stat-card.primary{background:var(--accent-subtle);border-color:var(--border-accent)}.stat-card.savings{background:var(--success-subtle);border-color:#4caf6e4d}.stat-value{font-size:2rem;font-weight:600;color:var(--accent);letter-spacing:-.03em;font-variant-numeric:tabular-nums}.stat-card.savings .stat-value{color:var(--success)}.stat-label{font-size:.75rem;color:var(--text-muted);margin-top:.25rem;text-transform:uppercase;letter-spacing:.04em;font-weight:500}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:.875rem}.stat-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:.625rem;text-align:center}.stat-item.hit{border-left:2px solid var(--success)}.stat-item.miss{border-left:2px solid var(--warning)}.stat-num{display:block;font-size:1.25rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.stat-name{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.response-time{margin-top:.875rem}.time-bar{height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.time-fill{height:100%;border-radius:3px;transition:width .3s ease,background-color .3s ease}.time-label{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;text-align:center}.time-compare{color:var(--text-muted);font-size:.625rem;display:block}.feed-cache-container{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;margin-bottom:1.75rem;height:350px}.event-feed{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.25rem;border:1px solid var(--border);height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.event-feed h3{margin-bottom:.875rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.events-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.375rem}.event-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.75rem;animation:eventSlide .3s ease}@keyframes eventSlide{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.event-item.hit{border-left:2px solid var(--success);background:var(--success-subtle)}.event-item.miss{border-left:2px solid var(--warning);background:var(--warning-subtle)}.event-item.info{border-left:2px solid var(--info)}.event-user{font-weight:600}.event-text{flex:1;color:var(--text-primary)}.event-hit-from{font-size:.6875rem;opacity:.85}.cache-contents{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.25rem;border:1px solid var(--border);height:100%;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.cache-contents h3{margin-bottom:.875rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.cache-topics{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.875rem;flex:1;overflow-y:auto}.topic-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:.875rem;border:1px solid var(--border)}.topic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.625rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.topic-name{font-weight:600;color:var(--info);font-size:.8125rem;letter-spacing:-.01em}.topic-count{font-size:.6875rem;color:var(--info);background:var(--info-subtle);padding:.125rem .5rem;border-radius:var(--radius-sm);font-weight:600;font-variant-numeric:tabular-nums}.topic-entries{display:flex;flex-direction:column;gap:.375rem}.topic-entry{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.entry-user{font-size:.875rem}.entry-query{color:var(--text-secondary)}.topic-more{font-size:.6875rem;color:var(--text-muted);text-align:center;margin-top:.5rem}.explanation{background:var(--bg-surface);border-radius:var(--radius-lg);padding:1.75rem;border:1px solid var(--border)}.explanation h3{text-align:center;margin-bottom:1.25rem;font-size:1.125rem;color:var(--text-primary);font-weight:600;letter-spacing:-.02em}.explanation-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.exp-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;text-align:center;transition:background var(--transition),border-color var(--transition)}.exp-card:hover{background:var(--bg-hover);border-color:var(--border-strong)}.exp-icon{font-size:2rem;margin-bottom:.625rem}.exp-title{font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.9375rem;letter-spacing:-.01em}.exp-text{font-size:.8125rem;color:var(--text-secondary);line-height:1.55}@media (max-width: 1200px){.visualization-container{grid-template-columns:1fr;gap:1.25rem}.users-panel{order:1}.cache-visualization{order:2;min-height:300px}.stats-panel{order:3}.users-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.625rem}.feed-cache-container{grid-template-columns:1fr}.explanation-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.cross-user-simulation{padding:1rem}.simulation-header h1{font-size:1.5rem}.users-grid{grid-template-columns:repeat(2,1fr)}.controls{flex-direction:column}.stat-grid{grid-template-columns:repeat(3,1fr)}.explanation-cards{grid-template-columns:1fr 1fr}.feed-cache-container{grid-template-columns:1fr}}.try-it-section{background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:var(--radius-lg);padding:1.75rem;margin:1.75rem auto;max-width:900px}.try-it-section.featured{border:1px solid rgba(76,175,110,.4);animation:featurePulse 2s ease-in-out infinite}@keyframes featurePulse{0%,to{box-shadow:0 0 #4caf6e00}50%{box-shadow:0 0 0 4px #4caf6e1f}}.try-it-section h2{text-align:center;font-size:1.5rem;color:var(--text-primary);font-weight:600;letter-spacing:-.025em;margin-bottom:1.25rem}.try-it-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:1rem}.api-toggle{display:flex;align-items:center}.toggle-label{display:flex;align-items:center;gap:.625rem;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{display:none}.toggle-switch{position:relative;width:36px;height:20px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;transition:background var(--transition)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:var(--text-primary);border-radius:50%;transition:transform var(--transition)}.toggle-label input[type=checkbox]:checked+.toggle-switch{background:var(--success);border-color:var(--success)}.toggle-label input[type=checkbox]:checked+.toggle-switch:after{transform:translate(16px);background:#fff}.toggle-text{color:var(--text-primary);font-size:.8125rem;font-weight:500}.api-status{padding:.125rem .625rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;margin-left:.5rem;text-transform:uppercase;letter-spacing:.04em}.api-status.checking{background:var(--warning-subtle);color:var(--warning)}.api-status.online{background:var(--success-subtle);color:var(--success)}.api-status.offline{background:var(--error-subtle);color:var(--error)}.cache-info{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--info-subtle);border:1px solid rgba(74,158,255,.3);border-radius:var(--radius-md);font-size:.8125rem;color:var(--info)}.cache-info-icon{font-size:1rem}.try-it-form{display:flex;gap:.75rem;margin-bottom:1.25rem}.try-it-input{flex:1;padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);color:var(--text-primary);font-size:.9375rem;transition:border-color var(--transition),box-shadow var(--transition);font-family:var(--font-sans)}.try-it-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.try-it-input::placeholder{color:var(--text-muted)}.try-it-button{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);background:var(--accent);color:#fff;font-size:.9375rem;font-weight:500;cursor:pointer;transition:background var(--transition);white-space:nowrap;font-family:var(--font-sans)}.try-it-button:hover:not(:disabled){background:var(--accent-hover)}.try-it-button:disabled{opacity:.5;cursor:not-allowed}.try-it-results{margin-bottom:1.25rem}.try-it-results h4{color:var(--text-secondary);font-size:.75rem;font-weight:600;margin-bottom:.625rem;text-transform:uppercase;letter-spacing:.06em}.try-it-result{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:.875rem;margin-bottom:.625rem;border-left:2px solid transparent}.try-it-result.hit{border-left-color:var(--success);background:var(--success-subtle)}.try-it-result.miss{border-left-color:var(--warning);background:var(--warning-subtle)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.result-badge{padding:.125rem .625rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.result-badge.hit{background:var(--success-subtle);color:var(--success)}.result-badge.miss{background:var(--warning-subtle);color:var(--warning)}.result-time{color:var(--text-secondary);font-size:.8125rem;font-weight:600;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.result-query{color:var(--text-primary);font-size:.875rem;margin-bottom:.5rem}.result-match{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.8125rem}.match-arrow{color:var(--success);font-weight:700}.match-text{color:var(--text-secondary);flex:1}.match-similarity{padding:.125rem .5rem;background:var(--success-subtle);color:var(--success);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;font-variant-numeric:tabular-nums}.result-savings{margin-top:.5rem;color:var(--success);font-size:.8125rem;font-weight:600}.try-it-suggestions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.suggestions-label{color:var(--text-secondary);font-size:.8125rem;margin-right:.5rem}.suggestion-chip{padding:.3125rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition);font-family:var(--font-sans)}.suggestion-chip:hover{background:var(--accent-subtle);border-color:var(--border-accent);color:var(--accent)}.events-list::-webkit-scrollbar,.cache-topics::-webkit-scrollbar{width:6px}.events-list::-webkit-scrollbar-track,.cache-topics::-webkit-scrollbar-track{background:transparent}.events-list::-webkit-scrollbar-thumb,.cache-topics::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}.events-list::-webkit-scrollbar-thumb:hover,.cache-topics::-webkit-scrollbar-thumb:hover{background:#ffffff26}@media (max-width: 768px){.try-it-form{flex-direction:column}.try-it-controls{flex-direction:column;align-items:stretch}.hero-stats{gap:1.5rem}.hero-stat-value{font-size:1.75rem}}.home-page{min-height:100vh;background:var(--bg-base);color:var(--text-primary);overflow-x:hidden}.hero{position:relative;min-height:88vh;display:flex;align-items:center;justify-content:center;padding:5rem 1.5rem;overflow:hidden;border-bottom:1px solid var(--border)}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(94,106,210,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(94,106,210,.04) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%)}.hero-orb{display:none}.hero-content{position:relative;z-index:10;text-align:center;max-width:820px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .875rem;background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:#a5b4fc;margin-bottom:2rem}.badge-icon{font-size:.875rem}.hero-title{font-size:clamp(2.5rem,7vw,4.5rem);font-weight:600;line-height:1.05;margin-bottom:1.5rem;letter-spacing:-.035em;color:var(--text-primary)}.title-gradient{background:linear-gradient(135deg,#5e6ad2,#7b8ee8,#8a9cf0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.125rem;color:var(--text-secondary);line-height:1.6;max-width:640px;margin:0 auto 2.5rem;font-weight:400}.hero-subtitle strong{color:var(--success);font-weight:600}.hero-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:4rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.125rem;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition);border:none;text-decoration:none;font-family:var(--font-sans);letter-spacing:-.005em}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.btn-primary{background:var(--accent);color:#fff;box-shadow:inset 0 0 0 1px #ffffff14}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-primary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.hero-stats{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:1.75rem;font-weight:600;color:var(--accent);letter-spacing:-.03em;font-variant-numeric:tabular-nums}.stat-label{font-size:.8125rem;color:var(--text-muted);font-weight:500}.stat-divider{width:1px;height:32px;background:var(--border)}.section{padding:5rem 1.5rem;border-bottom:1px solid var(--border)}.section-container{max-width:1120px;margin:0 auto}.section-header{text-align:center;margin-bottom:3.5rem}.section-badge{display:inline-block;padding:.25rem .75rem;background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:#a5b4fc;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.04em}.section-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:600;margin-bottom:.75rem;letter-spacing:-.03em;color:var(--text-primary)}.section-subtitle{font-size:1rem;color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.how-it-works{background:var(--bg-base)}.flow-diagram{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}.flow-step{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;text-align:center;max-width:280px;flex:1;min-width:240px;transition:background var(--transition),border-color var(--transition)}.flow-step:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.flow-step.highlighted{background:var(--accent-subtle);border-color:var(--border-accent)}.flow-icon{width:48px;height:48px;margin:0 auto 1.25rem;background:var(--accent-subtle);color:var(--accent);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.flow-icon svg{width:24px;height:24px}.flow-step h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.01em}.flow-step p{color:var(--text-secondary);font-size:.875rem;line-height:1.55}.flow-layers{display:flex;gap:.375rem;justify-content:center;margin-top:.875rem;flex-wrap:wrap}.layer{padding:.125rem .5rem;background:var(--accent-subtle);border-radius:var(--radius-sm);font-size:.6875rem;color:#a5b4fc;font-weight:500}.flow-arrow{color:var(--text-muted);flex-shrink:0}.flow-arrow svg{width:20px;height:20px}.features{background:var(--bg-base)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.feature-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;transition:background var(--transition),border-color var(--transition)}.feature-card:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.feature-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}.feature-icon svg{width:20px;height:20px}.feature-icon-purple{background:#8b5cf61f;color:#a78bfa}.feature-icon-blue{background:#4a9eff1f;color:#60a5fa}.feature-icon-green{background:#4caf6e1f;color:#34d399}.feature-icon-orange{background:#f59f0b1f;color:#fb923c}.feature-icon-pink{background:#ec48991f;color:#f472b6}.feature-icon-cyan{background:#06b6d41f;color:#22d3ee}.feature-card h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.01em;color:var(--text-primary)}.feature-card>p{color:var(--text-secondary);font-size:.875rem;line-height:1.55;margin-bottom:1rem}.feature-list{list-style:none;padding:0;margin:0}.feature-list li{position:relative;padding-left:1.25rem;color:var(--text-muted);font-size:.8125rem;margin-bottom:.375rem;line-height:1.5}.feature-list li:before{content:"";position:absolute;left:0;top:.5rem;width:12px;height:2px;background:var(--accent);border-radius:1px}.architecture{background:var(--bg-base)}.architecture-diagram{display:flex;align-items:stretch;justify-content:center;gap:0;margin-bottom:3rem;flex-wrap:wrap}.arch-layer{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;max-width:280px;flex:1;min-width:220px;transition:background var(--transition),border-color var(--transition)}.arch-layer:hover{background:var(--bg-elevated)}.layer-1{border-color:#4caf6e40}.layer-1:hover{border-color:#4caf6e66}.layer-2{border-color:#4a9eff40}.layer-2:hover{border-color:#4a9eff66}.layer-3{border-color:#8b5cf640}.layer-3:hover{border-color:#8b5cf666}.layer-header{margin-bottom:1rem}.layer-badge{display:inline-block;padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.04em}.layer-1 .layer-badge{background:#4caf6e26;color:#34d399}.layer-2 .layer-badge{background:#4a9eff26;color:#60a5fa}.layer-3 .layer-badge{background:#8b5cf626;color:#a78bfa}.layer-header h3{font-size:1rem;font-weight:600;letter-spacing:-.01em}.layer-content{text-align:center}.layer-icon{width:40px;height:40px;margin:0 auto 1rem;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.layer-1 .layer-icon{background:#4caf6e26;color:#34d399}.layer-2 .layer-icon{background:#4a9eff26;color:#60a5fa}.layer-3 .layer-icon{background:#8b5cf626;color:#a78bfa}.layer-icon svg{width:20px;height:20px}.layer-content p{color:var(--text-secondary);font-size:.8125rem;margin-bottom:1rem;line-height:1.5}.layer-speed{display:inline-block;padding:.125rem .5rem;background:#4caf6e1f;color:#34d399;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;font-family:var(--font-mono)}.arch-connector{display:flex;flex-direction:column;align-items:center;padding:0 .75rem;align-self:center}.connector-line{width:32px;height:1px;background:var(--border-strong)}.connector-label{font-size:.6875rem;color:var(--text-muted);margin-top:.375rem;text-transform:uppercase;letter-spacing:.04em}.arch-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:900px;margin:0 auto}.benefit-item{display:flex;align-items:center;gap:.625rem;padding:.875rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md)}.benefit-icon{font-size:1.125rem}.benefit-text{color:var(--text-secondary);font-size:.875rem}.demos{background:var(--bg-base)}.demo-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.demo-card{display:flex;gap:1.25rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:background var(--transition),border-color var(--transition);align-items:flex-start}.demo-card:hover{background:var(--bg-elevated);border-color:var(--border-accent)}.demo-card-icon{flex-shrink:0;width:40px;height:40px;background:var(--accent-subtle);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent)}.demo-card-icon svg{width:20px;height:20px}.demo-card-content{flex:1}.demo-card-content h3{font-size:1rem;font-weight:600;margin-bottom:.375rem;letter-spacing:-.01em;color:var(--text-primary)}.demo-card-content p{color:var(--text-secondary);font-size:.875rem;line-height:1.5;margin-bottom:.625rem}.demo-link{color:var(--accent);font-size:.8125rem;font-weight:500;transition:color var(--transition)}.demo-card:hover .demo-link{color:var(--accent-hover)}.tech-stack{background:var(--bg-base)}.tech-grid{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.tech-item{display:flex;flex-direction:column;align-items:center;gap:.625rem;padding:1.25rem 1.5rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:background var(--transition),border-color var(--transition);min-width:120px}.tech-item:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.tech-icon-img{width:40px;height:40px;object-fit:contain}.tech-item span{color:var(--text-primary);font-size:.8125rem;font-weight:500}.cta{background:var(--bg-surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.cta-content{text-align:center}.cta-content h2{font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:600;margin-bottom:.875rem;letter-spacing:-.03em;color:var(--text-primary)}.cta-content>p{color:var(--text-secondary);font-size:1rem;margin-bottom:2rem;line-height:1.6}.cta-buttons{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.footer{background:var(--bg-base);padding:2.5rem 1.5rem;border-top:1px solid var(--border)}.footer-content{max-width:1120px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.footer-brand{display:flex;align-items:center;gap:.5rem}.footer-logo{font-size:1.25rem}.footer-name{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.footer-links{display:flex;gap:1.5rem}.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.8125rem;transition:color var(--transition);font-weight:500}.footer-links a:hover{color:var(--text-primary)}.footer-license{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.8125rem}.footer-separator{color:var(--text-muted);opacity:.5}@media (max-width: 960px){.features-grid,.arch-benefits{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.hero{padding:4rem 1.25rem}.hero-stats{gap:1.5rem}.stat-divider{display:none}.flow-arrow{transform:rotate(90deg)}.architecture-diagram{flex-direction:column;gap:.75rem}.arch-connector{transform:rotate(90deg);padding:.5rem 0}.features-grid,.demo-cards,.arch-benefits{grid-template-columns:1fr}.demo-card{flex-direction:column;text-align:left}}.app-container{display:flex;flex-direction:column;min-height:100vh;overflow:auto;background:var(--bg-base)}.app-container.simulation-view,.app-container.admin-view{background:var(--bg-base);overflow:auto}.app-nav{display:flex;align-items:center;gap:0;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0;position:relative;z-index:100;height:52px}.nav-brand{background:transparent!important;color:var(--text-primary)!important;font-weight:600!important;font-size:.9rem!important;border-right:1px solid var(--border)!important;letter-spacing:-.01em}.nav-brand:hover{background:var(--bg-elevated)!important}.nav-spacer{flex:1}.nav-btn{padding:0 1rem;height:52px;background:transparent;color:var(--text-secondary);border:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:color var(--transition),background var(--transition);border-bottom:2px solid transparent;display:flex;align-items:center;gap:.5rem;font-family:var(--font-sans)}.nav-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-btn.active{background:transparent;color:var(--text-primary);border-bottom-color:var(--accent)}.nav-dropdown{position:relative;height:52px}.nav-dropdown-trigger{display:flex;align-items:center;gap:.375rem}.dropdown-arrow{transition:transform var(--transition);opacity:.6}.dropdown-arrow.open{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:100%;left:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);min-width:200px;overflow:hidden;animation:slideDown .12s ease;margin-top:4px;padding:4px}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:block;width:100%;padding:.5rem .75rem;background:transparent;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;text-align:left;cursor:pointer;transition:background var(--transition),color var(--transition);border-radius:var(--radius-md);font-family:var(--font-sans)}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-item.active{background:var(--accent-subtle);color:var(--text-primary)}.dropdown-item+.dropdown-item{border-top:none}.app{display:flex;flex-direction:column;flex:1}.header{background:var(--bg-surface);border-bottom:1px solid var(--border);color:var(--text-primary);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.header h1{font-size:1.125rem;font-weight:600;letter-spacing:-.02em}.stats{display:flex;align-items:center;gap:1rem;font-size:.8125rem;color:var(--text-secondary)}.clear-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border);padding:.375rem .75rem;border-radius:var(--radius-md);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all var(--transition);font-family:var(--font-sans)}.clear-btn:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-strong)}.chat-container{flex:1;display:flex;flex-direction:column;max-width:960px;margin:0 auto;width:100%;padding:1.5rem;overflow:hidden}.messages{flex:1;overflow-y:auto;padding:.5rem 0;display:flex;flex-direction:column;gap:1rem}.welcome{text-align:center;padding:3rem 2rem;color:var(--text-secondary)}.welcome h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.welcome p{margin-bottom:.5rem;line-height:1.6;font-size:.9375rem}.hint{font-style:normal;font-size:.8125rem;margin-top:1rem!important;color:var(--text-muted)}.message{display:flex;margin-bottom:.25rem}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{max-width:70%;padding:.75rem 1rem;border-radius:var(--radius-lg);word-wrap:break-word;font-size:.9375rem;line-height:1.5}.message.user .message-content{background:var(--accent);color:#fff}.message.assistant .message-content{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border)}.message-content p{margin:0;line-height:1.5}.message-meta{margin-top:.5rem;font-size:.75rem;opacity:.85;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.cached-badge{background:var(--success-subtle);color:var(--success);padding:.125rem .5rem;border-radius:var(--radius-sm);font-weight:500;font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em}.fresh-badge{background:var(--info-subtle);color:var(--info);padding:.125rem .5rem;border-radius:var(--radius-sm);font-weight:500;font-size:.6875rem;text-transform:uppercase;letter-spacing:.03em}.typing-indicator{display:flex;gap:.25rem;padding:.5rem 0}.typing-indicator span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.input-form{display:flex;gap:.5rem;padding:.75rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:1rem}.input-field{flex:1;padding:.625rem .875rem;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-primary);border-radius:var(--radius-md);font-size:.9375rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);font-family:var(--font-sans)}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.input-field:disabled{background:var(--bg-surface);color:var(--text-muted);cursor:not-allowed}.send-btn{padding:.625rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background var(--transition);font-family:var(--font-sans)}.send-btn:hover:not(:disabled){background:var(--accent-hover)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.messages::-webkit-scrollbar{width:6px}.messages::-webkit-scrollbar-track{background:transparent}.messages::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.messages::-webkit-scrollbar-thumb:hover{background:#ffffff26}:root{--bg-base: #0f0f0f;--bg-surface: #161618;--bg-elevated: #1c1c1e;--bg-hover: #232326;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--border-accent: rgba(94, 106, 210, .3);--accent: #5e6ad2;--accent-hover: #6875d9;--accent-pressed: #4f59b8;--accent-subtle: rgba(94, 106, 210, .12);--accent-glow: rgba(94, 106, 210, .25);--text-primary: #e8e8e8;--text-secondary: #8a8f98;--text-muted: #5a5f6a;--text-inverse: #0f0f0f;--success: #4caf6e;--success-subtle: rgba(76, 175, 110, .15);--error: #e5484d;--error-subtle: rgba(229, 72, 77, .15);--warning: #f59f0b;--warning-subtle: rgba(245, 159, 11, .15);--info: #4a9eff;--info-subtle: rgba(74, 158, 255, .15);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--transition: .15s ease;--transition-slow: .25s ease;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Menlo, Monaco, Consolas, "Courier New", monospace;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);font-feature-settings:"cv11","ss01","ss03";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-base);color:var(--text-primary);letter-spacing:-.011em}code{font-family:var(--font-mono)}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}
