html{background:#f5f7fb;min-height:100%}body{background:#f5f7fb;min-height:100%;margin:0}#root{min-height:100vh}:root{--bg:#f5f7fb;--surface:#fff;--surface-soft:#eef3fb;--text:#0e1626;--muted:#5b6475;--accent:#00d2ff;--accent-dark:#0e1626;--done:#18b66a;--danger:#ef4444;--border:#0e16261f;--shadow:0 8px 22px #0e162612}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app{background:var(--bg);max-width:520px;min-height:100vh;margin:0 auto;padding:16px 14px 92px}main{min-height:calc(100vh - 108px)}.page{flex-direction:column;gap:14px;width:100%;display:flex}.page>*{width:100%}h2{color:var(--text);text-align:center;margin:0 0 2px;font-size:26px;font-weight:800;line-height:1.15}.today-progress{background:var(--surface);border:1px solid var(--border);width:100%;box-shadow:var(--shadow);border-radius:20px;padding:16px}.today-progress-top{justify-content:space-between;align-items:flex-end;gap:16px;width:100%;margin-bottom:12px;display:flex}.today-progress-percent{color:var(--text);flex:none;font-size:30px;font-weight:900;line-height:1}.today-progress-count{color:var(--muted);text-align:right;white-space:nowrap;flex:none;margin-left:auto;font-size:16px;font-weight:700;line-height:1}.progress-bar{background:var(--surface-soft);border-radius:999px;width:100%;height:10px;overflow:hidden}.progress-bar-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .25s}.list{flex-direction:column;gap:12px;display:flex}.today-list{gap:10px}.habit-card{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);text-align:left;min-height:64px;box-shadow:var(--shadow);border-radius:18px;align-items:center;gap:13px;padding:12px 14px;display:flex}.habit-card.static{cursor:default}.habit-card:active,.habit-overview-card:active{transform:scale(.99)}.habit-flag{background:var(--surface-soft);width:46px;height:46px;color:var(--surface);border:2px solid #0e16262e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:900;display:inline-flex}.habit-flag.done{background:var(--done);border-color:var(--done);color:#fff}.habit-text{flex-direction:column;gap:3px;min-width:0;display:flex}.habit-text strong{color:var(--text);font-size:17px}.habit-text small{color:var(--muted);font-size:13px}.habit-overview-card{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);text-align:left;box-shadow:var(--shadow);border-radius:20px;padding:14px}.habit-overview-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.habit-overview-header strong{color:var(--text);margin-bottom:3px;font-size:17px;display:block}.habit-overview-header small{color:var(--muted);font-size:13px}.chevron{color:var(--muted);font-size:26px;line-height:1}.heatmap-wrapper{width:100%;margin-top:10px}.heatmap-header{color:var(--muted);grid-template-columns:22px repeat(24,1fr);column-gap:2px;margin-bottom:5px;font-size:9px;font-weight:800;line-height:1;display:grid}.heatmap-header span:first-child{grid-column:1}.heatmap-header .h0{grid-column:2;justify-self:center}.heatmap-header .h6{grid-column:8;justify-self:center}.heatmap-header .h12{grid-column:14;justify-self:center}.heatmap-header .h18{grid-column:20;justify-self:center}.heatmap-header .h23{grid-column:25;justify-self:center}.heatmap{flex-direction:column;gap:2px;display:flex}.heatmap-row-wrapper{grid-template-columns:22px 1fr;align-items:center;column-gap:5px;display:grid}.heatmap-day{color:var(--muted);text-align:right;font-size:9px;font-weight:800;line-height:1}.heatmap-row{grid-template-columns:repeat(24,1fr);gap:2px;display:grid}.heat{aspect-ratio:1;background:#e6edf7;border-radius:50%;place-self:center;width:92%;position:relative}.heat.divider:before{content:"";background:#0e16260f;width:1px;position:absolute;top:-1px;bottom:-1px;left:-2px}.heat.level-1{background:#00d2ff47}.heat.level-2{background:#00d2ff94}.heat.level-3{background:#00d2ff}.empty{color:var(--muted);text-align:center;margin:48px 0 0}label,.field-title{color:var(--text);flex-direction:column;gap:8px;font-size:15px;font-weight:700;display:flex}input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);box-shadow:var(--shadow);border-radius:16px;outline:none;padding:14px}input:focus{border-color:var(--accent)}.mode-switch{background:var(--surface-soft);border-radius:18px;grid-template-columns:1fr 1fr;gap:8px;padding:5px;display:grid}.mode-switch button{color:var(--muted);background:0 0;border:0;border-radius:14px;padding:12px 8px;font-weight:800}.mode-switch button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow)}.schedule-editor{flex-direction:column;gap:12px;display:flex}.schedule-day-row{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px;grid-template-columns:42px 1fr;align-items:flex-start;gap:10px;padding:12px;display:grid}.schedule-day-name{background:var(--surface-soft);width:38px;height:38px;color:var(--text);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:900;display:flex}.schedule-times{flex-direction:column;gap:8px;display:flex}.schedule-time-row{grid-template-columns:1fr 46px;align-items:center;gap:8px;display:grid}.schedule-time-row input{box-shadow:none;border-radius:14px;padding:11px 12px}.time-range{grid-template-columns:1fr 1fr;gap:10px;display:grid}.days{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.days button{border:1px solid var(--border);background:var(--surface);color:var(--text);box-shadow:var(--shadow);border-radius:14px;padding:11px 0;font-weight:700}.days button.selected{background:var(--accent);border-color:var(--accent);color:var(--accent-dark)}.checkbox-row{flex-direction:row;align-items:center;font-weight:600}.checkbox-row input{width:auto;box-shadow:none}.small-button{border:1px solid var(--border);background:var(--surface);color:var(--text);box-shadow:none;border-radius:14px;height:44px;font-size:22px;font-weight:900}.primary,.secondary,.danger{box-shadow:var(--shadow);border:0;border-radius:18px;padding:15px;font-weight:900}.secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.secondary.compact{box-shadow:none;border-radius:14px;padding:11px}.primary{background:var(--accent);color:var(--accent-dark)}.danger{color:var(--danger);background:#fff;border:1px solid #ef444459}.stat-card{background:var(--surface);border:1px solid var(--border);width:100%;box-shadow:var(--shadow);border-radius:24px;flex-direction:column;gap:4px;padding:24px;display:flex}.stat-card strong{color:var(--text);font-size:44px;line-height:1}.stat-card span{color:var(--muted)}.overall-stat{width:100%}.overall-stat-top{justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:12px;display:flex}.overall-stat-top strong{font-size:38px;line-height:1}.overall-stat-top span{color:var(--muted);white-space:nowrap;font-size:16px;font-weight:800}.stat-habit-card{background:var(--surface);border:1px solid var(--border);width:100%;box-shadow:var(--shadow);border-radius:20px;grid-template-columns:58px 1fr;gap:12px;padding:14px;display:grid}.stat-percent{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:14px;font-weight:900;display:flex}.stat-percent.good{background:var(--done)}.stat-percent.medium{background:#f59e0b}.stat-percent.bad{background:var(--danger)}.stat-habit-content{min-width:0}.stat-habit-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.stat-habit-header strong{font-size:17px}.streak{color:var(--muted);white-space:nowrap;font-size:13px;font-weight:800}.stat-habit-meta{color:var(--muted);flex-wrap:wrap;gap:10px;margin:6px 0 10px;font-size:13px;font-weight:600;display:flex}.progress-bar.small{height:7px}.progress-bar-fill.good{background:var(--done)}.progress-bar-fill.medium{background:#f59e0b}.progress-bar-fill.bad{background:var(--danger)}.stat-days{grid-template-columns:repeat(15,1fr);gap:3px;margin-top:10px;display:grid}.stat-day{aspect-ratio:1;background:#e6edf7;border-radius:4px;width:100%}.stat-day.done{background:var(--done)}.bottom-nav{background:var(--surface);border:1px solid var(--border);border-radius:24px;grid-template-columns:repeat(4,1fr);gap:8px;width:min(520px,100% - 28px);padding:8px;display:grid;position:fixed;bottom:14px;left:50%;transform:translate(-50%);box-shadow:0 10px 34px #0e162629}.bottom-nav button{color:var(--muted);background:0 0;border:0;border-radius:16px;padding:11px 0;font-size:13px;font-weight:700}.bottom-nav button.active{background:var(--accent);color:var(--accent-dark)}.page-title-block{flex-direction:column;align-items:center;gap:4px;display:flex}.page-title-block h2{margin:0}.page-title-block span{color:var(--muted);font-size:13px;font-weight:700}.today-section{flex-direction:column;gap:8px;display:flex}.today-section-title{color:var(--muted);padding:0 4px;font-size:13px;font-weight:900}.habit-card.status-overdue{border-color:#ef444459}.habit-card.status-now{border-color:#18b66a59}.habit-card.status-soon{border-color:#00d2ff59}.habit-card.status-done{opacity:.72}
