:root{color:#18232c;background:#eef4f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#eef4f2}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:wait;opacity:.7}.app-shell{width:min(1180px,calc(100% - 28px));margin:0 auto;padding:18px 0 28px}.topbar,.tabs,.settings-panel,.progress-panel,.allowance-panel,.goal-panel,.day-card{border:1px solid #d4ded9;border-radius:8px;background:#fff;box-shadow:0 10px 30px #31455314}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 18px}.eyebrow{margin:0 0 2px;color:#0b8f83;font-size:13px;font-weight:700}h1,h2,h3,p{margin:0}h1{color:#18232c;font-size:30px;line-height:1.1}.topbar span,.norm-row,.metric-row span,.day-toggle span,footer{color:#64737c}.icon-button,.save-button,.tabs button,.preset-button,.day-toggle,.event-row button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:8px}.icon-button{width:44px;height:44px;color:#fff;background:#166f67}.tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:14px;padding:8px}.tabs button{min-height:44px;border:1px solid transparent;color:#52626c;background:#f8fbfa;font-weight:800}.tabs button.active{border-color:#0b8f83;color:#fff;background:#0b8f83}.settings-panel{display:grid;grid-template-columns:auto minmax(180px,1fr) minmax(160px,260px) auto;gap:12px;align-items:end;margin-top:14px;padding:14px}.panel-title,.section-heading{display:flex;align-items:center;gap:8px;color:#26333c;font-weight:800}label{display:grid;gap:5px;color:#52626c;font-size:13px;font-weight:700}input,select{width:100%;min-height:42px;border:1px solid #cbd8d2;border-radius:8px;padding:0 11px;color:#18232c;background:#f8fbfa}.save-button{height:42px;padding:0 14px;color:#fff;background:#0b8f83;font-weight:800}.error-banner{margin-top:12px;border:1px solid #f0b7a5;border-radius:8px;padding:12px 14px;color:#762f1e;background:#fff0ea;font-weight:700}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.8fr);grid-template-areas:"progress allowance";gap:14px;margin-top:14px}.settings-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.8fr);gap:14px;margin-top:14px}.progress-panel{grid-area:progress;padding:18px}.allowance-panel{grid-area:allowance;padding:16px}.goal-panel{padding:16px}.metric-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.metric-row div{display:grid;gap:4px}.metric-row strong{color:#18232c;font-size:36px;line-height:1.05}.progress-track{position:relative;overflow:visible;display:flex;height:34px;margin-top:18px;border-radius:8px;background:#dde7e3}.progress-segment,.progress-empty{position:relative;height:100%;min-width:2px}.progress-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.25)}.progress-empty{background:#dde7e3}.norm-gap{position:absolute;top:0;bottom:0;min-width:4px;background:#0b8f8338;border-left:1px solid rgba(11,143,131,.38);border-right:1px solid rgba(11,143,131,.38);pointer-events:auto;z-index:1}.norm-marker{position:absolute;top:0;bottom:0;width:19px;transform:translate(-8px);background:linear-gradient(90deg,transparent 0,transparent 8px,#202830 8px,#202830 11px,transparent 11px);z-index:2}[data-tooltip]:after{position:absolute;z-index:20;left:50%;bottom:calc(100% + 9px);max-width:min(260px,70vw);width:max-content;transform:translate(-50%) translateY(3px);border-radius:7px;padding:7px 9px;color:#fff;background:#18232c;box-shadow:0 8px 22px #18232c2e;content:attr(data-tooltip);font-size:12px;font-weight:800;line-height:1.25;opacity:0;pointer-events:none;text-align:center;transition:opacity .12s ease,transform .12s ease;white-space:normal}[data-tooltip]:before{position:absolute;z-index:21;left:50%;bottom:calc(100% + 3px);width:0;height:0;transform:translate(-50%) translateY(3px);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #18232c;content:"";opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease}[data-tooltip]:hover:after,[data-tooltip]:hover:before,[data-tooltip]:focus-visible:after,[data-tooltip]:focus-visible:before{opacity:1;transform:translate(-50%) translateY(0)}.norm-row{display:flex;justify-content:space-between;gap:12px;margin-top:8px;font-size:14px;font-weight:700}.preset-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:18px}.preset-button{min-height:72px;padding:12px;color:#fff;font-weight:800}.preset-button b{margin-left:auto;font-size:18px}.water220,.water300{background:#1688d3}.coffee220{background:#9b5a24}.tea300{background:#d49312}.allowance-list{display:grid;gap:8px;margin-top:12px}.panel-note{margin-top:8px;color:#64737c;font-size:14px;font-weight:700}.allowance-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:2px 10px;align-items:center;border-bottom:1px solid #edf1ef;padding:8px 0}.allowance-row span{font-weight:800}.allowance-row strong{color:#0b8f83;font-size:22px}.allowance-row small{color:#64737c}.stepper-row,.time-row{display:grid;gap:8px;margin-top:12px}.stepper-row{grid-template-columns:repeat(4,minmax(0,1fr))}.stepper-row button{height:38px;border:1px solid #cbd8d2;border-radius:8px;background:#f8fbfa;color:#26333c;font-weight:800}.stepper-row button.active{border-color:#0b8f83;color:#fff;background:#0b8f83}.time-row{grid-template-columns:1fr 1fr}.history-section{margin-top:18px}.history-toolbar{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;gap:10px;align-items:center;margin-bottom:12px}.section-heading{justify-content:center;margin-bottom:0}.section-heading h2{font-size:20px;text-transform:capitalize}.month-button{width:44px;height:44px;border:1px solid #d4ded9;border-radius:8px;color:#26333c;background:#fff}.month-button:disabled{color:#a7b4bb;background:#f4f8f6}.month-summary{display:grid;grid-template-columns:minmax(180px,.65fr) minmax(0,1fr) minmax(0,1fr);gap:12px;margin-bottom:12px}.month-total,.month-breakdown{border:1px solid #d4ded9;border-radius:8px;background:#fff;box-shadow:0 10px 30px #31455314}.month-total{display:grid;gap:4px;padding:14px}.month-total span,.month-total small{color:#64737c;font-weight:800}.month-total strong{color:#18232c;font-size:28px;line-height:1.05}.month-breakdown{padding:14px}.month-breakdown h3{margin-bottom:10px;font-size:16px}.summary-chip-list{display:flex;flex-wrap:wrap;gap:7px}.summary-chip-list span{display:inline-flex;align-items:center;gap:7px;border:1px solid #d4ded9;border-radius:999px;padding:5px 9px;color:#26333c;background:#f8fbfa;font-size:13px;font-weight:900}.summary-chip-list i{width:10px;height:10px;flex:0 0 10px;border-radius:999px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px}.calendar-weekday{border-radius:8px;padding:9px 6px;color:#64737c;background:#f8fbfa;font-size:13px;font-weight:900;text-align:center}.calendar-weekday.weekend{color:#a45f20;background:#fff6e8}.calendar-empty{min-height:166px;border:1px dashed #dbe5e0;border-radius:8px;background:#ffffff73}.day-card{min-width:0;min-height:166px;padding:14px}.day-card.weekend{border-color:#ead4af;background:#fffaf0}.day-toggle{width:100%;border:0;padding:0;color:inherit;background:transparent;display:flex;justify-content:space-between;gap:12px;align-items:start;text-align:left}.day-card h3{font-size:24px}.day-toggle-right{display:inline-flex;align-items:center;gap:6px}.day-toggle-right strong{color:#0b8f83;font-size:16px}.day-toggle-right svg{transition:transform .16s ease}.day-card.expanded .day-toggle-right svg{transform:rotate(180deg)}.day-toggle-right b{min-width:28px;border-radius:999px;padding:4px 7px;text-align:center;color:#fff;background:#166f67}.day-progress-wrap{display:grid;gap:5px;margin-top:12px}.day-progress-track{display:flex;overflow:visible;position:relative;height:18px;border-radius:7px;background:#dde7e3}.day-progress-segment,.day-progress-empty{position:relative;min-width:2px;height:100%}.day-progress-segment{display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:900;text-shadow:0 1px 2px rgba(0,0,0,.28)}.day-progress-empty{background:#dde7e3}.day-progress-meta{display:flex;justify-content:space-between;gap:10px;color:#64737c;font-size:13px;font-weight:800}.day-progress-meta strong{color:#0b8f83}.day-preset-strip{display:flex;flex-wrap:wrap;gap:5px;min-height:24px;margin-top:12px}.day-preset-strip span{border-radius:999px;padding:4px 7px;color:#fff;font-size:11px;font-weight:900}.empty{margin-top:28px;color:#7a878f}.collapsed-hint{margin-top:18px;color:#7a878f;font-size:13px;font-weight:700}.event-list{display:grid;gap:6px;margin-top:12px}.event-row{display:grid;grid-template-columns:42px minmax(0,1fr) 30px;align-items:center;gap:8px;min-height:36px;border-left:5px solid #70c05b;border-radius:8px;padding:0 4px 0 8px;background:#f4f8f6}.event-row span{color:#64737c;font-size:12px}.event-row strong{display:inline-flex;align-items:center;gap:7px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.event-row strong i{width:10px;height:10px;flex:0 0 10px;border-radius:999px}.event-row button{width:30px;height:30px;color:#a13d2b;background:transparent}footer{padding:18px 2px 0;font-size:13px}.spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:820px){.app-shell{width:min(100% - 18px,1180px);padding-top:9px}.settings-panel{grid-template-columns:1fr;align-items:stretch}.dashboard-grid,.settings-grid{grid-template-columns:1fr}.dashboard-grid{grid-template-areas:"progress" "allowance"}.metric-row,.preset-grid,.time-row{grid-template-columns:1fr}.metric-row strong{font-size:30px}.month-summary,.calendar-grid{grid-template-columns:1fr}.calendar-weekday,.calendar-empty{display:none}}
