:root{font-family:sans-serif;color-scheme:light}*{-webkit-tap-highlight-color:transparent}html,body{margin:0;min-width:320px;min-height:100vh;background-color:#fff;color:#333d4b}@media(min-width:481px){body{display:flex;justify-content:center;align-items:flex-start;background-color:#f5f5f5}}#root{width:100%;min-height:100vh;box-sizing:border-box;padding:calc(24px + env(safe-area-inset-top)) calc(24px + env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) calc(24px + env(safe-area-inset-left))}@media(min-width:481px){#root{background-color:#fff;max-width:480px;margin:0 auto}}.error-fallback{display:flex;flex-direction:column;align-items:center;gap:12px;padding:64px 0;text-align:center}.error-title{font-size:18px;font-weight:700}.error-desc{color:#6b7280;font-size:14px}.app{display:flex;flex-direction:column}.app-header{display:flex;flex-direction:column;gap:8px;padding:24px 0 8px}.page-title{margin:0;font-size:24px;font-weight:700;color:#333d4b}.page-subtitle{margin:0;font-size:16px;color:#8b95a1}.loading{padding:48px 0;text-align:center;font-size:16px;color:#8b95a1}.section-title{margin:0 0 12px;font-size:15px;font-weight:600;color:#4e5968}.app-button{width:100%;border:none;border-radius:16px;padding:18px;font-size:17px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.app-button:active{transform:scale(.97);transition:transform .1s ease}.app-button:disabled{opacity:.5;cursor:default}.app-button-primary-on{background-color:#3182f6;color:#fff}.app-button-ghost{background-color:#f2f4f6;color:#4e5968}.app-button-danger-on{background-color:#e5484d;color:#fff}.text-button{align-self:center;margin-top:12px;background:none;border:none;padding:8px 12px;font-size:14px;font-weight:600;color:#8b95a1;cursor:pointer}.text-button:disabled{opacity:.4;cursor:default}.text-button-danger{color:#e5484d}.stats{display:flex;gap:12px;padding:24px 0 8px}.stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;background-color:#f9fafb;border-radius:16px}.stat-num{font-size:26px;font-weight:700;color:#333d4b;font-variant-numeric:tabular-nums}.stat-label{font-size:13px;color:#8b95a1}.manage{display:flex;flex-direction:column;align-items:center;padding:24px 0 8px}.confirm-box{width:100%;margin-top:12px;padding:16px;background-color:#f9fafb;border-radius:16px;box-sizing:border-box}.confirm-text{margin:0 0 12px;font-size:15px;color:#4e5968;text-align:center}.confirm-btns{display:flex;gap:12px}.onboarding{min-height:calc(100vh - 48px);justify-content:space-between}.onboarding-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px}.onboarding-mark{font-size:72px;line-height:1}.onboarding-title{margin:0;font-size:28px;font-weight:800;color:#333d4b}.onboarding-desc{margin:0;font-size:17px;line-height:1.5;color:#4e5968}.onboarding-start{margin-bottom:8px}.water-card{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:16px;padding:24px 20px 20px;background-color:#f4f9ff;border-radius:24px}.water-message{margin:0;font-size:16px;font-weight:600;color:#4e5968;text-align:center}.water-tap{width:200px;height:200px;border:none;border-radius:50%;background:radial-gradient(circle at 50% 38%,#5a9cff,#3182f6 70%);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;box-shadow:0 12px 28px #3182f652;-webkit-user-select:none;user-select:none}.water-tap:active{transform:scale(.95);transition:transform .1s ease}.water-drop{font-size:34px;line-height:1;display:inline-block;animation:drop-pop .35s ease}@keyframes drop-pop{0%{transform:scale(.4);opacity:.2}60%{transform:scale(1.25);opacity:1}to{transform:scale(1)}}.water-count{display:flex;align-items:baseline;gap:2px}.water-count-num{font-size:56px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.water-count-unit{font-size:22px;font-weight:700}.water-goal{font-size:13px;font-weight:600;color:#ffffffd9}.goal-bar{width:100%;height:10px;background-color:#dbe9ff;border-radius:999px;overflow:hidden}.goal-bar-fill{height:100%;background-color:#3182f6;border-radius:999px;transition:width .25s ease}.cup-dots{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.cup-dot{width:16px;height:16px;border-radius:50%;background-color:#dbe9ff}.cup-dot-filled{background-color:#3182f6}.cup-extra{font-size:13px;font-weight:700;color:#3182f6}.week-section{padding:28px 0 8px}.week-chart{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:140px;padding:8px 4px 0}.week-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.week-bar-track{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.week-bar-fill{width:70%;max-width:22px;background-color:#c5dcff;border-radius:8px 8px 4px 4px;transition:height .25s ease}.week-bar-today{background-color:#3182f6}.week-bar-value{font-size:12px;font-weight:700;color:#6b7684;font-variant-numeric:tabular-nums;min-height:14px}.week-bar-label{font-size:12px;color:#b0b8c1}.week-bar-label.is-today{color:#3182f6;font-weight:700}.history{padding:12px 0 8px}.history-empty{margin:0;padding:16px;background-color:#f9fafb;border-radius:16px;font-size:14px;color:#8b95a1;text-align:center}.entry-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.entry-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background-color:#f9fafb;border-radius:14px}.entry-date{font-size:15px;color:#4e5968}.entry-cups{font-size:15px;font-weight:700;color:#333d4b;font-variant-numeric:tabular-nums}
