:root{--cream:#fff8ec;--cream-2:#fff2dd;--cream-3:#fdebc8;--paper:#fffdf7;--ink:#3b2e2a;--ink-2:#6b5b55;--ink-3:#a39389;--line:#f3e6cf;--line-2:#edd9b8;--peach:#ffb59a;--peach-deep:#ff9e7a;--peach-soft:#ffe0ce;--mint:#c9e9d7;--mint-deep:#7fcea8;--blush:#ffeef1;--lavender:#f0e8ff;--coral-deep:#c94c70;--pink:#ffe0ce;--pink-deep:#ff9e7a;--yellow:#f5ebd3;--yellow-deep:#b89968;--sky:#e8e0d2;--sky-deep:#8a7860;--lav:#e8e0d2;--lav-deep:#8a7860;--success:#6fc69a;--warning:#f2b556;--danger:#f09090;--r-xs:8px;--r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:22px;--r-pill:999px;--sh-sm:0 1px 2px #785a3c0a;--sh-md:0 2px 8px #785a3c0f;--sh-lg:0 4px 18px #785a3c14;--sh-inset:none;--gap:20px;--pad:24px;--page-pad-x:36px;--page-pad-y:30px}@media (max-width:1024px){:root{--page-pad-x:24px;--page-pad-y:24px}}@media (max-width:640px){: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:640px){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:640px){.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:#d9c4a0}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:768px){.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:640px){.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:#b85030;background:#ffe8dc;border-color:#ffd0b8}.chip.mint{color:#3b7558;background:#e4f1ea;border-color:#c9e0d2}.chip.yellow,.chip.sky,.chip.lav,.chip.gray{color:#6b5b40;background:#f1ebdd;border-color:#e0d5bd}.btn{border-radius:var(--r-pill);border:1.5px solid #0000;align-items:center;gap:8px;min-height:44px;padding:10px 18px;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 2px #af825f1f}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(1px);box-shadow:0 0 #af825f1f}.btn-primary{background:var(--peach-deep);color:#fff}.btn-primary:hover{background:#ff8e66}.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}.grass-cell{background:var(--cream-3);border-radius:4px;width:14px;height:14px;transition:transform .2s}.grass-cell:hover{z-index:2;transform:scale(1.4)}.grass-cell.l1{background:#e9f5ec}.grass-cell.l2{background:#c6e8d0}.grass-cell.l3{background:#8fd1a8}.grass-cell.l4{background:#5db586}.grass-cell.miss{background:#ffe3e3;border:1px dashed #f4b3b3}@media (max-width:640px){.grass-cell{width:11px;height:11px}}
.sidebar{background:var(--paper);border-right:1.5px solid var(--line);z-index:50;flex-direction:column;flex-shrink:0;gap:8px;width:240px;min-height:100vh;padding:26px 18px;display:flex;position:sticky;top:0}.sidebar-item{border-radius:var(--r-md);color:var(--ink-2);cursor:pointer;align-items:center;gap:12px;padding:11px 14px;font-size:14.5px;font-weight:700;transition:background .15s;display:flex}.sidebar-item:hover{background:var(--cream-2)}.sidebar-item.active{background:var(--peach-soft);color:#b35038}.sidebar-item .icon{justify-content:center;align-items:center;width:28px;height:28px;display:flex}@media (max-width:1024px) and (min-width:769px){.sidebar{width:76px;padding:22px 10px}.sidebar-item{justify-content:center;gap:0;padding:11px 8px}.sidebar-item-label,.sidebar-brand-text,.sidebar-user-info,.sidebar-item-dot{display:none}.sidebar>div:first-child{justify-content:center;padding:0 0 16px!important}}.mobile-topbar,.mobile-tabbar{display:none}@media (max-width:768px){.sidebar{display:none}.mobile-topbar{background:var(--paper);border-bottom:1.5px solid var(--line);z-index:40;justify-content:space-between;align-items:center;gap:10px;padding:12px 16px;display:flex;position:sticky;top:0}.mobile-topbar-brand{align-items:center;gap:10px;font-family:Jua,sans-serif;font-size:16px;display:flex}.mobile-topbar-brand-icon{background:linear-gradient(135deg,#ffe5a0,#ff9e7a);border-radius:12px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex;box-shadow:0 2px #af825f2e}.mobile-tabbar{background:var(--paper);border-top:1.5px solid var(--line);z-index:50;padding:6px 4px calc(6px + env(safe-area-inset-bottom));display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 14px #af825f14}.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:11px;font-weight:700;display:flex}.mobile-tabbar-item .icon{font-size:22px;line-height:1}.mobile-tabbar-item.active{color:#b35038}.mobile-tabbar-item.active .icon{transform:scale(1.1)}.mobile-tabbar-item.active:before{content:"";background:var(--peach-deep);border-radius:999px;width:28px;height:3px;position:absolute;top:2px}.app-shell{flex-direction:column!important}main{padding-bottom:calc(76px + env(safe-area-inset-bottom))!important}}.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:768px){.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:#b35038;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:640px){.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}.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:10px;display:flex}.home-today{padding:28px}.home-today-top{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.home-today-kpi{margin-top:6px;font-size:48px}.home-today-mascot{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.home-today-mascot-label{color:var(--ink-3);font-size:12px;font-weight:700}.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:#c8623b}.home-today-progress-meta .pct.met{color:#3b8a63}.home-today-bar{height:14px}.home-mini-stats{grid-template-columns:1fr 1fr;gap:16px;display:grid}.home-mini-stat{border-radius:var(--r-md);border:1px solid var(--line);background:var(--cream-2);padding:14px}.home-mini-stat-icon,.home-mini-stat .icon{margin-bottom:2px;font-size:20px}.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:#b35038;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-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-icon{text-align:right;min-width:18px;font-size:14px}.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-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);background:var(--paper);color:var(--ink-2);cursor:pointer;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}.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:#fff1e8}.home-streak-card .home-section-title h3{font-size:17px}.home-streak-beads{align-items:center;gap:6px;display:flex}.home-streak-bead{border-radius:var(--r-sm);background:var(--paper);border:1px solid var(--line);flex:1;justify-content:center;align-items:center;height:32px;font-size:14px;display:flex}.home-streak-bead.past{border-color:var(--line-2);background:#ffe4b8}.home-streak-bead.today{background:var(--mint);border-color:var(--line-2)}.home-streak-bead.today.at-risk{background:var(--peach-soft);border-color:var(--line-2)}.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:#c8623b;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:#3b8a63}.home-recent-date.miss .dow{color:#c8623b}.home-recent-date .day{color:var(--ink);font-family:Jua,sans-serif;font-size:15px}.home-recent-date.met .day{color:#3b8a63}.home-recent-date.miss .day{color:#c8623b}.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:#3b8a63}.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:#c8623b;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:1024px){.home-grid-main,.home-grid-progress,.home-grid-bottom{grid-template-columns:1fr}}@media (max-width:640px){.home-grid-plan{grid-template-columns:1fr}.home-mini-stats{gap:8px}.home-mini-stat{padding:10px}.home-today-kpi{font-size:38px}.home-today-mascot{transform:scale(.85)}.home-week-progress-ring{width:170px;height:170px}.home-week-progress-pct{font-size:32px}}
.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-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:16px;max-width:780px;margin:0 auto;display:grid}.rank-podium-item{flex-direction:column;align-items:center;gap:10px;min-width:0;display:flex}.rank-podium-avatar-wrap{position:relative}.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:-8px;right:-8px}.rank-podium-name{text-align:center;width:100%}.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}.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:#ffe29a;height:210px}.rank-podium-stand.r2{background:var(--cream-3);height:170px}.rank-podium-stand.r3{background:#f5dcc4;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-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-radius:var(--r-md);border:1px solid var(--line);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-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:#3b8a63}.rank-row-trend.down{color:#c94c70}.rank-row-trend.flat{color:var(--ink-3)}.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:768px){.rank-podium-card{padding:20px 14px}.rank-podium{grid-template-columns:1fr;gap:10px}.rank-podium-stand.r1,.rank-podium-stand.r2,.rank-podium-stand.r3{height:auto;padding:16px}.rank-tab{padding:9px 14px;font-size:12.5px}.rank-list-head{padding:16px 14px 8px}.rank-list-body{padding:0 10px 12px}.rank-reflection{padding:16px}.rank-reflection-grid{grid-template-columns:1fr 1fr}}@media (max-width:640px){.rank-row{gap:10px;padding:10px}.rank-row-mascot{width:40px;height:40px}.rank-row-name{font-size:14px}.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-stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;display:grid}.record-grid-top{grid-template-columns:1fr 1.3fr;gap:20px;margin-bottom:22px;display:grid}.record-grid-bottom{grid-template-columns:1.4fr 1fr;gap:20px;display:grid}.record-stat{border-radius:var(--r-lg);background:var(--cream-2);border:1px solid var(--line);padding:20px}.record-stat .icon{margin-bottom:4px;font-size:26px}.record-stat .label{color:var(--ink-3);font-size:12.5px;font-weight:700}.record-stat .value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:2px;font-family:Jua,sans-serif;font-size:26px}.record-plant-card{background:var(--mint);padding:24px;position:relative;overflow:hidden}.record-plant-title{margin-bottom:6px;font-family:Jua,sans-serif;font-size:18px}.record-plant-sub{color:var(--ink-3);margin-bottom:14px;font-size:12.5px;font-weight:700}.record-plant-visual{text-align:center;padding:8px 0}.record-plant-stage{text-align:center;margin-top:8px}.record-plant-stage .stage{color:#3b8a63;font-family:Jua,sans-serif;font-size:16px}.record-plant-stage .next{color:var(--ink-3);margin-top:4px;font-size:12px;font-weight:700}.record-grass-card{padding:24px}.record-grass-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.record-grass-head h3{letter-spacing:-.015em;white-space:nowrap;margin:0;font-family:Jua,sans-serif;font-size:18px;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{gap:12px;padding-bottom:4px;display:flex;overflow-x:auto}.record-grass-day-labels{flex-direction:column;gap:4px;padding-top:22px;display:flex}.record-grass-day-label{width:18px;height:14px;color:var(--ink-3);align-items:center;font-size:10px;font-weight:700;display:flex}.record-grass-week{flex-direction:column;gap:4px;display:flex}.record-grass-week-label{color:var(--ink-3);text-align:center;width:14px;font-size:10px;font-weight:700}.record-grass-future{background:var(--cream-3);opacity:.5;border-radius:4px;width:14px;height:14px}.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:#6b7aaa}.record-cal-dow .sun{color:#c8623b}.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:#fff3cc}.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-plant-progress{border-radius:var(--r-pill);background:var(--cream-3);height:8px;margin-top:14px;overflow:hidden}.record-plant-progress-fill{background:var(--mint-deep);border-radius:var(--r-pill);height:100%;transition:width .6s}.record-plant-stages{grid-template-columns:repeat(4,1fr);gap:6px;margin:14px 0 0;padding:0;list-style:none;display:grid}.record-plant-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-plant-stages li.active{opacity:1;border-color:var(--mint-deep);background:var(--mint)}.record-plant-stages li .dot{font-size:18px}.record-plant-stages li .range{color:var(--ink-3);font-size:11px;font-weight:700}.record-plant-stages li .name{color:var(--ink-2);font-size:12.5px;font-weight:800}.record-list-card-wide{padding:0;overflow:hidden}@media (max-width:1024px){.record-grid-top,.record-grid-bottom{grid-template-columns:1fr}.record-stats-grid{grid-template-columns:repeat(2,1fr)}.record-plant-stages{grid-template-columns:1fr 1fr}}@media (max-width:768px){.record-plant-card,.record-grass-card,.record-cal-card{padding:16px}.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}}@media (max-width:640px){.record-stats-grid{grid-template-columns:1fr 1fr;gap:10px}.record-stat{padding:14px}.record-stat .value{font-size:20px}}
.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-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{background:#ffcf5c}.admin-conf-fill.low{background:#f2b556}.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:#1a1b2e;border:6px solid #2a2b3e;width:100%;max-height:280px;padding:16px;position:relative;overflow:hidden}.admin-ocr-preview .stamp{color:#9b9db8;font-family:monospace;font-size:10px}.admin-ocr-preview .center{color:#fff;text-align:center;margin-top:12px}.admin-ocr-preview .center .small{color:#9b9db8;margin-bottom:4px;font-size:10px}.admin-ocr-preview .center .big{color:#ffcf5c;font-family:monospace;font-size:28px;font-weight:700}.admin-ocr-preview .row{color:#c8c9dc;background:#2a2b3e;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:#3a3b4e;height:1px;margin:8px 0}.admin-ocr-preview .highlight{pointer-events:none;border:2px dashed #ffcf5c;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:1024px){.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{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:#3b8a63}.admin-num-unpaid{color:var(--coral-deep,#c94c70)}.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)}.season-editor{flex-direction:column;gap:6px;margin-top:6px;display:flex}.season-editor-label{color:var(--ink-3);font-size:12.5px;font-weight:700}.season-editor-row{align-items:center;gap:8px;display:flex}.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:100px;padding:8px 12px;font-family:inherit;font-size:14px;font-weight:700}.season-editor-input:focus{border-color:var(--peach)}.season-editor-err{color:#c94c70;font-size:12px;font-weight:700}.season-editor-ok{color:#3b8a63;font-size:12px;font-weight:700}.admin-upload-wrap{margin-bottom:22px}.admin-weekly-chart-svg{width:100%;height:200px}.admin-row-error{color:var(--coral-deep,#c94c70);margin-right:8px;font-size:12px;font-weight:700}@media (max-width:768px){.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}.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}}
.chat-panel{background:var(--paper);border-left:1.5px solid var(--line);flex-direction:column;flex-shrink:0;width:320px;height:100vh;display:flex;position:sticky;top:0}.chat-panel.fullscreen{border-left:none;width:100%;height:100%;min-height:100dvh;position:relative}@media (max-width:1279px){.chat-panel.fullscreen{top:60px;left:0;right:0;bottom:calc(76px + env(safe-area-inset-bottom));z-index:30;background:var(--cream);width:auto;height:auto;min-height:0;position:fixed}.chat-panel.fullscreen .chat-input-bar{padding-bottom:10px}}.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-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-end;gap:8px;display:flex}.chat-row.me{flex-direction:row-reverse}.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-body{flex-direction:column;gap:2px;max-width:78%;display:flex}.chat-row.me .chat-row-body{align-items:flex-end}.chat-row-name{color:var(--ink-3);margin-left:4px;font-size:11.5px;font-weight:700}.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:#6b2e18}.chat-bubble.deleted{color:var(--ink-3);background:var(--cream-2);border-style:dashed;font-style:italic}.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:#c94c70}.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-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:#b35038;border-radius:var(--r-md);padding:6px 10px;font-size:12px;font-weight:700}@media (max-width:1279px){.chat-panel:not(.fullscreen){display:none}}@media (min-width:1280px){.sidebar-item.chat-only-narrow{display:none}}.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}
html,body{overflow-x:hidden}.app-shell{align-items:flex-start;min-height:100vh;display:flex}.app-main{flex:1;min-width:0}.empty-state{text-align:center;color:var(--ink-3);padding:36px 16px}.sidebar-brand{border-bottom:1px solid var(--line);align-items:center;gap:10px;margin-bottom:14px;padding:0 8px 20px;display:flex}.sidebar-brand-icon{background:var(--peach-soft);border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.sidebar-brand-title{font-family:Jua,sans-serif;font-size:17px;line-height:1}.sidebar-brand-week{color:var(--ink-3);margin-top:5px;font-size:11.5px;font-weight:700}.sidebar-user-info{background:var(--cream-2);border:1px solid var(--line);border-radius:14px;margin-top:auto;padding:14px}.sidebar-user-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.sidebar-user-text{flex:1;min-width:0}.sidebar-user-name{text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:700;overflow:hidden}.sidebar-user-meta{color:var(--ink-3);font-size:11.5px;font-weight:600}.sidebar-item-dot{background:var(--peach-deep);border-radius:50%;width:6px;height:6px;margin-left:auto}.cheer-banner{border:1px solid var(--line);border-radius:16px;align-items:center;gap:16px;padding:18px 22px;display:flex}.cheer-banner-mascot{flex-shrink:0}.cheer-banner-message{color:#3b2e2a;letter-spacing:-.01em;flex:1;font-size:16px;font-weight:700;line-height:1.55}.admin-message{background:var(--paper);border:1px solid var(--line);border-radius:14px;align-items:stretch;gap:14px;margin-bottom:18px;padding:12px 18px;display:flex}.admin-message-body{flex:1;min-width:0}.admin-message-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.admin-message-label{color:var(--ink-3);letter-spacing:.4px;text-transform:uppercase;font-size:11.5px;font-weight:800}.admin-message-text{color:var(--ink);white-space:pre-wrap;word-break:break-word;margin-top:4px;font-size:14.5px;font-weight:600;line-height:1.55}.admin-message-edit-btn{min-height:26px;padding:4px 10px;font-size:11.5px}.admin-message-editor{flex-direction:column;gap:8px;margin-top:6px;display:flex}.admin-message-textarea{resize:vertical;border-radius:var(--r-md);border:1.5px solid var(--line-2);background:var(--cream-2);outline:none;width:100%;min-height:60px;padding:9px 12px;font-family:inherit;font-size:14px;line-height:1.5}.admin-message-textarea:focus{border-color:var(--peach);background:var(--paper)}.admin-message-actions{justify-content:flex-end;gap:6px;display:flex}.admin-message-err{background:var(--peach-soft);color:#b35038;border-radius:var(--r-md);padding:6px 10px;font-size:12px;font-weight:700}.me-tag{color:var(--coral-deep,#c94c70);margin-left:4px;font-size:11px;font-weight:700}
