@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--gray-950:#08090c;--gray-900:#0d0f14;--gray-850:#12141a;--gray-800:#181b22;--gray-700:#1f232d;--gray-600:#2a2f3b;--gray-500:#3d4455;--gray-400:#5a6278;--gray-300:#7d869b;--gray-200:#a1a9bd;--gray-100:#cdd3e0;--gray-50:#e8ecf4;--purple-400:#a78bfa;--purple-500:#8b5cf6;--purple-600:#7c3aed;--purple-glow:#8b5cf640;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-glow:#3b82f633;--cyan-400:#22d3ee;--cyan-glow:#22d3ee26;--text:var(--gray-300);--text-h:var(--gray-50);--text-dim:var(--gray-400);--bg:var(--gray-950);--bg-card:var(--gray-850);--bg-elevated:var(--gray-800);--border:var(--gray-600);--border-dim:var(--gray-700);--code-bg:var(--gray-800);--accent:var(--purple-500);--accent-text:var(--purple-400);--accent-light:#8b5cf61a;--accent-border:#8b5cf659;--accent-glow:var(--purple-glow);--success:#34d399;--success-dim:#059669;--success-light:#34d39914;--success-border:#34d3994d;--danger:#f87171;--danger-dim:#dc2626;--danger-light:#f8717114;--danger-border:#f871714d;--warning:#fbbf24;--warning-dim:#d97706;--warning-light:#fbbf2414;--warning-border:#fbbf244d;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 32px #0009;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--sans:"Inter", system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", ui-monospace, Consolas, monospace;font:15px/1.5 var(--sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}*,:before,:after{box-sizing:border-box}body{background:var(--bg);margin:0}body:before{content:"";z-index:9999;pointer-events:none;opacity:.015;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}h1,h2,h3,h4{color:var(--text-h);letter-spacing:-.02em;margin:0;font-weight:600}p{margin:0}code{font-family:var(--mono);border-radius:var(--radius-sm);background:var(--code-bg);color:var(--accent-text);border:1px solid var(--border-dim);padding:2px 8px;font-size:.85em}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-600);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.btn{font-family:var(--mono);border-radius:var(--radius-md);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.8125rem;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.3;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.btn--primary:hover:not(:disabled){filter:brightness(1.2);box-shadow:0 0 30px var(--accent-glow), 0 0 60px #8b5cf61a}.btn--secondary{background:var(--accent-light);color:var(--accent-text);border-color:var(--accent-border)}.btn--secondary:hover:not(:disabled){background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-glow)}.btn--ghost{color:var(--text);border-color:var(--border);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-h);border-color:var(--gray-500)}.btn--lg{padding:14px 36px;font-size:.875rem}.input{font-family:var(--mono);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--gray-900);color:var(--text-h);text-align:center;text-transform:uppercase;letter-spacing:4px;outline:none;padding:10px 16px;font-size:1.125rem;transition:all .2s}.input:focus{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.input::placeholder{color:var(--gray-500);letter-spacing:1px;text-transform:none;font-size:.875rem}.session-page{flex-direction:column;justify-content:center;align-items:center;gap:48px;min-height:100dvh;padding:40px 24px;display:flex;position:relative}.session-page:before{content:"";background-image:linear-gradient(var(--gray-800) 1px, transparent 1px), linear-gradient(90deg, var(--gray-800) 1px, transparent 1px);opacity:.3;pointer-events:none;background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(60% 50% at 50% 40%,#000 20%,#0000 100%);mask-image:radial-gradient(60% 50% at 50% 40%,#000 20%,#0000 100%)}.session-page>*{z-index:1;position:relative}.session-page__hero{text-align:center}.session-page__title{font-family:var(--mono);letter-spacing:-2px;background:linear-gradient(135deg, var(--purple-400), var(--blue-400), var(--cyan-400));-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 30px var(--purple-glow));-webkit-background-clip:text;background-clip:text;font-size:3.25rem;font-weight:700}.session-page__subtitle{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:3px;margin-top:10px;font-size:.8125rem}.session-page__join{flex-direction:column;align-items:center;gap:16px;display:flex}.session-page__actions{flex-direction:column;align-items:center;gap:20px;width:340px;display:flex}.session-page__divider{width:100%;color:var(--text-dim);font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;align-items:center;gap:16px;font-size:.75rem;display:flex}.session-page__divider:before,.session-page__divider:after{content:"";background:linear-gradient(90deg, transparent, var(--border), transparent);flex:1;height:1px}.session-page__join-form{gap:8px;width:100%;display:flex}.session-page__join-form .input{flex:1}.session-page__error{color:var(--danger);font-family:var(--mono);font-size:.8125rem}.session-page__setup{flex-direction:column;align-items:center;gap:40px;width:100%;max-width:600px;display:flex}.session-page__code-display{text-align:center}.session-page__code-display p{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-size:.8125rem}.session-page__code{font-family:var(--mono);letter-spacing:10px;background:var(--gray-900);border:1px solid var(--accent-border);border-radius:var(--radius-md);color:var(--purple-400);-webkit-user-select:all;user-select:all;box-shadow:0 0 30px var(--accent-glow), inset 0 0 30px #8b5cf608;padding:16px 32px;font-size:2.75rem;font-weight:700}.session-page__role-assigned{color:var(--text-m);text-align:center;font-size:1.1rem}.session-page__role-assigned strong{color:var(--accent-cyan)}.role-select{width:100%}.role-select__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;text-align:center;color:var(--text-dim);margin-bottom:16px;font-size:.8125rem}.role-select__grid{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.role-select__card{border:1px solid var(--border-dim);border-radius:var(--radius-md);background:var(--bg-card);cursor:pointer;min-width:180px;max-width:220px;font-family:var(--sans);flex-direction:column;flex:1;align-items:center;gap:8px;padding:24px 16px;transition:all .2s;display:flex;position:relative;overflow:hidden}.role-select__card:before{content:"";background:linear-gradient(180deg, transparent 60%, var(--accent-light));opacity:0;transition:opacity .2s;position:absolute;inset:0}.role-select__card:hover:not(:disabled){border-color:var(--accent-border);box-shadow:0 0 20px var(--accent-glow)}.role-select__card:hover:not(:disabled):before{opacity:1}.role-select__card--active{border-color:var(--accent);background:var(--bg-elevated);box-shadow:0 0 24px var(--accent-glow)}.role-select__card--active:before{opacity:1}.role-select__card--active.role-select__card--intruder{border-color:var(--danger);box-shadow:0 0 24px #f8717126}.role-select__card--active.role-select__card--intruder:before{background:linear-gradient(180deg, transparent 60%, var(--danger-light));opacity:1}.role-select__icon{z-index:1;font-size:1.75rem;position:relative}.role-select__label{font-family:var(--mono);color:var(--text-h);text-transform:uppercase;letter-spacing:1px;z-index:1;font-size:.875rem;font-weight:600;position:relative}.role-select__desc{color:var(--text-dim);z-index:1;font-size:.75rem;position:relative}@media (width<=480px){.role-select__grid{grid-template-columns:1fr}}.mode-select{width:100%}.mode-select__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;text-align:center;color:var(--text-dim);margin-bottom:16px;font-size:.8125rem}.mode-select__options{grid-template-columns:1fr 1fr;gap:10px;display:grid}.mode-select__btn{border:1px solid var(--border-dim);border-radius:var(--radius-md);background:var(--bg-card);cursor:pointer;font-family:var(--sans);flex-direction:column;align-items:center;gap:6px;padding:20px;transition:all .2s;display:flex}.mode-select__btn:hover:not(:disabled){border-color:var(--accent-border)}.mode-select__btn--active{border-color:var(--accent);background:var(--bg-elevated);box-shadow:0 0 20px var(--accent-glow)}.mode-select__btn--active.mode-select__btn--quantum{border-color:var(--purple-400);box-shadow:0 0 24px var(--purple-glow)}.mode-select__btn-title{font-family:var(--mono);color:var(--text-h);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:600}.mode-select__btn-sub{color:var(--text-dim);font-size:.75rem}.simulation-page{background:var(--gray-950);flex-direction:column;min-height:100dvh;display:flex}.simulation-page__body{flex:1;gap:0;display:flex}.simulation-page__sidebar{border-right:1px solid var(--border-dim);background:var(--gray-900);flex-direction:column;flex-shrink:0;gap:28px;width:280px;padding:24px;display:flex}.simulation-page__main{flex-direction:column;flex:1;gap:28px;padding:32px;display:flex}.simulation-page__setup{flex-direction:column;align-items:center;gap:32px;width:100%;max-width:500px;margin:0 auto;display:flex}.simulation-page__waiting{color:var(--text-m);text-align:center;letter-spacing:.03em;font-size:1.1rem}.simulation-page__waiting-hint{color:var(--warning,#f59e0b);text-align:center;letter-spacing:.03em;font-size:.9rem}.simulation-page__mode-info{color:var(--text-l);text-align:center}.simulation-page__mode-info strong{color:var(--accent-purple)}.simulation-page__toolbar{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.simulation-page__actions{justify-content:center;gap:12px;display:flex}@media (width<=768px){.simulation-page__body{flex-direction:column}.simulation-page__sidebar{border-right:none;border-bottom:1px solid var(--border-dim);flex-flow:wrap;width:100%;padding:16px}}.session-header{border-bottom:1px solid var(--border-dim);background:var(--gray-900);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;height:48px;padding:0 24px;display:flex}.session-header__left{align-items:center;gap:16px;display:flex}.session-header__title{font-family:var(--mono);letter-spacing:-.5px;background:linear-gradient(135deg, var(--purple-400), var(--blue-400));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1rem;font-weight:700}.session-header__id{color:var(--text-dim);font-size:.8125rem}.session-header__id code{padding:1px 6px;font-size:.75rem}.session-header__right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.session-header__role,.session-header__mode,.session-header__status,.session-header__phase{font-family:var(--mono);text-transform:uppercase;letter-spacing:.8px;border-radius:var(--radius-sm);border:1px solid #0000;padding:3px 8px;font-size:.625rem;font-weight:600}.session-header__role{background:var(--accent-light);color:var(--accent-text);border-color:var(--accent-border)}.session-header__role--intruder{background:var(--danger-light);color:var(--danger);border-color:var(--danger-border)}.session-header__mode--quantum{background:var(--accent-light);color:var(--accent-text);border-color:var(--accent-border)}.session-header__mode--classical{background:var(--warning-light);color:var(--warning);border-color:var(--warning-border)}.session-header__status{color:var(--danger);background:var(--danger-light);border-color:var(--danger-border)}.session-header__status--on{color:var(--success);background:var(--success-light);border-color:var(--success-border)}.session-header__phase{color:var(--text-dim);background:var(--gray-800);border-color:var(--border-dim)}.device-status__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);border-bottom:1px solid var(--border-dim);margin-bottom:14px;padding-bottom:8px;font-size:.6875rem}.device-status__list{flex-direction:column;gap:10px;display:flex}.device-status__item{font-family:var(--mono);color:var(--gray-500);align-items:center;gap:10px;font-size:.8125rem;display:flex}.device-status__item--connected{color:var(--purple-400);text-shadow:0 0 8px #8b5cf699,0 0 20px #8b5cf64d}.device-status__dot{background:var(--gray-600);border-radius:50%;flex-shrink:0;width:8px;height:8px}.device-status__item--connected .device-status__dot{background:var(--purple-400);box-shadow:0 0 8px var(--purple-400), 0 0 16px #8b5cf666}.device-status__item--me.device-status__item--connected{color:var(--accent-cyan);text-shadow:0 0 8px #22d3ee99,0 0 20px #22d3ee4d}.device-status__item--me.device-status__item--connected .device-status__dot{background:var(--accent-cyan);box-shadow:0 0 8px var(--accent-cyan), 0 0 16px #22d3ee66}.device-status__you{opacity:.7;text-transform:lowercase;font-size:.7em}.device-status__role{text-transform:uppercase;letter-spacing:.5px}.file-upload{border:1px dashed var(--gray-600);border-radius:var(--radius-md);background:var(--gray-900);text-align:center;width:100%;padding:32px;transition:all .2s;position:relative}.file-upload--drag{border-color:var(--accent);background:var(--bg-elevated);box-shadow:inset 0 0 30px var(--accent-glow)}.file-upload--has-file{border-style:solid;border-color:var(--success-dim);background:var(--success-light)}.file-upload__prompt p{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:.8125rem}.file-upload__btn{font-family:var(--mono);text-transform:uppercase;letter-spacing:.8px;border:1px solid var(--accent-border);border-radius:var(--radius-sm);background:var(--accent-light);color:var(--accent-text);cursor:pointer;padding:8px 20px;font-size:.75rem;font-weight:500;transition:all .2s}.file-upload__btn:hover:not(:disabled){background:var(--accent);color:#fff;box-shadow:0 0 16px var(--accent-glow)}.file-upload__info{flex-direction:column;gap:4px;display:flex}.file-upload__name{font-family:var(--mono);color:var(--text-h);font-size:.9375rem;font-weight:600}.file-upload__size{font-family:var(--mono);color:var(--text-dim);font-size:.75rem}.metrics-panel__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);border-bottom:1px solid var(--border-dim);margin-bottom:14px;padding-bottom:8px;font-size:.6875rem}.metrics-panel__grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;display:grid}.metrics-panel__card{border-radius:var(--radius-md);border:1px solid var(--border-dim);background:var(--gray-900);flex-direction:column;gap:6px;padding:14px 16px;display:flex;position:relative;overflow:hidden}.metrics-panel__card:before{content:"";background:var(--gray-600);height:2px;position:absolute;top:0;left:0;right:0}.metrics-panel__card--success{border-color:var(--success-border)}.metrics-panel__card--success:before{background:var(--success);box-shadow:0 0 10px var(--success)}.metrics-panel__card--danger{border-color:var(--danger-border)}.metrics-panel__card--danger:before{background:var(--danger);box-shadow:0 0 10px var(--danger)}.metrics-panel__label{font-family:var(--mono);text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);font-size:.625rem;font-weight:600}.metrics-panel__value{color:var(--text-h);font-size:1.5rem;font-weight:700;font-family:var(--mono)}.metrics-panel__bar{background:var(--gray-700);border-radius:2px;height:3px;margin-top:6px;overflow:hidden}.metrics-panel__bar-fill{background:var(--success);height:100%;box-shadow:0 0 6px var(--success);border-radius:2px;transition:width .6s}.metrics-panel__bar-fill--danger{background:var(--danger);box-shadow:0 0 6px var(--danger)}.intruder-controls__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);border-bottom:1px solid var(--border-dim);margin-bottom:14px;padding-bottom:8px;font-size:.6875rem}.intruder-controls__toggle{margin-bottom:16px}.intruder-controls__label{font-family:var(--mono);color:var(--text-h);cursor:pointer;align-items:center;gap:10px;font-size:.8125rem;display:flex}.intruder-controls__label input[type=checkbox]{accent-color:var(--danger);width:14px;height:14px}.intruder-controls__slider{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.intruder-controls__slider .intruder-controls__label{color:var(--text-dim);font-size:.75rem}.intruder-controls__slider input[type=range]{width:100%;accent-color:var(--danger);height:4px}.intruder-controls__status h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:10px;font-size:.625rem}.intruder-controls__intel{flex-direction:column;gap:8px;display:flex}.intruder-controls__intel-item{font-family:var(--mono);color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:8px;font-size:.75rem;display:flex}.intruder-controls__intel-item--captured{color:var(--danger);font-weight:600}.intruder-controls__intel-dot{background:var(--gray-600);border-radius:50%;flex-shrink:0;width:5px;height:5px}.intruder-controls__intel-item--captured .intruder-controls__intel-dot{background:var(--danger);box-shadow:0 0 8px var(--danger), 0 0 16px #f8717133;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.transfer-status{border-radius:var(--radius-md);border:1px solid var(--border-dim);background:var(--gray-900);text-align:center;padding:24px;position:relative;overflow:hidden}.transfer-status--key_exchange:after,.transfer-status--transferring:after{content:"";pointer-events:none;background:linear-gradient(#0000 0%,#8b5cf608 50%,#0000 100%) 0 0/100% 8px;animation:3s linear infinite scan;position:absolute;inset:0}@keyframes scan{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}.transfer-status__heading{font-family:var(--mono);text-transform:uppercase;letter-spacing:1px;z-index:1;margin-bottom:14px;font-size:1rem;position:relative}.transfer-status__message{border-radius:var(--radius-sm);text-align:left;z-index:1;padding:14px 18px;font-size:.875rem;line-height:1.7;position:relative}.transfer-status__message p+p{margin-top:4px}.transfer-status__message--success{background:var(--success-light);border:1px solid var(--success-border);color:var(--success)}.transfer-status__message--danger{background:var(--danger-light);border:1px solid var(--danger-border);color:var(--danger)}.transfer-status__message--warning{background:var(--warning-light);border:1px solid var(--warning-border);color:var(--warning)}.transfer-status__progress{z-index:1;justify-content:center;padding:16px 0;display:flex;position:relative}.transfer-status__spinner{border:2px solid var(--gray-700);border-top-color:var(--accent-text);width:28px;height:28px;box-shadow:0 0 12px var(--accent-glow);border-radius:50%;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.bitstream{border:1px solid var(--border-dim);border-radius:var(--radius-md);background:var(--gray-900);overflow:hidden}.bitstream__header{border-bottom:1px solid var(--border-dim);background:var(--gray-850);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.bitstream__label{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-size:.6875rem;font-weight:600}.bitstream__counter{font-family:var(--mono);color:var(--accent-text);letter-spacing:.5px;font-size:.6875rem}.bitstream__progress-bar{background:var(--gray-800);height:2px}.bitstream__progress-fill{background:linear-gradient(90deg, var(--purple-500), var(--blue-400), var(--cyan-400));height:100%;box-shadow:0 0 8px var(--purple-glow);transition:width .1s linear}.bitstream__columns{grid-template-columns:1fr 1fr;display:grid}.bitstream__col{flex-direction:column;min-width:0;display:flex}.bitstream__col:first-child{border-right:1px solid var(--border-dim)}.bitstream__col-header{font-family:var(--mono);text-transform:uppercase;letter-spacing:2px;color:var(--gray-500);border-bottom:1px solid var(--border-dim);background:var(--gray-850);padding:8px 12px;font-size:.5625rem;font-weight:600}.bitstream__grid{scrollbar-width:thin;flex-wrap:wrap;gap:2px;max-height:220px;padding:10px;display:flex;overflow-y:auto}.bitstream__bit{font-family:var(--mono);border-radius:2px;justify-content:center;align-items:center;width:16px;height:16px;font-size:.625rem;font-weight:600;line-height:1;transition:background .1s,color .1s;display:inline-flex}.bitstream__bit--0{background:var(--gray-800);color:var(--gray-400)}.bitstream__bit--1{color:var(--purple-400);background:#8b5cf626}.bitstream__bit--mismatch{color:var(--danger);background:#f8717133;animation:1s ease-out mismatch-flash;box-shadow:0 0 4px #f871714d}.bitstream__bit--hidden{background:var(--gray-850);color:var(--gray-700)}.bitstream__bit--empty{background:var(--gray-850);border-radius:2px;width:16px;height:16px}@keyframes mismatch-flash{0%{background:#f8717180}to{background:#f8717133}}@media (width<=768px){.bitstream__columns{grid-template-columns:1fr}.bitstream__col:first-child{border-right:none;border-bottom:1px solid var(--border-dim)}.bitstream__grid{max-height:150px}}.panel-overlay{z-index:100;-webkit-backdrop-filter:blur(6px);background:#000000a6;justify-content:center;align-items:center;animation:.15s ease-out panel-fade-in;display:flex;position:fixed;inset:0}@keyframes panel-fade-in{0%{opacity:0}to{opacity:1}}.panel{background:var(--gray-900);border:1px solid var(--border-dim);border-radius:var(--radius-lg,12px);flex-direction:column;width:min(90vw,960px);max-height:85vh;animation:.2s ease-out panel-slide-up;display:flex;overflow:hidden;box-shadow:0 0 40px #8b5cf614,0 20px 60px #00000080}@keyframes panel-slide-up{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.panel__header{border-bottom:1px solid var(--border-dim);background:var(--gray-850);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.panel__title{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-size:.75rem;font-weight:600}.panel__close{width:28px;height:28px;color:var(--gray-400);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.25rem;transition:all .15s;display:flex}.panel__close:hover{background:var(--gray-700);color:var(--text-h)}.panel__body{scrollbar-width:thin;flex:1;padding:0;overflow-y:auto}.panel__body .bitstream{border:none;border-radius:0}.panel__body .bitstream__grid{max-height:50vh}.bitstream__empty{flex-direction:column;display:flex}.bitstream__empty-message{text-align:center;font-family:var(--mono);color:var(--text-dim);letter-spacing:.5px;padding:24px;font-size:.85rem}.file-preview{padding:24px}.file-preview__meta{border-bottom:1px solid var(--border-dim);flex-wrap:wrap;align-items:baseline;gap:8px 16px;margin-bottom:20px;padding-bottom:16px;display:flex}.file-preview__label{font-family:var(--mono);text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);width:100%;margin-bottom:4px;font-size:.6875rem;font-weight:600}.file-preview__name{font-family:var(--mono);color:var(--text-h);font-size:.9375rem;font-weight:600}.file-preview__size,.file-preview__type{font-family:var(--mono);color:var(--gray-500);font-size:.75rem}.file-preview__image-wrap{background:var(--gray-850);border:1px solid var(--border-dim);border-radius:var(--radius-md);justify-content:center;padding:16px;display:flex;overflow:hidden}.file-preview__image{object-fit:contain;border-radius:4px;max-width:100%;max-height:50vh}.file-preview__text{font-family:var(--mono);color:var(--text);background:var(--gray-850);border:1px solid var(--border-dim);border-radius:var(--radius-md);white-space:pre-wrap;word-break:break-all;scrollbar-width:thin;max-height:50vh;padding:16px;font-size:.75rem;line-height:1.6;overflow-x:auto}.file-preview__binary{font-family:var(--mono);color:var(--gray-500);text-align:center;background:var(--gray-850);border:1px dashed var(--border-dim);border-radius:var(--radius-md);padding:40px 20px;font-size:.8125rem}.simulation-page__bottom{align-items:stretch;gap:24px;width:100%;margin-top:24px;display:flex}.simulation-page__circuit{flex:1;min-width:0}.circuit{border:1px solid var(--border-dim);border-radius:var(--radius-md);background:var(--gray-900);width:100%;height:260px;position:relative;overflow:hidden;box-shadow:inset 0 0 40px #8b5cf60a,0 0 30px #8b5cf614}.circuit--active{border-color:#22d3ee4d;box-shadow:inset 0 0 40px #8b5cf60f,0 0 40px #22d3ee1f}.simulation-page__bloch{background:linear-gradient(145deg, var(--gray-900), #0f0a1ef2);border-radius:var(--radius-md);-webkit-user-select:none;user-select:none;border:1px solid #8b5cf64d;justify-content:center;align-items:center;width:300px;min-width:300px;height:300px;display:flex;box-shadow:inset 0 0 30px #8b5cf60f,0 0 20px #8b5cf61a}.bloch-sphere{width:100%;height:100%}.bloch-sphere__label{font-family:var(--mono);fill:#ffffffb3;font-size:.7rem;font-weight:600}.bloch-sphere__vector{stroke:var(--accent-cyan);stroke-width:3px;stroke-linecap:round;filter:drop-shadow(0 0 8px var(--accent-cyan)) drop-shadow(0 0 16px #22d3ee66);transition:x2 .3s,y2 .3s}.bloch-sphere__tip{fill:var(--accent-cyan);filter:drop-shadow(0 0 10px var(--accent-cyan)) drop-shadow(0 0 20px #22d3ee80);transition:cx .3s,cy .3s}.bloch-sphere__gate-label{font-family:var(--mono);fill:var(--purple-400);text-transform:uppercase;letter-spacing:1px;filter:drop-shadow(0 0 4px #8b5cf666);font-size:.75rem;font-weight:700}.bloch-sphere__state-label{font-family:var(--mono);fill:#fff9;font-size:.65rem}.intruder-panel{flex-direction:column;gap:24px;display:flex}.intruder-panel__stats{gap:12px;display:flex}.intruder-panel__stats div{border-radius:var(--radius-sm);text-align:center;background:#f871710d;border:1px solid #f8717133;flex-direction:column;flex:1;gap:6px;padding:14px 12px;display:flex}.intruder-panel__stats span{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:.7rem}.intruder-panel__stats strong{color:var(--danger);font-size:1.1rem;font-family:var(--mono)}.intruder-panel__stats strong.detected{color:var(--danger)}.intruder-panel__stats strong.undetected{color:var(--success,#22c55e)}.intruder-panel__capture{gap:12px;display:flex}.capture-badge{border-radius:var(--radius-sm);text-align:center;font-family:var(--mono);flex-direction:column;flex:1;gap:4px;padding:12px;display:flex}.capture-badge span{text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);font-size:.7rem}.capture-badge strong{letter-spacing:.5px;font-size:.85rem}.capture-badge--success{background:#f8717114;border:1px solid #f871714d}.capture-badge--success strong{color:var(--danger)}.capture-badge--fail{background:#22c55e0d;border:1px solid #22c55e33}.capture-badge--fail strong{color:var(--success,#22c55e)}.intruder-panel__timeline-section{flex-direction:column;gap:8px;display:flex}.timeline-label{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:.7rem}.intruder-panel__timeline{flex-wrap:wrap;gap:3px;display:flex}.timeline-dot{background:#ffffff14;border-radius:50%;width:6px;height:6px;transition:background .2s}.timeline-dot--ok{background:#22d3ee4d}.timeline-dot--hit{background:var(--danger);box-shadow:0 0 6px var(--danger)}.intruder-panel__collapse{text-align:center;border-top:1px solid var(--border-dim);flex-direction:column;gap:12px;padding-top:8px;display:flex}.collapse-title{font-family:var(--mono);color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:.75rem}.collapse-row{justify-content:center;align-items:center;gap:20px;display:flex}.collapse-arrow{color:var(--text-dim);font-size:1.2rem}.collapse-state.superposed{background:radial-gradient(circle,#22d3eecc,#8b5cf64d,#0000);border-radius:50%;width:44px;height:44px;animation:1.5s ease-in-out infinite pulse;box-shadow:0 0 15px #22d3ee66}.collapse-state.measured{border:2px solid var(--danger);width:44px;height:44px;color:var(--danger);font-family:var(--mono);background:#f8717126;border-radius:6px;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex;box-shadow:0 0 10px #f871714d}.collapse-state.collapsed{border:2px solid var(--purple-400);width:44px;height:44px;color:var(--purple-400);font-family:var(--mono);background:#8b5cf626;border-radius:6px;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}.collapse-desc{color:var(--text-dim);font-size:.7rem;font-style:italic}.btn--danger{color:var(--danger)!important;border-color:#f871714d!important}.btn--danger:hover{border-color:var(--danger)!important;background:#f871711a!important}.simulation-page__progress{background:var(--gray-900);border:1px solid var(--border-dim);border-radius:var(--radius-md);flex-direction:column;justify-content:center;gap:16px;width:320px;height:200px;padding:20px;display:flex}.classical-progress__header{font-family:var(--mono);color:var(--text-dim);justify-content:space-between;font-size:.8rem;display:flex}.classical-progress__bar{background:#ffffff0d;border-radius:999px;width:100%;height:18px;position:relative;overflow:hidden}.classical-progress__fill{background:linear-gradient(90deg, var(--accent-cyan), var(--purple-400));height:100%;transition:width .2s ease-out;box-shadow:0 0 10px #22d3ee66,0 0 20px #8b5cf633}.classical-progress__footer{text-align:center;color:var(--text-dim);font-size:.75rem}.classical-progress__fill{animation:2s infinite progress-pulse}@keyframes progress-pulse{0%,to{opacity:.85}50%{opacity:1}}.simulation-page__bottom--full{justify-content:center;align-items:center;display:flex}.simulation-page__bottom--full .classical-progress{width:100%;max-width:900px}.simulation-page__bottom--full .classical-progress__bar{height:28px}
