@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;600;700;800&family=Fira+Code:wght@400;500&display=swap";:root,[data-theme=light]{--bg-primary:#f3f4f6;--bg-secondary:#fff;--bg-tertiary:#e8eaed;--color-green:#1b9849;--color-green-glow:#22c55e14;--color-purple:#641ae6;--color-purple-glow:#8b5cf614;--color-red:#cf1736;--color-red-glow:#ef444414;--color-amber:#c47f08;--color-amber-glow:#f59e0b14;--text-primary:#131720;--text-secondary:#607085;--text-muted:#8d97a5;--border-glow:#8b5cf626;--border-muted:#0000000f;--border-hover:#0000001f;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display:"Outfit", sans-serif;--font-mono:"Fira Code", monospace;--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--grid-line:#00000004;--radial-glow-1:#8b5cf608;--radial-glow-2:#22c55e05;--glass-shadow:0 4px 20px -2px #00000008, 0 2px 8px -1px #00000003;--glass-shadow-hover:0 10px 25px -5px #0000000d, 0 4px 12px -2px #00000005}[data-theme=dark]{--bg-primary:#0b0e13;--bg-secondary:#131720;--bg-tertiary:#1f232e;--color-green:#1dc95c;--color-green-glow:#22c55e1f;--color-purple:#9055f6;--color-purple-glow:#a855f71f;--color-red:#ee2b4b;--color-red-glow:#ef44441f;--color-amber:#f9a006;--color-amber-glow:#f59e0b1f;--text-primary:#f8fafc;--text-secondary:#b3bdcc;--text-muted:#7a899f;--border-glow:#a855f740;--border-muted:#ffffff14;--border-hover:#ffffff29;--grid-line:#ffffff05;--radial-glow-1:#a855f714;--radial-glow-2:#22c55e0f;--glass-shadow:0 4px 30px #0006, 0 2px 10px #0003;--glass-shadow-hover:0 10px 40px #0009, 0 4px 20px #0000004d}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;transition:background-color var(--transition-normal), color var(--transition-normal);background-image:radial-gradient(at 0% 0%, var(--radial-glow-1) 0px, transparent 50%), radial-gradient(at 100% 0%, var(--radial-glow-2) 0px, transparent 50%), linear-gradient(to right, var(--grid-line) 1px, transparent 1px), linear-gradient(to bottom, var(--grid-line) 1px, transparent 1px);background-size:100% 100%,100% 100%,50px 50px,50px 50px;position:relative;overflow-x:hidden}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #22c55e4d}70%{transform:scale(1);box-shadow:0 0 0 6px #22c55e00}to{transform:scale(.95);box-shadow:0 0 #22c55e00}}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 #ef44444d}70%{transform:scale(1);box-shadow:0 0 0 6px #ef444400}to{transform:scale(.95);box-shadow:0 0 #ef444400}}@keyframes flash-red-bg{0%{background-color:#ef444400}10%{background-color:#ef444408}to{background-color:#ef444400}}@keyframes slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.dashboard-container{width:100vw;min-height:100vh;display:flex}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-muted);z-index:10;flex-direction:column;flex-shrink:0;width:270px;padding:32px 24px;display:flex}.logo-section{align-items:center;gap:12px;margin-bottom:40px;display:flex}.logo-text{font-family:var(--font-display);letter-spacing:-.5px;background:linear-gradient(to right, var(--text-primary), #525f7a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:6px;font-size:1.4rem;font-weight:800;display:flex}.shield-badge{color:var(--color-green);font-size:.65rem;font-weight:700;font-family:var(--font-sans);letter-spacing:.5px;background-color:#22c55e0f;border:1px solid #22c55e66;border-radius:4px;padding:2px 6px}.menu-list{flex-direction:column;gap:8px;list-style:none;display:flex}.menu-item{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:500;display:flex}.menu-item:hover{background-color:var(--bg-primary);color:var(--text-primary)}.menu-item.active{color:var(--color-purple);background-color:#8b5cf60f;border-color:#8b5cf61a}.sidebar-footer{border-top:1px solid var(--border-muted);flex-direction:column;gap:12px;margin-top:auto;padding-top:24px;display:flex}.engine-status-card{background:var(--bg-primary);border:1px solid var(--border-muted);border-radius:8px;flex-direction:column;gap:6px;padding:14px;font-size:.8rem;display:flex}.status-row{justify-content:space-between;align-items:center;display:flex}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.green{background-color:var(--color-green);animation:2s infinite pulse-green}.dot.purple{background-color:var(--color-purple)}.dot.red{background-color:var(--color-red);animation:2s infinite pulse-red}.main-content{flex-direction:column;flex-grow:1;gap:32px;height:100vh;padding:40px;display:flex;overflow-y:auto}.header-section{justify-content:space-between;align-items:flex-start;display:flex}.header-title{font-family:var(--font-display);letter-spacing:-.5px;color:var(--text-primary);font-size:2.2rem;font-weight:700}.header-subtitle{color:var(--text-secondary);margin-top:4px;font-size:.95rem}.glass-panel{background:var(--bg-secondary);border:1px solid var(--border-muted);box-shadow:var(--glass-shadow);transition:background-color var(--transition-normal), border-color var(--transition-normal), box-shadow var(--transition-normal), transform var(--transition-fast);border-radius:12px;padding:24px;animation:.4s ease-out slide-in}.glass-panel:hover{border-color:var(--border-hover);box-shadow:var(--glass-shadow-hover)}.glass-panel.glowing-green{box-shadow:var(--glass-shadow), 0 0 20px #22c55e0d;border-color:#22c55e59}.glass-panel.glowing-purple{box-shadow:var(--glass-shadow), 0 0 20px #a855f70d;border-color:#a855f759}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.stat-card{flex-direction:column;gap:12px;display:flex}.stat-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:600;display:flex}.stat-value{font-family:var(--font-display);color:var(--text-primary);align-items:baseline;gap:8px;font-size:2rem;font-weight:700;display:flex}.stat-value-sub{color:var(--text-secondary);font-size:.85rem;font-family:var(--font-sans);font-weight:400}.input-field{background-color:var(--bg-primary);border:1px solid var(--border-muted);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-fast);border-radius:8px;outline:none;padding:12px 16px;font-size:.95rem}.input-field:focus{border-color:var(--color-purple);background-color:var(--bg-secondary);box-shadow:0 0 0 3px #8b5cf61a}.btn{cursor:pointer;transition:var(--transition-fast);font-size:.95rem;font-weight:600;font-family:var(--font-sans);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;display:inline-flex}.btn-primary{background-color:var(--color-purple);color:#fff;box-shadow:0 4px 12px #8b5cf633}.btn-primary:hover{background-color:#5c17d3;transform:translateY(-1px);box-shadow:0 6px 16px #8b5cf64d}.btn-secondary{background-color:var(--bg-secondary);border:1px solid var(--border-muted);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--bg-primary);border-color:var(--text-secondary)}.gauge-container{flex-direction:column;gap:16px;display:flex}.gauge-row{align-items:center;gap:16px;display:flex}.gauge-label{width:170px;color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.gauge-bar-bg{background-color:var(--bg-primary);border-radius:4px;flex-grow:1;height:8px;position:relative;overflow:hidden}.gauge-bar-fill{border-radius:4px;width:0%;height:100%;transition:width .6s cubic-bezier(.1,.8,.2,1)}.gauge-bar-fill.safe{background-color:var(--color-green)}.gauge-bar-fill.warning{background-color:var(--color-amber)}.gauge-bar-fill.danger{background-color:var(--color-red)}.gauge-value{text-align:right;width:48px;font-size:.85rem;font-weight:600;font-family:var(--font-mono)}.console-split{grid-template-columns:1.2fr 1fr;gap:24px;height:700px;display:grid}.console-editor{flex-direction:column;gap:16px;display:flex}.console-terminal{font-family:var(--font-mono);background-color:#0a0b10;border:1px solid #0000001a;border-radius:8px;flex-direction:column;gap:8px;padding:20px;font-size:.85rem;display:flex;position:relative;overflow-y:auto}.code-green{color:#22c35d}.code-purple{color:#935eed}.code-red{color:#e8304f;font-weight:600}.code-yellow{color:#f59f0a}.code-blue{color:#4ca6ff}.code-muted{color:#707d8f}.code-block-container{background-color:#0a0b10;border:1px solid #0000001a;border-radius:8px;margin-top:12px;position:relative;overflow:hidden}.code-block-header{color:#94a3b8;background-color:#12151c;border-bottom:1px solid #0000001a;justify-content:space-between;align-items:center;padding:10px 16px;font-size:.8rem;display:flex}.code-block-content{font-family:var(--font-mono);white-space:pre;color:#dbe6f0;padding:16px;font-size:.85rem;line-height:1.6;overflow-x:auto}.copy-btn{color:#94a3b8;cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;align-items:center;gap:6px;font-size:.75rem;display:flex}.copy-btn:hover{color:#dbe6f0}.violation-list{flex-direction:column;gap:12px;max-height:400px;display:flex;overflow-y:auto}.violation-card{background-color:#ef444405;border:1px solid #ef444414;border-radius:8px;flex-direction:column;gap:8px;padding:16px;animation:.3s ease-out slide-in;display:flex;position:relative}.violation-card:before{content:"";background-color:var(--color-red);border-top-left-radius:8px;border-bottom-left-radius:8px;width:4px;position:absolute;top:0;bottom:0;left:0}.violation-header{justify-content:space-between;align-items:center;display:flex}.violation-title{color:var(--color-red);font-family:var(--font-display);font-size:.95rem;font-weight:700}.violation-time{color:var(--text-muted);font-size:.75rem}.security-alert-overlay{animation:2s flash-red-bg}@media (width<=1200px){.console-split{grid-template-columns:1fr;gap:30px;height:auto}}@media (width<=1024px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.dashboard-container{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border-muted);width:100%;padding:20px}.logo-section{justify-content:center;margin-bottom:20px}.menu-list{flex-flow:wrap;justify-content:center;gap:6px}.menu-item{padding:10px 14px;font-size:.9rem}.sidebar-footer{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:20px;padding-top:16px;display:grid}.main-content{height:auto;padding:20px;overflow-y:visible}.header-section{flex-direction:column;align-items:stretch;gap:16px}.header-title{font-size:1.8rem}.grid-3,.grid-2{grid-template-columns:1fr}.console-split{grid-template-columns:1fr;height:auto}.console-editor{min-height:auto}}@media (width<=480px){.sidebar-footer{grid-template-columns:1fr}}.input-field:focus-visible,.btn:focus-visible,.menu-item:focus-visible{outline:2px solid var(--color-purple);outline-offset:2px}.attack-card-interactive{background:var(--bg-secondary);border:1px solid var(--border-muted);box-shadow:var(--glass-shadow);cursor:pointer;transition:all var(--transition-normal);border-radius:8px;padding:16px}.attack-card-interactive:hover{border-color:var(--border-hover);box-shadow:var(--glass-shadow-hover);transform:translateY(-2px)}.attack-card-interactive.selected{border-color:var(--color-red)!important;background:#ef444405!important;box-shadow:0 0 15px #ef444414!important}.pipeline-container{background:var(--bg-primary);border:1px solid var(--border-muted);border-radius:8px;justify-content:space-between;align-items:center;padding:12px 10px;display:flex;position:relative}.pipeline-step{text-align:center;opacity:.4;width:72px;transition:all var(--transition-normal);flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.pipeline-step.active{opacity:1}.pipeline-step .step-icon-circle{background:var(--bg-secondary);border:1px solid var(--border-muted);width:36px;height:36px;color:var(--text-secondary);box-shadow:var(--glass-shadow);transition:all var(--transition-normal);border-radius:50%;justify-content:center;align-items:center;display:flex}.pipeline-step.active .step-icon-circle{border-color:var(--color-purple);color:var(--color-purple);background:#8b5cf61a;box-shadow:0 0 10px #8b5cf633}.pipeline-step.pulse .step-icon-circle{animation:1.5s infinite alternate pipeline-pulse-glow}@keyframes pipeline-pulse-glow{0%{border-color:var(--color-purple);transform:scale(1);box-shadow:0 0 #8b5cf666}to{border-color:var(--color-purple);transform:scale(1.08);box-shadow:0 0 12px 4px #8b5cf633}}.pipeline-step .step-label{color:var(--text-muted);transition:all var(--transition-normal);font-size:.72rem;font-weight:600}.pipeline-step.active .step-label{color:var(--text-primary)}.pipeline-arrow{background:var(--border-muted);opacity:.3;height:2px;transition:all var(--transition-normal);flex-grow:1;min-width:16px;margin:0 8px;position:relative}.pipeline-arrow.active{background:linear-gradient(90deg, var(--color-purple), #b086f9);opacity:1;box-shadow:0 0 8px #8b5cf680}.pipeline-arrow.active:after{content:"";background:linear-gradient(90deg,#0000,#fff,#0000);width:30%;height:100%;animation:1.2s linear infinite arrow-flow;position:absolute;top:0;left:0}@keyframes arrow-flow{0%{left:-30%}to{left:100%}}.chat-layout{flex-direction:column;gap:16px;height:700px;display:flex}.chat-messages-container{border:1px solid var(--border-muted);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000001f;border-radius:12px;flex-direction:column;flex-grow:1;gap:20px;padding:24px;display:flex;overflow-y:auto;box-shadow:inset 0 2px 8px #00000026}.chat-bubble{border-radius:16px;flex-direction:column;gap:8px;max-width:80%;padding:16px 20px;font-size:.95rem;line-height:1.5;animation:.35s cubic-bezier(.16,1,.3,1) message-slide;display:flex;position:relative;box-shadow:0 4px 15px #0000001a}.chat-bubble.user{background:linear-gradient(135deg, var(--color-purple), #8242f0);color:#fff;border-bottom-right-radius:4px;align-self:flex-end;box-shadow:0 4px 20px #8b5cf640}.chat-bubble.gemini{background:var(--bg-secondary);border:1px solid var(--border-muted);color:var(--text-primary);box-shadow:var(--glass-shadow);border-bottom-left-radius:4px;align-self:flex-start}.chat-sender-name{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);align-items:center;gap:6px;font-size:.75rem;font-weight:700;display:flex}.chat-bubble.user .chat-sender-name{color:#ffffffe6}.chat-message-text{white-space:pre-wrap;word-break:break-word}.chat-message-text code{font-family:var(--font-mono);background:#0003;border-radius:4px;padding:2px 6px;font-size:.85rem}.chat-bubble.gemini .chat-message-text code{background:#ffffff14}.chat-tool-execution{border:1px solid var(--border-muted);background:var(--bg-primary);border-radius:8px;margin-top:10px;font-size:.8rem;overflow:hidden;box-shadow:inset 0 1px 3px #0003}.chat-tool-header{border-bottom:1px solid var(--border-muted);cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;justify-content:space-between;align-items:center;padding:10px 14px;font-weight:600;transition:background .2s,color .2s;display:flex}.chat-tool-header:hover{color:var(--color-purple);background:#ffffff0f}.chat-tool-body{font-family:var(--font-mono);color:var(--text-primary);background:#06070a;border-bottom-right-radius:8px;border-bottom-left-radius:8px;padding:14px;overflow-x:auto}.chat-input-bar{background:var(--bg-secondary);border:1px solid var(--border-muted);box-shadow:var(--glass-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;align-items:center;gap:12px;padding:14px;display:flex}.chat-input-field{background:var(--bg-primary);border:1px solid var(--border-muted);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:8px;outline:none;flex-grow:1;padding:12px 18px;font-size:.95rem}.chat-input-field:focus{border-color:var(--color-purple);box-shadow:0 0 0 2px #8b5cf626}.chat-bubble.user a{color:#c084fc;text-decoration:underline}.chat-bubble.gemini a{color:var(--color-purple);text-decoration:underline}@keyframes message-slide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
