@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=Inter:wght@300;400;500;600;700&family=Space+Mono:ital,wght@0,400;0,700;1,400&family=Caveat:wght@400;600;700&display=swap";:root{--color-bg: #fafaf7;--color-surface: #ffffff;--color-surface-2: #f4f0e8;--color-border: #ddd8ce;--color-border-focus: #1a4fd6;--color-primary: #1a4fd6;--color-primary-dark: #1340b8;--color-accent: #e07000;--color-success: #1a6b3c;--color-warning: #b45309;--color-danger: #c0392b;--color-text: #1a1a18;--color-text-muted: #7a7068;--color-ink: #2d2820;--font-display: "DM Serif Display", Georgia, serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "Space Mono", "Fira Code", monospace;--font-hand: "Caveat", cursive;--radius: 6px;--radius-lg: 10px;--shadow: 0 1px 4px rgba(0, 0, 0, .07), 0 4px 16px rgba(0, 0, 0, .05);--shadow-card: 0 1px 0 rgba(255, 255, 255, .9) inset, 0 2px 8px rgba(0, 0, 0, .07)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='2.8' fill='%231a4fd6'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%231a4fd6' stroke-width='1.5' fill='none'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%231a4fd6' stroke-width='1.5' fill='none' transform='rotate(60 16 16)'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%231a4fd6' stroke-width='1.5' fill='none' transform='rotate(120 16 16)'/%3E%3C/svg%3E") 16 16,auto}button,a,input[type=range],select,.history-item,[role=button]{cursor:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='16' cy='16' r='2.8' fill='%23e07000'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%23e07000' stroke-width='1.5' fill='none'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%23e07000' stroke-width='1.5' fill='none' transform='rotate(60 16 16)'/%3E%3Cellipse cx='16' cy='16' rx='14' ry='5' stroke='%23e07000' stroke-width='1.5' fill='none' transform='rotate(120 16 16)'/%3E%3C/svg%3E") 16 16,pointer}.cursor-halo{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;will-change:transform;transition:background .25s ease,width .2s ease,height .2s ease}.cursor-halo--inner{width:28px;height:28px;background:radial-gradient(circle,rgba(26,79,214,.38) 0%,rgba(26,79,214,.08) 50%,transparent 70%)}.cursor-halo--outer{width:80px;height:80px;background:radial-gradient(circle,rgba(26,79,214,.13) 0%,rgba(26,79,214,.04) 50%,transparent 70%)}.cursor-halo--active.cursor-halo--inner{width:36px;height:36px;background:radial-gradient(circle,rgba(224,112,0,.5) 0%,rgba(224,112,0,.12) 50%,transparent 70%)}.cursor-halo--active.cursor-halo--outer{width:96px;height:96px;background:radial-gradient(circle,rgba(224,112,0,.16) 0%,rgba(224,112,0,.04) 50%,transparent 70%)}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;background-image:linear-gradient(rgba(26,79,214,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(26,79,214,.07) 1px,transparent 1px),linear-gradient(rgba(26,79,214,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(26,79,214,.035) 1px,transparent 1px);background-size:80px 80px,80px 80px,16px 16px,16px 16px;background-position:-1px -1px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes atomSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes stampIn{0%{opacity:0;transform:rotate(-2deg) scale(.85)}to{opacity:1;transform:rotate(-1.5deg) scale(1)}}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--color-surface);border-bottom:2px solid var(--color-primary);padding:1.25rem 2rem;position:relative;z-index:10;box-shadow:var(--shadow)}.app-header__inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.app-header__brand{display:flex;align-items:center;gap:1rem}.app-header__icon{font-size:2rem;line-height:1;display:inline-block;animation:atomSpin 16s linear infinite;color:var(--color-primary)}.app-header__title{font-family:var(--font-display);font-size:1.375rem;font-weight:400;font-style:italic;color:var(--color-text);letter-spacing:0}.app-header__subtitle{font-family:var(--font-sans);font-size:.75rem;font-weight:400;color:var(--color-text-muted);letter-spacing:.02em;margin-top:.125rem}.app-header__badges{display:flex;gap:.5rem;flex-wrap:wrap}.tech-badge{padding:.2rem .625rem;border-radius:var(--radius);font-family:var(--font-mono);font-size:.625rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--color-surface-2);color:var(--color-primary);border:1px solid var(--color-border)}.error-banner{background:#fef2f2;border-bottom:1px solid var(--color-danger);color:var(--color-danger);padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.9375rem}.error-banner__close{background:none;border:none;color:var(--color-danger);font-size:1rem;padding:.25rem;line-height:1;opacity:.7;transition:opacity .15s}.error-banner__close:hover{opacity:1}.app-main{flex:1;display:grid;grid-template-columns:320px 1fr;max-width:1400px;width:100%;margin:0 auto;padding:1.5rem;gap:1.5rem;align-items:start}@media (max-width: 900px){.app-main{grid-template-columns:1fr;padding:1rem}}.panel-title{font-family:var(--font-sans);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);margin-bottom:1.25rem;border-bottom:1px solid var(--color-border);padding-bottom:.625rem}.controls-panel{background:var(--color-surface);border:1px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-card);transition:box-shadow .3s ease}.controls-panel:hover{box-shadow:var(--shadow-card),0 0 0 3px #1a4fd61a,0 6px 32px #1a4fd61f}.controls-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-family:var(--font-sans);font-size:.75rem;font-weight:600;letter-spacing:.04em;color:var(--color-text-muted);text-transform:uppercase;display:flex;align-items:center;justify-content:space-between}.form-value{font-family:var(--font-mono);font-size:1rem;font-weight:700;transition:color .3s;color:var(--color-primary)}.form-select,.form-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:var(--font-sans);font-size:.9375rem;padding:.625rem .875rem;width:100%;transition:border-color .15s,box-shadow .15s}.form-select:hover,.form-input:hover{border-color:var(--color-primary)}.form-select:focus,.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4fd61a}.form-select option{background:var(--color-surface);color:var(--color-text)}.noise-presets{display:flex;gap:.375rem;flex-wrap:wrap;margin-bottom:.375rem}.preset-btn{flex:1 1 0;min-width:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text-muted);font-family:var(--font-sans);font-size:clamp(.625rem,1.8vw,.75rem);font-weight:500;padding:.3125rem .125rem;transition:background .18s,border-color .18s,color .18s;white-space:nowrap}.preset-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff}.preset-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.preset-btn:disabled{opacity:.4}.form-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:100px;background:var(--color-border);outline:none;accent-color:var(--color-primary)}.form-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);border:2px solid #ffffff;box-shadow:0 1px 4px #0003;transition:transform .15s,background .18s}.form-range::-webkit-slider-thumb:hover{background:var(--color-accent);transform:scale(1.15)}.range-labels{display:flex;justify-content:space-between;font-size:.6875rem;color:var(--color-text-muted);font-family:var(--font-mono)}.form-hint{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.btn-run{background:var(--color-primary);color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius);padding:.8125rem 1rem;font-family:var(--font-sans);font-size:.8125rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:background .22s,border-color .22s,transform .1s,box-shadow .22s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 2px 8px #1a4fd640}.btn-run:hover:not(:disabled){background:var(--color-accent);border-color:var(--color-accent);box-shadow:0 4px 14px #e0700059;transform:translateY(-1px)}.btn-run:active:not(:disabled){transform:translateY(0)}.btn-run:disabled{opacity:.4;box-shadow:none}.btn-run--loading{opacity:.85}.spinner{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.btn-sweep{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:var(--radius);padding:.75rem 1rem;font-family:var(--font-sans);font-size:.8125rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;transition:background .22s,color .22s,border-color .22s,transform .1s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-sweep:hover:not(:disabled){background:#1a6b3c;border-color:#1a6b3c;color:#fff;transform:translateY(-1px)}.btn-sweep:active:not(:disabled){transform:translateY(0)}.btn-sweep:disabled{opacity:.35}.btn-sweep--loading{border-color:var(--color-text-muted);color:var(--color-text-muted)}.sweep-section-wrapper{max-width:1400px;width:100%;margin:0 auto;padding:0 1.5rem}.fidelity-section{background:var(--color-surface);border:1px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;animation:fadeSlideIn .4s ease;box-shadow:var(--shadow-card)}.fidelity-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.fidelity-subtitle{font-size:.8125rem;color:var(--color-text-muted);margin-top:.25rem}.fidelity-chart-wrapper{height:260px;margin-bottom:1.25rem}.crossover-badge{border:2px solid var(--color-danger);border-radius:3px;padding:.4rem .75rem;text-align:center;min-width:100px;transform:rotate(-1.5deg);display:inline-block;animation:stampIn .35s ease}.crossover-badge--resilient{border-color:var(--color-success)}.crossover-label{display:block;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.125rem;font-family:var(--font-sans)}.crossover-value{display:block;font-size:1.25rem;font-weight:700;font-family:var(--font-mono);color:var(--color-danger)}.crossover-badge--resilient .crossover-value{color:var(--color-success);font-size:.9375rem}.sweep-insights{display:flex;gap:.5rem;flex-wrap:wrap}.sweep-point{display:flex;flex-direction:column;align-items:center;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.375rem .625rem;min-width:52px}.sweep-point__rate{font-size:.6875rem;color:var(--color-text-muted);font-family:var(--font-mono)}.sweep-point__fidelity{font-size:.9375rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text)}.sweep-progress-bar{height:4px;background:var(--color-border);border-radius:100px;overflow:hidden;margin-bottom:.75rem}.sweep-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent),var(--color-primary));background-size:200% auto;border-radius:100px;transition:width .4s ease;animation:shimmer 1.5s linear infinite}.sweep-progress-label{font-size:.875rem;color:var(--color-text-muted)}.sweep-progress-text{font-size:.8125rem;color:var(--color-text-muted);font-style:italic}.results-panel{background:var(--color-surface);border:1px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:var(--radius-lg);padding:1.5rem;min-height:480px;box-shadow:var(--shadow-card);animation:fadeSlideIn .35s ease}.results-panel--empty{display:flex;align-items:center;justify-content:center;border-top-color:var(--color-border)}.empty-state{text-align:center}.empty-state__icon{font-size:3rem;opacity:.15;display:block;margin-bottom:1rem;animation:atomSpin 24s linear infinite;color:var(--color-primary)}.empty-state__title{font-family:var(--font-display);font-size:1.375rem;font-style:italic;font-weight:400;color:var(--color-text-muted);margin-bottom:.5rem}.empty-state__text{color:var(--color-text-muted);font-size:.9375rem}.results-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.375rem;flex-wrap:wrap}.results-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;font-style:italic;color:var(--color-text)}.results-subtitle{font-size:.875rem;color:var(--color-text-muted);font-family:var(--font-mono);margin-top:.25rem}.results-noise-label{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1.25rem;font-family:var(--font-hand);font-size:1rem;color:var(--color-ink);opacity:.7}.chart-wrapper{height:280px;margin-bottom:.75rem;position:relative}.chart-callout{display:flex;justify-content:flex-end;margin-bottom:1.25rem;padding-right:.5rem}.chart-callout__text{font-family:var(--font-hand);font-size:1.0625rem;color:var(--color-text-muted);opacity:.75;transform:rotate(-1deg);display:inline-block;line-height:1.2;border-left:2px solid var(--color-border);padding-left:.5rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:3px;border-width:2px;border-style:solid;font-family:var(--font-sans);font-size:.6875rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;transform:rotate(-1.5deg);animation:stampIn .3s ease}.badge--ideal{color:var(--color-success);border-color:var(--color-success);background:#1a6b3c0f}.badge--low{color:#2a7a4b;border-color:#2a7a4b;background:#2a7a4b0f}.badge--moderate{color:var(--color-warning);border-color:var(--color-warning);background:#b4530912}.badge--high{color:var(--color-danger);border-color:var(--color-danger);background:#c0392b12}.badge--extreme{color:#8b0000;border-color:#8b0000;background:#8b000012}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media (max-width: 600px){.stats-row{grid-template-columns:1fr}}.stat-card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius);padding:.875rem 1rem;display:flex;flex-direction:column;gap:.125rem;transition:border-color .18s,box-shadow .18s}.stat-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #1a4fd614}.stat-label{font-family:var(--font-sans);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.stat-value{font-size:1.75rem;font-weight:700;font-family:var(--font-mono);color:var(--color-primary);line-height:1.1}.stat-sub{font-size:.75rem;color:var(--color-text-muted);font-family:var(--font-sans)}.history-panel{background:var(--color-surface);border-top:2px solid var(--color-border);padding:1.25rem 2rem;max-width:1400px;width:100%;margin:0 auto}.history-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.history-hint{font-size:.75rem;color:var(--color-text-muted);font-family:var(--font-hand);font-size:.9375rem}.history-empty{font-size:.875rem;color:var(--color-text-muted);font-family:var(--font-hand);font-size:1rem}.history-list{display:flex;flex-wrap:wrap;gap:.5rem}.history-item{display:flex;align-items:center;gap:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .875rem;font-size:.875rem;transition:border-color .15s,background .15s,box-shadow .15s,transform .1s;font-family:inherit;text-align:left}.history-item:hover{border-color:var(--color-primary);background:#f0f5ff;transform:translateY(-1px);box-shadow:0 2px 8px #1a4fd61a}.history-item:active{transform:translateY(0)}.history-id{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-muted);min-width:2rem}.history-circuit{font-family:var(--font-sans);font-size:.8125rem;font-weight:600;color:var(--color-text)}.history-noise{font-family:var(--font-mono);font-size:.75rem;padding:.125rem .4rem;border-radius:3px;font-weight:600;border:1.5px solid currentColor;transform:rotate(-.5deg);display:inline-block}.noise-ideal{color:var(--color-success)}.noise-low{color:#2a7a4b}.noise-moderate{color:var(--color-warning)}.noise-high{color:var(--color-danger)}.noise-extreme{color:#8b0000}.history-shots,.history-time{color:var(--color-text-muted);font-size:.8125rem;font-family:var(--font-mono)}.history-time:before{content:"·";margin-right:.5rem;opacity:.4}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius)}.btn-run:focus-visible,.btn-sweep:focus-visible,.preset-btn:focus-visible,.history-item:focus-visible{outline-offset:3px}@media (max-width: 768px){.app-header{padding:.875rem 1rem}.app-header__title{font-size:1.125rem}.app-header__subtitle{display:none}.app-main{padding:1rem;gap:1rem}.history-panel{padding:1rem}.history-list{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.5rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.history-list::-webkit-scrollbar{height:4px}.history-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:100px}.history-item{flex-shrink:0}.stats-row{grid-template-columns:repeat(3,1fr);gap:.5rem}.stat-value{font-size:1.25rem}.sweep-section-wrapper{padding:0 1rem}}@media (max-width: 480px){.stats-row{grid-template-columns:1fr 1fr}.noise-presets{gap:.25rem}.preset-btn{font-size:.6875rem;padding:.25rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
