:root{--bg-top: #fcf8f0;--bg-bottom: #ecf5e8;--surface: #fffefa;--surface-muted: #f3f7f0;--surface-soft: #eaf3e7;--border: #d6e2d2;--brand: #3f8a63;--brand-press: #34724f;--text-main: #2f3a31;--text-sub: #6f7a6f;--text-light: #7a8377;--warning: #a35b36;--warning-bg: #fff3ee;--warning-border: #e8c9b8}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,PingFang SC,Noto Sans SC,sans-serif;color:var(--text-main);background:linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bottom) 100%)}button,input{font:inherit}.shell-background{min-height:100dvh}.mobile-shell{width:100%;min-height:100dvh;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);background:linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bottom) 100%)}.mobile-scroll{flex:1;overflow-y:auto;padding:16px 16px calc(120px + env(safe-area-inset-bottom))}.tab-shell{padding:12px 21px calc(21px + env(safe-area-inset-bottom));background:#f4f7f1}.tab-pill{width:100%;height:62px;display:grid;grid-template-columns:repeat(4,1fr);gap:3px;padding:4px;border-radius:36px;border:1px solid #d3dece;background:var(--surface)}.tab-item{border:none;border-radius:26px;background:var(--surface);color:#7a8398;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;cursor:pointer}.tab-item.active{background:var(--brand);color:#fff;box-shadow:0 4px 10px #3f8a6333}.tab-icon{font-size:12px;line-height:1}.tab-label{font-size:10px;line-height:1;font-weight:600;letter-spacing:.5px}.screen-content{display:flex;flex-direction:column;gap:14px}.page-title{margin:0;font-size:25px;line-height:1.25;color:var(--text-main)}.page-subtitle{margin:0;color:var(--text-sub);font-size:14px;line-height:1.45}.card{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:16px;display:flex;flex-direction:column;gap:12px}.card-title{margin:0;font-size:15px;line-height:1.3;color:#304033}.card-copy{margin:0;color:var(--text-sub);font-size:13px;line-height:1.45}.row-between{display:flex;justify-content:space-between;align-items:center;gap:8px}.tiny-text{font-size:13px;color:var(--text-sub);font-weight:600}.action-copy{color:var(--brand);font-size:13px;font-weight:700}.weight-panel{gap:14px}.weight-input-box{background:#f2f6ee;border-radius:16px;min-height:54px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.weight-input{border:none;background:transparent;width:100%;color:#1a1d27;font-size:24px;font-weight:700;outline:none}.unit-text{color:#6f7890;font-size:14px;font-weight:600}.quick-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.quick-chip{background:#e4f1e6;border:1px solid #c8dccb;color:var(--brand);border-radius:10px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600}.quick-chip-muted{color:#5f6980}.primary-btn,.secondary-btn{width:100%;border:none;border-radius:18px;min-height:52px;font-size:15px;font-weight:700;cursor:pointer}.primary-btn{background:var(--brand);color:#fffdf7;box-shadow:0 6px 14px #2d6b4a40}.primary-btn:active{background:var(--brand-press)}.secondary-btn{background:var(--surface-soft);border:1px solid #c9dbc8;color:var(--brand)}.primary-btn:disabled,.secondary-btn:disabled,.entry-row:disabled{opacity:.55;cursor:not-allowed}.button-inline{min-height:40px;border-radius:14px;font-size:14px}.inline-note,.mutual-note{margin:0;color:var(--text-light);font-size:12px;line-height:1.45}.mutual-note{font-weight:600}.retro-entry{display:flex;align-items:center;justify-content:space-between;min-height:44px;border-radius:14px;border:1px solid #c7dbc9;background:#f1f7ef;padding:0 12px;font-size:14px;color:var(--brand);font-weight:700}.retro-entry-button{width:100%;border:none;cursor:pointer}.retro-entry-value{color:#304033;font-size:15px;font-weight:700}.picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:flex-end;justify-content:center;padding:12px 12px calc(12px + env(safe-area-inset-bottom));background:#1b28216b}.picker-sheet{width:100%;max-width:380px;border-radius:22px;border:1px solid var(--border);background:var(--surface);padding:14px;display:flex;flex-direction:column;gap:12px}.picker-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.picker-title{margin:0;font-size:16px;font-weight:700;color:#304033}.picker-close{border:none;background:transparent;color:var(--brand);font-size:13px;font-weight:700;cursor:pointer}.picker-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.date-option{min-height:56px;border-radius:14px;border:1px solid #cfddcb;background:#f7fbf5;color:#314236;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer}.date-option-main{font-size:14px;font-weight:700}.date-option-sub{font-size:11px;color:#6f7a6f;font-weight:600}.date-option.active{border-color:var(--brand);background:#e5f1e7}.date-option.active .date-option-main,.date-option.active .date-option-sub{color:var(--brand)}.picker-today{min-height:40px;border:1px solid #c9dbc8;border-radius:12px;background:var(--surface-soft);color:var(--brand);font-size:14px;font-weight:700;cursor:pointer}.notice-banner{margin:0;border-radius:12px;padding:10px 12px;border:1px solid transparent;font-size:12px;line-height:1.45}.notice-success{color:#225d41;background:#ebf8f0;border-color:#c6e5d3}.notice-error{color:var(--warning);background:var(--warning-bg);border-color:var(--warning-border)}.notice-neutral{color:#54605b;background:#f3f7f0;border-color:#d6e2d2}.range-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.range-chip{min-height:34px;border:none;border-radius:14px;background:var(--surface-soft);color:#5f6980;font-size:13px;font-weight:600;cursor:pointer}.range-chip.active{background:var(--brand);color:#fff;box-shadow:0 4px 10px #3f8a6333}.state-card{border-radius:20px;border:1px solid var(--border);background:var(--surface);padding:14px;display:flex;flex-direction:column;gap:8px}.state-card-error{background:var(--warning-bg);border-color:var(--warning-border)}.state-title{margin:0;font-size:14px;color:#304033}.state-card-error .state-title,.state-card-error .state-copy{color:var(--warning)}.state-copy{margin:0;font-size:12px;color:var(--text-sub);line-height:1.45}.chart-card{gap:10px}.chart-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.chart-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.target-copy{color:var(--brand);font-size:13px;font-weight:600}.unit-copy{color:#6a748c;font-size:12px;font-weight:600}.chart-surface{border-radius:14px;background:#f5f8f2;border:1px solid #e3ece0;overflow:hidden}.trend-svg{width:100%;display:block}.trend-grid-line{stroke:#d5e1d3;stroke-width:1}.trend-target-line{stroke:#d27a4a;stroke-width:2;stroke-dasharray:5 5}.trend-main-line{fill:none;stroke:#3f8a63;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.trend-avg-line{fill:none;stroke:#9ccfaf;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.trend-point-dot{fill:#3f8a63}.trend-axis-label{font-size:10px;fill:#7a8398;font-weight:600}.warning-note{margin:0;color:#8a6a45;font-size:12px}.button-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.leaderboard-list{display:flex;flex-direction:column;gap:10px}.leaderboard-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.leaderboard-name{color:#304033;font-size:14px;font-weight:600}.leaderboard-value{color:var(--brand);font-size:14px;font-weight:700}.top-action-row{display:flex;justify-content:space-between;align-items:center;min-height:24px}.text-link{border:none;background:transparent;color:var(--brand);font-size:13px;font-weight:700;padding:0;cursor:pointer}.top-action-title{color:var(--text-main);font-size:14px;font-weight:700}.form-card{gap:10px}.form-grid{display:flex;flex-direction:column;gap:10px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.field-label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-sub);font-weight:600}.text-input{min-height:40px;border:1px solid #cfddcb;background:#f7fbf5;border-radius:12px;padding:0 10px;color:var(--text-main);outline:none}.text-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #3f8a6326}.switch-label{color:#304033;font-size:14px;font-weight:600}.switch-btn{width:46px;height:26px;border:none;border-radius:999px;padding:2px;display:flex;align-items:center;transition:background-color .16s ease;cursor:pointer}.switch-btn.on{background:var(--brand);justify-content:flex-end}.switch-btn.off{background:#ccd6ca;justify-content:flex-start}.switch-thumb{width:22px;height:22px;border-radius:999px;background:#fff;box-shadow:0 1px 3px #0f172a33}.entry-row{width:100%;min-height:34px;border:1px solid var(--border);border-radius:10px;background:var(--surface-muted);display:flex;justify-content:space-between;align-items:center;gap:8px;padding:0 10px;font-size:13px;color:#304033;font-weight:600;cursor:pointer}.entry-row span:last-child{color:var(--brand);font-weight:700}.compliance-card{gap:8px;border-radius:18px}.entry-row.danger{background:#fff4ee;border-color:#f1d4c5;color:var(--warning)}.entry-row.danger span:last-child{color:var(--warning)}.legal-list{margin:0;padding-left:16px;display:flex;flex-direction:column;gap:8px;color:#435347;font-size:13px;line-height:1.5}
