*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=bauhaus]{--bg-primary: #f0e9d6;--bg-secondary: #e8e0c8;--bg-card: #faf6e8;--bg-card-hover: #f5efd8;--border: #1a1612;--border-light: #1a1612;--text-primary: #1a1612;--text-secondary: #3a342c;--text-muted: #6e6759;--accent: #e23b22;--accent-light: #f5c842;--accent-dim: #f5c842;--accent-grad: #e23b22;--on-accent: #faf6e8;--green: #2e6e3a;--green-dim: rgba(46, 110, 58, .18);--red: #c43030;--red-dim: rgba(196, 48, 48, .18);--blue: #1d3a6c;--blue-grad: #1d3a6c;--overlay: rgba(26, 22, 18, .55);--font-heading: "Archivo Black", "Funnel Display", sans-serif;--font-body: "Familjen Grotesk", "Onest", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--stamp-bg: #1a1612;--stamp-fg: #f5c842;--focus-ring: #1a1612}[data-theme=bauhaus-dark]{--bg-primary: #14110b;--bg-secondary: #1c1812;--bg-card: #221d16;--bg-card-hover: #2c261d;--border: #f0e9d6;--border-light: #f0e9d6;--text-primary: #f0e9d6;--text-secondary: #cfc7b3;--text-muted: #8a8273;--accent: #ef5a45;--accent-light: #f5c842;--accent-dim: #f5c842;--accent-grad: #ef5a45;--on-accent: #14110b;--green: #6ec46e;--green-dim: rgba(110, 196, 110, .2);--red: #ef5a45;--red-dim: rgba(239, 90, 69, .22);--blue: #6e9ad8;--blue-grad: #6e9ad8;--overlay: rgba(0, 0, 0, .72);--stamp-bg: #f5c842;--stamp-fg: #14110b;--focus-ring: #f0e9d6}html,body{transition:background .3s ease,color .3s ease}h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:600}body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;letter-spacing:-.005em}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes pulse-green{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 12px 4px #22c55e26}}@keyframes pulse-red{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 12px 4px #ef444426}}@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}90%{opacity:1}to{transform:translate(var(--drift, 0),105vh) rotate(720deg);opacity:0}}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes tx-ribbon-enter{0%{opacity:0;transform:translateY(16px) rotate(-1.4deg)}to{opacity:1;transform:translateY(0) rotate(-1.4deg)}}@keyframes tx-ribbon-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes tx-panel-pop{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes tx-phase-pulse{0%,to{transform:translateY(0);background:var(--bg-card);color:var(--text-muted)}45%{transform:translateY(-2px);background:var(--accent-light);color:var(--border)}}.tx-status-link{color:inherit;text-decoration:underline;text-underline-offset:3px;pointer-events:auto;white-space:nowrap}.tx-status-toast{position:fixed;top:70px;left:50%;transform:translate(-50%);z-index:300;padding:12px 24px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font-heading);animation:slide-up .3s ease;max-width:min(400px,calc(100vw - 32px));text-align:center;line-height:1.35}.tx-status-toast .tx-status-link{margin-left:6px}.tx-status-success{background:var(--green-dim);border:1px solid var(--green);color:var(--green)}.tx-status-warning{background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent)}.tx-status-error{background:var(--red-dim);border:1px solid var(--red);color:var(--red)}.tx-loading-stage{position:fixed;left:0;right:0;top:clamp(150px,38vh,390px);z-index:320;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:14px}.tx-loading-ribbon{width:100vw;overflow:hidden;background:var(--accent-light);border-top:4px solid var(--border);border-bottom:4px solid var(--border);box-shadow:8px 8px 0 var(--accent);transform:rotate(-1.4deg);animation:tx-ribbon-enter .18s ease-out}.tx-loading-track{display:flex;width:max-content;animation:tx-ribbon-scroll var(--tx-ribbon-duration, 5.5s) linear infinite;will-change:transform}.tx-loading-word{display:inline-flex;align-items:center;height:clamp(64px,8vw,118px);padding:0 clamp(22px,4vw,58px);color:var(--border);font-family:var(--font-heading);font-size:clamp(30px,5.6vw,82px);font-weight:900;line-height:1;letter-spacing:0;text-transform:uppercase;white-space:nowrap;text-shadow:3px 3px 0 rgba(250,246,232,.55)}.tx-loading-word:after{content:"";width:clamp(12px,1.8vw,26px);height:clamp(12px,1.8vw,26px);margin-left:clamp(22px,4vw,58px);background:var(--accent);border:3px solid var(--border)}.tx-loading-panel{pointer-events:auto;min-width:min(520px,calc(100vw - 32px));max-width:calc(100vw - 32px);background:var(--bg-card);border:3px solid var(--border);border-radius:0;box-shadow:6px 6px 0 var(--accent);padding:12px 16px;display:grid;gap:10px;justify-items:center;color:var(--text-primary);font-family:var(--font-heading);animation:tx-panel-pop .18s ease-out}.tx-loading-message{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;line-height:1.25;text-align:center}.tx-loading-dot{width:10px;height:10px;background:var(--accent);border:2px solid var(--border);flex:0 0 auto;animation:tx-phase-pulse .9s ease-in-out infinite}.tx-loading-phases{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}.tx-loading-phase{border:2px solid var(--border);background:var(--bg-card);color:var(--text-muted);padding:4px 8px;font-size:10px;line-height:1;letter-spacing:0;animation:tx-phase-pulse 1.25s ease-in-out infinite}@media (max-width: 640px){.tx-loading-stage{top:34vh;gap:10px}.tx-loading-panel{min-width:calc(100vw - 28px);padding:10px 12px}.tx-loading-message{font-size:12px}}@media (prefers-reduced-motion: reduce){.tx-loading-track,.tx-loading-dot,.tx-loading-phase,.tx-loading-ribbon,.tx-loading-panel{animation:none}}.theme-toggle{background:var(--bg-card);border:1px solid var(--border-light);border-radius:999px!important;height:28px;display:inline-flex;align-items:center;padding:2px;cursor:pointer;transition:border-color .2s;flex-shrink:0;gap:0}.theme-toggle:hover{border-color:var(--accent)}.theme-toggle .seg{width:24px;height:24px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;line-height:1;padding:0;transition:background .2s,color .2s;font-family:JetBrains Mono,monospace}.theme-toggle .seg:hover{color:var(--text-primary)}.theme-toggle .seg.on{background:var(--accent);color:var(--on-accent)}[data-theme=bauhaus] body,[data-theme=bauhaus-dark] body{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 300 300' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E")}[data-theme=bauhaus] h1,[data-theme=bauhaus] h2,[data-theme=bauhaus] h3,[data-theme=bauhaus] h4,[data-theme=bauhaus-dark] h1,[data-theme=bauhaus-dark] h2,[data-theme=bauhaus-dark] h3,[data-theme=bauhaus-dark] h4{font-family:Archivo Black,sans-serif;text-transform:uppercase;letter-spacing:-.01em;font-weight:900}[data-theme=bauhaus] [style*=border-radius]:not([style*="50%"]),[data-theme=bauhaus] [style*=borderRadius]:not([style*="50%"]),[data-theme=bauhaus-dark] [style*=border-radius]:not([style*="50%"]),[data-theme=bauhaus-dark] [style*=borderRadius]:not([style*="50%"]){border-radius:0!important}[data-theme=bauhaus] [style*="border: 1px"],[data-theme=bauhaus] [style*="border:1px"],[data-theme=bauhaus-dark] [style*="border: 1px"],[data-theme=bauhaus-dark] [style*="border:1px"]{border-width:2px!important}[data-theme=bauhaus] [style*="border: 2px"],[data-theme=bauhaus] [style*="border:2px"],[data-theme=bauhaus-dark] [style*="border: 2px"],[data-theme=bauhaus-dark] [style*="border:2px"]{border-width:3px!important}[data-theme=bauhaus] h1,[data-theme=bauhaus-dark] h1{background:var(--stamp-bg);color:var(--stamp-fg);display:inline-block;padding:.2em .5em .25em;margin-bottom:.4em!important;font-size:2.4rem!important;letter-spacing:0!important}[data-theme=bauhaus] .theme-toggle,[data-theme=bauhaus-dark] .theme-toggle{border-radius:999px!important}[data-theme=bauhaus] .bauhaus-deco,[data-theme=bauhaus-dark] .bauhaus-deco{position:relative;overflow:hidden}[data-theme=bauhaus] .bauhaus-deco:after,[data-theme=bauhaus-dark] .bauhaus-deco:after{content:"";position:absolute;bottom:-22px;right:-22px;width:64px;height:64px;border-radius:50%!important;background:var(--accent-light);pointer-events:none;z-index:0}[data-theme=bauhaus] .bauhaus-deco>*,[data-theme=bauhaus-dark] .bauhaus-deco>*{position:relative;z-index:1}[data-theme=bauhaus] button:focus-visible,[data-theme=bauhaus] input:focus-visible,[data-theme=bauhaus-dark] button:focus-visible,[data-theme=bauhaus-dark] input:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}
