:root{--bg-color: #1a1a1a;--text-color: #f0f0f0;--text-color-secondary: #a0a0a0;--text-color-highlight: #ffffff;--border-color: #444;--header-bg: #242424;--header-text: #ffffff;--footer-bg: #242424;--footer-text: #cccccc;--icon-color: #cccccc;--icon-hover-color: #ffffff;--button-hover-bg: #555;--button-hover-text: #ffffff;--dex-bg: #383838;--dex-border: #1f1f1f;--screen-bg: #9aaf8f;--screen-border: #444;--screen-text-color: #1f2a1f;--list-pane-bg: #4a4a4a;--list-item-hover-bg: #5a5a5a;--list-item-selected-bg: #d9534f;--list-item-selected-text: #ffffff;--button-dex-bg: #5cb85c;--button-dex-hover-bg: #4cae4c;--button-dex-text: #ffffff;--image-frame-bg: #d8d8d8;--image-frame-border: #777;--led-red: #ff1c1c;--led-yellow: #f5f525;--led-green: #32ff32;--led-blue: #1c8cff;--led-shadow: rgba(0, 0, 0, .5);font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body.light-theme{--bg-color: #f4f4f4;--text-color: #213547;--text-color-secondary: #555;--text-color-highlight: #000000;--border-color: #dcdcdc;--header-bg: #ffffff;--header-text: #213547;--footer-bg: #ffffff;--footer-text: #555;--icon-color: #555;--icon-hover-color: #000000;--button-hover-bg: #e0e0e0;--button-hover-text: #000000;--dex-bg: #e0e0e0;--dex-border: #a0a0a0;--screen-bg: #5f5f5f;--screen-border: #333;--screen-text-color: #e0e0e0;--list-pane-bg: #cccccc;--list-item-hover-bg: #bbbbbb;--list-item-selected-bg: #d9534f;--list-item-selected-text: #ffffff;--button-dex-bg: #5cb85c;--button-dex-hover-bg: #4cae4c;--button-dex-text: #ffffff;--image-frame-bg: #ffffff;--image-frame-border: #cccccc;--led-red: #ff1c1c;--led-yellow: #f5f525;--led-green: #32ff32;--led-blue: #1c8cff;--led-shadow: rgba(100, 100, 100, .3);color-scheme:light}body{margin:0;display:flex;flex-direction:column;min-height:100vh;background-color:var(--bg-color);color:var(--text-color);font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;transition:background-color .3s ease,color .3s ease}#root{width:100%;max-width:1280px;margin:0 auto;display:flex;flex-direction:column;flex-grow:1}*{box-sizing:border-box}audio{display:none}@keyframes pulse{0%{box-shadow:0 0 3px 1px var(--led-shadow),0 0 5px 2px currentColor}50%{box-shadow:0 0 8px 3px var(--led-shadow),0 0 12px 5px currentColor}to{box-shadow:0 0 3px 1px var(--led-shadow),0 0 5px 2px currentColor}}.app-header{background-color:var(--header-bg);color:var(--header-text);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--dex-border);transition:background-color .3s ease,color .3s ease,border-color .3s ease;position:relative}.header-content{text-align:left}.header-title{margin:0;font-size:1.8rem;font-weight:700}.header-subtitle{margin:.2rem 0 0;font-size:.9rem;opacity:.8}.theme-toggle-button{background:none;border:1px solid var(--text-color);color:var(--text-color);padding:.5rem;border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;font-size:1.2rem;transition:background-color .3s ease,color .3s ease,transform .2s ease,border-color .3s ease}.theme-toggle-button:hover{background-color:var(--button-hover-bg);color:var(--button-hover-text);transform:scale(1.1)}@media (max-width: 600px){.app-header{padding:.8rem 1rem;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.header-title{font-size:1.5rem}.header-subtitle{font-size:.8rem}.theme-toggle-button{position:absolute;top:1rem;right:1rem;padding:.4rem;font-size:1rem}}.app-footer{background-color:var(--footer-bg);color:var(--footer-text);padding:1.5rem 2rem;text-align:center;border-top:1px solid var(--dex-border);margin-top:auto;transition:background-color .3s ease,color .3s ease,border-color .3s ease;flex-shrink:0}.social-links{margin-bottom:.8rem}.social-links a{color:var(--icon-color);font-size:1.8rem;margin:0 .8rem;transition:color .3s ease,transform .2s ease}.social-links a:hover{color:var(--icon-hover-color);transform:scale(1.15) translateY(-2px)}.footer-text{margin:.3rem 0;font-size:.9rem;opacity:.8}.project-title{font-weight:700;opacity:1}.creator-credit{font-style:italic}@media (max-width: 600px){.app-footer{padding:1rem}.social-links a{font-size:1.6rem;margin:0 .6rem}.footer-text{font-size:.8rem}}.character-list-nav{width:240px;flex-shrink:0;background-color:var(--list-pane-bg);padding:1rem .5rem;overflow-y:auto;overflow-x:hidden;border-right:3px solid var(--dex-border);transition:background-color .3s ease,border-color .3s ease}.character-list-nav::-webkit-scrollbar{width:10px}.character-list-nav::-webkit-scrollbar-track{background:var(--list-pane-bg);border-radius:0}.character-list-nav::-webkit-scrollbar-thumb{background-color:var(--dex-border);border-radius:3px;border:2px solid var(--list-pane-bg)}.character-list-nav::-webkit-scrollbar-thumb:hover{background-color:#555}.character-list{list-style:none;padding:0;margin:0}.character-list li{margin-bottom:.3rem}.character-list-button{width:100%;padding:.7rem 1rem;background-color:transparent;color:var(--text-color);border:none;border-radius:5px;text-align:left;cursor:pointer;font-size:.95rem;font-weight:500;transition:background-color .2s ease,color .2s ease,transform .1s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.character-list-button:hover{background-color:var(--list-item-hover-bg);color:var(--text-color-highlight);transform:translate(3px)}.character-list-button.selected{background-color:var(--list-item-selected-bg);color:var(--list-item-selected-text);font-weight:700;box-shadow:inset 0 0 5px #0003;transform:translate(0)}@media (max-width: 900px){.character-list-nav{width:100%;height:auto;min-height:60px;overflow-y:hidden;overflow-x:auto;border-right:none;border-bottom:3px solid var(--dex-border);padding:.5rem;border-radius:7px 7px 0 0;scrollbar-width:thin;scrollbar-color:var(--dex-border) var(--list-pane-bg)}.character-list-nav::-webkit-scrollbar{height:8px;width:auto}.character-list-nav::-webkit-scrollbar-thumb{border:none}.character-list{display:flex;width:max-content;padding-bottom:.5rem}.character-list li{margin-bottom:0;margin-right:.5rem;flex-shrink:0}.character-list li:last-child{margin-right:0}.character-list-button{width:auto;padding:.6rem 1rem;font-size:.9rem;white-space:nowrap}.character-list-button.selected,.character-list-button:hover{transform:none}.character-list-nav:before{display:none}}.character-detail{flex-grow:1;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--screen-bg);color:var(--screen-text-color);border-radius:0 10px 10px 0;box-shadow:inset 0 0 20px #0006;position:relative;transition:background-color .3s ease,color .3s ease;overflow-y:auto}.character-detail.placeholder{color:var(--screen-text-color);opacity:.6;font-style:italic;font-size:1.3rem;text-align:center}.image-frame{width:250px;height:250px;border:5px solid var(--image-frame-border);background-color:var(--image-frame-bg);margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center;overflow:hidden;border-radius:8px;box-shadow:0 3px 8px #0003;transition:border-color .3s ease,background-color .3s ease;flex-shrink:0}.character-image{max-width:95%;max-height:95%;object-fit:contain;display:block;image-rendering:pixelated}.character-name{font-size:2rem;font-weight:700;color:var(--screen-text-color);margin-bottom:1.5rem;text-shadow:1px 1px 1px rgba(0,0,0,.2);transition:color .3s ease;text-align:center;flex-shrink:0}.audio-controls{display:flex;align-items:center;justify-content:center;flex-shrink:0}.play-pause-button{background:var(--button-dex-bg);color:var(--button-dex-text);border:2px outset rgba(255,255,255,.3);border-radius:50%;width:60px;height:60px;font-size:1.5rem;cursor:pointer;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 6px #0000004d,inset 0 -4px 4px #0003;transition:background-color .2s ease,transform .1s ease,box-shadow .1s ease,border-style .1s ease}.play-pause-button:hover{background-color:var(--button-dex-hover-bg)}.play-pause-button:active{transform:scale(.95) translateY(1px);box-shadow:0 2px 3px #0003,inset 0 3px 4px #0000004d;border-style:inset}.play-pause-button:disabled{background-color:#aaa;cursor:not-allowed;opacity:.7;border-style:inset;box-shadow:0 1px 2px #0003,inset 0 2px 3px #0000004d}@media (max-width: 900px){.character-detail{padding:1.5rem 1rem;justify-content:flex-start;border-radius:0 0 7px 27px;min-height:380px;box-shadow:inset 0 5px 15px #0000004d;width:100%}.image-frame{width:180px;height:180px;margin-bottom:1rem}.character-name{font-size:1.6rem;margin-bottom:1rem}.play-pause-button{width:55px;height:55px;font-size:1.3rem}}@media (max-width: 500px){.character-detail{min-height:320px;padding:1rem .8rem;border-radius:0 0 3px 18px}.image-frame{width:150px;height:150px;margin-bottom:.8rem}.character-name{font-size:1.4rem;margin-bottom:.8rem}.play-pause-button{width:50px;height:50px;font-size:1.2rem}}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;justify-content:center;align-items:center;flex-grow:1;padding:2rem 1rem;width:100%}@media (max-width: 900px){.main-content{padding:1rem .5rem}}.dex-body{display:flex;width:100%;max-width:900px;height:600px;background-color:var(--dex-bg);border:4px solid var(--dex-border);border-radius:15px 15px 15px 50px;box-shadow:0 10px 30px #0000004d,inset 0 3px 8px #0006;overflow:hidden;transition:background-color .3s ease,border-color .3s ease;position:relative}@media (max-width: 900px){.dex-body{flex-direction:column;height:auto;max-width:500px;margin:1rem auto;border-radius:10px 10px 10px 30px}}@media (max-width: 500px){.dex-body{border-radius:5px 5px 5px 20px;border-width:3px;max-width:95%}}
