:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#27272a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#a1a1aa;text-decoration:none}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:#3f3f46;background-image:url(/gcode-visualizer/bg-pattern.svg);background-repeat:repeat;background-size:auto;background-blend-mode:overlay}.container{background:#e4e4e7;padding:32px;border-radius:0;border:2px solid #a1a1aa;width:calc(100vw - 40px);max-width:1800px;height:95vh;margin:0;display:flex;flex-direction:column;overflow:hidden}h1{font-size:3.2em;line-height:1.1;color:#52525b;font-weight:800;letter-spacing:-.02em;margin:0 0 32px;padding:16px;text-align:center;position:relative;flex-shrink:0}h1:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:100px;height:4px;background:#71717a;border-radius:0}.app-description{text-align:center;color:#64748b;font-size:1.1em;line-height:1.6;max-width:700px;margin:-16px auto 32px;padding:0 20px;font-weight:400;flex-shrink:0}.tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #d4d4d8;padding-bottom:0;flex-wrap:wrap;flex-shrink:0}.tab{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#71717a;font-size:1em;font-weight:600;cursor:pointer;position:relative;bottom:-2px}.tab:disabled{opacity:.4;cursor:not-allowed}.tab.active{color:#52525b;border-bottom-color:#71717a;background:#d4d4d8}.tab:not(:disabled):active{transform:none}.tab-content{flex:1;overflow-y:auto;overflow-x:hidden;padding-right:8px}.tab-content::-webkit-scrollbar{width:10px}.tab-content::-webkit-scrollbar-track{background:#d4d4d8;border-radius:0}.tab-content::-webkit-scrollbar-thumb{background:#71717a;border-radius:0}h2{font-size:1.8em;line-height:1.2;text-align:left;color:#27272a;font-weight:700;margin:32px 0 16px;padding:12px 16px;background:#d4d4d8;border-left:4px solid #71717a;border-radius:0}h3{font-size:1.2em;line-height:1.2;text-align:left;color:#3f3f46;font-weight:600;margin:20px 0 12px;padding:8px 12px;background:#e4e4e7;border-left:3px solid #a1a1aa;border-radius:0}button{border-radius:0;border:2px solid #52525b;padding:.7em 1.4em;font-size:.95em;font-weight:600;font-family:inherit;cursor:pointer;background:#71717a;color:#fff}button:active{background:#52525b}button:focus,button:focus-visible{outline:2px solid #a1a1aa;outline-offset:2px}input[type=file]{border:2px solid #a1a1aa;padding:10px 16px;border-radius:0;font-family:inherit;font-size:.95em;background:#fff;cursor:pointer}@media (prefers-color-scheme: light){:root{color:#27272a;background-color:#e4e4e7}}#root{max-width:100%;margin:0 auto;padding:20px;width:100%;display:flex;justify-content:center;align-items:center;min-height:100vh}.logo{height:6em;padding:1.5em}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}.container{animation:fadeIn .6s ease-out}}.card{padding:20px;background:#fff;border-radius:4px;box-shadow:0 2px 8px #0000000d;border:1px solid #e2e8f0}.read-the-docs{color:#64748b}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:0}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:0}textarea{border:2px solid #e2e8f0;border-radius:4px;padding:12px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9em;line-height:1.5;background:#f8fafc;color:#1e293b;transition:all .3s ease;resize:vertical}textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;background:#fff}p{margin:8px 0;color:#475569;line-height:1.6}canvas{border-radius:2px;box-shadow:0 4px 12px #0000001a;border:2px solid #e2e8f0}
