/* ═══════════════════════════════════════════════════
   EasyLife V2 — app.css
   Base: easylife-themes.css tokens + V2 app shell CSS
   ═══════════════════════════════════════════════════ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;1,9..144,400&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
button:focus{outline:none}
button:focus-visible{outline:1.5px solid var(--accent);outline-offset:2px}
html,body{min-height:100vh;min-height:100dvh}

/* ── Dark theme (default) ── */
:root,[data-theme="dark"]{
  --font:'Plus Jakarta Sans',system-ui,sans-serif;
  --bg:#080c15;
  --bg-card:#0f1424;
  --card-solid:#0e1628;
  --card-solid-alt:#0a0f1c;
  --col-solid:#0c1020;
  --surface:rgba(13,18,32,0.9);
  --surface-b:rgba(255,255,255,0.08);
  --surface-b2:rgba(255,255,255,0.13);
  --accent:#00d4aa;
  --accent-c:#00b4d8;
  --accent-d:rgba(0,212,170,0.1);
  --accent-bd:rgba(0,212,170,0.25);
  --pri:#e4e8f1;
  --sec:#6a7394;
  --mut:#3a4260;
  --bdr:#1a2040;
  --today-green:#22c55e;
  --today-green-d:rgba(34,197,94,0.12);
  --red-fill:rgba(52,211,153,0.15);--red-ink:#34d399;--red-tint:rgba(52,211,153,0.07);
  --amber-fill:rgba(251,191,36,0.16);--amber-ink:#fbbf24;--amber-tint:rgba(251,191,36,0.07);
  --blue-fill:rgba(56,189,248,0.16);--blue-ink:#38bdf8;--blue-tint:rgba(56,189,248,0.07);
  --gray-fill:rgba(148,163,184,0.14);--gray-ink:#94a3b8;--gray-tint:rgba(148,163,184,0.06);
  --topnav-bg:rgba(6,9,18,0.97);
  --topnav-bdr:rgba(255,255,255,0.07);
  --nav-inactive:rgba(255,255,255,0.45);
  --nav-active:#fff;
  --nav-ctx:rgba(255,255,255,0.38);
  --nav-divider:rgba(255,255,255,0.14);
  --mode-pill-bg:rgba(255,255,255,0.06);
  --mode-pill-bdr:rgba(255,255,255,0.10);
  --mode-btn-clr:rgba(255,255,255,0.40);
  --mode-btn-active-bg:rgba(255,255,255,0.12);
  --mode-btn-active-clr:#fff;
  --stab-bg:rgba(255,255,255,0.04);
  --stab-active-bg:var(--accent);
  --stab-active-clr:#000;
  --r:14px;--rl:20px;--rs:8px;
}

/* ── Light theme ── */
[data-theme="light"]{
  --bg:#f5f1ea;
  --bg-card:#fff;
  --card-solid:#fff;
  --card-solid-alt:#f8f4ed;
  --col-solid:#fbf8f2;
  --surface:rgba(255,255,255,0.92);
  --surface-b:rgba(26,24,22,0.09);
  --surface-b2:rgba(26,24,22,0.18);
  --accent:#007a5e;
  --accent-c:#0066a0;
  --accent-d:rgba(0,122,94,0.10);
  --accent-bd:rgba(0,122,94,0.25);
  --pri:#1a1816;
  --sec:#5a534a;
  --mut:#9a9388;
  --bdr:rgba(26,24,22,0.12);
  --today-green:#16a34a;
  --today-green-d:rgba(22,163,74,0.10);
  --red-fill:rgba(22,163,74,0.12);--red-ink:#15803d;--red-tint:rgba(22,163,74,0.06);
  --amber-fill:rgba(180,83,9,0.12);--amber-ink:#b45309;--amber-tint:rgba(180,83,9,0.05);
  --blue-fill:rgba(29,78,216,0.10);--blue-ink:#1d4ed8;--blue-tint:rgba(29,78,216,0.05);
  --gray-fill:rgba(100,116,139,0.12);--gray-ink:#475569;--gray-tint:rgba(100,116,139,0.05);
  --topnav-bg:rgba(251,248,242,0.97);
  --topnav-bdr:rgba(26,24,22,0.10);
  --nav-inactive:rgba(26,24,22,0.45);
  --nav-active:#1a1816;
  --nav-ctx:rgba(26,24,22,0.38);
  --nav-divider:rgba(26,24,22,0.14);
  --mode-pill-bg:rgba(26,24,22,0.06);
  --mode-pill-bdr:rgba(26,24,22,0.12);
  --mode-btn-clr:rgba(26,24,22,0.45);
  --mode-btn-active-bg:rgba(26,24,22,0.10);
  --mode-btn-active-clr:#1a1816;
  --stab-bg:rgba(26,24,22,0.05);
  --stab-active-bg:#007a5e;
  --stab-active-clr:#fff;
}

/* ── Base ── */
body{background:var(--bg);color:var(--pri);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;background:
  radial-gradient(ellipse 55% 50% at 15% 0%,rgba(0,212,170,0.07) 0%,transparent 60%),
  radial-gradient(ellipse 40% 40% at 85% 100%,rgba(0,180,216,0.04) 0%,transparent 55%);
  pointer-events:none;z-index:0}
[data-theme="light"] body::before{background:
  radial-gradient(ellipse 60% 50% at 15% 0%,rgba(110,36,24,0.04) 0%,transparent 60%),
  radial-gradient(ellipse 40% 40% at 85% 100%,rgba(26,58,92,0.04) 0%,transparent 55%);}

/* ── V2 App Shell ── */
.v2-app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;position:relative;z-index:1}
.v2-main{flex:1;max-width:1440px;margin:0 auto;width:100%;padding:0 28px 40px;position:relative;z-index:1;display:flex;flex-direction:column}
.v2-page{padding-top:20px;flex:1;display:flex;flex-direction:column}

/* ── Topnav ── */
.el-topnav{position:sticky;top:0;z-index:700;background:var(--topnav-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--topnav-bdr);padding-top:env(safe-area-inset-top,0px)}
.el-topnav-in{max-width:1440px;margin:0 auto;padding:0 28px;height:58px;display:flex;align-items:center;gap:0}

/* Logo ring */
.logo-ring{width:34px;height:34px;border-radius:50%;position:relative;flex-shrink:0}
.logo-ring::before{content:'';position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,var(--accent),#004d3a,var(--accent-c),#001a44,var(--accent));animation:lspin 4s linear infinite;filter:blur(1px)}
.logo-ring::after{content:'';position:absolute;inset:6px;border-radius:50%;background:var(--bg-card)}
@keyframes lspin{to{transform:rotate(360deg)}}
.logo-chk{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}
.logo-chk svg{width:13px;height:13px}
.el-nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;cursor:pointer;border:none;background:transparent}
.el-nav-brand{font-size:16px;font-weight:800;color:var(--pri);letter-spacing:-.4px}
.el-nav-divider{width:1px;height:18px;background:var(--nav-divider);margin:0 14px;flex-shrink:0}
.el-nav-ctx{font-size:13px;font-weight:500;color:var(--nav-ctx);text-decoration:none;transition:color .15s;flex-shrink:0}
.el-nav-ctx:hover{color:rgba(255,255,255,0.65)}

/* Center nav links */
.el-nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.el-nav-link{padding:5px 12px;border:none;background:transparent;color:var(--nav-inactive);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;border-radius:8px;transition:color .15s,background .15s;text-decoration:none;display:inline-flex;align-items:center;letter-spacing:.1px;white-space:nowrap}
.el-nav-link:hover{color:var(--nav-active);background:rgba(255,255,255,0.05)}
.el-nav-link.active{color:var(--nav-active);font-weight:600}

/* Right side */
.el-nav-right{display:flex;align-items:center;gap:10px;margin-left:28px;flex-shrink:0}
.el-mode-pill{display:flex;align-items:center;background:var(--mode-pill-bg);border:1px solid var(--mode-pill-bdr);border-radius:999px;padding:3px;gap:1px}
.el-mpb{height:26px;padding:0 12px;border:none;background:transparent;color:var(--mode-btn-clr);border-radius:999px;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:5px;transition:all .15s;letter-spacing:.1px;white-space:nowrap}
.el-mpb i{font-size:12px}
.el-mpb:hover{color:var(--nav-active)}
.el-mpb.active{background:var(--mode-btn-active-bg);color:var(--mode-btn-active-clr)}
.el-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#000;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:opacity .15s;border:none}
.el-avatar:hover{opacity:.85}

/* ── Work / Personal pill (hybrid: el-mode-pill shape + sliding thumb) ── */
.el-wp-pill{position:relative;display:inline-flex;align-items:center;background:var(--mode-pill-bg);border:1px solid var(--mode-pill-bdr);border-radius:999px;padding:3px;gap:0;flex-shrink:0;overflow:hidden}
.el-wp-thumb{position:absolute;top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px);border-radius:999px;background:var(--mode-btn-active-bg);transition:transform .32s cubic-bezier(0.34,1.15,0.5,1);z-index:0;pointer-events:none;box-shadow:0 1px 2px rgba(0,0,0,0.18)}
.el-wpb{position:relative;z-index:1;height:26px;padding:0 14px;border:none;background:transparent;color:var(--mode-btn-clr);border-radius:999px;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:color .18s;letter-spacing:.1px;white-space:nowrap;min-width:78px}
.el-wpb i{font-size:13px;opacity:.85}
.el-wpb:hover{color:var(--nav-active)}
.el-wpb.active{color:var(--mode-btn-active-clr)}
.el-wpb.active i{opacity:1}
[data-theme="light"] .el-wp-pill{background:var(--mode-pill-bg);border-color:var(--mode-pill-bdr)}
[data-theme="light"] .el-wpb{color:var(--mode-btn-clr)}
[data-theme="light"] .el-wpb:hover{color:var(--pri)}
[data-theme="light"] .el-wpb.active{color:var(--mode-btn-active-clr)}

/* Compact variant for the mobile dashboard header */
.el-wp-pill.el-wp-sm{padding:2px}
.el-wp-pill.el-wp-sm .el-wp-thumb{top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px)}
.el-wp-pill.el-wp-sm .el-wpb{height:24px;padding:0 11px;font-size:11px;min-width:64px;gap:4px}
.el-wp-pill.el-wp-sm .el-wpb i{font-size:12px}

/* Light theme topnav overrides */
[data-theme="light"] .el-topnav{background:var(--topnav-bg);border-bottom-color:var(--topnav-bdr);box-shadow:0 1px 0 rgba(26,24,22,0.06)}
[data-theme="light"] .el-nav-brand{color:var(--pri)}
[data-theme="light"] .el-nav-ctx{color:var(--nav-ctx)}
[data-theme="light"] .el-nav-link{color:var(--nav-inactive)}
[data-theme="light"] .el-nav-link:hover{color:var(--nav-active);background:rgba(26,24,22,0.05)}
[data-theme="light"] .el-nav-link.active{color:var(--nav-active)}
[data-theme="light"] .el-nav-divider{background:var(--nav-divider)}
[data-theme="light"] .el-mode-pill{background:var(--mode-pill-bg);border-color:var(--mode-pill-bdr)}
[data-theme="light"] .el-mpb{color:var(--mode-btn-clr)}
[data-theme="light"] .el-mpb:hover{color:var(--pri)}
[data-theme="light"] .el-mpb.active{background:var(--mode-btn-active-bg);color:var(--mode-btn-active-clr)}
[data-theme="light"] .el-avatar{background:var(--accent);color:#fff}

/* ── Sub-nav ── */
.el-subnav{display:flex;align-items:center;justify-content:space-between;padding:14px 0 18px;gap:16px}
.el-subnav-tabs{display:flex;align-items:center;gap:2px;background:var(--stab-bg);border:1px solid var(--surface-b);border-radius:12px;padding:3px}
.el-stab{height:30px;padding:0 13px;border:none;background:transparent;color:var(--sec);border-radius:9px;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);display:inline-flex;align-items:center;gap:5px;transition:all .15s;text-decoration:none;letter-spacing:.1px}
.el-stab i{font-size:13px}
.el-stab:hover{color:var(--pri);background:rgba(255,255,255,0.05)}
.el-stab.active{background:var(--stab-active-bg);color:var(--stab-active-clr)}
.el-subnav-date{font-size:11px;font-weight:500;color:var(--mut);white-space:nowrap;letter-spacing:.3px}
[data-theme="light"] .el-subnav-tabs{background:var(--stab-bg);border-color:var(--surface-b)}
[data-theme="light"] .el-stab{color:var(--sec)}
[data-theme="light"] .el-stab:hover{background:rgba(26,24,22,0.05);color:var(--pri)}
[data-theme="light"] .el-stab.active{background:var(--stab-active-bg);color:var(--stab-active-clr)}

/* ── Avatar dropdown ── */
.av-wrap{position:relative;display:flex;align-items:center}
.av-menu{position:absolute;top:calc(100% + 10px);right:0;width:230px;background:var(--bg-card);border:1px solid var(--surface-b2);border-radius:16px;padding:5px;box-shadow:0 20px 50px rgba(0,0,0,0.40),0 4px 14px rgba(0,0,0,0.20);z-index:700;display:none}
[data-theme="light"] .av-menu{box-shadow:0 8px 28px rgba(26,24,22,0.14),0 2px 6px rgba(26,24,22,0.08)}
.av-menu.open{display:block;animation:avIn .16s cubic-bezier(0.25,1,0.5,1)}
@keyframes avIn{from{opacity:0;transform:translateY(-6px) scale(0.97)}to{opacity:1;transform:none}}
.av-user{padding:10px 13px 9px;border-bottom:1px solid var(--surface-b);margin-bottom:4px}
.av-mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;margin:0 0 6px;background:var(--mode-pill-bg);border:1px solid var(--mode-pill-bdr);border-radius:12px}
.av-mode-btn{height:32px;border:none;border-radius:9px;background:transparent;color:var(--mode-btn-clr);font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:5px;transition:background .15s,color .15s,transform .15s}
.av-mode-btn:hover{color:var(--pri);background:rgba(255,255,255,0.05)}
.av-mode-btn:active{transform:scale(.98)}
.av-mode-btn.active{background:var(--mode-btn-active-bg);color:var(--mode-btn-active-clr)}
.av-mode-btn i{font-size:13px}
.av-user-name{font-size:13px;font-weight:700;color:var(--pri)}
.av-user-sub{font-size:11px;color:var(--mut);margin-top:2px}
.av-row{display:flex;align-items:center;gap:10px;padding:9px 13px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:500;color:var(--pri);font-family:'Plus Jakarta Sans',system-ui,sans-serif;transition:background .12s;user-select:none}
.av-row:hover{background:var(--surface-b)}
.av-row i{font-size:15px;color:var(--sec);width:16px;flex-shrink:0}
.av-row-lbl{flex:1}
.av-sep{border:none;border-top:1px solid var(--surface-b);margin:4px 0}
.av-toggle{width:36px;height:20px;border-radius:10px;background:var(--mut);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;border:none;padding:0;display:inline-block;vertical-align:middle}
.av-toggle.on{background:var(--accent)}
.av-toggle::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s cubic-bezier(0.25,1,0.5,1);pointer-events:none}
.av-toggle.on::after{transform:translateX(16px)}

/* ── Logo animations ── */
@keyframes logoSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── Hero card (Today/tasks) ── */
.hero{background:var(--card-solid);border:1px solid var(--surface-b);border-radius:var(--rl);padding:18px 20px;position:relative;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.25),0 8px 32px rgba(0,0,0,.2)}
.hero.ha::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--today-green),#4ade80)}
.hero.ha{border-color:rgba(34,197,94,0.18);box-shadow:0 0 0 1px rgba(34,197,94,0.08),0 8px 32px rgba(0,0,0,.2)}
.hero .st h2{font-size:20px;font-weight:800;letter-spacing:-.5px;color:var(--pri);text-transform:none}
.hero .fl{font-size:16px;color:var(--today-green)}
.hl{display:flex;flex-direction:column;gap:2px}
.he{font-size:12px;color:var(--mut);font-style:italic;padding:10px 4px;text-align:center}
.hero.hm{background:var(--card-solid-alt);box-shadow:none;opacity:.8}
.hero.hm .st h2{color:var(--sec);font-weight:600}
.hdz{padding:5px;border-radius:var(--rs);transition:background .15s}
.hdz.dov{background:rgba(0,212,170,0.06);border:1px solid var(--accent-bd)}
[data-theme="light"] .hero{background:var(--card-solid);border-color:var(--surface-b);box-shadow:0 1px 3px rgba(26,24,22,0.06),0 4px 16px rgba(26,24,22,0.04)}
[data-theme="light"] .hero.ha{border-color:rgba(22,163,74,0.2)}
[data-theme="light"] .hero .st h2{color:var(--pri)}
[data-theme="light"] .hero .fl{color:var(--today-green)}
[data-theme="light"] .hero.hm{background:var(--card-solid-alt)}
[data-theme="light"] .he{color:var(--mut)}

/* ── Layout ── */
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.st{display:flex;align-items:center;gap:10px}
.st h2{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.3px;color:var(--sec);margin:0}
.mk{font-size:10px;text-transform:uppercase;letter-spacing:1.3px;color:var(--mut);font-weight:700}
.layout{display:grid;grid-template-columns:minmax(0,1fr) 1px minmax(0,1fr);gap:40px;align-items:start}
.divider{background:var(--surface-b);width:1px;align-self:stretch;min-height:500px}
.lc,.wqw{display:flex;flex-direction:column;gap:22px;min-width:0}

/* ── Task row ── */
.tr{display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:10px;transition:background .15s,opacity .2s;min-width:0;cursor:grab}
.tr:active{cursor:grabbing}
.tr:hover{background:rgba(255,255,255,0.04)}
.tr.done{opacity:.32}
.tr.dragging{opacity:.38;background:rgba(0,212,170,0.06)}
.ck{width:20px;height:20px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:all .18s;background:transparent;padding:0;-webkit-appearance:none;appearance:none}
.ck:hover{border-color:var(--accent)}
.ck.chk{background:var(--accent);border-color:var(--accent)}
.ck.chk::after{content:'';display:block;width:8px;height:5px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translate(1px,-1px)}
.tm{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.tt{font-size:14px;font-weight:500;word-break:break-word;color:var(--pri)}
.tr.done .tt{text-decoration:line-through;color:var(--sec)}
.tme{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--mut)}
.ta{display:flex;align-items:center;gap:4px;flex-shrink:0}
.tdl{width:24px;height:24px;border:none;background:transparent;color:var(--mut);cursor:pointer;border-radius:var(--rs);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;opacity:0;font-size:11px}
.tr:hover .tdl{opacity:1}
.tdl:hover{background:rgba(248,113,113,0.12);color:var(--red-ink)}
.task-star{width:22px;height:22px;border:none;background:transparent;cursor:pointer;color:var(--mut);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,opacity .15s;opacity:0;font-size:12px}
.tr:hover .task-star{opacity:.5}
.task-star.active{opacity:1!important;color:var(--amber-ink)}
.task-star:hover{color:var(--pri);opacity:1}
[data-theme="light"] .tr:hover{background:rgba(26,24,22,0.03)}
[data-theme="light"] .tr.done{opacity:.38}
[data-theme="light"] .ck{border-color:var(--mut)}
[data-theme="light"] .ck:hover{border-color:var(--accent)}
[data-theme="light"] .ck.chk{background:var(--accent);border-color:var(--accent)}
[data-theme="light"] .ck.chk::after{border-color:#fff}
[data-theme="light"] .tt{color:var(--pri)}
[data-theme="light"] .tr.done .tt{color:var(--mut)}
[data-theme="light"] .tdl:hover{background:rgba(180,83,9,0.1);color:var(--amber-ink)}

/* ── Done section ── */
.ds{margin-top:24px;padding-top:16px;border-top:1px solid var(--surface-b)}
.dsh{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dsl{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;color:var(--mut);font-weight:700;cursor:pointer;user-select:none}
.dscl{border:none;background:transparent;color:var(--mut);font-size:10px;text-transform:uppercase;letter-spacing:.8px;cursor:pointer;font-weight:700;font-family:var(--font);padding:4px 8px;border-radius:var(--rs);transition:all .15s}
.dscl:hover{color:var(--pri);background:rgba(255,255,255,0.06)}
.layout-easy .ciw{padding-right:14px}

/* ── Work queue ── */
.rc{display:flex;flex-direction:column;gap:12px;min-width:0}
.col{border:1px solid var(--surface-b);border-radius:var(--r);padding:11px 12px 10px;display:flex;flex-direction:column;min-width:0;background:var(--col-solid);transition:background .12s,border-color .12s}
.col.drag-over{background:var(--accent-d);border-color:var(--accent)}
.colh{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;gap:8px}
.coll{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;padding:3px 10px;border-radius:999px;min-width:0;letter-spacing:.4px}
.coll i{font-size:11px;flex-shrink:0}
.coll .lb{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.colc{font-size:10px;color:var(--mut);font-weight:700;flex-shrink:0}
.colis{display:flex;flex-direction:column;gap:1px}
.cr{display:flex;align-items:center;gap:8px;padding:7px 7px;border-radius:var(--rs);transition:background .15s;min-width:0;cursor:grab}
.cr:active{cursor:grabbing}
.cr:hover{background:rgba(255,255,255,0.04)}
.cr.done{opacity:.32}
.cr.dragging{opacity:.38;background:rgba(0,212,170,0.06)}
.crc{width:15px;height:15px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;background:transparent;padding:0;-webkit-appearance:none;appearance:none}
.crc:hover{border-color:var(--accent)}
.crc.chk{background:var(--accent);border-color:var(--accent)}
.crc.chk::after{content:'';display:block;width:6px;height:4px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translate(0,-1px)}
.crm{flex:1;min-width:0;display:flex;align-items:baseline;gap:7px;cursor:pointer}
.crt{font-size:13px;font-weight:500;line-height:1.4;color:var(--pri);word-break:break-word;flex:1;min-width:0}
.cr.done .crt{text-decoration:line-through;color:var(--sec)}
.crd{width:20px;height:20px;border:none;background:transparent;color:var(--mut);cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;opacity:0;font-size:11px}
.cr:hover .crd{opacity:1}
.crd:hover{color:var(--red-ink)}
.cole{font-size:12px;color:var(--mut);font-style:italic;padding:5px 7px}
[data-theme="light"] .col{background:var(--col-solid);border-color:var(--surface-b)}
[data-theme="light"] .cr:hover{background:rgba(26,24,22,0.03)}
[data-theme="light"] .crt{color:var(--pri)}
[data-theme="light"] .cr.done .crt{color:var(--mut)}
[data-theme="light"] .cole{color:var(--mut)}
[data-theme="light"] .crc{border-color:var(--mut)}
[data-theme="light"] .crc:hover{border-color:var(--accent)}
[data-theme="light"] .crc.chk{background:var(--accent);border-color:var(--accent)}
[data-theme="light"] .crc.chk::after{border-color:#fff}

/* ── Composer ── */
.cs{margin-bottom:8px}
.comp{display:flex;gap:8px;align-items:stretch}
.ciw{flex:1;height:44px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.05);border-radius:var(--r);padding:0 8px 0 16px;display:flex;align-items:center;gap:8px;transition:border-color .15s,background .15s;min-width:0}
.ciw:focus-within{border-color:var(--accent-bd);background:rgba(0,212,170,0.04)}
.ciw input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:14px;color:var(--pri);outline:none;min-width:0;padding:0;height:100%}
.ciw input::placeholder{color:var(--mut);font-style:italic}
.ab{height:44px;padding:0 18px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.06);color:var(--pri);border-radius:var(--r);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--font);display:inline-flex;align-items:center;gap:6px;transition:all .15s;flex-shrink:0}
.ab:hover{background:var(--accent);color:#000;border-color:transparent;box-shadow:0 4px 20px rgba(0,212,170,.3)}
.ab:active{transform:scale(.97)}
.ab i{font-size:14px}
[data-theme="light"] .ciw{background:rgba(255,255,255,0.8);border-color:var(--surface-b)}
[data-theme="light"] .ciw:focus-within{border-color:var(--accent-bd);background:#fff}
[data-theme="light"] .ab{background:rgba(26,24,22,0.06);border-color:var(--surface-b);color:var(--pri)}
[data-theme="light"] .ab:hover{background:var(--accent);color:#fff;border-color:transparent}

/* ── Flip card ── */
.flip-container{perspective:1800px;position:relative}
.flipper{position:relative;transform-style:preserve-3d;-webkit-transform-style:preserve-3d;transition:transform .6s cubic-bezier(0.4,0,0.2,1)}
.flipper.flipped{transform:rotateY(180deg)}
.flip-face{position:relative;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:rotateY(0deg)}
.flip-back{position:absolute;top:0;left:0;right:0;height:100%;transform:rotateY(180deg)}
.flipper.flipped .flip-front{pointer-events:none}
.flipper:not(.flipped) .flip-back{pointer-events:none}
.flip-toggle{position:absolute;top:14px;right:14px;background:rgba(255,255,255,0.06);border:1px solid var(--surface-b2);cursor:pointer;color:var(--sec);display:inline-flex;align-items:center;gap:5px;font-family:var(--font);font-size:10px;font-weight:700;letter-spacing:.4px;padding:5px 10px;border-radius:999px;transition:all .15s;z-index:2;text-transform:uppercase}
.flip-toggle:hover{color:var(--pri);border-color:var(--accent-bd);background:var(--accent-d)}
.flip-toggle i{font-size:11px}
[data-theme="light"] .flip-toggle{background:rgba(26,24,22,0.06);border-color:var(--surface-b2);color:var(--sec)}
[data-theme="light"] .flip-toggle:hover{background:rgba(26,24,22,0.1);color:var(--pri)}

/* ── Strategic section (Big Wins + Deadlines) ── */
.wqx{display:grid;grid-template-columns:1fr 1fr;gap:40px}
@media(max-width:900px){.wqx{grid-template-columns:1fr;gap:20px}}
.wqs{display:flex;flex-direction:column;min-width:0}
.wqs-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--surface-b)}
.wqs-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.3px;color:var(--sec);margin:0}
.wqs-add{width:22px;height:22px;border:none;background:rgba(255,255,255,0.06);color:var(--sec);border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .15s}
.wqs-add:hover{background:var(--accent-d);color:var(--accent)}
.wqs-list{display:flex;flex-direction:column}
.wqs-empty{font-size:12px;color:var(--mut);font-style:italic;padding:10px 0}
.bwr{display:flex;align-items:baseline;gap:9px;padding:9px 2px;cursor:pointer;min-width:0;position:relative;transition:opacity .15s}
.bwr+.bwr{border-top:1px solid var(--surface-b)}
.bwr.done{opacity:.38}
.bwr-num{font-size:10px;font-weight:700;color:var(--accent);width:14px;flex-shrink:0;opacity:.7}
.bwr.done .bwr-num{text-decoration:line-through;opacity:.3}
.bwr-text{flex:1;font-size:13px;font-weight:500;color:var(--pri);word-break:break-word;min-width:0}
.bwr.done .bwr-text{text-decoration:line-through;color:var(--sec)}
.bwr-unstar{width:18px;height:18px;border:none;background:transparent;color:var(--mut);cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:opacity .15s;font-size:11px}
.bwr:hover .bwr-unstar{opacity:.5}
.bwr-unstar:hover{color:var(--red-ink);opacity:1!important}
.dlr{padding:9px 2px;cursor:pointer;transition:background .15s}
.dlr+.dlr{border-top:1px solid var(--surface-b)}
.dlr-row{display:flex;align-items:baseline;gap:10px;min-width:0}
.dlr-title{flex:1;font-size:13px;color:var(--pri);min-width:0;line-height:1.4;word-break:break-word;font-weight:500}
.dlr-when{font-size:10px;font-weight:700;color:var(--mut);flex-shrink:0;letter-spacing:.4px}
.dlr.soon .dlr-when{color:var(--amber-ink)}
.dlr.urgent .dlr-when{color:var(--red-ink)}
.dlr.overdue .dlr-when{color:var(--red-ink);font-weight:800}
.dlr-note{font-size:12px;color:var(--sec);font-style:italic;margin-top:4px;line-height:1.5}
[data-theme="light"] .wqs-head{border-bottom-color:var(--surface-b)}
[data-theme="light"] .wqs-title{color:var(--sec)}
[data-theme="light"] .bwr-num{color:var(--accent)}
[data-theme="light"] .bwr-text{color:var(--pri)}
[data-theme="light"] .bwr.done .bwr-text{color:var(--mut)}
[data-theme="light"] .dlr-title{color:var(--pri)}
[data-theme="light"] .dlr-note{color:var(--sec)}
[data-theme="light"] .dlr-when{color:var(--mut)}
[data-theme="light"] .dlr.soon .dlr-when{color:var(--amber-ink)}
[data-theme="light"] .dlr.urgent .dlr-when,.dlr.overdue .dlr-when{color:#b91c1c}

/* ── Week view ── */
.wv-head{margin-bottom:22px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.wv-head h2{font-size:28px;font-weight:800;letter-spacing:-.04em;color:var(--pri);margin:0}
.wv-head p{font-size:12px;color:var(--sec);margin:4px 0 0;font-weight:500}
.wg{display:grid;grid-template-columns:repeat(7,minmax(138px,1fr));gap:10px;align-items:start}
.wc2{display:flex;flex-direction:column;min-width:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--surface-b);background:var(--col-solid);transition:border-color .15s}
.wc2.ist{border-color:var(--accent-bd);background:rgba(0,212,170,0.04);box-shadow:0 0 0 1px rgba(0,212,170,0.15)}
.wch{padding:11px 11px 8px;border-bottom:1px solid var(--surface-b);position:relative}
.wc2.ist .wch::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-c))}
.wcd{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;font-weight:700;color:var(--mut);margin-bottom:2px}
.wc2.ist .wcd{color:var(--accent)}
.wcdt{font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--pri);line-height:1}
.wcmo{font-size:9px;color:var(--mut);margin-top:3px;text-transform:uppercase;letter-spacing:.8px;font-weight:600}
.wcts{padding:6px 5px;display:flex;flex-direction:column;gap:3px;min-height:170px}
.wt{display:flex;align-items:flex-start;gap:6px;padding:7px;border-radius:var(--rs);cursor:grab;transition:background .15s;min-width:0}
.wt:hover{background:rgba(255,255,255,0.05)}
.wtc{width:13px;height:13px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;margin-top:2px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;background:transparent;padding:0;-webkit-appearance:none;appearance:none}
.wtc:hover{border-color:var(--accent)}
.wtc.chk{background:var(--accent);border-color:var(--accent)}
.wtc.chk::after{content:'';display:block;width:5px;height:3px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translate(0,-1px)}
.wtb{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.wtt{font-size:11px;line-height:1.4;color:var(--pri);word-break:break-word;font-weight:500}
.wt.done .wtt{text-decoration:line-through;color:var(--sec)}
.wce{font-size:11px;color:var(--mut);font-style:italic;padding:8px;text-align:center}
[data-theme="light"] .wc2{background:var(--col-solid);border-color:var(--surface-b)}
[data-theme="light"] .wc2.ist{border-color:rgba(22,163,74,0.25);background:#f6fef9}
[data-theme="light"] .wcd{color:var(--mut)}
[data-theme="light"] .wc2.ist .wcd{color:var(--today-green)}
[data-theme="light"] .wcdt{color:var(--pri)}
[data-theme="light"] .wcmo{color:var(--mut)}
[data-theme="light"] .wtt{color:var(--pri)}

/* ── Done view ── */
.dv-head{margin-bottom:24px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.dv-head h2{font-size:28px;font-weight:800;letter-spacing:-.04em;color:var(--pri);margin:0}
.dv-head sub{font-size:14px;color:var(--sec);font-weight:500;display:block;margin-top:4px}
.dg{margin-bottom:26px}
.dgh{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--surface-b)}
.dgt{font-size:14px;font-weight:700;color:var(--pri);margin:0}
.dgt em{font-style:normal;color:var(--sec);font-weight:500;font-size:12px;margin-left:6px}
.dgc{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--mut);font-weight:700}
.di{display:flex;align-items:center;gap:10px;padding:8px 9px;border-radius:var(--rs);transition:background .15s}
.di:hover{background:rgba(255,255,255,0.04)}
.dic{width:14px;height:14px;border-radius:50%;background:var(--accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.dic::after{content:'';display:block;width:5px;height:3px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translate(0,-1px)}
.ditx{flex:1;font-size:13px;font-weight:500;color:var(--sec);text-decoration:line-through;text-decoration-color:var(--mut);word-break:break-word}
[data-theme="light"] .dic{background:var(--accent)}
[data-theme="light"] .ditx{color:var(--sec)}
[data-theme="light"] .dgt{color:var(--pri)}
[data-theme="light"] .dgc{color:var(--mut)}

/* ── Project cards ── */
.pv-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:20px;flex-wrap:wrap}
.pv-head-left h2{font-size:32px;font-weight:800;letter-spacing:-.04em;color:var(--pri);margin:0 0 4px}
.pv-head-left p{font-size:12px;color:var(--sec);font-weight:500;margin:0}
.pv-filters{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pf{height:32px;padding:0 14px;border:1px solid var(--surface-b);background:transparent;color:var(--sec);border-radius:999px;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);display:inline-flex;align-items:center;gap:5px;transition:all .15s}
.pf:hover{border-color:var(--surface-b2);color:var(--pri)}
.pf.active{background:var(--accent);color:#000;border-color:transparent;box-shadow:0 4px 16px rgba(0,212,170,.25)}
.pf.new-pf{border-style:dashed;color:var(--mut)}
.pf.new-pf:hover{border-color:var(--accent-bd);color:var(--accent)}
.pf i{font-size:13px}
.pv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
@media(max-width:700px){.pv-grid{grid-template-columns:1fr}}
.pc{background:var(--surface);border:1px solid var(--surface-b);border-radius:var(--rl);padding:18px 20px 44px;display:flex;flex-direction:column;min-width:0;position:relative;transition:border-color .15s,box-shadow .15s;backdrop-filter:blur(20px);box-shadow:0 1px 2px rgba(0,0,0,.2);overflow:hidden}
.pc:hover{border-color:var(--surface-b2);box-shadow:0 4px 24px rgba(0,0,0,.2)}
.pc.fav{border-color:rgba(251,191,36,0.24);background:linear-gradient(180deg,rgba(251,191,36,0.055),var(--surface) 42%)}
.pc.fav::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:var(--rl) var(--rl) 0 0;background:linear-gradient(90deg,var(--amber-ink),rgba(251,191,36,.25),transparent)}
.pc-fav{position:absolute;top:12px;left:12px;width:26px;height:26px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--mut);cursor:pointer;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:all .15s;z-index:3;backdrop-filter:blur(6px)}
.pc-fav:hover{color:var(--amber-ink);border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.08)}
.pc-fav:active{transform:scale(.93)}
.pc-fav.active{color:var(--amber-ink);border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.1)}
.pc-arc{position:absolute;bottom:12px;right:12px;width:24px;height:24px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--mut);cursor:pointer;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s;z-index:3;opacity:0}
.pc:hover .pc-arc{opacity:1}
.pc-arc:hover{color:var(--sec);border-color:var(--surface-b2);background:rgba(255,255,255,0.08)}
.pc-arc:active{transform:scale(.93)}
.pc-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;padding-left:32px;padding-right:54px;min-height:32px}
.pc-head-text{flex:1;min-width:0}
.pc-title{font-size:17px;font-weight:700;letter-spacing:-.02em;color:var(--pri);line-height:1.2;margin:0 0 4px;word-break:break-word}
.pc-sub{font-size:11px;color:var(--mut);font-weight:600;display:inline-flex;align-items:center;gap:4px;padding:2px 0}
.pc-easy{min-height:0;padding-bottom:12px}
.pc-easy .pc-head{padding-right:6px;margin-bottom:6px}
.pc-easy-bar{margin-top:0;height:4px;border-radius:999px;background:var(--surface-b);overflow:hidden}
.pc-easy-bar-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}
.pc-ring{position:absolute;top:15px;right:17px;width:44px;height:44px;z-index:2}
.pc-ring svg{width:44px;height:44px;transform:rotate(-90deg)}
.pc-ring-bg{fill:none;stroke:rgba(255,255,255,0.08);stroke-width:3}
.pc-ring-fg{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .4s ease}
.pc.fav .pc-ring-fg{stroke:var(--amber-ink)}
.pc-ring-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--pri);letter-spacing:-.02em;line-height:1}
.pc-divider{border:none;border-top:1px solid rgba(255,255,255,0.06);margin:4px 0 12px}
.pc-section-label{font-size:9px;text-transform:uppercase;letter-spacing:1.3px;color:var(--mut);font-weight:700;margin-bottom:8px}
.pc-tasks{display:flex;flex-direction:column;gap:1px;margin-bottom:6px}
.pc-task{display:flex;align-items:flex-start;gap:9px;padding:5px 3px;border-radius:6px;cursor:pointer;transition:background .15s;min-width:0}
.pc-task:hover{background:rgba(255,255,255,0.04)}
.pc-task.done{opacity:.35}
.pc-task-check{width:13px;height:13px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;margin-top:2px;background:transparent;padding:0;-webkit-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.pc-task-check:hover{border-color:var(--accent)}
.pc-task-check.chk{background:var(--accent);border-color:var(--accent)}
.pc-task-check.chk::after{content:'';display:block;width:5px;height:3px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translate(0,-1px)}
.pc-task-text{flex:1;font-size:12px;font-weight:500;line-height:1.4;color:var(--pri);word-break:break-word;min-width:0}
.pc-task.done .pc-task-text{text-decoration:line-through;color:var(--sec)}
.pc-tasks-more{font-size:11px;color:var(--mut);font-style:italic;padding:3px 3px 0;cursor:pointer;transition:color .15s;background:transparent;border:none;font-family:var(--font);text-align:left;display:block;width:100%}
.pc-tasks-more:hover{color:var(--sec)}
.pc-pagination{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:6px 2px 2px;border-top:1px solid rgba(255,255,255,0.06);margin-top:4px}
.pc-page-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--mut);background:transparent;border:1px solid rgba(255,255,255,0.1);border-radius:6px;padding:3px 7px;cursor:pointer;font-family:var(--font);transition:color .15s,border-color .15s,opacity .15s}
.pc-page-btn:hover:not(:disabled){color:var(--sec);border-color:var(--accent-bd)}
.pc-page-btn:disabled{opacity:0.3;cursor:default}
.pc-page-info{font-size:10px;color:var(--mut);font-weight:600;flex:1;text-align:center}
.pc-add{display:flex;align-items:center;gap:8px;padding:8px 4px;cursor:text;color:var(--mut);font-size:12px;border:none;border-top:1px solid rgba(255,255,255,0.05);margin-top:8px;width:100%;transition:color .15s,border-color .15s;background:transparent;border-radius:0}
.pc-add:hover{color:var(--sec);border-top-color:rgba(255,255,255,0.09)}
.pc-add.is-adding{border:1px solid var(--accent-bd);border-radius:8px;padding:7px 10px;background:rgba(0,212,170,0.03);cursor:default;margin-top:8px}
.pc-add input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:12px;color:var(--pri);outline:none;padding:0;min-width:0}
.pc-add input::placeholder{color:var(--mut);font-style:italic}
.pc-add-submit{width:22px;height:22px;border-radius:6px;background:var(--accent);border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:#000;font-size:11px;flex-shrink:0;transition:all .15s;opacity:.9}
.pc-add-submit:hover{opacity:1;transform:translateX(1px)}
.pc-task-del{width:18px;height:18px;border-radius:5px;border:none;background:transparent;color:var(--mut);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s,background .15s;margin-left:auto}
.pc-task:hover .pc-task-del{opacity:1}
.pc-task-del:hover{color:#ef4444;background:rgba(239,68,68,0.1)}
.pc-deadline-pill{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:999px;background:rgba(56,189,248,0.1);color:#38bdf8;border:1px solid rgba(56,189,248,0.2)}
.pc-deadline-pill.overdue{background:rgba(239,68,68,0.1);color:#ef4444;border-color:rgba(239,68,68,0.2)}
.pc-deadline-pill.soon{background:rgba(251,191,36,0.1);color:#fbbf24;border-color:rgba(251,191,36,0.2)}
.wv-nav{border:none;background:rgba(255,255,255,0.05);color:var(--sec);cursor:pointer;width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}
.wv-nav:hover{background:rgba(255,255,255,0.1);color:var(--pri)}
.pc-menu-btn{position:absolute;right:10px;bottom:8px;width:28px;height:28px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--sec);cursor:pointer;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}
.pc-menu-btn:hover{color:var(--pri);background:rgba(255,255,255,0.08);border-color:var(--surface-b2);transform:translateY(-1px)}
.pc.new-card{background:transparent;border:1px dashed rgba(255,255,255,0.1);box-shadow:none;display:flex;align-items:center;justify-content:center;padding:48px 20px;cursor:pointer;transition:all .15s;min-height:180px}
.pc.new-card:hover{border-color:var(--accent-bd);background:rgba(0,212,170,0.03)}
.pc-new-text{font-size:15px;font-weight:500;color:var(--mut);font-style:italic;transition:color .15s}
.pc.new-card:hover .pc-new-text{color:var(--sec)}
.pv-empty{padding:80px 20px;text-align:center;grid-column:1/-1}
.pv-empty i{font-size:32px;display:block;margin-bottom:12px;opacity:.25;color:var(--sec)}
.pv-empty p{font-size:14px;font-style:italic;color:var(--sec);margin:0}
.stats-row{display:flex;gap:14px;margin-bottom:28px;flex-wrap:wrap}
.stat-card{background:var(--surface);border:1px solid var(--surface-b);border-radius:var(--r);padding:12px 18px;display:flex;align-items:center;gap:12px;backdrop-filter:blur(20px);flex:1;min-width:140px}
.stat-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.stat-num{font-size:22px;font-weight:800;color:var(--pri);letter-spacing:-.04em;line-height:1}
.stat-lbl{font-size:10px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.8px;margin-top:2px}
[data-theme="light"] .pc{background:var(--bg-card);border-color:var(--surface-b);box-shadow:0 1px 3px rgba(26,24,22,0.06)}
[data-theme="light"] .pc:hover{border-color:var(--surface-b2);box-shadow:0 4px 16px rgba(26,24,22,0.08)}
[data-theme="light"] .pc.fav{border-color:rgba(180,83,9,0.22);background:linear-gradient(180deg,#fffbf0,#fff 44%)}
[data-theme="light"] .pc-title{color:var(--pri)}
[data-theme="light"] .pc-ring-fg{stroke:var(--accent)}
[data-theme="light"] .pc-ring-bg{stroke:rgba(26,24,22,0.1)}
[data-theme="light"] .pc-ring-text{color:var(--pri)}
[data-theme="light"] .pc-task-text{color:var(--pri)}
[data-theme="light"] .pc-task.done .pc-task-text{color:var(--mut)}
[data-theme="light"] .pc-task-check{border-color:var(--mut)}
[data-theme="light"] .pc-task-check:hover{border-color:var(--accent)}
[data-theme="light"] .pc-task-check.chk{background:var(--accent);border-color:var(--accent)}
[data-theme="light"] .pc-task-check.chk::after{border-color:#fff}
[data-theme="light"] .pc-tasks-more{color:var(--mut)}
[data-theme="light"] .pc-add{border-color:var(--surface-b);color:var(--sec);background:rgba(26,24,22,0.03)}
[data-theme="light"] .pc-add:hover{background:rgba(26,24,22,0.06);color:var(--pri)}
[data-theme="light"] .pf{border-color:var(--surface-b);color:var(--sec)}
[data-theme="light"] .pf:hover{border-color:var(--surface-b2);color:var(--pri)}
[data-theme="light"] .pf.active{background:var(--accent);color:#fff}
[data-theme="light"] .stat-card{background:var(--bg-card);border-color:var(--surface-b)}
[data-theme="light"] .stat-num{color:var(--pri)}
[data-theme="light"] .pv-head-left h2{color:var(--pri)}
[data-theme="light"] .pc.new-card{background:transparent;border-color:rgba(26,24,22,0.15)}
[data-theme="light"] .pc.new-card:hover{border-color:var(--accent-bd);background:var(--accent-d)}
[data-theme="light"] .pc-new-text{color:var(--mut)}

/* ── Popovers ── */
.popover{position:absolute;background:var(--bg-card);border:1px solid var(--surface-b2);border-radius:var(--r);padding:5px;box-shadow:0 20px 50px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.3);z-index:100;min-width:158px;animation:mIn .12s ease-out;backdrop-filter:blur(20px)}
@keyframes mIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.mi{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--rs);cursor:pointer;font-size:12px;font-weight:500;color:var(--pri);user-select:none;transition:background .12s}
.mi:hover{background:rgba(255,255,255,0.07)}
.mi.sel{font-weight:700}
.mi.sel::after{content:'';margin-left:auto;width:5px;height:5px;border-radius:50%;background:var(--accent)}
.mi i{font-size:13px;color:var(--sec)}
[data-theme="light"] .popover{background:var(--bg-card);border-color:var(--surface-b2);box-shadow:0 8px 24px rgba(0,0,0,0.12),0 2px 6px rgba(0,0,0,0.07)}
[data-theme="light"] .mi{color:var(--pri)}
[data-theme="light"] .mi:hover{background:rgba(26,24,22,0.05)}

/* ── Date pill on task row ── */
.dt{display:inline-flex;align-items:center;gap:3px;font-weight:600;cursor:pointer;padding:2px 5px;margin-left:-5px;border-radius:5px;transition:background .15s;font-size:11px;color:var(--mut);background:transparent;border:none;font-family:var(--font)}
.dt:hover{background:rgba(255,255,255,0.06);color:var(--pri)}
.dt i{font-size:10px}
.dt.ov{color:var(--red-ink)}
.dt.td{color:var(--amber-ink)}
[data-theme="light"] .dt:hover{background:rgba(26,24,22,0.05);color:var(--pri)}

/* ── Composer date button (new task) ── */
.ic{border:none;cursor:pointer;display:inline-flex;align-items:center;gap:4px;border-radius:999px;font-weight:700;flex-shrink:0;transition:opacity .15s;font-family:var(--font);padding:4px 10px;font-size:10px;height:26px;letter-spacing:.3px}
.ic:hover{opacity:.8}
.ic i.ci{font-size:11px}
.ic i.cv{font-size:10px;opacity:.5;margin-left:-2px}
.ic.dc{background:rgba(255,255,255,0.06);color:var(--sec);border:1px solid var(--surface-b)}
.ic.dc:hover{color:var(--pri);border-color:var(--surface-b2)}
.ic.dc.hd{background:var(--accent-d);color:var(--accent);border-color:var(--accent-bd)}
[data-theme="light"] .ic.dc{background:rgba(26,24,22,0.04)}

/* ── Date picker popover ── */
.dpk{width:270px;padding:10px}
.dpp{display:flex;flex-direction:column;gap:1px;margin-bottom:8px}
.dpi{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:var(--rs);cursor:pointer;font-size:12px;font-weight:500;color:var(--pri);background:transparent;border:none;font-family:var(--font);text-align:left;width:100%;transition:background .12s}
.dpi:hover{background:rgba(255,255,255,0.07)}
.dpi i{font-size:13px;color:var(--sec);width:13px;flex-shrink:0}
.dpi .dll{margin-left:auto;font-size:10px;color:var(--mut);font-variant-numeric:tabular-nums}
.dpi.clr{color:var(--mut)}
.dpi.clr:hover{color:var(--red-ink);background:rgba(248,113,113,0.08)}
.dpi.clr i{color:inherit}
.dpc{border-top:1px solid var(--surface-b);padding-top:10px;margin-top:4px}
.dpch{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding:0 4px}
.dpct{font-size:12px;font-weight:700;text-transform:capitalize;color:var(--pri)}
.dpn{width:24px;height:24px;border:none;background:transparent;color:var(--sec);cursor:pointer;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;transition:all .12s}
.dpn:hover{background:rgba(255,255,255,0.08);color:var(--pri)}
.dpg{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dpw{font-size:9px;color:var(--mut);text-align:center;padding:3px 0;text-transform:uppercase;letter-spacing:.6px;font-weight:700}
.dpd{aspect-ratio:1;border:none;background:transparent;color:var(--pri);cursor:pointer;border-radius:6px;font-size:11px;font-family:var(--font);font-variant-numeric:tabular-nums;transition:background .12s;padding:0;font-weight:500}
.dpd:hover{background:rgba(255,255,255,0.08)}
.dpd.mu{color:var(--mut);opacity:.3}
.dpd.tdy{font-weight:800;color:var(--accent)}
.dpd.seld{background:var(--accent);color:#000;font-weight:700}
.dpd.seld:hover{background:var(--accent)}
[data-theme="light"] .dpi:hover{background:rgba(26,24,22,0.05)}
[data-theme="light"] .dpd:hover{background:rgba(26,24,22,0.05)}
[data-theme="light"] .dpn:hover{background:rgba(26,24,22,0.05)}

/* Overdue row indicator */
.tr.io{border-left:2px solid var(--red-ink);background:rgba(248,113,113,0.04)}

/* ── Light: Fraunces headings ── */
[data-theme="light"] .hero .st h2,[data-theme="light"] .wv-head h2,[data-theme="light"] .dv-head h2,[data-theme="light"] .pv-head-left h2{font-family:'Fraunces',Georgia,serif;font-weight:400;letter-spacing:-.03em}
[data-theme="light"] .hero .st h2{font-size:22px}
[data-theme="light"] .he{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300}
[data-theme="light"] .wqs-empty{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300}
[data-theme="light"] .cole,[data-theme="light"] .wce,[data-theme="light"] .smse{font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:300}
[data-theme="light"] .pc-title{font-family:'Fraunces',Georgia,serif;font-weight:500}
[data-theme="light"] .dlr-note,[data-theme="light"] .bwr-text{font-family:'Fraunces',Georgia,serif;font-weight:400;font-size:14px}

/* ── Dashboard root ── */
.dash-root{padding-top:20px;display:flex;flex-direction:column;min-height:calc(100vh - 58px - 80px)}

/* ── Pro mode layout ── */
.dash-pro-layout{display:flex;flex-direction:column;gap:14px;height:100%;min-height:0}
.dash-pro-grid{flex:1;display:flex;gap:14px;overflow:hidden;min-height:0}
.dash-pro-col{width:236px;flex-shrink:0;display:flex;flex-direction:column;gap:11px;overflow:hidden}
.dash-pro-center{flex:1;display:flex;gap:14px;min-width:0;overflow:hidden}

/* ── Easy mode layout ── */
.dash-easy-layout{display:flex;flex-direction:column;gap:16px;height:100%;min-height:0}

/* ── Dashboard note rich-text editor ── */
.dash-note-editor:empty:before{content:attr(data-placeholder);color:var(--mut);font-style:italic;pointer-events:none}
.dash-note-editor ul,.dash-note-editor ol{padding-left:1.4em;margin:4px 0}
.dash-note-editor li{margin:2px 0}
.dash-note-editor p{margin:0 0 4px}
.dash-note-editor strong{font-weight:700}
.dash-note-editor em{font-style:italic}
.dash-note-editor a{color:var(--accent);text-decoration:underline;cursor:pointer}

/* ── Panel row (task/routine item) ── */
.dash-panel-row{display:flex;align-items:center;gap:10px;padding:7px 4px;border-radius:8px;transition:background 0.15s;cursor:default}
.dash-panel-check{width:20px;height:20px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:all 0.18s;background:transparent;padding:0;-webkit-appearance:none;appearance:none}
.dash-panel-check:hover{border-color:var(--accent)}
.dash-panel-check.chk{background:var(--accent);border-color:var(--accent)}
.dash-panel-circle{width:22px;height:22px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:all 0.18s;background:transparent;padding:0;-webkit-appearance:none;appearance:none}
.dash-panel-circle:hover{border-color:var(--accent)}
.dash-panel-circle.chk{background:var(--accent);border-color:var(--accent)}
.dash-panel-text{font-size:13px;font-weight:500;color:var(--pri);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color 0.2s}
.dash-panel-text.done{color:var(--sec);text-decoration:line-through}

/* Light theme panel rows */
[data-theme="light"] .dash-panel-check{border-color:var(--mut)}
[data-theme="light"] .dash-panel-check:hover{border-color:var(--accent)}
[data-theme="light"] .dash-panel-check.chk{background:var(--accent);border-color:var(--accent)}
[data-theme="light"] .dash-panel-circle{border-color:var(--mut)}
[data-theme="light"] .dash-panel-circle:hover{border-color:var(--accent)}
[data-theme="light"] .dash-panel-circle.chk{background:var(--accent);border-color:var(--accent)}
[data-theme="light"] .dash-panel-row:hover{background:rgba(26,24,22,0.03)}

/* ── Responsive dashboard ── */
@media(max-width:1100px){
  .dash-pro-col{width:208px}
  .dash-pro-center{gap:12px}
}
@media(max-width:900px){
  .dash-pro-grid{flex-direction:column;overflow:visible}
  .dash-pro-col{width:100%;flex-direction:row;flex-wrap:wrap}
  .dash-pro-center{min-height:400px}
}
@media(max-width:640px){
  .dash-pro-layout{gap:12px}
  .dash-pro-grid{flex-direction:column;overflow:visible}
  .dash-pro-col{width:100%}
  .dash-easy-layout .dash-easy-cols{flex-direction:column}
}

/* ── Stub pages ── */
.stub-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:16px}
.stub-page h1{font-size:32px;font-weight:800;color:var(--pri);letter-spacing:-.04em}
.stub-page p{font-size:14px;color:var(--sec);font-style:italic}

/* ── Journal (Fase 2.4) ── */
.j-mobile{display:flex;flex-direction:column;gap:0;padding:0;margin:0 -28px;background:var(--bg);min-height:calc(100vh - 58px)}
.j-mobile-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;flex-shrink:0}
.j-pill{height:36px;width:36px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:var(--surface-b);border:1px solid var(--surface-b2);color:var(--sec);cursor:pointer;font-family:inherit;backdrop-filter:blur(12px)}
.j-tb-btn{width:32px;height:30px;border-radius:8px;border:1px solid var(--bdr);background:var(--surface-b);color:var(--sec);cursor:pointer;font-family:inherit;font-size:13px;display:flex;align-items:center;justify-content:center;padding:0}
.j-tb-btn:hover{background:var(--surface-b2);color:var(--pri)}

.j-desktop{margin:0 -28px;padding:0;flex:1;display:flex;flex-direction:column}
.j-desk-head{height:54px;flex-shrink:0;border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 24px;gap:12px;background:var(--topnav-bg)}
.j-desk-btn-icon{height:30px;width:30px;border-radius:7px;border:1px solid var(--bdr);background:var(--accent-d);color:#ff6b82;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px}
[data-theme="light"] .j-desk-btn-icon{color:#dc2626}
.j-desk-btn-save{height:30px;padding:0 16px;border-radius:8px;border:none;background:var(--accent);color:#000;cursor:pointer;font-family:inherit;font-size:12px;font-weight:700;transition:all .2s;min-width:110px}
[data-theme="light"] .j-desk-btn-save{color:#fff}
.j-desk-body{flex:1;display:flex;overflow:hidden;min-height:calc(100vh - 58px - 54px - 40px)}
.j-desk-sidebar{width:236px;flex-shrink:0;border-right:1px solid var(--bdr);display:flex;flex-direction:column;overflow:hidden;background:var(--card-solid-alt)}
.j-desk-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--bg)}
.j-desk-rightpanel{width:280px;flex-shrink:0;border-left:1px solid var(--bdr);display:flex;flex-direction:column;overflow-y:auto;background:var(--card-solid-alt)}
.j-desk-toolbar{height:46px;flex-shrink:0;border-top:1px solid var(--bdr);display:flex;align-items:center;padding:0 40px;gap:4px;background:var(--topnav-bg)}

@media(max-width:1100px){
  .j-desk-rightpanel{width:240px}
  .j-desk-sidebar{width:200px}
}

/* ── Loading ── */
.loading-spinner{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--sec);font-size:13px;gap:10px}

/* ── Responsive ── */
@media(max-width:1000px){.layout{gap:28px}}
@media(max-width:640px){
  .v2-main{padding:0 14px 60px}
  .el-nav-links{display:none}
  .el-nav-ctx{display:none}
  .el-nav-divider{display:none}
  .el-mode-pill{display:none}
  .el-topnav-in{padding:0 14px}
  .el-nav-right{margin-left:auto;gap:8px}
  .el-nav-right .el-wp-pill .el-wpb{padding:0 10px;font-size:11px;min-width:56px;gap:4px}
  .el-nav-right .el-wp-pill .el-wpb i{font-size:12px}
  .el-nav-right .el-wp-pill .el-wpb span{display:inline}
  .el-subnav{flex-wrap:wrap;gap:10px}
  .layout{display:block}
  .divider{display:none}
  .lc,.wqw{gap:16px}
  .wqw{margin-top:24px}
  .hero{padding:14px 13px}
  .hero .st h2{font-size:17px}
  .comp{flex-wrap:wrap}
  .ciw{flex-basis:100%;order:1}
  .ab{flex:1;order:2}
  .tr{padding:8px 4px;gap:8px}
  .ta{gap:2px}
  .task-star{opacity:.5}
  .tdl{opacity:.6}
  .flip-toggle{top:12px;right:12px}
  .pv-head{flex-direction:column;align-items:flex-start;gap:12px}
  .stats-row{gap:8px}
  .stat-card{min-width:120px;padding:10px 14px}
  .stat-num{font-size:18px}
  .wg{display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
  .wg::-webkit-scrollbar{display:none}
  .wg .wc2{min-width:165px;flex-shrink:0}
  .dash-grid{grid-template-columns:1fr}
  .dash-clock{font-size:36px}
}

/* ═══════════════════════════════════════════════════
   Mobile Dashboard — full-screen native layout
   ═══════════════════════════════════════════════════ */

/* CSS variable aliases for mobile design components */
:root,[data-theme="dark"]{
  --text-primary:var(--pri);
  --text-secondary:var(--sec);
  --text-muted:var(--mut);
  --border:var(--bdr);
  --accent-cyan:var(--accent-c);
  --accent-check:#00e676;
  --accent-glow:rgba(0,212,170,0.2);
  --anim-scale:1;
}
[data-theme="light"]{
  --text-primary:var(--pri);
  --text-secondary:var(--sec);
  --text-muted:var(--mut);
  --border:var(--bdr);
  --accent-cyan:var(--accent-c);
  --accent-check:var(--accent);
  --accent-glow:rgba(0,122,94,0.2);
}

/* Mobile dashboard wrapper — sits below the topnav (topnav z-index:700 is above) */
.mob-dash{position:fixed;top:calc(58px + env(safe-area-inset-top,0px));left:0;right:0;bottom:0;background:var(--bg);display:flex;flex-direction:column;z-index:600;overflow:hidden;overscroll-behavior:contain;max-width:100vw}

/* Body lock while mobile dashboard is mounted */
body.mob-dash-active{overflow:hidden;overscroll-behavior:none;height:100vh;height:100dvh}
body.mob-dash-active .v2-main{padding:0}

/* Mobile header */
.el-header{padding:20px 20px 10px;display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;overflow:hidden}
.el-title{font-size:28px;font-weight:800;color:var(--text-primary);letter-spacing:-0.5px;line-height:1.1}
.el-date{font-size:13px;color:var(--text-secondary);margin-top:3px;font-weight:500}

/* Mobile main */
.el-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.el-section{flex:1;display:flex;flex-direction:column;min-height:0}
.el-section-head{padding:10px 20px 2px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.el-section-label{font-size:14px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1.2px}
.el-section-count{font-size:12px;font-weight:600;color:var(--text-muted)}
.el-section-scroll{flex:1;overflow-y:auto;padding:4px 12px 8px;transition:opacity 0.2s,transform 0.2s}
.el-section-scroll.el-fading{opacity:0;transform:translateY(6px)}
.el-section-scroll::-webkit-scrollbar{width:3px}
.el-section-scroll::-webkit-scrollbar-track{background:transparent}
.el-section-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.el-empty{text-align:center;color:var(--text-muted);font-size:13px;padding:20px;font-weight:500}
.el-divider{height:1px;margin:2px 20px;background:linear-gradient(90deg,transparent,var(--accent) 30%,var(--accent-cyan) 70%,transparent);opacity:0.15;flex-shrink:0}

/* Mobile item rows */
.el-item{display:flex;align-items:center;gap:12px;padding:9px 8px;border-radius:12px;transition:background 0.2s,opacity calc(0.35s * var(--anim-scale,1));cursor:default;position:relative}
.el-item:active{background:rgba(255,255,255,0.03)}
.el-completed{opacity:0.4}

/* Checkbox */
.el-checkbox{width:28px;height:28px;background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.el-cb-box{fill:none;stroke:var(--text-muted);stroke-width:1.6;transition:stroke calc(0.2s * var(--anim-scale,1))}
.el-cb-fill{fill:var(--accent);stroke:none;transform:scale(0);transform-origin:center;transition:transform calc(0.3s * var(--anim-scale,1)) cubic-bezier(0.34,1.56,0.64,1)}
.el-cb-check{fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:22;stroke-dashoffset:22;transition:stroke-dashoffset calc(0.35s * var(--anim-scale,1)) calc(0.1s * var(--anim-scale,1)) cubic-bezier(0.65,0,0.35,1)}
.el-completing .el-cb-box,.el-completed .el-cb-box{stroke:var(--accent)}
.el-completing .el-cb-fill,.el-completed .el-cb-fill{transform:scale(1)}
.el-completing .el-cb-check,.el-completed .el-cb-check{stroke-dashoffset:0}

/* Circle (routines) */
.el-circle{width:28px;height:28px;background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.el-cr-ring{fill:none;stroke:var(--text-muted);stroke-width:1.6;transition:stroke calc(0.2s * var(--anim-scale,1))}
.el-cr-fill{fill:var(--accent);stroke:none;transform:scale(0);transform-origin:center;transition:transform calc(0.3s * var(--anim-scale,1)) cubic-bezier(0.34,1.56,0.64,1)}
.el-cr-check{fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:20;stroke-dashoffset:20;transition:stroke-dashoffset calc(0.35s * var(--anim-scale,1)) calc(0.1s * var(--anim-scale,1)) cubic-bezier(0.65,0,0.35,1)}
.el-completing .el-cr-ring,.el-completed .el-cr-ring{stroke:var(--accent)}
.el-completing .el-cr-fill,.el-completed .el-cr-fill{transform:scale(1)}
.el-completing .el-cr-check,.el-completed .el-cr-check{stroke-dashoffset:0}

/* Item text */
.el-item-text{font-size:15px;font-weight:500;color:var(--text-primary);position:relative;flex:1;min-width:0;transition:color calc(0.3s * var(--anim-scale,1));text-wrap:pretty}
.el-completing .el-item-text,.el-completed .el-item-text{color:var(--text-secondary)}
.el-item-text::after{content:'';position:absolute;left:0;top:50%;width:0;height:1.5px;background:var(--text-muted);transition:width calc(0.3s * var(--anim-scale,1)) calc(0.15s * var(--anim-scale,1)) ease}
.el-completing .el-item-text::after,.el-completed .el-item-text::after{width:100%}

.mob-mode-toggle{display:flex;align-items:center;gap:2px;padding:3px;border-radius:999px;background:var(--mode-pill-bg);border:1px solid var(--mode-pill-bdr);backdrop-filter:blur(10px)}
.mob-mode-toggle button{height:24px;padding:0 10px;border:none;border-radius:999px;background:transparent;color:var(--mode-btn-clr);font-family:var(--font);font-size:11px;font-weight:800;cursor:pointer;transition:background .15s,color .15s,transform .15s}
.mob-mode-toggle button.active{background:var(--mode-btn-active-bg);color:var(--mode-btn-active-clr)}
.mob-mode-toggle button:active{transform:scale(.96)}

/* Mobile bottom bar — locked at bottom */
.mob-bottom-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 40px max(20px, env(safe-area-inset-bottom));flex-shrink:0;border-top:1px solid var(--bdr);overflow:hidden}

/* Lock the middle layout — no horizontal scroll, only the section-scrolls move */
.mob-dash .el-main{overflow-x:hidden;max-width:100vw}
.mob-dash .el-section{overflow-x:hidden}
.mob-dash .el-section-scroll{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y}
.mob-icon-btn{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,0.12);background:rgba(255,255,255,0.04);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),background 0.2s}
.mob-icon-btn:active{transform:scale(0.88)}
[data-theme="light"] .mob-icon-btn{border-color:rgba(26,24,22,0.12);background:rgba(26,24,22,0.04)}

/* Mobile menu overlay — circular reveal from bottom-center, matches New_design */
.mob-menu-overlay{position:fixed;inset:0;z-index:700;display:flex;flex-direction:column;align-items:center;justify-content:center;clip-path:circle(0% at 50% 95%);transition:clip-path 0.55s cubic-bezier(0.25,1,0.5,1);overflow:hidden}
.mob-menu-overlay.mob-menu-open{clip-path:circle(150% at 50% 95%)}
.mob-menu-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 46%,#0c1a2e 0%,#060c18 45%,#030508 100%)}
.mob-menu-aurora{position:absolute;inset:-50%;background:conic-gradient(from 0deg at 50% 50%,transparent 0deg,rgba(0,212,170,0.045) 55deg,transparent 110deg,rgba(0,180,216,0.03) 175deg,transparent 230deg,rgba(0,212,170,0.05) 295deg,transparent 360deg);animation:menuAuroraRotate 18s linear infinite}
@keyframes menuAuroraRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.mob-menu-orb{position:absolute;border-radius:50%;filter:blur(50px);pointer-events:none;animation:menuOrbFloat var(--orb-dur,9s) ease-in-out infinite alternate}
@keyframes menuOrbFloat{from{transform:translate(0,0) scale(1)}to{transform:translate(var(--orb-tx,20px),var(--orb-ty,-20px)) scale(1.12)}}
.mob-menu-ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;animation:menuRingPulse var(--ring-dur,6s) ease-in-out infinite alternate}
@keyframes menuRingPulse{from{opacity:var(--ring-op-a,0.06);transform:translate(-50%,-50%) scale(1)}to{opacity:var(--ring-op-b,0.03);transform:translate(-50%,-50%) scale(1.04)}}
.mob-menu-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.035) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 75%)}
.mob-menu-vignette{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 40%,rgba(3,5,8,0.7) 100%)}

/* Menu grid (ring of tiles around center logo) */
.mob-menu-grid{position:relative;width:340px;height:340px;display:flex;align-items:center;justify-content:center;padding:0}
.mob-menu-tile{position:absolute;display:flex;flex-direction:column;align-items:center;gap:7px;padding:0;border-radius:0;background:transparent;border:none;cursor:pointer;color:var(--pri);font-family:var(--font);width:70px;height:70px;left:50%;top:50%;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),opacity 0.2s}
.mob-menu-tile-card{width:46px;height:46px;border-radius:14px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);display:flex;align-items:center;justify-content:center;transition:background 0.2s,border-color 0.2s;backdrop-filter:blur(8px)}
.mob-menu-tile:hover .mob-menu-tile-card{background:rgba(0,212,170,0.1);border-color:rgba(0,212,170,0.25)}
.mob-menu-tile:nth-child(2){--angle:0deg}
.mob-menu-tile:nth-child(3){--angle:40deg}
.mob-menu-tile:nth-child(4){--angle:80deg}
.mob-menu-tile:nth-child(5){--angle:120deg}
.mob-menu-tile:nth-child(6){--angle:160deg}
.mob-menu-tile:nth-child(7){--angle:200deg}
.mob-menu-tile:nth-child(8){--angle:240deg}
.mob-menu-tile:nth-child(9){--angle:280deg}
.mob-menu-tile:nth-child(10){--angle:320deg}
.mob-menu-tile{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-118px) rotate(calc(0deg - var(--angle,0deg)))!important}
.mob-menu-tile:hover{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-118px) rotate(calc(0deg - var(--angle,0deg))) scale(1.18)!important}
.mob-menu-tile:active{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-118px) rotate(calc(0deg - var(--angle,0deg))) scale(0.88)!important}
@media (max-width:380px){
  .mob-menu-grid{width:300px;height:300px}
  .mob-menu-tile{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-105px) rotate(calc(0deg - var(--angle,0deg)))!important}
  .mob-menu-tile:hover{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-105px) rotate(calc(0deg - var(--angle,0deg))) scale(1.18)!important}
  .mob-menu-tile:active{transform:translate(-50%,-50%) rotate(var(--angle,0deg)) translateY(-105px) rotate(calc(0deg - var(--angle,0deg))) scale(0.88)!important}
}

/* Add item sheet */
.mob-add-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid rgba(255,255,255,0.08);border-radius:20px 20px 0 0;padding:12px 20px max(20px, env(safe-area-inset-bottom));transform:translateY(120%);transition:transform 0.35s cubic-bezier(0.25,1,0.5,1);z-index:650}
.mob-add-sheet.mob-add-open{transform:translateY(0)}
.mob-add-handle{width:36px;height:4px;border-radius:4px;background:rgba(255,255,255,0.12);margin:0 auto 12px}
.mob-add-input{flex:1;padding:10px 14px;border-radius:12px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:var(--text-primary);font-family:var(--font);font-size:15px;outline:none;transition:border-color 0.2s}
.mob-add-input:focus{border-color:var(--accent)}
.mob-add-input::placeholder{color:rgba(255,255,255,0.25)}
.mob-add-submit{width:44px;height:44px;border-radius:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;flex-shrink:0}

/* Mobile logo spin */
@keyframes menuAuroraRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes logoSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ─── Priority chip on Tasks row + composer (.ct / .nct) ─── */
.ct,.nct{height:24px;padding:0 9px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--sec);border-radius:8px;cursor:pointer;font-family:var(--font);font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:5px;transition:all .15s;flex-shrink:0;white-space:nowrap;letter-spacing:.2px}
.ct:hover,.nct:hover{border-color:var(--accent-bd);color:var(--pri)}
.ct i,.nct i{font-size:12px}
.nct{height:32px;padding:0 12px}
[data-theme="light"] .ct,[data-theme="light"] .nct{background:rgba(26,24,22,0.04)}

/* Priority popover */
.prio-pop{position:absolute;background:var(--bg-card);border:1px solid var(--surface-b2);border-radius:var(--r);padding:5px;box-shadow:0 20px 50px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.3);z-index:200;min-width:170px;backdrop-filter:blur(20px);animation:mIn .12s ease-out}
.prio-pop-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 10px;border-radius:var(--rs);border:none;background:transparent;color:var(--pri);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:500;transition:background .12s}
.prio-pop-item:hover{background:rgba(255,255,255,0.06)}
.prio-pop-item.sel{background:var(--accent-d);color:var(--accent);font-weight:700}
.prio-pop-item i{font-size:14px;width:16px;text-align:center}
[data-theme="light"] .prio-pop-item:hover{background:rgba(26,24,22,0.06)}

/* ─── Simple-mode flat task list (.smr / .sms*) ─── */
.smr{display:flex;flex-direction:column;gap:0}
.sms{padding:14px 0;border-bottom:1px solid var(--surface-b)}
.sms:last-child{border-bottom:none}
.smsh{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:8px;padding:0 2px}
.smst{font-size:11px;font-weight:700;color:var(--sec);text-transform:uppercase;letter-spacing:1.2px;margin:0}
.smsc{font-size:11px;font-weight:600;color:var(--mut)}
.smsl{display:flex;flex-direction:column}
.smse{font-size:13px;color:var(--mut);font-style:italic;padding:8px 4px}
.smr .tr{display:flex;align-items:center;gap:10px;padding:9px 4px;border-radius:0;border-bottom:1px solid var(--surface-b);cursor:pointer}
.smr .tr:last-child{border-bottom:none}
.smr .tr .tt{font-size:14px;font-weight:500}
.smr .tr .ta{display:none!important}
.smr .tr .ck{cursor:pointer}

/* ─── Done view date groups (.dg) ─── */
.dg{margin-bottom:18px}
.dgh{display:flex;align-items:baseline;justify-content:space-between;padding:8px 0 6px;border-bottom:1px solid var(--surface-b);margin-bottom:6px}
.di{display:flex;align-items:center;gap:10px;padding:7px 4px;min-width:0}
.di:hover .diu{opacity:1}
.dica{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;flex-shrink:0;letter-spacing:.4px}
.dica i{font-size:11px}
.dca{margin-top:18px;padding-top:14px;border-top:1px solid var(--surface-b);display:flex;justify-content:center}
.dca button{padding:9px 18px;border-radius:10px;border:1px solid var(--surface-b);background:rgba(255,76,76,0.07);color:#ff4c4c;font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.dca button:hover{background:rgba(255,76,76,0.14);border-color:rgba(255,76,76,0.25)}

/* ─── Week view scroll buttons + extras (.wsb / .wex) ─── */
.wgw{position:relative}
.wsb{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;border:1px solid var(--surface-b);background:var(--bg-card);color:var(--sec);cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s;opacity:0;pointer-events:none}
.wsb.l{left:-12px}
.wsb.r{right:-12px}
.wsb:hover{color:var(--accent);border-color:var(--accent-bd)}
.wex{margin-top:24px;display:flex;flex-direction:column;gap:18px}
.wexs{display:flex;flex-direction:column;gap:8px}
.wexl{font-size:11px;font-weight:700;color:var(--sec);text-transform:uppercase;letter-spacing:1.2px;display:inline-flex;align-items:center;gap:6px;padding-bottom:6px;border-bottom:1px solid var(--surface-b);width:100%}
.wexl.isov{color:var(--red-ink,#ef4444)}
.wexl i{font-size:13px}
.wxg{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px}
.wxi{display:flex;align-items:flex-start;gap:8px;padding:8px 9px;border-radius:8px;background:rgba(255,255,255,0.03);border:1px solid var(--surface-b);transition:background .12s;min-width:0;cursor:grab}
.wxi:hover{background:rgba(255,255,255,0.06)}
.wxi.done{opacity:.4}
.wxic{width:16px;height:16px;border:1.5px solid var(--mut);border-radius:50%;cursor:pointer;flex-shrink:0;background:transparent;padding:0;margin-top:1px}
.wxic.chk{background:var(--accent);border-color:var(--accent)}
.wxib{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.wxit{font-size:12px;font-weight:500;color:var(--pri);word-break:break-word;line-height:1.4}
.wxim{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.wxid,.wxica{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;border:none;cursor:pointer;font-family:var(--font);letter-spacing:.2px}
.wxid{background:rgba(255,255,255,0.04);color:var(--sec)}
.wxid.isov{background:rgba(239,68,68,0.12);color:var(--red-ink,#ef4444)}
.wxid.isnd{background:rgba(255,255,255,0.04);color:var(--mut);font-style:italic}
.wxid i,.wxica i{font-size:11px}
[data-theme="light"] .wxi{background:rgba(26,24,22,0.03)}

/* ─── Deadline inline + expand (.dlr-*) ─── */
.dlr{cursor:pointer;transition:background .12s}
.dlr.expanded{background:rgba(255,255,255,0.03)}
.dlr-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 10px;min-width:0}
.dlr-title{flex:1;font-size:13px;color:var(--pri);min-width:0;line-height:1.4;word-break:break-word;font-weight:500;cursor:pointer}
.dlr-title-edit{flex:1;font-size:13px;color:var(--pri);background:rgba(255,255,255,0.05);border:1px solid var(--accent-bd);border-radius:6px;padding:4px 8px;font-family:var(--font);font-weight:500;outline:none}
.dlr-when{font-size:11px;font-weight:700;color:var(--sec);flex-shrink:0;padding:2px 8px;border-radius:999px;background:rgba(255,255,255,0.04)}
.dlr.overdue .dlr-when{background:rgba(239,68,68,0.12);color:var(--red-ink,#ef4444)}
.dlr.urgent .dlr-when{background:rgba(251,191,36,0.12);color:var(--amber-ink,#fbbf24)}
.dlr.soon .dlr-when{background:rgba(52,211,153,0.1);color:var(--today-green,#22c55e)}
.dlr-note{font-size:12px;color:var(--sec);font-style:italic;padding:0 10px 8px;line-height:1.5;cursor:pointer}
.dlr-note-edit{display:block;width:calc(100% - 20px);margin:0 10px 8px;font-size:12px;color:var(--pri);background:rgba(255,255,255,0.05);border:1px solid var(--accent-bd);border-radius:6px;padding:6px 8px;font-family:var(--font);outline:none;resize:none;min-height:36px}
.dlr-expand{padding:0 10px 10px;display:none}
.dlr.expanded .dlr-expand{display:block}
.dlr-actions{display:flex;gap:6px;justify-content:flex-end}
.dlr-action{padding:5px 10px;border-radius:6px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--sec);font-family:var(--font);font-size:11px;font-weight:600;cursor:pointer;transition:all .12s}
.dlr-action:hover{background:rgba(255,255,255,0.08);color:var(--pri)}
.dlr-action.danger{color:#ff4c4c;border-color:rgba(255,76,76,0.2);background:rgba(255,76,76,0.07)}
.dlr-action.danger:hover{background:rgba(255,76,76,0.14)}

/* ─── Wqs inline-add forms (Big Wins / Deadlines) ─── */
.wqs-inline{display:flex;gap:6px;align-items:center;padding:6px 2px;margin-bottom:4px}
.wqs-inline input{flex:1;height:30px;padding:0 10px;border:1px solid var(--accent-bd);background:rgba(255,255,255,0.05);color:var(--pri);font-family:var(--font);font-size:13px;border-radius:7px;outline:none;min-width:0}
.wqs-inline input:focus{border-color:var(--accent)}
.wqs-inline-cancel{width:24px;height:24px;border:none;background:transparent;color:var(--mut);cursor:pointer;font-size:16px;line-height:1;border-radius:5px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.wqs-inline-cancel:hover{color:var(--pri);background:rgba(255,255,255,0.06)}
.wqs-inline-date{display:inline-flex;align-items:center;gap:4px;height:30px;padding:0 9px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--sec);font-family:var(--font);font-size:11px;font-weight:600;border-radius:7px;cursor:pointer;flex-shrink:0;white-space:nowrap}
.wqs-inline-date.has{color:var(--accent);border-color:var(--accent-bd)}
.wqs-inline-date i{font-size:12px}

/* ─── Flip-card (Today ↔ Tomorrow) ─── */
.flip-container{perspective:1800px;position:relative;min-height:200px}
.flip-face{position:relative;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.flip-back{position:absolute;inset:0;transform:rotateY(180deg)}

/* ─── Tasks page mobile layout (≤700px) ─── */
@media(max-width:700px){
  .v2-page .el-subnav{flex-wrap:wrap;gap:8px;padding:8px 0}
  .v2-page .el-subnav-tabs{flex:1;width:100%;justify-content:space-between}
  .v2-page .el-subnav-tabs .el-stab{flex:1;justify-content:center;padding:0 6px;font-size:11px}
  .v2-page .el-subnav-date{font-size:11px}
  .v2-page .layout{display:block;gap:18px}
  .v2-page .divider{display:none}
  .v2-page .wqw{display:none}
  .v2-page .strategic-divider{display:none}
  .v2-page .wqx{display:flex;flex-direction:column;gap:16px;margin-bottom:14px}
  .v2-page .hero{padding:14px 14px}
  .v2-page .cs{margin-bottom:0}
  .v2-page .comp{flex-direction:column;align-items:stretch;gap:8px}
  .v2-page .comp .ab{align-self:flex-end;height:38px;padding:0 14px}
  .v2-page .ciw{flex-wrap:wrap;height:auto;min-height:44px;padding:8px 12px}
  .v2-page .ciw input{flex:1 1 100%;min-width:120px}
  .v2-page .tr{padding:10px 6px;flex-wrap:wrap;gap:8px}
  .v2-page .tr .tt{font-size:13px}
  .v2-page .ta{margin-left:auto;display:flex;gap:2px}
  .v2-page .ta .task-star,.v2-page .ta .ct{opacity:.7}
  .v2-page .tdl{opacity:.7}
  .v2-page .wg{grid-template-columns:repeat(7,minmax(200px,1fr));overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
  .v2-page .wc2{scroll-snap-align:start}
  .v2-page .wxg{grid-template-columns:1fr}
}

/* ─── Projects mobile (≤700px already collapses grid to 1col; tighten cards) ─── */
@media(max-width:700px){
  .pv-grid{gap:12px}
  .pc{padding:16px 16px 38px}
  .pc-ring{top:12px;right:14px;width:38px;height:38px}
  .pc-ring svg{width:38px;height:38px}
  .pc-fav{top:12px;left:14px}
  .pc-title{font-size:15px}
  .pc-sub{font-size:11px}
  .pc-task-text{font-size:13px}
  .pc-add-text{font-size:12px}
  .pc.new-card{min-height:120px;padding:32px 16px}
  .stats-row{gap:8px}
  .stat-card{padding:10px 12px;flex:1 1 30%;min-width:90px;gap:8px}
  .stat-card .stat-icon{width:28px;height:28px}
  .stat-num{font-size:18px}
  .stat-lbl{font-size:10px}
  .pv-head{flex-direction:column;align-items:flex-start;gap:10px}
  .pv-filters{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .pv-filters .pf{flex-shrink:0}
}

/* ─── ItemSettings modal (TaskSettings / RoutineSettings) ─── */
.is-wrap{position:fixed;inset:0;z-index:1000;background:rgba(3,5,8,0.6);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;animation:isWrapIn .18s ease-out}
.is-wrap.is-mobile{align-items:flex-end;padding:0}
@keyframes isWrapIn{from{opacity:0}to{opacity:1}}
.is-card{background:var(--bg-card);border:1px solid var(--surface-b);border-radius:20px;width:100%;max-width:440px;max-height:calc(100vh - 40px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.6),0 4px 12px rgba(0,0,0,.3);animation:isCardIn .22s cubic-bezier(0.25,1,0.5,1)}
@keyframes isCardIn{from{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}
.is-card-mob{border-radius:20px 20px 0 0;max-width:100%;max-height:90vh;animation:isCardMobIn .3s cubic-bezier(0.25,1,0.5,1)}
@keyframes isCardMobIn{from{transform:translateY(100%)}to{transform:translateY(0)}}
.is-handle{width:36px;height:4px;border-radius:4px;background:rgba(255,255,255,0.14);margin:10px auto 4px;flex-shrink:0}
.is-head{padding:14px 18px 12px;border-bottom:1px solid var(--surface-b);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.is-title{font-size:15px;font-weight:700;color:var(--pri);letter-spacing:-.1px}
.is-close{width:30px;height:30px;border-radius:8px;border:none;background:rgba(255,255,255,0.05);color:var(--sec);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}
.is-close:hover{background:rgba(255,255,255,0.1);color:var(--pri)}
.is-body{padding:16px 18px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;flex:1}
.is-field{display:flex;flex-direction:column;gap:6px}
.is-label{font-size:11px;font-weight:700;color:var(--sec);text-transform:uppercase;letter-spacing:1.1px;margin-bottom:2px}
.is-input{width:100%;height:40px;padding:0 12px;border:1px solid var(--surface-b);background:rgba(255,255,255,0.04);color:var(--pri);border-radius:10px;font-family:var(--font);font-size:14px;outline:none;transition:border-color .15s}
.is-input:focus{border-color:var(--accent-bd)}
.is-input[type="date"]{padding:0 12px}
[data-theme="light"] .is-input{background:rgba(26,24,22,0.04)}
.is-prio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.is-prio-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1.5px solid var(--surface-b);background:rgba(255,255,255,0.03);color:var(--pri);border-radius:10px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;transition:all .15s}
.is-prio-btn:hover{border-color:var(--accent-bd)}
.is-prio-btn i{font-size:15px;flex-shrink:0}
.is-cat-row{display:flex;gap:6px}
.is-cat-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 10px;border:1.5px solid var(--surface-b);background:rgba(255,255,255,0.03);color:var(--sec);border-radius:10px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600;transition:all .15s}
.is-cat-btn.active{border-color:var(--accent-bd);background:var(--accent-d);color:var(--accent)}
.is-cat-btn i{font-size:14px}
.is-day-row{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.is-day-btn{height:38px;border:1.5px solid var(--surface-b);background:rgba(255,255,255,0.03);color:var(--sec);border-radius:8px;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:700;transition:all .15s}
.is-day-btn.active{border-color:var(--accent-bd);background:var(--accent-d);color:var(--accent)}
.is-day-btn:hover{border-color:var(--accent-bd)}
.is-toggle-row{flex-direction:row;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--surface-b);border-radius:10px;background:rgba(255,255,255,0.02);cursor:pointer;user-select:none}
.is-toggle-row:hover{background:rgba(255,255,255,0.04)}
.is-toggle{width:36px;height:20px;border-radius:10px;background:var(--mut);position:relative;flex-shrink:0;transition:background .2s}
.is-toggle::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s cubic-bezier(0.25,1,0.5,1)}
.is-toggle.on{background:var(--accent)}
.is-toggle.on::after{transform:translateX(16px)}
.is-actions{display:flex;align-items:center;gap:8px;margin-top:6px;padding-top:14px;border-top:1px solid var(--surface-b)}
.is-btn-del,.is-btn-cancel,.is-btn-save{height:38px;padding:0 14px;border-radius:10px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.is-btn-del{border:1px solid rgba(255,76,76,0.22);background:rgba(255,76,76,0.08);color:#ff4c4c}
.is-btn-del:hover{background:rgba(255,76,76,0.16);border-color:rgba(255,76,76,0.4)}
.is-btn-cancel{border:1px solid var(--surface-b);background:transparent;color:var(--sec)}
.is-btn-cancel:hover{background:rgba(255,255,255,0.04);color:var(--pri)}
.is-btn-save{border:none;background:var(--accent);color:#000}
.is-btn-save:hover{filter:brightness(1.05)}
[data-theme="light"] .is-btn-save{color:#fff}

/* Drag-to-today visual feedback */
.hero.card-drag-over{border-color:var(--accent);background:rgba(0,212,170,0.05)}
