@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(../media/cdf703449fd42bc8-s.665aa8c9.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(../media/3f10656f33c57dec-s.1b5b6537.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(../media/56eb15be423b6220-s.23b201d9.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(../media/96074e70a40501da-s.8c31978f.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"Press Start 2P";font-style:normal;font-weight:400;font-display:swap;src:url(../media/de161955856a921d-s.p.25da2b95.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"Press Start 2P Fallback";src:local(Arial);ascent-override:44.58%;descent-override:0.0%;line-gap-override:0.0%;size-adjust:224.32%}.press_start_2p_10a0754e-module__SvTriW__className{font-family:"Press Start 2P","Press Start 2P Fallback";font-style:normal;font-weight:400}.press_start_2p_10a0754e-module__SvTriW__variable{--font-press-start-2p:"Press Start 2P","Press Start 2P Fallback"}
@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.start{inset-inline-start:var(--spacing)}}:root{--font-body:var(--font-noto-sans-kr);--font-pixel:var(--font-press-start-2p);--red-outer:#d93344;--red-dark:#ad1b2f;--yellow-acc:#ffd447;--blue-panel:#3b77c9;--screen-bg:#e8f8ff;--ink:#14233a}*{box-sizing:border-box}body{min-height:100vh;color:var(--ink);font-family:var(--font-body),sans-serif;background:radial-gradient(circle at 20% 15%,#fff9c2 0%,#0000 35%),radial-gradient(circle at 80% 10%,#c7e8ff 0%,#0000 30%),radial-gradient(circle at 50% 85%,#b4f5d4 0%,#0000 36%),linear-gradient(145deg,#6fd4ff 0%,#9cd881 100%);margin:0}.pokemon-world{place-items:center;width:100%;min-height:100vh;padding:24px;display:grid}.pokedex-shell{background:linear-gradient(160deg,var(--red-outer)0%,var(--red-dark)90%);border:10px solid #6d0e1c;border-radius:24px;grid-template-columns:1.1fr .9fr;width:min(1020px,100%);min-height:680px;display:grid;overflow:hidden;box-shadow:0 24px 40px #00000047,inset -6px -6px #00000038,inset 6px 6px #ffffff26}.pokedex-left{background:linear-gradient(#ef5160 0%,#cf273a 100%);border-right:5px solid #7f1423;padding:28px}.pokedex-right{background:linear-gradient(#0000 30%,#ffffff14 100%),linear-gradient(#f74f5f 0%,#d43043 100%);flex-direction:column;gap:16px;padding:28px;display:flex}.lens-row{align-items:center;gap:10px;margin-bottom:18px;display:flex}.main-lens{background:radial-gradient(circle at 32% 28%,#d7f3ff 10%,#2e7dc9 68%,#1b4f89 100%);border:5px solid #ecf6ff;border-radius:999px;width:60px;height:60px;box-shadow:0 0 0 3px #1a4f89}.dot{border:2px solid #0003;border-radius:999px;width:16px;height:16px}.dot-red{background:#ff6161}.dot-yellow{background:#ffda4f}.dot-green{background:#57e079}.title{color:#fff8dc;font-family:var(--font-pixel),monospace;text-shadow:2px 2px #0006;margin:0;font-size:2.68476rem;line-height:1.5}.subtitle{color:#ffeec2;margin:12px 0 20px;font-size:.92rem;line-height:1.5}.generator-form{flex-direction:column;gap:14px;display:flex}.field{color:#fff8dc;flex-direction:column;gap:8px;font-size:.85rem;font-weight:700;display:flex}.field-header{justify-content:space-between;align-items:center;display:flex}.char-count{color:#ffedc0;opacity:.7;font-size:.75rem;font-weight:400;transition:color .2s,opacity .2s}.char-count.over{color:#ff6b6b;opacity:1}.text-input{color:#1b2e4c;width:100%;font-size:.95rem;font-family:var(--font-body),sans-serif;background:#f7fbff;border:3px solid #254f88;border-radius:10px;outline:none;padding:10px 12px}.text-input:focus{box-shadow:0 0 0 4px #ffd4478c}.prompt-input{resize:vertical;min-height:80px}.type-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.generate-button{background:linear-gradient(180deg,#ffe46f 0%,var(--yellow-acc)100%);color:#18345c;font-family:var(--font-pixel),monospace;cursor:pointer;border:4px solid #124075;border-radius:999px;padding:14px 16px;font-size:.8rem;transition:transform .2s,filter .2s}.generate-button:hover:not(:disabled){filter:brightness(1.04);transform:translateY(-2px)}.generate-button:disabled{cursor:not-allowed;filter:saturate(.3)}.screen{background:repeating-linear-gradient(180deg,#fff0 0,#fff0 7px,#57abdb2e 8px,#57abdb2e 9px),var(--screen-bg);border:6px solid #20558f;border-radius:16px;place-items:center;min-height:500px;padding:14px;display:grid;box-shadow:inset 0 0 0 3px #99d6f7,inset 0 -8px 16px #20558f38}.generated-image{object-fit:contain;border-radius:8px;width:100%;max-height:460px;animation:.45s ease-out float-in}.screen-status,.screen-placeholder{text-align:center;color:#1f476f;margin:0;padding:0 10px;font-weight:700;line-height:1.6}.screen-status{animation:1.2s infinite pulse}.loading-container{flex-direction:column;align-items:center;gap:20px;display:flex}.pokeball-spinner{background:linear-gradient(#f44 0% 42%,#222 42% 58%,#fff 58% 100%);border:3px solid #333;border-radius:50%;width:52px;height:52px;animation:1s linear infinite spin;position:relative}.pokeball-spinner:after{content:"";background:#fff;border:3px solid #333;border-radius:50%;width:16px;height:16px;margin:auto;position:absolute;inset:0}.screen-placeholder-wrap{flex-direction:column;align-items:center;gap:12px;display:flex}.placeholder-icon{font-size:3rem;animation:2.5s ease-in-out infinite float}.error-text{color:#fff3f3;background:#921c2a;border:2px solid #7d0015;border-radius:8px;margin:0;padding:10px 12px;font-weight:700}@keyframes float-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width:900px){.pokemon-world{padding:10px}.pokedex-shell{border-width:7px;border-radius:16px;grid-template-columns:1fr}.pokedex-left{border-bottom:5px solid #7f1423;border-right:0}.pokedex-left,.pokedex-right{padding:18px}.screen{min-height:360px}.generated-image{max-height:320px}}
