.homePage{display:grid;gap:14px}.homeHeroCard,.homeInfoCard{border:1px solid #e9e9e9;border-radius:26px;background:#fffffff0;box-shadow:0 14px 32px #00000012}.homeHeroCard{padding:22px 18px 18px;background:linear-gradient(180deg,#fffffffa,#f9f9f9f5)}.homeHeroBadge{display:inline-flex;align-items:center;min-height:30px;padding:0 12px;border-radius:999px;background:#111;color:#fff;font-size:12px;font-weight:900;width:fit-content}.homeHeroTitle{margin:14px 0 0;font-size:32px;line-height:1.08;letter-spacing:-.05em}.homeHeroText{margin:12px 0 0;color:#444;font-size:15px;line-height:1.55}.homeHeroActions{margin-top:18px;display:grid;gap:8px}.homePrimaryBtn,.homeSecondaryBtn{width:100%;min-height:50px;border-radius:16px;font-weight:900;font-size:15px;display:inline-flex;align-items:center;justify-content:center}.homePrimaryBtn{border:none;background:#111;color:#fff}.homeSecondaryBtn{border:1px solid #e0e0e0;background:#fff;color:#111}.homeInfoCard{padding:18px}.homeInfoHead{display:grid;gap:2px;margin-bottom:12px}.homeInfoTitle{font-size:18px;font-weight:900;letter-spacing:-.03em}.homeInfoSub{font-size:13px;color:#666;font-weight:700}.homeMiniGrid{display:grid;gap:10px}.homeMiniCard{border:1px solid #ededed;border-radius:18px;background:#fff;padding:14px}.homeMiniLabel{font-size:12px;color:#777;font-weight:800}.homeMiniValue{margin-top:6px;font-size:15px;font-weight:900;word-break:break-all}.homeFeatureList{display:grid;gap:12px}.homeFeatureItem{display:grid;grid-template-columns:44px 1fr;gap:12px;align-items:start;padding:12px;border:1px solid #efefef;border-radius:18px;background:#fff}.homeFeatureIcon{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;font-size:20px}.homeFeatureTitle{font-size:15px;font-weight:900;letter-spacing:-.02em}.homeFeatureText{margin-top:4px;font-size:13px;color:#666;line-height:1.45}.loginPage{display:grid;gap:14px}.loginCard,.loginBottomCard{border:1px solid #e9e9e9;border-radius:26px;background:#fffffff2;box-shadow:0 14px 32px #00000012}.loginCard{padding:22px 18px 18px}.loginBottomCard{padding:16px}.loginHead{display:grid;gap:8px}.loginEyebrow{font-size:12px;font-weight:900;letter-spacing:.08em;color:#6b6b6b}.loginTitle{margin:0;font-size:30px;line-height:1.06;letter-spacing:-.05em}.loginText{margin:0;font-size:14px;color:#555;line-height:1.5}.loginForm{margin-top:16px;display:grid;gap:12px}.loginLabel{display:grid;gap:6px;font-size:14px;font-weight:800}.loginInput{width:100%;min-width:0;height:48px;border:1px solid #dfdfdf;border-radius:16px;background:#fff;padding:0 14px;font-size:15px;outline:none}.loginInput:focus{border-color:#111;box-shadow:0 0 0 3px #11111114}.loginPasswordWrap>div{width:100%}.loginPasswordWrap input{width:100%;min-width:0;height:48px;border:1px solid #dfdfdf;border-radius:16px;background:#fff;padding:0 14px;font-size:15px;outline:none}.loginPasswordWrap input:focus{border-color:#111;box-shadow:0 0 0 3px #11111114}.loginError{color:#dc143c;font-size:14px;font-weight:800}.loginPrimaryBtn,.loginSecondaryBtn{width:100%;min-height:50px;border-radius:16px;font-size:15px;font-weight:900;display:inline-flex;align-items:center;justify-content:center}.loginPrimaryBtn{border:none;background:#111;color:#fff}.loginPrimaryBtn:disabled{opacity:.5}.loginBottomTitle{font-size:14px;font-weight:800;color:#666;margin-bottom:10px}.loginSecondaryBtn{border:1px solid #e0e0e0;background:#fff;color:#111}.signupPage{display:grid;gap:14px}.signupCard,.signupBottomCard{border:1px solid #e9e9e9;border-radius:26px;background:#fffffff2;box-shadow:0 14px 32px #00000012}.signupCard{padding:22px 18px 18px}.signupBottomCard{padding:16px}.signupHead{display:grid;gap:8px}.signupEyebrow{font-size:12px;font-weight:900;letter-spacing:.08em;color:#6b6b6b}.signupTitle{margin:0;font-size:30px;line-height:1.06;letter-spacing:-.05em}.signupText{margin:0;font-size:14px;color:#555;line-height:1.5}.signupForm{margin-top:16px;display:grid;gap:12px}.signupLabel{display:grid;gap:6px;font-size:14px;font-weight:800}.signupInput{width:100%;min-width:0;height:48px;border:1px solid #dfdfdf;border-radius:16px;background:#fff;padding:0 14px;font-size:15px;outline:none}.signupInput:focus{border-color:#111;box-shadow:0 0 0 3px #11111114}.signupPasswordWrap>div{width:100%}.signupPasswordWrap input{width:100%;min-width:0;height:48px;border:1px solid #dfdfdf;border-radius:16px;background:#fff;padding:0 14px;font-size:15px;outline:none}.signupPasswordWrap input:focus{border-color:#111;box-shadow:0 0 0 3px #11111114}.signupError{color:#dc143c;font-size:14px;font-weight:800}.signupPrimaryBtn,.signupSecondaryBtn{width:100%;min-height:50px;border-radius:16px;font-size:15px;font-weight:900;display:inline-flex;align-items:center;justify-content:center}.signupPrimaryBtn{border:none;background:#111;color:#fff}.signupPrimaryBtn:disabled{opacity:.5}.signupBottomTitle{font-size:14px;font-weight:800;color:#666;margin-bottom:10px}.signupSecondaryBtn{border:1px solid #e0e0e0;background:#fff;color:#111}.newGamePage{height:calc(100vh - 120px);display:flex;flex-direction:column;gap:12px;position:relative}.newGameTopBar{display:flex;justify-content:space-between;align-items:center;gap:10px}.newGameTopBtn{width:44px;height:44px;border-radius:14px;border:1px solid #e8e8e8;background:#fff;font-size:18px;font-weight:800;box-shadow:0 4px 14px #0000000f}.newGameTopTitle{font-weight:900;font-size:18px;letter-spacing:-.02em}.newGameTopSpacer{width:44px}.newGameBody{flex:1;overflow-y:auto;border:1px solid #ececec;border-radius:22px;padding:16px;background:linear-gradient(180deg,#fff,#fafafa);box-shadow:0 12px 28px #0000000f;-ms-overflow-style:none;scrollbar-width:none;min-width:0;transition:box-shadow .18s ease}.newGameBody::-webkit-scrollbar{display:none}.newGameSectionTitle{font-weight:900;font-size:20px;margin-bottom:12px;letter-spacing:-.02em}.newGameFormGrid{display:grid;gap:12px;width:100%;max-width:520px;min-width:0}.newGameLabel{display:grid;gap:6px;font-size:14px;font-weight:700;width:100%;min-width:0}.newGameInput{width:100%;min-width:0;box-sizing:border-box;height:46px;border:1px solid #dfdfdf;border-radius:14px;padding:0 14px;font-size:15px;background:#fff;outline:none}.newGameInput:focus{border-color:#111;box-shadow:0 0 0 3px #11111114}.newGameHeaderCard{border:1px solid #ececec;border-radius:20px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;background:#fff;box-shadow:0 10px 24px #0000000f}.newGameHeaderLeft{display:grid;gap:6px;min-width:0}.newGameHeaderTitle{font-weight:900;font-size:20px;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.newGameHeaderDate{font-size:13px;opacity:.72;font-weight:600}.newGameHeaderRight{text-align:right;flex-shrink:0}.newGameHeaderScoreLabel{font-size:12px;opacity:.65;font-weight:700}.newGameHeaderScore{font-size:32px;font-weight:900;letter-spacing:-.03em}.newGameError{margin-top:10px;color:#dc143c;font-size:14px;font-weight:700}.newGameFrames{margin-top:8px;display:grid;gap:10px}.newGameFrameRow{display:grid;grid-template-columns:1fr 1fr;gap:9px}.newGameBottomBar{position:sticky;bottom:0;background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid #e9e9e9;border-radius:20px;padding:10px;box-shadow:0 12px 28px #00000014}.newGamePrimaryBtn,.newGameSecondaryBtn{width:100%;height:48px;border-radius:14px;font-weight:900;font-size:15px}.newGamePrimaryBtn{border:none;background:#111;color:#fff}.newGamePrimaryBtn:disabled{opacity:.5}.newGameSecondaryBtn{border:1px solid #dcdcdc;background:#fff;color:#111}.newGameBottomGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.frameCard{border:1px solid #ececec;border-radius:18px;padding:12px;-webkit-user-select:none;user-select:none;position:relative;background:#fff;box-shadow:0 6px 18px #0000000d}.frameCardNext{border:2px solid #111;box-shadow:0 10px 22px #1111111f}.frameCardHead{display:flex;justify-content:space-between;align-items:baseline}.frameCardTitle{font-weight:900;font-size:15px}.frameCardScore{font-size:13px;opacity:.72;font-weight:800;min-width:24px;text-align:right}.frameCardBoxes{margin-top:10px;display:flex;gap:8px}.rollBox{width:38px;height:38px;border-radius:12px;border:1px solid #dcdcdc;display:flex;align-items:center;justify-content:center;font-weight:900;background:#fff;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.rollBox:hover{transform:translateY(-1px);box-shadow:0 6px 14px #00000014}.rollBoxSelected{border:2px solid #333}.rollBoxNext{border:3px solid #111;box-shadow:0 6px 16px #1111111f}.bottomSheetBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:1000}.bottomSheet{position:fixed;left:0;right:0;bottom:0;z-index:1001;background:#fff;border-top-left-radius:22px;border-top-right-radius:22px;padding:14px;border-top:1px solid #e7e7e7;box-shadow:0 -14px 34px #0000001f}.bottomSheetHandle{width:42px;height:5px;border-radius:999px;background:#d8d8d8;margin:0 auto 10px}.bottomSheetHead{display:flex;justify-content:space-between;align-items:center;gap:10px}.bottomSheetTitleWrap{display:grid;gap:2px}.bottomSheetTitle{font-weight:900;font-size:16px}.bottomSheetSubtitle{font-size:12px;opacity:.7}.bottomSheetCloseBtn{padding:8px 12px;border-radius:12px;border:1px solid #e3e3e3;background:#fff;font-weight:700}.bottomSheetBody{margin-top:12px}.bottomSheetGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.bottomSheetKeyBtn{height:56px;border-radius:16px;font-weight:900;font-size:18px;border:1px solid #e2e2e2;background:#fff;box-shadow:0 4px 12px #0000000a}.bottomSheetKeyBtn:active{transform:scale(.98)}.bottomSheetKeyBtnSpecial{background:#111;color:#fff;border-color:#111}@media (max-width: 420px){.newGameFrameRow{gap:8px}.frameCard{padding:10px}.rollBox{width:34px;height:34px}.bottomSheetKeyBtn{height:52px;font-size:17px}}.bottomSheetKeyBtn:disabled{box-shadow:none;transform:none}.bottomSheetKeyBtnSpecial:disabled{background:#f3f3f3;color:#999;border-color:#e2e2e2}.newGameFramesWrap{display:grid;gap:0}.newGameScrollSpacer{height:0;flex-shrink:0;transition:height .22s ease}.newGameScrollSpacerOpen{height:320px}.frameCardActive{transform:translateY(-2px) scale(1.01);border:2px solid #111;box-shadow:0 14px 28px #11111124,0 4px 10px #11111114;background:linear-gradient(180deg,#fff,#fcfcfc)}.frameCardDim{opacity:.82;transform:scale(.995)}.frameCard{transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease,border-color .18s ease,background .18s ease}.rollBox{transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease}.rollBoxNext{border:3px solid #111;box-shadow:0 8px 18px #11111124,inset 0 0 0 1px #fff6;background:#fff}.rollBoxSelected{border:2px solid #333;background:#f7f7f7}.newGameHeaderCard{position:sticky;top:0;z-index:2}.newGameTopBarWrap{display:grid;gap:10px}.newGameTopMetaCard{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border:1px solid #e9e9e9;border-radius:20px;background:#fffffff5;box-shadow:0 10px 24px #0000000f}.newGameTopMetaLeft{min-width:0;display:grid;gap:4px}.newGameTopMetaName{font-size:18px;font-weight:900;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.newGameTopMetaDate{font-size:13px;color:#666;font-weight:700}.newGameTopMetaRight{flex-shrink:0;text-align:right}.newGameTopMetaScoreLabel{font-size:11px;color:#777;font-weight:800}.newGameTopMetaScore{font-size:30px;font-weight:900;letter-spacing:-.04em;line-height:1}.newGameInfoCard{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:20px;border:1px solid #e9e9e9;background:#fffffff2;box-shadow:0 10px 24px #0000000f}.newGameInfoLeft{display:grid;gap:3px}.newGameInfoName{font-size:18px;font-weight:900}.newGameInfoDate{font-size:13px;color:#666;font-weight:700}.newGameInfoRight{text-align:right}.newGameInfoScoreLabel{font-size:11px;color:#777}.newGameInfoScore{font-size:30px;font-weight:900}.pickerHeaderCard{display:grid;gap:8px}.pickerHeaderTop{display:flex;justify-content:space-between;align-items:center;gap:12px}.pickerHeaderFrame{font-size:16px;font-weight:900}.pickerHeaderTarget{font-size:13px;color:#666;font-weight:800}.pickerHeaderBoxes{display:flex;gap:8px}:root{color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:radial-gradient(circle at top,#f8f8f8,#f4f4f4 35%,#efefef);color:#111;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input{font:inherit}.appShell{min-height:100vh;padding:14px}.appShellInner{width:100%;max-width:560px;margin:0 auto;min-height:calc(100vh - 28px);display:flex;flex-direction:column;gap:14px}.appTopBar{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:64px 1fr 64px;align-items:center;min-height:64px;padding:10px 12px;border-radius:22px;border:1px solid rgba(230,230,230,.9);background:#ffffffe6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 10px 28px #0000000f}.appTopBarSide{display:flex;align-items:center}.appTopBarRight{justify-content:flex-end}.appTopBarCenter{min-width:0;display:grid;justify-items:center;gap:2px}.appTopBarSpacer{width:40px;height:40px}.appBrand{font-size:12px;font-weight:900;opacity:.58;letter-spacing:.08em;text-transform:uppercase}.appPageTitle{font-size:18px;font-weight:900;letter-spacing:-.03em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appIconBtn{width:40px;height:40px;border:1px solid #e3e3e3;border-radius:14px;background:#fff;box-shadow:0 4px 14px #0000000d;font-size:18px;font-weight:900}.appGhostBtn,.appGhostBtnLink{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 10px;border:1px solid #e3e3e3;border-radius:14px;background:#fff;box-shadow:0 4px 14px #0000000d;font-size:12px;font-weight:800;white-space:nowrap}.appContent{flex:1;min-height:0}
