:root{--bg:#eaf7ec;--surface:#fff;--ink:#2f4a55;--muted:#8aa0ab;--primary:#3f9fc4;--primary-ink:#fff;--accent:#ec7f9d;--cta:#ffb64d;--cta-ink:#7a3d0f;--cta-shadow:#d97a2f;--good:#34c759;--bad:#ff5a5f;--ring:#3f9fc447;--radius:24px;--shadow:0 12px 24px -12px #3c78a059;--sky:linear-gradient(180deg, #7fc9f5 0%, #a5ddf7 38%, #d3f0ee 74%, #eafbe6 100%);--font-head:"Fredoka", "Segoe UI", system-ui, sans-serif;font-family:Nunito Sans,Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--sky);color:var(--ink)}#root{justify-content:center;width:100%;display:flex}.app-frame{background:0 0;flex-direction:column;width:100%;max-width:1280px;min-height:100dvh;padding:clamp(14px,3vh,40px) clamp(12px,3vw,48px);display:flex;position:relative}@keyframes drift{0%{transform:translate(0)}to{transform:translate(60px)}}@keyframes drift2{0%{transform:translate(0)}to{transform:translate(-50px)}}@keyframes puff{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-10px)scale(1.02)}}@keyframes sunbeat{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.75;transform:scale(1.12)}}@keyframes hop{0%,to{transform:translateY(0)rotate(-2deg)}30%{transform:translateY(-18px)rotate(3deg)}55%{transform:translateY(3px)rotate(-1deg)}}@keyframes wave{0%,60%,to{transform:rotate(0)}70%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}90%{transform:rotate(-6deg)}}@keyframes blink2{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}@keyframes skyfly{0%{transform:translate(-80px)}to{transform:translate(103vw)}}@keyframes flap{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes crossR{0%{transform:translate(-100px)}50%{transform:translate(102vw)}to{transform:translate(102vw)}}@keyframes crossL{0%{transform:translate(102vw)}50%{transform:translate(-100px)}to{transform:translate(-100px)}}@keyframes walkbob{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-9px)rotate(2deg)}}@keyframes waddle{0%,to{transform:translateY(0)rotate(3deg)}50%{transform:translateY(-4px)rotate(-3deg)}}@keyframes froghop{0%,to{transform:translateY(0)}40%{transform:translateY(-46px)}}@keyframes peek{0%,22%{transform:translateY(96px)}34%,46%{transform:translateY(6px)}58%,to{transform:translateY(96px)}}@keyframes popgrass{0%,26%{transform:translateY(100px)}40%,54%{transform:translateY(4px)}66%,to{transform:translateY(100px)}}@keyframes dashspin{to{transform:rotate(360deg)}}@keyframes pulse2{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes tapbob{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(-6px)}}@keyframes popin{0%{transform:scale(.35)}55%{transform:scale(1.12)}78%{transform:scale(.96)}to{transform:scale(1)}}@keyframes screen-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.screen{z-index:1;animation:.4s cubic-bezier(.22,1,.36,1) both screen-in;position:relative}@media (prefers-reduced-motion:reduce){.screen{animation:none}}.screen{width:100%;max-width:var(--content-max);--content-max:640px;background:var(--surface);border:3px solid #fff;border-radius:32px;flex-direction:column;flex:1;align-self:center;gap:16px;padding:24px 26px;display:flex;overflow-y:auto;box-shadow:0 40px 70px -26px #326e9673}.screen>:not(.overlay){width:100%}.screen-wide{--content-max:1120px}.screen .bigcard{max-width:460px;margin-inline:auto}.screen .grid2x2{max-width:520px;margin-inline:auto}.screen-home{max-width:1120px}.screen-home .home-grid{margin-block:auto}h1{font-family:var(--font-head);margin:0;font-size:30px;font-weight:600}h2{font-family:var(--font-head);margin:0;font-size:21px;font-weight:600}p{margin:0;line-height:1.4}.muted{color:var(--muted)}.center{text-align:center}button{font-family:var(--font-head);cursor:pointer;color:var(--ink);background:#fff;border:none;border-radius:16px;padding:14px 18px;font-size:16px;font-weight:600;transition:transform 80ms,box-shadow .15s,background .15s;box-shadow:0 8px 16px -10px #3c78a080}button:active{transform:scale(.97)}button:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--cta);color:var(--cta-ink);box-shadow:0 8px 0 var(--cta-shadow)}.btn-primary:active{box-shadow:0 4px 0 var(--cta-shadow);transform:translateY(4px)}.btn-accent{background:var(--accent);color:#fff;box-shadow:0 8px #c85f7d}.btn-accent:active{transform:translateY(4px);box-shadow:0 4px #c85f7d}.btn-ghost{box-shadow:none;background:0 0}.btn-block{width:100%}.btn-pill{color:var(--ink);font-family:var(--font-head);background:#fff;border-radius:999px;align-items:center;gap:6px;padding:9px 16px;font-size:15px;font-weight:600;display:inline-flex;box-shadow:0 6px 14px -8px #3c78a080}.btn-pill .btn-pill-icon{font-size:16px;line-height:1}.row{gap:12px;display:flex}.row>*,.spacer{flex:1}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);border:3px solid #fff;padding:18px}.hero{color:#fff;background:linear-gradient(150deg,#5bb8c9 0%,#3f9fc4 100%);border:none;border-radius:28px;padding:24px 26px;position:relative;overflow:hidden;box-shadow:0 18px 30px -12px #3296b48c}.hero h2{color:#fff}.hero .muted{color:#e3f6fa}.hero-paw{opacity:.14;pointer-events:none;-webkit-user-select:none;user-select:none;position:absolute}.homecard{text-align:left;border:3px solid #fff;border-radius:26px;align-items:center;gap:16px;padding:18px 20px;display:flex}.homecard-explore{background:linear-gradient(150deg,#fff2d0,#ffe4a8)}.homecard-practice{background:linear-gradient(150deg,#ffe1e8,#ffc9d6)}.homecard-icon{border-radius:18px;flex:none;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.homecard-icon.explore{background:linear-gradient(150deg,#8fd3f0,#5eb6e0)}.homecard-icon.practice{background:linear-gradient(150deg,#f7a8bf,#ec7f9d)}.home-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.home-head-right{align-items:center;gap:12px;display:flex}.eyebrow{font-family:var(--font-head);letter-spacing:.1em;text-transform:uppercase;color:var(--primary);font-size:13px;font-weight:600}.home-grid{grid-template-columns:1.5fr 1fr;align-items:stretch;gap:18px;display:grid}.home-grid .hero-tall{grid-area:1/1/span 2}.home-grid .homecard-explore{grid-area:1/2}.home-grid .homecard-practice{grid-area:2/2}.home-grid .hero-tall{flex-direction:column;justify-content:center;display:flex}@media (width<=760px){.home-grid{grid-template-columns:1fr}.home-grid .hero-tall,.home-grid .homecard-explore,.home-grid .homecard-practice{grid-area:auto}}input,select{font:inherit;width:100%;color:var(--ink);background:#fff;border:2px solid #e4def4;border-radius:12px;padding:13px 14px}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--ring);outline:none}label{margin-bottom:6px;font-size:14px;font-weight:600;display:block}.field{margin-bottom:16px}.tile{aspect-ratio:1;background:#efeafb;border-radius:18px;justify-content:center;align-items:center;display:flex;overflow:hidden}.tile img{object-fit:cover;width:100%;height:100%}.screen .photo-slot{cursor:pointer;width:172px;height:172px;margin:8px auto 0;display:block;position:relative}.photo-slot input{opacity:0;width:1px;height:1px;position:absolute}.photo-ring{border:5px dashed #7fd0c4;border-radius:50%;animation:18s linear infinite dashspin;position:absolute;inset:0}.photo-inner{background:linear-gradient(160deg,#eafffb,#c6f2ea) 50%/cover;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:9px;overflow:hidden;box-shadow:inset 0 -10px 18px #3c968c2e}.photo-inner .cam{font-size:48px}.photo-inner .hint{font-family:var(--font-head);color:var(--primary);font-size:15px;font-weight:600}.photo-plus{background:var(--cta);color:#fff;border:5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:24px;animation:2s ease-in-out infinite pulse2;display:flex;position:absolute;bottom:4px;right:4px;box-shadow:0 6px 12px -4px #e6963280}.photo-tap{color:#fff;font-family:var(--font-head);white-space:nowrap;background:#ff7a6b;border-radius:999px;padding:5px 12px;font-size:13px;font-weight:600;animation:1.4s ease-in-out infinite tapbob;position:absolute;top:-10px;left:50%;box-shadow:0 6px 12px -4px #dc504680}.photo-snapped{animation:.55s ease-out popin}.thumb-grid{grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:10px;display:grid}.theme-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.theme-tile{text-align:center;background:var(--surface);box-shadow:var(--shadow);border:2px solid #0000;border-radius:16px;padding:16px 12px;font-weight:700}.theme-tile.locked{opacity:.5;filter:grayscale(.6)}.theme-emoji{margin-bottom:6px;font-size:30px;display:block}.bigcard{aspect-ratio:1;width:100%;box-shadow:var(--shadow);background:#fff;border-radius:26px;justify-content:center;align-items:center;display:flex;overflow:hidden}.bigcard img{object-fit:cover;width:100%;height:100%}.word-en{text-align:center;font-size:38px;font-weight:800}.word-ko{color:var(--muted);text-align:center;font-size:22px}.grid2x2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grid2x2 .tile{cursor:pointer;border:4px solid #0000;transition:all .15s}.tile.correct{border-color:var(--good);box-shadow:0 0 0 6px #34c75940}.tile.wrong{opacity:.4;border-color:var(--bad)}.pos-indicator{justify-content:center;gap:6px;display:flex}.dot{background:#d8d0ef;border-radius:50%;width:8px;height:8px}.dot.on{background:var(--primary)}.topbar{justify-content:space-between;align-items:center;display:flex}.icon-btn{border-radius:50%;width:44px;height:44px;padding:0;font-size:20px}.overlay{z-index:20;background:#281e4673;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet{background:#fff;border-radius:24px 24px 0 0;flex-direction:column;gap:14px;width:100%;padding:22px;display:flex}.celebrate{text-align:center;font-size:64px;animation:.5s pop}@keyframes pop{0%{opacity:0;transform:scale(.2)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.badge{color:var(--muted);background:#ece8f7;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700}.statuspill{border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.statuspill.ready{color:#1c9d4b;background:#e3f9ea}.statuspill.gen{color:#c87f00;background:#fff3e0}.avatar{object-fit:cover;box-shadow:var(--shadow);background:#efeafb;border-radius:50%;flex:none}.avatar-placeholder{color:var(--primary);justify-content:center;align-items:center;font-size:1.4em;font-weight:800;display:flex}.avatar-bob{animation:2.4s ease-in-out infinite bob}.avatar-wave{transform-origin:70% 90%;animation:2.8s ease-in-out infinite wave}.avatar-cheer{animation:.6s ease-in-out infinite cheer}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes cheer{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-10px)scale(1.05)}}.chips{flex:none;gap:8px;padding-bottom:6px;display:flex;overflow-x:auto}.chip{color:var(--muted);background:#ece8f7;border-radius:999px;flex:none;padding:8px 14px;font-size:13px;font-weight:700}.chip.on{background:var(--primary);color:#fff}@media (width>=760px){.chips{flex-wrap:wrap;overflow-x:visible}.overlay{align-items:center}.sheet{border-radius:24px;max-width:460px;margin:auto}}.spinner{border:3px solid #f0d9b0;border-top-color:#c87f00;border-radius:50%;flex:none;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.landing-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}@media (width<=620px){.landing-grid{grid-template-columns:1fr}}.landing-card{text-align:center;box-shadow:var(--shadow);cursor:pointer;border:3px solid #fff;border-radius:26px;flex-direction:column;align-items:center;gap:6px;padding:28px 22px;display:flex;position:relative}.landing-card.learn{color:#fff;background:linear-gradient(150deg,#5bb8c9,#3f9fc4)}.landing-card.learn .landing-desc{color:#e3f6fa}.landing-card.create{background:linear-gradient(150deg,#fff2d0,#ffe4a8)}.landing-card.learn{transition:transform .14s,box-shadow .18s}.landing-card.learn:hover{transform:translateY(-5px)scale(1.02);box-shadow:0 20px 34px -16px #3278a08c}.landing-card.is-disabled{filter:grayscale();opacity:.55;cursor:not-allowed;box-shadow:none}.landing-card.is-disabled:hover{transform:none}.landing-emoji{font-size:52px}.landing-title{font-family:var(--font-head);margin-top:4px;font-size:24px;font-weight:600}.landing-desc{color:var(--muted);max-width:22ch;font-size:14px}.landing-cta{font-family:var(--font-head);margin-top:10px;font-weight:600}.landing-card.learn .landing-cta{color:#fff}.landing-footer{border-top:1px solid #eef2f5;justify-content:center;align-items:center;gap:10px;padding-top:14px;display:flex}.landing-badge{color:#fff;font-family:var(--font-head);background:#ff7a6b;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;position:absolute;top:14px;right:14px}.auth-tabs{background:#eef4f7;border-radius:16px;gap:8px;padding:5px;display:flex}.auth-tab{box-shadow:none;color:var(--muted);font-family:var(--font-head);background:0 0;border-radius:12px;flex:1;padding:10px}.auth-tab.on{color:var(--ink);background:#fff;box-shadow:0 4px 10px -6px #3c78a080}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-steps{color:var(--muted);justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.auth-step{font-family:var(--font-head);align-items:center;gap:6px;display:flex}.auth-step.on{color:var(--primary)}.auth-step-dot{width:22px;height:22px;color:var(--muted);background:#e6eef2;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.auth-step.on .auth-step-dot{background:var(--primary);color:#fff}.auth-msg{border-radius:12px;padding:10px 12px;font-size:13px;font-weight:600}.auth-msg.err{color:#c0392b;background:#fde8e8}.auth-msg.ok{color:#1c9d4b;background:#e3f9ea}.auth-divider{color:var(--muted);align-items:center;gap:10px;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#e4e9ee;flex:1;height:1px}.auth-social{flex-direction:column;gap:10px;display:flex}.social-btn{font-family:var(--font-head);border:1px solid #00000014;border-radius:14px;justify-content:center;align-items:center;gap:10px;padding:13px;font-weight:600;display:flex}.legal{overflow-y:auto}.legal-section{margin-bottom:16px}.legal-section h2{font-family:var(--font-head);color:var(--ink);margin-bottom:6px;font-size:16px}.legal-p{color:#4a5a63;margin-bottom:4px;font-size:13.5px;line-height:1.6}.consent{background:#f4fbfd;border:2px solid #d6ecf3;border-radius:14px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.consent-row{color:var(--ink);align-items:flex-start;gap:8px;font-size:13.5px;display:flex}.consent-row input{flex:none;width:auto;margin-top:2px}.consent-row .req{color:var(--bad);font-weight:700}.consent-link{color:var(--primary);cursor:pointer;box-shadow:none;background:0 0;padding:0;font-size:13.5px;text-decoration:underline}.phone-row{align-items:center;gap:8px;display:flex}.phone-row input{text-align:center}.phone-sep{color:var(--muted);font-weight:700}.social-btn.kakao{color:#3c1e1e;background:#fee500}.social-btn.google{color:#3c4043;background:#fff}.social-btn.naver{color:#fff;background:#03c75a}.createcard-steps{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 4px;margin-top:22px;display:flex}.createcard-step{align-items:center;gap:4px;display:flex}.createcard-step-emoji{width:52px;height:52px;box-shadow:var(--shadow);background:#fff;border:2px solid #fff;border-radius:16px;justify-content:center;align-items:center;font-size:26px;display:flex}.createcard-step-label{color:var(--muted);margin:0 4px 0 2px;font-size:12px;font-weight:700}.createcard-arrow{color:var(--muted)}
