:root{font-family:Inter,Pretendard,Apple SD Gothic Neo,Noto Sans KR,system-ui,sans-serif;color:#17233a;background:#91d9ff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button{border:0;font:inherit;touch-action:manipulation;cursor:pointer}button:active{transform:translateY(2px) scale(.98)}.page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 14% 22%,rgba(255,255,255,.9) 0 9%,transparent 10%),linear-gradient(180deg,#42b6f7,#94dcff 44%,#f4f4d3);padding:0}.phone-frame{position:relative;width:min(100vw,430px);min-height:100vh;overflow:hidden;background:linear-gradient(180deg,#5fbef9eb 0,#5fbef9eb 28%,#dcf5ffb3 50%,#fff7d5eb),#9edfff;box-shadow:0 22px 60px #06345e3d;padding:112px 10px 12px}.game-header{position:absolute;z-index:4;top:0;left:0;right:0;display:grid;grid-template-columns:44px 1fr auto auto;gap:7px;align-items:center;padding:8px 9px 10px;background:linear-gradient(180deg,#0d73d1,#0b5eb2);border-bottom:3px solid rgba(3,58,115,.5);color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.18)}.round-button,.pill{color:#fff;box-shadow:inset 0 2px #ffffff47,0 3px #03306261}.round-button{width:40px;height:40px;border-radius:50%;background:linear-gradient(180deg,#49a9ff,#075eb7);font-size:30px;font-weight:900;line-height:1}.language-button{position:absolute;right:10px;top:58px;z-index:5;width:42px;height:34px;border-radius:15px;background:#6949cf;font-size:13px}.logo-block{min-width:0;display:flex;align-items:center;gap:3px;font-size:clamp(18px,6vw,24px);font-weight:950;color:#ffea4c;line-height:.92;-webkit-text-stroke:1px #17345b}.pencil{color:#ffd133;-webkit-text-stroke:0;font-size:24px}.pill{min-height:34px;border-radius:17px;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:0 10px;background:linear-gradient(180deg,#145ea7,#0d4482);font-size:14px;font-weight:900;white-space:nowrap}.coin-pill,.heart-pill,.hint-pill{grid-row:2}.level-pill{grid-column:3 / 5}.coin-pill{grid-column:2 / 3;justify-self:end}.heart-pill{grid-column:3 / 4}.hint-pill{grid-column:4 / 5;color:#6a3b00;background:linear-gradient(180deg,#ffe575,#ffb92d);text-shadow:none}.coin-dot,.heart-dot{width:22px;height:22px;display:inline-grid;place-items:center;border-radius:50%;color:#fff}.coin-dot{background:linear-gradient(180deg,#ffd84c,#f9a318)}.heart-dot{background:linear-gradient(180deg,#ff695c,#e8183f)}.sky-scene{position:absolute;top:112px;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.stage-stepper{position:relative;z-index:3;display:flex;justify-content:flex-start;gap:8px;width:min(calc(100vw - 22px),408px);margin:0 auto 8px;padding:5px 8px;border-radius:999px;background:#ffffffd1;box-shadow:0 4px #42769b24;overflow-x:auto;scrollbar-width:none}.stage-stepper::-webkit-scrollbar{display:none}.stage-dot{flex:0 0 auto;width:34px;height:28px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(180deg,#e8edf5,#c9d4e2);color:#687589;font-size:13px;font-weight:950;box-shadow:inset 0 2px #ffffffb8,0 2px #50698447}.stage-dot.is-unlocked{background:linear-gradient(180deg,#fff,#eaf3ff);color:#1c6dbb}.stage-dot.is-active{background:linear-gradient(180deg,#fff071,#ffbd2e);color:#6b3b00;box-shadow:inset 0 2px #ffffffb8,0 2px #bd7a1561,0 0 0 3px #ffe75957}.stage-dot.is-locked{opacity:.82}.cloud{position:absolute;width:96px;height:42px;border-radius:999px;background:#fffc;filter:blur(.2px)}.cloud:before,.cloud:after{content:"";position:absolute;border-radius:50%;background:inherit}.cloud:before{width:40px;height:40px;left:16px;top:-18px}.cloud:after{width:52px;height:52px;right:10px;top:-26px}.cloud-a{left:-34px;top:78px}.cloud-b{right:-28px;top:170px}.leaf{position:absolute;width:70px;height:120px;border-radius:70% 0;opacity:.45;background:linear-gradient(145deg,#38aa55,#a4db5b)}.leaf-a{left:-46px;top:64px;transform:rotate(24deg)}.leaf-b{right:-45px;top:120px;transform:rotate(-34deg)}.progress-card{position:relative;z-index:1;margin:12px auto 10px;width:min(78%,304px);height:44px;display:grid;grid-template-columns:1fr auto;align-items:center;column-gap:10px;padding:7px 14px;border-radius:22px;background:#fffffff5;box-shadow:0 5px #4e7eab33}.star-track{position:absolute;left:50%;top:-9px;transform:translate(-50%);display:flex;gap:12px;font-size:28px}.star{color:#b6c3cc;text-shadow:0 2px 0 #8b99a4}.star.is-lit{color:#ffd039;text-shadow:0 2px 0 #d38d1e}.progress-line{height:9px;border-radius:999px;background:#d5d5d5;box-shadow:inset 0 1px 2px #00000029;overflow:hidden}.progress-line span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ffd13b,#57d877);transition:width .28s ease}.progress-card strong{font-size:13px;color:#2e5d8b}.board-shell{position:relative;z-index:1;display:grid;grid-template-columns:repeat(var(--cols),1fr);grid-template-rows:repeat(var(--rows),1fr);gap:2px;width:min(calc(100vw - 22px),408px);margin:0 auto;padding:8px;aspect-ratio:var(--cols) / var(--rows);border:4px solid #f4f8ff;border-radius:15px;background:#243c4c;box-shadow:inset 0 0 18px #ffffff0f,0 8px #2252732e}.board-cell{position:relative;min-width:0;border-radius:5px}.block-cell{background:linear-gradient(180deg,#263f4f,#203644);box-shadow:inset 0 0 0 1px #ffffff08}.answer-cell{display:grid;place-items:center;background:linear-gradient(180deg,#fff,#f4f1eb);color:#203245;box-shadow:inset 0 0 0 1px #575c6424,0 1px 2px #0000002e;transition:background .18s ease,transform .18s ease,box-shadow .18s ease}.answer-cell.is-selected{background:linear-gradient(180deg,#fff4a2,#ffdb4b);box-shadow:inset 0 0 0 2px #ffc51d,0 0 0 2px #ffd64747}.answer-cell.is-active{box-shadow:inset 0 0 0 3px #8752ff,0 0 0 2px #6f54ff40}.answer-cell.is-complete{background:linear-gradient(180deg,#dbffe1,#8eea91)}.answer-cell.is-error{animation:shake .42s ease;box-shadow:inset 0 0 0 3px #ff4b5f}.answer-cell.is-hint{animation:hintGlow .78s ease}.number-badge{position:absolute;left:-5px;top:-6px;min-width:18px;height:18px;display:grid;place-items:center;border-radius:5px;background:linear-gradient(180deg,#4facff,#176dd2);color:#fff;font-size:11px;font-weight:900;box-shadow:0 2px #003e8259}.cell-letter{font-size:clamp(17px,6vw,27px);font-weight:950;line-height:1}.clue-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px auto 8px;width:min(calc(100vw - 18px),414px)}.clue-card{overflow:hidden;border-radius:15px;background:#fffffff5;border:3px solid;box-shadow:0 4px #2c4d6533}.clue-across{border-color:#4aa8f0}.clue-down{border-color:#48b45a}.clue-card h2{margin:0;padding:5px 8px;color:#fff;text-align:center;font-size:17px;line-height:1}.clue-across h2{background:linear-gradient(180deg,#58bfff,#2387db)}.clue-down h2{background:linear-gradient(180deg,#69c95e,#2e9846)}.clue-list{max-height:148px;overflow:auto;padding:5px}.clue-item{width:100%;min-height:31px;display:grid;grid-template-columns:20px 1fr;gap:5px;align-items:center;padding:3px;border-radius:8px;background:transparent;color:#24324a;text-align:left}.clue-item span{width:19px;height:19px;display:grid;place-items:center;border-radius:5px;background:#347dd1;color:#fff;font-size:11px;font-weight:900}.clue-item p{margin:0;font-size:11px;line-height:1.25;word-break:keep-all}.clue-item.is-selected{background:#efe6ff;color:#7437d6;font-weight:900}.clue-item.is-selected span{background:#7a4ae2}.clue-item.is-complete{color:#23844a}.game-footer{position:relative;z-index:1;width:min(calc(100vw - 22px),408px);display:flex;align-items:center;justify-content:space-between;margin:0 auto 6px;padding:0 6px;color:#215c87;font-size:13px;font-weight:900}.keyboard-panel{position:relative;z-index:1;width:min(calc(100vw - 8px),422px);margin:0 auto;display:grid;grid-template-columns:68px 1fr 72px;grid-template-rows:auto auto;gap:7px;padding:10px;border-radius:15px;background:linear-gradient(180deg,#1688e8,#0b67bf);border:3px solid #0860ad;box-shadow:inset 0 2px #ffffff52,0 6px #033f7e61}.key-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:5px}.letter-key,.keyboard-action{min-height:42px;border-radius:9px;font-weight:950;box-shadow:inset 0 2px #fffc,0 3px #20375647}.letter-key{background:linear-gradient(180deg,#fff,#e9edf5);color:#25364b;font-size:23px}.vowel-key{color:#145eaf}.keyboard-action{display:grid;place-items:center;align-content:center;gap:2px;color:#fff;font-size:12px}.erase-key{grid-row:1 / 3;background:linear-gradient(180deg,#0f5fab,#07417f)}.enter-key{grid-column:3;grid-row:1 / 3;background:linear-gradient(180deg,#ffe06c,#f6b22d);color:#663900;font-size:14px}.eraser-icon{width:26px;height:18px;border-radius:5px 5px 4px 4px;background:#f8fbff;transform:rotate(-42deg);box-shadow:inset -9px 0 #9ad5ff}.check-icon{font-size:34px;line-height:.8}.draft-bubble{grid-column:2;min-height:28px;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;background:#ffffff2e;color:#fff;font-size:12px;font-weight:800}.draft-bubble strong{min-width:28px;font-size:22px;line-height:1}.modal-backdrop{position:fixed;z-index:10;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0e30587a;padding:22px}.clear-modal{width:min(330px,100%);border-radius:24px;padding:24px 20px 20px;text-align:center;background:linear-gradient(180deg,#fff,#fff8cf);box-shadow:0 18px 50px #07204259;animation:modalPop .34s ease both}.reward-stars{display:flex;justify-content:center;gap:8px;color:#ffd038;font-size:34px;text-shadow:0 3px 0 #d89720;animation:sparkle .8s ease infinite alternate}.clear-modal h2{margin:8px 0 6px;color:#215a97}.clear-modal p{margin:0 0 16px}.reward-chip{width:fit-content;margin:0 auto 16px;display:flex;gap:8px;align-items:center;padding:8px 14px;border-radius:999px;background:#e8fff0;color:#24834c;font-weight:900}.clear-modal button{min-width:120px;min-height:44px;border-radius:12px;background:linear-gradient(180deg,#58c86e,#209848);color:#fff;font-weight:950;box-shadow:0 4px #196a3773}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}}@keyframes hintGlow{0%,to{filter:brightness(1)}50%{filter:brightness(1.35)}}@keyframes sparkle{0%{transform:translateY(0) scale(1)}to{transform:translateY(-4px) scale(1.04)}}@keyframes modalPop{0%{opacity:0;transform:translateY(18px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@media(min-width:700px){.page{padding:24px}.phone-frame{min-height:920px;border-radius:28px;border:8px solid rgba(255,255,255,.74)}}@media(max-width:372px){.phone-frame{padding-left:6px;padding-right:6px}.pill{padding:0 8px;font-size:12px}.key-grid{gap:4px}.letter-key{min-height:38px;font-size:20px}.clue-item p{font-size:10px}}
