*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.-bottom-10{bottom:-2.5rem}.-right-2{right:-.5rem}.-top-2{top:-.5rem}.bottom-4{bottom:1rem}.left-1\/2{left:50%}.top-full{top:100%}.z-20{z-index:20}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mt-2{margin-top:.5rem}.flex{display:flex}.grid{display:grid}.h-4{height:1rem}.h-5{height:1.25rem}.h-screen{height:100vh}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.min-w-\[100px\]{min-width:100px}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-ascii-primary{--tw-border-opacity:1;border-color:rgb(0 255 136/var(--tw-border-opacity,1))}.border-ascii-secondary{--tw-border-opacity:1;border-color:rgb(102 255 170/var(--tw-border-opacity,1))}.bg-ascii-primary{--tw-bg-opacity:1;background-color:rgb(0 255 136/var(--tw-bg-opacity,1))}.bg-canvas-green{--tw-bg-opacity:1;background-color:rgb(13 79 60/var(--tw-bg-opacity,1))}.bg-control-bg{background-color:rgba(0,0,0,.7)}.bg-opacity-90{--tw-bg-opacity:0.9}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.font-mono{font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.text-ascii-primary{--tw-text-opacity:1;color:rgb(0 255 136/var(--tw-text-opacity,1))}.text-canvas-green-dark{--tw-text-opacity:1;color:rgb(10 61 47/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity,1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-80{opacity:.8}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--canvas-green:#0d4f3c;--canvas-green-dark:#0a3d2f;--canvas-green-light:#105e48;--ascii-primary:#0f8;--ascii-secondary:#6fa;--control-bg:rgba(0,0,0,.7);--control-hover:rgba(0,255,136,.1);--grid-size:12px;--font-mono:Monaco,Menlo,"Ubuntu Mono",Consolas,"source-code-pro",monospace}html{scroll-behavior:smooth}body{margin:0;padding:0;font-family:var(--font-mono);background:linear-gradient(135deg,var(--canvas-green) 0,var(--canvas-green-dark) 100%);color:var(--ascii-primary);overflow:hidden;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}:focus{outline:none}button:focus-visible,input:focus-visible{outline:2px solid var(--ascii-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--canvas-green-dark)}::-webkit-scrollbar-thumb{background:var(--ascii-secondary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ascii-primary)}.canvas-container{position:relative;width:100vw;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}.drawing-canvas{display:block;cursor:crosshair;background:var(--canvas-green);border:2px solid var(--ascii-secondary);border-radius:4px;box-shadow:0 0 20px rgba(0,255,136,.3)}.drawing-canvas:active{cursor:none}.control-panel{position:absolute;background:var(--control-bg);backdrop-filter:blur(10px);border:1px solid var(--ascii-secondary);border-radius:8px;padding:12px;display:flex;align-items:center;gap:8px;z-index:10}.control-panel.top-left{top:16px;left:16px}.control-panel.top-right{top:16px;right:16px}.control-panel.bottom-left{bottom:16px;left:16px}.control-panel.bottom-right{bottom:16px;right:16px}.control-button{background:transparent;border:1px solid var(--ascii-secondary);color:var(--ascii-primary);padding:8px 12px;border-radius:4px;font-family:var(--font-mono);font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.control-button:hover{background:var(--control-hover);border-color:var(--ascii-primary);transform:translateY(-1px)}.control-button:active{transform:translateY(0)}.control-button.primary{background:var(--ascii-primary);color:var(--canvas-green-dark)}.control-button.primary:hover{background:var(--ascii-secondary)}.control-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.pattern-switcher{display:flex;flex-direction:column;align-items:center;gap:8px}.pattern-name{font-size:12px;color:var(--ascii-secondary);text-align:center;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-spinner{width:20px;height:20px;border-top:2px solid var(--canvas-green-light);border:2px solid var(--canvas-green-light);border-top-color:var(--ascii-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.status-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--control-bg);border:1px solid var(--ascii-secondary);border-radius:8px;padding:20px;text-align:center;max-width:300px;z-index:20}.status-message.error{border-color:#f44;color:#f66}.status-message.success{border-color:var(--ascii-primary);color:var(--ascii-primary)}@media (max-width:768px){.control-panel{padding:8px;gap:6px}.control-button{padding:6px 10px;font-size:12px}.pattern-name{font-size:11px;max-width:100px}}@media (max-width:480px){.control-panel.top-left,.control-panel.top-right{top:8px}.control-panel.bottom-left,.control-panel.top-left{left:8px}.control-panel.bottom-right,.control-panel.top-right{right:8px}.control-panel.bottom-left,.control-panel.bottom-right{bottom:8px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none;border-top-color:var(--ascii-primary)}}@media (prefers-contrast:high){:root{--ascii-primary:#0f0;--ascii-secondary:#fff;--control-bg:rgba(0,0,0,.9)}.drawing-canvas{border-width:3px}.control-button{border-width:2px}}@media (pointer:coarse){.control-button{padding:12px 16px;font-size:16px;min-height:44px}.drawing-canvas{touch-action:none}}@media print{body{background:#fff;color:#000}.control-panel{display:none}.drawing-canvas{border:1px solid #000;box-shadow:none}}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.pulse-soft{animation:pulseSoft 2s ease-in-out infinite}@keyframes pulseSoft{0%,to{opacity:1}50%{opacity:.7}}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--control-bg);color:var(--ascii-primary);padding:6px 8px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:100;margin-bottom:5px;border:1px solid var(--ascii-secondary)}.tooltip:hover:after{opacity:1}.custom-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--ascii-secondary);border-radius:3px;background:transparent;cursor:pointer;position:relative}.custom-checkbox:checked{background:var(--ascii-primary);border-color:var(--ascii-primary)}.custom-checkbox:checked:after{content:"✓";position:absolute;top:-2px;left:2px;color:var(--canvas-green-dark);font-size:14px;font-weight:700}.pattern-preview{display:flex;gap:2px;margin-top:4px}.pattern-char{font-family:var(--font-mono);font-size:10px;opacity:.7}.audio-status{position:relative}.audio-status:before{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--ascii-primary)}.audio-status.muted:before{background:#f44}@media (max-width:768px) and (orientation:portrait){.canvas-container{flex-direction:column}.drawing-canvas{max-width:calc(100vw - 32px);max-height:calc(100vh - 120px)}}::selection{background:var(--ascii-primary);color:var(--canvas-green-dark)}::-moz-selection{background:var(--ascii-primary);color:var(--canvas-green-dark)}.focus\:not-sr-only:focus{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}.focus\:absolute:focus{position:absolute}.focus\:left-4:focus{left:1rem}.focus\:top-4:focus{top:1rem}.focus\:z-50:focus{z-index:50}.focus\:rounded:focus{border-radius:.25rem}.focus\:bg-ascii-primary:focus{--tw-bg-opacity:1;background-color:rgb(0 255 136/var(--tw-bg-opacity,1))}.focus\:px-4:focus{padding-left:1rem;padding-right:1rem}.focus\:py-2:focus{padding-top:.5rem;padding-bottom:.5rem}.focus\:text-canvas-green-dark:focus{--tw-text-opacity:1;color:rgb(10 61 47/var(--tw-text-opacity,1))}