@keyframes twinkle{0%,to{opacity:.22}42%{opacity:.5}}@keyframes twinkle-alt{0%,to{opacity:.12}58%{opacity:.3}}@keyframes pulse-border{0%,to{border-color:#d9bd7261;box-shadow:0 0 #d9bd7200,inset 0 0 #d9bd7200}50%{border-color:#d9bd72b8;box-shadow:0 0 32px 4px #d9bd7224,inset 0 0 24px #d9bd720f}}@keyframes shimmer-slide{0%{background-position:-300% center}to{background-position:300% center}}@keyframes moon-breathe{0%,to{filter:drop-shadow(0 0 10px rgb(255 235 160 / 55%)) drop-shadow(0 0 28px rgb(255 235 160 / 20%))}50%{filter:drop-shadow(0 0 18px rgb(255 235 160 / 85%)) drop-shadow(0 0 50px rgb(255 235 160 / 30%))}}@keyframes fade-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes hand-glow-idle{0%,to{filter:drop-shadow(0 0 8px rgb(217 189 114 / 45%))}50%{filter:drop-shadow(0 0 18px rgb(217 189 114 / 70%))}}:root{color:#f7efd8;background:#07091a;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;letter-spacing:0;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}[hidden]{display:none!important}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(ellipse 45% 28% at 10% 4%,rgb(255 225 130 / 13%),transparent),radial-gradient(ellipse 30% 22% at 85% 5%,rgb(90 195 160 / 10%),transparent),radial-gradient(ellipse 55% 38% at 50% 82%,rgb(75 40 120 / 18%),transparent),radial-gradient(ellipse 28% 20% at 68% 28%,rgb(130 70 200 / 9%),transparent),radial-gradient(ellipse 20% 15% at 30% 55%,rgb(60 40 110 / 12%),transparent),linear-gradient(165deg,#04060f,#0b1022,#050d10)}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgb(255 247 214 / 75%) 0 1px,transparent 1.5px),radial-gradient(circle,rgb(177 220 202 / 55%) 0 1px,transparent 1.5px),radial-gradient(circle,rgb(200 165 255 / 50%) 0 1px,transparent 1.5px);background-position:0 0,52px 38px,85px 18px;background-size:124px 124px,188px 188px,230px 170px;animation:twinkle 5s ease-in-out infinite}body:after{content:"";position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgb(220 235 255 / 60%) 0 1px,transparent 1.5px),radial-gradient(circle,rgb(255 240 200 / 50%) 0 1px,transparent 1.5px);background-position:32px 72px,95px 42px;background-size:158px 145px,208px 208px;animation:twinkle-alt 7.5s ease-in-out infinite 2s}button,input{font:inherit}.shell{position:relative;width:min(720px,calc(100% - 24px));margin:0 auto;padding:36px 0 64px}.intro{display:grid;gap:18px;padding:10px 0 28px;animation:fade-rise .9s ease-out both}.cat-hero{position:relative;width:min(100%,420px);margin:0 auto 4px;border:1px solid rgb(217 189 114 / 30%);border-radius:18px;overflow:hidden;background:#ffffff0a;box-shadow:0 24px 70px #0000005c,0 0 60px #d9bd721f}.cat-hero:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 58%,rgb(5 8 20 / 28%)),inset 0 1px 0 #ffffff1a}.cat-hero img{display:block;width:100%;aspect-ratio:1 / 1;object-fit:cover}.intro-head{display:grid;gap:10px;justify-items:center;text-align:center}.moon-icon{width:44px;height:44px;color:#e8c96a;animation:moon-breathe 4.5s ease-in-out infinite}.eyebrow{margin:0;color:#d9bd72;font-size:.77rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}h1,h2,h3,h4{font-family:"Noto Serif JP",Georgia,serif;font-weight:700}h1,h2,h3,h4,p{overflow-wrap:anywhere}h1{margin:0;color:#fff8e0;font-size:clamp(2.1rem,10vw,3.8rem);line-height:1.1;letter-spacing:0;text-shadow:0 0 48px rgb(217 189 114 / 28%),0 0 96px rgb(217 189 114 / 10%)}.sp-only{display:none}.lead{width:min(100%,560px);margin:0 auto;color:#cec6b2;font-size:1.02rem;line-height:2;text-align:center}.workspace{display:grid;gap:20px;align-items:start}.panel,.result-panel{position:relative;overflow:hidden;background:linear-gradient(180deg,#12162ce0,#080e1cf0);border:1px solid rgb(217 189 114 / 30%);border-radius:12px;box-shadow:0 24px 80px #0006,0 0 0 1px #ffffff0a,inset 0 1px #ffffff17}.panel:before,.result-panel:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(118deg,transparent 0 36%,rgb(217 189 114 / 8%) 37%,transparent 40%),radial-gradient(ellipse at 85% 15%,rgb(217 189 114 / 10%),transparent 30%),radial-gradient(ellipse at 15% 85%,rgb(100 60 180 / 8%),transparent 30%)}.panel{display:grid;gap:22px;padding:24px}.panel>*,.result-panel>*{position:relative}.upload-zone{display:grid;place-items:center;min-height:240px;padding:28px;border:1px dashed rgb(217 189 114 / 45%);border-radius:10px;background:#ffffff08;color:#f8eed0;cursor:pointer;text-align:center;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease;animation:pulse-border 3.5s ease-in-out infinite}.upload-zone:hover{border-color:#e8c96a;background:#d9bd7214;box-shadow:0 0 48px #d9bd7224,inset 0 0 32px #d9bd720d;animation:none}.file-input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.panel.has-image .upload-zone{display:none}.upload-hand-icon{width:54px;height:68px;margin-bottom:16px;color:#e6c96a;animation:hand-glow-idle 3.5s ease-in-out infinite;transition:filter .2s ease}.upload-zone:hover .upload-hand-icon{animation:none;filter:drop-shadow(0 0 22px rgb(217 189 114 / 90%))}.upload-title{display:block;font-weight:900;font-size:1.05rem}.upload-meta{display:block;margin-top:8px;color:#b8ae98;font-size:.88rem}.preview-wrap{display:grid;gap:14px}.preview-image{width:100%;max-height:58vh;border:1px solid rgb(217 189 114 / 25%);border-radius:10px;object-fit:contain;background:#0d1228}.preview-actions{display:flex;gap:12px;align-items:center;justify-content:space-between}.change-image-button{display:inline-grid;place-items:center;min-height:38px;padding:0 16px;border:1px solid rgb(217 189 114 / 34%);border-radius:8px;color:#fff2c7;cursor:pointer;font-size:.88rem;font-weight:800;white-space:nowrap;transition:border-color .16s ease,background .16s ease}.change-image-button:hover{border-color:#d9bd72a6;background:#d9bd7212}.privacy-note,.dev-note,.status,.disclaimer{margin:0;color:#b0a892;font-size:.88rem;line-height:1.65}.turnstile-area{min-height:70px;display:grid;align-items:center}.status.is-error{color:#ffb09e;font-weight:800}.primary-button{min-height:56px;border:0;border-radius:10px;cursor:pointer;font-family:"Noto Serif JP",Georgia,serif;font-size:1.05rem;font-weight:700;letter-spacing:.05em;transition:opacity .16s ease,box-shadow .16s ease}.primary-button:not(:disabled){background:linear-gradient(90deg,#a87820,#e8cc80 28%,#fce9b4,#e8cc80 72%,#a87820);background-size:300% 100%;color:#0e1120;box-shadow:0 12px 40px #d9bd7240,0 0 0 1px #ffffff1a inset;animation:shimmer-slide 3.5s linear infinite}.primary-button:not(:disabled):hover{opacity:.9;box-shadow:0 16px 54px #d9bd7261,0 0 0 1px #ffffff24 inset}.primary-button:disabled{background:#32303ecc;color:#9a96a4;box-shadow:none;cursor:not-allowed}.result-panel{padding:30px;animation:fade-rise .7s ease-out both}.result-panel[hidden]{display:none}.result-header{padding-bottom:24px;border-bottom:1px solid rgb(217 189 114 / 18%)}.result-header h2{margin:10px 0 16px;color:#fff8e0;font-size:clamp(1.45rem,6vw,2.15rem);line-height:1.25;text-shadow:0 0 40px rgb(217 189 114 / 28%)}.result-header p:last-child,.result-block p,.hint-section p,.lucky-action p,.empty-result p{margin:0;color:#d8d0bc;line-height:1.85}.result-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:22px}.result-block,.hint-section{border-radius:10px}.result-block{padding:18px 20px;background:#ffffff0a;border:1px solid rgb(255 255 255 / 7%)}.result-block h3,.hint-section h3,.lucky-action h4{margin:0 0 9px;color:#ffe8a0;font-size:.92rem;letter-spacing:.04em}.hint-section{margin-top:12px;padding:18px 20px;background:radial-gradient(ellipse at 20% 20%,rgb(217 189 114 / 16%),transparent 38%),radial-gradient(ellipse at 80% 80%,rgb(100 60 180 / 12%),transparent 38%),#ffffff0a;border:1px solid rgb(217 189 114 / 26%);box-shadow:inset 0 0 40px #d9bd720a}.hint-section h3{font-size:.95rem;line-height:1.4;color:#ffe8a0;text-shadow:none}.lucky-action{margin-top:18px;padding-top:16px;border-top:1px solid rgb(217 189 114 / 18%)}.lucky-action h4{color:#d9bd72;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.disclaimer{margin-top:20px;font-size:.82rem}.empty-result{display:grid;gap:14px;align-content:center;min-height:320px}.empty-result h2{margin:0;color:#fff8e0;font-size:1.8rem}.empty-result small{color:#b0a892}@media(max-width:860px){.shell{width:min(100% - 24px,680px);padding-top:28px}}@media(max-width:520px){.sp-only{display:inline}}@media(max-width:460px){.shell{width:min(100% - 20px,680px);padding-top:20px}.panel,.result-panel{padding:18px}.preview-actions{align-items:stretch;flex-direction:column}.change-image-button{width:100%}}
