/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
button{background:none;border:none;cursor:pointer;font:inherit;color:inherit;}
input,textarea{font:inherit;color:inherit;background:none;border:none;outline:none;}
::-webkit-scrollbar{width:0;}

/* ── THEMES ── */
[data-theme="dark"]  {--bg:#111113;--bg2:#18181c;--surface:#1e1e23;--surface2:#26262d;--border:#2e2e38;--text:#eeeef0;--text-muted:#6b6b78;--text-soft:#9898a8;--nav-bg:#16161a;--overlay:rgba(0,0,0,.6);}
[data-theme="dim"]   {--bg:#1c1a26;--bg2:#221f30;--surface:#28253a;--surface2:#302d44;--border:#3a3650;--text:#e4e2f0;--text-muted:#7070a0;--text-soft:#a0a0c0;--nav-bg:#201e2e;--overlay:rgba(0,0,0,.55);}
[data-theme="sand"]  {--bg:#2a2420;--bg2:#322c28;--surface:#3a3430;--surface2:#423c38;--border:#504840;--text:#f0ebe4;--text-muted:#887870;--text-soft:#b0a898;--nav-bg:#282220;--overlay:rgba(0,0,0,.55);}
[data-theme="light"] {--bg:#f5f2ee;--bg2:#edeae4;--surface:#fff;--surface2:#f8f5f1;--border:#e0dbd2;--text:#1a1714;--text-muted:#9a9289;--text-soft:#6b6460;--nav-bg:#fff;--overlay:rgba(0,0,0,.3);}

/* ── BASE ── */
html,body{height:100%;background:var(--bg);}
body{font-family:'DM Sans',sans-serif;color:var(--text);transition:background .35s,color .35s;overscroll-behavior:none;}
.app{max-width:420px;margin:0 auto;min-height:100dvh;background:var(--bg);position:relative;}
.view-scroll{overflow-y:auto;padding-bottom:100px;-webkit-overflow-scrolling:touch;}

/* ── LOADING SPLASH ── */
.loading-splash{display:flex;align-items:center;justify-content:center;height:100dvh;}
.loading-icon{font-size:40px;animation:pulse 1.5s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ── HEADER ── */
.header{padding:52px 20px 14px;}
.header-top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px;}
.app-name{font-family:'DM Serif Display',serif;font-size:20px;line-height:1;color:var(--accent);}
.date-label{font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);}
.greeting{font-family:'DM Serif Display',serif;font-size:30px;color:var(--text);line-height:1.1;}
.greeting em{font-style:italic;color:var(--accent);}
.day-progress{display:flex;align-items:center;gap:10px;margin-top:12px;}
.progress-track{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden;}
.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .8s cubic-bezier(.16,1,.3,1);}
.progress-text{font-size:12px;color:var(--text-muted);font-weight:500;white-space:nowrap;}
.progress-text.all-done{color:var(--accent);}

/* ── ACCORDION ── */
.groups-list{padding:10px 16px 0;display:flex;flex-direction:column;gap:10px;}
.group-block{border-radius:18px;overflow:hidden;border:1.5px solid var(--border);background:var(--surface);transition:border-color .3s,background .35s;animation:fadeIn .3s ease both;}
.group-block.open{border-color:var(--accent);}
.group-header{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .2s;}
.group-header:active{background:var(--surface2);}
.group-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.group-meta{flex:1;min-width:0;}
.group-name{font-size:14px;font-weight:500;color:var(--text);margin-bottom:3px;transition:color .35s;}
.group-block.open .group-name{color:var(--accent);}
.group-progress{display:flex;align-items:center;gap:7px;}
.mini-track{flex:1;height:3px;background:var(--border);border-radius:2px;overflow:hidden;min-width:60px;}
.mini-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .6s cubic-bezier(.16,1,.3,1);}
.mini-label{font-size:11px;color:var(--text-muted);white-space:nowrap;}
.mini-label.all-done{color:var(--accent);}
.group-chevron{color:var(--text-muted);transition:transform .3s,color .35s;flex-shrink:0;}
.group-block.open .group-chevron{transform:rotate(180deg);color:var(--accent);}
.group-body{overflow:hidden;max-height:0;transition:max-height .45s cubic-bezier(.16,1,.3,1);}
.group-block.open .group-body{max-height:2000px;}
.group-inner{padding:0 12px 12px;display:flex;flex-direction:column;gap:7px;}
.group-empty-hint{font-size:13px;color:var(--text-muted);padding:4px 2px;}

/* ── HABIT ROW ── */
.habit-row{background:var(--surface2);border-radius:13px;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .25s,transform .15s;position:relative;overflow:hidden;user-select:none;-webkit-tap-highlight-color:transparent;}
.habit-row::before{content:'';position:absolute;inset:0;background:var(--done-glow);opacity:0;transition:opacity .4s;}
.habit-row.done{background:var(--done-light);}
.habit-row.done::before{opacity:1;}
.habit-row:active{transform:scale(.985);}
.check-ring{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .35s cubic-bezier(.34,1.56,.64,1),border-color .35s;background:transparent;}
.habit-row.done .check-ring{background:var(--done);border-color:var(--done);transform:scale(1.08);}
.check-icon{opacity:0;transform:scale(.4) rotate(-10deg);transition:all .3s cubic-bezier(.34,1.56,.64,1) .05s;}
.habit-row.done .check-icon{opacity:1;transform:scale(1) rotate(0deg);}
.row-info{flex:1;min-width:0;}
.row-name{font-size:14px;font-weight:500;color:var(--text);margin-bottom:1px;transition:color .3s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.habit-row.done .row-name{color:var(--done);}
.row-meta{font-size:11px;color:var(--text-muted);}
.row-right{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:3px;flex-shrink:0;transition:color .3s;}
.habit-row.done .row-right{color:var(--done);}

/* ── WORKOUT LOG ── */
.workout-log{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:none;flex-direction:column;gap:8px;position:relative;z-index:1;}
.workout-log.open{display:flex;}
.log-row{display:flex;gap:6px;}
.log-group{flex:1;display:flex;flex-direction:column;}
.log-label{font-size:10px;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-weight:500;margin-bottom:3px;}
.log-field{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:12px;color:var(--text);font-family:'DM Sans',sans-serif;outline:none;transition:border-color .2s;}
.log-field:focus{border-color:var(--accent);}
.log-save{align-self:flex-end;background:var(--accent);color:#fff;border-radius:8px;padding:7px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:opacity .2s;}
.log-save:hover{opacity:.85;}

/* ── GAMING ── */
.game-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:6px 2px 4px;display:flex;align-items:center;gap:6px;}
.reset-badge{font-size:9px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:2px 6px;color:var(--text-muted);}

/* ── WORK TODOS ── */
.work-project-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:6px 2px 4px;display:flex;align-items:center;justify-content:space-between;}
.work-week-badge{font-size:9px;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:2px 6px;color:var(--text-muted);}
.todo-row{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:flex;align-items:flex-start;gap:10px;transition:background .25s,border-color .25s;cursor:pointer;position:relative;overflow:hidden;user-select:none;-webkit-tap-highlight-color:transparent;}
.todo-row::before{content:'';position:absolute;inset:0;background:var(--done-glow);opacity:0;transition:opacity .4s;}
.todo-row.done{border-color:var(--done-border);background:var(--done-light);}
.todo-row.done::before{opacity:1;}
.todo-check{width:20px;height:20px;border-radius:5px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:all .3s cubic-bezier(.34,1.56,.64,1);}
.todo-row.done .todo-check{background:var(--done);border-color:var(--done);}
.todo-content{flex:1;min-width:0;}
.todo-text{font-size:13px;color:var(--text);line-height:1.4;transition:color .3s;}
.todo-row.done .todo-text{color:var(--done);text-decoration:line-through;opacity:.7;}

/* ── ADD GROUP ROW ── */
.add-group-row{display:flex;align-items:center;gap:8px;padding:14px 18px;cursor:pointer;opacity:.6;transition:opacity .2s;-webkit-tap-highlight-color:transparent;}
.add-group-row:hover{opacity:1;}
.add-group-row span{font-size:13px;color:var(--text-muted);font-weight:500;}

/* ── NAV (text-only) ── */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:420px;max-width:100%;background:var(--nav-bg);border-top:1px solid var(--border);display:flex;padding:14px 0 max(18px,env(safe-area-inset-bottom));z-index:50;}
.nav-item{flex:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent;letter-spacing:.01em;}
.nav-item.active{color:var(--accent);font-weight:600;}

/* ── EDIT MODE ── */
.item-edit-toggle{font-size:11px;font-weight:500;color:var(--text-muted);text-align:right;padding:0 2px 2px;cursor:pointer;transition:color .2s;-webkit-tap-highlight-color:transparent;}
.item-edit-toggle:hover{color:var(--accent);}

.group-edit-controls{display:flex;align-items:center;gap:6px;flex-shrink:0;}
.edit-ctrl-btn{font-size:16px;color:var(--text-muted);padding:4px 6px;border-radius:7px;transition:background .15s,color .15s;line-height:1;-webkit-tap-highlight-color:transparent;}
.edit-ctrl-btn:hover{background:var(--surface2);color:var(--text);}
.edit-ctrl-btn.danger:hover{background:#e8555520;color:#e85555;}
.edit-done-btn{font-size:12px;font-weight:600;color:var(--accent);background:var(--accent-light);border-radius:100px;padding:5px 12px;-webkit-tap-highlight-color:transparent;white-space:nowrap;}
.edit-done-btn:hover{opacity:.85;}

.edit-row{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:10px 12px;}
.edit-move-btns{display:flex;flex-direction:column;gap:2px;flex-shrink:0;}
.move-btn{font-size:13px;color:var(--text-muted);padding:1px 4px;border-radius:5px;transition:background .15s,color .15s;line-height:1.2;-webkit-tap-highlight-color:transparent;}
.move-btn:hover:not(:disabled){background:var(--surface);color:var(--text);}
.move-btn:disabled{opacity:.25;cursor:default;}
.edit-row-label{flex:1;font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;}
.delete-btn{font-size:16px;color:var(--text-muted);padding:4px 8px;border-radius:8px;flex-shrink:0;transition:background .15s,color .15s;line-height:1;-webkit-tap-highlight-color:transparent;}
.delete-btn:hover{background:#e8555520;color:#e85555;}

.group-add-btn{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:10px;border:1.5px dashed var(--border);color:var(--text-muted);font-size:12px;cursor:pointer;transition:border-color .2s,color .2s;-webkit-tap-highlight-color:transparent;}
.group-add-btn:hover{border-color:var(--accent);color:var(--accent);}

/* ── TEMPLATES ── */
.view-header{padding:52px 20px 20px;}
.view-title{font-family:'DM Serif Display',serif;font-size:28px;color:var(--text);margin-bottom:4px;}
.view-subtitle{font-size:13px;color:var(--text-muted);line-height:1.5;}
.template-list{padding:0 16px 24px;display:flex;flex-direction:column;gap:10px;}
.template-card{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;padding:18px;transition:background .2s,border-color .2s;}
.template-card:hover{background:var(--surface2);}
.template-card.applied{border-color:var(--done-border);}
.tmpl-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;}
.tmpl-emoji{font-size:26px;line-height:1;}
.tmpl-badge{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);border-radius:100px;padding:3px 8px;}
.tmpl-name{font-size:15px;font-weight:500;color:var(--text);margin-bottom:4px;}
.tmpl-desc{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:10px;}
.tmpl-habits{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px;}
.tmpl-pill{font-size:11px;color:var(--text-soft);background:var(--surface2);border-radius:100px;padding:3px 10px;border:1px solid var(--border);}
.tmpl-footer{display:flex;align-items:center;justify-content:space-between;}
.tmpl-uses{font-size:11px;color:var(--text-muted);}
.tmpl-btn{font-size:12px;font-weight:600;color:var(--accent);background:var(--accent-light);border-radius:100px;padding:6px 16px;cursor:pointer;}
.template-card.applied .tmpl-btn{color:var(--done);background:var(--done-light);}

/* ── SETTINGS ── */
.settings-section{padding:0 16px 8px;}
.settings-section-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:0 4px;margin-bottom:8px;}
.settings-group{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:20px;}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s;}
.settings-row:last-child{border-bottom:none;}
.settings-row:hover{background:var(--surface2);}
.settings-row-left{display:flex;align-items:center;gap:12px;}
.settings-row-icon{width:32px;height:32px;border-radius:8px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.settings-row-label{font-size:14px;font-weight:500;color:var(--text);}
.settings-row-sub{font-size:12px;color:var(--text-muted);margin-top:1px;}
.settings-row-right{font-size:12px;color:var(--text-muted);}
.theme-picker{display:flex;gap:8px;}
.theme-circle{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:transform .2s,border-color .2s;flex-shrink:0;}
.theme-circle:hover{transform:scale(1.15);}
.theme-circle.active{border-color:var(--text);}
.theme-circle[data-t="dark"]{background:#111113;}
.theme-circle[data-t="dim"]{background:#1c1a26;}
.theme-circle[data-t="sand"]{background:#2a2420;}
.theme-circle[data-t="light"]{background:#f0ece6;border:2.5px solid #ccc;}
.accent-picker{display:flex;gap:7px;flex-wrap:wrap;}
.accent-circle{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:transform .2s,border-color .2s;flex-shrink:0;}
.accent-circle:hover{transform:scale(1.15);}
.accent-circle.active{border-color:var(--text);transform:scale(1.08);}
.premium-banner{margin:0 16px 20px;border-radius:18px;padding:20px;background:linear-gradient(135deg,var(--accent-light),transparent);border:1.5px solid var(--border);cursor:pointer;transition:opacity .2s;}
.premium-banner:hover{opacity:.9;}
.premium-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:6px;}
.premium-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text);margin-bottom:6px;}
.premium-price{font-size:13px;color:var(--text-muted);margin-bottom:14px;}
.premium-features{display:flex;flex-direction:column;gap:5px;margin-bottom:16px;}
.premium-feature{font-size:13px;color:var(--text-soft);display:flex;align-items:center;gap:8px;}
.premium-feature::before{content:'\2726';color:var(--accent);font-size:9px;}
.premium-cta{display:inline-block;background:var(--accent);color:#fff;font-size:13px;font-weight:600;border-radius:100px;padding:10px 22px;}
.version-label{text-align:center;font-size:11px;color:var(--text-muted);padding:8px 24px 24px;}

/* ── SHEETS ── */
.sheet-overlay{position:fixed;inset:0;background:var(--overlay);z-index:100;opacity:0;pointer-events:none;transition:opacity .3s;}
.sheet-overlay.open{opacity:1;pointer-events:auto;}
.sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(100%);width:420px;max-width:100%;background:var(--bg2);border-radius:24px 24px 0 0;padding:0 0 max(28px,env(safe-area-inset-bottom));z-index:101;transition:transform .4s cubic-bezier(.32,.72,0,1);max-height:92vh;overflow-y:auto;}
.sheet.open{transform:translateX(-50%) translateY(0);}
.sheet-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:14px auto 20px;}
.sheet-title{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text);padding:0 24px 20px;}
.sheet-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);padding:0 24px;margin-bottom:10px;}
.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px;padding:0 20px;margin-bottom:20px;}
.emoji-btn{aspect-ratio:1;border-radius:10px;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,transform .15s;-webkit-tap-highlight-color:transparent;}
.emoji-btn:hover{background:var(--surface);}
.emoji-btn.selected{background:var(--accent-light);transform:scale(1.1);}
.sheet-input-wrap{padding:0 24px;margin-bottom:20px;}
.sheet-input{width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:12px 16px;font-size:15px;color:var(--text);transition:border-color .2s;}
.sheet-input:focus{border-color:var(--accent);}
.sheet-input::placeholder{color:var(--text-muted);}
.type-pills{display:flex;gap:8px;padding:0 24px;margin-bottom:20px;flex-wrap:wrap;}
.type-pill{padding:8px 14px;border-radius:100px;border:1.5px solid var(--border);font-size:13px;font-weight:500;color:var(--text-soft);cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;}
.type-pill.selected{background:var(--accent-light);border-color:var(--accent);color:var(--accent);}
.sheet-save{margin:0 24px;width:calc(100% - 48px);padding:14px;border-radius:14px;background:var(--accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s;}
.sheet-save:hover{opacity:.9;}
.sheet-save:active{transform:scale(.97);}
.sheet-save:disabled{opacity:.4;cursor:not-allowed;}
.sheet-spacer{height:12px;}

/* ── CONFIRM ── */
.confirm-dialog{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.confirm-dialog.open{opacity:1;pointer-events:auto;}
.confirm-bg{position:absolute;inset:0;background:var(--overlay);}
.confirm-box{position:relative;width:420px;max-width:100%;background:var(--bg2);border-radius:24px 24px 0 0;padding:24px 24px max(24px,env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);}
.confirm-dialog.open .confirm-box{transform:translateY(0);}
.confirm-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:6px;}
.confirm-sub{font-size:13px;color:var(--text-muted);margin-bottom:20px;}
.confirm-btns{display:flex;flex-direction:column;gap:10px;}
.confirm-delete{padding:14px;border-radius:12px;background:#e8555520;color:#e85555;font-size:15px;font-weight:600;cursor:pointer;text-align:center;transition:background .2s;}
.confirm-delete:hover{background:#e8555530;}
.confirm-cancel{padding:14px;border-radius:12px;background:var(--surface);color:var(--text-soft);font-size:15px;cursor:pointer;text-align:center;}

/* ── TOAST ── */
.toast{position:fixed;bottom:88px;left:50%;transform:translateX(-50%) translateY(60px);background:var(--surface2);color:var(--text);border:1px solid var(--border);padding:10px 18px;border-radius:100px;font-size:13px;font-weight:500;white-space:nowrap;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .4s;opacity:0;z-index:300;pointer-events:none;}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;}

/* ── EMPTY STATE ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;padding:32px 36px;text-align:center;gap:12px;}
.empty-icon{font-size:44px;margin-bottom:8px;}
.empty-title{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text);}
.empty-sub{font-size:14px;color:var(--text-muted);line-height:1.6;}
.empty-btn{margin-top:8px;padding:12px 28px;background:var(--accent);color:#fff;border-radius:100px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s;}
.empty-btn:hover{opacity:.9;}

/* ── BLAZOR ERROR ── */
#blazor-error-ui{position:fixed;bottom:0;width:100%;padding:12px 16px;background:#e85555;color:white;display:none;z-index:1000;}
#blazor-error-ui .reload{color:white;font-weight:600;margin-left:8px;}
#blazor-error-ui .dismiss{float:right;cursor:pointer;}

/* ── PROGRESSIVE ONBOARDING ── */
.starter-card{margin:0 16px 10px;background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px;}
.starter-title{font-size:13px;font-weight:600;color:var(--text);}
.starter-input-row{display:flex;gap:8px;align-items:center;}
.starter-input{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:11px;padding:11px 12px;font-size:14px;color:var(--text);}
.starter-input:focus{border-color:var(--accent);}
.starter-add-btn{padding:10px 12px;border-radius:10px;background:var(--accent);color:#fff;font-size:12px;font-weight:600;white-space:nowrap;}
.starter-add-btn:disabled{opacity:.45;cursor:not-allowed;}

.starter-habit-row{position:relative;}
.starter-habit-row .habit-row{padding-right:44px;}
.starter-delete-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:8px;background:transparent;color:var(--text-muted);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;}
.starter-delete-btn:hover{background:#e8555520;color:#e85555;}

.progressive-hint{margin:0 16px 10px;padding:10px 12px;border-radius:12px;background:var(--accent-light);color:var(--text);font-size:12px;line-height:1.5;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.progressive-hint-btn{padding:8px 10px;border-radius:9px;background:var(--surface);border:1px solid var(--border);color:var(--accent);font-size:11px;font-weight:600;white-space:nowrap;}

.mini-stats-card{margin:0 16px 10px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:10px 12px;}
.mini-stats-title{font-size:11px;color:var(--text-muted);margin-bottom:8px;}
.mini-stats-dots{display:flex;align-items:center;justify-content:space-between;gap:6px;}
.mini-day-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:24px;}
.mini-day-dot{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--border);background:transparent;}
.mini-day-dot.done{background:var(--accent);border-color:var(--accent);}
.mini-day-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;}

/* ── MEALS ── */
.meal-row{background:var(--surface2);border:1px solid var(--border);border-radius:13px;padding:12px 14px;transition:background .25s,border-color .25s;cursor:pointer;position:relative;overflow:hidden;}
.meal-row::before{content:'';position:absolute;inset:0;background:var(--done-glow);opacity:0;transition:opacity .4s;}
.meal-row.done{border-color:var(--done-border);background:var(--done-light);}
.meal-row.done::before{opacity:1;}
.meal-row:active{transform:scale(.985);}
.meal-top{display:flex;align-items:center;gap:10px;}
.meal-time-badge{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-light);padding:3px 8px;border-radius:6px;white-space:nowrap;flex-shrink:0;}
.meal-name-text{flex:1;font-size:13px;font-weight:500;color:var(--text);transition:color .3s;}
.meal-row.done .meal-name-text{color:var(--done);}
.meal-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);}
.meal-check.done{background:var(--done);border-color:var(--done);}
.meal-macros{font-size:11px;color:var(--text-muted);margin-top:6px;display:flex;gap:6px;align-items:center;transition:color .3s;}
.meal-row.done .meal-macros{color:var(--done);opacity:.7;}
.meal-macro-sep{opacity:.4;}

.meal-time-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:6px 2px 4px;}
.meal-macro-summary{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg2);border-radius:10px;font-size:12px;font-weight:500;color:var(--text);margin-bottom:2px;}
.macro-total{color:var(--text-muted);font-weight:400;}
.macro-sep{color:var(--text-muted);opacity:.4;}

/* macro inputs in AddMealSheet */
.macro-inputs{display:flex;gap:10px;padding:0 24px;margin-bottom:20px;}
.macro-input-group{flex:1;display:flex;flex-direction:column;gap:6px;}
.macro-input-label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);}
.macro-input{text-align:center;}

/* ── ANIMATIONS ── */
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
