:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:var(--color-gray-800);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;scrollbar-gutter:stable}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-gray-900);cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:var(--color-white)}a:hover{color:#747bff}button{background-color:var(--color-gray-50)}}:root{--color-white: #ffffff;--color-black: #000000;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-indigo-400: #818cf8;--color-indigo-500: #6366f1;--color-indigo-600: #4f46e5;--color-blue-600: #2563eb;--color-blue-700: #1d4ed8;--color-cyan-300: #67e8f9;--color-cyan-500: #06b6d4;--color-green-500: #16a34a;--color-green-600: #15803d;--color-red-600: #dc2626;--color-red-700: #b91c1c;--color-purple-glow: rgba(168, 129, 255, .5);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.25rem;--spacing-2xl: 1.5rem;--spacing-3xl: 2rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1.5rem;--radius-full: 50%;--font-mono: "Fira Code", "Menlo", "Monaco", "Courier New", monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--touch-sm: 36px;--touch-md: 44px;--touch-lg: 48px;--touch-xl: 52px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 25px 50px rgba(0, 0, 0, .25);--transition: all .2s ease;--transition-slow: all .3s ease;--glass-bg: rgba(55, 65, 81, .1);--glass-border: rgba(255, 255, 255, .1);--card-bg: rgba(17, 24, 39, .5);--card-border: rgba(75, 85, 99, .3);--glass-base-bg: rgba(75, 85, 99, .4);--glass-elevated-bg: linear-gradient(135deg, rgba(75, 85, 99, .3), rgba(75, 85, 99, .2));--glass-container-bg: linear-gradient(135deg, rgba(17, 24, 39, .6), rgba(31, 41, 55, .6));--glass-border-subtle: rgba(255, 255, 255, .1);--glass-border-elevated: rgba(255, 255, 255, .2);--glass-shadow-base: 0 8px 32px rgba(0, 0, 0, .2);--glass-shadow-elevated: 0 4px 16px rgba(0, 0, 0, .3), 0 1px 4px rgba(255, 255, 255, .1) inset;--glass-container-glow: 0 0 40px rgba(17, 24, 39, .8), 0 0 80px rgba(31, 41, 55, .6), 0 0 120px rgba(55, 65, 81, .4);--glass-card-glow: inset 0 0 20px rgba(196, 181, 253, .1), inset 0 0 40px rgba(168, 162, 158, .05);--glass-card-outward-glow: 0 0 18px rgba(255, 255, 255, .04), 0 0 35px rgba(255, 255, 255, .02);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px}.glass-base{background:var(--glass-base-bg);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid var(--glass-border-subtle);box-shadow:var(--glass-shadow-base)}.glass-elevated{background:var(--glass-elevated-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-elevated);box-shadow:var(--glass-shadow-elevated)}.glass-card{background:var(--glass-base-bg);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid var(--glass-border-subtle);box-shadow:var(--glass-shadow-base)}.glass-container{background:var(--glass-elevated-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-elevated);box-shadow:var(--glass-shadow-elevated)}#root{margin:0;padding:0;min-height:100vh;width:100%}.app-container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem;max-width:600px;width:100%;min-height:100vh;margin:0 auto;position:relative;box-sizing:border-box}.app-container:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:70%;background:#3741511a;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:32px;pointer-events:none;z-index:-1;box-shadow:0 25px 50px #0000004d,inset 0 1px #ffffff1a}.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}.crawler-text{position:absolute;color:transparent;font-size:0;line-height:0;opacity:0;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:-999}.tool-page-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:2rem;min-height:100vh;width:100vw;max-width:none;box-sizing:border-box}.subtitle-text{opacity:.7;margin-bottom:.5rem}.button-list{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:400px;margin:1rem 0 2rem}.nav-button{position:relative;display:block;width:100%;height:70px;background:#37415133;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.1);border-radius:24px;transition:all .3s ease;-webkit-user-select:none;user-select:none;text-decoration:none;box-sizing:border-box;box-shadow:0 8px 32px #0003}button.nav-button{font-family:inherit;margin:0;padding:0;cursor:pointer;outline:none!important;border:1px solid rgba(255,255,255,.1)!important;background:#37415133!important;backdrop-filter:blur(15px)!important;-webkit-backdrop-filter:blur(15px)!important;-webkit-appearance:none;-moz-appearance:none;appearance:none}button.nav-button:hover{outline:none!important;border:1px solid rgba(255,255,255,.1)!important;background:#37415133!important;backdrop-filter:blur(15px)!important;-webkit-backdrop-filter:blur(15px)!important}button.nav-button:focus{outline:none!important;border:1px solid rgba(255,255,255,.1)!important}.nav-button:before{content:attr(data-text);position:absolute;top:0;left:0;z-index:1;display:flex;align-items:center;justify-content:center;width:100%;min-height:60px;padding:1rem 1.5rem;background:linear-gradient(135deg,#4b55634d,#4b556333);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:2px solid rgba(255,255,255,.2);border-radius:24px;color:var(--color-gray-200);font-size:1rem;font-weight:500;text-align:center;line-height:1.2;box-sizing:border-box;transform:translate(-0px,-3px);box-shadow:0 4px 16px #0000004d,0 1px 4px #ffffff1a inset;transition:all .3s ease}.nav-button:after{content:"";position:absolute;top:0;left:0;width:100%;height:calc(100% - 4px);border-radius:24px;box-shadow:0 0 15px 4px #a881ff80;z-index:0;opacity:0;transition:opacity .3s ease;pointer-events:none}.nav-button:hover{border-color:#ffffff1a}.nav-button:hover:before{transform:translate(-0px,-8px)}.nav-button:hover:after{opacity:1}.nav-button:active{transform:translateY(2px)}.nav-button:active:before{transform:translate(-0px,-1px);box-shadow:0 1px 2px #00000080,0 0 20px 4px #a881ffcc}.nav-button:active:after{opacity:1}button.nav-button.nav-button-back-footer{width:200px;height:70px;margin:0 auto 2rem!important;display:block}@media (max-width: 768px){button.nav-button.nav-button-back-footer{width:calc(100% - 2rem);max-width:280px;height:60px;margin:0 auto 1.75rem!important}}.user-info{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;width:100%;max-width:400px}.welcome-text{margin:0;color:var(--color-gray-300);font-size:1.1rem}.logout-button{padding:.75rem 2rem;background-color:var(--color-red-600);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;min-height:44px;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;outline-offset:2px}.logout-button:hover{background-color:var(--color-red-700);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.logout-button:focus-visible{outline:2px solid var(--color-indigo-500);outline-offset:2px}@media (max-width: 768px){.nav-button{height:60px;margin-bottom:.75rem}.nav-button:before{min-height:48px;padding:.75rem 1rem;font-size:.9rem;line-height:1.3}.button-list{gap:.75rem;padding:0 .5rem}.app-container{padding:.75rem}}.font-firacode{font-family:Fira Code,monospace}.dot-grid{display:grid;gap:8px;border:1px solid var(--color-gray-700);padding:16px;border-radius:8px;background-color:var(--color-gray-800);transition:all .3s ease;max-height:45vh;overflow-y:auto}.dot{width:100%;aspect-ratio:1 / 1;border-radius:50%;cursor:pointer;transition:all .15s ease-in-out;background-color:var(--color-gray-700);border:2px solid transparent;box-sizing:border-box}.dot.active{background-color:var(--color-cyan-300);box-shadow:inset 0 0 0 4px var(--color-gray-800)}.dot:hover{border-color:var(--color-indigo-600)}#output-box{font-size:2.5rem;letter-spacing:.1em;background-color:var(--color-black);padding:1rem;border-radius:.5rem;line-height:1.2;resize:vertical;min-height:160px;width:fit-content;max-width:100%;border:1px solid var(--color-gray-600);color:var(--color-gray-300);text-align:center}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#0f172a 0%,#1e293b 25%,var(--color-gray-700) 50%,var(--color-gray-600) 75%,var(--color-gray-800) 100%);min-height:100vh;position:relative;color:var(--color-gray-300)}body:before{content:"";position:fixed;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(75,85,99,.2) 0%,transparent 60%),radial-gradient(circle at 80% 20%,rgba(55,65,81,.25) 0%,transparent 50%),radial-gradient(circle at 40% 80%,rgba(31,41,59,.15) 0%,transparent 70%),radial-gradient(circle at 70% 70%,rgba(15,23,42,.2) 0%,transparent 50%),radial-gradient(circle at 10% 80%,rgba(59,130,246,.2) 0%,transparent 50%),radial-gradient(circle at 90% 80%,rgba(59,130,246,.2) 0%,transparent 50%),radial-gradient(circle at 90% 10%,rgba(99,102,241,.15) 0%,transparent 60%),radial-gradient(circle at 10% 10%,rgba(99,102,241,.15) 0%,transparent 60%),radial-gradient(circle at 60% 10%,rgba(147,197,253,.1) 0%,transparent 40%),radial-gradient(circle at 40% 10%,rgba(147,197,253,.1) 0%,transparent 40%);pointer-events:none;z-index:-1}.converter-container{width:100%;max-width:48rem;background:var(--glass-container-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;box-shadow:var(--glass-container-glow);border-radius:.75rem;padding:2rem;box-sizing:border-box}.converter-container>*+*{margin-top:1.5rem}.converter-header{text-align:center}.converter-header h1{font-size:1.875rem;font-weight:700;color:var(--color-white);margin:0}.converter-header p{margin-top:.5rem;color:var(--color-gray-400)}.card{background:var(--glass-base-bg);backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:none;box-shadow:none;padding:1.5rem;border-radius:.5rem;text-align:left}.card>*+*{margin-top:1.5rem}.card-header{display:flex;justify-content:space-between;align-items:center}.card-header-clickable{cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;margin-bottom:0;transition:var(--transition)}.card-header-clickable:hover{opacity:.8}.card-header-clickable h3{margin:0;flex:1}.card-chevron{transition:transform .3s ease;font-size:.875rem;margin-left:.5rem;color:var(--color-gray-400)}.card-chevron.collapsed{transform:rotate(-90deg)}.card-content{max-height:2000px;overflow:hidden;transition:max-height .3s ease,opacity .3s ease,margin-top .3s ease;margin-top:1.5rem;opacity:1}.card-content.collapsed{max-height:0;opacity:0;margin-top:0}.card h3{font-size:1.125rem;font-weight:600;color:var(--color-white);margin:0}.form-group>*+*{margin-top:.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-control{width:100%;box-sizing:border-box;background-color:var(--color-gray-700);color:var(--color-white);border-radius:.375rem;padding:.75rem;border:1px solid var(--color-gray-600);font-size:1rem;font-family:inherit;transition:all .2s;min-height:44px}.form-control:focus{outline:2px solid transparent;outline-offset:2px;border-color:var(--color-indigo-500);box-shadow:0 0 0 3px #6366f11a}.form-control:disabled{opacity:.6;cursor:not-allowed}.form-control--text{font-family:inherit}.form-control--mono{font-family:Fira Code,Menlo,Monaco,Courier New,monospace}.form-control--number{text-align:center;font-weight:600;border:2px solid var(--color-gray-600);border-radius:.5rem;padding:.75rem;font-size:1.25rem}.form-control--char{text-align:center;font-size:1.5rem;font-weight:700;font-family:Fira Code,monospace;border:2px solid var(--color-gray-600);border-radius:.5rem;padding:.75rem;min-height:56px}.form-control--number:focus,.form-control--char:focus{border-color:var(--color-cyan-500);box-shadow:0 0 0 3px #06b6d41a}.form-control--sm{padding:.5rem;font-size:.875rem;min-height:36px}.form-control--lg{padding:1rem;font-size:1.125rem;min-height:52px}.form-control--color{padding:.25rem;min-height:44px;cursor:pointer}.form-control--textarea{min-height:120px;resize:vertical;font-family:Fira Code,monospace;line-height:1.5}@media (max-width: 768px){.form-control{padding:.875rem;min-height:48px;font-size:1.063rem}.form-control--char{font-size:1.75rem;min-height:60px}.form-control--number{font-size:1.375rem;min-height:56px}.form-control--lg{min-height:56px;padding:1.125rem}.form-control--sm{min-height:40px;padding:.625rem}}.drop-zone{display:flex;justify-content:center;align-items:center;width:100%;height:8rem;padding:1.5rem;box-sizing:border-box;border:2px dashed var(--color-gray-600);border-radius:.375rem;cursor:pointer;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.drop-zone:hover{border-color:var(--color-gray-500)}.drop-zone--dragging{border-color:var(--color-indigo-500);background-color:#6366f11a}.drop-zone__inner{text-align:center}.drop-zone__icon{margin-left:auto;margin-right:auto;height:2.5rem;width:2.5rem;color:var(--color-gray-500)}.drop-zone__text{margin-top:.5rem;font-size:.875rem;color:var(--color-gray-400)}.drop-zone__text span{font-weight:600;color:var(--color-indigo-400)}.image-preview__img{max-width:100%;max-height:12rem;height:auto;border-radius:.375rem;margin:auto}.slider{width:100%;height:.5rem;background-color:var(--color-gray-700);border-radius:.5rem;-webkit-appearance:none;appearance:none;cursor:pointer;min-height:44px;display:flex;align-items:center}.slider::-webkit-slider-thumb{appearance:none;height:1.25rem;width:1.25rem;border-radius:50%;background:var(--color-indigo-500);cursor:pointer;border:2px solid var(--color-white);box-shadow:0 2px 4px #0003}.slider::-moz-range-thumb{height:1.25rem;width:1.25rem;border-radius:50%;background:var(--color-indigo-500);cursor:pointer;border:2px solid var(--color-white);box-shadow:0 2px 4px #0003}.slider::-webkit-slider-track{background:var(--color-gray-600);border-radius:.5rem;height:.5rem}.slider::-moz-range-track{background:var(--color-gray-600);border-radius:.5rem;height:.5rem;border:none}@media (max-width: 768px){.slider{min-height:48px}.slider::-webkit-slider-thumb{height:1.5rem;width:1.5rem}.slider::-moz-range-thumb{height:1.5rem;width:1.5rem}}.btn{min-height:44px;min-width:44px;padding:.75rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:600;line-height:1.2;text-align:center;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;outline:none;outline-offset:2px}.btn:focus-visible{outline:2px solid var(--color-indigo-500);outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn--primary{background-color:var(--color-green-500);color:var(--color-white)}.btn--primary:hover{background-color:var(--color-green-600);transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.btn--primary:active{transform:translateY(0)}.btn--secondary{background-color:var(--color-gray-600);color:var(--color-white)}.btn--secondary:hover{background-color:var(--color-gray-700);transform:translateY(-1px);box-shadow:0 4px 12px #4b55634d}.btn--secondary:active{transform:translateY(0)}.btn--tertiary{background-color:var(--color-blue-600);color:var(--color-white)}.btn--tertiary:hover{background-color:var(--color-blue-700);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn--tertiary:active{transform:translateY(0)}.btn--danger{background-color:var(--color-red-600);color:var(--color-white)}.btn--danger:hover{background-color:var(--color-red-700);transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.btn--danger:active{transform:translateY(0)}.btn--ghost{background-color:transparent;color:var(--color-gray-500);border:1px solid var(--color-gray-700)}.btn--ghost:hover{background-color:var(--color-gray-700);color:var(--color-gray-300);border-color:var(--color-gray-600)}.btn--sm{min-height:36px;padding:.5rem 1rem;font-size:.875rem}.btn--lg{min-height:52px;padding:1rem 2rem;font-size:1.125rem}.btn--full{width:100%}.btn-group{display:flex;gap:.75rem;flex-wrap:wrap}.btn-group--sm{gap:.5rem}.btn-stack{display:flex;flex-direction:column;gap:.75rem}.btn-stack--sm{gap:.5rem}@media (max-width: 768px){.btn{min-height:48px;padding:.875rem 1.5rem}.btn--sm{min-height:40px;padding:.625rem 1.25rem}.btn-group{flex-direction:column}.btn-group--mobile-row{flex-direction:row}}.output-box{background-color:var(--color-black);border-radius:.375rem;padding:1rem;min-height:250px;max-height:400px;overflow-y:auto}.output-box--preview{max-height:none;height:auto;padding:.5rem}.output-box__raw{white-space:pre;font-family:Menlo,Monaco,Courier New,monospace;line-height:1.2;font-size:10px;overflow-x:auto;color:var(--color-gray-300)}.ansi-preview-content{white-space:pre;font-family:Menlo,Monaco,Courier New,monospace;line-height:1;font-size:8px;cursor:default;transform-origin:top left;transform:scale(1)}.ansi-preview-content span{display:inline-block;width:.6em;height:1em}.bg-changer{display:flex;align-items:center;gap:1rem;padding-top:1rem;margin-top:1rem;border-top:1px solid var(--color-gray-700)}.color-picker{width:2.5rem;height:2.5rem;padding:0;border:none;background-color:transparent;border-radius:.375rem;cursor:pointer}.hidden{display:none}.controls-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 768px){.controls-grid{grid-template-columns:repeat(5,1fr);align-items:end}.controls-grid__item--span-2{grid-column:span 2 / span 2}}.App-header{width:100%;padding:1rem 0;text-align:center}.figlet-header{text-align:center;min-height:150px;margin:0 auto;font-family:Courier New,Monaco,Menlo,monospace;color:var(--color-gray-300);white-space:pre;overflow:visible;max-width:100%;font-size:1rem;line-height:1.2;display:flex;align-items:center;justify-content:center;box-sizing:border-box;transition:transform .3s ease}@media (max-width: 768px){.App-header{padding:.5rem 0}.figlet-header{min-height:100px;padding:0 1rem}}@media (max-width: 640px){.figlet-header{min-height:80px}}.site-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-gray-700);text-align:center;width:100%;max-width:400px}.social-icons{margin-bottom:1.5rem;display:flex;justify-content:center;gap:1rem}.social-link{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-gray-400);transition:color .2s,transform .2s;border-radius:50%;background:#4b556333}.social-link:hover{color:var(--color-gray-300);transform:translateY(-2px);background:#4b556366}.social-icon{width:18px;height:18px}.footer-links{margin-bottom:1rem}.footer-link{color:var(--color-gray-400);text-decoration:none;font-size:.875rem;transition:color .2s}.footer-link:hover{color:var(--color-gray-300)}.footer-divider{color:var(--color-gray-600);margin:0 1rem}.footer-text{color:var(--color-gray-500);font-size:.75rem;margin:0}.ascii-control-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.ascii-control-group label{font-size:.875rem;font-weight:500;color:var(--color-gray-400)}.ascii-control-group input[type=text],.ascii-control-group input[type=range]{width:100%}.ascii-control-group input[type=color]{width:100%;height:2.5rem;border-radius:var(--radius-md);border:1px solid var(--color-gray-600);cursor:pointer}.ascii-ditherer-container,.ascii-draw-container{width:100%;max-width:none;padding:var(--spacing-3xl);box-sizing:border-box}.ascii-ditherer-header,.ascii-draw-header,.tokenviz-header{text-align:center;margin-bottom:var(--spacing-3xl);max-width:800px;margin-left:auto;margin-right:auto}.ascii-ditherer-header h1,.ascii-draw-header h1,.tokenviz-header h1{font-size:2.5rem;font-weight:700;color:var(--color-white);margin:0 0 var(--spacing-lg) 0}.ascii-ditherer-header p,.ascii-draw-header p,.tokenviz-header p{font-size:1.1rem;color:var(--color-gray-400);margin:0}.ascii-ditherer-layout,.ascii-draw-layout,.tokenviz-layout{display:grid;grid-template-columns:1fr 380px;gap:var(--spacing-3xl);max-width:1600px;margin:0 auto}.ascii-canvas-container,.ascii-draw-canvas-container,.tokenviz-canvas-container{background-color:var(--card-bg);padding:0;border-radius:var(--radius-xl);height:calc(100vh - 200px);min-height:700px;max-height:900px;display:flex;flex-direction:column}.ascii-canvas-container h3,.ascii-draw-canvas-container h3{font-size:1.25rem;font-weight:600;color:var(--color-white);margin:0 0 var(--spacing-sm) 0}.ascii-canvas-container p,.ascii-draw-canvas-container p{font-size:.9rem;color:var(--color-gray-400);margin:0 0 var(--spacing-2xl) 0}.ascii-canvas-viewport,.ascii-draw-canvas-wrapper,.tokenviz-canvas-viewport{position:relative;width:100%;flex:1;min-height:600px;background-color:var(--color-gray-800);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.ascii-canvas-viewport{box-shadow:inset 0 2px 4px #0000001a}.ascii-controls-sidebar,.ascii-draw-controls-sidebar,.tokenviz-controls-sidebar{display:flex;flex-direction:column;gap:var(--spacing-2xl);max-height:calc(100vh - 200px);min-height:700px;overflow-y:auto;padding-right:var(--spacing-sm)}.ascii-controls-sidebar::-webkit-scrollbar,.ascii-draw-controls-sidebar::-webkit-scrollbar,.tokenviz-controls-sidebar::-webkit-scrollbar{width:6px}.ascii-controls-sidebar::-webkit-scrollbar-track,.ascii-draw-controls-sidebar::-webkit-scrollbar-track,.tokenviz-controls-sidebar::-webkit-scrollbar-track{background:var(--color-gray-700);border-radius:3px}.ascii-controls-sidebar::-webkit-scrollbar-thumb,.ascii-draw-controls-sidebar::-webkit-scrollbar-thumb,.tokenviz-controls-sidebar::-webkit-scrollbar-thumb{background:var(--color-gray-500);border-radius:3px}.ascii-controls-sidebar .card,.ascii-draw-controls-sidebar .card,.tokenviz-controls-sidebar .card{margin-bottom:0;background:var(--glass-elevated-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-elevated);box-shadow:var(--glass-shadow-elevated)}.ascii-controls-sidebar .card h3,.ascii-draw-controls-sidebar .card h3,.tokenviz-controls-sidebar .card h3{margin-bottom:1.25rem;font-size:1.1rem;color:var(--color-gray-100)}.ascii-controls-grid,.ascii-draw-controls-grid,.tokenviz-controls-grid{display:flex;flex-direction:column;gap:1.25rem}.ascii-action-buttons,.ascii-draw-action-buttons{display:flex;gap:var(--spacing-md);flex-direction:column;margin-top:var(--spacing-2xl)}.ascii-draw-preview{background:var(--glass-elevated-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-elevated);box-shadow:var(--glass-shadow-elevated);padding:var(--spacing-2xl);border-radius:var(--radius-xl);margin-top:var(--spacing-lg)}.ascii-draw-preview h3{font-size:1.1rem;font-weight:600;color:var(--color-gray-100);margin:0 0 var(--spacing-lg) 0;text-align:center}.ascii-draw-preview-content{background-color:var(--color-gray-900);border-radius:var(--radius-lg);padding:var(--spacing-lg);min-height:200px;overflow:hidden;display:flex;align-items:center;justify-content:center}@media (max-width: 1280px){.ascii-ditherer-layout,.ascii-draw-layout,.tokenviz-layout{grid-template-columns:1fr 360px;gap:var(--spacing-2xl)}}@media (max-width: 1280px){.ascii-ditherer-container,.ascii-draw-container,.tokenviz-container{padding:var(--spacing-2xl)}.ascii-ditherer-layout,.ascii-draw-layout,.tokenviz-layout{grid-template-columns:1fr;gap:var(--spacing-3xl);max-width:900px}.ascii-controls-sidebar,.ascii-draw-controls-sidebar,.tokenviz-controls-sidebar{max-height:none;overflow-y:visible;flex-direction:row;gap:var(--spacing-2xl);padding-right:0}.ascii-controls-sidebar .card,.ascii-draw-controls-sidebar .card,.tokenviz-controls-sidebar .card{flex:1}.ascii-action-buttons,.ascii-draw-action-buttons{flex-direction:row;flex-wrap:wrap}.ascii-action-buttons .btn,.ascii-draw-action-buttons .btn{flex:1;min-width:140px}}@media (max-width: 1024px){.ascii-ditherer-header h1,.ascii-draw-header h1,.tokenviz-header h1{font-size:2rem}.ascii-canvas-container,.ascii-draw-canvas-container,.tokenviz-canvas-container{height:calc(100vh - 180px);min-height:500px;max-height:700px}.ascii-canvas-viewport,.ascii-draw-canvas-wrapper,.tokenviz-canvas-viewport{min-height:400px}}@media (max-width: 768px){.ascii-ditherer-container,.ascii-draw-container,.tokenviz-container{padding:var(--spacing-lg)}.ascii-ditherer-header,.ascii-draw-header,.tokenviz-header{margin-bottom:var(--spacing-3xl)}.ascii-ditherer-header h1,.ascii-draw-header h1,.tokenviz-header h1{font-size:1.75rem}.ascii-controls-sidebar,.ascii-draw-controls-sidebar,.tokenviz-controls-sidebar,.ascii-action-buttons,.ascii-draw-action-buttons{flex-direction:column}.ascii-action-buttons .btn,.ascii-draw-action-buttons .btn{flex:none}}.input-section{background:#1f2937;border:1px solid rgba(75,85,99,1);border-radius:.5rem;padding:1.5rem;margin-bottom:1.5rem}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.input-group{display:flex;flex-direction:column}.input-group label{display:block;font-size:.875rem;font-weight:500;color:#d1d5db;margin-bottom:.5rem}.value-display{background:#11182780;border-radius:.5rem;padding:1.5rem;margin-bottom:2rem}.value-display h2{font-size:1.125rem;font-weight:600;color:#d1d5db;margin-bottom:1rem;text-align:center}.char-display{color:#06b6d4;font-family:monospace;font-size:1.5rem;margin:0 .5rem;padding:.5rem;background:#374151;border-radius:.25rem}.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;text-align:center}.value-card{background:#374151;padding:1rem;border-radius:.5rem}.value-card h3{font-size:.875rem;color:#9ca3af;font-weight:700;text-transform:uppercase;margin-bottom:.5rem}.value-number{font-size:1.875rem;font-family:monospace;font-weight:700;color:#fff;margin:0}.code-section{margin-bottom:2rem}.code-section h2{font-size:1.125rem;font-weight:600;color:#d1d5db;margin-bottom:1rem;text-align:center}.code-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}.code-snippet{background:#111827;border-radius:.5rem;padding:1rem;position:relative;border:1px solid rgba(55,65,81,1)}.code-snippet-header{color:#9ca3af;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-bottom:.5rem}.code-snippet-content{background:#0006;border-radius:.25rem;padding:.75rem;overflow-x:auto;overflow-y:hidden;max-height:200px;border:1px solid rgba(31,41,55,1)}.code-snippet-pre{color:#fff;font-size:.875rem;font-family:Courier New,Consolas,monospace;margin:0;white-space:pre;line-height:1.4}.code-snippet-copy{position:absolute;top:.75rem;right:.75rem;background:#374151;color:#fff;border:1px solid rgba(75,85,99,1);border-radius:.375rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:background-color .2s}.code-snippet-copy:hover{background:#4b5563}.table-section h2{font-size:1.125rem;font-weight:600;color:#d1d5db;margin-bottom:1rem;text-align:center}.table-container{overflow-x:auto;border-radius:.5rem;border:1px solid rgba(75,85,99,1)}.breakdown-table{min-width:100%;border-collapse:collapse}.breakdown-table thead{background:#37415180}.breakdown-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:500;color:#d1d5db;text-transform:uppercase;letter-spacing:.05em}.breakdown-table tbody{background:#1f2937}.breakdown-table tr{border-top:1px solid rgba(75,85,99,1)}.breakdown-table tr:hover{background:#37415180}.breakdown-table td{padding:.75rem 1rem}.char-cell{font-family:monospace;color:#06b6d4;font-size:1.125rem}.value-cell{font-family:monospace;color:#fff}@media (max-width: 768px){.input-row,.value-grid,.code-grid{grid-template-columns:1fr}}.feedback-popup-backdrop{position:fixed;inset:0;background:transparent;z-index:9998;pointer-events:none}.feedback-popup{position:fixed;bottom:2rem;right:2rem;width:90%;max-width:380px;max-height:90vh;overflow-y:auto;z-index:9999;background:var(--glass-elevated-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border-elevated);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow-elevated),var(--shadow-lg);padding:var(--spacing-2xl);color:var(--color-white);animation:slideInUp .4s cubic-bezier(.16,1,.3,1)}.feedback-close-btn{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-white);font-size:1.25rem;transition:var(--transition);padding:0}.feedback-close-btn:hover{background:#fff3;transform:scale(1.1)}.feedback-close-btn:active{transform:scale(.95)}.feedback-title{font-size:1.25rem;font-weight:700;margin:0 0 var(--spacing-sm) 0;color:var(--color-white);font-family:var(--font-sans)}.feedback-subtitle{font-size:.875rem;color:var(--color-gray-300);margin:0 0 var(--spacing-xl) 0;line-height:1.5}.feedback-success,.feedback-error{padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);text-align:center;font-weight:600;animation:slideInDown .3s ease}.feedback-success{background:#16a34a33;border:1px solid var(--color-green-500);color:var(--color-green-500)}.feedback-error{background:#dc262633;border:1px solid var(--color-red-600);color:var(--color-red-600)}.feedback-success-icon{display:inline-block;margin-right:var(--spacing-sm);font-size:1.25rem}.feedback-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.feedback-label{display:block;font-size:.9rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--color-white)}.feedback-required{color:var(--color-red-600)}.feedback-rating-container{margin-bottom:var(--spacing-sm)}.feedback-stars{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.feedback-star{background:transparent;border:none;font-size:1.5rem;cursor:pointer;transition:var(--transition);padding:var(--spacing-xs);filter:grayscale(100%);opacity:.4}.feedback-star:hover,.feedback-star-filled{filter:grayscale(0%);opacity:1;transform:scale(1.1)}.feedback-star:active{transform:scale(.95)}.feedback-field{margin-bottom:var(--spacing-sm)}.feedback-textarea,.feedback-input{width:100%;background:#11182799;border:1px solid var(--glass-border-subtle);border-radius:var(--radius-md);padding:var(--spacing-lg);color:var(--color-white);font-family:var(--font-sans);font-size:.95rem;transition:var(--transition);box-sizing:border-box;resize:vertical}.feedback-textarea{min-height:80px;line-height:1.5}.feedback-textarea:focus,.feedback-input:focus{outline:none;border-color:var(--color-indigo-500);box-shadow:0 0 0 3px #6366f133}.feedback-textarea::placeholder,.feedback-input::placeholder{color:var(--color-gray-500)}.feedback-textarea:disabled,.feedback-input:disabled{opacity:.6;cursor:not-allowed}.feedback-char-count{font-size:.8rem;color:var(--color-gray-400);text-align:right;margin-top:var(--spacing-xs)}.feedback-email-note{font-size:.8rem;color:var(--color-gray-400);margin-top:var(--spacing-xs)}.feedback-actions{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.feedback-btn{flex:1;padding:var(--spacing-lg) var(--spacing-xl);border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition);border:none;font-family:var(--font-sans);min-height:var(--touch-md)}.feedback-btn-primary{background:linear-gradient(135deg,var(--color-indigo-600),var(--color-indigo-500));color:var(--color-white);box-shadow:0 4px 12px #6366f14d}.feedback-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-indigo-500),var(--color-indigo-400));box-shadow:0 6px 16px #6366f166;transform:translateY(-2px)}.feedback-btn-primary:active:not(:disabled){transform:translateY(0)}.feedback-btn-primary:disabled{opacity:.5;cursor:not-allowed}.feedback-btn-secondary{background:#ffffff1a;color:var(--color-white);border:1px solid var(--glass-border-subtle)}.feedback-btn-secondary:hover:not(:disabled){background:#ffffff26;border-color:var(--glass-border-elevated)}.feedback-btn-secondary:active:not(:disabled){background:#ffffff0d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 640px){.feedback-popup{bottom:0;right:0;left:0;width:100%;max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--spacing-2xl) var(--spacing-xl);max-height:85vh}.feedback-title{font-size:1.25rem}.feedback-stars{justify-content:center}.feedback-star{font-size:1.75rem}.feedback-actions{flex-direction:column;gap:var(--spacing-md)}.feedback-btn{width:100%}}@media (prefers-reduced-motion: reduce){.feedback-popup,.feedback-popup-backdrop,.feedback-success,.feedback-error,.feedback-star,.feedback-btn{animation:none;transition:none}}@media (prefers-contrast: high){.feedback-popup,.feedback-textarea,.feedback-input{border:2px solid var(--color-white)}}
