*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0E0F11;--bg2:#13151A;--bg3:#1A1C21;--bg4:#1E2025;--border:#22252E;
  --text:#E8E9EB;--text2:#8B8F9E;--text3:#5A5E6B;--text4:#3A3E4C;
  --accent:#7C9EFF;--green:#69D5A0;--amber:#FFD166;--coral:#FF8A65;
  --pink:#FF6B8A;--purple:#D4AAFF;
  --safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);
}
html,body{height:100%;min-height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:'DM Sans',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overscroll-behavior:none}
body{min-height:100dvh}
#app{height:100dvh;min-height:100svh;display:flex;flex-direction:column;max-width:480px;width:100%;margin:0 auto;position:relative}
#header{padding:calc(var(--safe-top) + 14px) 20px 0;background:var(--bg);flex-shrink:0;z-index:10}
.header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.header-label{font-size:10px;color:var(--text3);letter-spacing:.1em;text-transform:uppercase;font-weight:500;font-family:'DM Mono',monospace}
.header-title{font-size:24px;font-weight:700;letter-spacing:-.03em;color:var(--text);margin-top:2px}
.header-right{display:flex;gap:8px;align-items:flex-start}
.planned-badge{background:var(--bg2);border-radius:12px;padding:8px 12px;text-align:center;border:1px solid var(--border);min-width:74px}
.pb-label{font-size:8px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace}
.pb-value{font-size:16px;font-weight:700;color:var(--accent);margin-top:2px;font-family:'DM Mono',monospace}
.streak-badge{background:var(--bg2);border-radius:12px;padding:8px 12px;text-align:center;border:1px solid var(--border);min-width:62px}
.sb-icon{font-size:14px}.sb-value{font-size:14px;font-weight:700;color:var(--amber);font-family:'DM Mono',monospace}
.day-strip{display:flex;gap:5px;overflow-x:auto;padding:12px 0 10px;scrollbar-width:none}
.day-strip::-webkit-scrollbar{display:none}
.day-btn{background:var(--bg3);color:var(--text3);border:1px solid transparent;border-radius:12px;padding:8px 10px;cursor:pointer;font-size:12px;font-weight:600;min-width:48px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s;font-family:'DM Sans',sans-serif}
.day-btn.active{background:var(--accent);color:var(--bg);font-weight:700}
.day-btn.overdue-day{border-color:#FF6B8A44}
.day-dot{width:5px;height:5px;border-radius:50%;background:var(--text4)}
.day-btn.active .day-dot{background:var(--bg)}
.day-dot.done{background:var(--green)}.day-dot.partial{background:var(--accent)}
.header-divider{height:1px;background:var(--border)}
#scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:calc(88px + var(--safe-bottom))}
#scroll-area::-webkit-scrollbar{display:none}
.view{display:none}.view.active{display:block}
.section-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.09em;font-family:'DM Mono',monospace;margin:0 0 10px}
/* DAILY */
.daily-content{padding:16px 20px 0}
.intention-box{background:var(--bg2);border-radius:12px;padding:12px 14px;margin-bottom:16px;border-left:3px solid var(--purple)}
.intention-input{background:none;border:none;outline:none;color:var(--text);font-size:14px;font-weight:500;width:100%;font-family:'DM Sans',sans-serif;line-height:1.4}
.intention-input::placeholder{color:var(--text3)}
.progress-bar-wrap{margin-bottom:18px}
.progress-meta{display:flex;justify-content:space-between;margin-bottom:7px}
.progress-meta span{font-size:11px;color:var(--text3);font-family:'DM Mono',monospace}
.progress-track{height:3px;background:var(--bg4);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--green));border-radius:99px;transition:width .5s cubic-bezier(.34,1.56,.64,1)}
.task-list{display:flex;flex-direction:column;gap:9px}
.task-card{background:var(--bg2);border-radius:16px;padding:14px 14px 14px 15px;display:flex;align-items:flex-start;gap:12px;border-left:3px solid var(--accent);transition:opacity .2s;position:relative;animation:slideUp .18s ease}
.task-card.done{opacity:.4}
.task-check{width:21px;height:21px;border-radius:6px;border:2px solid var(--bg4);background:transparent;cursor:pointer;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.task-check.checked::after{content:'✓';color:var(--bg);font-size:11px;font-weight:700}
.task-body{flex:1;min-width:0;cursor:pointer}
.task-name{font-size:15px;font-weight:600;color:var(--text);line-height:1.4;word-break:break-word}
.task-card.done .task-name{text-decoration:line-through;color:var(--text4)}
.task-meta{font-size:11px;color:var(--text3);margin-top:4px;font-family:'DM Mono',monospace}
.task-tag{font-size:10px;padding:1px 7px;border-radius:99px;font-weight:600;font-family:'DM Mono',monospace;display:inline-block;margin:2px 2px 0 0}
.task-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.task-delete{background:none;border:none;cursor:pointer;color:var(--text4);font-size:16px;padding:2px 4px;line-height:1;transition:color .15s}
.task-delete:active{color:var(--pink)}
.task-priority{font-size:10px;font-family:'DM Mono',monospace;padding:1px 7px;border-radius:99px}
.priority-urgent{background:#FF6B8A22;color:#FF6B8A}.priority-high{background:#FF8A6522;color:#FF8A65}
.priority-normal{background:#7C9EFF22;color:#7C9EFF}.priority-low{background:#5A5E6B44;color:#8B8F9E}
.task-timer-btn{background:none;border:1px solid var(--border);border-radius:8px;padding:4px 7px;font-size:11px;cursor:pointer;color:var(--text3);font-family:'DM Mono',monospace}
.overdue-label{font-size:10px;color:var(--pink);text-transform:uppercase;letter-spacing:.09em;font-family:'DM Mono',monospace;margin-bottom:8px;margin-top:4px}
.add-task-card{background:var(--bg2);border-radius:13px;border:2px dashed var(--border);padding:12px 14px;cursor:pointer;color:var(--text4);font-size:14px;display:flex;align-items:center;gap:10px;font-family:'DM Sans',sans-serif;width:100%;text-align:left}
.add-task-form{background:var(--bg2);border-radius:13px;padding:12px 14px}
.add-task-input{
  width:100%;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:12px;
  padding:15px 16px;
  outline:none;
  color:var(--text);
  font-size:16px;
  font-weight:600;
  font-family:'DM Sans',sans-serif;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
.add-task-input::placeholder{color:rgba(243,246,251,.88)}
.add-task-form{
  padding-bottom:calc(112px + var(--safe-bottom));
}
.add-task-input:focus{
  border-color:color-mix(in srgb,var(--accent) 45%, var(--border));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 22%, transparent), inset 0 1px 0 rgba(255,255,255,.02);
}
.add-task-input.error{
  border:1px solid #FF6B8A88;
  background:rgba(255,107,138,.06);
  border-radius:12px;
  padding:14px 15px;
}
.field-error{
  color:var(--pink);
  font-size:12px;
  margin-top:9px;
  line-height:1.45;
}
.shake{
  animation:vmShake .22s linear 1;
}
@keyframes vmShake{
  0%{transform:translateX(0)}
  20%{transform:translateX(-4px)}
  40%{transform:translateX(4px)}
  60%{transform:translateX(-3px)}
  80%{transform:translateX(3px)}
  100%{transform:translateX(0)}
}
.dur-row{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.dur-btn{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:5px 9px;font-size:11px;color:var(--text3);cursor:pointer;font-family:'DM Mono',monospace;transition:all .12s}
.dur-btn.selected{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}
.estimate-wrap{margin-top:10px;padding:11px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:11px}
.estimate-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.estimate-title{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace}
.estimate-preview{font-size:12px;color:var(--text);font-weight:600}
.estimate-controls{display:grid;grid-template-columns:1fr 1fr auto auto;gap:8px;align-items:end}
.estimate-field label,.schedule-field label{display:block;font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace;margin-bottom:5px}
.estimate-num,.schedule-select{width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:9px;padding:9px 10px;color:var(--text);font-size:14px;font-family:'DM Sans',sans-serif;outline:none}
.estimate-stepper{display:flex;gap:6px;align-items:end;justify-content:flex-start}
.estimate-stepper button,.tiny-toggle{background:var(--bg2);border:1px solid var(--border);color:var(--text2);border-radius:9px;padding:9px 10px;font-size:12px;font-family:'DM Mono',monospace;cursor:pointer;min-width:56px;min-height:46px}
.estimate-stepper button{min-width:56px}
.estimate-stepper.estimate-stepper-single{display:block}
@media (max-width:420px){
  .estimate-controls{grid-template-columns:1fr 1fr;gap:10px}
  .estimate-stepper,.estimate-stepper.estimate-stepper-single{display:flex}
  .estimate-stepper button{flex:1}
}
.schedule-wrap{margin-top:10px;padding:11px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:11px}
.mode-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.mode-btn{background:var(--bg2);border:1px solid var(--border);border-radius:99px;padding:6px 11px;font-size:11px;color:var(--text3);cursor:pointer;font-family:'DM Mono',monospace;transition:all .12s}
.mode-btn.selected{background:var(--accent)22;border-color:var(--accent);color:var(--accent)}
.schedule-help{font-size:11px;color:var(--text3);margin-top:7px;line-height:1.4}
.recurring-days-wrap{margin-top:10px;padding:11px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:11px}
.recurring-days-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.recurring-days-title{font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace}
.recurring-days-row{display:flex;gap:6px;flex-wrap:wrap}
.recurring-day-btn{background:var(--bg2);border:1px solid var(--border);border-radius:999px;padding:7px 11px;font-size:11px;color:var(--text2);cursor:pointer;font-family:'DM Mono',monospace;transition:all .12s}
.recurring-day-btn.selected{background:rgba(105,213,160,.12);border-color:var(--green);color:var(--green)}
.add-section-title{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace;margin:12px 0 8px}
.premium-box{background:linear-gradient(135deg,#1A1D2E,var(--bg2));border-radius:14px;padding:14px;border:1px solid #2A2D3A}
.premium-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.premium-pill{font-size:11px;padding:5px 9px;border-radius:99px;background:var(--bg3);color:var(--text2);border:1px solid var(--border);font-family:'DM Sans',sans-serif}
.priority-row{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.pri-btn{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:5px 9px;font-size:11px;cursor:pointer;font-family:'DM Mono',monospace;color:var(--text3);transition:all .12s}
.pri-btn[data-p="urgent"].selected{background:#FF6B8A22;border-color:var(--pink);color:var(--pink)}
.pri-btn[data-p="high"].selected{background:#FF8A6522;border-color:var(--coral);color:var(--coral)}
.pri-btn[data-p="normal"].selected{background:#7C9EFF22;border-color:var(--accent);color:var(--accent)}
.pri-btn[data-p="low"].selected{background:#5A5E6B44;border-color:var(--text3);color:var(--text3)}
.tag-row{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.tag-chip{background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:4px 10px;font-size:11px;color:var(--text3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .12s}
.tag-chip.selected{background:var(--accent)22;border-color:var(--accent);color:var(--accent)}
.color-dots{display:flex;gap:6px;margin-top:8px}
.color-dot{width:18px;height:18px;border-radius:50%;border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:transform .12s}
.color-dot.selected{border-color:#fff;transform:scale(1.25)}
.notes-input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px;width:100%;resize:none;font-family:'DM Sans',sans-serif;outline:none;margin-top:8px;height:56px}
.notes-input::placeholder{color:var(--text4)}
.form-actions{display:flex;align-items:center;gap:8px;margin-top:10px}
.btn-cancel{background:none;border:none;cursor:pointer;color:var(--text3);font-size:13px;font-family:'DM Sans',sans-serif;padding:6px 8px}
.btn-add{background:var(--accent);color:var(--bg);border:none;border-radius:9px;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}
.shutdown-box{background:linear-gradient(135deg,#1A1D2E,var(--bg2));border-radius:14px;padding:16px;border:1px solid #2A2D3A;margin-top:20px}
.shutdown-title{font-size:12px;font-weight:600;color:var(--amber);margin-bottom:10px}
.shutdown-textarea{background:none;border:none;outline:none;color:var(--text2);font-size:13px;width:100%;resize:none;height:54px;font-family:'DM Sans',sans-serif;line-height:1.5}
.shutdown-textarea::placeholder{color:var(--text4)}
.mood-row{display:flex;gap:8px;margin-top:10px}
.mood-btn{font-size:22px;background:none;border:none;cursor:pointer;padding:4px;border-radius:8px;transition:transform .15s,background .15s;line-height:1}
.mood-btn.selected{background:var(--bg3);transform:scale(1.3)}
/* CALENDAR */
.cal-content{padding:6px 0 22px;position:relative}
.cal-hour-row{display:flex;align-items:flex-start;min-height:48px;border-top:1px solid rgba(124,158,255,.14)}
.cal-time{font-size:11px;color:var(--text3);width:74px;padding:12px 0 0 18px;flex-shrink:0;font-family:'DM Mono',monospace}
.cal-slot{flex:1;position:relative;min-height:48px;padding-right:12px}
.cal-block{position:absolute;left:8px;right:10px;border-radius:16px;padding:11px 14px 10px;border-left:4px solid;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.14);overflow:hidden}
.cal-block-title{font-size:13px;font-weight:700;line-height:1.25;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-block-sub{font-size:11px;margin-top:4px;opacity:.72;font-family:'DM Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.now-line{position:absolute;left:74px;right:12px;height:2px;background:var(--pink);display:flex;align-items:center;z-index:5;pointer-events:none}
.now-dot{width:9px;height:9px;border-radius:50%;background:var(--pink);margin-left:-4px;box-shadow:0 0 0 4px rgba(255,107,138,.12)}
/* WEEKLY */
.weekly-content{padding:20px 20px 0}
.stats-row{display:flex;gap:8px;margin-bottom:22px}
.stat-card{flex:1;background:var(--bg2);border-radius:13px;padding:12px 8px;text-align:center;border:1px solid var(--border)}
.stat-value{font-size:20px;font-weight:700;font-family:'DM Mono',monospace}
.stat-label{font-size:10px;color:var(--text3);margin-top:3px;line-height:1.3}
.bar-chart{display:flex;gap:6px;align-items:flex-end;height:68px;margin-bottom:22px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}
.bar-track{width:100%;background:var(--bg3);border-radius:7px;flex:1;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.bar-fill{width:100%;border-radius:7px;transition:height .5s cubic-bezier(.34,1.56,.64,1);min-height:0}
.bar-label{font-size:9px;color:var(--text4);font-family:'DM Mono',monospace}
.goal-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.goal-card{background:var(--bg2);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:opacity .2s}
.goal-card.done{opacity:.45}
.goal-check{width:21px;height:21px;border-radius:7px;border:2px solid var(--bg4);background:transparent;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.goal-check.checked{background:var(--green);border-color:var(--green)}
.goal-check.checked::after{content:'✓';color:var(--bg);font-size:11px;font-weight:700}
.goal-text{font-size:14px;font-weight:500;color:var(--text)}
.goal-card.done .goal-text{text-decoration:line-through;color:var(--text4)}
.add-goal-btn{background:none;border:2px dashed var(--border);border-radius:12px;padding:11px 14px;color:var(--text4);font-size:13px;display:flex;align-items:center;gap:10px;cursor:pointer;width:100%;font-family:'DM Sans',sans-serif;margin-bottom:20px}
.reflection-box{background:linear-gradient(135deg,#1A1D2E,var(--bg2));border-radius:14px;padding:16px;border:1px solid #2A2D3A;margin-bottom:12px}
.reflection-title{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:8px}
.reflection-textarea{background:none;border:none;outline:none;color:var(--text2);font-size:13px;width:100%;resize:none;height:72px;font-family:'DM Sans',sans-serif;line-height:1.6}
.reflection-textarea::placeholder{color:var(--text4)}
/* MONTHLY */
.monthly-content{padding:20px 20px 0}
.month-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.month-nav-btn{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;color:var(--text2);cursor:pointer;font-size:18px;font-family:'DM Sans',sans-serif}
.month-nav-title{font-size:15px;font-weight:700;color:var(--text)}
.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:22px}
.month-day-label{font-size:9px;color:var(--text4);text-align:center;font-family:'DM Mono',monospace;padding-bottom:4px}
.month-cell{aspect-ratio:1;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11px;cursor:default;font-family:'DM Mono',monospace;transition:none}
.month-cell:active{transform:none}
.month-cell.today{outline:2px solid var(--accent);outline-offset:-2px}
.month-cell.empty{cursor:default}
.h0{background:var(--bg3);color:var(--text4)}.h1{background:#7C9EFF22;color:var(--accent)}.h2{background:#7C9EFF44;color:var(--accent)}.h3{background:#7C9EFF88;color:#fff}.hfull{background:var(--green);color:var(--bg)}
.chart-wrap{background:var(--bg2);border-radius:13px;padding:14px;margin-bottom:14px;border:1px solid var(--border)}
.chart-title{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace;margin-bottom:12px}
.trend-bars{display:flex;gap:4px;align-items:flex-end;height:60px}
.trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%}
.trend-bar{width:100%;background:var(--accent);border-radius:4px 4px 0 0;min-height:2px;transition:height .4s ease}
.trend-bar-label{font-size:9px;color:var(--text4);font-family:'DM Mono',monospace}
/* SEARCH */
.search-wrap{padding:14px 20px 0}
.search-input{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:10px 14px 10px 36px;color:var(--text);font-size:14px;width:100%;font-family:'DM Sans',sans-serif;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235A5E6B' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center}
.search-input::placeholder{color:var(--text4)}
.search-results{padding:10px 20px 0;display:flex;flex-direction:column;gap:8px}
/* SETTINGS */
.settings-content{padding:20px 20px 0}
.settings-section{margin-bottom:22px}
.settings-title{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.09em;font-family:'DM Mono',monospace;margin-bottom:10px}
.settings-row{background:var(--bg2);border-radius:11px;padding:13px 14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;border:1px solid var(--border)}
.settings-label{font-size:14px;font-weight:500;color:var(--text)}
.settings-sub{font-size:11px;color:var(--text3);margin-top:2px}
.toggle{width:44px;height:24px;background:var(--bg3);border-radius:99px;position:relative;cursor:pointer;border:1px solid var(--border);transition:background .2s;flex-shrink:0}
.toggle.on{background:var(--accent)}
.toggle-knob{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.toggle.on .toggle-knob{left:22px}
.accent-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.accent-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:transform .12s}
.accent-swatch.selected{border-color:#fff;transform:scale(1.2)}
.work-hours-row{display:flex;gap:8px;align-items:center;margin-top:8px}
.hour-select{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);font-size:13px;font-family:'DM Mono',monospace;outline:none}
.tags-wrap{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.tag-manage-chip{background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:5px 12px;font-size:12px;color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:6px;font-family:'DM Sans',sans-serif}
.tag-remove{color:var(--pink);font-size:14px;line-height:1}
/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.hidden{display:none}
.modal-sheet{background:var(--bg2);border-radius:20px 20px 0 0;padding:24px 24px calc(24px + var(--safe-bottom));width:100%;max-width:480px;animation:sheetUp .25s ease;position:relative}
.detail-modal{background:var(--bg2);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + var(--safe-bottom));width:100%;max-width:480px;animation:sheetUp .25s ease;position:relative;max-height:90vh;overflow-y:auto}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:36px;height:4px;background:var(--bg4);border-radius:99px;margin:0 auto 20px}
.close-btn{background:none;border:none;color:var(--text3);font-size:20px;cursor:pointer;padding:0;position:absolute;top:20px;right:20px}
.detail-input{background:none;border:none;outline:none;color:var(--text);font-size:18px;font-weight:700;width:100%;font-family:'DM Sans',sans-serif;margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:10px}
.detail-notes{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px;color:var(--text2);font-size:13px;width:100%;resize:none;font-family:'DM Sans',sans-serif;outline:none;height:76px;line-height:1.5}
.detail-notes::placeholder{color:var(--text4)}
.subtask-list{display:flex;flex-direction:column;gap:5px;margin-bottom:8px}
.subtask-row{display:flex;align-items:center;gap:8px}
.subtask-check{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--bg4);background:transparent;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.subtask-check.checked{background:var(--green);border-color:var(--green)}
.subtask-check.checked::after{content:'✓';color:var(--bg);font-size:9px;font-weight:700}
.subtask-name{font-size:12px;color:var(--text2)}.subtask-name.done{text-decoration:line-through;color:var(--text4)}
.subtask-add-row{display:flex;gap:8px;margin-bottom:12px}
.subtask-add-input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:7px 10px;color:var(--text);font-size:13px;flex:1;outline:none;font-family:'DM Sans',sans-serif}
.subtask-add-input::placeholder{color:var(--text4)}
.btn-sm{background:var(--accent);color:var(--bg);border:none;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}
.actual-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.actual-label{font-size:12px;color:var(--text3)}
.actual-input{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 10px;color:var(--text);font-size:13px;width:80px;outline:none;font-family:'DM Mono',monospace;text-align:center}
.carry-btn{background:#FFD16622;border:1px solid #FFD16644;border-radius:9px;padding:8px 14px;font-size:12px;cursor:pointer;color:var(--amber);font-family:'DM Sans',sans-serif;font-weight:600}
.delete-btn-full{background:#FF6B8A22;border:1px solid #FF6B8A44;border-radius:9px;padding:8px 14px;font-size:12px;cursor:pointer;color:var(--pink);font-family:'DM Sans',sans-serif;font-weight:600}
/* NAV */
#bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:rgba(14,15,17,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);display:flex;padding:8px 0 calc(8px + var(--safe-bottom));justify-content:space-around;z-index:50}
.nav-btn{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;padding:3px 6px;color:var(--text4);transition:color .15s;min-width:46px}
.nav-btn.active{color:var(--accent)}
.nav-icon{font-size:19px;line-height:1}
.nav-label{font-size:9px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;font-family:'DM Mono',monospace}
#install-banner{display:none;position:fixed;bottom:calc(68px + var(--safe-bottom));left:50%;transform:translateX(-50%);background:var(--accent);color:var(--bg);border-radius:14px;padding:10px 16px;font-size:13px;font-weight:600;align-items:center;gap:8px;z-index:200;cursor:pointer;box-shadow:0 8px 32px rgba(124,158,255,.35);max-width:calc(100% - 40px)}
#install-banner.show{display:flex}
@keyframes slideUp{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
#pro-entry-btn{
  position:fixed;
  right:16px;
  bottom:calc(82px + var(--safe-bottom));
  z-index:210;
  display:none;
  align-items:center;
  gap:8px;
  padding:12px 14px;
  border:none;
  border-radius:999px;
  background:linear-gradient(135deg,#1C2433,var(--bg2));
  color:var(--text);
  box-shadow:0 12px 28px rgba(0,0,0,.28);
  border:1px solid rgba(255,255,255,.06);
  cursor:pointer;
  font-weight:700;
  font-size:12px;
}
#pro-entry-btn.show{display:flex}
/* Pro modal */
#pro-modal{align-items:center !important;padding:16px !important;overflow-y:auto !important;-webkit-overflow-scrolling:touch !important}
#pro-modal .modal-sheet{width:min(520px,100%) !important;max-width:520px !important;max-height:none !important;overflow:visible !important;margin:auto !important;border-radius:20px !important}
.pro-feature-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.pro-feature-item{
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:12px;
  padding:11px 12px;
}
.pro-feature-item strong{
  display:block;
  font-size:13px;
  color:var(--text);
  margin-bottom:3px;
}
.pro-feature-item span{
  display:block;
  font-size:12px;
  color:var(--text3);
  line-height:1.5;
}
.billing-grid{
  display:grid;
  grid-template-columns:1fr 110px;
  gap:8px;
  margin-top:8px;
}
.billing-summary{
  margin-top:12px;
  padding:12px;
  border-radius:14px;
  background:linear-gradient(135deg,#162033,var(--bg2));
  border:1px solid var(--border);
}
.billing-summary strong{
  display:block;
  font-size:13px;
  margin-bottom:6px;
}
.billing-summary .small-note{margin-top:8px}
@media (max-width:420px){
  .billing-grid{grid-template-columns:1fr}
  #pro-entry-btn{right:12px;bottom:calc(78px + var(--safe-bottom))}
}
#add-task-overlay .modal-sheet{
  max-height:min(92vh,900px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
}
#add-task-overlay .form-actions{
  position:sticky;
  bottom:0;
  display:flex;
  align-items:center;
  gap:10px;
  background:linear-gradient(180deg, rgba(16,20,28,0), rgba(16,20,28,.92) 18%, rgba(16,20,28,.98) 42%, rgba(16,20,28,.99) 100%);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-top:1px solid rgba(255,255,255,.05);
  margin-top:18px;
  padding:14px 0 calc(8px + var(--safe-bottom));
}
.form-actions .btn-cancel{
  min-height:52px;
  padding:0 14px;
  border-radius:12px;
}
.form-actions .btn-add{
  flex:1;
  min-height:52px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
}


/* v3 polish */
:root{
  --bg:#10141C;--bg2:#171C26;--bg3:#202736;--bg4:#2A3345;--border:#334059;
  --text:#F3F6FB;--text2:#CCD5E4;--text3:#97A4BA;--text4:#6F7E96;
}
#header{background:linear-gradient(180deg,#10141C 0%,rgba(16,20,28,.96) 100%)}
.task-card,.settings-row,.stat-card,.chart-wrap,.reflection-box,.shutdown-box,.premium-box,.goal-card,.intention-box,.add-task-form{box-shadow:0 10px 30px rgba(0,0,0,.16)}
.task-delete{color:var(--text4)}
#scroll-area{padding-bottom:calc(102px + var(--safe-bottom))}
#daily-cta{margin-bottom:14px}
.primary-add-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%, #ffffff 30%));border:none;border-radius:16px;padding:15px 16px;color:#0D1320;cursor:pointer;box-shadow:0 14px 32px color-mix(in srgb,var(--accent) 26%, transparent)}
.primary-add-copy{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left}
.primary-add-copy strong{font-size:15px;line-height:1.1}
.primary-add-copy small{font-size:12px;color:rgba(13,19,32,.72)}
.primary-add-badge{font-size:11px;font-weight:700;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.55);white-space:nowrap}
.empty-state{text-align:center;padding:36px 0 8px;color:var(--text3)}
.empty-icon{font-size:32px;margin-bottom:8px;color:var(--accent)}
.empty-title{font-size:16px;font-weight:700;color:var(--text)}
.empty-sub{font-size:13px;margin-top:7px;color:var(--text3);max-width:280px;margin-left:auto;margin-right:auto;line-height:1.5}
.helper-card{background:linear-gradient(135deg,#1A2030,var(--bg2));border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:16px}
.helper-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.helper-text{font-size:12px;color:var(--text3);line-height:1.5}
.capacity-warning{
  margin:0 0 14px;
  padding:12px 13px;
  border-radius:14px;
  border:1px solid rgba(255,209,102,.18);
  background:linear-gradient(135deg, rgba(255,209,102,.09), rgba(255,138,101,.08));
  color:var(--text);
}
.capacity-warning strong{
  display:block;
  font-size:13px;
  margin-bottom:4px;
}
.capacity-warning small{
  display:block;
  font-size:12px;
  color:var(--text2);
  line-height:1.5;
}
.helper-btn{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:9px 12px;color:var(--text);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.next-up-card{background:linear-gradient(135deg,#182131,var(--bg2));border:1px solid var(--border);border-radius:16px;padding:14px 15px;margin-bottom:16px;box-shadow:0 10px 28px rgba(0,0,0,.16)}
.next-up-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.next-up-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace;margin-bottom:6px}
.next-up-title{font-size:16px;font-weight:700;color:var(--text);line-height:1.25}
.next-up-meta{font-size:12px;color:var(--text2);margin-top:6px;font-family:'DM Mono',monospace}
.next-up-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.insight-box{background:linear-gradient(135deg,#182131,var(--bg2));border-radius:14px;padding:15px;border:1px solid var(--border);margin:0 0 22px}
.insight-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:8px 0 10px}
.insight-stat{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:11px 12px;display:flex;flex-direction:column;gap:4px}
.insight-stat strong{font-size:19px;color:var(--text)}
.insight-stat span{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;font-family:'DM Mono',monospace}
.task-mini-action{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:3px 7px;font-size:10px;color:var(--text2);cursor:pointer;font-family:'DM Mono',monospace}
.detail-chip-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.detail-chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:var(--accent)22;border:1px solid color-mix(in srgb,var(--accent) 40%, transparent);color:var(--accent);font-size:11px;font-weight:700;font-family:'DM Mono',monospace}
.detail-chip.subtle{background:var(--bg3);border-color:var(--border);color:var(--text2)}
.mini-link-btn{background:none;border:none;padding:0;color:var(--text2);font-size:12px;text-decoration:underline;cursor:pointer}
.task-live-timer{
  margin-top:10px;
  font-size:32px;
  font-weight:700;
  letter-spacing:-.04em;
  font-family:'DM Mono',monospace;
  color:var(--text);
}
.task-timer-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.task-timer-actions .secondary-btn,
.task-timer-actions .btn-sm{
  min-height:42px;
}

.schedule-help{color:var(--text3)}
.dur-btn,.pri-btn,.tag-chip,.mode-btn,.estimate-stepper button,.hour-select,.estimate-num,.schedule-select,.tag-manage-chip{color:var(--text2)}
.add-task-card{border-color:var(--border);color:var(--text2)}
#bottom-nav{background:rgba(16,20,28,.95);border-top-color:var(--border)}
.nav-btn{color:var(--text3)}
.nav-btn.active{color:var(--accent)}
@supports not (color: color-mix(in srgb, black 50%, white)){
  .primary-add-btn{background:linear-gradient(135deg,var(--accent),#b9c8ff)}
  .detail-chip{border-color:var(--accent)}
}


.template-row{display:flex;gap:8px;overflow-x:auto;padding:2px 0 2px;scrollbar-width:none;margin-top:10px}
.template-row::-webkit-scrollbar{display:none}
.template-chip{border:none;background:var(--bg2);border:1px solid var(--border);color:var(--text2);padding:10px 12px;border-radius:999px;font-size:12px;white-space:nowrap;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.template-chip.locked{opacity:.85}
.locked-pill{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;border-radius:999px;background:rgba(255,255,255,.08);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.ad-card{background:linear-gradient(135deg,#171c28,#121721);border:1px solid var(--border);border-radius:18px;padding:16px 16px 15px;margin:18px 0 22px;box-shadow:0 10px 28px rgba(0,0,0,.16)}
.ad-label{font-size:10px;color:var(--text4);text-transform:uppercase;letter-spacing:.09em;font-family:'DM Mono',monospace;margin-bottom:7px}
.ad-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px}
.ad-copy{font-size:13px;color:var(--text3);line-height:1.55}
.ad-cta{margin-top:12px;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:9px 12px;font-size:12px;font-weight:700;cursor:pointer}
.plan-switch{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.plan-chip{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:7px 12px;color:var(--text2);font-size:12px;cursor:pointer;font-weight:700}
.plan-chip.active{background:var(--accent);border-color:var(--accent);color:#0D1320}
.notice-card{background:linear-gradient(135deg,#162033,var(--bg2));border:1px solid var(--border);border-radius:14px;padding:14px;margin-top:10px}
.notice-copy{font-size:12px;color:var(--text3);line-height:1.5;margin-top:6px}
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.feature-cell{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:10px 11px}
.feature-cell strong{display:block;font-size:12px;color:var(--text);margin-bottom:4px}
.feature-cell span{font-size:11px;color:var(--text3);line-height:1.45}
.permission-badge{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;background:var(--bg3);border:1px solid var(--border);font-size:11px;color:var(--text2);font-family:'DM Mono',monospace}
.button-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.secondary-btn{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:9px 12px;color:var(--text);font-size:12px;font-weight:700;cursor:pointer}
.inline-selects{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.inline-selects .hour-select{min-width:78px}
.pro-lock{opacity:.72;filter:saturate(.8)}
.small-note{font-size:11px;color:var(--text4);margin-top:6px;line-height:1.45}


.onboarding-sheet{min-height:min(82vh,760px);display:flex;flex-direction:column}
.onboard-progress{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:18px}
.onboard-step-copy{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.09em;font-family:'DM Mono',monospace}
.onboard-dots{display:flex;gap:6px;align-items:center}
.onboard-dot{width:8px;height:8px;border-radius:50%;background:var(--bg4);border:1px solid var(--border)}
.onboard-dot.active{background:var(--accent);border-color:var(--accent);transform:scale(1.15)}
.onboard-dot.done{background:var(--green);border-color:var(--green)}
.onboard-title{font-size:24px;font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:8px}
.onboard-sub{font-size:14px;color:var(--text3);line-height:1.6;margin-bottom:18px}
.onboard-card{background:linear-gradient(135deg,#182131,var(--bg2));border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:14px}
.onboard-preview{background:var(--bg3);border:1px solid var(--border);border-radius:16px;padding:14px;margin-top:12px}
.onboard-preview-name{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;font-family:'DM Mono',monospace}
.onboard-preview-main{font-size:18px;font-weight:700;margin-top:6px}
.onboard-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px 15px;color:var(--text);font-size:16px;outline:none;font-family:'DM Sans',sans-serif}
.onboard-input::placeholder{color:var(--text4)}
.onboard-nav{display:flex;gap:10px;justify-content:space-between;margin-top:auto;padding-top:18px}
.onboard-btn{border:none;border-radius:12px;padding:12px 16px;font-size:14px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}
.onboard-btn.primary{background:var(--accent);color:#0D1320;flex:1}
.onboard-btn.secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}
.onboard-btn.ghost{background:none;color:var(--text3)}
.onboard-accent-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:10px}
.onboard-accent{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer}
.onboard-accent.active{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%, transparent) inset}
.onboard-swatch{width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.16)}
.onboard-accent span{font-size:12px;color:var(--text2)}
.onboard-hours{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:end}
.onboard-hours .hour-select{width:100%;padding:12px 10px;font-size:15px}
.onboard-pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.onboard-pill{background:var(--bg3);border:1px solid var(--border);border-radius:999px;padding:8px 12px;color:var(--text2);font-size:12px;cursor:pointer;font-weight:700}
.onboard-pill.active{background:var(--accent);border-color:var(--accent);color:#0D1320}
.onboard-task-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:12px}


  /* Splash screen */
  #splash-screen{
    position:fixed; inset:0; z-index:9999;
    background:#000;
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    transition:opacity .42s ease, visibility .42s ease;
  }
  #splash-screen.hide{
    opacity:0; visibility:hidden; pointer-events:none;
  }
  .splash-logo-wrap{
    width:156px; height:156px; border-radius:38px;
    display:flex; align-items:center; justify-content:center;
    margin-bottom:22px;
    background:linear-gradient(180deg,#0a0d14,#090b10);
    box-shadow:0 16px 40px rgba(0,0,0,.42), inset 0 1px 0 rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.05);
    animation:splashRise .55s cubic-bezier(.16,1,.3,1);
  }
  .splash-logo{
    width:110px; height:110px; object-fit:contain; display:block;
  }
  .splash-title{
    color:#F3F6FB; font-size:34px; font-weight:700; letter-spacing:-.04em;
    margin-bottom:7px; opacity:0; animation:splashFade .55s ease .15s forwards;
    font-family:'DM Sans',system-ui,sans-serif;
  }
  .splash-tag{
    color:#9AA4B8; font-size:15px; font-weight:500; letter-spacing:.02em;
    opacity:0; animation:splashFade .55s ease .28s forwards;
    font-family:'DM Sans',system-ui,sans-serif;
  }
  @keyframes splashRise{
    0%{transform:translateY(18px); opacity:0}
    100%{transform:translateY(0); opacity:1}
  }
  @keyframes splashFade{
    0%{transform:translateY(10px); opacity:0}
    100%{transform:translateY(0); opacity:1}
  }



/* auth overlay for hosted web app */
.auth-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}
.auth-error,.auth-status{font-size:13px;line-height:1.5;margin-top:10px}
.auth-error{color:#FF8A9B}
.auth-status{color:var(--text3)}
#app.app-locked{filter:blur(6px);pointer-events:none;user-select:none}
.user-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;background:linear-gradient(180deg,#1A2332,#151C28);border:1px solid var(--border);border-radius:18px;font-size:13px;color:var(--text2);min-height:52px;box-shadow:0 10px 24px rgba(0,0,0,.16)}
.user-chip strong{font-size:13px;color:var(--text)}
.user-chip button{background:none;border:none;color:var(--text2);cursor:pointer;text-decoration:underline;font-size:12px;padding:0}


/* desktop layout upgrade */
@media (min-width: 1100px){
  html,body{overflow:hidden;background:radial-gradient(circle at top left,#172033 0%,#0f1420 42%,#0b0f18 100%)}
  body{padding:18px}
  #app{
    height:calc(100dvh - 36px);
    min-height:calc(100dvh - 36px);
    max-width:none;
    margin:0;
    border:1px solid rgba(255,255,255,.06);
    border-radius:28px;
    overflow:hidden;
    background:linear-gradient(180deg,#10141C 0%,#0E121B 100%);
    box-shadow:0 32px 80px rgba(0,0,0,.42);
    padding-left:104px;
  }
  #header{
    padding:28px 32px 0;
    background:linear-gradient(180deg,rgba(16,20,28,.98) 0%, rgba(16,20,28,.90) 100%);
  }
  .header-top{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:18px;margin-bottom:20px}
  .header-title{font-size:38px;line-height:1.05}
  .header-label{font-size:11px;margin-bottom:6px}
  .header-left{min-width:0}
  .header-right{display:grid;grid-template-columns:auto auto auto;gap:14px;align-items:stretch}
  .planned-badge,.streak-badge{padding:14px 16px;border-radius:18px;min-height:72px;display:flex;flex-direction:column;justify-content:center;box-shadow:0 14px 28px rgba(0,0,0,.16)}
  .pb-value{font-size:22px}
  .sb-value{font-size:18px}
  .day-strip{gap:8px;padding:14px 0 14px}
  .day-btn{min-width:68px;padding:10px 12px;border-radius:14px}
  #scroll-area{padding-bottom:28px}
  #bottom-nav{
    left:18px;
    top:18px;
    bottom:18px;
    transform:none;
    width:86px;
    max-width:none;
    border-top:none;
    border-right:1px solid var(--border);
    border-radius:28px 0 0 28px;
    padding:16px 10px;
    flex-direction:column;
    justify-content:flex-start;
    gap:10px;
    background:linear-gradient(180deg,rgba(18,24,36,.98),rgba(13,18,28,.96));
  }
  .nav-btn{width:100%;padding:12px 6px;border-radius:18px;gap:6px}
  .nav-btn.active{background:var(--accent);color:#0D1320;box-shadow:0 14px 32px color-mix(in srgb,var(--accent) 26%, transparent)}
  .nav-icon{font-size:20px}
  .nav-label{font-size:10px}
  #pro-entry-btn{right:28px;bottom:28px}

  .daily-content,.weekly-content,.monthly-content,.settings-content,.search-wrap,.search-results{padding-left:32px;padding-right:32px}
  .cal-content{padding:16px 24px 32px}

  .daily-content{
    display:grid;
    grid-template-columns:minmax(0,1.45fr) minmax(360px,.82fr);
    grid-template-areas:
      "progress side"
      "cta side"
      "overdue side"
      "tasks shutdown";
    gap:20px 26px;
    align-items:start;
  }
  #progress-wrap{grid-area:progress}
  #daily-cta{grid-area:cta}
  #overdue-section{grid-area:overdue}
  #task-list{grid-area:tasks}
  #next-up-wrap,#capacity-warning-wrap{grid-area:side}
  #shutdown-section{grid-area:shutdown}
  #task-list{position:relative}
  #task-list .task-card{padding:16px 16px 16px 18px;border-radius:18px}
  #next-up-wrap .next-up-card,#capacity-warning-wrap .capacity-warning{position:sticky;top:18px}
  #capacity-warning-wrap .capacity-warning{margin-top:16px;margin-bottom:0}
  #shutdown-section .shutdown-box{margin-top:0;min-height:220px}
  #next-up-wrap .next-up-card{min-height:150px}

  .weekly-content,.monthly-content,.settings-content{max-width:1400px}
  .stats-row{gap:12px}
  .stat-card{padding:16px 12px;border-radius:18px}
  .bar-chart{height:160px;gap:10px}
  .chart-wrap,.reflection-box,.insight-box{border-radius:18px}
  .month-grid{gap:8px;max-width:1100px}
  .month-cell{font-size:12px;border-radius:10px}

  .search-wrap{max-width:920px;padding-top:24px}
  .search-results{max-width:920px}

  .settings-content{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 24px;align-items:start}
  .settings-section{margin-bottom:0}

  .modal-overlay{align-items:center;padding:24px}
  .modal-sheet,.detail-modal{border-radius:26px;max-width:min(860px,92vw);max-height:min(88vh,900px);padding-bottom:24px}
  #add-task-overlay .modal-sheet{max-width:min(900px,92vw)}
  .detail-modal{padding:28px}
}

@media (min-width: 1400px){
  #app{padding-left:112px}
  #bottom-nav{width:94px}
  #header{padding-left:40px;padding-right:40px}
  .daily-content,.weekly-content,.monthly-content,.settings-content,.search-wrap,.search-results{padding-left:40px;padding-right:40px}
  .daily-content{grid-template-columns:minmax(0,1.65fr) minmax(380px,.82fr)}
}


/* desktop upgrade pass v2 */
.desktop-planner-card,.desktop-daydrop-card{
  background:linear-gradient(180deg,#171D29 0%, #121722 100%);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:0 16px 34px rgba(0,0,0,.18);
}
.desktop-planner-card{
  padding:16px 16px 12px;
  position:sticky;
  top:18px;
}
.desktop-planner-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.desktop-planner-title{
  font-size:18px;
  font-weight:700;
}
.desktop-planner-sub{
  font-size:12px;
  color:var(--text3);
  margin-top:4px;
  line-height:1.5;
}
.desktop-planner-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.desktop-chip-btn{
  background:var(--bg3);
  color:var(--text2);
  border:1px solid var(--border);
  border-radius:10px;
  padding:7px 10px;
  font-size:11px;
  font-weight:700;
  cursor:pointer;
  font-family:'DM Mono',monospace;
}
.desktop-chip-btn:hover{background:var(--bg4)}
.desktop-timeline{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
  max-height:58vh;
  overflow:auto;
  padding-right:2px;
}
.desktop-slot{
  display:grid;
  grid-template-columns:62px 1fr;
  gap:10px;
  align-items:flex-start;
}
.desktop-slot-time{
  font-size:11px;
  color:var(--text4);
  font-family:'DM Mono',monospace;
  padding-top:11px;
}
.desktop-slot-drop{
  min-height:54px;
  border:1px dashed rgba(255,255,255,.08);
  border-radius:14px;
  background:rgba(255,255,255,.02);
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  padding:8px 10px;
  transition:all .14s ease;
}
.desktop-slot-drop:hover{
  border-color:rgba(124,158,255,.34);
  background:rgba(124,158,255,.06);
}
.desktop-slot-empty{
  font-size:12px;
  color:var(--text4);
}
.desktop-planner-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  background:var(--bg3);
  border:1px solid rgba(255,255,255,.06);
  color:var(--text);
  font-size:12px;
  line-height:1.3;
  max-width:100%;
}
.desktop-planner-pill strong{
  font-size:12px;
  white-space:nowrap;
}
.desktop-planner-pill span{
  color:var(--text3);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.day-strip.drop-enabled .day-btn{position:relative}
.task-card{
  position:relative;
}
.task-card.drop-above{box-shadow:0 -3px 0 0 var(--accent) inset}
.task-card.drop-below{box-shadow:0 3px 0 0 var(--accent) inset}
.settings-section{
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(180deg,#171D29 0%, #111722 100%);
  box-shadow:0 16px 34px rgba(0,0,0,.16);
  padding:16px;
}
.settings-title{
  font-size:11px;
  letter-spacing:.12em;
  margin-bottom:14px;
}
.settings-row{
  border-radius:14px;
  background:rgba(255,255,255,.03);
}
.settings-content .settings-row:last-child{margin-bottom:0}
.desktop-nav-top,.desktop-nav-brand{display:none}
@media (min-width:1100px){
  .desktop-shell-toggle{display:inline-flex}
  .desktop-nav-top,.desktop-nav-brand{display:flex}
  .desktop-nav-top{width:100%;justify-content:center;align-items:center;padding:2px 0 6px;}
.desktop-nav-brand{align-items:center;justify-content:center;padding:0;border:none;background:none;cursor:pointer;width:100%;height:auto;min-height:108px;border-radius:28px;background:transparent;box-shadow:none;margin:0 auto 10px;overflow:hidden;}
.desktop-brand-logo{width:100px;height:100px;display:block;max-width:100%;margin:0 auto;filter:drop-shadow(0 14px 30px rgba(124,158,255,.28));}
  #bottom-nav{transition:width .18s ease,padding .18s ease,left .18s ease}
  #app{transition:padding-left .18s ease}
  #next-up-wrap,#capacity-warning-wrap,#shutdown-section{grid-column:2}
  #capacity-warning-wrap{display:block}
  #daily-cta,#progress-wrap,#overdue-section,#task-list{grid-column:1}
  #capacity-warning-wrap .desktop-planner-card{margin-bottom:14px}
  .daily-content{
    grid-template-columns:minmax(0,1.25fr) minmax(420px,.95fr);
  }
}
@media (min-width:1400px){
  .daily-content{
    grid-template-columns:minmax(0,1.35fr) minmax(470px,.9fr);
  }
}

.is-hidden{display:none!important}
.progress-fill.is-zero{width:0%}
.goal-plus-icon{font-size:18px}
.month-helper-note{margin:-2px 0 12px}
.search-empty-state{color:var(--text4);font-size:13px;padding-top:24px;text-align:center}

/* DayFlow notices */
#app-status-banner{display:none;padding:0 0 18px;position:relative;z-index:40}
#app-status-banner.show{display:block}
.status-banner{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(124,158,255,.24);
  background:
    radial-gradient(circle at top left, rgba(124,158,255,.16), transparent 34%),
    linear-gradient(135deg, rgba(24,33,49,.96), rgba(18,23,34,.94));
  border-radius:20px;
  padding:16px 18px;
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:space-between;
  box-shadow:
    0 0 0 1px rgba(124,158,255,.05),
    0 14px 34px rgba(0,0,0,.18),
    0 0 30px rgba(124,158,255,.08);
}
.status-banner::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(124,158,255,.10), transparent 20%, transparent 78%, rgba(105,213,160,.06));
}
.status-banner::after{
  content:'';
  position:absolute;
  left:0;
  top:14px;
  bottom:14px;
  width:4px;
  border-radius:0 999px 999px 0;
  background:linear-gradient(180deg, rgba(124,158,255,.98), rgba(105,213,160,.85));
  box-shadow:0 0 18px rgba(124,158,255,.35);
}
.status-banner.warning{
  border-color:rgba(255,209,102,.26);
  background:
    radial-gradient(circle at top left, rgba(255,209,102,.14), transparent 34%),
    linear-gradient(135deg, rgba(24,33,49,.96), rgba(18,23,34,.94));
}
.status-banner.warning::after{
  background:linear-gradient(180deg, rgba(255,209,102,.96), rgba(255,138,101,.82));
  box-shadow:0 0 18px rgba(255,209,102,.34);
}
.status-banner.danger{
  border-color:rgba(255,107,138,.30);
  background:
    radial-gradient(circle at top left, rgba(255,107,138,.16), transparent 34%),
    linear-gradient(135deg, rgba(27,26,40,.96), rgba(18,23,34,.95));
  box-shadow:
    0 0 0 1px rgba(255,107,138,.06),
    0 18px 42px rgba(0,0,0,.22),
    0 0 34px rgba(255,107,138,.10);
}
.status-banner.danger::after{
  background:linear-gradient(180deg, rgba(255,107,138,.98), rgba(212,170,255,.82));
  box-shadow:0 0 18px rgba(255,107,138,.42);
}
.status-banner.success{
  border-color:rgba(105,213,160,.24);
  background:
    radial-gradient(circle at top left, rgba(105,213,160,.14), transparent 34%),
    linear-gradient(135deg, rgba(24,33,49,.96), rgba(18,23,34,.94));
}
.status-banner.success::after{
  background:linear-gradient(180deg, rgba(105,213,160,.96), rgba(124,158,255,.82));
  box-shadow:0 0 18px rgba(105,213,160,.34);
}
.status-banner-left{
  min-width:0;
  position:relative;
  z-index:1;
  flex:1;
  padding-left:4px;
}
.status-banner-kicker{
  font-size:10px;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-family:'DM Mono',monospace;
  margin-bottom:6px;
}
.status-banner-title{
  font-size:15px;
  font-weight:700;
  color:var(--text);
  line-height:1.35;
}
.status-banner-copy{
  margin-top:4px;
  font-size:13px;
  line-height:1.55;
  color:var(--text2);
  max-width:980px;
}
.status-banner-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
  align-items:center;
  position:relative;
  z-index:1;
  flex-shrink:0;
}
.status-mini-btn{
  background:var(--bg3);
  border:1px solid rgba(255,255,255,.08);
  color:var(--text);
  border-radius:12px;
  padding:10px 14px;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  min-height:40px;
  box-shadow:0 8px 18px rgba(0,0,0,.14);
}
.status-mini-btn:hover{transform:translateY(-1px)}
.status-mini-btn.primary{
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 72%, #fff 28%));
  border-color:transparent;
  color:#0D1320;
}
.status-mini-btn.ghost{background:rgba(255,255,255,.04)}
#app-status-modal-overlay{
  z-index:280;
  background:rgba(5,8,14,.76);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.status-modal{
  background:
    radial-gradient(circle at top left, rgba(124,158,255,.18), transparent 30%),
    radial-gradient(circle at bottom right, rgba(105,213,160,.08), transparent 36%),
    linear-gradient(145deg,#171f2d,#111722 70%);
  border:1px solid rgba(124,158,255,.20);
  border-radius:26px 26px 0 0;
  padding:26px 24px calc(24px + var(--safe-bottom));
  width:100%;
  max-width:560px;
  animation:sheetUp .25s ease;
  position:relative;
  box-shadow:
    0 0 0 1px rgba(124,158,255,.06),
    0 24px 80px rgba(0,0,0,.42),
    0 0 50px rgba(124,158,255,.10);
}
.status-modal::before{
  content:'';
  position:absolute;
  left:0;
  top:20px;
  bottom:20px;
  width:5px;
  border-radius:0 999px 999px 0;
  background:linear-gradient(180deg, rgba(255,107,138,.98), rgba(212,170,255,.82));
  box-shadow:0 0 20px rgba(255,107,138,.42);
}
.status-modal .modal-handle{margin-bottom:16px}
.status-modal .close-btn{
  top:18px;
  right:18px;
  width:40px;
  height:40px;
  border-radius:12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
}
.status-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,107,138,.12);
  border:1px solid rgba(255,107,138,.22);
  font-size:11px;
  color:#ffb4c3;
  font-family:'DM Mono',monospace;
  margin-bottom:12px;
}
.status-pill::before{
  content:'';
  width:8px;
  height:8px;
  border-radius:999px;
  background:#FF6B8A;
  box-shadow:0 0 14px rgba(255,107,138,.7);
}
.status-modal-title{
  font-size:26px;
  font-weight:700;
  letter-spacing:-.03em;
  color:var(--text);
  margin-bottom:8px;
  padding-right:28px;
  line-height:1.12;
}
.status-modal-copy{
  font-size:14px;
  line-height:1.68;
  color:var(--text2);
}
.status-modal-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:20px;
}
.status-modal .btn-add,
.status-modal .secondary-btn{
  min-height:46px;
  border-radius:14px;
  padding:0 16px;
}
@media (max-width:720px){
  #app-status-banner{padding:0 0 14px}
  .status-banner{flex-direction:column;align-items:flex-start;padding:15px 15px 14px}
  .status-banner-actions{justify-content:flex-start;width:100%}
  .status-mini-btn{flex:0 0 auto}
}

/* ==========================================================================
   DayFlow consistency layer
   Keeps visual tokens aligned without rewriting component logic.
   ========================================================================== */
:root{
  --ui-font-sans:'DM Sans',system-ui,sans-serif;
  --ui-font-mono:'DM Mono',monospace;
  --ui-control-bg:var(--bg3);
  --ui-control-border-color:var(--border);
  --ui-control-border:1px solid var(--ui-control-border-color);
  --ui-control-radius:10px;
  --ui-pill-radius:999px;
  --ui-control-padding-y:9px;
  --ui-control-padding-x:12px;
  --ui-pill-padding-y:6px;
  --ui-pill-padding-x:12px;
  --ui-control-font-size:12px;
  --ui-pill-font-size:11px;
}

button,
input,
select,
textarea{
  font-family:var(--ui-font-sans);
}

.header-label,
.pb-label,
.pb-value,
.sb-value,
.section-label,
.progress-meta span,
.task-meta,
.task-tag,
.task-priority,
.overdue-label,
.estimate-title,
.estimate-field label,
.schedule-field label,
.recurring-days-title,
.add-section-title,
.cal-time,
.cal-block-sub,
.stat-value,
.bar-label,
.month-day-label,
.chart-title,
.trend-bar-label,
.nav-label,
.next-up-label,
.next-up-meta,
.insight-stat span,
.detail-chip,
.ad-label,
.permission-badge,
.onboard-step-copy,
.onboard-preview-name,
.auth-label,
.status-banner-kicker,
.status-pill{
  font-family:var(--ui-font-mono) !important;
}

.btn-add,
.btn-sm,
.secondary-btn,
.auth-btn,
.onboard-btn,
.helper-btn,
.status-mini-btn,
.desktop-chip-btn,
.template-chip,
.mode-btn,
.dur-btn,
.pri-btn,
.month-nav-btn,
.recurring-day-btn{
  border-radius:var(--ui-control-radius) !important;
  padding:var(--ui-control-padding-y) var(--ui-control-padding-x) !important;
  font-size:var(--ui-control-font-size) !important;
}

.btn-add,
.btn-sm,
.auth-btn,
.onboard-btn{
  font-family:var(--ui-font-sans) !important;
  font-weight:700 !important;
}

.secondary-btn,
.helper-btn,
.status-mini-btn,
.desktop-chip-btn,
.template-chip,
.mode-btn,
.dur-btn,
.pri-btn,
.month-nav-btn,
.recurring-day-btn{
  background:var(--ui-control-bg) !important;
  border:var(--ui-control-border) !important;
}

.task-tag,
.task-priority,
.premium-pill,
.tag-chip,
.tag-manage-chip,
.detail-chip,
.locked-pill,
.plan-chip,
.permission-badge,
.onboard-pill,
.desktop-planner-pill,
.status-pill{
  border-radius:var(--ui-pill-radius) !important;
  padding:var(--ui-pill-padding-y) var(--ui-pill-padding-x) !important;
  font-size:var(--ui-pill-font-size) !important;
}

.premium-pill,
.tag-chip,
.tag-manage-chip,
.plan-chip,
.permission-badge,
.onboard-pill,
.desktop-planner-pill{
  border:var(--ui-control-border) !important;
}

.search-input,
.estimate-num,
.schedule-select,
.notes-input,
.hour-select,
.detail-notes,
.subtask-add-input,
.actual-input,
.auth-input,
.onboard-input{
  border:var(--ui-control-border) !important;
  font-family:var(--ui-font-sans) !important;
}

.task-timer-btn,
.task-mini-action{
  border:var(--ui-control-border) !important;
  font-family:var(--ui-font-mono) !important;
}

.settings-row,
.settings-section,
.auth-card,
.notice-card,
.helper-card,
.chart-wrap,
.reflection-box,
.insight-box,
.desktop-planner-card,
.desktop-daydrop-card{
  border-color:var(--ui-control-border-color) !important;
}

.template-chip{
  border-style:solid !important;
}

.desktop-nav-brand{
  background:transparent !important;
}


/* Auth tabs neutralised here; final styles live in assets/css/pages/auth.css */

