@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Share+Tech+Mono&display=swap";:root{--bg-main: #f4f5f7;--panel-bg: #1e293b;--text-light: #f8fafc;--text-dark: #0f172a;--accent: #3b82f6;--accent-hover: #2563eb;--danger: #ef4444;--border: #334155;--canvas-bg: #0f172a;--font-ui: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "Courier New", Courier, monospace;--font-digital: "Share Tech Mono", monospace;--radius: 12px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}*{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;overflow:auto;font-family:var(--font-ui);background:linear-gradient(135deg,#0f172a,#1e293b 40%,#3b82f6);color:var(--text-light);min-width:1024px;min-height:768px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app-grid{display:grid;grid-template-columns:1fr 300px;grid-template-rows:auto 1fr 250px;width:100%;height:100%;gap:20px;padding:20px}#top-nav{grid-column:1 / 3;background:#1e293bb3;backdrop-filter:blur(12px);color:var(--text-light);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:15px;padding:15px 20px;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:var(--shadow-sm);z-index:10}.module-selector{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;order:3;flex-wrap:nowrap}.brand h1{font-size:1.2rem;letter-spacing:.5px}.global-time-controls{display:flex;align-items:center;gap:10px}.global-time-controls label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:var(--text-light)}.global-time-controls input[type=checkbox]{appearance:none;-webkit-appearance:none;width:32px;height:18px;background:#fff3;border-radius:9px;position:relative;cursor:pointer;outline:none;transition:background .3s;margin:0;box-shadow:inset 0 1px 2px #0000001a}.global-time-controls input[type=checkbox]:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0003}.global-time-controls input[type=checkbox]:checked{background:var(--accent)}.global-time-controls input[type=checkbox]:checked:after{transform:translate(14px)}#simulation-area{grid-column:1 / 2;grid-row:2 / 3;background-color:transparent;position:relative;overflow:hidden;padding:15px;border:1px solid rgba(255,255,255,.1);border-radius:16px}#canvas-wrapper{position:relative;width:100%;height:100%;background-color:var(--canvas-bg);border-radius:var(--radius);box-shadow:inset 0 0 50px #00000080,var(--shadow-md);overflow:hidden}#canvas-wrapper:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(56,189,248,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(56,189,248,.05) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;-webkit-mask-image:radial-gradient(ellipse at center,black 60%,transparent 100%);mask-image:radial-gradient(ellipse at center,black 60%,transparent 100%);z-index:0}#simulation-canvas{width:100%;height:100%;display:block;position:relative;z-index:1}#overlay-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}#controls-container{grid-column:2 / 3;grid-row:2 / 4;background:#1e293bb3;backdrop-filter:blur(12px);color:var(--text-light);padding:20px;overflow-y:auto;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:inset 0 1px 1px #ffffff1a,-2px 0 10px #0000000d;z-index:5}.control-group{margin-bottom:20px}.control-group label{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:5px}.control-group input[type=range]{-webkit-appearance:none;appearance:none;width:100%;background:transparent;cursor:pointer}.control-group input[type=range]:focus{outline:none}.control-group input[type=range]:disabled{cursor:not-allowed;opacity:.5}#dashboard-container{grid-column:1 / 2;grid-row:3 / 4;background:#1e293bb3;backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:0 15px 15px;overflow:hidden;gap:15px;border:1px solid rgba(255,255,255,.1);border-radius:16px;box-shadow:inset 0 1px 1px #ffffff1a,var(--shadow-sm)}.uplot{font-family:var(--font-mono)}.uplot .u-title{font-family:var(--font-ui);font-weight:500}.u-legend{color:var(--text-light)}.u-legend .u-series{background:#ffffff0d;border-radius:20px;padding:4px 12px;margin-bottom:8px;display:inline-block}.ruler-overlay,.stopwatch-overlay{position:absolute;pointer-events:auto;cursor:grab;user-select:none;border-radius:var(--radius)}.ruler-overlay{background:repeating-linear-gradient(90deg,rgba(255,255,255,.2),rgba(255,255,255,.2) 1px,transparent 1px,transparent 10px),#0f172a99;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px #ffffff80,var(--shadow-md);padding:5px;font-family:var(--font-mono);color:var(--text-light)}.stopwatch-overlay{background:#0f172a99;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 1px 2px #00000080,var(--shadow-md);padding:10px 15px;color:var(--text-light);font-family:var(--font-ui)}.ruler-overlay:active,.stopwatch-overlay:active{cursor:grabbing}.stopwatch-value{font-family:var(--font-digital);font-size:1.6rem;color:#10b981;text-shadow:0 0 8px rgba(16,185,129,.5);letter-spacing:2px}#main-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:transparent;color:var(--text-dark);text-align:center;padding:20px}.glass-panel{background:#ffffff14;backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:50px;box-shadow:var(--shadow-lg),0 0 30px #3b82f626;display:flex;flex-direction:column;align-items:center;color:var(--text-light)}.glass-panel h1{font-size:2.5rem;margin-bottom:40px;text-shadow:0 2px 4px rgba(0,0,0,.3)}img.main-logo{display:block;width:180px;height:180px;margin-bottom:25px;object-fit:contain}img.brand-logo{width:44px;height:44px;object-fit:contain;flex-shrink:0}.menu-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:15px;width:100%;max-width:800px}.glass-panel footer{margin-top:50px;font-size:.9rem;color:#cbd5e1;text-align:center;line-height:1.6;max-width:32rem}.main-menu-credits__school{margin:0 0 .65rem;font-weight:600;color:#e2e8f0;letter-spacing:.02em}.main-menu-credits__authors{margin:0;font-size:.85rem;color:#cbd5e1}.btn{background:transparent;border:1px solid transparent;color:var(--text-dark);padding:8px 12px;cursor:pointer;font-size:.9rem;font-family:var(--font-ui);transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:var(--radius);display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}.btn svg{flex-shrink:0}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0);box-shadow:none}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);color:#fff;border-color:transparent;box-shadow:0 4px 15px #3b82f666}.btn-primary:hover,.btn-primary:focus-visible{background:linear-gradient(135deg,var(--accent-hover) 0%,var(--accent) 100%);border-color:transparent;box-shadow:0 0 20px #3b82f699}.btn-ghost{border-color:#fff3;color:var(--text-light)}.btn-ghost:hover{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.btn-ghost.active{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);border-color:transparent;color:#fff;box-shadow:0 4px 15px #3b82f666}.nav-btn{text-align:center;padding:6px 10px;font-size:.85rem;position:relative}.btn-ghost.nav-btn.active{background:transparent;color:var(--accent);box-shadow:none;border-color:transparent}.nav-btn:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:0;height:3px;background:var(--accent);transition:width .3s ease,box-shadow .3s ease;border-radius:3px}.nav-btn.active:after{width:80%;box-shadow:0 0 8px var(--accent)}.menu-btn{grid-column:span 2;padding:15px 25px;font-size:1.1rem;text-align:center}.menu-btn:nth-child(4){grid-column:2 / 4}.menu-btn:nth-child(5){grid-column:4 / 6}.back-btn{padding:6px 12px;font-size:.85rem}.preset-btn{width:100%;margin-bottom:8px;background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.2)}.preset-btn:hover{background:var(--accent);border-color:var(--accent)}input[type=checkbox]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius)}.control-group input[type=range]:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px #3b82f666}.control-group input[type=range]:focus-visible::-moz-range-thumb{box-shadow:0 0 0 4px #3b82f666}.control-group input[type=range]::-webkit-slider-runnable-track{height:6px;background:linear-gradient(to right,var(--accent) var(--value-percent, 50%),rgba(255,255,255,.1) var(--value-percent, 50%));border-radius:var(--radius);box-shadow:inset 0 1px 2px #0000001a}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;height:18px;width:18px;background:var(--accent);border-radius:50%;margin-top:-6px;border:2px solid white;box-shadow:0 0 10px var(--accent),inset 0 1px 2px #ffffff80;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s}.control-group input[type=range]:hover::-webkit-slider-thumb{transform:scale(1.15);box-shadow:0 0 15px var(--accent),inset 0 1px 2px #ffffff80}.control-group input[type=range]:focus::-webkit-slider-thumb,.control-group input[type=range]:active::-webkit-slider-thumb{background:var(--accent-hover);box-shadow:0 0 20px var(--accent),inset 0 1px 2px #ffffff80}.control-group input[type=range]::-moz-range-track{height:6px;background:#ffffff1a;border-radius:var(--radius);box-shadow:inset 0 1px 2px #0000001a}.control-group input[type=range]::-moz-range-progress{height:6px;background:var(--accent);border-radius:var(--radius)}.control-group input[type=range]::-moz-range-thumb{height:18px;width:18px;background:var(--accent);border:2px solid white;border-radius:50%;box-shadow:0 0 10px var(--accent),inset 0 1px 2px #ffffff80;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s}.control-group input[type=range]:hover::-moz-range-thumb{transform:scale(1.15);box-shadow:0 0 15px var(--accent),inset 0 1px 2px #ffffff80}.control-group input[type=range]:focus::-moz-range-thumb,.control-group input[type=range]:active::-moz-range-thumb{background:var(--accent-hover);box-shadow:0 0 20px var(--accent),inset 0 1px 2px #ffffff80}#controls-container::-webkit-scrollbar{width:8px}#controls-container::-webkit-scrollbar-track{background:var(--panel-bg)}#controls-container::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius)}#controls-container::-webkit-scrollbar-thumb:hover{background:var(--accent)}.dashboard-card{background-color:var(--canvas-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md),0 0 15px #3b82f61a;transition:transform .2s;color:var(--text-light)}.controls-section-header{font-size:.85rem;font-weight:600;color:var(--text-light);border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:5px;margin-top:15px;margin-bottom:15px;text-transform:uppercase;letter-spacing:1px}.controls-section-header:first-child{margin-top:0}.vector-legend{position:absolute;bottom:20px;right:20px;background:#0f172abf;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);padding:10px;display:flex;flex-direction:column;gap:5px;font-size:.85rem;color:var(--text-light);box-shadow:var(--shadow-md);pointer-events:none;z-index:3}.vector-legend .legend-item{display:flex;align-items:center;gap:8px;font-weight:500}.vector-legend .color-box{width:12px;height:12px;border-radius:3px;display:inline-block;box-shadow:0 1px 2px #00000080}@keyframes fadeInUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeInUp .4s cubic-bezier(.16,1,.3,1) forwards}.uplot,.uplot *,.uplot *:before,.uplot *:after{box-sizing:border-box}.uplot{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";line-height:1.5;width:min-content}.u-title{text-align:center;font-size:18px;font-weight:700}.u-wrap{position:relative;user-select:none}.u-over,.u-under{position:absolute}.u-under{overflow:hidden}.uplot canvas{display:block;position:relative;width:100%;height:100%}.u-axis{position:absolute}.u-legend{font-size:14px;margin:auto;text-align:center}.u-inline{display:block}.u-inline *{display:inline-block}.u-inline tr{margin-right:16px}.u-legend th{font-weight:600}.u-legend th>*{vertical-align:middle;display:inline-block}.u-legend .u-marker{width:1em;height:1em;margin-right:4px;background-clip:padding-box!important}.u-inline.u-live th:after{content:":";vertical-align:middle}.u-inline:not(.u-live) .u-value{display:none}.u-series>*{padding:4px}.u-series th{cursor:pointer}.u-legend .u-off>*{opacity:.3}.u-select{background:#00000012;position:absolute;pointer-events:none}.u-cursor-x,.u-cursor-y{position:absolute;left:0;top:0;pointer-events:none;will-change:transform}.u-hz .u-cursor-x,.u-vt .u-cursor-y{height:100%;border-right:1px dashed #607D8B}.u-hz .u-cursor-y,.u-vt .u-cursor-x{width:100%;border-bottom:1px dashed #607D8B}.u-cursor-pt{position:absolute;top:0;left:0;border-radius:50%;border:0 solid;pointer-events:none;will-change:transform;background-clip:padding-box!important}.u-axis.u-off,.u-select.u-off,.u-cursor-x.u-off,.u-cursor-y.u-off,.u-cursor-pt.u-off{display:none}
