
:root{
  --bg:linear-gradient(135deg,#fef3ee 0%,#fffbf2 50%,#fdf0fb 100%);
  --glass:rgba(255,255,255,0.75);--gb:rgba(255,255,255,0.88);
  --border:rgba(255,255,255,0.4);
  --shadow:0 10px 30px rgba(0,0,0,0.08),0 2px 6px rgba(0,0,0,0.04);
  --shadow-lg:0 20px 50px rgba(0,0,0,0.12),0 4px 12px rgba(0,0,0,0.06);
  --inset:inset 0 1px 0 rgba(255,255,255,0.6);
  --text:#2c1810;--muted:#8c7b6e;--subtle:#b8a99a;--accent:#c26b4f;
  --r:16px;--rs:12px;--rxs:8px;
  --home-bg:rgba(219,234,254,0.32);--home-t:#1e3a8a;--home-d:#3b82f6;--home-b:rgba(255,255,255,0.5);
  --mw-bg:rgba(254,249,140,0.35);--mw-t:#4a5c00;--mw-d:#a3c41a;--mw-b:rgba(255,255,255,0.5);
  --work-bg:rgba(253,222,242,0.32);--work-t:#831843;--work-d:#db2777;--work-b:rgba(255,255,255,0.5);
  --soc-bg:rgba(242,232,255,0.32);--soc-t:#4c1d95;--soc-d:#9333ea;--soc-b:rgba(255,255,255,0.5);
  --lt-bg:rgba(255,249,219,0.32);--lt-t:#78350f;--lt-d:#d97706;--lt-b:rgba(255,255,255,0.5);
  --rec-bg:rgba(220,252,231,0.32);--rec-t:#064e3b;--rec-d:#059669;--rec-b:rgba(255,255,255,0.5);
  --buy-bg:rgba(255,235,200,0.32);--buy-t:#7c2d12;--buy-d:#ea580c;--buy-b:rgba(255,255,255,0.5);
  --ov-bg:rgba(255,220,214,0.38);--ov-t:#9f3826;--ov-d:#e05c3a;--ov-b:rgba(255,255,255,0.5);
  --tv-bg:rgba(219,234,254,0.32);--tv-t:#1e3a8a;--tv-d:#3b82f6;--tv-b:rgba(255,255,255,0.5);
  --bd-bg:rgba(255,235,200,0.32);--bd-t:#7c2d12;--bd-d:#ea580c;--bd-b:rgba(255,255,255,0.5);
  --imp-bg:rgba(255,249,219,0.38);--imp-t:#78350f;--imp-d:#d97706;--imp-b:rgba(255,255,255,0.5);
  --sidebar-bg:rgba(255,255,255,0.75);
}
/* ── Dark mode ── */
body.dark{
  --bg:linear-gradient(135deg,#1a100a 0%,#1c1208 50%,#1a0e12 100%);
  --glass:rgba(255,240,230,0.06);--gb:rgba(255,240,230,0.12);
  --border:rgba(255,220,200,0.12);
  --shadow:0 10px 30px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.25);
  --shadow-lg:0 20px 50px rgba(0,0,0,.55),0 4px 12px rgba(0,0,0,.35);
  --text:#f0e8e0;--muted:#7a6a60;--subtle:#504035;--accent:#e08b6e;
  --home-bg:rgba(59,130,246,.15);--home-t:#93c5fd;--home-b:rgba(59,130,246,.2);
  --mw-bg:rgba(163,196,26,.12);--mw-t:#bef264;--mw-b:rgba(163,196,26,.2);
  --work-bg:rgba(236,72,153,.12);--work-t:#f9a8d4;--work-b:rgba(236,72,153,.2);
  --soc-bg:rgba(147,51,234,.15);--soc-t:#d8b4fe;--soc-b:rgba(147,51,234,.2);
  --lt-bg:rgba(148,163,184,.10);--lt-t:#94a3b8;--lt-b:rgba(148,163,184,.2);
  --rec-bg:rgba(16,185,129,.12);--rec-t:#6ee7b7;--rec-b:rgba(16,185,129,.2);
  --buy-bg:rgba(234,179,8,.12);--buy-t:#fde68a;--buy-b:rgba(234,179,8,.2);
  --ov-bg:rgba(239,68,68,.12);--ov-t:#fca5a5;--ov-b:rgba(239,68,68,.25);
  --tv-bg:rgba(20,184,166,.12);--tv-t:#5eead4;--tv-b:rgba(20,184,166,.2);
  --bd-bg:rgba(249,115,22,.12);--bd-t:#fdba74;--bd-b:rgba(249,115,22,.2);
  --imp-bg:rgba(234,179,8,.12);--imp-t:#fde68a;--imp-b:rgba(234,179,8,.3);
  --sidebar-bg:rgba(0,0,0,0.25);
}
body.dark{background:#1a100a;background-attachment:fixed;}
body.dark .sidebar{background:var(--sidebar-bg);}
body.dark .nav-item:hover{background:rgba(255,255,255,.07);}
body.dark .nav-item.active{background:rgba(194,107,79,.18);}
body.dark .card{background:rgba(40,22,14,.55);}
body.dark .modal{background:rgba(28,16,10,.97);}
body.dark .ti:hover{background:rgba(255,255,255,.09)!important;box-shadow:0 2px 10px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.12);}
body.dark .ti.sel-row{background:var(--sel-bg-dark)!important;}
body.dark input,body.dark select,body.dark textarea{background:rgba(255,255,255,.06);color:var(--text);border-color:rgba(255,255,255,.12);}
body.dark .ainput,body.dark .asel{background:rgba(255,255,255,.06);color:var(--text);}
body.dark .kol{background:rgba(255,255,255,.03);}
body.dark .kol-item{background:rgba(255,255,255,.04);}
body.dark .kol-item:hover{background:rgba(255,255,255,.08);}
body.dark #ctxMenu,body.dark #pupCtxMenu,body.dark #bdayCtxMenu,body.dark #wrRuleCtxMenu,body.dark #wrScopePicker,body.dark #wrSkippedPicker{background:rgba(20,18,35,.98);}
body.dark .ctx-item:hover{background:rgba(255,255,255,.08);}
body.dark .wkc-chip{filter:brightness(.85);}
body.dark .chk{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);}
body.dark .ch-prog-bar{background:rgba(255,255,255,.08);}

/* Dark toggle button */
.dark-toggle{display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-size:13px;background:rgba(255,255,255,.65);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);border-radius:20px;padding:4px 10px;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px rgba(0,0,0,.06);color:var(--muted);line-height:1;}
.dark-toggle:hover{background:rgba(255,255,255,.85);box-shadow:0 3px 12px rgba(0,0,0,.1);}
body.dark .dark-toggle{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:var(--text);}
body.dark .dark-toggle:hover{background:rgba(255,255,255,.14);}
/* Settings button + popup */
.settings-btn{display:flex;align-items:center;justify-content:center;min-width:0;font-family:'DM Sans',sans-serif;font-size:12px;background:rgba(255,255,255,.65);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);border-radius:20px;padding:4px 8px;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px rgba(0,0,0,.06);color:var(--muted);line-height:1;}
.settings-btn:hover{background:rgba(255,255,255,.85);box-shadow:0 3px 12px rgba(0,0,0,.1);}
body.dark .settings-btn{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:var(--text);}
body.dark .settings-btn:hover{background:rgba(255,255,255,.14);}
.settings-popup{display:none;position:fixed;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.8);border-radius:14px;padding:10px;box-shadow:0 8px 32px rgba(0,0,0,.12);min-width:160px;z-index:9999;flex-direction:column;gap:6px;}
.settings-popup.open{display:flex;}
body.dark .settings-popup{background:rgba(28,26,48,.95);border-color:rgba(255,255,255,.1);}
.settings-popup-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:11px;color:var(--muted);transition:background .12s;white-space:nowrap;}
.settings-popup-item:hover{background:rgba(0,0,0,.06);}
body.dark .settings-popup-item:hover{background:rgba(255,255,255,.08);}
body.dark .settings-popup-item{color:var(--text);}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;user-select:none;-webkit-user-select:none;}
body{font-family:'DM Sans',sans-serif;background:#fef6f0;background-attachment:fixed;color:var(--text);font-size:13px;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}
.bg-canvas{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;animation:drift 18s ease-in-out infinite alternate}
.orb1{width:560px;height:560px;background:radial-gradient(circle,#fcd5ce,#f9b8ae);top:-120px;left:-80px;animation-duration:20s}
.orb2{width:520px;height:520px;background:radial-gradient(circle,#fed7aa,#fbbf7a);top:10%;right:-80px;animation-duration:25s;animation-delay:-8s}
.orb3{width:500px;height:500px;background:radial-gradient(circle,#fbcfe8,#f9a8d4);bottom:-80px;left:20%;animation-duration:22s;animation-delay:-4s}
.orb4{width:380px;height:380px;background:radial-gradient(circle,#fef3c7,#fde68a);top:35%;left:38%;animation-duration:28s;animation-delay:-12s}
.orb5{width:420px;height:420px;background:radial-gradient(circle,#e9d5ff,#d8b4fe);bottom:5%;right:5%;animation-duration:24s;animation-delay:-6s}
@keyframes drift{0%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.04)}66%{transform:translate(-20px,30px) scale(.97)}100%{transform:translate(15px,10px) scale(1.02)}}
.shell{display:flex;height:100vh;overflow:hidden;position:relative;z-index:1}

/* Sidebar */
.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;width:186px;background:rgba(255,255,255,0.75);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-right:1px solid rgba(255,255,255,0.4);display:flex;flex-direction:column;padding:11px 8px 11px;box-shadow:0 10px 30px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,0.6);transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .22s}
.sidebar.closed{transform:translateX(-190px);opacity:0;pointer-events:none}
.sb-top{display:flex;align-items:flex-start;justify-content:space-between;padding:0 4px 10px;border-bottom:1px solid var(--border);margin-bottom:4px}
.brand{font-size:13px;font-weight:700;letter-spacing:-.3px;line-height:1.3}
.brand-date{font-family:'DM Sans',sans-serif;font-size:9px;color:var(--muted);margin-top:2px}
.sb-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:14px;padding:2px 3px;border-radius:5px;transition:all .15s;line-height:1}
.sb-close:hover{background:rgba(0,0,0,.06);color:var(--text)}
.nav-item{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:var(--rs);cursor:pointer;font-size:12px;font-weight:500;color:var(--muted);transition:all .15s;border:none;background:none;width:100%;font-family:inherit;margin-bottom:1px;text-decoration:none}
.nav-item:hover{background:rgba(255,237,213,.55);color:var(--text)}
.nav-item.active{background:rgba(255,255,255,0.88);color:var(--accent);font-weight:700;box-shadow:0 10px 30px rgba(0,0,0,0.08),inset 0 1px 0 rgba(255,255,255,0.6)}
.ndot{width:6px;height:6px;border-radius:50%;flex-shrink:0}

/* Open btn */
.menu-open{position:fixed;left:8px;top:8px;z-index:200;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border:1px solid var(--gb);box-shadow:var(--shadow);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:12px;transition:all .15s}
.menu-open:hover{background:#fff;box-shadow:var(--shadow-lg)}
.menu-open.visible{display:flex}


.sync-bar{position:relative;padding:0 !important;width:20px;height:20px;}
.settings-btn[data-tip]:hover::after,.sync-bar[data-tip]:hover::after{content:attr(data-tip);position:absolute;top:calc(100% + 6px);right:0;white-space:nowrap;background:rgba(30,30,40,.88);color:#fff;font-size:10px;font-family:'DM Sans',sans-serif;padding:3px 8px;border-radius:6px;pointer-events:none;z-index:9999;}
.sdot{width:5px;height:5px;border-radius:50%;background:#22c55e;flex-shrink:0}
.sdot.loading{background:#f59e0b;animation:bl 1s infinite}.sdot.err{background:#ef4444}
@keyframes bl{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes confetti-fall{0%{transform:translate(0,0) rotate(0deg) scale(1);opacity:1}60%{opacity:1}100%{transform:translate(var(--cx),var(--cy)) rotate(var(--cr)) scale(.5);opacity:0}}
@keyframes donut-wiggle{0%,100%{transform:rotate(-10deg) translateY(0)}25%{transform:rotate(10deg) translateY(-3px)}50%{transform:rotate(-8deg) translateY(0)}75%{transform:rotate(8deg) translateY(-2px)}}
@keyframes d-arm-l{0%,100%{transform:rotate(-20deg)}50%{transform:rotate(28deg)}}
@keyframes d-arm-r{0%,100%{transform:rotate(-32deg)}50%{transform:rotate(16deg)}}
@keyframes d-leg-l{0%,100%{transform:rotate(24deg)}50%{transform:rotate(-18deg)}}
@keyframes d-leg-r{0%,100%{transform:rotate(-24deg)}50%{transform:rotate(18deg)}}
.confetti-particle{position:fixed;pointer-events:none;z-index:9999;animation:confetti-fall var(--cd) cubic-bezier(.2,.8,.4,1) var(--delay) both;user-select:none}
.donut-dancing{animation:donut-wiggle .7s ease-in-out 4 forwards;transform-origin:28px 28px;overflow:visible}
.d-arm-l{animation:d-arm-l .7s ease-in-out 4 forwards}
.d-arm-r{animation:d-arm-r .7s ease-in-out 4 forwards}
.d-leg-l{animation:d-leg-l .7s ease-in-out 4 forwards}
.d-leg-r{animation:d-leg-r .7s ease-in-out 4 forwards}

/* Main */
.main{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 0 36px 0;margin-left:186px;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}
#page-overview{padding:clamp(12px,3vw,56px);padding-top:60px}
#page-pups{padding:0 clamp(12px,3vw,56px);width:100%;box-sizing:border-box}
.ov-topbar{position:fixed;top:14px;left:0;right:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;z-index:89;pointer-events:none;transition:left .25s cubic-bezier(.4,0,.2,1)}
.ov-topbar-left{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding-right:10px;pointer-events:none}
.ov-topbar-right{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding-left:10px;pointer-events:none}
.ov-topbar-label{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.02em}
.ov-topbar-date{font-size:13px;font-weight:700;color:var(--text)}
.ov-topbar-dot{width:2.5px;height:2.5px;border-radius:50%;background:var(--text);opacity:0.25;flex-shrink:0}
.ov-topbar-time{display:inline-flex;align-items:center;justify-content:center;padding:3px 11px;border-radius:20px;font-size:12px;font-weight:600;background:rgba(120,110,180,.03);border:1px solid rgba(120,110,180,.06);color:var(--muted)}
.overview-cols{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(0,2.6fr);gap:14px;margin:0 auto 36px;max-width:1600px;width:100%;height:min(740px,calc(100vh - 84px))}
@media(max-width:1280px){.row1-right-top{grid-template-columns:1fr 1fr;height:auto}}
@media(max-width:900px){.main{margin-left:0;padding:12px 0 24px 0}#page-overview{padding:0 12px}.overview-cols{grid-template-columns:1fr;height:auto}}
.main.full{margin-left:0}
.page{display:none}.page.active{display:block}#page-birthdays.active{display:flex!important;flex-direction:column;height:100vh;width:100%;box-sizing:border-box}

/* Undo toast */
.back-btn{display:none}
#backToOv{display:none;position:fixed;top:52px;right:20px;z-index:90;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--muted);background:none;border:none;cursor:pointer;padding:0;opacity:.7;transition:opacity .15s;font-family:'DM Sans',sans-serif}
#backToOv:hover{opacity:1}
/* Pup Page */
.pup-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}
.pup-stat{display:flex;align-items:baseline;gap:4px}.pup-stat-num{font-size:16px;font-weight:700;color:var(--text)}.pup-stat-lbl{font-size:10px;color:var(--muted);font-weight:500}
.pup-skill-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:1px solid rgba(210,205,228,.12);flex-wrap:wrap}.pup-skill-row:last-child{border-bottom:none}
.pup-skill-emphasis{background:rgba(255,255,255,.5);border-radius:6px;padding:7px 8px!important;border:1px solid rgba(210,205,228,.2)!important;margin-bottom:4px}
.pup-focus-row{background:rgba(255,255,255,.75);border-radius:6px;padding:5px 8px!important;border:1px solid rgba(210,205,228,.2)!important;margin-bottom:3px}
.pup-done-row{padding:3px 0!important;border-bottom:1px solid rgba(210,205,228,.08)!important}
.pup-skill-name{font-size:11px;font-weight:600;color:var(--text);flex:1;min-width:0}
.pup-skill-meta{display:flex;gap:4px;flex-shrink:0}
.pup-next-step{font-size:9px;color:var(--muted);width:100%;padding-left:2px;margin-top:1px;font-style:italic}
.pup-pill{font-size:8px;font-weight:700;padding:1px 5px;border-radius:4px;background:rgba(210,205,228,.25);color:var(--text);border:1px solid rgba(210,205,228,.3)}
.pup-pill-sr{background:rgba(163,196,26,.15);color:#5a7a00;border-color:rgba(163,196,26,.3)}
.pup-pill-dim{opacity:.55}
.pup-check{font-size:9px;color:#a3c41a;font-weight:800;flex-shrink:0}
.pup-col{display:flex;flex-direction:column;min-height:0}
.pup-skill-row{cursor:default}
.pup-skill-emphasis,.pup-focus-row,.pup-done-row{cursor:pointer;user-select:none;-webkit-user-select:none}
.pup-tbl{width:100%;border-collapse:collapse;font-size:11px;table-layout:auto}
.pup-tbl th{font-size:10px;font-weight:600;color:var(--muted);padding:5px 6px;border-bottom:1.5px solid rgba(210,205,228,.25);text-align:left;white-space:nowrap;position:sticky;top:0;background:rgba(255,248,244,0.97);z-index:2}
body.dark .pup-tbl th{background:rgba(40,22,14,.97)}
.pup-tbl td{padding:3px 5px;border-bottom:1px solid rgba(210,205,228,.1);vertical-align:middle;text-align:left}
.pup-tbl th:first-child,.pup-tbl td:first-child{padding-left:14px!important}
.pup-tbl th:nth-child(2),.pup-tbl td:nth-child(2){padding-left:10px!important}
.pup-tbl tr:hover td{background:rgba(255,255,255,.4)}
.pup-tbl tr.pup-sel td{background:var(--sel-bg,rgba(130,115,100,.1))!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.pup-tbl .pup-dots{opacity:0;padding:0 4px;cursor:pointer;font-size:13px;color:var(--muted);background:none;border:none;line-height:1}
.pup-tbl tr:hover .pup-dots,.pup-tbl tr.pup-sel .pup-dots{opacity:1}
.pup-tbl .pup-del{opacity:0;padding:0 3px;cursor:pointer;font-size:13px;color:var(--muted);background:none;border:none;line-height:1}
.pup-tbl tr:hover .pup-del,.pup-tbl tr.pup-sel .pup-del{opacity:1}
.pup-tbl .pup-del:hover{color:#ef4444}
.pup-tbl input,.pup-tbl select{font-size:11px;font-family:inherit;border:none;background:transparent;color:var(--text);width:100%;outline:none;cursor:pointer;padding:2px 3px;border-radius:3px;transition:background .12s}
.pup-tbl input:focus,.pup-tbl select:focus{background:rgba(255,255,255,.85);cursor:text}
.pup-tbl select{cursor:pointer;-webkit-appearance:auto}
#pupFilterPop{background:rgba(255,248,244,0.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,0.7);border-radius:10px;padding:10px;box-shadow:0 6px 28px rgba(0,0,0,.13),inset 0 1.5px 0 rgba(255,255,255,1);opacity:0;transform:translateY(-6px) scale(.97);transition:opacity .15s ease,transform .15s ease;pointer-events:none}
#pupFilterPop.pfopen{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
body.dark #pupFilterPop{background:rgba(40,22,14,.97);border-color:rgba(255,220,200,.15);box-shadow:0 6px 28px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.06)}
.pf-cb-row{display:flex;align-items:center;padding:4px 6px;border-radius:6px;cursor:pointer;font-size:12px;color:var(--text);user-select:none}
.pf-cb-row:hover{background:rgba(255,255,255,.4)}
.undo-toast{position:fixed;bottom:16px;left:50%;transform:translateX(-50%) translateY(60px);background:rgba(37,32,64,.92);color:#fff;font-size:11px;font-weight:600;padding:7px 14px;border-radius:20px;box-shadow:var(--shadow-lg);transition:transform .22s ease,opacity .22s ease;opacity:0;z-index:900;display:flex;align-items:center;gap:8px;white-space:nowrap}
.undo-toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.undo-btn{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:6px;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;cursor:pointer;transition:background .12s}
.undo-btn:hover{background:rgba(255,255,255,.35)}
.pup-dog-toggle{display:inline-flex;border-radius:20px;border:1px solid var(--border);overflow:hidden;background:rgba(255,255,255,.4)}
.pup-dog-btn{padding:4px 12px;font-size:12px;font-weight:600;font-family:inherit;border:none;background:transparent;cursor:pointer;color:var(--muted);transition:all .15s;line-height:1.4}
.pup-dog-btn.active{background:#2c1810;color:#fff}
body.dark .pup-dog-toggle{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12)}
body.dark .pup-dog-btn.active{background:rgba(194,107,79,.5);color:#fff}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--rs);border:none;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-dark{background:#2c1810;color:#fff;box-shadow:0 4px 12px rgba(44,24,16,.25)}
.btn-dark:hover{background:#3d2418;transform:translateY(-1px)}
.btn-ghost{background:rgba(255,252,248,.7);color:var(--muted);border:1px solid rgba(255,220,200,.45);box-shadow:inset 0 1px 0 rgba(255,255,255,0.6)}
.btn-ghost:hover{background:rgba(255,252,248,.95);color:var(--text)}
.btn-xs{padding:2px 6px;font-size:10px}
.btn-plus{width:18px;height:18px;padding:0;justify-content:center;font-size:12px;border-radius:50%;background:rgba(255,255,255,.6);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .15s;flex-shrink:0;display:inline-flex;align-items:center;line-height:1}
.btn-plus:hover{background:#fff;color:var(--accent);border-color:var(--accent)}

/* Cards */
.card{background:rgba(255,255,255,0.62);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,0.55);border-radius:var(--r);box-shadow:0 10px 30px rgba(0,0,0,0.08),inset 0 1.5px 0 rgba(255,255,255,1),inset 1px 0 0 rgba(255,255,255,0.6),inset -1px 0 0 rgba(255,255,255,0.6);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s;position:relative}
.card-hero{background:rgba(255,255,255,0.88)!important;border-color:rgba(255,255,255,0.6)!important;box-shadow:0 10px 30px rgba(0,0,0,0.1),inset 0 1px 0 rgba(255,255,255,0.8)!important}
.ch{padding:4px 13px;display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(210,205,228,.22);flex-shrink:0;min-height:31px;box-sizing:border-box}
.ch-prog{display:flex;align-items:center;gap:6px;padding:0 10px;border-bottom:1px solid rgba(210,205,228,.22);flex-shrink:0;min-height:31px;box-sizing:border-box}
.ch-prog .ct{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);white-space:nowrap}
.ch-prog-bar{flex:1;height:7px;background:rgba(180,160,220,.18);border-radius:99px;overflow:hidden;box-shadow:inset 0 1px 3px rgba(0,0,0,.06);min-width:30px}
.ch-prog-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#4a8f08 0%,#78bc1a 60%,#95d433 100%);transition:width .6s cubic-bezier(.4,0,.2,1)}
.ch-prog-stat{display:flex;align-items:center;gap:3px;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:600;color:var(--muted);white-space:nowrap}
.ch-prog-stat .pct{color:#5a8f00;font-weight:700;font-size:10px}
.ct{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);flex:1}
.cbadge{font-family:'DM Sans',sans-serif;font-size:9px;background:rgba(255,255,255,.65);border:1px solid var(--border);padding:0px 5px;border-radius:8px;color:var(--muted)}
.prog{padding:7px 13px 6px;flex-shrink:0}
.prog-lbl{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.prog-lbl-left{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.prog-lbl-right{font-size:10px;font-weight:600;color:var(--muted);font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:3px}
.prog-track{height:8px;background:rgba(180,160,220,.18);border-radius:99px;overflow:hidden;box-shadow:inset 0 1px 3px rgba(0,0,0,.06)}
.prog-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#4a8f08 0%,#78bc1a 60%,#95d433 100%);transition:width .6s cubic-bezier(.4,0,.2,1)}


.ql-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr);gap:6px;padding:8px}
.ql-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:7px 4px;border-radius:10px;border:1px solid rgba(255,220,200,.4);background:rgba(255,252,248,.6);font-size:9.5px;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s;font-family:inherit;text-align:center;line-height:1.2;height:100%;text-decoration:none}
.ql-btn:hover{background:rgba(255,252,248,.92);border-color:rgba(194,107,79,.3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(194,107,79,.12)}
.ql-icon{font-size:16px;line-height:1}
/* Task items — tighter */
.tlist{overflow-y:auto;padding:2px 0}
#todList .ti{margin-left:0;padding-left:7px;padding-right:16px}
#shopOv .ti,#recList .ti{margin:0 6px;padding:3px 22px 3px 10px}
#shopOv .cpill{position:absolute;right:3px;top:50%;transform:translateY(-50%);padding:1px 4px;line-height:1;margin:0;transition:opacity .1s;pointer-events:none}
#shopOv .ti:hover .cpill,#shopOv .ti.sel-row .cpill{opacity:0}
#shopOv .tn,#recList .tn{font-size:11px;color:rgba(80,70,65,.72)}
#shopOv .chk,#recList .chk{width:11px;height:11px}
.ti{display:flex;align-items:center;gap:8px;padding:3px 22px 3px 10px;margin:1px 6px;border-radius:7px;transition:background .12s,box-shadow .12s,transform .12s,border-color .12s;position:relative;min-width:0;cursor:pointer;border:1px solid transparent}
.ti:hover{background:rgba(255,255,255,.72)!important;box-shadow:0 2px 10px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.95);transform:translateY(-1px);}
.ti.done{opacity:.38}.ti.done .tn{text-decoration:line-through;color:var(--muted)}
.ti[draggable="true"]{cursor:grab}.ti[draggable="true"]:active{cursor:grabbing;opacity:.4}
.ti.ov-row{background:rgba(252,213,206,0.55);border:1px solid rgba(255,255,255,0.55)}.ti.ov-row .tn{color:#9f3826;font-weight:600}
.ti.imp-row{background:rgba(254,243,199,0.55);border:1px solid rgba(255,255,255,0.55)}
.ti.imp-row .tn{font-weight:600}
.ti.sel-row{background:var(--sel-bg)!important;border:1px solid var(--sel-b)!important;box-shadow:0 4px 14px var(--sel-shadow),0 1px 4px var(--sel-shadow),inset 0 1px 1px rgba(255,255,255,.92)!important;transform:translateY(-1.5px)!important}
.chip.sel-row{outline:1px solid color-mix(in srgb,var(--sel-d) 40%,transparent)!important;outline-offset:-1px;box-shadow:0 3px 10px var(--sel-shadow),0 1px 4px var(--sel-shadow)!important}.mcell-t.sel-row{outline:1px solid color-mix(in srgb,var(--sel-d) 40%,transparent)!important;outline-offset:-1px;box-shadow:0 3px 10px var(--sel-shadow)!important}.mcell-t[data-tid^="tv-"].sel-row{outline:none!important;outline-offset:0}.wkc-banner.sel-row{outline:1.5px solid color-mix(in srgb,var(--sel-d) 55%,transparent)!important;outline-offset:-1px;box-shadow:0 3px 10px var(--sel-shadow),0 1px 4px var(--sel-shadow)!important;transform:translateY(-1px)}
.chk-wrap{display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:7px 6px;margin:-7px -6px;cursor:pointer;border-radius:6px}
.chk{width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(180,170,210,.5);cursor:pointer;appearance:none;flex-shrink:0;background:rgba(255,255,255,.8);transition:all .2s;box-shadow:inset 0 1px 2px rgba(0,0,0,.04);pointer-events:none}
.chk:checked{background:#a3c41a;border-color:#a3c41a;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3.5 8l3 3 6-6' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.tn{flex:1;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;letter-spacing:-.01em}
.tn:hover{color:var(--accent)}
.cpill{font-size:9px;font-weight:600;padding:2px 7px;border-radius:5px;flex-shrink:0;border:1px solid rgba(255,255,255,0.6);white-space:nowrap;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.7)}
.cat-dot{position:absolute;right:11px;top:50%;transform:translateY(-50%);display:block;overflow:visible;transition:opacity .1s}
.ti:hover .cat-dot,.ti.sel-row .cat-dot{opacity:0}
.dlbl{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--subtle);flex-shrink:0;min-width:44px;text-align:right;white-space:nowrap;margin-left:auto}
.date-clr{opacity:0;font-size:9px;color:var(--muted);transition:opacity .12s;margin-left:1px}
.inline-date-picker{position:absolute;z-index:800;background:rgba(255,255,255,.98);border:1px solid rgba(210,205,228,.4);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.12);padding:8px;backdrop-filter:blur(12px);display:none}
body.dark .inline-date-picker{background:rgba(20,18,35,.98);border-color:rgba(255,255,255,.12);}
.inline-date-picker.show{display:block;animation:fadeUp .12s ease}
.inline-date-picker input[type="date"]{padding:5px 8px;border-radius:7px;border:1px solid rgba(210,205,228,.4);font-family:inherit;font-size:12px;font-weight:500;background:rgba(255,255,255,.8);color:var(--text);outline:none;cursor:pointer}
body.dark .inline-date-picker input[type="date"]{background:rgba(255,255,255,.08);color:var(--text);border-color:rgba(255,255,255,.15);}
.inline-date-picker input[type="date"]:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(109,95,230,.12)}
.idp-actions{display:flex;gap:4px;margin-top:6px}
.idp-btn{flex:1;padding:3px 0;border-radius:6px;border:none;font-family:inherit;font-size:10px;font-weight:600;cursor:pointer}
.idp-clear{background:rgba(239,68,68,.1);color:#ef4444}
.idp-clear:hover{background:rgba(239,68,68,.2)}
.idp-save{background:var(--accent);color:#fff}
.idp-save:hover{opacity:.9}
.dlbl:hover .date-clr{opacity:1}
.dlbl.ov{color:#ef4444!important;margin-right:-4px}
.flag-u{font-size:8px;font-weight:600;padding:0px 4px;border-radius:4px;background:rgba(148,163,184,.12);color:var(--muted);border:1px solid rgba(148,163,184,.2);flex-shrink:0}
.imp-star{font-size:11px;flex-shrink:0;line-height:1}
.delbtn{opacity:0;background:none;border:none;cursor:pointer;color:var(--subtle);font-size:10px;padding:1px 2px;border-radius:3px;flex-shrink:0;transition:opacity .1s;position:absolute;right:3px;top:50%;transform:translateY(-50%)}
.ti:hover .delbtn,.ti.sel-row .delbtn{opacity:1;color:var(--subtle)}.delbtn:hover{color:#ef4444!important}
.wr-has-cad{font-size:10.5px}
.wr-cad-badge{position:absolute;right:3px;top:50%;transform:translateY(-50%);font-size:9px;font-weight:700;letter-spacing:.3px;padding:1px 3px;border-radius:3px;background:rgba(0,0,0,.08);color:rgba(100,116,139,.95);pointer-events:none}
.wr-cad-badge.changed{background:rgba(59,130,246,.18);color:#1e40af}
.wr-dot{position:absolute;right:5px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:#93c5fd;pointer-events:none;flex-shrink:0}
.ti:hover .wr-cad-badge,.ti.sel-row .wr-cad-badge,.ti:hover .wr-dot,.ti.sel-row .wr-dot{display:none}
.arow{padding:4px 8px;border-top:1px solid rgba(210,205,228,.22);display:flex;gap:3px;background:rgba(255,255,255,.18);flex-shrink:0}
.ov-banner{display:none;align-items:center;gap:8px;padding:6px 16px;background:rgba(254,242,242,.9);border-bottom:1px solid rgba(239,68,68,.15);font-size:11px;font-weight:500;color:#b91c1c;flex-shrink:0}
body.dark .ov-banner{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.2);color:#fca5a5;}
.ov-banner.show{display:flex}
.ov-banner-btn{margin-left:auto;background:#ef4444;color:#fff;border:none;border-radius:6px;padding:3px 9px;font-size:10px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap}
.ov-banner-btn:hover{background:#dc2626}
.ainput{flex:1;padding:4px 7px;border-radius:var(--rs);border:1px solid var(--gb);font-family:inherit;font-size:11px;font-weight:500;background:rgba(255,255,255,.7);color:var(--text);outline:none;min-width:0}
.ainput:focus{border-color:var(--accent);background:rgba(255,255,255,.95);box-shadow:0 0 0 2px rgba(109,95,230,.1)}
.ainput::placeholder{color:var(--subtle)}
.asel{padding:3px 4px;border-radius:var(--rs);border:1px solid var(--gb);font-family:inherit;font-size:10px;font-weight:500;background:rgba(255,255,255,.7);color:var(--text);outline:none;cursor:pointer}

/* Quick-add popup */
.qa-popup{position:fixed;z-index:600;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border:1px solid var(--gb);border-radius:13px;box-shadow:var(--shadow-lg);padding:12px 14px 11px;width:270px;display:none}
.qa-popup.open{display:block;animation:fadeUp .13s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.qa-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:-.1px}
.qa-field{margin-bottom:6px}
.qa-field label{display:block;font-size:9px;font-weight:700;color:var(--muted);margin-bottom:2px;text-transform:uppercase;letter-spacing:.07em}
.qa-field input,.qa-field select{width:100%;padding:5px 7px;border-radius:var(--rs);border:1px solid var(--border);font-family:inherit;font-size:12px;background:rgba(255,255,255,.8);color:var(--text);outline:none;font-weight:500}
.qa-field input:focus,.qa-field select:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(109,95,230,.1)}
.qa-imp-row{display:flex;align-items:center;gap:6px;padding:4px 0 2px}
.qa-imp-row label{font-size:11px;font-weight:500;color:var(--text);cursor:pointer}
.qa-hint{font-size:9px;color:var(--subtle);margin-top:6px;text-align:center}
.qa-close{position:absolute;top:8px;right:10px;background:none;border:none;cursor:pointer;color:var(--subtle);font-size:13px;padding:2px 3px;border-radius:4px}
.qa-close:hover{color:var(--text);background:rgba(0,0,0,.05)}

/* Layout — consistent 14px gaps everywhere */
.overview-left{display:flex;flex-direction:column;gap:14px;min-height:0}
.row1-right-panel{display:flex;flex-direction:column;gap:14px;min-height:0}
.row1-right-top{display:grid;grid-template-columns:1.05fr 0.9fr 0.6fr;gap:14px;flex-shrink:0;max-height:min(225px,28vh)}
.top-right-controls{position:fixed;top:14px;right:20px;z-index:1000;display:flex;align-items:center;gap:8px}
.row1-right{display:grid;grid-template-columns:1fr 0.85fr 0.6fr;grid-template-rows:auto 1fr;gap:14px;min-height:0}
.row1-left{display:flex;flex-direction:column;gap:8px;min-height:0}
.row1-left-btns{display:flex;align-items:center;gap:6px;flex-shrink:0;flex-wrap:wrap}
.row1-right-cards{display:contents}
.sum-metrics{display:flex;align-items:center;gap:14px;padding:5px 14px;grid-column:1/3;min-height:44px}
.row1-controls{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end;gap:6px;padding-bottom:2px}
.sum-metric{display:flex;flex-direction:column;gap:3px}
.sum-metric-val{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.4px;line-height:1;font-family:'DM Sans',sans-serif}
.sum-metric-lbl{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.sum-divider{width:1px;height:24px;background:rgba(210,205,228,.3);flex-shrink:0;align-self:center}
.tod-tb-header{display:flex;align-items:center;gap:4px;padding:1px 8px 1px 6px;border-bottom:1px solid rgba(210,205,228,.22);flex-shrink:0;background:rgba(255,255,255,.06)}
.tod-tb-center{flex:1;text-align:center}
.tod-tb-right{display:flex;align-items:center;gap:3px;flex-shrink:0}
.tod-tb-body{flex:1;min-height:0;display:flex;flex-direction:row;overflow:hidden}
.tod-section{flex:0.95;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.tb-section{flex:1.05;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.tod-tb-divider{flex-shrink:0;border-left:1px solid rgba(210,205,228,.3);margin:0}
.pup-skills-highlight{flex-shrink:0;margin:4px 6px 2px;border-radius:10px;background:rgba(237,233,254,.38);border:1px solid rgba(196,181,253,.4);box-shadow:0 2px 8px rgba(109,95,230,.06),inset 0 1px 0 rgba(255,255,255,.7);overflow:hidden}
.row2{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.row3{margin-top:20px;margin-bottom:14px;padding-bottom:2px}

/* Time Blocker */
.tb-nav{display:flex;align-items:center;gap:3px;padding:9px 10px;border-bottom:1px solid rgba(210,205,228,.25);background:rgba(255,255,255,.1);flex-shrink:0;min-height:38px;box-sizing:border-box}
.tb-lbl{flex:1;text-align:center;font-size:10px;font-weight:700;color:var(--text)}
.tb-scroll{flex:1;overflow-y:scroll;position:relative;scrollbar-width:none;-ms-overflow-style:none}.tb-scroll::-webkit-scrollbar{display:none}
.tb-grid{display:flex}
.tb-gutter{width:24px;flex-shrink:0}
.tb-tlbl{height:40px;display:flex;align-items:flex-start;justify-content:flex-end;padding-right:4px;padding-top:2px;font-family:'DM Sans',sans-serif;font-size:8px;color:var(--muted);border-right:1px solid rgba(210,205,228,.25)}
.tb-col{flex:1;position:relative;border-left:1px solid rgba(210,205,228,.15)}
.tb-hour{height:40px;border-bottom:1px solid rgba(210,205,228,.12);position:relative;cursor:crosshair;transition:background .1s}
.tb-hour::after{content:'';position:absolute;top:50%;left:0;right:0;border-top:1px dashed rgba(210,205,228,.15);pointer-events:none}
.tb-hour.don{background:rgba(109,95,230,.05)}
.tb-block{position:absolute;left:2px;right:2px;border-radius:8px;padding:2px 5px;z-index:2;min-height:16px;border:1px solid rgba(255,255,255,0.6);cursor:grab;overflow:hidden;transition:box-shadow .1s,transform .1s;user-select:none;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.75)}
.tb-block.tb-drop-over{outline:2px dashed rgba(109,95,230,.55);outline-offset:-2px;box-shadow:0 0 0 4px rgba(109,95,230,.1)!important}
.tb-block.done-block{opacity:.45}
.tb-block.done-block .tb-bt{text-decoration:line-through}
.tb-block.dragging-block{opacity:.35;cursor:grabbing}
.tb-chk{width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(180,170,210,.5);cursor:pointer;appearance:none;flex-shrink:0;background:rgba(255,255,255,.8);transition:all .2s;margin-right:2px;align-self:flex-start;margin-top:-1.415px}
.tb-chk:checked{background:#a3c41a;border-color:#a3c41a;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3.5 8l3 3 6-6' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.tb-block:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,0.85),0 8px 20px rgba(0,0,0,0.12);transform:translateY(-1px)}
.tb-block.sel-row{box-shadow:0 0 0 0.75px color-mix(in srgb,var(--sel-d) 50%,transparent),0 4px 14px var(--sel-shadow),0 1px 4px var(--sel-shadow),inset 0 1px 1px rgba(255,255,255,.92)!important;transform:translateY(-1.5px)!important}
.atb-block{position:absolute;left:2px;right:2px;border-radius:8px;padding:2px 5px;z-index:1;min-height:16px;border:1px solid rgba(180,175,200,.18);cursor:grab;overflow:hidden;user-select:none;background:rgba(245,244,250,.28);color:#b0aec0;pointer-events:auto}
.atb-block.tb-drop-over{outline:2px dashed rgba(109,95,230,.55);outline-offset:-2px;background:rgba(109,95,230,.07)!important}
.atb-block .tb-btime{color:#c8c6d4;font-size:7px}
.atb-block.dragging-block{opacity:.35;cursor:grabbing}
.atb-block.sel-atb{background:rgba(235,233,245,.65)!important;box-shadow:0 0 0 0.75px rgba(160,155,185,.5),0 4px 14px rgba(160,155,185,.25),0 1px 4px rgba(160,155,185,.2),inset 0 1px 1px rgba(255,255,255,.92)!important;transform:translateY(-1.5px)!important}
.tb-row{display:flex;align-items:flex-start;justify-content:space-between;gap:4px;padding:clamp(2px,0.5vh,5px) 2px 0;min-width:0;flex:1}
.tb-bt{font-size:8px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;line-height:1.1;margin-top:0.185px}
.tb-bt.wrap{white-space:normal;overflow:visible;text-overflow:unset}
.tb-edit{font-size:8px;font-weight:600;flex:1;min-width:0;background:rgba(255,255,255,.7);border:none;border-radius:3px;padding:1px 3px;outline:none;font-family:inherit;color:var(--text);line-height:1.1}
.tb-right{position:relative;flex-shrink:0;display:flex;align-items:center}
.tb-btime{font-size:7.5px;opacity:.7;white-space:nowrap;line-height:1.1;transition:opacity .12s}
.tb-bdel{font-size:9px;opacity:0;background:none;border:none;cursor:pointer;color:inherit;padding:0;position:absolute;right:0;top:50%;transform:translateY(-50%);line-height:1;transition:opacity .12s}
.tb-block:hover .tb-bdel{opacity:1;color:var(--subtle)}
.tb-block:hover .tb-btime{opacity:0}
.atb-block:hover .tb-bdel{opacity:1;color:rgba(180,175,200,.7)}
.atb-block:hover .tb-btime{opacity:0}
.atb-block .tb-right{align-self:center}
.tb-notes{font-size:8px;opacity:.5;padding:0 2px 1px 2px;line-height:1.2}
.tb-block.tb-expanded{overflow:visible!important;transition:height .15s ease,box-shadow .1s,transform .1s!important;box-shadow:0 8px 24px rgba(0,0,0,.18)!important;z-index:25!important}
.tb-resize{position:absolute;bottom:0;left:0;right:0;height:4px;cursor:ns-resize}
.tb-resize::after{content:'';display:block;width:12px;height:1.5px;border-radius:1px;background:currentColor;opacity:.2;margin:0 auto}
.nowline{position:absolute;left:0;right:0;z-index:20;pointer-events:none;height:2px;background:rgba(120,120,120,0.7)}
.nowdot{width:8px;height:8px;border-radius:50%;background:#888;position:absolute;left:2px;top:-3px}
.tb-sum{display:none}
.si{display:flex;align-items:center;gap:2px;font-size:8px;color:var(--muted)}
.sdotc{width:4px;height:4px;border-radius:50%;flex-shrink:0}
.sv{font-weight:700;color:var(--text);font-family:'DM Sans',sans-serif}
.day-flash{position:absolute;inset:0;background:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--accent);pointer-events:none;opacity:0;transition:opacity .2s;z-index:10;border-radius:var(--r)}
.day-flash.show{opacity:1}

/* Notion-style Week Cal */
.wkc-outer{flex:1;overflow:hidden;display:flex;flex-direction:column}
.wkc-nav{display:flex;align-items:center;gap:6px;padding:0 10px;border-bottom:1px solid rgba(210,205,228,.25);background:rgba(255,255,255,.1);flex-shrink:0;min-height:31px;box-sizing:border-box}
.wkc-lbl{flex:1;text-align:center;font-size:10px;font-weight:700;color:var(--text);letter-spacing:-.1px}
.wkc-inner{flex:1;overflow:hidden;display:flex;flex-direction:column}
.wkc-head{display:flex;border-bottom:1px solid rgba(210,205,228,.25);flex-shrink:0;background:rgba(255,255,255,.18);padding:2px 0 1px}
.wkc-day-h{flex:1;min-width:0;padding:2px 2px;text-align:center;border-left:1px solid rgba(210,205,228,.18);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.wkc-day-h:first-child{border-left:none}
.wkc-dn{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);line-height:1}
.wkc-dd{font-size:11px;font-weight:700;color:var(--text);width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.wkc-dd.tn2{background:var(--accent);color:#fff}
.wkc-cols{flex:1;display:flex;overflow-y:auto;scrollbar-width:none}
.wkc-cols::-webkit-scrollbar{display:none}
/* drag zone at edges for week navigation */
.wkc-edge{position:absolute;top:0;bottom:0;width:32px;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:background .15s;opacity:0}
.wkc-edge.active{opacity:1}
.wkc-edge.left{left:0;background:linear-gradient(to right,rgba(109,95,230,.12),transparent)}
.wkc-edge.right{background:linear-gradient(to left,rgba(109,95,230,.12),transparent)}
#wkcEdgeR{right:0}
.wkc-cols-wrap{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column;padding-top:0}
.wk-list-edge{position:absolute;top:0;bottom:0;width:36px;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .15s;font-size:15px;font-weight:700;color:var(--accent);cursor:pointer}
.wk-list-edge.active{opacity:1;pointer-events:all}
.wk-list-edge-l{left:0;background:linear-gradient(to right,rgba(109,95,230,.15),transparent)}
.wk-list-edge-r{right:0;background:linear-gradient(to left,rgba(109,95,230,.15),transparent)}
.wkc-col{flex:1;min-width:0;border-left:1px solid rgba(210,205,228,.15);padding:2px 2px;overflow:hidden;transition:background .1s;user-select:none;-webkit-user-select:none}
.wkc-col:first-child{border-left:none}
.wkc-col.drop-here{background:rgba(109,95,230,.05)}
.wkc-goals-col{flex:1;min-width:0;border-left:2px solid rgba(255,255,255,.88);padding:2px 2px;overflow:hidden;user-select:none;-webkit-user-select:none;background:rgba(255,255,255,.18)}
.wkc-goals-col .chip{backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 2px 8px rgba(0,0,0,.07),inset 0 1px 0 rgba(255,255,255,.9)}
.wkc-goals-h{border-left:2px solid rgba(255,255,255,.88);display:flex;flex-direction:column;padding:0 2px;flex:1;min-width:0;justify-content:center;align-items:center}
.wo-hdr-btn{background:rgba(255,255,255,.6);border:1px solid rgba(210,205,228,.55);cursor:pointer;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);line-height:1.35;padding:2px 4px;border-radius:5px;text-align:center;transition:background .12s,color .12s,border-color .12s;width:100%;margin:0;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.wo-hdr-btn:hover{background:rgba(109,95,230,.09);color:var(--accent);border-color:rgba(109,95,230,.3)}
.wo-modal{width:min(96vw,1000px);padding:16px 14px 14px;display:flex;flex-direction:column}
.wo-modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px;flex-shrink:0}
.wo-modal-title{font-size:13px;font-weight:700;letter-spacing:-.3px;flex:1;text-align:center}
.wo-nav-btn{background:rgba(255,255,255,.6);border:1px solid rgba(210,205,228,.5);border-radius:7px;padding:5px 14px;cursor:pointer;font-size:14px;color:var(--text);transition:background .1s,border-color .1s;line-height:1;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.wo-nav-btn:hover{background:rgba(109,95,230,.09);border-color:rgba(109,95,230,.3)}
.wo-cols-wrap{position:relative;flex:1}
.wo-cols{display:flex;gap:8px;height:440px}
.wo-col{flex:1;min-width:0;border-radius:10px;background:rgba(255,255,255,.45);border:1px solid rgba(210,205,228,.3);display:flex;flex-direction:column;overflow:hidden}
.wo-col-current{background:rgba(109,95,230,.07);border-color:rgba(109,95,230,.28)}
.wo-col-past{opacity:.75}
.wo-col-h{padding:7px 8px 6px;border-bottom:1px solid rgba(210,205,228,.25);text-align:center;flex-shrink:0}
.wo-col-lbl{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);line-height:1}
.wo-col-range{font-size:10px;font-weight:700;color:var(--text);letter-spacing:-.2px;margin-top:2px}
.wo-col-body{overflow-y:auto;padding:4px 5px;flex:1}
.wo-chip{width:100%;box-sizing:border-box}
.wo-chip.sel-row,.wkc-goals-col .chip.sel-row{outline:1px solid rgba(200,196,218,.7)!important;outline-offset:-1px;box-shadow:0 3px 10px rgba(180,175,205,.28),0 1px 4px rgba(180,175,205,.2)!important;transform:none!important}
.wo-edge{position:absolute;top:0;bottom:0;width:44px;z-index:10;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .15s;font-size:18px;font-weight:700;color:var(--accent)}
.wo-edge.active{opacity:1}
.wo-edge.left{left:0;background:linear-gradient(to right,rgba(109,95,230,.18),transparent)}
.wo-edge.right{right:0;background:linear-gradient(to left,rgba(109,95,230,.18),transparent)}
#todList.drop-here{background:rgba(109,95,230,.04);border-radius:8px;outline:1.5px dashed rgba(109,95,230,.25)}
.chip{margin-bottom:2px;padding:2px 4px;border-radius:6px;font-size:9px;font-weight:500;display:flex;align-items:center;gap:4px;cursor:pointer;border:1px solid rgba(255,255,255,0.6);white-space:nowrap;overflow:hidden;transition:filter .1s;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.75)}
.chip:hover{filter:brightness(.96)}
.chip .wchk{width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(180,170,210,.5);appearance:none;cursor:pointer;flex-shrink:0;background:rgba(255,255,255,.8);transition:all .2s}
.chip .wchk:checked{background:#a3c41a;border-color:#a3c41a;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3.5 8l3 3 6-6' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.chip.done-chip{opacity:.25}
.tb-arrow{position:absolute;right:3px;top:50%;transform:translateY(-50%);font-size:9px;font-weight:600;opacity:.75;color:var(--accent);pointer-events:none;transition:opacity .1s}
.ti:hover .tb-arrow{opacity:0}
.chip-name{flex:1;overflow:hidden;text-overflow:ellipsis;font-size:9px}
/* Travel/birthday banner row spanning multiple days */
.wkc-banners{height:22px;position:absolute;top:0;left:0;right:0;z-index:6;pointer-events:none}
.wkc-banner{position:absolute;top:2px;height:18px;border-radius:6px;font-size:9px;font-weight:700;display:flex;align-items:center;padding:0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:all;cursor:pointer;z-index:5;border:1px solid rgba(255,255,255,0.6);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:inset 0 1px 0 rgba(255,255,255,0.75)}
.wkc-banner:hover{filter:brightness(.96)}
.wkc-banner .ban-del{opacity:0;background:none;border:none;cursor:pointer;color:currentColor;font-size:9px;padding:0 2px;margin-left:auto;flex-shrink:0;transition:opacity .1s;line-height:1}
.wkc-banner:hover .ban-del{opacity:.65}.wkc-banner.sel-row .ban-del{opacity:.65}.wkc-banner .ban-del:hover{opacity:1!important;color:#ef4444!important}
/* Drag-to-add-travel ghost */
.wkc-drag-ghost{position:absolute;top:2px;height:18px;border-radius:4px;pointer-events:none;z-index:20;opacity:.55;transition:none}
.wkc-col.drag-sel{background:rgba(20,184,166,.07)}

.wkc-foot{display:flex;align-items:center;padding:4px 8px;flex-shrink:0;gap:6px;min-height:30px}
#unAssignedBadge:hover{opacity:.85}
.month-btn{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;padding:3px 5px;border-radius:var(--rxs);background:none;transition:all .15s}
.month-btn:hover{background:rgba(109,95,230,.07);color:var(--accent)}

/* Kanban */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;width:100%;align-items:stretch}
.kanban::-webkit-scrollbar{height:3px}
.kol{flex:1;min-width:200px;max-width:300px;background:transparent;border:none;box-shadow:none;border-radius:var(--r);display:flex;flex-direction:column;height:265px;overflow:hidden}
.kol-head{padding:6px 9px 4px;border-bottom:1px solid rgba(210,205,228,.25);display:flex;align-items:center;gap:4px;flex-shrink:0}
.kol-title{font-size:9px;font-weight:700;letter-spacing:.04em;flex:1}
.kol-cnt{font-family:'DM Sans',sans-serif;font-size:9px;color:var(--muted)}
.kol-body{flex:1;overflow-y:auto;padding:2px 0;min-height:0;overflow-x:hidden}
.kol-item{display:flex;align-items:center;gap:8px;padding:5px 9px;border-bottom:1px solid rgba(255,220,200,.18);transition:background .1s,box-shadow .1s;position:relative}
.kol-item:last-child{border-bottom:none}
.kol-item:hover{background:rgba(255,237,213,.4);box-shadow:inset 0 1px 0 rgba(255,255,255,0.6)}.kol-item:hover .delbtn{opacity:1;color:var(--subtle)}.kol-item.imp-row:hover{background:rgba(254,243,199,.55)}
.kol-item.done{opacity:.35}.kol-item.done .kn{text-decoration:line-through}
.kol-item.ov-row .kn{color:#9f3826;font-weight:600}
.kol-item.imp-row{background:rgba(254,243,199,0.35);border-left:2px solid rgba(217,119,6,0.6);box-shadow:inset 0 1px 0 rgba(255,255,255,0.55)}.kol-item.imp-row .kn{font-weight:600}
.kn{flex:1;font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;min-width:0}
.kn:hover{color:var(--accent)}
.kol-add{padding:4px 8px;border-top:1px solid rgba(210,205,228,.15);display:flex;gap:3px;background:rgba(255,255,255,.28);flex-shrink:0;border-radius:0 0 var(--r) var(--r)}
.kol-input{flex:1;padding:3px 6px;border-radius:var(--rxs);border:1px solid var(--gb);font-family:inherit;font-size:11px;background:rgba(255,255,255,.7);color:var(--text);outline:none;min-width:0}
.kol-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(109,95,230,.1)}
.kol-input::placeholder{color:var(--subtle)}
.dzone.over{background:rgba(109,95,230,.04)}

/* Modals */
.overlay{position:fixed;inset:0;background:rgba(30,20,60,.32);display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;pointer-events:none;transition:opacity .18s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:rgba(255,252,248,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.5);border-radius:16px;box-shadow:0 20px 50px rgba(0,0,0,0.12),inset 0 1px 0 rgba(255,255,255,0.7);transform:scale(.94) translateY(18px);opacity:0;transition:transform .28s cubic-bezier(.34,1.38,.64,1),opacity .2s ease}
.overlay{transition:opacity .2s ease}
.overlay.open .modal{transform:scale(1) translateY(0);opacity:1}
#mModal,#recMoModal{backdrop-filter:none;-webkit-backdrop-filter:none}
.bg-canvas.orbs-paused .orb{animation-play-state:paused}
.mt{font-size:14px;font-weight:700;letter-spacing:-.3px;margin-bottom:11px}
.mfield{margin-bottom:8px}
.mfield label{display:block;font-size:9px;font-weight:700;color:var(--muted);margin-bottom:2px;text-transform:uppercase;letter-spacing:.07em}
.mfield input,.mfield select{width:100%;padding:6px 8px;border-radius:var(--rs);border:1px solid var(--border);font-family:inherit;font-size:12px;background:rgba(255,255,255,.8);color:var(--text);outline:none;font-weight:500}
.mfield input:focus,.mfield select:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(109,95,230,.1)}
.mimp-row{display:flex;align-items:center;gap:6px;padding:5px 0 2px}
.mimp-row label{font-size:11px;font-weight:500;color:var(--text);cursor:pointer}
.mact{display:flex;gap:5px;justify-content:flex-end;margin-top:11px}
.task-modal{width:300px;padding:16px}

/* Month modal — larger */
.month-modal{width:min(98vw,1400px);display:flex;height:94vh;overflow:hidden}
.mo-search-hl{outline:2px solid #a78bfa!important;outline-offset:1px;z-index:2;position:relative;opacity:.7}
.mo-search-hl-cur{outline:3px solid #7c3aed!important;outline-offset:1px;z-index:3;position:relative;opacity:1!important;box-shadow:0 0 0 4px rgba(124,58,237,.18)!important}
#moSearchWrap:focus-within{border-color:rgba(124,58,237,.5)}
#moSearchSug .mo-sug-item:first-child{border-radius:8px 8px 0 0}
#moSearchSug .mo-sug-item:last-child{border-radius:0 0 8px 8px}
.mcal-side{flex:1;display:flex;flex-direction:column;overflow:hidden}
.mua-side{width:150px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.mhead{display:flex;align-items:center;gap:7px;padding:0 13px;min-height:38px;border-bottom:1px solid rgba(210,205,228,.3);border-radius:8px;box-sizing:border-box}
.mgrid{flex:1;overflow-y:auto;padding:0 12px 12px;scroll-padding-top:21px}
.mdow{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:0;position:sticky;top:0;z-index:5;background:var(--bg);padding:4px 12px 3px;margin-left:-12px;margin-right:-12px;border-radius:0}
#recMoDow,#recMoCells{grid-template-columns:repeat(7,1fr) minmax(60px,1.1fr)}
#mDow,#mCells{grid-template-columns:repeat(7,1fr) minmax(60px,1.08fr)}
.mdowl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:center;padding:2px 0}
.mo-sep{grid-column:1/-1;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:10px 4px 4px;border-top:1px solid rgba(210,205,228,.3);margin-top:2px}
.mcells{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.mo-goals-cell{background:rgba(255,255,255,.18)!important;border:1px solid rgba(255,255,255,.25)!important;border-left:2px solid rgba(255,255,255,.88)!important}
.mcell{min-height:max(70px,calc((94vh - 100px) / 4 - 4px));min-width:0;background:rgba(255,252,248,.55);border:1px solid rgba(255,220,200,.35);border-radius:var(--rs);padding:4px;cursor:pointer;transition:background .1s;user-select:none;-webkit-user-select:none}
.mcell.travel-sel{background:rgba(20,184,166,.09);border-color:rgba(20,184,166,.4)}
.mcell:hover{background:rgba(255,252,248,.82)}
.mcell.om{opacity:.3}.mcell.tc{border-color:var(--accent);border-width:1.5px}
.mcell-n{font-size:10px;font-weight:700;font-family:'DM Sans',sans-serif;color:var(--text);width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:2px}
.mcell.tc .mcell-n{background:var(--accent);color:#fff}
.mcell-t{font-size:8px;font-weight:600;height:18px;padding:0 4px;border-radius:4px;margin-bottom:1px;white-space:nowrap;overflow:hidden;border:1px solid rgba(255,255,255,0.6);box-shadow:inset 0 1px 0 rgba(255,255,255,0.7);display:flex;align-items:center;gap:2px}
.chip-del{opacity:0;background:none;border:none;cursor:pointer;font-size:8px;padding:0 2px;color:inherit;flex-shrink:0;line-height:1;transition:opacity .1s}
.chip:hover .chip-del,.mcell-t:hover .chip-del{opacity:1;color:var(--subtle)}.chip-del:hover{color:#ef4444!important}
.wkc-col .chip,.wkc-goals-col .chip{position:relative}
.wkc-col .chip .chip-del,.wkc-goals-col .chip .chip-del{position:absolute;right:2px;top:50%;transform:translateY(-50%);flex-shrink:unset}
.mcell.dov{background:rgba(109,95,230,.07);border-color:var(--accent)}
.muah{padding:9px 12px 5px;border-bottom:1px solid rgba(210,205,228,.28);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.mual{flex:1;overflow-y:auto;padding:4px}
.uitem{padding:3px 5px;background:rgba(255,255,255,.55);border:1px solid var(--border);border-radius:var(--rxs);margin-bottom:2px;font-size:9px;font-weight:500;cursor:grab;display:flex;align-items:center;gap:3px}
.uitem:hover{box-shadow:var(--shadow)}.uitem:active{cursor:grabbing;opacity:.4}
.udot{width:5px;height:5px;border-radius:50%;flex-shrink:0}

/* Settings */
.sf{margin-bottom:9px}.sf label{display:block;font-size:9px;font-weight:700;color:var(--muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.07em}
.si2{width:100%;padding:6px 9px;border-radius:var(--rs);border:1px solid var(--border);font-family:'DM Sans',sans-serif;font-size:11px;background:rgba(255,255,255,.7);color:var(--text);outline:none}
.si2:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(109,95,230,.1)}
.cst{display:flex;align-items:center;gap:6px;padding:7px 9px;border-radius:var(--rs);font-size:11px;font-weight:600;margin:8px 0;border:1px solid transparent}
.cst.ok{background:rgba(34,197,94,.08);color:#166534;border-color:rgba(34,197,94,.2)}
.cst.err2{background:rgba(239,68,68,.07);color:#991b1b;border-color:rgba(239,68,68,.18)}
.cst.idle{background:rgba(255,255,255,.5);color:var(--muted);border-color:var(--border)}

::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(180,160,220,.2);border-radius:2px}

.ctx-item{padding:6px 12px;border-radius:5px;font-size:11px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text);transition:background .1s}
.ctx-item:hover{background:rgba(109,95,230,.08)}
.ctx-danger{color:#ef4444}
.ctx-danger:hover{background:rgba(239,68,68,.08)!important}
.ctx-divider{height:1px;background:rgba(210,205,228,.3);margin:3px 4px}
/* Recurring tasks table */
.rt-tbl{width:100%;border-collapse:collapse;font-size:11.5px;table-layout:fixed}
.rt-tbl thead tr{border-bottom:1px solid rgba(210,205,228,.18)}
.rt-tbl th{text-align:center;padding:4px 8px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.rt-tbl td{padding:3px 8px;vertical-align:middle;border-bottom:1px solid rgba(210,205,228,.06);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rt-tbl td:last-child{text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:2px;padding:3px 6px}
.rt-tbl .rt-meta{font-size:10.5px;color:var(--muted)}
.rt-editable{cursor:text}.rt-editable:hover{background:rgba(255,255,255,.45);border-radius:4px}
.rt-edit-input{width:100%;max-width:100%;box-sizing:border-box;font-size:11px;background:rgba(255,255,255,.95);border:1px solid var(--accent);border-radius:4px;padding:1px 5px;font-family:inherit;color:var(--text);outline:none}
.rt-row{cursor:pointer;transition:background .1s}
.rt-row:hover td{background:rgba(255,237,213,.3)}
body.dark .rt-row:hover td{background:rgba(255,220,200,.06)}
.rt-tbl .delbtn{position:static;transform:none;flex-shrink:0}
.rt-row:hover .delbtn{opacity:1}
.rt-row.sel-row td{background:var(--sel-bg,rgba(130,115,100,.1))!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.rt-row.done .tn{text-decoration:line-through;color:var(--muted)}
.rt-row td:last-child{width:52px;text-align:right;white-space:nowrap}

/* Quick Notes */
#qnBtn{position:fixed;bottom:20px;right:20px;z-index:950;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.7);box-shadow:0 4px 16px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,.9);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:all .18s}
#qnBtn:hover{background:#fff;box-shadow:0 6px 20px rgba(0,0,0,.16);transform:translateY(-2px)}
body.dark #qnBtn{background:rgba(255,240,230,.08);border-color:rgba(255,220,200,.15)}
/* Panel — glass card like .card but notepad shaped */
#qnPanel{position:fixed;bottom:70px;right:20px;z-index:949;width:340px;height:480px;display:flex;flex-direction:column;border-radius:var(--r);overflow:visible;box-shadow:var(--shadow-lg),inset 0 1.5px 0 rgba(255,255,255,1),inset 1px 0 0 rgba(255,255,255,.6),inset -1px 0 0 rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.55);background:rgba(255,255,255,.72);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);transform:translateY(16px) scale(.97);opacity:0;pointer-events:none;transition:transform .22s cubic-bezier(.34,1.56,.64,1),opacity .18s ease}
#qnPanel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
body.dark #qnPanel{background:rgba(40,22,14,.75);border-color:rgba(255,220,200,.12);box-shadow:0 20px 50px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.35)}
/* Spiral binding — left strip */
.qn-binding{position:absolute;left:-14px;top:12px;bottom:12px;width:14px;display:flex;flex-direction:column;justify-content:space-evenly;align-items:center;pointer-events:none;z-index:5}
.qn-coil{width:14px;height:10px;border:2px solid rgba(194,107,79,.45);border-radius:50%;background:rgba(255,255,255,.7);box-shadow:0 1px 3px rgba(0,0,0,.12)}
body.dark .qn-coil{border-color:rgba(194,107,79,.3);background:rgba(40,22,14,.8)}
/* Header — matches .ch style */
.qn-header{display:flex;align-items:center;gap:6px;padding:9px 13px;border-bottom:1px solid rgba(210,205,228,.22);flex-shrink:0;min-height:38px}
.qn-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);flex:1}
.qn-close-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:13px;padding:2px 4px;border-radius:5px;transition:all .12s;line-height:1}
.qn-close-btn:hover{background:rgba(0,0,0,.06);color:var(--text)}
/* Lined paper area */
.qn-list{flex:1;overflow-y:auto;padding:6px 12px;scrollbar-width:thin;scrollbar-color:rgba(180,160,140,.2) transparent;background-image:repeating-linear-gradient(transparent,transparent 27px,rgba(180,150,100,.1) 27px,rgba(180,150,100,.1) 28px);background-size:100% 28px;background-position:0 6px}
body.dark .qn-list{background-image:repeating-linear-gradient(transparent,transparent 27px,rgba(255,180,80,.06) 27px,rgba(255,180,80,.06) 28px)}
.qn-list::-webkit-scrollbar{width:3px}.qn-list::-webkit-scrollbar-thumb{background:rgba(180,160,140,.2);border-radius:2px}
.qn-item{display:flex;align-items:flex-start;gap:7px;padding:5px 4px;min-height:31px;border-radius:6px;transition:background .1s}
.qn-item:hover{background:rgba(255,237,213,.55)}
body.dark .qn-item:hover{background:rgba(255,255,255,.07)}
.qn-bullet{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.6;flex-shrink:0;margin-top:5px}
.qn-text{flex:1;font-size:12px;font-weight:500;color:var(--text);line-height:1.5;word-break:break-word}
.qn-del{background:none;border:none;cursor:pointer;color:var(--subtle);font-size:11px;padding:1px 3px;border-radius:4px;opacity:0;transition:opacity .12s,background .12s,color .12s;flex-shrink:0;line-height:1;margin-top:3px}
.qn-item:hover .qn-del{opacity:1}
.qn-del:hover{background:rgba(239,68,68,.1);color:#ef4444}
.qn-empty{padding:24px 12px;text-align:center;font-size:11px;color:var(--subtle);font-style:italic}
/* Input footer — matches card footer style */
.qn-input-row{display:flex;gap:6px;padding:8px 10px;border-top:1px solid rgba(210,205,228,.22);flex-shrink:0;background:rgba(255,255,255,.4)}
body.dark .qn-input-row{background:rgba(255,255,255,.03)}
.qn-input{flex:1;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--text);background:rgba(255,255,255,.8);border:1px solid rgba(210,205,228,.35);border-radius:var(--rxs);padding:5px 9px;outline:none;transition:border-color .15s}
.qn-input:focus{border-color:rgba(194,107,79,.45);box-shadow:0 0 0 2px rgba(194,107,79,.1)}
body.dark .qn-input{background:rgba(255,255,255,.06);border-color:rgba(255,220,200,.12)}
.qn-add-btn{background:rgba(194,107,79,.15);border:1px solid rgba(194,107,79,.25);border-radius:var(--rxs);color:var(--accent);font-size:16px;font-weight:600;width:30px;flex-shrink:0;cursor:pointer;transition:all .14s;display:flex;align-items:center;justify-content:center;padding:0}
.qn-add-btn:hover{background:rgba(194,107,79,.28);border-color:rgba(194,107,79,.4)}

/* ── Recipes Page ── */
.rec-tbl{width:100%;border-collapse:collapse;font-size:11px;table-layout:fixed}
.rec-tbl th{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:6px 8px;border-bottom:1.5px solid rgba(210,205,228,.25);text-align:left;white-space:nowrap;position:sticky;top:0;background:rgba(255,248,244,0.97);z-index:1;cursor:pointer;user-select:none}
body.dark .rec-tbl th{background:rgba(40,22,14,.97)}
.rec-tbl td{padding:5px 8px;border-bottom:1px solid rgba(210,205,228,.1);vertical-align:middle}
.rec-tbl tr:hover td{background:rgba(255,255,255,.4)}
.rec-tbl tr.rec-sel td{background:var(--sel-bg,rgba(130,115,100,.1))!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.rec-tbl .rec-dots{opacity:0;padding:0 4px;cursor:pointer;font-size:13px;color:var(--muted);background:none;border:none;line-height:1}
.rec-tbl tr:hover .rec-dots,.rec-tbl tr.rec-sel .rec-dots{opacity:1}
.rec-fav{font-size:13px;cursor:pointer;opacity:.35;transition:opacity .12s,transform .12s;line-height:1;background:none;border:none;padding:1px 2px;border-radius:3px}
.rec-fav.active{opacity:1}
.rec-fav:hover{opacity:.7;transform:scale(1.2)}
.rec-diff-pill{font-size:9px;font-weight:700;padding:2px 6px;border-radius:5px;white-space:nowrap}
.rec-diff-easy{background:rgba(34,197,94,.12);color:#166534;border:1px solid rgba(34,197,94,.2)}
.rec-diff-medium{background:rgba(234,179,8,.12);color:#713f12;border:1px solid rgba(234,179,8,.2)}
.rec-diff-hard{background:rgba(239,68,68,.1);color:#991b1b;border:1px solid rgba(239,68,68,.18)}
.rec-meal-pill{font-size:9px;font-weight:600;padding:2px 6px;border-radius:5px;background:rgba(194,107,79,.1);color:var(--accent);border:1px solid rgba(194,107,79,.18);white-space:nowrap}
.rec-time-lbl{font-size:11px;color:var(--muted);white-space:nowrap}
.rec-filter-bar{display:flex;align-items:center;gap:8px;padding:8px 0 10px;flex-wrap:wrap;flex-shrink:0}
.rec-search{flex:0 0 200px;padding:5px 10px;border-radius:20px;border:1px solid rgba(255,220,200,.45);font-family:inherit;font-size:12px;background:rgba(255,255,255,.7);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.rec-search:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(194,107,79,.1);background:rgba(255,255,255,.95)}
body.dark .rec-search{background:rgba(255,255,255,.06);border-color:rgba(255,220,200,.15);color:var(--text)}
.rec-filter-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid rgba(255,220,200,.4);background:rgba(255,255,255,.6);color:var(--muted);transition:all .12s;white-space:nowrap;font-family:inherit}
.rec-filter-chip:hover{background:rgba(255,255,255,.9);color:var(--text)}
.rec-filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
body.dark .rec-filter-chip{background:rgba(255,255,255,.06);border-color:rgba(255,220,200,.12);color:var(--text)}
body.dark .rec-filter-chip.active{background:var(--accent);color:#fff}
.rec-side-panel{position:fixed;top:0;right:0;bottom:0;width:0;background:rgba(255,252,248,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-left:1px solid rgba(255,220,200,.3);box-shadow:-8px 0 32px rgba(0,0,0,.08);z-index:95;overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.rec-side-panel.open{width:400px}
body.dark .rec-side-panel{background:rgba(28,16,10,.97);border-color:rgba(255,220,200,.12);box-shadow:-8px 0 32px rgba(0,0,0,.35)}
.rec-sp-header{padding:14px 16px 10px;border-bottom:1px solid rgba(210,205,228,.2);flex-shrink:0}
.rec-sp-title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.2px;margin-bottom:6px;line-height:1.3;word-break:break-word}
.rec-sp-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.rec-sp-body{flex:1;overflow-y:auto;padding:12px 16px 16px}
.rec-sp-body::-webkit-scrollbar{width:3px}
.rec-sp-section{margin-bottom:14px}
.rec-sp-section-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:5px}
.rec-sp-text{font-size:12px;color:var(--text);line-height:1.6;white-space:pre-wrap;word-break:break-word}
.rec-sp-detail-row{display:flex;gap:14px;flex-wrap:wrap;padding:8px 0;border-bottom:1px solid rgba(210,205,228,.15);margin-bottom:10px}
.rec-sp-detail{display:flex;flex-direction:column;gap:2px;flex:1;min-width:60px}
.rec-sp-detail-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.rec-sp-detail-val{font-size:13px;font-weight:600;color:var(--text)}
.rec-sp-actions{display:flex;gap:6px;padding:10px 16px;border-top:1px solid rgba(210,205,228,.2);flex-shrink:0}
.rec-made-btn{flex:1;padding:6px 10px;border-radius:var(--rs);border:1px solid rgba(34,197,94,.3);background:rgba(34,197,94,.08);color:#166534;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.rec-made-btn:hover{background:rgba(34,197,94,.16)}
body.dark .rec-made-btn{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.25);color:#6ee7b7}
#recFilterPop{background:rgba(255,248,244,0.97);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,0.7);border-radius:10px;padding:10px;box-shadow:0 6px 28px rgba(0,0,0,.13),inset 0 1.5px 0 rgba(255,255,255,1);opacity:0;transform:translateY(-6px) scale(.97);transition:opacity .15s ease,transform .15s ease;pointer-events:none}
#recFilterPop.rfopen{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
body.dark #recFilterPop{background:rgba(40,22,14,.97);border-color:rgba(255,220,200,.15);box-shadow:0 6px 28px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.06)}
body.dark #recCtxMenu{background:rgba(20,18,35,.98);}
/* Recipe ingredient list (modal) */
.rm-ing-wrap{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:rgba(255,255,255,.45);margin-bottom:4px}
body.dark .rm-ing-wrap{background:rgba(255,255,255,.04)}
.rm-ing-row{display:flex;align-items:center;gap:4px;padding:2px 8px;border-bottom:1px solid rgba(210,205,228,.1);transition:background .1s}
.rm-ing-row:last-child{border-bottom:none}
.rm-ing-row:hover{background:rgba(255,255,255,.7)}
body.dark .rm-ing-row:hover{background:rgba(255,255,255,.06)}
.rm-ing-dot{width:5px;height:5px;border-radius:50%;background:rgba(194,107,79,.35);flex-shrink:0}
.rm-ing-amt{width:72px;font-size:11px;padding:3px 5px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--muted);font-family:inherit;outline:none;transition:border-color .12s,background .12s}
.rm-ing-name{flex:1;font-size:12px;padding:3px 5px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text);font-family:inherit;outline:none;transition:border-color .12s,background .12s}
.rm-ing-amt:focus,.rm-ing-name:focus{border-color:rgba(194,107,79,.5);background:rgba(255,255,255,.85)}
body.dark .rm-ing-amt:focus,body.dark .rm-ing-name:focus{background:rgba(255,255,255,.07);border-color:rgba(194,107,79,.4)}
.rm-ing-del{opacity:0;background:none;border:none;cursor:pointer;color:var(--subtle);font-size:10px;padding:2px 5px;border-radius:4px;transition:opacity .1s,color .1s;line-height:1;flex-shrink:0}
.rm-ing-row:hover .rm-ing-del{opacity:1}
.rm-ing-del:hover{color:#ef4444}
.rm-ing-add-btn{background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:5px 10px;font-family:inherit;text-align:left;width:100%;transition:color .12s,background .12s;border-top:1px dashed rgba(210,205,228,.35)}
.rm-ing-add-btn:hover{color:var(--accent);background:rgba(194,107,79,.05)}
/* Recipe side panel — inline editable fields */
.rec-sp-title-inp{font-size:15px;font-weight:700;border:none;border-bottom:1px solid transparent;background:transparent;font-family:inherit;color:var(--text);padding:1px 0;outline:none;width:100%;min-width:0;transition:border-color .12s}
.rec-sp-title-inp:hover{border-bottom-color:rgba(210,205,228,.5)}.rec-sp-title-inp:focus{border-bottom-color:var(--accent)}
.rec-sp-sel{border:none;border-bottom:1px solid transparent;background:transparent;font-family:inherit;font-size:11px;font-weight:600;color:var(--accent);padding:2px 2px 2px 0;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;transition:border-color .12s}
.rec-sp-sel:hover,.rec-sp-sel:focus{border-bottom-color:var(--accent)}
body.dark .rec-sp-sel{background:transparent}
.rec-sp-inp{border:none;border-bottom:1px solid transparent;background:transparent;font-family:inherit;font-size:12px;color:var(--text);padding:2px 0;outline:none;min-width:0;transition:border-color .12s}
.rec-sp-inp:hover{border-bottom-color:rgba(210,205,228,.4)}.rec-sp-inp:focus{border-bottom-color:var(--accent)}
.rec-sp-ta{width:100%;border:1px solid transparent;background:transparent;font-family:inherit;font-size:12px;color:var(--text);padding:3px 0;outline:none;resize:none;line-height:1.6;overflow:hidden;display:block;border-radius:4px;transition:background .12s,border-color .12s}
.rec-sp-ta:focus{border-color:rgba(194,107,79,.35);background:rgba(255,255,255,.6);padding:4px 6px}
body.dark .rec-sp-ta:focus{background:rgba(255,255,255,.06);border-color:rgba(194,107,79,.3)}
/* Birthdays Page */
.bday-section{padding:0 6px 8px}
.bday-section-header{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:10px 4px 5px;display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(210,205,228,.18);margin-bottom:3px}
.bday-tbl{display:grid;grid-template-columns:1fr auto auto auto}
.bday-name-cell{display:flex;align-items:center;gap:4px;min-width:0}
.bday-row{display:grid;grid-column:1/-1;grid-template-columns:subgrid;align-items:center;gap:0 6px;padding:5px 8px;border-radius:8px;transition:background .12s;cursor:pointer;user-select:none}
.bday-row:hover{background:rgba(255,255,255,.72);box-shadow:0 2px 10px rgba(0,0,0,.06)}
.bday-today{background:rgba(255,237,213,.55)}
.bday-today:hover{background:rgba(255,237,213,.8)}
.bday-today .bday-name{color:var(--accent);font-weight:700}
.bday-name{font-size:13px;font-weight:600;color:#777;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.bday-emoji{font-size:15px;line-height:1}
.bday-countdown{font-size:9px;font-weight:700;padding:2px 7px;border-radius:5px;border:1px solid transparent;white-space:nowrap;text-align:center}
.bday-date-lbl{font-size:11px;color:#777;white-space:nowrap;text-align:right}
.bday-age-pill{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;background:rgba(0,0,0,.06);color:#777;border:1px solid rgba(0,0,0,.08);white-space:nowrap;text-align:center}
.bday-gift-btn{background:none;border:none;cursor:pointer;font-size:11px;color:var(--muted);padding:2px 5px;border-radius:6px;transition:all .12s;display:flex;align-items:center;gap:3px;font-family:inherit;line-height:1}
.bday-gift-btn:hover{background:rgba(255,237,213,.7);color:var(--accent)}
.bday-gift-btn.has-gifts{color:var(--accent);font-weight:600}
.bday-del-btn{opacity:0;background:none;border:none;cursor:pointer;font-size:10px;color:var(--subtle);padding:2px 4px;border-radius:4px;transition:opacity .1s,color .1s}
.bday-row:hover .bday-del-btn{opacity:1}
.bday-del-btn:hover{color:#ef4444}
.bday-presents{padding:4px 12px 8px 40px;background:rgba(255,253,250,.5);border-radius:0 0 9px 9px;border-top:1px dashed rgba(210,205,228,.3)}
body.dark .bday-presents{background:rgba(255,255,255,.03)}
.bday-presents.open{display:block!important}
.bday-present-item{display:flex;align-items:center;gap:6px;padding:3px 0;min-height:26px}
.bday-present-dot{width:4px;height:4px;border-radius:50%;background:rgba(249,115,22,.45);flex-shrink:0}
.bday-present-text{flex:1;font-size:12px;color:var(--text)}
.bday-present-del{opacity:0;background:none;border:none;cursor:pointer;color:var(--subtle);font-size:10px;padding:1px 4px;border-radius:3px;transition:opacity .1s;line-height:1;flex-shrink:0}
.bday-present-item:hover .bday-present-del{opacity:1}
.bday-present-del:hover{color:#ef4444}
.bday-add-row{display:flex;gap:5px;align-items:center;padding-top:5px;margin-top:3px;border-top:1px dashed rgba(210,205,228,.2)}
.bday-add-input{flex:1;padding:4px 8px;border-radius:var(--rxs);border:1px solid var(--gb);font-family:inherit;font-size:11px;background:rgba(255,255,255,.7);color:var(--text);outline:none;min-width:0}
.bday-add-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(194,107,79,.1)}
.bday-add-input::placeholder{color:var(--subtle)}
body.dark .bday-add-input{background:rgba(255,255,255,.06);border-color:rgba(255,220,200,.12)}
.bday-row.bday-sel{background:var(--sel-bg,rgba(130,115,100,.1))!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
body.dark .bday-row.bday-sel{background:var(--sel-bg-dark,rgba(194,107,79,.12))!important}
.bday-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(3,1fr);gap:10px;padding:8px;height:100%;width:100%;box-sizing:border-box}
.bday-month-card{border-radius:10px;background:rgba(0,0,0,.025);border:1px solid rgba(210,205,228,.2);padding:8px 6px;overflow-y:auto}
body.dark .bday-month-card{background:rgba(255,255,255,.03);border-color:rgba(255,220,200,.1)}
.bday-month-current{box-shadow:0 0 0 1px rgba(194,107,79,.3),0 0 28px 6px rgba(194,107,79,.28),0 4px 20px rgba(194,107,79,.18);background:rgba(255,255,255,.92)!important;border-color:rgba(194,107,79,.18)!important}
body.dark .bday-month-current{box-shadow:0 0 0 1px rgba(194,107,79,.4),0 0 28px 6px rgba(194,107,79,.35),0 4px 20px rgba(194,107,79,.22);background:rgba(60,30,18,.85)!important}
.bday-month-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:2px 4px 5px;margin-bottom:3px;border-bottom:1px solid rgba(210,205,228,.18)}
.bday-month-current .bday-month-name{color:#444;letter-spacing:.09em}
.bday-month-current .bday-name{color:#222;font-weight:700}
.bday-month-current .bday-date-lbl{color:#555}
.bday-month-current .bday-age-pill{background:rgba(194,107,79,.12);color:var(--accent);border-color:rgba(194,107,79,.25)}
.bday-month-current .bday-past .bday-name{color:#999;font-weight:600}
.bday-month-current .bday-past .bday-date-lbl{color:#999}
.bday-month-current .bday-past .bday-age-pill{background:rgba(0,0,0,.04);color:#999;border-color:rgba(0,0,0,.07)}
body.dark .bday-month-current .bday-month-name{color:#ddd}
body.dark .bday-month-current .bday-name{color:#f0e8e0;font-weight:700}
body.dark .bday-month-current .bday-date-lbl{color:rgba(255,220,200,.65)}
body.dark .bday-month-current .bday-past .bday-name{color:rgba(255,200,170,.45)}
body.dark .bday-month-current .bday-past .bday-date-lbl{color:rgba(255,200,170,.35)}
.bday-add-menu{position:fixed;z-index:9999;background:rgba(255,255,255,.98);border:1px solid rgba(210,205,228,.35);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.13);padding:6px;min-width:200px;backdrop-filter:blur(14px)}
body.dark .bday-add-menu{background:rgba(38,20,10,.97);border-color:rgba(255,220,180,.15)}
.bday-add-menu-item{padding:7px 12px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text);transition:background .1s}
.bday-add-menu-item:hover{background:rgba(194,107,79,.1)}
.bday-add-menu-fmt{padding:8px 12px 6px;border-top:1px solid rgba(210,205,228,.2);margin-top:4px}
.bday-add-menu-fmt-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:5px}
.bday-add-menu-fmt-row{font-size:11px;color:var(--muted);padding:1px 0;display:flex;gap:8px}
.bday-add-menu-fmt-eg{font-family:monospace;color:var(--subtle);font-size:10px}
.bday-month-empty{height:8px}
.bday-month-card .bday-main{padding:4px 6px}
.bday-month-card .bday-name{font-size:12px}
.bday-month-card .bday-date-lbl{font-size:10px}
.cat-sel-wrap{position:relative;user-select:none}
.cat-sel-trigger{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:var(--rs);border:1px solid;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;transition:filter .12s}
.cat-sel-trigger:hover{filter:brightness(.96)}
.cat-sel-drop{position:absolute;top:calc(100% + 3px);left:0;right:0;background:rgba(255,252,248,.98);border:1px solid var(--border);border-radius:var(--rs);box-shadow:0 4px 14px rgba(0,0,0,.1);z-index:9999;display:none;padding:3px}
.cat-sel-drop.open{display:block}
.cat-sel-opt{padding:6px 10px;cursor:pointer;font-size:12px;font-weight:600;border-radius:6px;margin-bottom:2px}
.cat-sel-opt:last-child{margin-bottom:0}
@keyframes donut-glow{0%,100%{filter:drop-shadow(0 0 2px rgba(34,197,94,.3))}50%{filter:drop-shadow(0 0 7px rgba(34,197,94,.65))}}
.donut-glow{animation:donut-glow 3s ease-in-out infinite}
.cat-sel-opt:hover{filter:brightness(.95)}
/* Anti-FOUC: applied before first paint via html classes set in head script */
html.init-dark body{background:#1a100a!important;background-attachment:fixed!important;}
html.init-sb #main{left:186px!important;}
html.init-sb .ov-topbar{left:186px!important;}
