:root{--cream:#f7f3ec;--cream-2:#f1e9dd;--cream-3:#e8dacb;--paper:#fffdf8;--ink:#2d2a26;--ink-2:#7a7167;--ink-3:#9a9085;--line:#e7dccf;--line-2:#d9c8b8;--peach:#e09a78;--peach-deep:#d66a3a;--peach-soft:#f1d8cb;--mint:#dce9dd;--mint-deep:#4f8f6b;--blush:#f0d8d6;--lavender:#e8dacb;--coral-deep:#c85c5c;--pink:#f0d8d6;--pink-deep:#c85c5c;--yellow:#e9d9b8;--yellow-deep:#9f7337;--sky:#e8dacb;--sky-deep:#7a7167;--lav:#e8dacb;--lav-deep:#7a7167;--success:#4f8f6b;--warning:#b9853f;--danger:#c85c5c;--r-xs:8px;--r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:22px;--r-pill:999px;--sh-sm:0 1px 2px #4634260a;--sh-md:0 2px 8px #4634260f;--sh-lg:0 4px 18px #46342614;--sh-inset:none;--gap:20px;--pad:24px;--page-pad-x:36px;--page-pad-y:30px}@media (max-width:99999px){:root{--page-pad-x:16px;--page-pad-y:18px;--pad:18px;--gap:14px}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--cream);color:var(--ink);-webkit-font-smoothing:antialiased;letter-spacing:-.01em;font-family:Pretendard,-apple-system,sans-serif;font-size:15px;line-height:1.55}@media (max-width:99999px){body{font-size:14px}}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}a{color:inherit;text-decoration:none}input,textarea,select{color:inherit;font-family:inherit}.app-bg{background:var(--cream);min-height:100vh}.display{letter-spacing:-.015em;font-family:Jua,sans-serif}.mono-num{font-variant-numeric:tabular-nums}.cheer-text,.handwritten{letter-spacing:-.005em;font-family:Pretendard,sans-serif;font-weight:600;line-height:1.55}.kpi-label{color:var(--ink-3);letter-spacing:0;font-size:13px;font-weight:700}.sublabel{color:var(--ink-3);font-size:13px;font-weight:600;line-height:1.5}.meta{color:var(--ink-3);font-size:12px;font-weight:600}.kpi-value{color:var(--ink);letter-spacing:-.02em;white-space:nowrap;margin-top:4px;font-family:Jua,sans-serif;font-size:32px;line-height:1.05}.kpi-value .unit{color:var(--ink-3);margin-left:2px;font-size:16px}@media (max-width:99999px){.kpi-value{font-size:26px}.kpi-value .unit{font-size:13px}}.row{align-items:center;display:flex}.col{flex-direction:column;display:flex}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.gap-24{gap:24px}.grow{flex:1}.muted{color:var(--ink-3)}.soft{color:var(--ink-2)}.center{justify-content:center;align-items:center;display:flex}.between{justify-content:space-between}.hr-dashed{border:none;border-top:1.5px dashed var(--line-2);height:0;margin:14px 0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--line-2);border:2px solid var(--cream);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#c6b098}body[data-density=loose]{--pad:28px;--gap:24px}body[data-density=compact]{--pad:18px;--gap:14px}body[data-radius=sharp]{--r-lg:18px;--r-md:14px;--r-xl:22px}body[data-radius=round]{--r-lg:36px;--r-md:26px;--r-xl:44px}.show-mobile{display:none}.hide-mobile{display:initial}@media (max-width:99999px){.show-mobile{display:initial}.hide-mobile{display:none!important}}
.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;display:flex}.page-header-text{flex:1;min-width:0}.page-header-sub{color:var(--ink-3);letter-spacing:.3px;margin-bottom:4px;font-size:13px;font-weight:700}.page-header-title{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;margin:0;font-family:Jua,sans-serif;font-size:32px;font-weight:400;overflow:hidden}.page-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}@media (max-width:99999px){.page-header-title{font-size:24px}.page-header{gap:10px}}.card,.card-soft,.card-tinted{transition:transform .2s,box-shadow .2s}.card.hover-lift:hover,.card-soft.hover-lift:hover{box-shadow:var(--sh-md);border-color:var(--line-2);transform:translateY(-1px)}@media (hover:none){.card.hover-lift:hover,.card-soft.hover-lift:hover{transform:none}}.card{background:var(--paper);border-radius:var(--r-lg);padding:var(--pad);box-shadow:var(--sh-sm);border:1px solid var(--line);position:relative}.card-soft{background:var(--paper);border-radius:var(--r-lg);padding:var(--pad);border:1px solid var(--line);box-shadow:var(--sh-sm)}.card-tinted{border-radius:var(--r-lg);padding:var(--pad);box-shadow:var(--sh-sm);border:1.5px solid #0000000a}.chip{border-radius:var(--r-pill);background:var(--cream-2);color:var(--ink-2);border:1.5px solid var(--line-2);white-space:nowrap;align-items:center;gap:6px;padding:5px 12px;font-size:12.5px;font-weight:700;display:inline-flex}.chip.peach,.chip.pink{color:#9e4625;background:#f1d8cb;border-color:#e5b9a2}.chip.mint{color:#4f8f6b;background:#e5eee5;border-color:#c8dccb}.chip.yellow,.chip.sky,.chip.lav,.chip.gray{color:#7a6546;background:#ede4d6;border-color:#d8c8b2}.btn{border-radius:var(--r-sm);box-shadow:none;border:1px solid #0000;align-items:center;gap:8px;min-height:44px;padding:10px 18px;font-size:14px;font-weight:700;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn:hover,.btn:active{transform:none}.btn-primary{background:var(--peach-deep);color:#fff}.btn-primary:hover{background:#c85c32}.btn-ghost{background:var(--paper);color:var(--ink);border-color:var(--line-2)}.btn-ghost:hover{background:var(--cream-2)}.btn-mint{background:var(--mint-deep);color:#fff}.btn-sky{background:var(--paper);color:var(--ink);border-color:var(--line-2)}.progress{background:var(--cream-2);border-radius:var(--r-pill);border:1px solid var(--line);height:8px;position:relative;overflow:hidden}.progress-fill{border-radius:var(--r-pill);background:var(--peach-deep);height:100%;transition:width .6s cubic-bezier(.22,1,.36,1);position:relative}.progress-fill.mint{background:var(--mint-deep)}.progress.progress-thin{height:6px}.progress-fill.yellow,.progress-fill.sky,.progress-fill.lav{background:var(--peach-deep)}.sticker{background:var(--yellow);width:52px;height:52px;color:var(--ink);border:3px solid var(--paper);border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:inline-flex;transform:rotate(-8deg);box-shadow:0 2px #af825f2e,0 6px 16px #af825f2e}.avatar{background:var(--cream-2);border:2px solid var(--paper);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:inline-flex;box-shadow:0 2px #af825f1a}.avatar.lg{width:58px;height:58px;font-size:28px}.avatar.sm{width:32px;height:32px;font-size:16px}.profile-avatar{position:relative;overflow:visible}.profile-avatar-img{object-fit:cover;border-radius:inherit;width:100%;height:100%;display:block}.profile-avatar-online{border:2px solid var(--paper);background:#2bb673;border-radius:50%;width:10px;height:10px;position:absolute;bottom:-1px;right:-1px;box-shadow:0 0 0 1px #2bb67347}.profile-avatar-online.offline{background:#b8b1a8;box-shadow:0 0 0 1px #5b4e402e}.profile-uploader{flex-shrink:0;position:relative}.profile-uploader-trigger{appearance:none;cursor:pointer;background:0 0;border:0;padding:0;display:block;position:relative}.profile-uploader-edit{background:var(--ink);color:#fff;white-space:nowrap;border-radius:7px;padding:3px 6px;font-size:9.5px;font-weight:800;line-height:1.3;position:absolute;bottom:-4px;right:-4px}.profile-uploader-input{display:none}.profile-cropper-backdrop{z-index:200;background:#221c176b;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.profile-cropper{border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);width:min(100%,380px);box-shadow:var(--sh-lg);padding:18px}.profile-cropper-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.profile-cropper-head h3{margin:0 0 4px;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.profile-cropper-head p{color:var(--ink-3);margin:0;font-size:12px;font-weight:700;line-height:1.45}.profile-cropper-close{background:var(--cream-2);border-radius:var(--r-pill);color:var(--ink-2);cursor:pointer;border:0;padding:6px 10px;font-size:12px;font-weight:800}.profile-cropper-canvas{background:linear-gradient(90deg, #ffffff59 1px, transparent 1px), linear-gradient(#ffffff59 1px, transparent 1px), var(--cream-3);border:1px solid var(--line);cursor:grab;touch-action:none;background-size:33.333% 33.333%;border-radius:18px;width:280px;max-width:100%;height:280px;margin:0 auto;display:block}.profile-cropper-canvas:active{cursor:grabbing}.profile-cropper-zoom{color:var(--ink-3);grid-template-columns:42px 1fr;align-items:center;gap:10px;margin-top:14px;font-size:12px;font-weight:800;display:grid}.profile-cropper-zoom input{width:100%}.profile-cropper-error{color:var(--coral-deep,#c85c5c);margin-top:10px;font-size:12px;font-weight:800}.profile-cropper-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.account-password-open,.sidebar-password-btn{justify-content:center;width:100%;min-height:38px;padding:7px 12px;font-size:12.5px}.account-modal-backdrop{z-index:240;background:#221c176b;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.account-modal{border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);width:min(100%,380px);box-shadow:var(--sh-lg);padding:18px}.account-modal-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.account-modal-head h3{margin:0 0 4px;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.account-modal-head p{color:var(--ink-3);margin:0;font-size:12px;font-weight:700;line-height:1.45}.account-modal-close{background:var(--cream-2);border-radius:var(--r-pill);color:var(--ink-2);cursor:pointer;border:0;padding:6px 10px;font-size:12px;font-weight:800}.account-field{margin-top:10px;display:block}.account-field span{color:var(--ink-2);margin-bottom:6px;font-size:12px;font-weight:800;display:block}.account-field input{box-sizing:border-box;border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--cream-2);width:100%;min-height:42px;color:var(--ink);font:inherit;outline:none;padding:9px 12px}.account-field input:focus{border-color:var(--peach);background:var(--paper)}.account-modal-error,.account-modal-success{border-radius:var(--r-md);margin-top:10px;padding:8px 10px;font-size:12px;font-weight:800}.account-modal-error{background:var(--peach-soft);color:#9e4625}.account-modal-success{background:var(--mint);color:var(--mint-deep)}.account-modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.grass-cell{box-sizing:border-box;background:var(--cream-3);border:1px solid #0000;border-radius:4px;flex-shrink:0;width:14px;height:14px;transition:transform .2s}.grass-cell:hover{z-index:2;transform:scale(1.4)}.grass-cell.l1{background:#eef3ec}.grass-cell.l2{background:#c8dccb}.grass-cell.l3{background:#83b893}.grass-cell.l4{background:#4f8f6b}.grass-cell.miss{background:#f0d8d6;border:1px dashed #d99a95}.season-goal-card{background:var(--cream-2);padding:22px}.season-goal-card.compact{padding:20px}.season-goal-card--empty{border:1px dashed var(--line-2);border-radius:var(--r-lg);background:0 0;flex-direction:column;gap:8px;padding:14px 18px;display:flex}.season-goal-empty-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.season-goal-empty-link{color:var(--peach-deep);font-size:14px;font-weight:800;text-decoration:none;display:inline-block}.season-goal-empty-link:hover{text-underline-offset:3px;text-decoration:underline}.season-goal-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.season-goal-kicker{color:var(--ink-3);margin-bottom:3px;font-size:12px;font-weight:900}.season-goal-head h3{letter-spacing:-.015em;margin:0;font-family:Jua,sans-serif;font-size:20px;font-weight:400}.season-goal-editor{border:1px solid var(--line-2);border-radius:var(--r-md);background:var(--paper);padding:12px}.season-goal-editor textarea{resize:vertical;width:100%;min-height:72px;color:var(--ink);font:inherit;background:0 0;border:0;outline:none;font-size:14px;font-weight:700;line-height:1.55}.season-goal-editor textarea::placeholder{color:var(--ink-3)}.season-goal-editor-foot{justify-content:space-between;align-items:center;gap:12px;margin-top:8px;display:flex}.season-goal-editor-foot span{color:var(--ink-3);font-size:12px;font-weight:800}.season-goal-save{min-height:36px;padding:6px 14px;font-size:12.5px}.season-goal-error{color:#9e4625;margin-top:8px;font-size:12px;font-weight:800}.season-goal-list{gap:7px;margin-top:14px;display:grid}.season-goal-row{border-radius:var(--r-md);background:#fffdf8ad;border:1px solid #0000;align-items:flex-start;gap:10px;padding:9px 10px;display:flex}.season-goal-row.is-me{border-color:var(--line-2);background:var(--peach-soft)}.season-goal-avatar{background:var(--cream-2);border:1px solid var(--line);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex;overflow:hidden}.season-goal-person{flex:1;min-width:0}.season-goal-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:12.5px;font-weight:900;overflow:hidden}.season-goal-text{color:var(--ink-2);overflow-wrap:anywhere;font-size:13px;font-weight:700;line-height:1.45}.season-goal-empty{border-radius:var(--r-md);color:var(--ink-3);text-align:center;background:#fffdf8b3;padding:16px;font-size:13px;font-weight:800}.season-goal-readonly{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);gap:12px;padding:16px;display:grid}.season-goal-readonly h3{margin:0 0 8px;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.season-goal-readonly p{color:var(--ink-2);overflow-wrap:anywhere;margin:0;font-size:14px;font-weight:800;line-height:1.55}.season-goal-readonly .empty{color:var(--ink-3)}.season-goal-profile-link{border-radius:8px;justify-self:start;min-height:36px;padding:7px 14px;font-size:13px}@media (max-width:99999px){.grass-cell{width:11px;height:11px}.season-goal-card{padding:16px}.season-goal-head{align-items:flex-start}.season-goal-head h3{font-size:17px}.season-goal-editor-foot{align-items:stretch}.season-goal-save{min-width:94px}.season-goal-row{padding:8px}.season-goal-profile-link{justify-content:center;width:100%}}
.sidebar{display:none!important}.nav-icon-svg{flex-shrink:0;display:block}.mobile-topbar{background:var(--paper);border-bottom:1.5px solid var(--line);z-index:5;justify-content:space-between;align-items:center;gap:10px;padding:14px 18px;display:flex;position:sticky;top:0}.mobile-topbar-brand{align-items:center;gap:11px;min-width:0;font-family:Jua,sans-serif;display:flex}.mobile-topbar-brand-icon{background:var(--peach-soft);color:#9e4625;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 2px #af825f2e}.mobile-topbar-brand-title{font-size:16px;line-height:1}.mobile-topbar-brand-week{color:var(--ink-3);white-space:nowrap;text-overflow:ellipsis;max-width:140px;margin-top:4px;font-family:Pretendard,sans-serif;font-size:10.5px;font-weight:700;overflow:hidden}.mobile-topbar-actions{flex-shrink:0;align-items:center;gap:7px;display:flex}.mobile-account-button{appearance:none;border:1px solid var(--line);background:var(--cream-2);border-radius:var(--r-pill);min-height:38px;color:var(--ink);cursor:pointer;white-space:nowrap;align-items:center;gap:8px;padding:2px 12px 2px 4px;font-size:12px;font-weight:900;display:inline-flex}.mobile-account-button .avatar{width:30px;height:30px}.mobile-account-backdrop{z-index:180;background:#221c176b;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.mobile-account-sheet{box-sizing:border-box;width:100%;max-width:460px;padding:10px 16px calc(18px + env(safe-area-inset-bottom));background:var(--paper);border:1px solid var(--line);border-radius:22px 22px 0 0;box-shadow:0 -10px 30px #4634262e}.mobile-account-handle{border-radius:var(--r-pill);background:var(--line-2);width:42px;height:4px;margin:0 auto 14px}.mobile-account-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.mobile-account-title{align-items:center;gap:11px;min-width:0;display:flex}.mobile-account-title .avatar{width:44px;height:44px}.mobile-account-title h3{text-overflow:ellipsis;white-space:nowrap;max-width:200px;margin:0;font-family:Jua,sans-serif;font-size:18px;font-weight:400;overflow:hidden}.mobile-account-title p{color:var(--ink-3);margin:2px 0 0;font-size:12px;font-weight:800}.mobile-account-close{background:var(--cream-2);border-radius:var(--r-pill);color:var(--ink-2);cursor:pointer;border:0;padding:7px 11px;font-size:12px;font-weight:900}.mobile-account-actions{gap:9px;display:grid}.mobile-account-profile-action{border-radius:var(--r-md);background:var(--cream-2);border:1px solid var(--line);align-items:center;gap:12px;padding:12px;display:flex}.mobile-account-profile-action .profile-uploader .avatar{width:42px;height:42px}.mobile-account-profile-action .profile-uploader-edit{display:none}.mobile-account-profile-action strong{color:var(--ink);font-size:13px;font-weight:900;display:block}.mobile-account-profile-action span{color:var(--ink-3);margin-top:2px;font-size:11.5px;font-weight:800;display:block}.mobile-account-action-btn{justify-content:center;width:100%;min-height:42px}.mobile-account-logout{color:#9e4625}.mobile-tabbar{background:var(--paper);border-top:1.5px solid var(--line);z-index:5;padding:6px 4px calc(6px + env(safe-area-inset-bottom));display:flex;position:sticky;bottom:0;box-shadow:0 -4px 14px #af825f0f}.mobile-tabbar-item{border-radius:var(--r-md);color:var(--ink-3);cursor:pointer;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:56px;padding:8px 4px;font-size:10.5px;font-weight:700;display:flex;position:relative}.mobile-tabbar:has(.mobile-tabbar-item:nth-child(6)) .mobile-tabbar-item{padding-left:2px;padding-right:2px;font-size:10px}.mobile-tabbar-item .icon{color:currentColor;opacity:.9;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.mobile-tabbar-item.active{color:#9e4625}.mobile-tabbar-item.active .icon{opacity:1}.mobile-tabbar-item.active:before{content:"";background:var(--peach-deep);border-radius:999px;width:28px;height:3px;position:absolute;top:2px}@media (min-width:1280px){.mobile-tabbar-item.tab-chat{display:none}}.mobile-tabbar-item.tab-desktop-only{display:none}@media (min-width:1024px){.mobile-tabbar-item.tab-desktop-only{display:flex}}@media (max-width:720px){.mobile-tabbar{z-index:70;position:fixed;bottom:0;left:0;right:0}}.tweak-panel{background:var(--paper);border:1.5px solid var(--line);border-radius:var(--r-lg);width:280px;box-shadow:var(--sh-lg);z-index:1000;padding:18px;font-size:13px;position:fixed;bottom:20px;right:20px}@media (max-width:720px){.tweak-panel{bottom:calc(82px + env(safe-area-inset-bottom));width:auto;left:12px;right:12px}}.tweak-title{justify-content:space-between;align-items:center;margin-bottom:12px;font-family:Jua,sans-serif;font-size:16px;display:flex}.tweak-row{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.tweak-row-label{color:var(--ink-2);font-size:12.5px;font-weight:700}.tweak-buttons{flex-wrap:wrap;gap:6px;display:flex}.tweak-btn{border-radius:var(--r-pill);background:var(--cream-2);border:1.5px solid var(--line-2);color:var(--ink-2);cursor:pointer;padding:6px 10px;font-size:12px;font-weight:700}.tweak-btn.active{background:var(--peach-soft);color:#9e4625;border-color:var(--peach)}.tweak-btn:hover{background:var(--cream-3)}
@keyframes twinkle{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.twinkle{animation:2.2s ease-in-out infinite twinkle}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}.hover-wobble:hover{animation:.5s ease-in-out wobble}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.4s ease-out fadeUp}@keyframes confettiFall{0%{opacity:1;transform:translate(0)rotate(0)}to{opacity:0;transform:translate(var(--dx), var(--dy)) rotate(var(--rot))}}.confetti{pointer-events:none;width:10px;height:14px;animation:1.2s cubic-bezier(.22,1,.36,1) forwards confettiFall;position:absolute}@keyframes stampPop{0%{opacity:0;transform:scale(0)rotate(-30deg)}50%{opacity:1;transform:scale(1.3)rotate(-10deg)}to{opacity:1;transform:scale(1)rotate(-8deg)}}.stamp-pop{animation:.5s cubic-bezier(.22,1,.36,1) forwards stampPop}@keyframes slowFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.slow-float{animation:5s ease-in-out infinite slowFloat}.bg-deco{pointer-events:none;opacity:.6;position:absolute}@media (max-width:99999px){.bg-deco{display:none}}
.home-page{padding:var(--page-pad-y) var(--page-pad-x) 60px;box-sizing:border-box;max-width:1240px;position:relative}.home-grid-main{grid-template-columns:1.3fr 1fr;gap:20px;margin-bottom:20px;display:grid}.home-grid-plan,.home-grid-progress,.home-grid-bottom{gap:20px;margin-bottom:20px;display:grid}.home-grid-plan{grid-template-columns:1fr 1fr;margin-top:24px}.home-grid-progress{grid-template-columns:1fr 1.4fr}.home-grid-bottom{grid-template-columns:1.4fr 1fr;margin-bottom:0}.home-header-chips{gap:8px;margin-bottom:8px;display:flex}.home-header-date{color:var(--ink-3);letter-spacing:.3px;font-size:13px;font-weight:700}.home-season-goal-wrap{margin:-8px 0 18px}.home-daily-goal-wrap{margin-bottom:20px}.home-season-goal-note{grid-template-columns:4px minmax(0,1fr);align-items:center;gap:12px;padding:3px 0;display:grid}.home-season-goal-rail{background:var(--mint-deep);border-radius:999px;width:4px;height:34px}.home-season-goal-body{min-width:0}.home-season-goal-head{align-items:center;gap:7px;display:flex}.home-season-goal-label{color:var(--ink-3);letter-spacing:.35px;font-size:11px;font-weight:900}.home-season-goal-note p{color:var(--ink);overflow-wrap:anywhere;margin:3px 0 0;font-size:15px;font-weight:900;line-height:1.5}.home-season-goal-note.empty .home-season-goal-rail{background:var(--line-2)}.home-season-goal-note.empty p{color:var(--ink-2);font-weight:800}.home-season-goal-link{color:#4f8f6b;white-space:nowrap;border:1px solid #4f8f6b38;border-radius:999px;align-self:center;padding:1px 6px;font-size:10.5px;font-weight:900;line-height:1.5}.home-season-goal-link:hover{background:#4f8f6b14}.home-daily-goal-card{background:linear-gradient(180deg, #fff7f0c7, #ffffff6b), var(--cream-2);padding:19px 22px 18px}.daily-goal-title{align-items:center;margin-bottom:8px;display:flex}.daily-goal-title-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.daily-goal-text{color:var(--ink);overflow-wrap:anywhere;margin:0;font-size:17px;font-weight:900;line-height:1.55}.daily-goal-text:before{content:"";background:var(--peach-deep);vertical-align:-.18em;border-radius:999px;width:4px;height:1.1em;margin-right:10px;display:inline-block}.daily-goal-text-button{appearance:none;color:#7b6a59;cursor:pointer;white-space:nowrap;background:0 0;border:0;padding:4px 0;font-family:inherit;font-size:12.5px;font-weight:900;line-height:1}.daily-goal-text-button:hover{color:#9e4625}.daily-goal-text-button:disabled{cursor:not-allowed;opacity:.5}.daily-goal-text-button.danger{color:#b1644c}.daily-goal-input-row{border-bottom:1.5px solid #89705233;align-items:center;gap:10px;min-width:0;padding-bottom:8px;display:flex}.daily-goal-form{grid-template-columns:minmax(0,1fr);gap:7px;display:grid}.daily-goal-input-row input{width:100%;min-width:0;min-height:36px;color:var(--ink);background:0 0;border:0;outline:none;padding:0;font-family:inherit;font-size:15px;font-weight:800}.daily-goal-input-row input::placeholder{color:#5b4e4094}.daily-goal-save-button{appearance:none;border:1px solid var(--peach-deep);background:var(--peach-deep);color:#fff;cursor:pointer;white-space:nowrap;border-radius:999px;flex-shrink:0;min-width:58px;min-height:34px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:900}.daily-goal-save-button:disabled{color:var(--ink-3);cursor:not-allowed;background:#ffffff80;border-color:#89705233}.daily-goal-form-footer{justify-content:space-between;align-items:center;gap:10px;min-height:20px;display:flex}.daily-goal-meta{color:var(--ink-3);margin-left:auto;font-size:12px;font-weight:800}.daily-goal-error{color:#9e4625;margin-top:8px;font-size:12px;font-weight:800}.season-goal-prompt-backdrop{z-index:180;background:#221c176b;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.season-goal-prompt{border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);width:min(100%,420px);box-shadow:var(--sh-lg);padding:24px}.season-goal-prompt-mark{border-radius:var(--r-pill);background:var(--peach-soft);color:#9e4625;justify-content:center;align-items:center;margin-bottom:12px;padding:5px 10px;font-size:12px;font-weight:900;display:inline-flex}.season-goal-prompt h2{margin:0 0 8px;font-family:Jua,sans-serif;font-size:24px;font-weight:400}.season-goal-prompt p{color:var(--ink-2);margin:0;font-size:14px;font-weight:700;line-height:1.6}.season-goal-prompt-actions{justify-content:flex-end;gap:8px;margin-top:18px;display:flex}.season-goal-prompt-actions .btn{border-radius:8px}.home-season-progress{background:var(--cream-2);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;margin-bottom:20px;padding:22px 24px;display:grid;overflow:hidden}.home-season-copy h2{letter-spacing:-.025em;margin:4px 0 6px;font-family:Jua,sans-serif;font-size:31px;font-weight:400}.home-season-copy p{color:var(--ink-2);margin:0;font-size:13.5px;font-weight:700;line-height:1.65}.home-season-date-range{gap:2px;display:grid}.home-season-date-range span{white-space:nowrap;display:block}.home-season-ring-area{justify-content:flex-end;align-items:center;gap:12px;display:flex}.home-season-ring{border-radius:50%;flex-shrink:0;width:92px;height:92px;padding:8px;box-shadow:inset 0 0 0 1px #7a543c14}.home-season-ring-inner{background:var(--paper);border:1px solid #89705229;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.home-season-ring-inner strong{color:var(--ink);font-size:18px;font-weight:900}.home-season-ring-meta{min-width:72px;color:var(--ink-3);gap:3px;font-size:12.5px;font-weight:800;line-height:1.35;display:grid}.home-season-ring-meta strong{color:#4f8f6b;font-size:13px}.home-season-ring-meta em{color:var(--ink-2);font-style:normal}.home-today{padding:22px;position:relative}.home-today-top{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.home-today-kpi{margin-top:6px;font-size:42px}.home-today-gift{border:1px solid var(--line);background:#ffffff9e;border-radius:13px;flex-direction:column;flex-shrink:0;align-items:center;gap:3px;padding:5px 8px 6px;display:flex}.home-today-gift-label{color:var(--ink-3);white-space:nowrap;font-size:11px;font-weight:800}.home-gift-mini{transform-origin:bottom;width:54px;height:50px;animation:3s ease-in-out infinite gift-breathe;position:relative}.home-gift-mini:after{content:"";filter:blur(2px);background:#2d2a261f;border-radius:999px;height:8px;position:absolute;bottom:2px;left:9px;right:9px}.home-gift-mini-body{background:#d66a3a;border:1.5px solid #7a543c2e;border-radius:7px 7px 10px 10px;height:27px;position:absolute;bottom:8px;left:8px;right:8px}.home-gift-mini-lid{background:#e09a78;border:1.5px solid #7a543c2e;border-radius:9px 9px 6px 6px;height:13px;position:absolute;bottom:34px;left:5px;right:5px}.home-gift-mini-ribbon{background:#e9d9b8;width:9px;height:39px;position:absolute;bottom:8px;left:50%;transform:translate(-50%);box-shadow:inset 0 0 0 1px #9f733724}.home-gift-mini.stage-1{transform:scale(.86)}.home-gift-mini.stage-1 .home-gift-mini-ribbon{display:none}.home-gift-mini.stage-3 .home-gift-mini-body{background:#4f8f6b}.home-gift-mini.stage-3 .home-gift-mini-lid{background:#dce9dd}.home-gift-mini.stage-4 .home-gift-mini-lid{background:#b9853f;bottom:37px}.home-gift-mini.stage-4 .home-gift-mini-body{background:#d66a3a}.home-today-progress-meta{justify-content:space-between;margin-bottom:10px;font-size:13.5px;font-weight:700;display:flex}.home-today-progress-meta .label{color:var(--ink-2)}.home-today-progress-meta .pct{color:#d66a3a}.home-today-progress-meta .pct.met{color:#4f8f6b}.home-today-bar{height:14px}.home-mini-stats{grid-template-columns:1fr 1fr;gap:10px;display:grid}.home-mini-stat{border-radius:var(--r-md);border:1px solid var(--line);background:#fff9;padding:12px 13px}.home-mini-stat-label,.home-mini-stat .label{color:var(--ink-3);font-size:12px;font-weight:700}.home-mini-stat-value,.home-mini-stat .value{font-variant-numeric:tabular-nums;margin-top:2px;font-family:Jua,sans-serif;font-size:20px}.home-last-week-card{margin-top:22px}.home-plan-actions{justify-content:flex-end;margin-top:12px;display:flex}.home-plan-save{padding:6px 16px;font-size:13px}.home-plan-err{color:#9e4625;margin-top:8px;font-size:12px;font-weight:700}.home-week-card{background:var(--cream-2);padding:24px}.home-section-title{align-items:center;gap:8px;margin-bottom:14px;display:flex}.home-section-title .ico{font-size:22px}.home-section-title h3{letter-spacing:-.015em;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;margin:0;font-family:Jua,sans-serif;font-size:19px;font-weight:400;overflow:hidden}.home-section-title .chip{flex-shrink:0;margin-left:auto}.home-section-title .ico{flex-shrink:0}.home-week-title h3{color:var(--ink-2);letter-spacing:.2px;font-family:inherit;font-size:13px;font-weight:900}.home-day-row{border-bottom:1px dashed var(--line);align-items:center;gap:12px;padding:9px 0;display:flex}.home-day-row:last-child{border-bottom:none}.home-day-pill{color:#8a5b3f;background:#f0d0c0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-family:Jua,sans-serif;font-size:14px;display:flex}.home-day-pill.met{background:var(--mint-deep);color:#fff}.home-day-pill.today{background:var(--peach-deep);color:#fff}.home-day-bar{flex:1;min-width:0}.home-day-bar .progress{background:var(--paper);border:1px solid var(--line);height:8px}.home-day-time{color:var(--ink-2);text-align:right;font-variant-numeric:tabular-nums;min-width:48px;font-size:13px;font-weight:700}.home-day-status{text-align:right;justify-content:flex-end;min-width:58px;display:flex}.home-status-badge{border-radius:var(--r-pill);border:1px solid var(--line-2);background:var(--paper);min-width:48px;min-height:24px;color:var(--ink-2);white-space:nowrap;justify-content:center;align-items:center;padding:3px 8px;font-size:11.5px;font-weight:900;line-height:1;display:inline-flex}.home-status-badge.done{color:#4f8f6b;background:#eef3ec;border-color:#b9dac6}.home-status-badge.progress{color:#9e4625;background:#f6e3d8;border-color:#e5b9a2}.home-status-badge.miss{color:#9e4625;background:#f4e1d6;border-color:#f0c7bb}.home-status-badge.planned{border-color:var(--line);background:var(--cream-2);color:var(--ink-3)}.home-status-badge.review{color:#7a6546;background:#eee2d0;border-color:#d8c8b2}.home-weekend-row{background:var(--paper);border-radius:var(--r-md);border:1px dashed var(--line-2);align-items:center;gap:12px;margin-top:6px;padding:11px 12px;display:flex}.home-weekend-pills{gap:4px;display:flex}.home-weekend-pill{background:var(--cream-3);width:24px;height:24px;color:var(--ink-2);border-radius:8px;justify-content:center;align-items:center;font-family:Jua,sans-serif;font-size:11px;display:flex}.home-weekend-label{color:var(--ink-2);flex:1;font-size:13px;font-weight:700}.home-weekend-meta{min-width:112px;color:var(--ink-2);justify-content:flex-end;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.home-plan-card{background:var(--cream-2);padding:22px}.home-plan-card .home-section-title h3{font-size:17px}.home-plan-input{background:var(--paper);border-radius:var(--r-md);border:1px solid var(--line-2);align-items:center;gap:8px;padding:14px;display:flex}.home-plan-input-label{color:var(--ink-2);min-width:54px;font-size:13px;font-weight:700}.home-plan-buttons{flex:1;gap:6px;display:flex}.home-plan-btn{border-radius:var(--r-sm);border:1px solid var(--line-2);color:var(--ink-3);cursor:pointer;background:#ffffff9e;flex:1;min-height:40px;padding:10px 0;font-family:Jua,sans-serif;font-size:14px;font-weight:700;transition:background .15s,color .15s,border-color .15s}.home-plan-btn.active{background:var(--peach-deep);border-color:var(--peach-deep);color:#fff;box-shadow:0 8px 18px #d66a3a2e}.home-plan-note{color:var(--ink-2);margin-top:10px;font-size:13.5px;font-weight:600;line-height:1.55}.home-streak-card{background:var(--cream-2);padding:22px}.home-streak-card.at-risk{background:#f4e1d6}.home-streak-card .home-section-title h3{font-size:17px}.home-week-progress{text-align:center;padding:28px;position:relative;overflow:hidden}.home-week-progress h3{letter-spacing:-.015em;margin:0 0 6px;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.home-week-progress .sublabel{margin-bottom:18px}.home-week-progress-ring{width:200px;height:200px;margin:0 auto;position:relative}.home-week-progress-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.home-week-progress-pct{font-variant-numeric:tabular-nums;font-family:Jua,sans-serif;font-size:38px;line-height:1}.home-week-progress-note{color:#d66a3a;margin-top:18px;font-size:14px;font-weight:700;line-height:1.55}.home-recent-card{padding:0;overflow:hidden}.home-card-head{justify-content:space-between;align-items:center;gap:12px;padding:22px 24px 12px;display:flex}.home-card-head h3{letter-spacing:-.015em;margin:0;font-family:Jua,sans-serif;font-size:19px;font-weight:400}.home-card-head-link{min-height:36px;padding:8px 14px;font-size:13px}.home-recent-list{padding:0 8px 16px}.home-recent-row{border-radius:var(--r-md);align-items:center;gap:14px;padding:12px 16px;display:flex}.home-recent-date{border-radius:var(--r-md);background:var(--cream-2);border:1px solid var(--line-2);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.home-recent-date.met{background:var(--mint);border-color:var(--line-2)}.home-recent-date .dow{color:var(--ink-2);font-size:10px;font-weight:700}.home-recent-date.met .dow{color:#4f8f6b}.home-recent-date.miss .dow{color:#d66a3a}.home-recent-date .day{color:var(--ink);font-family:Jua,sans-serif;font-size:15px}.home-recent-date.met .day{color:#4f8f6b}.home-recent-date.miss .day{color:#d66a3a}.home-recent-body{flex:1;min-width:0}.home-recent-meta{justify-content:space-between;gap:12px;margin-bottom:4px;display:flex}.home-recent-title{font-size:14px;font-weight:700}.home-recent-min{font-variant-numeric:tabular-nums;color:var(--ink-2);font-weight:700}.home-recent-min.met{color:#4f8f6b}.home-recent-icon{font-size:14px}.home-rank-list{padding:0 16px 16px}.home-rank-row{border-radius:var(--r-md);border:1px solid #0000;align-items:center;gap:14px;margin-bottom:4px;padding:10px 12px;display:flex}.home-rank-row.is-me{background:var(--peach-soft);border-color:var(--line-2)}.home-rank-name{font-size:14px;font-weight:700}.home-rank-name .me-tag{color:#d66a3a;margin-left:4px;font-size:11.5px}.home-rank-value{font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0;font-family:Jua,sans-serif;font-size:16px}.home-check-card{background:var(--cream-2);padding:24px}.home-check-amount-box{background:var(--paper);border-radius:var(--r-md);border:1px solid var(--line);margin-bottom:12px;padding:18px}.home-check-amount{color:var(--ink);font-variant-numeric:tabular-nums;font-family:Jua,sans-serif;font-size:32px}.home-check-amount-meta{color:var(--ink-3);margin-top:6px;font-size:12.5px;font-weight:600}.home-check-cheer{color:var(--ink-2);text-align:center;margin-bottom:12px;font-size:13.5px;font-weight:700;line-height:1.55}.home-check-cta{justify-content:center;width:100%}@media (max-width:99999px){.home-grid-main,.home-grid-progress,.home-grid-bottom{grid-template-columns:1fr}.home-season-progress{grid-template-columns:minmax(0,1fr) auto}.home-season-progress{gap:14px;padding:18px}.home-season-copy h2{font-size:27px}.home-week-card,.home-last-week-card,.home-plan-card{padding:16px}.home-grid-main{gap:14px;margin-bottom:14px}.home-grid-plan{gap:14px;margin-top:18px;margin-bottom:14px}.home-daily-goal-card{padding:16px}.home-last-week-card{margin-top:14px}.home-page{padding-left:10px;padding-right:10px}.home-today{padding:16px}.home-week-card,.home-last-week-card{padding:14px}.home-grid-plan{grid-template-columns:1fr}.season-goal-prompt{padding:20px}.season-goal-prompt-actions{flex-direction:column-reverse}.season-goal-prompt-actions .btn{justify-content:center;width:100%}.home-mini-stats{gap:8px}.home-mini-stat{padding:10px}.home-today-kpi{font-size:36px}.home-today-gift{transform:none}.home-week-progress-ring{width:170px;height:170px}.home-week-progress-pct{font-size:32px}.home-season-goal-note{grid-template-columns:4px minmax(0,1fr);align-items:start;gap:10px}}
.rank-page{padding:var(--page-pad-y) var(--page-pad-x) 60px;box-sizing:border-box;max-width:1100px}.rank-tabs{flex-wrap:wrap;gap:8px;margin-bottom:22px;display:flex}.rank-tab{border-radius:var(--r-pill);background:var(--paper);border:1px solid var(--line-2);color:var(--ink-2);cursor:pointer;white-space:nowrap;min-height:40px;padding:10px 18px;font-size:13.5px;font-weight:700;transition:background .15s,color .15s,border-color .15s}.rank-tab.active{background:var(--peach-deep);color:#fff;border-color:var(--peach-deep)}.rank-empty-card{text-align:center;background:var(--cream-2);margin-bottom:22px;padding:56px 24px}.rank-empty-emoji{margin-bottom:14px;font-size:44px;line-height:1}.rank-empty-card h3{color:var(--ink);letter-spacing:-.01em;margin:0 0 8px;font-family:Jua,sans-serif;font-size:20px;font-weight:400}.rank-empty-card p{color:var(--ink-3);margin:0;font-size:14px;font-weight:700;line-height:1.55}.rank-podium-card{background:var(--cream-2);margin-bottom:22px;padding:32px 28px 28px;position:relative;overflow:hidden}.rank-podium-title{text-align:center;color:var(--ink);letter-spacing:-.01em;margin-bottom:26px;font-family:Jua,sans-serif;font-size:20px}.rank-podium{grid-template-columns:1fr 1.2fr 1fr;align-items:end;gap:0 16px;max-width:780px;margin:0 auto;display:grid}.rank-podium-item{flex-direction:column;align-items:center;min-width:0;display:flex}.rank-podium-avatar-wrap{z-index:1;margin-bottom:5px;position:relative}.rank-podium-item.r2{grid-column:1}.rank-podium-item.r1{grid-column:2}.rank-podium-item.r3{grid-column:3}.rank-podium-avatar{border:3px solid var(--paper);width:90px;height:90px;box-shadow:var(--sh-md);border-radius:50%;justify-content:center;align-items:center;display:flex}.rank-podium-medal{position:absolute;top:-4px;right:-4px}.rank-podium-name{text-align:center;overflow-wrap:anywhere;width:100%;min-width:0;margin-bottom:8px}.rank-podium-name .name{white-space:nowrap;text-overflow:ellipsis;font-family:Jua,sans-serif;font-size:17px;overflow:hidden}.rank-podium-name .lv{color:var(--ink-3);font-size:12px;font-weight:700;line-height:1.35}.rank-podium-stand{border-radius:var(--r-lg);border:1px solid var(--line-2);flex-direction:column;justify-content:flex-start;align-items:center;width:100%;padding:14px 12px;display:flex}.rank-podium-stand.r1{background:#d8b86a;height:210px}.rank-podium-stand.r2{background:var(--cream-3);height:170px}.rank-podium-stand.r3{background:#ddb99b;height:140px}.rank-podium-stand .num{color:var(--ink);font-family:Jua,sans-serif;font-size:40px;line-height:1}.rank-podium-stand .val{white-space:nowrap;margin-top:6px;font-family:Jua,sans-serif;font-size:17px}.rank-podium-stand .trend{border-radius:var(--r-pill);background:#fff9;margin-top:8px;padding:3px 8px;font-size:11px;font-weight:800}.rank-list-card{padding:0;overflow:hidden}.rank-list-head{justify-content:space-between;align-items:center;gap:12px;padding:20px 24px 8px;display:flex}.rank-list-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0;font-family:Jua,sans-serif;font-size:19px;font-weight:400}.rank-list-range{color:var(--ink-3);margin-top:3px;font-size:12px;font-weight:700}.rank-list-body{padding:0 16px 16px}.rank-row{border-radius:var(--r-md);background:0 0;border:1px solid #0000;align-items:center;gap:14px;margin-bottom:6px;padding:14px;transition:background .15s;display:flex}.rank-row:hover{background:var(--cream-2)}.rank-row.is-me{background:var(--peach-soft);border-color:var(--line-2)}.rank-row-mascot{border:1px solid var(--line);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.rank-row-name{font-size:15px;font-weight:700}.rank-row-sub{color:var(--ink-3);margin-top:2px;font-size:12px;font-weight:600}.rank-row-goal{color:var(--ink-2);overflow-wrap:anywhere;margin-top:4px;font-size:12.5px;font-weight:800;line-height:1.35}.rank-row-goal.empty{color:var(--ink-3);font-weight:700}.rank-row-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.rank-row-value{font-variant-numeric:tabular-nums;white-space:nowrap;font-family:Jua,sans-serif;font-size:18px}.rank-row-trend{background:var(--cream-2);border-radius:var(--r-pill);border:1px solid var(--line-2);padding:2px 8px;font-size:11px;font-weight:800}.rank-row-trend.up{color:#4f8f6b}.rank-row-trend.down{color:#c85c5c}.rank-row-trend.flat{color:var(--ink-3)}.rank-pagination{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:0 16px 18px;display:flex}.rank-page-numbers{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;display:flex}.rank-page-btn,.rank-page-num{border-radius:var(--r-pill);border:1px solid var(--line-2);background:var(--paper);min-width:34px;min-height:34px;color:var(--ink-2);justify-content:center;align-items:center;font-size:12.5px;font-weight:800;display:inline-flex}.rank-page-btn{padding:0 12px}.rank-page-num.active{background:var(--peach-deep);border-color:var(--peach-deep);color:#fff}.rank-page-btn.disabled{color:var(--ink-3);pointer-events:none;opacity:.45}.rank-reflection{background:var(--cream-2);margin-top:22px;padding:24px}.rank-reflection-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.rank-reflection-stat{background:var(--paper);border-radius:var(--r-md);text-align:center;border:1px solid var(--line);padding:14px}.rank-reflection-stat .icon{margin-bottom:4px;font-size:24px}.rank-reflection-stat .label{color:var(--ink-3);font-size:12px;font-weight:700}.rank-reflection-stat .value{margin-top:2px;font-family:Jua,sans-serif;font-size:18px}@media (max-width:99999px){.rank-podium{grid-template-columns:1fr 1.15fr 1fr;column-gap:8px;max-width:100%}.rank-podium-avatar{border-width:2px;width:64px;height:64px}.rank-podium-name .lv{white-space:normal;font-size:11px;line-height:1.25}.rank-podium-stand{padding:10px 6px}.rank-tab{padding:9px 14px;font-size:12.5px}.rank-list-head{padding:16px 14px 8px}.rank-list-body{padding:0 10px 12px}.rank-pagination{gap:8px;padding:0 10px 14px}.rank-reflection{padding:16px}.rank-reflection-grid{grid-template-columns:1fr 1fr}.rank-podium-card{padding:16px 8px 12px}.rank-podium-avatar-wrap{margin-bottom:4px}.rank-podium-avatar{width:56px;height:56px}.rank-podium-name .name{font-size:12.5px}.rank-podium-name .lv{font-size:10.5px}.rank-podium-stand .num{font-size:26px}.rank-podium-stand .val{font-size:12px}.rank-podium-stand.r1{height:130px}.rank-podium-stand.r2{height:108px}.rank-podium-stand.r3{height:90px}.rank-row{gap:10px;padding:10px}.rank-row-mascot{width:40px;height:40px}.rank-row-name{font-size:14px}.rank-row-goal{font-size:11.5px}.rank-row-value{font-size:16px}}
.record-page{padding:var(--page-pad-y) var(--page-pad-x) 60px;box-sizing:border-box;max-width:1240px}.record-season-summary{border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);grid-template-columns:auto 1fr;align-items:center;gap:18px;margin-bottom:22px;padding:14px 18px;display:grid}.record-season-goal{margin-bottom:22px}.record-season-summary-head{color:var(--ink);white-space:nowrap;font-size:13px;font-weight:900}.record-season-summary-items{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;min-width:0;display:grid}.record-summary-item{border-radius:var(--r-md);background:var(--cream-2);justify-content:center;align-items:baseline;gap:7px;min-width:0;padding:6px 8px;display:flex}.record-summary-label{color:var(--ink-3);white-space:nowrap;font-size:12px;font-weight:800}.record-summary-value{color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:15px;font-weight:900}.record-summary-item.emphasis{background:var(--mint)}.record-summary-item.emphasis .record-summary-value{color:var(--mint-deep)}.record-grid-top{grid-template-columns:1fr 1.3fr;gap:20px;margin-bottom:22px;display:grid}.record-grid-gift{grid-template-columns:1fr}.record-grid-bottom{grid-template-columns:1.4fr 1fr;gap:20px;display:grid}.record-gift-card{background:var(--cream-2);padding:22px 24px 20px;position:relative;overflow:hidden}.record-gift-header{grid-template-columns:auto 1fr;align-items:center;gap:22px;display:grid}.record-gift-visual{text-align:center;flex-shrink:0}.record-gift-meta{flex-direction:column;gap:8px;min-width:0;display:flex}.record-gift-title{margin:0;font-family:Jua,sans-serif;font-size:18px}.record-gift-stage-line{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:10px;display:flex}.record-gift-stage-line .stage{color:#4f8f6b;font-family:Jua,sans-serif;font-size:17px}.record-gift-stage-line .next{color:var(--ink-3);white-space:nowrap;font-size:12.5px;font-weight:800}.record-gift-totals{color:var(--ink-3);font-variant-numeric:tabular-nums;font-size:12px;font-weight:700}.gift-visual{justify-content:center;align-items:center;min-height:214px;display:flex;position:relative}.gift-aura{filter:blur(.2px);opacity:.85;background:radial-gradient(circle at 50% 46%,#fffdf8eb,#fffdf833 52%,#0000 74%),radial-gradient(circle,#d66a3a2e,#4f8f6b14 58%,#0000 72%);border-radius:50%;width:184px;height:184px;position:absolute}.gift-box{z-index:2;transform-origin:bottom;width:150px;height:138px;animation:3s ease-in-out infinite gift-breathe;position:relative}.gift-visual.stage-3 .gift-aura,.gift-visual.stage-4 .gift-aura{box-shadow:0 0 34px #d66a3a2e}.gift-visual.stage-4 .gift-box{filter:drop-shadow(0 10px 20px #46342624)}.gift-shadow{filter:blur(3px);background:#2d2a261f;border-radius:999px;height:14px;position:absolute;bottom:5px;left:18px;right:18px}.gift-body{background:#d66a3a;border:2px solid #7a543c2e;border-radius:12px 12px 16px 16px;height:76px;position:absolute;bottom:16px;left:18px;right:18px;overflow:hidden}.gift-lid{background:#e09a78;border:2px solid #7a543c2e;border-radius:14px 14px 10px 10px;height:36px;position:absolute;bottom:88px;left:10px;right:10px}.gift-ribbon{background:#e9d9b8;position:absolute;box-shadow:inset 0 0 0 1px #9f733729}.gift-ribbon.vertical{width:24px;top:0;bottom:0;left:50%;transform:translate(-50%)}.gift-ribbon.horizontal{height:18px;top:27px;left:0;right:0}.gift-knot{z-index:2;background:#e9d9b8;border:2px solid #9f733733;border-radius:8px;width:24px;height:20px;position:absolute;top:-4px;left:50%;transform:translate(-50%)}.gift-bow{background:#e9d9b8;border:2px solid #9f733733;border-radius:22px 22px 8px;width:42px;height:28px;position:absolute;top:-16px}.gift-bow.left{right:50%;transform:rotate(-14deg)}.gift-bow.right{border-radius:22px 22px 22px 8px;left:50%;transform:rotate(14deg)}.gift-seal{opacity:0;background:#fffdf885;border:1px solid #fffdf8b3;border-radius:50%;width:24px;height:24px;position:absolute;bottom:14px;right:14px}.gift-rays{pointer-events:none;position:absolute;inset:12px 28px}.gift-rays span{opacity:0;background:#9f7337;border-radius:2px;width:8px;height:8px;animation:1.8s ease-in-out infinite twinkle;position:absolute}.gift-rays span:first-child{top:22px;left:22px}.gift-rays span:nth-child(2){animation-delay:.5s;top:42px;right:18px}.gift-rays span:nth-child(3){animation-delay:1s;bottom:34px;left:46px}.gift-nameplate{z-index:3;border-radius:var(--r-pill);border:1px solid var(--line);box-shadow:var(--sh-sm);white-space:nowrap;background:#fffdf8e6;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:800;display:inline-flex;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.gift-nameplate strong{color:#4f8f6b}.gift-visual.stage-1 .gift-box{transform:scale(.88)}.gift-visual.stage-1 .gift-lid{bottom:82px;left:18px;right:18px}.gift-visual.stage-1 .gift-bow,.gift-visual.stage-1 .gift-knot,.gift-visual.stage-1 .gift-ribbon.horizontal,.gift-visual.stage-1 .gift-seal{display:none}.gift-visual.stage-2 .gift-box{transform:scale(.96)}.gift-visual.stage-3 .gift-body{background:#4f8f6b}.gift-visual.stage-3 .gift-lid{background:#dce9dd}.gift-visual.stage-3 .gift-seal,.gift-visual.stage-4 .gift-seal{opacity:1}.gift-visual.stage-4 .gift-body{background:#d66a3a}.gift-visual.stage-4 .gift-lid{background:#b9853f;bottom:98px}.gift-visual.stage-4 .gift-rays span{opacity:1}@keyframes gift-breathe{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-5px)scale(1.025)}}.record-grass-card{padding:24px}.record-grass-card-main{margin-bottom:22px;padding:26px 28px 18px}.record-grass-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.record-grass-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0;font-family:Jua,sans-serif;font-size:21px;font-weight:400}.record-grass-head .sub{color:var(--ink-3);font-size:12.5px;font-weight:700}.record-grass-legend{color:var(--ink-3);align-items:center;gap:8px;font-size:11px;font-weight:700;display:flex}.record-grass-legend .grass-cell{width:11px;height:11px}.record-grass-body{align-items:start;gap:10px;padding:6px 0 8px;display:grid;overflow-x:visible}.record-grass-day-labels{flex-direction:column;gap:7px;padding-top:29px;display:flex}.record-grass-day-label{width:30px;height:22px;color:var(--ink-3);justify-content:center;align-items:center;font-size:11.5px;font-weight:700;line-height:1;display:flex}.record-grass-week{flex-direction:column;gap:7px;min-width:24px;display:flex}.record-grass-week-label{height:22px;color:var(--ink-3);text-align:center;text-overflow:clip;white-space:nowrap;justify-content:center;align-items:center;width:100%;min-width:24px;font-size:11.5px;font-weight:700;display:flex;overflow:visible}.record-grass-future{box-sizing:border-box;background:var(--cream-3);opacity:.5;border-radius:7px;flex-shrink:0;width:min(100%,26px);height:22px;position:relative}.record-grass-empty{box-sizing:border-box;flex-shrink:0;width:min(100%,26px);height:22px}.record-grass-week{align-items:center}.record-grass-week .grass-cell{border-radius:7px;width:min(100%,26px);height:22px;box-shadow:inset 0 -2px #2a76500f}.record-grass-week .record-grass-tooltip{cursor:default;outline:none;transition:transform .12s,box-shadow .12s,opacity .12s;position:relative}.record-grass-week .record-grass-tooltip:hover{z-index:20;transform:translateY(-2px)scale(1.12);box-shadow:0 8px 18px #46342629,inset 0 -2px #2a765014}.record-grass-week .record-grass-tooltip:before,.record-grass-week .record-grass-tooltip:after{opacity:0;pointer-events:none;z-index:30;transition:opacity 80ms,transform 80ms;position:absolute;left:50%}.record-grass-week .record-grass-tooltip:before{content:"";background:var(--ink);border:1px solid #fffdf82e;border-top:0;border-left:0;width:9px;height:9px;top:-10px;transform:translate(-50%,3px)rotate(45deg)}.record-grass-week .record-grass-tooltip:after{content:attr(data-tooltip);background:var(--ink);min-width:max-content;max-width:220px;color:var(--paper);white-space:nowrap;font-variant-numeric:tabular-nums;border:1px solid #fffdf82e;border-radius:10px;padding:8px 11px;font-size:12px;font-weight:800;line-height:1.15;bottom:calc(100% + 10px);transform:translate(-50%,3px);box-shadow:0 12px 28px #46342638}.record-grass-week .record-grass-tooltip:hover:before,.record-grass-week .record-grass-tooltip:hover:after{opacity:1;transform:translate(-50%)rotate(45deg)}.record-grass-week .record-grass-tooltip:hover:after{transform:translate(-50%)}.record-grass-week .record-grass-tooltip-start:before,.record-grass-week .record-grass-tooltip-start:after{left:0}.record-grass-week .record-grass-tooltip-start:before{transform:translate(8px,3px)rotate(45deg)}.record-grass-week .record-grass-tooltip-start:after{transform:translateY(3px)}.record-grass-week .record-grass-tooltip-start:hover:before{transform:translate(8px)rotate(45deg)}.record-grass-week .record-grass-tooltip-start:hover:after{transform:translate(0)}.record-grass-week .record-grass-tooltip-end:before,.record-grass-week .record-grass-tooltip-end:after{left:auto;right:0}.record-grass-week .record-grass-tooltip-end:before{transform:translate(-8px,3px)rotate(45deg)}.record-grass-week .record-grass-tooltip-end:after{transform:translateY(3px)}.record-grass-week .record-grass-tooltip-end:hover:before{transform:translate(-8px)rotate(45deg)}.record-grass-week .record-grass-tooltip-end:hover:after{transform:translate(0)}.record-grass-week .record-grass-tooltip-below:before{top:auto;bottom:-10px}.record-grass-week .record-grass-tooltip-below:after{top:calc(100% + 10px);bottom:auto}.record-grass-week .record-grass-tooltip-below:not(.record-grass-tooltip-start):not(.record-grass-tooltip-end):before{transform:translate(-50%,-3px)rotate(45deg)}.record-grass-week .record-grass-tooltip-below:not(.record-grass-tooltip-start):not(.record-grass-tooltip-end):after{transform:translate(-50%,-3px)}.record-grass-week .record-grass-tooltip-below:not(.record-grass-tooltip-start):not(.record-grass-tooltip-end):hover:before{transform:translate(-50%)rotate(45deg)}.record-grass-week .record-grass-tooltip-below:not(.record-grass-tooltip-start):not(.record-grass-tooltip-end):hover:after{transform:translate(-50%)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-start:before{transform:translate(8px,-3px)rotate(45deg)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-start:after{transform:translateY(-3px)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-start:hover:before{transform:translate(8px)rotate(45deg)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-start:hover:after{transform:translate(0)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-end:before{transform:translate(-8px,-3px)rotate(45deg)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-end:after{transform:translateY(-3px)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-end:hover:before{transform:translate(-8px)rotate(45deg)}.record-grass-week .record-grass-tooltip-below.record-grass-tooltip-end:hover:after{transform:translate(0)}.record-grass-summary{border-radius:var(--r-lg);background:#4f8f6b24;border:1px solid #4f8f6b2e;grid-template-columns:1fr 1fr;gap:1px;margin-top:16px;display:grid;overflow:hidden}.record-grass-summary-item{background:#f4f7f1;justify-content:center;align-items:center;gap:12px;min-height:74px;display:flex}.record-grass-summary-item .summary-icon{font-size:26px;line-height:1}.record-grass-summary-item .summary-label{color:var(--ink-3);font-size:12.5px;font-weight:800}.record-grass-summary-item .summary-value{color:var(--ink);margin-top:2px;font-family:Jua,sans-serif;font-size:22px}.record-cal-card{padding:24px}.record-cal-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.record-cal-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.record-cal-head .sub{color:var(--ink-3);font-size:12.5px;font-weight:700}.record-cal-nav{gap:4px;display:flex}.record-cal-nav button{min-height:32px;padding:6px 12px;font-size:12px}.record-cal-dow{grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px;display:grid}.record-cal-dow>div{text-align:center;color:var(--ink-3);padding:6px;font-size:11.5px;font-weight:800}.record-cal-dow .sat{color:#7a7167}.record-cal-dow .sun{color:#d66a3a}.record-cal-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.record-cal-cell{aspect-ratio:1;border-radius:var(--r-md);background:var(--cream-2);border:1px solid var(--line);flex-direction:column;padding:6px;display:flex;position:relative}.record-cal-cell.empty{background:0 0;border:none}.record-cal-cell.met{background:var(--mint);border-color:var(--line-2)}.record-cal-cell.partial{border-color:var(--line-2);background:#e9d9b8}.record-cal-cell.miss{background:var(--peach-soft);border-color:var(--line-2)}.record-cal-cell.today{background:var(--peach-deep);border:2px solid var(--peach-deep)}.record-cal-cell.today .day{color:#fff}.record-cal-cell.future{opacity:.4}.record-cal-cell .day{color:var(--ink-2);font-size:11px;font-weight:800}.record-cal-cell .center{text-align:center;margin-top:auto}.record-cal-cell .icon{font-size:14px}.record-cal-cell .min{color:var(--ink-2);font-variant-numeric:tabular-nums;font-size:10px;font-weight:700}.record-list-card{padding:0;overflow:hidden}.record-list-head{padding:20px 24px 12px}.record-list-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0 0 4px;font-family:Jua,sans-serif;font-size:18px;font-weight:400}.record-list-head .sub{color:var(--ink-3);font-size:12.5px;font-weight:700}.record-list-body{max-height:460px;padding:0 16px 16px;overflow-y:auto}.record-day-row{border-radius:var(--r-md);align-items:center;gap:12px;padding:11px 14px;display:flex}.record-day-date{border-radius:var(--r-md);background:var(--cream-2);border:1px solid var(--line);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.record-day-date.met{background:var(--mint);border-color:var(--line-2)}.record-day-date.zero{background:var(--peach-soft);border-color:var(--line-2)}.record-day-date .dow{color:var(--ink-2);font-size:9px;font-weight:800}.record-day-date .d{font-family:Jua,sans-serif;font-size:14px}.record-day-body{flex:1;min-width:0}.record-day-meta{justify-content:space-between;gap:12px;margin-bottom:4px;font-size:13px;font-weight:700;display:flex}.record-day-meta .min{font-variant-numeric:tabular-nums;white-space:nowrap}.record-day-icon{text-align:center;flex-shrink:0;width:22px;font-size:16px}.record-gift-progress{border-radius:var(--r-pill);background:var(--cream-3);height:8px;overflow:hidden}.record-gift-progress-fill{background:var(--peach-deep);border-radius:var(--r-pill);height:100%;transition:width .6s}.record-gift-stages{grid-template-columns:repeat(3,1fr);gap:6px;margin:18px 0 0;padding:0;list-style:none;display:grid}.record-gift-stages li{border-radius:var(--r-md);background:var(--paper);border:1px solid var(--line);text-align:center;opacity:.55;flex-direction:column;align-items:center;gap:2px;padding:8px 6px;display:flex}.record-gift-stages li.active{opacity:1;border-color:var(--mint-deep);background:var(--mint)}.record-gift-stages li .dot{background:var(--cream-3);width:22px;height:22px;color:var(--ink-2);font-variant-numeric:tabular-nums;border-radius:999px;justify-content:center;align-items:center;font-size:12px;font-weight:900;display:inline-flex}.record-gift-stages li.active .dot{background:var(--mint-deep);color:#fff}.record-gift-stages li .range{color:var(--ink-3);font-size:11px;font-weight:700}.record-gift-stages li .name{color:var(--ink-2);font-size:12.5px;font-weight:800}.record-gift-reward{text-align:center;margin-top:16px}.record-gift-claim{min-width:180px}.record-gift-claim:disabled{cursor:default;opacity:.66}.record-gift-claim-sub{color:var(--ink-3);margin-top:7px;font-size:12px;font-weight:800}.record-gift-claim-error{color:var(--coral-deep,#c85c5c);margin-top:8px;font-size:12px;font-weight:800}.gift-inbox{text-align:left;margin-top:18px}.gift-inbox-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:9px;display:flex}.gift-inbox-head h3{margin:0;font-family:Jua,sans-serif;font-size:17px;font-weight:400}.gift-inbox-head span{color:var(--ink-3);white-space:nowrap;font-size:12px;font-weight:900}.gift-inbox-empty{border-radius:var(--r-md);border:1px dashed var(--line-2);color:var(--ink-3);text-align:center;background:#fffdf8ad;padding:12px;font-size:12.5px;font-weight:800}.gift-inbox-list{gap:8px;display:grid}.gift-inbox-item{border-radius:var(--r-md);background:var(--paper);border:1px solid var(--line);grid-template-columns:46px 1fr;gap:10px;padding:11px;display:grid}.gift-inbox-item.mint{background:#f4f7f1}.gift-inbox-item.peach{background:#fff7ef}.gift-inbox-item.yellow{background:#f7f3ec}.gift-inbox-item.pink{background:#f7efec}.gift-inbox-stage{border:1px solid var(--line);width:42px;height:42px;color:var(--ink);white-space:nowrap;background:#fffdf8c7;border-radius:14px;justify-content:center;align-items:center;font-size:12px;font-weight:900;display:inline-flex}.gift-inbox-body{min-width:0}.gift-inbox-body strong{color:var(--ink);font-size:13.5px;font-weight:900;line-height:1.25;display:block}.gift-inbox-body p{color:var(--ink-2);overflow-wrap:anywhere;margin:4px 0 5px;font-size:12.5px;font-weight:700;line-height:1.35}.gift-inbox-body span{color:var(--ink-3);font-size:11.5px;font-weight:900}.gift-reward-modal-backdrop{z-index:210;background:#241e1870;justify-content:center;align-items:center;padding:18px;display:flex;position:fixed;inset:0}.gift-reward-modal{border-radius:var(--r-lg);background:var(--paper);border:1px solid var(--line);width:min(100%,370px);box-shadow:var(--sh-lg);text-align:center;padding:28px 22px 20px;animation:.34s ease-out both gift-pop;position:relative;overflow:hidden}.gift-reward-modal.mint{background:#f4f7f1}.gift-reward-modal.peach{background:#fff7ef}.gift-reward-modal.yellow{background:#f7f3ec}.gift-reward-modal.pink{background:#f7efec}.gift-reward-box{width:86px;height:78px;margin:0 auto 12px;animation:.74s ease-out both gift-open;position:relative}.gift-reward-body,.gift-reward-lid{border:2px solid #7a543c29;position:absolute;left:50%;transform:translate(-50%)}.gift-reward-body{background:#d66a3a;border-radius:8px 8px 12px 12px;width:68px;height:44px;bottom:0}.gift-reward-body:before{content:"";background:#e9d9b8;width:14px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.gift-reward-lid{background:#e09a78;border-radius:10px 10px 6px 6px;width:78px;height:24px;bottom:41px}.gift-reward-lid:before,.gift-reward-lid:after{content:"";background:#e9d9b8;border:2px solid #9f73372e;width:30px;height:22px;position:absolute;top:-17px}.gift-reward-lid:before{border-radius:18px 18px 6px;right:50%;transform:rotate(-12deg)}.gift-reward-lid:after{border-radius:18px 18px 18px 6px;left:50%;transform:rotate(12deg)}.gift-reward-burst{pointer-events:none;height:130px;position:absolute;inset:18px 34px auto}.gift-reward-burst span{background:#9f7337;border-radius:2px;width:8px;height:8px;animation:.82s ease-out both gift-spark;position:absolute;top:66px;left:50%}.gift-reward-burst span:first-child{--x:-96px;--y:-66px;animation-delay:40ms}.gift-reward-burst span:nth-child(2){--x:-62px;--y:-98px;animation-delay:80ms}.gift-reward-burst span:nth-child(3){--x:-18px;--y:-82px;animation-delay:20ms}.gift-reward-burst span:nth-child(4){--x:28px;--y:-94px;animation-delay:.1s}.gift-reward-burst span:nth-child(5){--x:70px;--y:-72px;animation-delay:50ms}.gift-reward-burst span:nth-child(6){--x:96px;--y:-40px;animation-delay:.12s}.gift-reward-kicker{color:var(--ink-3);font-size:12px;font-weight:900}.gift-reward-modal h3{margin:5px 0 6px;font-family:Jua,sans-serif;font-size:24px;font-weight:400}.gift-reward-modal p{max-width:280px;color:var(--ink-2);margin:0 auto 18px;font-size:13.5px;font-weight:700;line-height:1.55}@keyframes gift-pop{0%{opacity:0;transform:translateY(10px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes gift-open{0%{transform:translateY(8px)scale(.92)}52%{transform:translateY(-3px)scale(1.04)}to{transform:translateY(0)scale(1)}}@keyframes gift-spark{0%{opacity:0;transform:translate(-50%)scale(.4)rotate(0)}30%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--x)), var(--y)) scale(1) rotate(80deg)}}.record-list-card-wide{padding:0;overflow:hidden}@media (max-width:99999px){.record-grid-top,.record-grid-bottom{grid-template-columns:1fr}.record-gift-stages{grid-template-columns:repeat(3,1fr)}.record-season-summary{grid-template-columns:1fr;gap:10px;padding:14px}.record-season-summary-items{grid-template-columns:repeat(2,minmax(0,1fr))}.record-summary-item{justify-content:space-between}.record-gift-card,.record-grass-card,.record-cal-card{padding:16px}.record-grass-card-main{margin-bottom:22px}.record-grass-head h3{font-size:18px}.record-grass-body{gap:12px;padding-bottom:4px;display:flex;overflow-x:auto}.record-grass-day-labels{gap:4px;padding-top:18px}.record-grass-day-label{width:18px;height:14px;font-size:10px}.record-grass-week{flex:0 0 24px;gap:4px;width:24px}.record-grass-week-label{width:24px;min-width:24px;height:14px;font-size:9.5px}.record-grass-empty,.record-grass-future,.record-grass-week .grass-cell{border-radius:4px;width:14px;min-width:14px;max-width:14px;height:14px}.record-grass-summary{grid-template-columns:1fr}.record-grass-summary-item{min-height:60px}.record-grass-summary-item .summary-value{font-size:19px}.record-list-head{padding:16px 14px 8px}.record-list-body{padding:0 10px 12px}.record-cal-grid{gap:4px}.record-cal-cell{border-radius:10px;padding:4px}.record-cal-cell .icon{font-size:12px}.record-cal-cell .min{font-size:9px}.record-season-summary-items{gap:6px}.record-summary-item{gap:5px;padding:6px 7px}.record-summary-label{font-size:11px}.record-summary-value{font-size:13.5px}}
.admin-page{padding:var(--page-pad-y) var(--page-pad-x) 60px;box-sizing:border-box;max-width:1240px}.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;display:grid}.admin-mobile-menu{display:none}.admin-stat{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px}.admin-stat.peach{background:var(--peach-soft)}.admin-stat.pink{background:var(--blush)}.admin-stat-head{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.admin-stat .icon{font-size:18px}.admin-stat .value{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-family:Jua,sans-serif;font-size:24px}.admin-section{margin-bottom:22px;padding:24px}.admin-section.compact{padding:0;overflow:hidden}.admin-section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.admin-section-head.padded{margin-bottom:0;padding:20px 24px 14px}.admin-section-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0 0 2px;font-family:Jua,sans-serif;font-size:19px;font-weight:400}.admin-section-head .sub{color:var(--ink-3);font-size:12.5px;font-weight:700}.admin-section-head .actions{align-items:center;gap:8px;display:flex}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table thead th{background:var(--cream-2);text-align:left;color:var(--ink-3);letter-spacing:.3px;padding:12px 16px;font-size:12px;font-weight:800}.admin-table thead th.right{text-align:right}.admin-table tbody td{vertical-align:middle;border-bottom:1px dashed var(--line);padding:13px 16px}.admin-table tbody td.right{text-align:right}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table .user-cell{align-items:center;gap:10px;display:flex}.admin-table .user-name{font-weight:700}.admin-table .user-handle{color:var(--ink-3);font-size:11px;font-weight:600}.admin-table .num{font-variant-numeric:tabular-nums;font-weight:700}.admin-conf{align-items:center;gap:6px;display:flex}.admin-conf-track{background:var(--cream-3);border-radius:var(--r-pill);width:60px;height:6px;overflow:hidden}.admin-conf-fill{border-radius:var(--r-pill);background:var(--mint-deep);height:100%}.admin-conf-fill.med,.admin-conf-fill.low{background:#b9853f}.admin-conf-num{font-variant-numeric:tabular-nums;color:var(--ink-2);font-size:11px;font-weight:700}.admin-ocr-grid{grid-template-columns:1.3fr 1fr;gap:20px;margin-bottom:22px;display:grid}.admin-ocr-preview{aspect-ratio:9/16;border-radius:var(--r-lg);background:#2d2a26;border:6px solid #403a34;width:100%;max-height:280px;padding:16px;position:relative;overflow:hidden}.admin-ocr-preview .stamp{color:#b5aba0;font-family:monospace;font-size:10px}.admin-ocr-preview .center{color:#fff;text-align:center;margin-top:12px}.admin-ocr-preview .center .small{color:#b5aba0;margin-bottom:4px;font-size:10px}.admin-ocr-preview .center .big{color:#b9853f;font-family:monospace;font-size:28px;font-weight:700}.admin-ocr-preview .row{color:#e4dad0;background:#403a34;border-radius:10px;margin-top:16px;padding:10px;font-size:10px}.admin-ocr-preview .row .line{justify-content:space-between;display:flex}.admin-ocr-preview .row .divider{background:#5a5148;height:1px;margin:8px 0}.admin-ocr-preview .highlight{pointer-events:none;border:2px dashed #b9853f;border-radius:8px;height:38px;animation:2s ease-in-out infinite twinkle;position:absolute;top:38px;left:25%;right:25%}.admin-ocr-confirm{background:var(--cream-3);border-radius:var(--r-md);border:1.5px dashed var(--line-2);margin-top:14px;padding:14px}.admin-ocr-confirm-head{justify-content:space-between;margin-bottom:8px;font-size:12.5px;display:flex}.admin-ocr-confirm-head .label{color:var(--ink-3);font-weight:700}.admin-ocr-confirm-head .val{font-variant-numeric:tabular-nums;font-weight:700}.admin-ocr-confirm-actions{gap:8px;display:flex}.admin-ocr-confirm-actions input{border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--paper);flex:1;min-height:36px;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:700}@media (max-width:99999px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-ocr-grid{grid-template-columns:1fr}.admin-table{min-width:640px}}.admin-scroll,.admin-section.compact .admin-scroll{max-width:100%}.admin-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-empty{color:var(--ink-3);padding:20px 24px 24px;font-size:13px;font-weight:700}.admin-reminder-pre{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r-md);white-space:pre-wrap;color:var(--ink-1);margin:0;padding:14px;font-family:inherit;font-size:13px;line-height:1.6}.admin-num-paid{color:#4f8f6b}.admin-num-unpaid{color:var(--coral-deep,#c85c5c)}.admin-num-zero{color:var(--ink-3)}.admin-row-btn{min-height:28px;padding:5px 10px;font-size:11.5px}.admin-row-btn+.admin-row-btn{margin-left:4px}.admin-row-btn-confirm{background:var(--mint-deep);color:#fff}.admin-row-btn-undo{background:var(--cream-3);color:var(--ink-2)}.admin-fine-dashboard{padding:0 24px 24px}.admin-fine-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.admin-fine-summary{border-radius:var(--r-md);background:#fff7efbd;border:1px solid #d66a3a2e;min-width:0;padding:13px 14px}.admin-fine-summary.muted{border-color:var(--line);background:var(--cream-2)}.admin-fine-summary div{color:var(--ink-3);margin-bottom:4px;font-size:11.5px;font-weight:800}.admin-fine-summary strong{color:var(--ink);overflow-wrap:anywhere;font-size:18px;line-height:1.2;display:block}.admin-fine-controls{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.admin-fine-tabs{border:1px solid var(--line);border-radius:var(--r-pill);background:var(--cream-2);padding:3px;display:inline-flex}.admin-fine-tab{appearance:none;border-radius:var(--r-pill);color:var(--ink-3);cursor:pointer;white-space:nowrap;background:0 0;border:0;padding:8px 12px;font-family:inherit;font-size:12.5px;font-weight:900}.admin-fine-tab.active{background:var(--paper);color:var(--ink);box-shadow:0 4px 12px #2d2a2614}.admin-fine-search{min-width:min(260px,100%);color:var(--ink-3);align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.admin-fine-search input{border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--paper);width:100%;min-width:0;min-height:34px;color:var(--ink);outline:none;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:700}.admin-fine-search input:focus{border-color:var(--peach)}.admin-fine-groups{gap:10px;display:grid}.admin-fine-group{border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper);overflow:hidden}.admin-fine-group[open]{box-shadow:0 12px 28px #2d2a2614}.admin-fine-group-summary{cursor:pointer;grid-template-columns:minmax(0,1fr) auto auto auto auto;align-items:center;gap:12px;padding:14px 16px;list-style:none;display:grid}.admin-fine-group-summary::-webkit-details-marker{display:none}.admin-fine-group-summary:after{content:"펼치기";color:var(--ink-3);justify-self:end;font-size:11px;font-weight:800;line-height:1}.admin-fine-group[open] .admin-fine-group-summary:after{content:"접기"}.admin-fine-group-main{flex-wrap:wrap;align-items:baseline;gap:8px;min-width:0;display:flex}.admin-fine-group-name{color:var(--ink);font-size:15px;font-weight:900}.admin-fine-group-latest{color:var(--ink-3);font-variant-numeric:tabular-nums;font-size:12px;font-weight:800}.admin-fine-group-meta{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:5px;display:flex}.admin-fine-group-total{color:var(--coral-deep,#c85c5c);white-space:nowrap;font-size:15px;font-weight:900}.admin-fine-group-confirm{white-space:nowrap}.admin-fine-error{border-radius:var(--r-md);color:var(--coral-deep,#c85c5c);background:#c85c5c14;border:1px solid #c85c5c40;margin-bottom:12px;padding:10px 12px;font-size:12.5px;font-weight:800}.admin-fine-table-wrap{border-top:1px solid var(--line);overflow-x:auto}.admin-fine-table{min-width:640px}.admin-fine-recent{border:1px solid var(--line);border-radius:var(--r-md)}@media (max-width:760px){.admin-page{padding:12px 10px 92px}.admin-mobile-menu{z-index:12;border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);-webkit-overflow-scrolling:touch;background:#fffaf3f0;border-radius:12px;gap:6px;margin:-6px 0 14px;padding:8px;display:flex;position:sticky;top:8px;overflow-x:auto;box-shadow:0 10px 28px #2d2a2614}.admin-mobile-menu a{background:var(--cream-2);min-height:38px;color:var(--ink-2);white-space:nowrap;border-radius:999px;flex:none;justify-content:center;align-items:center;padding:0 12px;font-size:12.5px;font-weight:900;text-decoration:none;display:inline-flex}.admin-mobile-menu a:active{background:var(--peach-soft);color:#9e4625}.admin-fine-dashboard{padding:0 14px 18px}.admin-fine-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-fine-controls{flex-direction:column;align-items:stretch}.admin-fine-tabs{width:100%}.admin-fine-tab{flex:1}.admin-fine-search{min-width:0}.admin-fine-group-summary{grid-template-columns:minmax(0,1fr);align-items:start}.admin-fine-group-meta{justify-content:flex-start}.admin-fine-group-summary:after{justify-self:start}}.season-editor{flex-direction:column;gap:6px;margin-top:6px;display:flex}.season-editor-grid{grid-template-columns:110px minmax(150px,1fr) minmax(150px,1fr) auto;align-items:end;gap:10px;display:grid}.season-editor-field{flex-direction:column;gap:6px;min-width:0;display:flex}.season-editor-label{color:var(--ink-3);font-size:12.5px;font-weight:700}.season-editor-input{border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--paper);font-variant-numeric:tabular-nums;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:14px;font-weight:700}.season-editor-input-season{max-width:110px}.season-editor-input-date{min-width:0}.season-editor-save{min-height:38px}.season-editor-input:focus{border-color:var(--peach)}.season-editor-err{color:#c85c5c;font-size:12px;font-weight:700}.season-editor-ok{color:#4f8f6b;font-size:12px;font-weight:700}.chat-notice-editor{flex-direction:column;gap:10px;display:flex}.chat-notice-editor-field{flex-direction:column;gap:6px;display:flex}.chat-notice-editor-label{color:var(--ink-3);font-size:12.5px;font-weight:700}.chat-notice-editor-input{resize:vertical;border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--paper);width:100%;min-height:104px;color:var(--ink-1);box-sizing:border-box;outline:none;padding:12px 14px;font-family:inherit;font-size:14px;font-weight:700;line-height:1.55}.chat-notice-editor-input:focus{border-color:var(--peach)}.chat-notice-editor-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.chat-notice-editor-meta{color:var(--ink-3);flex-wrap:wrap;gap:10px;font-size:12px;font-weight:700;display:flex}.chat-notice-editor-actions{gap:8px;display:flex}.chat-notice-editor-err{color:#c85c5c;font-size:12px;font-weight:700}.chat-notice-editor-ok{color:#4f8f6b;font-size:12px;font-weight:700}.admin-upload-wrap{margin-bottom:22px}.admin-weekly-chart-svg{width:100%;height:200px}.admin-upload-panel{padding:0;overflow:hidden}.admin-upload-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:20px 24px 14px;display:flex}.admin-upload-title{font-family:Jua,sans-serif;font-size:19px}.admin-upload-subtitle{color:var(--ink-3);font-size:12.5px;font-weight:700}.admin-upload-mode{gap:6px;display:flex}.admin-upload-mode .chip{cursor:pointer;border:none}.admin-upload-input-grid{grid-template-columns:1fr 1fr auto;align-items:end;gap:12px;padding:0 24px 18px;display:grid}.admin-upload-field{flex-direction:column;gap:6px;min-width:0;display:flex}.admin-upload-input{border:1.5px solid var(--line-2);box-sizing:border-box;background:#fff;border-radius:12px;width:100%;min-width:0;padding:10px 12px;font-family:inherit;font-size:13.5px;font-weight:700}.admin-upload-file{border:1.5px solid var(--line-2);box-sizing:border-box;background:#fff;border-radius:12px;width:100%;min-width:0;padding:8px 10px;font-family:inherit;font-size:12.5px;font-weight:700}.admin-upload-hint{color:var(--ink-3);font-size:11.5px;font-weight:700}.admin-upload-submit{padding:10px 18px;font-size:13px}.admin-upload-alerts{padding:0 24px 14px}.admin-upload-alert{border-radius:12px;padding:10px 14px;font-size:13px;font-weight:700}.admin-upload-alert.err{color:#d66a3a;background:#f1d8cb;border:1.5px solid #e5b9a2}.admin-upload-alert.ok{color:#4f8f6b;background:#e5eee5;border:1.5px solid #dce9dd}.admin-upload-result-grid{grid-template-columns:minmax(0,1fr) 280px;gap:18px;padding:6px 24px 24px;display:grid}.admin-upload-table-wrap{min-width:0}.admin-upload-row-unmatched{background:#f1d8cb}.admin-upload-name{font-weight:700}.admin-upload-select{border:1.5px solid var(--line-2);background:#fff;border-radius:10px;min-width:140px;max-width:100%;padding:6px 10px;font-family:inherit;font-size:12.5px;font-weight:700}.admin-upload-matched-tag{color:var(--ink-3);margin-left:6px;font-size:11px;font-weight:700}.admin-upload-sum{font-weight:700}.admin-upload-delete{padding:5px 10px;font-size:11.5px}.admin-upload-empty{text-align:center;color:var(--ink-3);padding:24px;font-weight:700}.admin-upload-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:14px;display:flex}.admin-upload-add{padding:8px 14px;font-size:13px}.admin-upload-confirm{padding:10px 22px;font-size:14px}.admin-upload-preview-title{margin-bottom:8px;font-family:Jua,sans-serif;font-size:14px}.admin-upload-preview-img{border:1.5px solid var(--line-2);background:#f7f3ec;border-radius:14px;width:100%}.admin-upload-preview-meta{color:var(--ink-3);margin-top:8px;font-size:11px;font-weight:700}.admin-minutes-input{border:1.5px solid var(--line-2);text-align:right;box-sizing:border-box;background:#fff;border-radius:10px;width:80px;max-width:100%;padding:6px 10px;font-family:inherit;font-size:13px;font-weight:700}@media (max-width:99999px){.admin-upload-result-grid{grid-template-columns:1fr;padding:6px 14px 18px}.admin-upload-head{padding:14px}.admin-upload-title{font-size:17px}.admin-upload-input-grid{grid-template-columns:1fr;gap:10px;padding:0 14px 14px}.admin-upload-submit{width:100%}.admin-upload-alerts{padding:0 14px 12px}.admin-upload-result-grid{gap:14px;padding:6px 14px 18px}.admin-upload-select{min-width:110px}.admin-minutes-input{width:70px}}.admin-row-error{color:var(--coral-deep,#c85c5c);margin-right:8px;font-size:12px;font-weight:700}@media (max-width:99999px){.admin-section{margin-bottom:16px;padding:14px}.admin-section-head{flex-direction:column;align-items:flex-start;gap:8px}.admin-section-head.padded{padding:14px}.admin-section-head .actions{flex-wrap:wrap;width:100%}.admin-section-head h3{white-space:normal;word-break:keep-all}.season-editor-grid{grid-template-columns:1fr}.season-editor-input-season{max-width:none}.season-editor-save{width:100%}.admin-stats-grid{grid-template-columns:1fr 1fr;gap:10px}.admin-stat{padding:14px}.admin-stat .value{font-size:18px}.admin-table thead th,.admin-table tbody td{padding:10px 12px}.admin-empty{padding:14px}}@media (max-width:480px){.admin-stats-grid{grid-template-columns:1fr}.admin-table{min-width:560px}}@media (max-width:760px){.admin-stats-grid{gap:8px;margin-bottom:14px}.admin-stat,.admin-section,.admin-section.compact,.admin-upload-panel{border-radius:12px}.admin-section-head .actions{gap:8px}.admin-section-head .actions .btn,.admin-row-btn,.admin-upload-submit,.admin-upload-add,.admin-upload-confirm,.chat-notice-editor-actions .btn,.season-editor-save{justify-content:center;align-items:center;min-height:40px;display:inline-flex}.admin-section-head .actions .btn{flex:140px}.admin-scroll{margin-left:-14px;margin-right:-14px;padding:0 14px 4px}.admin-scroll:after{content:"좌우로 밀어서 보기";color:var(--ink-3);padding:7px 2px 0;font-size:11px;font-weight:800;display:block}.admin-table{border:1px solid var(--line);background:var(--paper);border-radius:10px;min-width:620px;overflow:hidden}.admin-table thead th,.admin-table tbody td{padding:10px}.admin-table tbody td.right{white-space:nowrap}.admin-table .user-cell{min-width:180px}.admin-table .user-handle{text-overflow:ellipsis;white-space:nowrap;max-width:170px;overflow:hidden}.admin-reminder-pre{max-height:320px;font-size:12.5px;overflow:auto}.chat-notice-editor-actions{width:100%}.chat-notice-editor-actions .btn{flex:1}.admin-upload-mode{width:100%}.admin-upload-mode .chip{flex:1;justify-content:center;min-height:36px}.admin-weekly-chart-svg{height:160px}}.atlas-tagger{z-index:50;background:#fff;padding:16px;position:fixed;inset:0;overflow:auto}.atlas-tagger-back{margin-bottom:8px}.atlas-tagger-head h1{margin:0 0 4px;font-size:18px}.atlas-tagger-head p{color:var(--text-muted,#6b7280);margin:0 0 12px;font-size:13px}.atlas-tagger-body{grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:16px;display:grid}.atlas-tagger-sheet-wrap{background:#faf6e9;border:1px solid #d4c8a8;max-height:calc(100vh - 140px);overflow:auto}.atlas-tagger-sheet{image-rendering:pixelated;-webkit-user-select:none;user-select:none;cursor:crosshair;position:relative}.atlas-tagger-sheet img{image-rendering:pixelated;display:block}.atlas-tagger-overlay{pointer-events:none;position:absolute;top:0;left:0}.atlas-tagger-overlay g,.atlas-tagger-overlay rect{pointer-events:auto}.atlas-tagger-overlay g[style*=cursor] rect:hover{fill:#1976d22e}.atlas-tagger-form{border:1px solid var(--border,#e5e7eb);background:#fff;border-radius:8px;flex-direction:column;gap:8px;max-height:calc(100vh - 140px);padding:12px;display:flex;overflow-y:auto}.atlas-tagger-form h2{margin:8px 0 4px;font-size:14px}.atlas-tagger-form label{color:var(--text-muted,#6b7280);flex-direction:column;gap:2px;font-size:12px;display:flex}.atlas-tagger-form input{border:1px solid var(--border,#d1d5db);border-radius:6px;padding:6px 8px;font-size:13px}.atlas-tagger-rect{grid-template-columns:1fr 1fr 1fr 1fr;gap:6px;display:grid}.atlas-tagger-drafts{flex-direction:column;gap:4px;max-height:200px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.atlas-tagger-drafts li{align-items:stretch;gap:4px;display:flex}.atlas-tagger-draft-pick{text-align:left;border:1px solid var(--border,#e5e7eb);cursor:pointer;background:#fafafa;border-radius:6px;flex:1;justify-content:space-between;gap:8px;padding:6px 8px;font-size:12px;display:flex}.atlas-tagger-draft-pick strong{font-size:12px}.atlas-tagger-draft-del{border:1px solid var(--border,#e5e7eb);cursor:pointer;background:#fff;border-radius:6px;width:28px}.atlas-tagger-hint{color:var(--text-muted,#6b7280);margin:0 0 4px;font-size:12px}.atlas-tagger-hint code{background:#f3f4f6;border-radius:3px;padding:1px 4px;font-size:11px}.atlas-tagger-actions{gap:8px;display:flex}.atlas-tagger-actions .btn-primary{flex:1}.atlas-tagger-msg{margin:0;font-size:12px}.atlas-tagger-msg.is-ok{color:#2e7d32}.atlas-tagger-msg.is-err{color:#c62828}@media (max-width:1024px){.atlas-tagger-body{grid-template-columns:1fr}}.admin-gift-test-buttons{flex-wrap:wrap;gap:12px;padding:0 24px;display:flex}.admin-gift-test-buttons .btn{flex:140px}
.profile-page{padding:var(--page-pad-y) var(--page-pad-x) 60px;box-sizing:border-box;max-width:980px}.profile-hero{background:var(--cream-2);align-items:center;gap:18px;margin-bottom:22px;padding:24px;display:flex}.profile-hero-avatar{flex-shrink:0}.profile-hero-avatar .profile-uploader-edit{border-radius:8px;padding:4px 8px;font-size:10.5px;bottom:-6px;right:-6px}.profile-hero-body{min-width:0}.profile-hero-body h2{margin:0 0 4px;font-family:Jua,sans-serif;font-size:28px;font-weight:400}.profile-hero-body p{color:var(--ink-3);overflow-wrap:anywhere;margin:0 0 10px;font-size:13px;font-weight:700}.profile-settings-grid{grid-template-columns:minmax(0,1.2fr) minmax(260px,.8fr);gap:20px;display:grid}.profile-settings-card{background:var(--paper);padding:22px}.profile-settings-head{margin-bottom:14px}.profile-settings-head h3{margin:0 0 4px;font-family:Jua,sans-serif;font-size:20px;font-weight:400}.profile-settings-head p{color:var(--ink-3);margin:0;font-size:12.5px;font-weight:700;line-height:1.5}.profile-season-goal-editor{flex-direction:column;gap:10px;display:flex}.profile-season-goal-editor textarea{resize:vertical;border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--cream-2);width:100%;min-height:120px;color:var(--ink);box-sizing:border-box;outline:none;padding:13px 14px;font-family:inherit;font-size:14px;font-weight:800;line-height:1.55}.profile-season-goal-editor textarea:focus{border-color:var(--peach)}.profile-season-goal-foot{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile-season-goal-foot .btn,.profile-account-actions .btn{border-radius:8px;min-height:40px}.profile-season-goal-foot span{color:var(--ink-3);font-size:12px;font-weight:800}.profile-account-actions{gap:10px;display:grid}.profile-account-actions .btn{justify-content:center}.profile-character-selector{flex-direction:column;gap:12px;display:flex}.profile-character-meta{color:var(--ink-3);justify-content:space-between;align-items:center;gap:12px;font-size:12px;font-weight:800;line-height:1.45;display:flex}.profile-character-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.profile-character-card{border:1.5px solid var(--line-2);background:var(--cream-2);min-width:0;min-height:132px;color:var(--ink);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:12px 10px;font-family:inherit;transition:background .15s,border-color .15s,color .15s;display:flex}.profile-character-card:not(:disabled):hover{border-color:var(--peach);background:#fff4ec}.profile-character-card.selected{border-color:var(--peach-deep);background:#fbe6da}.profile-character-card.locked{color:var(--ink-3);cursor:not-allowed;opacity:.72}.profile-character-sprite{background:var(--paper);border:1px solid var(--line);border-radius:8px;place-items:center;width:58px;height:58px;display:grid}.profile-character-sprite img{object-fit:contain;width:48px;height:48px;image-rendering:pixelated}.profile-character-fallback{font-family:Jua,sans-serif;font-size:24px}.profile-character-name{text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:14px;font-weight:900;overflow:hidden}.profile-character-status{background:var(--paper);border:1px solid var(--line);min-height:24px;color:var(--ink-3);border-radius:999px;justify-content:center;align-items:center;padding:3px 9px;font-size:11px;font-weight:900;display:inline-flex}.profile-character-card.selected .profile-character-status{background:var(--peach-deep);border-color:var(--peach-deep);color:#fff}.profile-settings-error{color:#9e4625;font-size:12px;font-weight:800}.profile-settings-ok{color:#4f8f6b;font-size:12px;font-weight:800}@media (max-width:99999px){.profile-settings-grid{grid-template-columns:1fr}.profile-page{padding-left:12px;padding-right:12px}.profile-hero{align-items:flex-start;padding:18px}.profile-hero-body h2{font-size:24px}.profile-settings-card{padding:18px}.profile-character-meta{flex-direction:column;align-items:flex-start;gap:4px}.profile-season-goal-foot{flex-direction:column;align-items:stretch}.profile-season-goal-foot .btn{justify-content:center;width:100%}}
.login-page{--night:#2d2a26;--night-2:#1f1c18;background:var(--night);grid-template-columns:1.05fr 1fr;min-height:100vh;display:grid}.login-counter-side{color:#f7f3ec;background:radial-gradient(900px 500px at 80% 20%, #d66a3a38 0%, transparent 55%), radial-gradient(700px 400px at 10% 95%, #4f8f6b29 0%, transparent 60%), var(--night);flex-direction:column;padding:clamp(28px,4.2vw,56px);display:flex;position:relative;overflow:hidden}.login-brand{color:#f7f3ecb3;letter-spacing:.6px;text-transform:uppercase;align-items:center;gap:10px;font-size:13px;font-weight:900;display:flex}.login-brand-dot{background:var(--peach-deep);border-radius:50%;width:22px;height:22px;box-shadow:0 0 0 6px #d66a3a2e}.login-eyebrow{color:#f7f3ecb3;white-space:nowrap;max-width:28ch;margin-top:clamp(28px,6vw,70px);font-family:Fraunces,Georgia,serif;font-size:clamp(14px,1.4vw,17px);font-style:italic;font-weight:500;line-height:1.4}.login-counter{letter-spacing:-.03em;color:#f7f3ec;font-variant-numeric:tabular-nums;flex-wrap:wrap;align-items:baseline;gap:clamp(8px,1.2vw,16px);margin-top:8px;font-family:Jua,sans-serif;font-size:clamp(64px,10vw,132px);line-height:.95;display:flex}.login-counter-unit{color:#f7f3ec99;letter-spacing:-.01em;font-family:Pretendard,sans-serif;font-size:clamp(20px,2.6vw,34px);font-weight:800}.login-counter-live{background:#82c29b;border-radius:50%;align-self:center;width:10px;height:10px;animation:1.6s ease-in-out infinite login-pulse;box-shadow:0 0 0 4px #82c29b33}.login-counter--empty{align-items:flex-start;font-size:clamp(40px,6vw,76px);line-height:1.05}.login-counter-empty-lead{color:var(--peach);font-family:Jua,sans-serif;font-size:clamp(56px,8vw,110px);line-height:.95}.login-counter-empty-tail{color:#f7f3ecc7;letter-spacing:-.01em;align-self:flex-end;padding-bottom:6px;font-family:Pretendard,sans-serif;font-size:clamp(22px,2.6vw,34px);font-weight:800;line-height:1.2}@keyframes login-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(1.2)}}.login-since{color:#f7f3ec8c;margin-top:clamp(12px,1.8vw,18px);font-size:clamp(14px,1.2vw,15px);font-weight:700}.login-since b{color:#f7f3ec;font-weight:900}.login-stats{grid-template-columns:minmax(160px,220px);gap:clamp(10px,1.2vw,16px);margin-top:auto;padding-top:clamp(28px,4vw,44px);display:grid}.login-stat{border-radius:var(--r-lg);background:#f7f3ec0d;border:1px solid #f7f3ec14;padding:clamp(14px,1.6vw,18px)}.login-stat-lbl{letter-spacing:.6px;text-transform:uppercase;color:#f7f3ec8c;font-size:11px;font-weight:900}.login-stat-val{color:#f7f3ec;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:8px;font-family:Jua,sans-serif;font-size:clamp(22px,2.4vw,28px);line-height:1}.login-stat-unit{color:#f7f3ec8c;margin-left:2px;font-family:Pretendard,sans-serif;font-size:clamp(11px,1vw,13px);font-weight:800}.login-form-side{background:var(--cream);color:var(--ink);border-left:1px solid var(--night-2);justify-content:center;align-items:center;padding:clamp(28px,4vw,48px);display:flex}.login-card{width:100%;max-width:440px}.login-kicker{letter-spacing:1.2px;color:var(--peach-deep);text-transform:uppercase;align-items:center;gap:8px;margin-bottom:6px;font-size:11px;font-weight:900;display:inline-flex}.login-kicker-pip{background:var(--peach-deep);border-radius:50%;width:6px;height:6px}.login-card-title{letter-spacing:-.015em;margin:0 0 6px;font-family:Jua,sans-serif;font-size:clamp(26px,3vw,32px);font-weight:400}.login-card-sub{color:var(--ink-3);margin:0 0 24px;font-size:13.5px;font-weight:700;line-height:1.5}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;display:flex}.login-field-label{color:var(--ink-3);letter-spacing:.4px;text-transform:uppercase;margin-bottom:7px;font-size:11.5px;font-weight:800}.login-input-wrap{display:block;position:relative}.login-input-ic{color:var(--ink-3);pointer-events:none;display:inline-flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-input{border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--paper);width:100%;color:var(--ink);outline:none;min-height:48px;padding:12px 14px 12px 40px;font-family:inherit;font-size:15px;transition:border-color .15s,background .15s,box-shadow .15s}.login-input:focus{border-color:var(--peach);background:#fffaf1;box-shadow:0 0 0 4px #d66a3a1a}.login-input::placeholder{color:var(--ink-3)}.login-row-between{justify-content:space-between;align-items:center;gap:10px;margin-top:2px;display:flex}.login-remember{color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:9px;font-size:13px;font-weight:800;display:inline-flex}.login-remember-check{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.login-remember-box{border:1.5px solid var(--line-2);background:var(--paper);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:background .15s,border-color .15s;display:inline-flex}.login-remember-box:after{content:"";transform-origin:50%;border-bottom:2px solid #fff;border-left:2px solid #fff;width:8px;height:5px;transition:transform .15s;transform:translateY(-1px)rotate(-45deg)scale(0)}.login-remember-check:checked+.login-remember-box{background:var(--peach-deep);border-color:var(--peach-deep)}.login-remember-check:checked+.login-remember-box:after{transform:translateY(-1px)rotate(-45deg)scale(1)}.login-remember-check:focus-visible+.login-remember-box{outline-offset:2px;outline:3px solid #d66a3a2e}.login-error{background:var(--peach-soft);color:#9e4625;border-radius:var(--r-md);padding:8px 12px;font-size:12.5px;font-weight:700}.login-submit{background:var(--peach-deep);color:#fff;border-radius:var(--r-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;min-height:50px;padding:14px 18px;font-family:inherit;font-size:15px;font-weight:800;transition:background .15s,transform .1s;display:inline-flex}.login-submit:hover:not(:disabled){background:#c85c32}.login-submit:active:not(:disabled){transform:translateY(1px)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-signup{color:var(--ink-3);text-align:center;margin-top:4px;font-size:13px;font-weight:700}.login-signup-link{color:var(--peach-deep);text-underline-offset:3px;font-weight:800;text-decoration:underline}.login-forgot{color:var(--ink-3);text-underline-offset:3px;cursor:pointer;background:0 0;border:0;align-self:center;margin-top:-2px;padding:4px 8px;font-family:inherit;font-size:12.5px;font-weight:700;text-decoration:underline}.login-forgot:hover{color:var(--peach-deep)}@media (max-width:1024px){.login-page{grid-template-columns:1fr}.login-counter-side{min-height:auto;padding:32px 28px 28px}.login-eyebrow{margin-top:28px;font-size:15px}.login-counter{font-size:78px}.login-counter-unit{font-size:22px}.login-since{font-size:14px}.login-stats{border-top:1px solid #f7f3ec14;margin-top:28px;padding-top:24px}.login-form-side{border-left:none;border-top:1px solid var(--night-2);padding:36px 28px 44px}.login-card{max-width:460px}}@media (max-width:640px){.login-counter-side{padding:24px 20px 22px}.login-brand{font-size:12px}.login-brand-dot{width:18px;height:18px}.login-eyebrow{white-space:normal;max-width:24ch;margin-top:22px;font-size:14px}.login-counter{gap:6px;margin-top:4px;font-size:56px}.login-counter-unit{font-size:18px}.login-counter-live{width:8px;height:8px;box-shadow:0 0 0 3px #82c29b33}.login-since{margin-top:10px;font-size:13.5px}.login-stats{gap:8px;margin-top:22px;padding-top:18px}.login-stat{border-radius:12px;padding:12px 12px 11px}.login-stat-lbl{letter-spacing:.4px;font-size:10px}.login-stat-val{margin-top:6px;font-size:20px}.login-stat-unit{font-size:11px}.login-form-side{padding:28px 20px 36px}.login-card-title{font-size:26px}.login-card-sub{margin-bottom:20px;font-size:13px}.login-input{min-height:46px;font-size:16px}.login-field-label{font-size:11px}}@media (max-width:380px){.login-counter{font-size:48px}.login-counter-unit{font-size:16px}.login-stat-val{font-size:18px}}.login-guest{flex-direction:column;align-items:center;gap:12px;margin-top:24px;display:flex}.login-guest-divider{color:var(--ink-3);letter-spacing:.1em;font-size:12px}.login-guest-link{color:var(--ink);border:1px solid var(--line-2);border-radius:999px;padding:10px 18px;font-size:14px;text-decoration:none;transition:background .15s,border-color .15s,color .15s}.login-guest-link:hover{border-color:var(--ink-3);color:var(--ink);background:#0000000a}
.chat-panel{display:none}@media (min-width:1280px){.chat-panel:not(.fullscreen){width:var(--chat-panel-w,320px);background:var(--paper);border-left:1.5px solid var(--line);z-index:45;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0}.chat-resize-handle{cursor:col-resize;z-index:1;-webkit-user-select:none;user-select:none;touch-action:none;width:8px;position:absolute;top:0;bottom:0;left:-3px}.chat-resize-handle:after{content:"";background:var(--line-2);border-radius:2px;width:2px;height:36px;transition:background .15s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chat-resize-handle:hover:after,.chat-resize-handle.dragging:after{background:var(--peach-deep)}.chat-panel.resizing{-webkit-user-select:none;user-select:none}}.chat-resize-handle{display:none}@media (min-width:1280px){.chat-panel:not(.fullscreen) .chat-resize-handle{display:block}}.chat-panel.fullscreen{background:var(--cream);flex-direction:column;width:100%;height:calc(100dvh - 128px);min-height:320px;display:flex}.chat-panel.fullscreen .chat-head{display:none}.chat-head{border-bottom:1.5px solid var(--line);background:var(--cream-2);align-items:center;gap:10px;padding:16px 18px;display:flex}.chat-head-title{font-family:Jua,sans-serif;font-size:17px}.chat-head-sub{color:var(--ink-3);margin-top:2px;font-size:12px;font-weight:700}.chat-back{border:1px solid var(--line);background:var(--paper);cursor:pointer;border-radius:50%;flex-shrink:0;width:36px;height:36px;font-size:18px}.chat-notice{background:#fff7ef;border-bottom:1.5px solid #e6cbb8;gap:10px;padding:12px 14px;display:flex}.chat-notice-tag{border-radius:var(--r-pill);background:var(--peach-soft);color:#8a4325;border:1px solid #e6b891;flex-shrink:0;align-self:flex-start;padding:4px 8px;font-size:11px;font-weight:800;line-height:1}.chat-notice-body{flex:1;min-width:0}.chat-notice-text{color:var(--ink-1);white-space:pre-wrap;word-break:break-word;font-size:13.5px;font-weight:700;line-height:1.5}.chat-notice-meta{color:var(--ink-3);margin-top:4px;font-size:11px;font-weight:700}.chat-body{background:var(--cream);flex-direction:column;flex:1;gap:8px;padding:14px;display:flex;overflow-y:auto}.chat-load-more{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-pill);color:var(--ink-3);cursor:pointer;align-self:center;margin-bottom:4px;padding:6px 14px;font-size:12px;font-weight:700}.chat-empty{color:var(--ink-3);text-align:center;margin:auto;padding:0 16px;font-size:13px;font-weight:700}.chat-row{align-items:flex-start;gap:8px;display:flex}.chat-row.me{flex-direction:row-reverse}.chat-row.compact{margin-top:-3px}.chat-row-mascot{background:var(--cream-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.chat-row-mascot:empty{background:0 0}.chat-row-mascot-spacer{flex-shrink:0;width:32px;height:1px}.chat-row-body{flex-direction:column;gap:4px;min-width:0;max-width:78%;display:flex}.chat-row.me .chat-row-body{align-items:flex-end}.chat-row-name{min-width:0;max-width:100%;color:var(--ink-3);flex-wrap:wrap;align-items:center;gap:5px;margin-left:4px;font-size:11.5px;font-weight:900;line-height:1.25;display:flex}.chat-row-user-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;overflow:hidden}.chat-row.me .chat-row-name{justify-content:flex-end;margin-left:0;margin-right:4px}.chat-row-goal{color:#9e4625;overflow-wrap:anywhere;white-space:normal;background:#d66a3a17;border:1px solid #d66a3a2e;border-radius:999px;max-width:100%;padding:2px 6px;font-size:11px;font-weight:800;display:inline-flex}.chat-row-bubble-wrap{align-items:flex-end;gap:6px;display:flex}.chat-row.me .chat-row-bubble-wrap{flex-direction:row-reverse}.chat-bubble{background:var(--paper);border:1px solid var(--line);word-break:break-word;white-space:pre-wrap;color:var(--ink-1);border-radius:14px;padding:9px 13px;font-size:14px;line-height:1.45}.chat-bubble.me{background:var(--peach-soft);border-color:var(--peach);color:#5a321f}.chat-bubble.deleted{color:var(--ink-3);background:var(--cream-2);border-style:dashed;font-style:italic}.chat-bubble.has-image{max-width:230px;padding:5px}.chat-message-text{padding:6px 8px 4px}.chat-image-message{cursor:zoom-in;background:0 0;border:0;border-radius:10px;width:100%;padding:0;display:block;overflow:hidden}.chat-image-message img{object-fit:cover;border-radius:10px;width:100%;max-height:280px;display:block}.chat-row-meta{color:var(--ink-3);white-space:nowrap;align-items:center;gap:6px;font-size:10.5px;font-weight:700;display:flex}.chat-del-btn{color:var(--ink-3);cursor:pointer;background:0 0;border:none;padding:0;font-size:10.5px;font-weight:700;text-decoration:underline}.chat-del-btn:hover{color:#c85c5c}.chat-jump-latest{background:var(--ink-1,#2d2d2d);color:#fff;border:1.5px solid var(--ink-1,#2d2d2d);cursor:pointer;z-index:5;border-radius:999px;align-self:center;align-items:center;gap:8px;margin:-22px auto 6px;padding:6px 14px;font-size:12.5px;font-weight:700;display:inline-flex;position:relative;box-shadow:0 4px 12px #0000002e}.chat-jump-latest:hover{opacity:.92}.chat-jump-latest-count{white-space:nowrap}.chat-input-bar{border-top:1.5px solid var(--line);padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:var(--paper);flex-direction:column;gap:6px;display:flex}.chat-input-row{align-items:flex-end;gap:8px;display:flex}.chat-file-input{display:none}.chat-attach{border:1.5px solid var(--line-2);background:var(--cream-2);width:38px;height:38px;color:var(--ink-2);cursor:pointer;border-radius:50%;flex-shrink:0;font-size:22px;line-height:1}.chat-attach:disabled{opacity:.45;cursor:not-allowed}.chat-input{resize:none;border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--cream-2);outline:none;flex:1;min-height:38px;max-height:120px;padding:9px 12px;font-family:inherit;font-size:14px;line-height:1.4}.chat-input:focus{border-color:var(--peach);background:var(--paper)}.chat-send{background:var(--peach-deep);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;width:38px;height:38px;font-size:16px}.chat-send:disabled{opacity:.4;cursor:not-allowed}.chat-input-meta{color:var(--ink-3);justify-content:space-between;font-size:11px;font-weight:700;display:flex}.chat-error{background:var(--peach-soft);color:#9e4625;border-radius:var(--r-md);padding:6px 10px;font-size:12px;font-weight:700}.chat-image-preview{border-radius:var(--r-md);border:1px solid var(--line);background:var(--cream-2);align-items:center;gap:10px;padding:8px;display:flex}.chat-image-preview-thumb{background:var(--paper);cursor:zoom-in;border:0;border-radius:10px;flex-shrink:0;width:48px;height:48px;padding:0;overflow:hidden}.chat-image-preview-thumb img{object-fit:cover;width:100%;height:100%;display:block}.chat-image-preview-text{min-width:0;color:var(--ink-2);flex:1;font-size:12px;font-weight:800}.chat-image-remove{color:var(--ink-3);cursor:pointer;background:0 0;border:0;font-size:12px;font-weight:800;text-decoration:underline}.chat-lightbox{z-index:500;cursor:zoom-out;background:#1c1814c7;border:0;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.chat-lightbox img{object-fit:contain;border-radius:var(--r-md);max-width:min(960px,94vw);max-height:88vh;display:block;box-shadow:0 20px 60px #00000052}.chat-badge{background:var(--peach-deep);color:#fff;font-variant-numeric:tabular-nums;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:auto;padding:0 5px;font-size:10.5px;font-weight:800;display:inline-flex}.mobile-tabbar-item .chat-badge{margin-left:0;position:absolute;top:4px;right:14px}
.device-switcher{z-index:40;-webkit-backdrop-filter:blur(14px)saturate(160%);background:#fffdf8c7;border:1px solid #d9c8b88c;border-radius:22px;flex-direction:column;gap:12px;padding:14px 12px;display:none;position:fixed;top:50%;left:32px;transform:translateY(-50%);box-shadow:0 12px 30px #4634261a}@media (min-width:1280px){.device-switcher{display:flex}}.device-switcher-label{letter-spacing:.7px;text-transform:uppercase;color:var(--ink-3);text-align:center;margin-bottom:2px;font-size:10px;font-weight:900}.device-switcher-btn{background:var(--paper);border:1.5px solid var(--line);cursor:pointer;width:86px;color:inherit;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:10px 6px 8px;font-family:inherit;transition:border-color .15s,transform .15s,background .15s;display:flex}.device-switcher-btn:hover{border-color:var(--line-2);transform:translateY(-1px)}.device-switcher-btn.active{border-color:var(--peach-deep);background:var(--peach-soft)}.device-switcher-thumb{background:linear-gradient(#2d2a26,#1f1c18);border-radius:6px;width:28px;height:44px;position:relative;box-shadow:inset 0 0 0 1.5px #ffffff0f}.device-switcher-thumb.iphone:before{content:"";background:#000;border-radius:999px;width:12px;height:4px;position:absolute;top:3px;left:50%;transform:translate(-50%)}.device-switcher-thumb.galaxy:before{content:"";background:#555;border-radius:999px;width:3px;height:3px;position:absolute;top:3px;left:50%;transform:translate(-50%)}.device-switcher-thumb.web{background:var(--cream-2);border:1.5px solid var(--line)}.device-switcher-thumb.web:before{content:"";background:var(--line-2);border-radius:3px;height:6px;position:absolute;top:4px;left:4px;right:4px}.device-switcher-name{color:var(--ink-2);font-family:Jua,sans-serif;font-size:11px;line-height:1}.device-switcher-btn.active .device-switcher-name{color:#9e4625}.device-switcher-sub{color:var(--ink-3);letter-spacing:.2px;margin-top:-2px;font-size:9px;font-weight:800}.device{--device-h:100vh;width:100%;max-width:432px;height:var(--device-h);flex-direction:column;transition:padding .35s,border-radius .35s,background .35s,box-shadow .35s;display:flex;position:relative}.device-screen{background:var(--paper);flex-direction:column;flex:1;min-height:0;transition:border-radius .35s;display:flex;position:relative;overflow:hidden}.device.iphone:after,.device.galaxy:after{content:"";z-index:2;pointer-events:none;background:var(--device-frame-image) center / 100% 100% no-repeat;position:absolute;inset:0}.device.iphone .device-screen,.device.galaxy .device-screen{z-index:1;inset:var(--screen-inset-top) var(--screen-inset-right) var(--screen-inset-bottom) var(--screen-inset-left);flex:none;position:absolute}.device.iphone{--device-w:min(432px, calc(100vh * 365 / 750));--device-frame-image:url(/devices/iphone.png);--screen-inset-top:calc(var(--device-w) * 13 / 365);--screen-inset-right:calc(var(--device-w) * 16 / 365);--screen-inset-bottom:calc(var(--device-w) * 13 / 365);--screen-inset-left:calc(var(--device-w) * 16 / 365);width:var(--device-w);aspect-ratio:365/750;filter:drop-shadow(0 30px 60px #46342647)drop-shadow(0 10px 24px #46342629);background:0 0;height:auto}.device.iphone .device-screen{border-radius:38px}.device.galaxy{--device-w:min(432px, calc(100vh * 660 / 1430));--device-frame-image:url(/devices/galaxy.png);--screen-inset-top:calc(var(--device-w) * 38 / 660);--screen-inset-right:calc(var(--device-w) * 42 / 660);--screen-inset-bottom:calc(var(--device-w) * 38 / 660);--screen-inset-left:calc(var(--device-w) * 38 / 660);width:var(--device-w);aspect-ratio:660/1430;filter:drop-shadow(0 30px 60px #46342647)drop-shadow(0 10px 24px #46342629);background:0 0;height:auto}.device.galaxy .device-screen{border-radius:30px}.device.web{background:0 0;border-radius:28px;padding:0;box-shadow:0 30px 80px -20px #4634262e,0 8px 24px -8px #4634261a}.device.web .device-screen{border-radius:28px}.device-status-bar{color:var(--ink);z-index:5;background:var(--paper);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 28px 10px;font-family:-apple-system,SF Pro,system-ui,Pretendard,sans-serif;font-size:14px;font-weight:600;display:flex;position:relative}.device.iphone .device-status-bar{padding:18px 36px 10px}.device.galaxy .device-status-bar{padding:14px 22px 8px;font-size:13px}.device.web .device-status-bar{display:none}.device-status-bar .icons{align-items:center;gap:6px;display:flex}.device-status-bar svg{display:block}.device-screen .mobile-frame{width:100%;max-width:none;height:auto;min-height:0;box-shadow:none;background:0 0;border-radius:0;flex:1}@media (max-width:720px){.device{max-width:none;height:auto;aspect-ratio:auto!important;box-shadow:none!important;filter:none!important;background:0 0!important;border-radius:0!important;padding:0!important}.device .device-status-bar{display:none!important}.device-screen{overflow:visible;border-radius:0!important}.device-screen .mobile-frame{box-shadow:none;border-radius:0;height:auto;min-height:100dvh}}
