:root{--brand: #6e56cf;--points: #f2b233;--bg: #faf8ff;--surface: #ffffff;--ink: #2b2540;--muted: #8a82a6;--hairline: #ece8f5;--lead: #2fb87a;--behind: #e06b6b;--avatar-purple: #6e56cf;--avatar-turquoise: #2ebfbf;--avatar-coral: #e06b6b;--avatar-amber: #f2b233;--avatar-mint: #2fb87a;--avatar-rose: #d86bb8;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 24px;--font-display: "DM Sans", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);font-feature-settings:"tnum" 1;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.015em;margin:0}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--radius-sm)}.muted{color:var(--muted)}.eyebrow{font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--muted);margin:0}.link{background:none;border:none;padding:0;color:var(--brand);font-size:14px;text-decoration:underline}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app{min-height:100%;display:flex;flex-direction:column}.content-wrap{flex:1;padding-bottom:110px}.page{max-width:560px;margin:0 auto;padding:24px 20px 8px;display:flex;flex-direction:column;gap:20px}.card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:20px}.profile{min-height:100%;padding:32px 20px 48px;max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.profile header h1{font-size:32px;letter-spacing:-.01em}.profile header p{margin:4px 0 0;color:var(--muted)}.avatar-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.avatar-grid button{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px 20px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);transition:transform .12s ease,border-color .12s ease}.avatar-grid button:hover{border-color:var(--brand);transform:translateY(-2px)}.avatar-grid button:active{transform:translateY(0)}.avatar-grid span{font-family:var(--font-display);font-weight:700;font-size:18px}.placeholder{padding:24px}.home-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.home-header h1{font-size:28px;letter-spacing:-.01em}.home-header .link{margin-top:4px}.week-card{display:flex;flex-direction:column;gap:14px}.week-card-head{display:flex;justify-content:space-between;align-items:center}.ranking{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.ranking-row{display:grid;grid-template-columns:28px 24px 1fr auto auto;gap:10px;align-items:center;padding:10px 6px;border-radius:var(--radius-md)}.ranking-row.me{background:#6e56cf0f}.ranking-row.flash{animation:leader-flash 1.4s ease-out}@keyframes leader-flash{0%{background:#2fb87a00;box-shadow:0 0 #2fb87a00}20%{background:#2fb87a38;box-shadow:0 0 0 6px #2fb87a2e}to{background:#2fb87a00;box-shadow:0 0 #2fb87a00}}@media (prefers-reduced-motion: reduce){.ranking-row.flash{animation:none}}.ranking-pos{font-family:var(--font-display);font-weight:700;color:var(--muted)}.ranking-dot{width:22px;height:22px;border-radius:50%}.ranking-name{font-weight:500;display:flex;gap:6px;align-items:baseline}.gap{font-size:13px;font-weight:500;padding-left:8px;font-variant-numeric:tabular-nums}.gap.lead{color:var(--lead)}.gap.behind{color:var(--behind)}.quick{display:flex;flex-direction:column;gap:10px}.quick-head{display:flex;justify-content:space-between;align-items:baseline}.quick-head .hint{font-size:12px}.quick-card[aria-busy=true]{opacity:.6}.quick-card:disabled{cursor:default}.quick-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.quick-card{display:grid;grid-template-columns:32px 1fr auto;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden;transition:border-color .16s ease,background .16s ease}.quick-card-action{display:grid;grid-template-columns:subgrid;grid-column:1 / -1;align-items:center;gap:12px;padding:14px 16px;background:transparent;border:none;text-align:left;width:100%}.quick-card-action:hover:not(:disabled){background:#6e56cf0a}.quick-card[aria-busy=true],.quick-card-action[aria-busy=true]{opacity:.55}.quick-card:has(.quick-card-action:disabled){cursor:default}.quick-emoji{font-size:22px;line-height:1}.quick-emoji.check{font-family:var(--font-display);font-weight:700;color:var(--lead);font-size:20px;padding-left:16px}.quick-name{font-size:15px;font-weight:500}.quick-card.confirmed{background:#2fb87a14;border-color:#2fb87a59;padding:14px 16px;animation:confirmed-in .22s cubic-bezier(.2,.8,.2,1)}@keyframes confirmed-in{0%{background:#2fb87a38}to{background:#2fb87a14}}@media (prefers-reduced-motion: reduce){.quick-card.confirmed{animation:none}}.undo-btn{background:none;border:1px solid var(--brand);color:var(--brand);font-weight:700;padding:6px 14px;border-radius:999px;font-size:13px}.undo-btn:hover:not(:disabled){background:#6e56cf14}.undo-btn:disabled{opacity:.5}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--hairline);padding:8px 8px calc(env(safe-area-inset-bottom,0px) + 8px);display:grid;grid-template-columns:1fr 1fr 72px 1fr 1fr;align-items:center;z-index:10}.tab{display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none;color:var(--muted);font-size:11px;font-weight:500;padding:6px 0;border-radius:var(--radius-sm);transition:color .12s ease}.tab.active{color:var(--brand)}.tab-icon{font-size:22px;line-height:1}.fab{width:60px;height:60px;border-radius:50%;background:var(--points);color:#fff;border:none;font-family:var(--font-display);font-weight:500;font-size:32px;line-height:1;margin:-28px auto 0;box-shadow:0 8px 18px #f2b23373;display:grid;place-items:center;transition:transform .12s ease}.fab:active{transform:translateY(2px)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2b254073;z-index:20;display:flex;align-items:flex-end;justify-content:center;animation:fade-in .16s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.sheet{width:100%;max-width:560px;max-height:92vh;background:var(--bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slide-up .22s cubic-bezier(.2,.8,.2,1)}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-head{position:relative;padding:16px 20px;border-bottom:1px solid var(--hairline);background:var(--surface);display:flex;align-items:center;justify-content:center}.sheet-head h2{font-size:18px}.sheet-close{position:absolute;left:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:28px;line-height:1;color:var(--muted);width:36px;height:36px;border-radius:50%}.sheet-body{flex:1;overflow-y:auto;padding:16px 20px 24px;display:flex;flex-direction:column;gap:20px}.sheet-section{display:flex;flex-direction:column;gap:10px}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--surface);border:1px solid var(--hairline);border-radius:999px;font-weight:500}.chip.active{border-color:var(--brand);color:var(--brand);background:#6e56cf0f}.chip-dot{width:14px;height:14px;border-radius:50%}.day-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.day{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md)}.day:disabled{opacity:.35}.day.active{border-color:var(--brand);color:var(--brand);background:#6e56cf14}.day.today{font-weight:600}.day-letter{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.06em}.day.active .day-letter{color:var(--brand)}.day-num{font-family:var(--font-display);font-weight:700;font-size:18px}.search{width:100%;padding:10px 14px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--surface)}.catalog{display:flex;flex-direction:column;gap:4px}.catalog details{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}.catalog summary{list-style:none;cursor:pointer;padding:12px 14px;font-weight:500;display:flex;align-items:center;gap:8px}.catalog summary::-webkit-details-marker{display:none}.catalog summary .badge{margin-left:auto;color:var(--brand)}.task-list{list-style:none;margin:0;padding:0 0 8px;border-top:1px solid var(--hairline)}.task-row{display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;padding:10px 14px;cursor:pointer}.task-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--brand)}.task-row.checked{background:#6e56cf0a}.task-name{font-size:15px}.sheet-foot{border-top:1px solid var(--hairline);background:var(--surface);padding:12px 20px calc(env(safe-area-inset-bottom,0px) + 12px);display:flex;align-items:center;gap:12px}.sheet-total{display:flex;flex-direction:column;gap:0}.cta{flex:1;background:var(--points);color:#fff;font-family:var(--font-display);font-weight:700;font-size:16px;border:none;border-radius:var(--radius-md);padding:14px 18px;box-shadow:0 6px 14px #f2b23366;transition:transform .12s ease,opacity .12s ease}.cta:disabled{opacity:.4;box-shadow:none}.cta:not(:disabled):active{transform:translateY(1px)}.sheet-confirm{padding:48px 24px 64px;display:flex;flex-direction:column;align-items:center;gap:16px}.sheet-confirm h2{font-size:24px}.rewards-head{display:flex;justify-content:space-between;align-items:center;gap:16px}.rewards-head .eyebrow{margin-bottom:4px}.rewards-head p{margin:0}.rewards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.reward-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.reward-card.locked{opacity:.65}.reward-emoji{font-size:32px;line-height:1}.reward-emoji.big{font-size:64px}.reward-name{font-weight:500;font-size:15px;line-height:1.2}.cta.secondary{background:var(--surface);color:var(--brand);border:1px solid var(--hairline);box-shadow:none;padding:10px 14px;font-size:14px;width:100%;margin-top:auto}.cta.secondary:not(:disabled):hover{border-color:var(--brand)}.history-card[open] summary{margin-bottom:12px}.history-card summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:500}.history-card summary::-webkit-details-marker{display:none}.redemption-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.redemption-list li{display:grid;grid-template-columns:32px 1fr auto auto;gap:10px;align-items:center;padding:6px 0;border-top:1px solid var(--hairline)}.redemption-list li:first-child{border-top:none}.redemption-list .reward-emoji{font-size:22px}.confirm-modal{width:calc(100% - 40px);max-width:420px;margin:auto;background:var(--surface);border-radius:var(--radius-lg);padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;animation:pop-in .2s cubic-bezier(.2,.8,.2,1)}@keyframes pop-in{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.confirm-modal h2{font-size:22px}.confirm-modal p{display:inline-flex;flex-wrap:wrap;gap:4px;align-items:baseline;justify-content:center;margin:0}.confirm-actions{display:flex;gap:10px;width:100%}.confirm-actions .cta{flex:1}.confirm-modal.celebrate{padding:36px 24px 44px}.cta.danger{background:var(--behind);color:#fff;box-shadow:0 6px 14px #e06b6b66}.icon-btn{background:none;border:none;color:var(--muted);width:32px;height:32px;border-radius:50%;font-size:18px;display:grid;place-items:center;transition:background .12s ease,color .12s ease}.icon-btn:hover{background:var(--hairline);color:var(--ink)}.icon-btn.danger:hover{color:var(--behind)}.day-card{display:flex;flex-direction:column;gap:10px}.day-card-head{display:flex;justify-content:space-between;align-items:center}.day-label{font-family:var(--font-display);font-weight:700;text-transform:capitalize}.log-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.log-row{display:grid;grid-template-columns:28px 1fr auto 32px;gap:10px;align-items:center;padding:10px 0;border-top:1px solid var(--hairline)}.log-row:first-child{border-top:none}.log-emoji{font-size:20px}.log-main{display:flex;flex-direction:column;gap:2px;min-width:0}.log-name{font-size:15px;font-weight:500}.log-meta{font-size:12px;display:flex;align-items:center;gap:6px}.settings-tabs{display:grid;grid-template-columns:repeat(4,1fr);background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:4px;gap:2px}.settings-tab{background:none;border:none;padding:8px 6px;font-weight:500;font-size:13px;color:var(--muted);border-radius:var(--radius-sm)}.settings-tab.active{background:#6e56cf1a;color:var(--brand)}.settings-list{display:flex;flex-direction:column;gap:12px}.catalog-cat{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);overflow:hidden}.catalog-cat>summary{list-style:none;cursor:pointer;padding:12px 14px;font-weight:500;display:flex;align-items:center;gap:8px}.catalog-cat>summary::-webkit-details-marker{display:none}.settings-row{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:8px;align-items:center;padding:8px 14px;border-top:1px solid var(--hairline)}.settings-rows{list-style:none;margin:0;padding:0;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md)}.settings-rows .settings-row:first-child{border-top:none}.add-row{background:var(--surface);border:1px dashed var(--hairline);border-radius:var(--radius-md);padding:12px;color:var(--brand);font-weight:500;width:100%;text-align:center;transition:border-color .12s ease,background .12s ease}.add-row:hover{border-color:var(--brand);background:#6e56cf0a}.edit-modal{align-items:stretch;text-align:left;padding:20px;max-width:460px}.edit-modal-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px}.edit-modal-head h2{font-size:20px}.edit-modal-body{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted)}.field input,.field select{padding:10px 12px;border:1px solid var(--hairline);border-radius:var(--radius-md);background:var(--surface);color:var(--ink);font-size:15px}.field input:focus-visible,.field select:focus-visible{outline:2px solid var(--brand);outline-offset:1px}.color-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.color-pick{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:10px;display:grid;place-items:center}.color-pick.active{border-color:var(--brand);background:#6e56cf0f}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(env(safe-area-inset-bottom,0px) + 96px);z-index:30;background:var(--ink);color:var(--surface);padding:12px 16px;border-radius:999px;display:flex;align-items:center;gap:16px;box-shadow:0 12px 32px #2b254040;max-width:calc(100% - 32px);font-size:14px;font-weight:500}.toast-msg{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-action{background:none;border:none;color:var(--points);font-family:var(--font-display);font-weight:700;font-size:14px;padding:4px 4px 4px 12px;border-left:1px solid rgba(255,255,255,.18);flex-shrink:0}
