:root{color:#5f4260;background:#fff6fb;font-family:Hiragino Maru Gothic ProN,Yu Gothic,Meiryo,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 18% 14%,#fff8c9 0 11%,transparent 12%),radial-gradient(circle at 90% 8%,#dff7ff 0 10%,transparent 11%),linear-gradient(180deg,#fff6fb,#ffe8f5)}button{border:0;color:inherit;font:inherit;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.app{width:min(100%,920px);min-height:100vh;margin:0 auto;padding:max(16px,env(safe-area-inset-top)) 16px max(20px,env(safe-area-inset-bottom))}.topBar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;min-height:52px;gap:12px}.stars{margin-left:auto;padding:10px 18px;border:3px solid #fff;border-radius:999px;background:#fff8c9;box-shadow:0 6px #ffd1e9;font-size:1.45rem;font-weight:800}.smallButton,.parentLink,.mamaButton,.adjustModeButton{padding:12px 18px;border-radius:999px;background:#fff;box-shadow:0 5px #e7c8df;font-weight:800}.adjustModeButton{background:#dff7ff;font-size:.95rem}.mamaButton{background:#fff;font-size:.95rem}.activeMamaMode{background:#fff8c9;color:#8b3369}.activeAdjustMode{background:#ffbde0;color:#7c2f61}.debugLink{background:#e8ddff}.home{display:grid;width:min(100%,520px);margin:0 auto;gap:16px;justify-items:center;padding-top:8px}h1,h2,p{margin:0}h1{color:#d9519a;text-align:center;font-size:clamp(1.95rem,8vw,3.2rem);line-height:1.12}h2{color:#d9519a;text-align:center;font-size:2rem}.menuGrid{display:grid;width:100%;gap:14px}.menuButton{min-height:82px;border:4px solid #fff;border-radius:26px;box-shadow:0 8px #d9519a38;font-size:clamp(1.45rem,6vw,2rem);font-weight:900}.clockButton{background:#dff7ff}.addButton{background:#fff8c9}.subButton{background:#e8ddff}.princessButton{background:#ffd8ef}.shopButton{background:#dff7ff}.princessPanel{width:100%;max-width:520px;padding:14px;border:4px solid #fff;border-radius:28px;background:linear-gradient(180deg,#fff,#ffeef8);box-shadow:0 8px #ffd1e9}.princessStage{position:relative;min-height:auto;aspect-ratio:1 / 1;margin-top:10px;border-radius:24px;background:#fff7fc;overflow:hidden}.princessLayer{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;pointer-events:none;transform:translate(var(--offset-x, 0),var(--offset-y, 0)) rotate(var(--layer-rotation, 0deg)) scale(var(--layer-scale, 1));transform-origin:50% 50%}.backgroundLayer{z-index:0;object-fit:cover}.baseLayer{z-index:3}.dressLayer{z-index:5}.shoesLayer{z-index:4}.bagLayer{z-index:6}.accessoryLayer{z-index:7}.magicLayer{z-index:8}.petLayer{z-index:2}.mamaPanel{display:grid;gap:10px;margin:8px 0 14px;padding:12px;border:3px solid #fff;border-radius:22px;background:#ffffffb8;box-shadow:0 6px #d9519a2e}.mamaPanel strong{color:#d9519a;font-size:1.1rem}.mamaActions{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px}.mamaActions button{min-height:50px;border-radius:16px;background:#dff7ff;box-shadow:0 4px #9fd9e8;font-weight:900}.mamaActions .dangerButton{background:#ffd8ef;box-shadow:0 4px #d9519a}.sceneSparkle,.sceneHeart{position:absolute;z-index:7;pointer-events:none}.sceneSparkle:before,.sceneSparkle:after{position:absolute;width:18px;height:18px;background:#fff8c9;content:"";clip-path:polygon(50% 0,61% 37%,100% 50%,61% 63%,50% 100%,39% 63%,0 50%,39% 37%)}.sparkleOne{top:52px;left:36px;animation:twinkle 1.2s ease-in-out infinite alternate}.sparkleTwo{right:42px;bottom:64px;animation:twinkle 1.5s ease-in-out infinite alternate}.sceneHeart{top:28px;right:40px;width:22px;height:20px;background:#ff9ccd;transform:rotate(-45deg);animation:twinkle 1.4s ease-in-out infinite alternate}.sceneHeart:before,.sceneHeart:after{position:absolute;width:22px;height:22px;border-radius:50%;background:#ff9ccd;content:""}.sceneHeart:before{top:-11px;left:0}.sceneHeart:after{top:0;left:11px}.layerDebug .princessLayer{outline:2px dashed rgba(217,81,154,.72);outline-offset:-3px}.partDebugBox{position:absolute;top:var(--debug-y);left:var(--debug-x);z-index:14;width:var(--debug-width);height:var(--debug-height);border:2px solid rgba(132,220,100,.95);border-radius:8px;pointer-events:none;transform:translate(var(--offset-x, 0),var(--offset-y, 0)) rotate(var(--layer-rotation, 0deg)) scale(var(--layer-scale, 1));transform-origin:50% 50%}.debugGuide,.guideLabel{position:absolute;z-index:13;pointer-events:none}.centerGuide{top:0;bottom:0;left:50%;border-left:2px dashed rgba(0,153,255,.82);transform:translate(-1px)}.shoulderGuide{top:43%;right:0;left:0;border-top:2px dashed rgba(255,63,150,.82)}.guideLabel{padding:3px 7px;border-radius:999px;background:#ffffffe6;font-size:.68rem;font-weight:900}.centerGuideLabel{top:8px;left:calc(50% + 6px);color:#0078c8}.shoulderGuideLabel{top:calc(43% + 5px);right:8px;color:#d9519a}.layerDebugLabel{position:absolute;left:8px;z-index:12;max-width:calc(100% - 16px);padding:3px 7px;border-radius:999px;background:#ffffffe0;color:#8b3369;font-size:.7rem;font-weight:900;pointer-events:none}.backgroundLayer+.layerDebugLabel{top:8px}.baseDebugLabel{top:30px}.dressLayer+.layerDebugLabel{top:52px}.accessoryLayer+.layerDebugLabel{top:74px}.shoesLayer+.layerDebugLabel{top:96px}.bagLayer+.layerDebugLabel{top:118px}.magicLayer+.layerDebugLabel{top:140px}.petLayer+.layerDebugLabel{top:162px}.princessMessage{margin-top:10px;color:#d9519a;text-align:center;font-size:1.1rem;font-weight:900}.shop,.myPrincess{display:grid;gap:16px}.princessPreviewDock{display:grid;justify-items:center}.closetPanel{width:100%;padding:14px;border:3px solid #fff;border-radius:26px;background:#ffffff9e}.closetTabs{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;scrollbar-width:none}.closetTabs::-webkit-scrollbar{display:none}.closetTab{flex:0 0 auto;min-height:48px;padding:9px 14px;border-radius:999px;background:#fff;box-shadow:0 4px #e7c8df;color:#7c4b76;font-weight:900}.activeClosetTab{background:#fff8c9;box-shadow:0 4px #e6cf74;color:#8b3369}.shopSection,.closetSection{width:100%;padding:14px;border:3px solid #fff;border-radius:26px;background:#ffffff9e}.shopGrid,.closetGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-top:12px}.shopItem,.closetItem{display:grid;min-height:166px;align-content:center;justify-items:center;gap:7px;padding:12px 8px;border-radius:18px;background:#fff;box-shadow:0 5px #ffd1e9;text-align:center}.shopItem.purchased,.closetItem.activeCloset{background:#fff8c9;color:#8c4c79;outline:4px solid #ff9ccd}.shopIcon,.closetItem img{width:86px;height:86px;object-fit:contain;border-radius:18px;background:#fff6fb}.shopItem strong,.closetItem strong{font-size:.92rem}.closetItem span{padding:3px 8px;border-radius:999px;background:#ffbde0;color:#7c2f61;font-size:.78rem;font-weight:900}.shopItem small{font-size:.85rem;font-weight:800}.shopItem p,.emptyCloset,.modalText{color:#d9519a;font-size:.95rem;font-weight:900}.buyButton,.wearButton{width:100%;min-height:46px;border-radius:999px;background:#ffbde0;box-shadow:0 4px #d9519a;color:#7c2f61;font-weight:900}.buyButton:disabled{background:#efedf0;box-shadow:0 4px #cac2cc;color:#9c96a0}.wearButton{background:#dff7ff;box-shadow:0 4px #9fd9e8}.wearButton.wearing{background:#fff8c9;box-shadow:0 4px #e6cf74}.lesson,.parent,.debugPanel{display:grid;gap:16px}.levelRow{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.level{min-height:54px;border-radius:18px;background:#fff;box-shadow:0 5px #e7c8df;font-size:1.35rem;font-weight:900}.level.active{background:#ffbde0;color:#8b3369}.questionBox{display:grid;min-height:154px;align-content:center;gap:8px;padding:18px;border:4px solid #fff;border-radius:28px;background:#fff;box-shadow:0 8px #ffd1e9;text-align:center}.prompt{white-space:pre-line;font-size:clamp(1.65rem,8vw,2.65rem);font-weight:900;line-height:1.25}.detail,.message{font-size:1.15rem;font-weight:800}.message{color:#d9519a}.answers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.answerButton{display:grid;min-height:116px;place-items:center;border:4px solid #fff;border-radius:28px;background:#fff8c9;box-shadow:0 8px #d9519a33;font-size:3.2rem;font-weight:900}.answerButton:active,.menuButton:active,.level:active,.smallButton:active,.parentLink:active{transform:translateY(4px);box-shadow:0 3px #d9519a2e}.clock{width:min(100%,136px);aspect-ratio:1}.clockFace{fill:#fff;stroke:#ffbde0;stroke-width:6}.clock text{fill:#7b557a;font-size:12px;font-weight:900;text-anchor:middle}.hourHand,.minuteHand{stroke:#7b557a;stroke-linecap:round}.hourHand{stroke-width:7}.minuteHand{stroke-width:4}.parent{padding-top:12px}.parentTotal,.statRow{border:3px solid #fff;border-radius:22px;background:#fff;box-shadow:0 6px #ffd1e9}.parentTotal{padding:20px;text-align:center;font-size:1.6rem;font-weight:900}.statRow{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:18px;font-size:1.25rem}.statRow span,.statRow strong{font-weight:900}.statRow strong{color:#d9519a;font-size:1.55rem}.statRow small{color:#887386;font-weight:800}.modalShade{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:20px;background:#36233885}.rewardModal{display:grid;width:min(100%,360px);justify-items:center;gap:12px;padding:28px 20px 22px;border:5px solid #fff;border-radius:30px;background:linear-gradient(180deg,#fff,#ffe3f3);box-shadow:0 16px #d9519a52;text-align:center;animation:popIn .32s ease-out both}.bigSparkles{color:#d9519a;font-size:2rem;animation:twinkle .8s ease-in-out infinite alternate}.bigRewardImage{width:126px;height:126px;border-radius:50%;background:#fff8c9;box-shadow:0 0 0 8px #fff,0 8px #ffbde0;object-fit:contain;padding:8px}.closeButton{min-width:160px;min-height:58px;border-radius:999px;background:#ffbde0;box-shadow:0 6px #d9519a;color:#7c2f61;font-size:1.35rem;font-weight:900}.closeButton.pale{background:#fff;box-shadow:0 6px #e7c8df;color:#7b557a}.modalActions{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.debugCard{display:grid;gap:12px;padding:16px;border:3px solid #fff;border-radius:22px;background:#ffffffc7;box-shadow:0 6px #ffd1e9}.debugCard dl{display:grid;gap:10px;margin:0}.debugCard dl div{display:grid;gap:4px}.debugCard dt{color:#d9519a;font-weight:900}.debugCard dd{margin:0;overflow-wrap:anywhere;font-weight:800}.debugCard pre{max-height:280px;margin:0;padding:12px;overflow:auto;border-radius:14px;background:#fff6fb;color:#5f4260;white-space:pre-wrap;overflow-wrap:anywhere;font-size:.82rem}.debugError{color:#b32968;font-weight:900}.debugHelp{color:#7b557a;font-weight:800}.adminButtons{display:grid;gap:10px}.adminButtons button{min-height:54px;border-radius:18px;background:#dff7ff;box-shadow:0 5px #9fd9e8;font-weight:900}.adminButtons .dangerButton{background:#ffd8ef;box-shadow:0 5px #d9519a}.adjustPanel{position:sticky;bottom:max(12px,env(safe-area-inset-bottom));z-index:20;display:grid;gap:12px;margin-top:16px;padding:14px;border:4px solid #fff;border-radius:24px;background:#fff6fbf5;box-shadow:0 8px #d9519a3d}.adjustHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#d9519a;font-size:1.1rem}.adjustHeader button{min-width:96px;min-height:46px;border-radius:999px;background:#ffbde0;box-shadow:0 4px #d9519a;color:#7c2f61;font-weight:900}.adjustEmpty{color:#7b557a;font-weight:900}.adjustParts{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.adjustPart{flex:0 0 auto;min-height:42px;padding:8px 14px;border-radius:999px;background:#fff;box-shadow:0 4px #e7c8df;font-weight:900}.adjustPart.activePart{background:#fff8c9;color:#8b3369;box-shadow:0 4px #e6cf74}.adjustValues{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0}.adjustValues div{display:grid;justify-items:center;gap:2px;padding:8px;border-radius:14px;background:#fff}.adjustValues dt{color:#d9519a;font-size:.8rem;font-weight:900}.adjustValues dd{margin:0;font-size:1.1rem;font-weight:900}.adjustControls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));justify-content:center;gap:8px}.scaleControls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:10px;font-weight:900}.holdButton{width:100%;min-height:54px;padding:8px 10px;border-radius:18px;background:#dff7ff;box-shadow:0 5px #9fd9e8;color:#5f4260;font-size:.95rem;font-weight:900;-webkit-user-select:none;user-select:none}@keyframes popIn{0%{opacity:0;transform:scale(.82) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes twinkle{0%{opacity:.55;transform:scale(.96)}to{opacity:1;transform:scale(1.05)}}@media(min-width:768px)and (max-width:1366px){body{font-size:18px}.app{width:min(100%,1080px);padding:max(24px,env(safe-area-inset-top)) 24px max(28px,env(safe-area-inset-bottom))}.topBar{min-height:68px;gap:16px}.stars{padding:14px 24px;font-size:1.85rem;box-shadow:0 7px #ffd1e9}.smallButton,.parentLink,.mamaButton,.adjustModeButton{min-height:56px;padding:14px 22px;font-size:1.05rem}.home{width:min(100%,720px);gap:22px;padding-top:16px}h1{font-size:clamp(2.6rem,5vw,4rem)}h2{font-size:2.35rem}.menuGrid{gap:18px}.menuButton{min-height:112px;border-radius:32px;font-size:clamp(2rem,4vw,2.7rem);box-shadow:0 10px #d9519a38}.princessPanel{max-width:680px;padding:20px;border-radius:32px}.princessStage{border-radius:28px}.princessMessage{font-size:1.3rem}.shop,.myPrincess,.lesson,.parent,.debugPanel{gap:20px}.myPrincess .princessPanel{max-width:760px}.closetPanel,.shopSection,.closetSection{padding:20px;border-radius:30px}.closetTabs{gap:12px;padding-bottom:16px}.closetTab{min-height:58px;padding:12px 20px;font-size:1.08rem}.closetGrid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.shopGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.shopItem,.closetItem{min-height:220px;gap:10px;padding:18px 12px;border-radius:24px}.shopIcon,.closetItem img{width:118px;height:118px;border-radius:22px}.shopItem strong,.closetItem strong{font-size:1.08rem}.shopItem small{font-size:1rem}.shopItem p,.emptyCloset,.modalText{font-size:1.08rem;line-height:1.35}.buyButton,.wearButton{min-height:58px;font-size:1.08rem}.levelRow{gap:14px}.level{min-height:64px;font-size:1.55rem}.questionBox{min-height:190px;padding:24px}.prompt{font-size:clamp(2.2rem,5vw,3.4rem)}.detail,.message{font-size:1.3rem}.answers{gap:18px}.answerButton{min-height:150px;font-size:3.8rem}.clock{width:min(100%,170px)}.parentTotal{padding:24px;font-size:1.9rem}.statRow{padding:22px;font-size:1.4rem}.closeButton{min-width:190px;min-height:66px;font-size:1.5rem}.adjustPanel{padding:18px;border-radius:28px}.adjustPart{min-height:52px;padding:10px 18px}.holdButton{min-height:62px;font-size:1.05rem}}@media(max-width:380px){.app{padding-inline:12px}.rewardGrid,.shopGrid{grid-template-columns:1fr}.closetGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.adjustValues{grid-template-columns:repeat(2,1fr)}.answerButton{min-height:104px}.princessStage{aspect-ratio:1 / 1}}
