*,*:before,*:after{box-sizing:border-box}body{background-color:#121212;color:#f0f0f0;font-family:Arial,sans-serif;margin:0;padding:0;overflow-x:hidden;height:100dvh}#root{display:flex;justify-content:center;padding:0;height:100%;width:100%;overflow:hidden}.container{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:480px}input[type=file],select,input[type=text],textarea,button{padding:.5rem;border-radius:4px;border:none;font-size:1rem}button{background-color:#1e88e5;color:#fff;cursor:pointer}button:hover{background-color:#1565c0}button:disabled{background-color:#555;color:#999;cursor:not-allowed;opacity:.6}canvas{width:100%;height:auto;border:1px solid #333}.drawing-canvas{touch-action:none}h1{text-align:center}.drop-zone{border:2px dashed #444;padding:1rem;text-align:center;cursor:pointer}.drop-zone.active{background-color:#ffffff1a}.progress-footer{padding:.5rem 1rem;padding-bottom:2em;position:fixed;bottom:0;left:0;right:0;background-color:#121212}.progress-footer progress{width:100%;height:1rem}@media (min-width: 600px){#root{padding:0}.container{max-width:600px}}.install-prompt{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#333;color:#eee;padding:1rem;border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:20;width:calc(100% - 2rem);max-width:95%;animation:popup .5s ease-out forwards;opacity:0}.edit-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#333;color:#eee;padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:1rem;z-index:20;width:calc(100% - 2rem);max-width:95%;animation:popup .5s ease-out forwards;opacity:0}.edit-popup textarea{width:100%;min-height:80px}.edit-popup-buttons{display:flex;justify-content:flex-end;gap:.5rem}@keyframes popup{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}60%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}80%{transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.install-buttons .install-button{margin-left:.5rem;padding:.5rem 1rem;background:#ff7043;color:#fff;border:none;border-radius:4px;cursor:pointer}.install-buttons .install-button:hover{background:#ffa270}.install-buttons .cancel-button,.cancel-button{margin-left:.5rem;padding:.5rem 1rem;background:#333;color:#fff;border:none;border-radius:4px;cursor:pointer}.install-buttons .cancel-button:hover,.cancel-button:hover{background:#444}.crop-container{position:relative;width:100%;height:400px;background:#333}.aspect-buttons{display:flex;gap:.5rem;margin-top:.5rem;justify-content:center}.aspect-buttons button{flex:1}.placement-container{position:relative;width:100%;overflow:hidden;touch-action:none}.base-image{width:100%;height:auto;display:block}.overlay-image{position:absolute;top:0;left:0;transform-origin:center;touch-action:none}.bubble{position:absolute;padding:.25rem .5rem;background:#fff;color:#000;border:1px solid #000;transform-origin:center;touch-action:none;pointer-events:none;-webkit-user-select:none;user-select:none}.bubble.thought{border-radius:50%}.bubble.box{border-radius:4px}.bubble-select{display:flex;justify-content:center;gap:10px;margin-top:.5rem}.bubble-option{display:flex;flex-direction:column;align-items:center;width:80px;position:relative}.bubble-option input[type=radio]{display:none}.bubble-preview-wrapper{position:relative;width:60px;height:60px;margin-bottom:4px}.bubble-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;color:#000;border:2px solid transparent}.bubble-thumb.speech{border-radius:16px}.bubble-thumb.thought{border-radius:50%}.bubble-thumb.box{border-radius:4px}.bubble-thumb.none{background:transparent;border:2px dashed #555;color:#fff}.bubble-option input[type=radio]:checked+.bubble-preview-wrapper .bubble-thumb{border-color:#ff7043}.bubble-option input[type=radio]:checked+.bubble-preview-wrapper .checkmark{display:flex}.range-control{display:flex;align-items:center;gap:.5rem}.range-control input[type=range]{flex:1;min-width:0}.history-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.history-item{display:flex;flex-direction:column;align-items:center}.history-item img{width:100%;aspect-ratio:1/1;object-fit:cover}.history-buttons{display:flex;gap:.5rem;margin-top:.5rem}.container{width:100%;max-width:480px;margin:0 auto;padding:3.5rem 1rem 4rem;box-sizing:border-box;font-family:sans-serif;height:100%;overflow-y:auto}body{background:#121212;color:#eee;margin:0;font-family:sans-serif}.app-header{display:flex;align-items:center;background:#ff7043;color:#fff;padding:.5rem 1rem;position:fixed;top:0;left:0;right:0;z-index:100}.app-header h1{font-size:1.25rem;margin:0}.app-title{position:absolute;left:50%;transform:translate(-50%);margin:0;font-size:1.25rem;width:100%;text-align:center;pointer-events:none}.menu-button{background:none;border:none;color:inherit;font-size:1.5rem;cursor:pointer;margin-right:1rem}.drawer{position:fixed;top:0;left:0;bottom:0;width:240px;background:#ff7043;color:#fff;padding:4rem 1rem 1rem;transform:translate(-100%);transition:transform .3s ease;z-index:10}.drawer.open{transform:translate(0)}.drawer a{display:block;color:#fff;text-decoration:none;padding:.5rem 0;font-size:1.2rem;transition:background .2s ease}.drawer a:hover{background:#fff3}.drawer-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:5}.steps-wrapper{display:flex;overflow:hidden;transition:transform .3s ease}.static-page{padding:1rem}.step{margin-bottom:20px;flex-shrink:0}.nav-buttons{margin-top:10px;display:flex;gap:10px}.nav-buttons button{flex:1;background:#333;color:#eee;border:none;padding:8px 12px;border-radius:4px;cursor:pointer}.nav-buttons button:hover{background:#444}.nav-buttons .primary-button{background:#ff7043;color:#fff}.nav-buttons .primary-button:hover{background:#ffa270}.nav-buttons button:disabled{background:#555;color:#888;cursor:not-allowed}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c}.loader{border:8px solid #f3f3f3;border-top:8px solid #3498db;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite}.progress-text{margin-top:1rem;color:#eee;text-align:center;max-width:80%}.error-text{color:#eee;margin-bottom:1rem;text-align:center;max-width:80%}.error-button{padding:.5rem 1rem;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer}canvas{max-width:100%;height:auto;border:1px solid #444}.step-title{display:flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;font-size:clamp(1rem,5vw,1.5rem)}.icon{width:1em;height:1em}@media (min-width: 640px){.container{max-width:600px;padding:3.5rem 20px 20px;box-sizing:border-box}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mascot-select{display:flex;flex-wrap:wrap;gap:10px}.mascot-option{display:flex;flex-direction:column;align-items:center;width:100px;position:relative}.mascot-option input[type=radio]{display:none}.mascot-image-wrapper{position:relative;width:80px;height:80px;margin-bottom:4px}.mascot-thumb{width:100%;height:100%;object-fit:contain;border:2px solid transparent;border-radius:4px}.mascot-thumb.none{background:transparent;border:2px dashed #555;display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px}.mascot-option>span{width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mascot-option input[type=radio]:checked+.mascot-image-wrapper .mascot-thumb{border-color:#ff7043}.checkmark{position:absolute;bottom:4px;right:4px;background:#ff7043;color:#fff;border-radius:50%;width:16px;height:16px;display:none;align-items:center;justify-content:center;font-size:12px}.mascot-option input[type=radio]:checked+.mascot-image-wrapper .checkmark{display:flex}@media (max-width: 639px){.app-header{padding:.15rem .5rem}.app-header h1{font-size:1rem}.app-title{font-size:1rem;width:100%;text-align:center;pointer-events:none}.menu-button{font-size:1.25rem;margin-right:.5rem}.container{padding-top:2.5rem;box-sizing:border-box}.drawer{padding-top:3rem}}
