*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text);transition:background-color .3s ease,color .3s ease}@keyframes subtleBg{0%{background-position:0% 0%}50%{background-position:100% 100%}to{background-position:0% 0%}}:root{--bg: #f8fafc;--panel: #ffffff;--panel-strong: #eef7f5;--text: #0f172a;--muted: #475569;--accent: #0f766e;--good: #15803d;--warn: #b45309;--error: #dc2626;--border: #dbe4e8;--shadow: rgba(15, 23, 42, .09);--hover: #e4e4e7;--active: #d4d4d8;--grid-size: 40px;--border-radius: 6px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--accent-rgb: 37, 99, 235;--good-rgb: 22, 163, 74}[data-theme=dark]{--bg: #081113;--panel: #10191c;--panel-strong: #15282a;--text: #eef8f7;--muted: #9fb4b4;--accent: #5eead4;--good: #86efac;--warn: #facc15;--error: #ef4444;--border: #244146;--shadow: rgba(0, 0, 0, .5);--hover: #172f33;--active: #1f4045;--accent-rgb: 59, 130, 246;--good-rgb: 34, 197, 94}#root,.App,.app-content{min-height:100dvh}a{color:var(--accent)}button,input,select{font:inherit}*:focus{outline:2px solid var(--accent);outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}h1,h2,h3,h4,h5,h6{font-weight:600;margin-bottom:var(--spacing-md)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{margin-bottom:var(--spacing-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--border-radius);background-color:var(--panel);color:var(--text);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease;min-height:44px;min-width:44px;gap:var(--spacing-xs)}.btn:hover{background-color:var(--hover);border-color:var(--accent)}.btn:active{background-color:var(--active);transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background-color:var(--accent);opacity:.9}.btn-success{background-color:var(--good);color:#fff;border-color:var(--good)}.btn-warning{background-color:var(--warn);color:#fff;border-color:var(--warn)}.btn-danger{background-color:var(--error);color:#fff;border-color:var(--error)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.game-layout{display:grid;grid-template-areas:"toolbox canvas info" "toolbox canvas info";grid-template-columns:250px 1fr 300px;grid-template-rows:1fr;min-height:100vh;gap:var(--spacing-sm);padding:var(--spacing-sm);overflow-y:auto}.toolbox{grid-area:toolbox;background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:var(--spacing-md);overflow-y:auto}.canvas{grid-area:canvas;background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);position:relative;overflow:hidden}.info-panel{grid-area:info;background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:var(--spacing-md);overflow-y:auto}@media (max-width: 768px){.game-layout{grid-template-areas:"toolbox" "canvas" "info";grid-template-columns:1fr;grid-template-rows:auto 1fr auto;height:100vh}.toolbox{max-height:150px}.info-panel{max-height:200px}.main-menu{padding:var(--spacing-md)}.menu-options{grid-template-columns:1fr;max-width:400px;gap:var(--spacing-md)}.menu-card:hover{transform:translateY(-4px)}}@media (max-width: 480px){.game-layout{padding:var(--spacing-xs);gap:var(--spacing-xs)}.toolbox,.info-panel{padding:var(--spacing-sm)}.main-menu{padding:var(--spacing-sm);min-height:100vh}.main-menu h1{font-size:2rem;margin-bottom:var(--spacing-md)}.menu-options{max-width:320px;gap:var(--spacing-sm)}.menu-card{padding:var(--spacing-md)}.menu-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px var(--shadow)}.menu-card:hover{transform:translateY(-2px) rotateX(0)}}.card{background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:var(--spacing-md);box-shadow:0 2px 4px var(--shadow);transition:all .2s ease}.card:hover{box-shadow:0 4px 8px var(--shadow);transform:translateY(-2px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal{background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:var(--spacing-lg);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 16px var(--shadow)}.component-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.component-item{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm);border:1px solid var(--border);border-radius:var(--border-radius);background-color:var(--bg);cursor:grab;transition:all .2s ease;min-height:80px;justify-content:center}.component-item:hover{background-color:var(--hover);border-color:var(--accent)}.component-item:active{cursor:grabbing;transform:scale(.95)}.component-item svg{width:32px;height:32px;margin-bottom:var(--spacing-xs)}.component-item span{font-size:.75rem;text-align:center}.physics-modules{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md);padding:var(--spacing-md)}.main-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;position:relative}.main-menu h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:var(--spacing-lg);background:linear-gradient(45deg,var(--accent),var(--good));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.menu-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);max-width:900px;width:100%;perspective:1000px}.menu-card{background-color:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:var(--spacing-lg);text-decoration:none;color:var(--text);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden;transform-style:preserve-3d;will-change:transform;display:flex;flex-direction:column;min-height:300px;height:100%}.menu-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent,var(--accent));opacity:0;transition:opacity .3s ease;pointer-events:none}.menu-card:hover{transform:translateY(-8px) rotateX(5deg);box-shadow:0 12px 32px var(--shadow),0 2px 8px #0000001a;border-color:var(--accent)}.menu-card:hover:before{opacity:.03}.menu-card:focus{outline:2px solid var(--accent);outline-offset:2px;transform:translateY(-4px)}.menu-card:active{transform:translateY(-2px) scale(.98)}.menu-card h2{color:var(--accent);margin-bottom:var(--spacing-md)}.theme-controls{position:fixed;top:var(--spacing-md);right:var(--spacing-md);display:flex;gap:var(--spacing-sm);z-index:100}.home-page{min-height:100dvh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--panel-strong) 0%,var(--bg) 42%,var(--bg) 100%)}.home-shell{width:min(1180px,calc(100% - 32px));margin:0 auto}.home-header{height:76px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand-mark{display:flex;align-items:center;gap:.75rem;color:var(--text);text-decoration:none;font-weight:800}.brand-mark img{width:42px;height:42px;border-radius:8px}.home-actions,.home-nav{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.home-hero{min-height:calc(100dvh - 180px);display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.86fr);gap:clamp(1rem,3vw,2.5rem);align-items:center;padding:1rem 0 2rem}.eyebrow{margin:0 0 .75rem;color:var(--accent);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.home-hero h1{margin:0;max-width:780px;font-size:clamp(2.3rem,5vw,5rem);line-height:.98;font-weight:900;color:var(--text)}.home-hero p{max-width:680px;margin:1rem 0 0;color:var(--muted);font-size:clamp(1rem,2vw,1.2rem)}.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-top:1.5rem;max-width:620px}.hero-stat,.lab-card,.legal-document,.mini-panel{border:1px solid var(--border);background:var(--panel);border-radius:8px;box-shadow:0 10px 30px var(--shadow)}.hero-stat{padding:.9rem}.hero-stat strong{display:block;font-size:1.3rem;color:var(--text)}.hero-stat span{color:var(--muted);font-size:.78rem}.lab-visual{min-height:470px;border:1px solid var(--border);border-radius:8px;background:var(--panel);box-shadow:0 18px 50px var(--shadow);overflow:hidden;display:grid;grid-template-rows:auto 1fr}.lab-visual-top{display:flex;justify-content:space-between;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border);color:var(--muted);font-size:.8rem}.lab-visual-stage{position:relative;min-height:360px;background:linear-gradient(90deg,color-mix(in srgb,var(--border) 35%,transparent) 1px,transparent 1px),linear-gradient(0deg,color-mix(in srgb,var(--border) 35%,transparent) 1px,transparent 1px);background-size:36px 36px}.atom-node,.orbit-ring,.molecule-bond{position:absolute}.orbit-ring{top:17%;right:17%;bottom:17%;left:17%;border:1px solid color-mix(in srgb,var(--accent) 44%,transparent);border-radius:50%;transform:rotate(-18deg)}.orbit-ring:nth-child(2){top:28%;right:28%;bottom:28%;left:28%;transform:rotate(38deg);border-color:color-mix(in srgb,var(--warn) 50%,transparent)}.atom-node{width:24px;height:24px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px color-mix(in srgb,var(--accent) 16%,transparent)}.atom-node.one{left:22%;top:23%}.atom-node.two{right:26%;top:31%;background:var(--warn)}.atom-node.three{left:46%;bottom:22%;background:var(--good)}.molecule-bond{left:30%;right:29%;top:50%;height:2px;background:var(--border);transform:rotate(20deg)}.mini-panel{position:absolute;left:1rem;right:1rem;bottom:1rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:.75rem;box-shadow:none}.mini-panel span{display:block;color:var(--muted);font-size:.72rem}.mini-panel strong{display:block;color:var(--text);font-size:.88rem}.lab-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;padding:0 0 2rem}.lab-card{min-height:280px;padding:1.25rem;text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:.75rem;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.lab-card:hover,.lab-card:focus-visible{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 18px 42px var(--shadow)}.lab-card-icon{font-size:2rem}.lab-card h2{margin:0;font-size:1.08rem}.lab-card p{margin:0;color:var(--muted);font-size:.88rem;flex:1}.tag-list{display:flex;flex-wrap:wrap;gap:.35rem}.tag-list span{border:1px solid var(--border);border-radius:4px;padding:.18rem .45rem;color:var(--muted);font-size:.7rem}.home-footer{border-top:1px solid var(--border);padding:1rem 0;color:var(--muted);font-size:.82rem}.home-footer .home-shell{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.legal-page{min-height:100dvh;padding:1rem;background:var(--bg)}.legal-nav{width:min(920px,100%);margin:0 auto 1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.legal-nav-link{border:1px solid var(--border);border-radius:6px;padding:.55rem .8rem;color:var(--text);text-decoration:none;background:var(--panel)}.legal-document{width:min(920px,100%);margin:0 auto;padding:clamp(1.2rem,4vw,2.5rem)}.legal-document h1{margin:0 0 .75rem;font-size:clamp(2rem,5vw,3.5rem)}.legal-intro,.legal-document p{color:var(--muted)}.legal-document article{padding-top:1rem;border-top:1px solid var(--border)}.legal-document h2{margin-bottom:.35rem;font-size:1.05rem}.legal-footer{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border);color:var(--muted)}.sandbox-page{height:100dvh;width:100%;display:grid;grid-template-rows:auto 1fr;overflow:hidden;color:var(--text);background:var(--bg)}.sandbox-header{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 1rem;border-bottom:1px solid var(--border);background:var(--panel)}.sandbox-title{display:flex;align-items:center;gap:.7rem;min-width:0}.sandbox-title h1{margin:0;font-size:clamp(1rem,2vw,1.45rem);line-height:1.1}.sandbox-title p{margin:.1rem 0 0;color:var(--muted);font-size:.78rem}.segmented{display:inline-flex;border:1px solid var(--border);border-radius:8px;background:var(--bg);padding:3px}.segmented button{border:0;border-radius:6px;padding:.45rem .75rem;background:transparent;color:var(--muted);cursor:pointer;font-weight:700;min-width:74px}.segmented button.active{background:var(--accent);color:#fff}.sandbox-body{min-height:0;overflow:hidden}.lab-sim{height:100%;display:grid;grid-template-columns:minmax(250px,320px) minmax(0,1fr) minmax(220px,280px);gap:.75rem;padding:.75rem;overflow:hidden}.lab-panel,.lab-stage{min-height:0;border:1px solid var(--border);background:var(--panel);border-radius:8px;overflow:hidden}.lab-panel{padding:.75rem;overflow-y:auto}.lab-panel h2,.lab-panel h3{margin:0 0 .65rem;font-size:.95rem}.control-stack{display:grid;gap:.55rem}.control-row{display:grid;gap:.25rem}.control-row label,.control-caption{display:flex;justify-content:space-between;gap:.5rem;color:var(--muted);font-size:.78rem}.control-row input[type=range]{width:100%;accent-color:var(--accent)}.button-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.lab-button{min-height:40px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);cursor:pointer;font-weight:700}.lab-button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.lab-button.danger{color:var(--error)}.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem}.metric-card{border:1px solid var(--border);border-radius:6px;background:var(--bg);padding:.55rem}.metric-card span{color:var(--muted);display:block;font-size:.7rem}.metric-card strong{display:block;color:var(--text);font-size:.92rem}.lab-stage{position:relative;display:grid;place-items:stretch}.lab-stage canvas{display:block}.canvas-host{position:absolute;top:0;right:0;bottom:0;left:0}.canvas-host canvas{width:100%!important;height:100%!important}.stage-hint{position:absolute;left:1rem;bottom:1rem;z-index:2;max-width:min(420px,calc(100% - 2rem));padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;background:color-mix(in srgb,var(--panel) 88%,transparent);color:var(--muted);font-size:.78rem}@media (max-width: 1100px){.home-hero{grid-template-columns:1fr;min-height:auto}.lab-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.lab-sim{grid-template-columns:240px minmax(0,1fr)}.lab-sim .lab-panel:last-child{display:none}}@media (max-width: 820px) and (orientation: landscape){.sandbox-header{min-height:56px;padding:.45rem .65rem}.sandbox-title p,.home-nav{display:none}.lab-sim{grid-template-columns:210px minmax(0,1fr);gap:.45rem;padding:.45rem}.lab-panel{padding:.55rem}}@media (max-width: 760px){.home-header{height:auto;padding:.75rem 0;align-items:flex-start;flex-direction:column}.lab-grid,.hero-stats,.mini-panel{grid-template-columns:1fr}.lab-card{min-height:220px}}.progress-bar{width:100%;height:8px;background-color:var(--border);border-radius:4px;overflow:hidden;margin-bottom:var(--spacing-md)}.progress-fill{height:100%;background-color:var(--good);transition:width .3s ease}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--good);color:#fff;border-radius:12px;font-size:.75rem;font-weight:500;margin:var(--spacing-xs)}.badge-new{animation:badgeGlow 2s ease-in-out}@keyframes badgeGlow{0%,to{box-shadow:0 0 0 0 var(--good)}50%{box-shadow:0 0 0 8px transparent}}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top:3px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.circuit-grid{position:relative;background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);width:100%;height:100%;min-height:400px}.circuit-component{position:absolute;cursor:pointer;-webkit-user-select:none;user-select:none}.circuit-wire{stroke:var(--text);stroke-width:3;fill:none;cursor:pointer}.circuit-wire.active{stroke:var(--accent);stroke-width:4}.physics-canvas{width:100%;height:100%;border:1px solid var(--border);border-radius:var(--border-radius)}.control-panel{display:flex;flex-direction:column;gap:var(--spacing-md)}.slider-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.slider-group label{font-weight:500;display:flex;justify-content:space-between;align-items:center}.slider-group input[type=range]{width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer}.slider-group input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:none}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-auto{margin-top:auto}.mb-auto{margin-bottom:auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.context-menu{position:absolute;background:var(--panel);border:1px solid var(--border);border-radius:var(--border-radius);padding:8px 0;box-shadow:0 4px 12px var(--shadow);z-index:1000;min-width:120px;-webkit-user-select:none;user-select:none}.context-menu-item{padding:8px 16px;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text);font-size:14px;transition:background-color .2s ease}.context-menu-item:hover{background-color:var(--hover)}.context-menu-item.danger{color:var(--error)}.context-menu-item.danger:hover{background-color:#ef44441a}.landscape-warning{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--bg);color:var(--text);z-index:9999;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}@media (orientation: portrait) and (max-width: 768px){.landscape-warning{display:flex}.app-content{display:none}}@media (max-width: 768px){.advanced-physics-lab{flex-direction:column!important;height:auto!important;min-height:100vh}.adv-lab-viewport{height:50vh!important;border-right:none!important;border-bottom:1px solid #333}.adv-lab-controls{width:100%!important;height:auto!important}}.advanced-physics-lab{display:flex;flex-direction:row;height:100vh;width:100%;background:#111;color:#eee;font-family:sans-serif}.adv-lab-viewport{flex:1;position:relative;border-right:1px solid #333}.adv-lab-controls{width:350px;background:#1a1a24;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}
