.app{min-width:640px;min-height:480px;height:100%;display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem 112px;box-sizing:border-box;overflow:hidden}@media(min-width:640px){.app{padding:.5rem 2rem 132px}}.app__main{width:100%;max-width:560px;margin-top:1rem;flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:auto}.idle-cat{width:300px;height:300px;flex-shrink:0}.idle-cat__svg{width:100%;height:100%;overflow:visible}.idle-cat__yarn{transform-origin:195px 220px;animation:idle-cat-yarn 2.5s ease-in-out infinite}.idle-cat__paw{transform-origin:130px 195px;animation:idle-cat-paw 1.8s ease-in-out infinite}.idle-cat__tail{transform-origin:95px 200px;animation:idle-cat-tail 3s ease-in-out infinite}.idle-cat__eye{transform-origin:center;animation:idle-cat-blink 4s ease-in-out infinite}@keyframes idle-cat-yarn{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-8px,4px) rotate(15deg)}50%{transform:translate(-4px,2px) rotate(-5deg)}75%{transform:translate(-10px,3px) rotate(10deg)}}@keyframes idle-cat-paw{0%,to{transform:translate(0) rotate(-5deg)}40%{transform:translate(28px,-12px) rotate(15deg)}70%{transform:translate(20px,-5px) rotate(8deg)}}@keyframes idle-cat-tail{0%,to{transform:rotate(0)}50%{transform:rotate(8deg)}}@keyframes idle-cat-blink{0%,45%,55%,to{transform:scaleY(1)}50%{transform:scaleY(.1)}}.app__input-bar{position:fixed;bottom:0;left:0;right:0;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-block:1.25rem;padding-inline:1rem;background:linear-gradient(to top,#fff 80%,transparent);box-sizing:border-box;overflow:hidden}.app__input-bar:before,.app__input-bar:after{content:"";flex:1 1 0;min-height:.5rem}@media(min-width:640px){.app__input-bar{padding-block:1.25rem;padding-inline:1rem}}.app__input-bar .logo-input{width:100%;max-width:560px;margin:0;background:#fff;border:1px solid #e5e5e5;border-radius:12px;padding:.5rem 1rem;box-shadow:0 2px 12px #00000014;box-sizing:border-box;flex-shrink:0}.app__again{margin-top:1rem;padding:.6rem 1.2rem;font-size:1rem;cursor:pointer;background:#eee;border:1px solid #ccc;border-radius:8px}.app__again:hover{background:#e0e0e0}.header{width:100%;max-width:560px;align-self:flex-start;margin-bottom:.5rem;padding-top:0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header__logo{display:inline-block;font-size:1.25rem;font-weight:700;color:#111;text-decoration:none;letter-spacing:-.02em}.header__logo:hover{color:#333}.header__download{position:fixed;top:.75rem;right:1rem;z-index:10;padding:.5rem 1rem;font-size:.95rem;cursor:pointer;background:#111;color:#fff;border:none;border-radius:8px}@media(min-width:640px){.header__download{right:2rem}}.header__download:hover{background:#333}.logo-input{display:flex;flex-direction:column;gap:.5rem;box-sizing:border-box}.logo-input__row{display:flex;flex-direction:row;align-items:flex-end;gap:.5rem;min-height:48px;box-sizing:border-box}.logo-input__field-wrap{flex:1;min-width:0;height:48px;min-height:48px;max-height:258px;box-sizing:border-box}.logo-input__field{width:100%;height:100%;min-height:48px;max-height:258px;padding:.5rem 0;font-size:1rem;font-family:inherit;line-height:1.4;border:none;border-radius:0;resize:none;box-sizing:border-box;background:transparent;overflow-y:auto;display:block}.logo-input__field:focus{outline:none}.logo-input__mic-error{margin:0 0 .25rem;font-size:.8rem;color:#b91c1c;line-height:1.3}.logo-input__footer{display:flex;justify-content:flex-end;align-items:center;gap:.25rem;flex-shrink:0;margin-bottom:11px}.logo-input__submit,.logo-input__voice{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;background:transparent;color:#666}.logo-input__submit{background:#111;color:#fff}.logo-input__submit:hover:not(:disabled){background:#333}.logo-input__submit:disabled{background:#ccc;cursor:not-allowed}.logo-input__submit-icon,.logo-input__voice-icon{width:20px;height:20px;display:block}.logo-input__voice:hover{color:#111;background:#f0f0f0}.logo-input__voice--active{color:#b91c1c;background:#fee2e2}.logo-input__voice--active .logo-input__voice-icon{animation:logo-input__pulse 1s ease-in-out infinite}@keyframes logo-input__pulse{50%{opacity:.6}}.loading-state{margin-top:1.5rem;text-align:center}.loading-state__spinner{width:40px;height:40px;margin:0 auto 1rem;border:3px solid #eee;border-top-color:#111;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state__text{font-size:.95rem;color:#666;margin:0}.logo-result{display:flex;flex-direction:column;align-items:center;gap:1rem}.logo-result__image{max-width:100%;height:auto;border-radius:8px;box-shadow:0 2px 12px #0000001a}.logo-result__download{padding:.6rem 1.25rem;font-size:1rem;cursor:pointer;background:#111;color:#fff;border:none;border-radius:8px}.logo-result__download:hover{background:#333}.error-state{margin-top:1rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;text-align:center}.error-state__message{margin:0 0 .75rem;color:#b91c1c}.error-state__detail{margin:0 0 .75rem;font-size:.85rem;color:#991b1b;font-family:ui-monospace,monospace}.error-state__retry{padding:.5rem 1rem;font-size:.95rem;cursor:pointer;background:#fff;border:1px solid #f87171;border-radius:6px;color:#b91c1c}.error-state__retry:hover{background:#fee2e2}*,*:before,*:after{box-sizing:border-box}html{min-width:640px;min-height:480px}body{margin:0;min-width:640px;min-height:480px;height:100vh;height:100dvh;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;color:#1a1a1a;-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100%}
