*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f6fa;--surface:#fff;--card:#fff;--border:#e8eaed;--border-2:#d1d5db;--text:#111827;--text-2:#374151;--text-muted:#6b7280;--text-light:#9ca3af;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000001a, 0 2px 4px #0000000f;--shadow-lg:0 12px 28px #00000024, 0 4px 8px #00000014;--r:14px;--r-sm:8px;--r-lg:20px;color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}body{background:var(--bg);min-height:100vh}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,textarea{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:99px}.app{height:100dvh;display:flex;overflow:hidden}.sidebar{background:#0f172a;flex-direction:column;gap:12px;width:200px;min-width:200px;padding:16px;transition:width .25s,min-width .25s,padding .25s;display:flex;overflow:hidden}.sidebar.collapsed{width:60px;min-width:60px;padding:16px 10px}.btn-serenity{color:#93c5fdd9;cursor:pointer;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;background:#60a5fa26;border:1px solid #60a5fa40;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:100%;height:30px;font-size:10px;font-weight:800;transition:background .15s,color .15s,border-color .15s;display:flex;overflow:hidden}.btn-serenity:hover{color:#bfdbfe;background:#60a5fa47;border-color:#60a5fa80}.btn-serenity.active{color:#93c5fd;background:#60a5fa4d;border-color:#60a5fa99}.sidebar-toggle{color:#ffffff8c;cursor:pointer;background:#ffffff14;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:100%;height:28px;transition:background .15s,color .15s;display:flex}.sidebar-toggle:hover{color:#ffffffe6;background:#ffffff29}.claude-chat-panel{background:var(--card);border-left:1px solid var(--border);z-index:200;flex-direction:column;width:360px;height:100vh;display:flex;position:fixed;top:0;right:0;box-shadow:-4px 0 24px #0000001f}.claude-chat-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.claude-chat-header-left{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.chat-header-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background .15s;display:flex}.chat-header-btn:hover{background:var(--hover);color:var(--text)}.chat-key-setup{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:24px;display:flex}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-empty{color:var(--text-light);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;font-size:13px;display:flex}.chat-msg{display:flex}.chat-msg-user{justify-content:flex-end}.chat-msg-assistant{justify-content:flex-start}.chat-msg-bubble{white-space:pre-wrap;word-break:break-word;border-radius:14px;max-width:85%;padding:9px 13px;font-size:13px;line-height:1.55}.chat-msg-user .chat-msg-bubble{color:#fff;background:#334155;border-bottom-right-radius:4px}.chat-msg-assistant .chat-msg-bubble{background:var(--hover);color:var(--text);border-bottom-left-radius:4px}.chat-typing{align-items:center;gap:5px;padding:12px 14px;display:flex}.chat-typing span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:.9s infinite chat-bounce}.chat-typing span:nth-child(2){animation-delay:.15s}.chat-typing span:nth-child(3){animation-delay:.3s}@keyframes chat-bounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.chat-input-row{border-top:1px solid var(--border);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 16px;display:flex}.chat-input{border:1.5px solid var(--border);background:var(--bg);color:var(--text);resize:none;border-radius:12px;outline:none;flex:1;max-height:120px;padding:9px 12px;font-family:inherit;font-size:13px;line-height:1.5;transition:border-color .15s;overflow-y:auto}.chat-input:focus{border-color:#94a3b8}.chat-send-btn{color:#fff;cursor:pointer;background:#334155;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:background .15s,opacity .15s;display:flex}.chat-send-btn:hover{background:#1e293b}.chat-send-btn:disabled{opacity:.4;cursor:default}.launcher-btn-claude.active{background:#e2e8f0;border-color:#94a3b8}.serenity-panel{flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.serenity-exit-btn{-webkit-backdrop-filter:none;cursor:pointer;white-space:nowrap;z-index:10;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.serenity-exit-btn:hover{opacity:.75}.serenity-logo-img{mix-blend-mode:screen;width:160px;height:auto;display:block}.serenity-logo-fallback{color:#fff;letter-spacing:.22em;text-transform:uppercase;text-shadow:0 2px 16px #00000080;font-size:20px;font-weight:300;display:none}.serenity-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.nav-card{cursor:pointer;color:#fff;-webkit-user-select:none;user-select:none;background-position:50%;background-repeat:no-repeat;background-size:cover;border:2.5px solid #0000;border-radius:20px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s,border-color .15s;display:flex;position:relative;overflow:hidden}.nav-card:after{content:"";border-radius:inherit;z-index:0;background:#0000006b;transition:background .2s;position:absolute;inset:0}.nav-card:hover:after{background:#00000047}.nav-card:hover{transform:scale(1.025)}.nav-card.active{border-color:#ffffffb3;transform:scale(1.025);box-shadow:0 8px 32px #00000080,inset 0 1px #ffffff26}.nav-card.active:after{background:#00000038}.nav-card:not(.nav-card-secondary){max-height:calc(33.3333dvh - 100.667px)}.nav-card-secondary{border-radius:14px;flex:0 0 72px;gap:8px;margin-bottom:20px}.nav-card-secondary .nav-card-icon{width:28px;height:28px}.nav-card-secondary .nav-card-icon svg{width:16px;height:16px}.nav-card-secondary .nav-card-label{font-size:10px}.nav-card-icon{z-index:1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fff3;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.nav-card-icon svg{width:22px;height:22px}.nav-card-label{letter-spacing:.06em;text-transform:uppercase;text-align:center;z-index:1;text-shadow:0 1px 4px #00000080;padding:0 8px;font-size:12px;font-weight:800;line-height:1.3;position:relative}.workshop-layout{flex:1;gap:0;min-height:0;display:flex;overflow:hidden}.workshop-sidebar{background:#131c2e;flex-direction:column;flex-shrink:0;gap:10px;width:160px;min-width:160px;padding:16px 12px;transition:width .25s,min-width .25s,padding .25s;display:flex}.workshop-sidebar.collapsed{width:54px;min-width:54px;padding:16px 8px}.workshop-sidebar-toggle{height:24px}.workshop-sidebar-toggle svg{pointer-events:none}.workshop-tab{cursor:pointer;background-position:50%;background-size:cover;border:2px solid #0000;border-radius:16px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:0;transition:transform .18s,border-color .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.workshop-tab:after{content:"";border-radius:inherit;z-index:0;background:#00000073;transition:background .18s;position:absolute;inset:0}.workshop-tab:hover:after{background:#0000004d}.workshop-tab:hover{transform:scale(1.03)}.workshop-tab.active{border-color:#ffffffb3;transform:scale(1.03);box-shadow:0 6px 24px #00000073,inset 0 1px #ffffff26}.workshop-tab.active:after{background:#00000038}.workshop-tab-icon{z-index:1;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:relative}.workshop-tab-icon svg{width:18px;height:18px}.workshop-tab-label{letter-spacing:.05em;text-transform:uppercase;text-align:center;z-index:1;color:#fff;text-shadow:0 1px 4px #00000080;padding:0 6px;font-size:10px;font-weight:800;line-height:1.3;position:relative}.workshop-content{flex-direction:column;flex:1;gap:24px;padding:32px 40px;display:flex;overflow-y:auto}.main-panel{flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.launcher-bar{z-index:201;flex-shrink:0;justify-content:flex-end;gap:8px;padding:10px 20px 0;display:flex;position:relative}.launcher-btn{cursor:pointer;-webkit-user-select:none;user-select:none;border:1.5px solid #0000;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;text-decoration:none;transition:background .15s,color .15s,border-color .15s,transform .12s;display:inline-flex}.launcher-btn:hover{transform:translateY(-2px)}.launcher-btn-claude{color:#334155;background:#f1f5f9;border-color:#cbd5e1}.launcher-btn-claude:hover{background:#e2e8f0;border-color:#94a3b8}.launcher-btn-terminal{color:#166534;background:#f0fdf4;border-color:#86efac}.launcher-btn-terminal:hover{background:#dcfce7;border-color:#4ade80}.launcher-btn-review{color:#0369a1;background:#f0f9ff;border-color:#bae6fd}.launcher-btn-review:hover{background:#e0f2fe;border-color:#7dd3fc}.launcher-btn-review.active,.launcher-btn-review:disabled{opacity:.6;cursor:wait}.today-banner{border-bottom:1px solid var(--border);flex-shrink:0;gap:12px;padding:14px 22px;display:flex}.banner-card{border-radius:var(--r);background-position:50%;background-repeat:no-repeat;background-size:cover;flex:1;align-items:center;gap:12px;min-width:0;padding:14px 18px;display:flex;position:relative;overflow:hidden}.banner-card:after{content:"";border-radius:inherit;background:0 0;transition:background .2s;position:absolute;inset:0}.banner-card:hover:after{background:0 0}.banner-today{border-left:4px solid #64748b}.banner-tomorrow{border-left:4px solid #3b82f6}.banner-card>*{z-index:1;position:relative}.banner-icon{border-radius:var(--r-sm);color:#fff;text-shadow:0 1px 4px #0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000040;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.banner-today .banner-icon{color:#fff;background:#6366f18c}.banner-tomorrow .banner-icon{color:#fff;background:#2563eb8c}.banner-body{flex:1;min-width:0}.banner-label{text-transform:uppercase;letter-spacing:.12em;margin-bottom:3px;font-size:10px;font-weight:800}.banner-today .banner-label,.banner-tomorrow .banner-label{color:#fff;text-shadow:0 1px 4px #00000080}.banner-note{color:#fff;text-shadow:0 1px 6px #0009;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.banner-todo-badge{color:#475569;white-space:nowrap;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:99px;flex-shrink:0;align-items:center;gap:5px;padding:4px 11px;font-size:11px;font-weight:800;transition:all .15s;display:flex}.banner-todo-badge.badge-done{color:#16a34a;background:#dcfce7;border-color:#86efac}.banner-check{cursor:pointer;z-index:1;background:0 0;border:2.5px solid #00000038;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:all .15s;display:flex;position:relative}.banner-check:hover{background:#64748b14;border-color:#64748b}.banner-check.checked{background:#64748b;border-color:#64748b}.banner-card.banner-done:after{background:#ffffff26}.banner-card.banner-done .banner-note{color:var(--text-muted);text-decoration:line-through}.banner-card.banner-done .banner-label{opacity:.6}.banner-card.banner-done .banner-icon{opacity:.5}.section{flex-direction:column;flex:1;gap:28px;min-height:0;padding:36px 40px;animation:.2s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.section-title{letter-spacing:1px;text-transform:uppercase;color:var(--text);font-size:32px;font-weight:900;line-height:1.1}.section-title span{border-radius:99px;width:48px;height:4px;margin-top:8px;display:block}.card{background:var(--surface);border-radius:var(--r);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.input{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent,#64748b);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,#64748b) 15%, transparent)}.input::placeholder{color:var(--text-light)}textarea.input{resize:vertical;line-height:1.55}.btn{border-radius:var(--r-sm);white-space:nowrap;padding:10px 20px;font-size:14px;font-weight:700;transition:all .15s}.btn-accent{background:var(--accent,#64748b);color:#fff;box-shadow:0 2px 8px color-mix(in srgb, var(--accent,#64748b) 40%, transparent)}.btn-accent:hover{filter:brightness(1.08);box-shadow:0 4px 14px color-mix(in srgb, var(--accent,#64748b) 45%, transparent)}.btn-accent:active{transform:scale(.97)}.btn-ghost{color:var(--text-muted);border-radius:var(--r-sm);padding:6px 10px}.btn-ghost:hover{background:var(--bg);color:var(--text)}.cashflow{--accent:#10b981}.cf-header-strip{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.cf-header-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:16px 18px}.cf-header-card.projected{border-color:#6ee7b7}.cf-header-card.worst{border-color:#fca5a5}.cf-header-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:700}.cf-header-amount{color:var(--text);letter-spacing:-.02em;font-size:28px;font-weight:800;line-height:1}.cf-header-amount.negative{color:#ef4444}.cf-header-sub{color:var(--text-muted);margin-top:5px;font-size:11px}.cf-columns{grid-template-columns:1fr 1fr;align-items:flex-start;gap:16px;display:grid}.cf-col{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);flex-direction:column;gap:12px;padding:16px;display:flex}.cf-col-title{text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;font-size:12px;font-weight:800;display:flex}.cf-inline-form{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 10px;display:flex}.cf-input{border:1.5px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;outline:none;flex:1;min-width:90px;padding:5px 8px;font-family:inherit;font-size:12px}.cf-input:focus{border-color:#10b981}.cf-input-amount{max-width:100px}.cf-select{flex:0 120px;min-width:90px}.cf-rec-toggle{color:var(--text-muted);cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;font-size:12px;display:flex}.cf-prob-btns{flex-shrink:0;gap:3px;display:flex}.cf-prob-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:5px;padding:3px 7px;font-size:11px;font-weight:700;transition:all .12s}.cf-prob-btn:hover{color:#10b981;border-color:#10b981}.cf-add-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#10b981;border:none;border-radius:6px;flex-shrink:0;padding:5px 12px;font-size:12px;font-weight:700}.cf-add-btn:hover{background:#059669}.cf-list{flex-direction:column;gap:6px;display:flex}.cf-empty{color:var(--text-muted);padding:8px 0;font-size:12px;font-style:italic}.cf-entry{background:var(--bg);border-left:3px solid #0000;border-radius:7px;grid-template-rows:auto auto;grid-template-columns:1fr auto;gap:2px 8px;padding:8px 38px 8px 10px;display:grid;position:relative}.cf-entry-main{grid-column:1;align-items:center;gap:8px;display:flex}.cf-entry-meta{flex-wrap:wrap;grid-column:1;align-items:center;gap:6px;display:flex}.cf-entry-desc{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.cf-entry-amount{white-space:nowrap;font-size:13px;font-weight:700}.cf-entry-amount.income{color:#16a34a}.cf-entry-amount.expense{color:#dc2626}.cf-entry-date{color:var(--text-muted);font-size:11px}.cf-prob-badge{color:#fff;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.cf-cat-badge{color:#92400e;background:#fef3c7;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.cf-rec-badge{color:#1e293b;background:#f1f5f9;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.cf-plan-badge{color:#b45309;background:#fef3c7;border-radius:999px;padding:1px 6px;font-size:10px;font-weight:700}.cf-chart-card{padding:16px 18px}.cf-overdue{border-left-width:4px!important}.cf-overdue-badge{text-transform:uppercase;letter-spacing:.06em;color:#fff;background:#f97316;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700}.cf-reconciled{opacity:.65}.cf-reconciled-badge{text-transform:uppercase;letter-spacing:.06em;color:#059669;background:#d1fae5;border-radius:4px;padding:2px 5px;font-size:9px;font-weight:700}.cf-history-toggle{color:var(--text-muted);cursor:pointer;text-align:left;opacity:.7;background:0 0;border:none;width:100%;padding:6px 0 2px;font-size:11px}.cf-history-toggle:hover{opacity:1}.cf-history-list{opacity:.8}.cf-stale-banner{color:#92400e;cursor:pointer;background:#fef3c7;border-radius:4px;margin-top:6px;padding:3px 7px;font-size:10px;display:inline-block}.cf-stale-banner:hover{background:#fde68a}.cf-30day-panel{background:var(--card);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:10px;padding:14px 20px;display:flex}.cf-30day-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:800}.cf-30day-row{align-items:center;display:flex}.cf-30day-item{flex-direction:column;flex:1;gap:2px;display:flex}.cf-30day-item-label{color:var(--text-muted);font-size:11px}.cf-30day-item-value{font-size:22px;font-weight:800}.cf-30day-item-value.income{color:#16a34a}.cf-30day-item-value.expense{color:#dc2626}.cf-30day-item-value.net{color:#10b981}.cf-30day-item-value.net.negative{color:#ef4444}.cf-30day-divider{background:var(--border);flex-shrink:0;width:1px;height:40px;margin:0 20px}.cf-transactions-details{border-radius:var(--r);padding:0}.cf-transactions-summary{cursor:pointer;color:var(--text-muted);padding:14px 18px;font-size:13px;font-weight:700;list-style:none}.cf-transactions-summary::-webkit-details-marker{display:none}.cf-transactions-summary:before{content:"▸ ";font-size:10px}details[open] .cf-transactions-summary:before{content:"▾ "}@media (width<=768px){.cf-header-strip,.cf-columns{grid-template-columns:1fr}.cf-header-amount{font-size:22px}}.balance-card{border-radius:var(--r-lg);color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);padding:28px 32px;box-shadow:0 8px 24px #10b98159}.balance-label{letter-spacing:.1em;text-transform:uppercase;opacity:.8;margin-bottom:6px;font-size:12px;font-weight:700}.balance-amount{letter-spacing:-2px;margin-bottom:20px;font-size:52px;font-weight:900;line-height:1}.balance-amount.negative{color:#fca5a5}.balance-stats{gap:32px;display:flex}.balance-stat{flex-direction:column;gap:3px;display:flex}.balance-stat-label{opacity:.7;text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:600}.balance-stat-value{letter-spacing:-.5px;font-size:18px;font-weight:800}.add-transaction-form{flex-wrap:wrap;align-items:center;gap:10px;padding:20px;display:flex}.add-transaction-form .input-desc{flex:2;min-width:160px}.add-transaction-form .input-amount{flex:1;min-width:100px;max-width:140px}.type-toggle{border-radius:var(--r-sm);border:1.5px solid var(--border);flex-shrink:0;display:flex;overflow:hidden}.type-toggle-btn{color:var(--text-muted);border:none;padding:9px 14px;font-size:13px;font-weight:700;transition:all .15s}.type-toggle-btn.income.active{color:#16a34a;background:#dcfce7}.type-toggle-btn.expense.active{color:#dc2626;background:#fee2e2}.category-select{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;outline:none;flex-shrink:0;padding:10px 14px;font-size:14px;font-weight:500;transition:border-color .15s}.category-select:focus{border-color:var(--accent)}.transactions-list{flex-direction:column;display:flex;overflow:hidden}.transactions-list-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);padding:14px 20px;font-size:12px;font-weight:700}.transaction-item{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:14px 20px;transition:background .12s;display:flex}.transaction-item:last-child{border-bottom:none}.transaction-item:hover{background:var(--bg)}.transaction-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.transaction-desc{flex:1;font-size:14px;font-weight:600}.transaction-category{text-transform:uppercase;letter-spacing:.05em;border-radius:99px;flex-shrink:0;padding:3px 9px;font-size:11px;font-weight:700}.transaction-category.income{color:#16a34a;background:#dcfce7}.transaction-category.expense{color:#dc2626;background:#fee2e2}.transaction-date{color:var(--text-muted);flex-shrink:0;font-size:12px}.transaction-amount{letter-spacing:-.3px;text-align:right;flex-shrink:0;min-width:90px;font-size:16px;font-weight:800}.transaction-amount.income{color:#16a34a}.transaction-amount.expense{color:#dc2626}.btn-delete{border-radius:var(--r-sm);width:28px;height:28px;color:var(--text-light);opacity:0;flex-shrink:0;justify-content:center;align-items:center;transition:all .12s;display:flex}.transaction-item:hover .btn-delete,.todo-item:hover .btn-delete{opacity:1}.cf-entry .btn-delete{opacity:.5}.cf-entry:hover .btn-delete{opacity:1}.btn-delete:hover{color:#dc2626;background:#fee2e2}.empty-list{text-align:center;color:var(--text-light);padding:40px;font-size:14px;font-style:italic}.todo{--accent:#64748b}.todo-add-form{gap:10px;padding:20px;display:flex}.todo-add-form .input{flex:1}.todo-items{flex-direction:column;display:flex}.todo-item{border-bottom:1px solid var(--border);transition:background .12s}.todo-item:last-child{border-bottom:none}.todo-item-row{grid-template-columns:24px 1fr 90px 80px 180px auto;align-items:center;gap:0 10px;padding:14px 20px;transition:background .12s;display:grid}.todo-item-row:hover{background:var(--bg)}.check-wrap{flex-shrink:0;justify-content:center;align-items:center;display:flex}.custom-check{border:2.5px solid var(--border-2);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.custom-check:hover{border-color:var(--accent,#87a878)}.custom-check.checked{background:var(--accent,#64748b);border-color:var(--accent,#64748b)}.custom-check svg{display:none}.custom-check.checked svg{display:block}.subtask-check{border-width:2px;border-radius:4px;width:18px;height:18px}.subtask-check.checked{background:#94a3b8;border-color:#94a3b8}.todo-title{cursor:default;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:15px;font-weight:600;transition:color .15s,opacity .15s;overflow:hidden}.todo-title.done{color:var(--text-light);opacity:.7;text-decoration:line-through}.todo-meta{align-items:center;gap:8px;display:flex}.subtask-badge{color:var(--text-light);background:var(--bg);border:1px solid var(--border);white-space:nowrap;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:700}.subtask-badge.has-progress{color:var(--accent,#64748b);border-color:color-mix(in srgb, var(--accent,#64748b) 30%, transparent);background:color-mix(in srgb, var(--accent,#64748b) 8%, transparent)}.btn-expand{border-radius:var(--r-sm);width:28px;height:28px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-expand:hover{background:var(--bg);color:var(--text)}.btn-expand svg{transition:transform .2s}.btn-expand.open svg{transform:rotate(180deg)}.subtasks-panel{flex-direction:column;gap:6px;padding:0 20px 14px 54px;animation:.18s expandDown;display:flex}@keyframes expandDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.subtask-item{border-radius:var(--r-sm);align-items:center;gap:10px;padding:6px 10px;transition:background .12s;display:flex}.subtask-item:hover{background:var(--bg)}.subtask-item:hover .btn-delete{opacity:1}.subtask-title{color:var(--text-2);flex:1;font-size:13.5px}.subtask-title.done{color:var(--text-light);text-decoration:line-through}.inline-edit-input{color:var(--text);background:0 0;border:none;border-bottom:2px solid #64748b;border-radius:0;outline:none;flex:1;min-width:0;padding:0 2px 2px;font-size:15px;font-weight:600}.inline-edit-input.sub{font-size:13.5px}.todo-title{cursor:default}.todo-title:not(.done):hover{color:#334155}.todo-title.supplier-linked-title{cursor:pointer}.todo-title.supplier-linked-title:not(.done){text-underline-offset:3px;-webkit-text-decoration:underline dotted #6366f166;text-decoration:underline dotted #6366f166}.todo-title.supplier-linked-title:not(.done):hover{color:#64748b;text-decoration-color:#64748b}.subtask-title:not(.done):hover{color:#475569}.add-subtask-row{gap:8px;margin-top:4px;display:flex}.priority-picker{flex-shrink:0;gap:5px;display:flex}.priority-btn{opacity:.45;border:2px solid #0000;border-radius:99px;padding:6px 11px;font-size:12px;font-weight:700;transition:all .15s}.priority-btn.active{opacity:1}.priority-btn:hover{opacity:.8}.priority-badge{letter-spacing:.04em;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1.5px solid #0000;border-radius:99px;flex-shrink:0;padding:3px 9px;font-size:11px;font-weight:800;transition:filter .15s,transform .1s}.priority-badge:hover{filter:brightness(.92);transform:scale(1.04)}.filter-toggles{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.filter-toggle-label{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.add-subtask-row .input{flex:1;padding:7px 11px;font-size:13px}.btn-sm{border-radius:var(--r-sm);padding:7px 14px;font-size:13px;font-weight:700}.calendar{--accent:#f97316}.calendar-nav{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.calendar-month-label{letter-spacing:-.5px;font-size:26px;font-weight:800}.calendar-nav-btn{border-radius:var(--r-sm);width:47px;height:47px;color:var(--text-muted);justify-content:center;align-items:center;font-size:18px;transition:background .12s,color .12s;display:flex}.calendar-nav-btn:hover{background:var(--bg);color:var(--text)}.calendar-grid{padding:16px 18px}.calendar-day-headers{grid-template-columns:repeat(7,1fr);margin-bottom:8px;display:grid}.calendar-day-header{text-align:center;color:var(--text-muted);letter-spacing:.07em;text-transform:uppercase;padding:6px 0;font-size:11px;font-weight:800}.calendar-cells{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.calendar-cell{aspect-ratio:1;border-radius:var(--r-sm);cursor:pointer;flex-direction:column;justify-content:flex-start;align-items:center;gap:0;padding-top:3px;transition:background .12s;display:flex;position:relative;overflow:hidden}.calendar-cell.empty{cursor:default;pointer-events:none}.calendar-cell:not(.empty):hover{background:var(--bg)}.calendar-cell:not(.empty):not(.has-note):hover:before{content:"+";color:var(--text-muted);opacity:.45;pointer-events:none;font-size:14px;font-weight:300;line-height:1;position:absolute;bottom:4px;right:5px}.cell-events{flex-direction:column;gap:1px;width:100%;padding:1px 3px 0;display:flex;overflow:hidden}.cell-event-text{text-overflow:ellipsis;white-space:nowrap;border-left:2px solid;border-radius:1px;padding-left:3px;font-size:9px;font-weight:600;line-height:1.3;overflow:hidden}.cell-event-more{color:var(--text-muted);text-align:right;padding-right:2px;font-size:8px;line-height:1.2}.calendar-cell.today .day-num{background:var(--accent,#f97316);color:#fff;box-shadow:0 2px 8px color-mix(in srgb, var(--accent,#f97316) 45%, transparent)}.calendar-cell.has-note .day-num{color:var(--accent,#f97316);font-weight:800}.day-num{width:42px;height:42px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:600;transition:background .12s;display:flex}.day-dot{background:var(--accent,#f97316);border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.calendar-cell.other-month .day-num{color:var(--text-light)}.note-overlay{z-index:100;background:#0f172a99;justify-content:center;align-items:center;padding:20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.note-modal{background:var(--card);border-radius:var(--r-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);opacity:1;animation:.18s cubic-bezier(.34,1.56,.64,1) popIn;overflow:hidden}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}.note-modal-header{justify-content:space-between;align-items:center;gap:12px;padding:22px 22px 0;display:flex}.note-modal-title{letter-spacing:-.3px;font-size:17px;font-weight:800}.note-modal-body{padding:18px 22px}.note-modal-body textarea{border:1.5px solid var(--border);border-radius:var(--r-sm);resize:none;outline:none;width:100%;min-height:110px;padding:12px 14px;font-size:14px;line-height:1.6;transition:border-color .15s}.note-modal-body textarea:focus{border-color:var(--accent,#f97316)}.note-modal-footer{justify-content:space-between;align-items:center;gap:10px;padding:0 22px 22px;display:flex}.note-modal-footer-right{gap:8px;display:flex}.btn-delete-note{border-radius:var(--r-sm);color:#dc2626;border:1.5px solid #fca5a5;padding:9px 15px;font-size:13px;font-weight:700;transition:background .12s}.btn-delete-note:hover{background:#fee2e2}.btn-cancel{border:1.5px solid var(--border);border-radius:var(--r-sm);color:var(--text-muted);padding:9px 15px;font-size:13px;font-weight:600;transition:background .12s}.btn-cancel:hover{background:var(--bg)}.btn-save{background:var(--accent,#f97316);color:#fff;border-radius:var(--r-sm);box-shadow:0 2px 8px color-mix(in srgb, var(--accent,#f97316) 40%, transparent);padding:9px 18px;font-size:13px;font-weight:700;transition:filter .12s}.btn-save:hover{filter:brightness(1.07)}.flex-1{flex:1}.mt-auto{margin-top:auto}.day-dot.from-todo,.day-dot.to-todo{background:#64748b}.sync-hint{border-radius:var(--r-sm);align-items:center;gap:7px;margin-top:10px;padding:9px 12px;font-size:12.5px;font-weight:700;display:flex}.hint-todo{color:#475569;background:#f1f5f9}.hint-star{color:#16a34a;background:#f0fdf4}.modal-sync-row{margin-top:10px}.btn-add-todo{border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;align-items:center;gap:7px;padding:8px 14px;font-size:12.5px;font-weight:700;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn-add-todo:hover,.btn-add-todo.active{color:#16a34a;background:#f0fdf4;border-color:#86efac}.supplier-grid{box-sizing:border-box;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:12px 24px;width:100%;display:grid}.misc-grid{grid-template-columns:repeat(2,320px);gap:12px;display:grid}.supplier-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;flex-direction:column;justify-content:center;min-height:90px;padding:21px 18px;transition:border-color .15s,box-shadow .15s;display:flex}.supplier-card:hover{border-color:#a5b4fc}.supplier-card.expanded{border-color:#818cf8;grid-column:1/-1;max-height:82vh;overflow-y:auto;box-shadow:0 0 0 3px #6366f114}.supplier-card.focused{border-color:#64748b;animation:.6s supplier-pulse;box-shadow:0 0 0 4px #64748b2e}@keyframes supplier-pulse{0%{box-shadow:0 0 #6366f166}70%{box-shadow:0 0 0 10px #6366f100}to{box-shadow:0 0 0 4px #64748b2e}}.supplier-card-header{grid-template-columns:130px minmax(0,1fr) 88px minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.supplier-card-name{align-items:center;min-width:0;display:flex;overflow:hidden}.supplier-meta-url,.supplier-meta-phone,.supplier-meta-email{min-width:0;overflow:hidden}.supplier-meta-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.supplier-logo-wrap{cursor:default;align-items:center;display:inline-flex;position:relative}.supplier-logo-img{object-fit:contain;object-position:left center;width:auto;max-width:140px;max-height:44px;display:block}.supplier-logo-text{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.supplier-logo-edit-row{align-items:center;gap:5px;margin-top:6px;display:flex}.supplier-logo-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1e293b;border:none;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:700;transition:background .15s;display:inline-flex}.supplier-logo-btn:hover{background:#334155}.supplier-logo-btn-clear{color:#991b1b;background:#fee2e2;padding:4px 5px}.supplier-logo-btn-clear:hover{background:#fecaca}.supplier-pill{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;border-radius:99px;max-width:100%;padding:2px 8px;font-size:11px;display:block;overflow:hidden}.supplier-details{border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:8px 20px;margin-top:14px;padding-top:14px;display:grid}.supplier-field{flex-direction:column;gap:2px;display:flex}.supplier-field-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:10px;font-weight:700}.supplier-field-value{color:var(--text);word-break:break-word;font-size:13px}.supplier-form-card{padding:20px}.supplier-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.supplier-form-field{color:var(--text-muted);flex-direction:column;gap:5px;font-size:12px;font-weight:600;display:flex}.supplier-form-field.full{grid-column:1/-1}.supplier-notes-input{resize:none;min-height:64px;font-family:inherit;overflow:hidden}.order-list{border-top:1.5px dashed var(--border);margin-top:16px;padding-top:14px}.order-list-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.order-list-title{letter-spacing:.08em;color:var(--text-muted);font-size:10px;font-weight:800}.order-add-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;padding:3px 9px;font-size:11px;font-weight:700;transition:background .15s}.order-add-btn:hover{background:#e2e8f0}.order-table{border-collapse:collapse;width:100%;font-size:12.5px}.order-table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding:0 8px 6px;font-size:10px;font-weight:700}.order-table th:first-child{padding-left:0}.order-table th:last-child{width:28px}.order-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:5px 8px}.order-table td:first-child{padding-left:0}.order-table tr:last-child td{border-bottom:none}.order-cell-product{width:40%}.order-cell-qty{width:12%}.order-cell-price{width:15%}.order-cell-del{text-align:right;width:28px}.order-cell-text{cursor:pointer;border-radius:4px;min-width:40px;padding:3px 5px;transition:background .12s;display:inline-block}.order-cell-text:hover{background:var(--bg)}.order-cell-placeholder{color:var(--text-muted);font-style:italic}.order-cell-input{background:var(--surface);width:100%;color:var(--text);border:1.5px solid #818cf8;border-radius:5px;outline:none;padding:3px 6px;font-family:inherit;font-size:12.5px}.shipping-wrap{display:flex}.shipping-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;border:none;border-radius:99px;padding:3px 22px 3px 9px;font-family:inherit;font-size:11px;font-weight:700;transition:opacity .15s}.shipping-select:hover{opacity:.85}.shipping-select:focus{outline-offset:1px;outline:2px solid #818cf8}.order-subtotal{text-align:right;color:var(--text-muted);border-top:1px solid var(--border);margin-top:8px;padding-top:6px;font-size:12px}.order-subtotal strong{color:var(--text)}.order-empty{color:var(--text-muted);padding:6px 0;font-size:12px;font-style:italic}.paste-autofill-banner{color:#16a34a;border-radius:var(--r-sm);background:#f0fdf4;border:1px solid #86efac;margin-top:6px;padding:7px 12px;font-size:12px;font-weight:600;animation:.2s fadeIn}.supplier-fetch-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:700;transition:background .15s}.supplier-fetch-btn:hover{background:#e2e8f0}.supplier-form-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.supplier-form-actions.full{grid-column:1/-1}.supplier-search-dropdown{background:var(--surface);border-radius:var(--r);z-index:100;border:1.5px solid #818cf8;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.supplier-search-hint{color:var(--text-muted);align-items:center;gap:8px;padding:10px 14px;font-size:12.5px;font-style:italic;display:flex}.supplier-search-spinner{border:2px solid var(--border);border-top-color:#64748b;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.supplier-suggestion{text-align:left;border-bottom:1px solid var(--border);background:var(--surface);cursor:pointer;flex-direction:column;gap:2px;width:100%;padding:10px 14px;transition:background .12s;display:flex}.supplier-suggestion:last-child{border-bottom:none}.supplier-suggestion:hover{background:#f1f5f9}.supplier-suggestion-name{color:var(--text);font-size:13px;font-weight:700}.supplier-suggestion-detail{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.supplier-suggestion-chips{flex-wrap:wrap;gap:6px;margin-top:3px;display:flex}.supplier-suggestion-chips span{color:#64748b;background:#f1f5f9;border-radius:99px;padding:1px 7px;font-size:10.5px;font-weight:600}.btn-icon{width:28px;height:28px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.btn-icon:hover{background:var(--bg);color:var(--text)}.supplier-link-badge{color:#64748b;cursor:pointer;white-space:nowrap;background:#f1f5f9;border:1px solid #c7d2fe;border-radius:99px;align-items:center;gap:5px;min-width:0;max-width:100%;padding:3px 8px;font-size:11px;font-weight:700;transition:background .15s,border-color .15s;display:inline-flex;overflow:hidden}.supplier-link-badge span{text-overflow:ellipsis;min-width:0;overflow:hidden}.supplier-link-badge:hover{background:#e2e8f0;border-color:#a5b4fc}.sl-supplier-header{background:var(--bg);align-items:center;gap:8px;padding:6px 20px;display:flex}.sl-supplier-header-name{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:800}.sl-supplier-header-count{color:var(--text-muted);opacity:.7;font-size:11px;font-weight:500}.supplier-select-row{border-bottom:1px solid var(--border);color:var(--text-muted);align-items:center;gap:8px;margin-bottom:6px;padding:8px 0 10px;display:flex}.supplier-select-label{font-size:12px;font-weight:600}.supplier-select{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);color:var(--text);cursor:pointer;flex:1;padding:4px 8px;font-size:12px}.supplier-select:focus{border-color:#818cf8;outline:none}.note-link-badge{letter-spacing:.04em;white-space:nowrap;border-radius:99px;flex-shrink:0;align-self:flex-start;padding:2px 7px;font-size:10px;font-weight:800}.todo-badge{color:#475569;background:#f1f5f9}.star-badge{color:#16a34a;background:#f0fdf4}.note-entry.linked-note{border-color:#cbd5e1}.note-entry.star-note{border-color:#86efac}.cal-sync-badge{white-space:nowrap;border-radius:99px;flex-shrink:0;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:700;display:flex}.cal-sync-badge.from-cal{color:#475569;background:#f1f5f9}.cal-sync-badge.to-cal{color:#ea580c;background:#fff7ed}.notes-list{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:16px 22px;display:flex}.notes-list-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:11px;font-weight:800}.note-entry{background:var(--bg);border-radius:var(--r-sm);border:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 14px;transition:border-color .12s;display:flex}.note-entry:hover{border-color:var(--accent,#f97316)}.note-entry-date{color:var(--accent,#f97316);min-width:80px;font-size:12px;font-weight:800}.note-entry-text{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.wsc-day-entry{cursor:pointer;padding:9px 0;transition:background .12s}.wsc-day-entry:hover{background:var(--bg)}.wsc-day-date{text-transform:uppercase;letter-spacing:.06em;color:#0891b2;margin-bottom:5px;font-size:10px;font-weight:800}.wsc-day-events{flex-direction:column;gap:3px;display:flex}.wsc-day-event-row{color:var(--text-2);border-left:2px solid;align-items:center;gap:6px;padding-left:7px;font-size:12.5px;line-height:1.35;display:flex}.wsc-cat-pill{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:800}.wsc-upcoming-row{cursor:pointer;align-items:baseline;gap:10px;padding:7px 0;transition:background .12s;display:flex}.wsc-upcoming-row:hover{background:var(--bg)}.wsc-upcoming-date{color:var(--text-muted);white-space:nowrap;flex-shrink:0;min-width:72px;font-size:10px;font-weight:800}.wsc-upcoming-text{text-overflow:ellipsis;white-space:nowrap;border-left:2px solid;padding-left:7px;font-size:12.5px;overflow:hidden}.product-hover-popup{display:none}@media (pointer:fine){.product-name-row:hover{background:var(--bg);border-radius:6px}.product-hover-popup{z-index:600;background:var(--surface);border:1px solid var(--border);pointer-events:auto;border-radius:10px;flex-direction:column;gap:5px;min-width:160px;max-width:220px;padding:10px 12px;display:flex;position:fixed;box-shadow:0 6px 24px #00000026}}.cal-day-popup{display:none}@media (pointer:fine){.cal-day-popup{z-index:500;background:var(--surface);border:1px solid var(--border);pointer-events:auto;border-radius:10px;min-width:170px;max-width:240px;max-height:220px;padding:8px 10px;display:block;position:absolute;overflow-y:auto;box-shadow:0 6px 24px #0000002e}.cal-day-popup-row{color:var(--text);align-items:baseline;gap:6px;padding:4px 0;font-size:12.5px;line-height:1.35;display:flex}.cal-day-popup-row+.cal-day-popup-row{border-top:1px solid var(--border)}.cal-day-popup-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:3px}.cal-day-popup-time{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.cal-day-popup-text{flex:1;min-width:0}}.mob-bottom-bar,.workshop-sidebar-hamburger{display:none}@media (width<=768px){.app{flex-direction:column;height:100dvh;overflow:hidden}.sidebar{display:none!important}.mob-bottom-bar{background:var(--surface);border-top:1px solid var(--border);z-index:300;padding:8px 12px;padding-bottom:calc(8px + env(safe-area-inset-bottom));gap:10px;display:flex;position:fixed;bottom:0;left:0;right:0}.mob-nav-btn{border:1.5px solid var(--border);background:var(--bg);height:44px;color:var(--text-muted);cursor:pointer;letter-spacing:.01em;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;font-family:inherit;font-size:13px;font-weight:700;transition:all .15s;display:flex}.mob-nav-btn.open{border-color:var(--text-muted);color:var(--text)}.mob-serenity-logo{mix-blend-mode:screen;width:80px;height:auto;display:block}.mob-serenity-fallback{display:none}.mob-nav-btn-serenity{color:#60a5facc;background:#60a5fa14;border-color:#60a5fa4d}.mob-nav-btn-serenity.serenity-active{color:#93c5fd;background:#60a5fa33;border-color:#60a5fa99}.mob-nav-popup{left:0;right:0;bottom:calc(60px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border);z-index:299;flex-direction:column;gap:6px;max-height:72dvh;padding:10px 10px 6px;display:flex;position:fixed;overflow-y:auto;box-shadow:0 -8px 32px #0000002e}.mob-popup-item{cursor:pointer;color:#fff;text-align:left;filter:grayscale();background-position:50%;background-size:cover;border:none;border-radius:12px;flex-shrink:0;align-items:center;gap:14px;height:54px;padding:0 16px;display:flex;position:relative;overflow:hidden}.mob-popup-item:before{content:"";background:#00000080;border-radius:12px;transition:background .12s;position:absolute;inset:0}.mob-popup-item.active:before{background:#00000040;outline:2.5px solid #fff9}.mob-popup-item-icon{z-index:1;background:#ffffff2e;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex;position:relative}.mob-popup-item-icon svg{width:15px;height:15px}.mob-popup-item-label{z-index:1;text-shadow:0 1px 4px #00000080;font-size:15px;font-weight:700;position:relative}.launcher-btn-claude,.launcher-btn-terminal{display:none!important}.main-panel{min-height:0;padding-bottom:calc(72px + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.workshop-sidebar{display:none!important}.launcher-bar{z-index:500;padding:calc(env(safe-area-inset-top) + 10px) 14px 8px;background:var(--bg);border-bottom:1px solid var(--border);justify-content:flex-end;gap:6px;position:fixed;top:0;left:0;right:0}.main-panel{padding-top:calc(env(safe-area-inset-top) + 58px)}.today-banner{flex-direction:column;gap:8px;padding:10px 12px}.banner-card{padding:12px 14px}.banner-icon{width:auto;min-width:36px}.banner-note{font-size:14px}.section{min-height:unset;flex:none;gap:18px;padding:20px 16px}.section-title{font-size:22px}.workshop-layout{height:auto;min-height:unset;flex-direction:column;flex:none;overflow:visible}.workshop-sidebar-toggle{display:none}.workshop-sidebar-hamburger{background:var(--bg);border:1.5px solid var(--border);cursor:pointer;color:var(--text);white-space:nowrap;box-sizing:border-box;border-radius:10px;flex-shrink:0;align-items:center;gap:10px;width:calc(100% - 20px);margin:6px 10px;padding:10px 16px;font-size:13px;font-weight:700;display:flex}.workshop-hamburger-label{font-size:13px;font-weight:700}.workshop-sidebar{flex-direction:column;flex-shrink:0;gap:0;height:auto;padding:4px 0;transition:none;overflow:hidden;width:100%!important;min-width:unset!important}.workshop-sidebar.collapsed .workshop-tab{display:none}.workshop-tab{border-radius:0;flex-direction:row;flex:none;justify-content:flex-start;gap:10px;width:100%;height:52px;padding:0 14px}.workshop-tab-label{font-size:14px;font-weight:700;display:block!important}.workshop-tab-icon{border-radius:8px;flex-shrink:0;width:32px;height:32px}.workshop-tab-icon svg{width:16px;height:16px}.workshop-content{height:auto;min-height:unset;box-sizing:border-box;flex:none;width:100%;padding:16px 14px;overflow:visible}.section.calendar{isolation:isolate;min-height:100dvh;position:relative}.section.calendar:before{content:"";z-index:-1;background:url(/todo-bg.jpg) top/cover no-repeat;position:absolute;inset:0}.section.calendar:after{content:"";z-index:-1;background:#00000073;position:absolute;inset:0}.section.calendar>div:last-child{flex-direction:column}.section.calendar .card[style*=min-width]{width:100%;min-width:unset!important}.jobs-products-panel,.product-hover-popup{display:none!important}.jobs-grid{width:100%;grid-template-columns:1fr!important}.jobs-grid .supplier-card{box-sizing:border-box;width:100%;max-width:100%}.misc-grid{box-sizing:border-box;grid-template-columns:1fr;width:100%;max-width:100vw}.misc-grid .card{box-sizing:border-box;width:100%}.supplier-grid{box-sizing:border-box;grid-template-columns:1fr;width:100%;max-width:100vw}.supplier-grid .supplier-card{box-sizing:border-box;width:100%;max-width:100%;overflow:hidden}.balance-amount{font-size:36px}.balance-stats{flex-wrap:wrap;gap:16px}.add-transaction-form{flex-direction:column;align-items:stretch}.add-transaction-form .input-desc,.add-transaction-form .input-amount{max-width:unset}.claude-chat-panel{width:100vw;left:0;right:0}.note-overlay{align-items:flex-end;padding:0}.note-modal{border-radius:var(--r-lg) var(--r-lg) 0 0;max-width:100%}.day-num{width:28px;height:28px;font-size:12px}.calendar-grid{padding:10px}.calendar-nav{padding:14px 16px}.calendar-month-label{font-size:17px}.section.calendar>div:last-child>div:last-child{box-sizing:border-box;width:100%;min-width:0}.section.calendar .notes-list{box-sizing:border-box;width:100%;padding:14px 16px}.wsc-day-entry,.wsc-day-events{max-width:100%;overflow:hidden}.wsc-day-event-row{flex-wrap:nowrap;min-width:0;overflow:hidden}.wsc-day-event-row>span:first-child{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.wsc-cat-pill{display:none}.wsc-upcoming-row{min-width:0;overflow:hidden}.wsc-upcoming-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.supplier-form-grid{grid-template-columns:1fr}.supplier-form-field.full{grid-column:1}.transaction-date{display:none}.transaction-amount{min-width:70px;font-size:14px}}.gmail-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);z-index:500;flex-direction:column;width:400px;max-height:calc(100vh - 80px);display:flex;position:fixed;top:64px;right:16px;overflow:hidden;box-shadow:0 16px 48px #00000038}.gmail-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px;font-size:14px;display:flex}.gmail-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.gmail-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:9px;font-size:13px;font-weight:600;transition:all .15s}.gmail-tab.active{color:#1a73e8;border-bottom-color:#1a73e8}.gmail-signin{flex-direction:column;flex:1;align-items:center;gap:8px;padding:32px 24px;display:flex}.gmail-inbox{flex-direction:column;flex:1;display:flex;overflow:hidden}.gmail-search-row{border-bottom:1px solid var(--border);flex-shrink:0;gap:8px;padding:10px 12px;display:flex}.gmail-list{flex:1;overflow-y:auto}.gmail-row{border-bottom:1px solid var(--border);cursor:default;padding:10px 14px;transition:background .1s}.gmail-row:hover{background:var(--surface)}.gmail-row-unread .gmail-row-from,.gmail-row-unread .gmail-row-subject{font-weight:700}.gmail-row-top{cursor:pointer;justify-content:space-between;align-items:baseline;margin-bottom:2px;display:flex}.gmail-row-from{color:var(--text);font-size:13px;font-weight:600}.gmail-row-date{color:var(--text-muted);flex-shrink:0;margin-left:8px;font-size:11px}.gmail-row-subject{color:var(--text);white-space:nowrap;text-overflow:ellipsis;cursor:pointer;margin-bottom:2px;font-size:13px;overflow:hidden}.gmail-row-snippet{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.gmail-row-body{color:var(--text);white-space:pre-wrap;background:var(--surface);border-radius:6px;max-height:180px;margin-top:8px;padding:8px 10px;font-size:12px;line-height:1.5;overflow-y:auto}.gmail-row-actions{gap:6px;margin-top:8px;display:flex}.gmail-action-btn{cursor:pointer;letter-spacing:.02em;border:1.5px solid;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;transition:all .15s}.gmail-action-job{color:#7a9e7e;background:0 0;border-color:#7a9e7e}.gmail-action-job:hover{color:#fff;background:#7a9e7e}.gmail-action-todo{color:#64748b;background:0 0;border-color:#64748b}.gmail-action-todo:hover{color:#fff;background:#64748b}.gmail-compose{flex-direction:column;gap:10px;display:flex}.gmail-compose-field{align-items:center;gap:8px;display:flex}.gmail-compose-label{color:var(--text-muted);flex-shrink:0;width:50px;font-size:12px;font-weight:700}.gmail-compose-body{resize:vertical;min-height:120px;font-size:13px}.gmail-compose-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.gmail-sent-banner{color:#16a34a;justify-content:center;align-items:center;gap:8px;padding:32px;font-size:15px;font-weight:600;display:flex}.gmail-thread-overlay{background:var(--card);z-index:10;flex-direction:column;display:flex;position:absolute;inset:0;overflow:hidden}.gmail-thread{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow:hidden}.gmail-thread-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.gmail-thread-messages{flex-direction:column;flex:1;gap:12px;display:flex;overflow-y:auto}.gmail-thread-msg{background:var(--surface);border-radius:8px;padding:10px 12px}.gmail-thread-msg-meta{justify-content:space-between;margin-bottom:6px;display:flex}.gmail-thread-msg-body{color:var(--text);white-space:pre-wrap;font-size:12px;line-height:1.5}.gmail-thread-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:4px;margin-bottom:8px;padding:10px 12px;display:flex}.gmail-thread-card-subject{color:var(--text);font-size:13px;font-weight:700}.gmail-thread-mini-msg{border-top:1px solid var(--border);align-items:center;gap:8px;padding:3px 0;display:flex}.gmail-modal-backdrop{z-index:900;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gmail-modal{background:var(--card);border-radius:var(--r-lg);flex-direction:column;width:520px;max-width:95vw;display:flex;overflow:hidden;box-shadow:0 24px 80px #0006}.gmail-authed-dot{border:1.5px solid var(--card);background:#16a34a;border-radius:50%;width:7px;height:7px;position:absolute;bottom:4px;right:4px}.gmail-loading{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.gmail-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px;font-style:italic}.gmail-error{color:#ef4444;background:#fee2e2;border-radius:6px;padding:8px 12px;font-size:12px}@media (width<=768px){.gmail-panel{top:auto;bottom:calc(env(safe-area-inset-bottom) + 56px);width:auto;max-height:70vh;left:8px;right:8px}}.wsh-tabs{gap:4px;margin-bottom:16px;display:flex}.wsh-tab{border:1.5px solid var(--border);background:var(--bg-card);color:var(--text-muted);cursor:pointer;border-radius:6px 6px 0 0;padding:18px 60px;font-size:2.7rem;font-weight:500;transition:background .15s,color .15s,border-color .15s}.wsh-tab:hover{background:var(--bg-hover,#f1f5f9);color:var(--text)}.wsh-tab-active{color:#fff;background:#0891b2;border-color:#0891b2}.wsh-employee-card{padding:0;overflow:hidden}.wsh-employee-header{border-bottom:1.5px solid var(--border);background:var(--card);justify-content:space-between;align-items:center;padding:22px 28px 18px;display:flex}.wsh-employee-name{letter-spacing:-.01em;color:var(--text);text-transform:uppercase;font-size:26px;font-weight:800}.wsh-employee-total{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.wsh-total-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:12px;font-weight:600}.wsh-total-value{color:#0891b2;font-size:22px;font-weight:800}.wsh-week-group{border-bottom:1px solid var(--border)}.wsh-week-current{border-left:3px solid #0891b2}.wsh-week-header{background:#0891b20f;justify-content:space-between;align-items:center;padding:13px 28px 10px;display:flex}.wsh-week-current .wsh-week-header{background:#0891b21c}.wsh-week-header-btn{cursor:pointer;-webkit-user-select:none;user-select:none;gap:10px}.wsh-week-header-btn:hover{background:#0891b221}.wsh-week-header-btn.wsh-week-open{background:#0891b21f}.wsh-week-current .wsh-week-header-btn.wsh-week-open{background:#0891b229}.wsh-week-chevron{color:#0891b2;flex-shrink:0;font-size:14px}.wsh-week-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);flex:1;align-items:center;gap:8px;font-size:13px;font-weight:700;display:flex}.wsh-week-current .wsh-week-label{color:var(--text)}.wsh-this-week-badge{text-transform:uppercase;letter-spacing:.09em;color:#0891b2;background:#0891b21f;border:1px solid #0891b24d;border-radius:5px;flex-shrink:0;padding:2px 7px;font-size:10px;font-weight:800}.wsh-week-total{color:#0891b2;font-size:17px;font-weight:800}.wsh-table-wrap{padding:0 4px;overflow-x:auto}.wsh-add-section{padding:12px 4px 4px}.wsh-table{border-collapse:collapse;width:100%;font-size:15px}.wsh-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);white-space:nowrap;padding:8px 16px;font-size:12px;font-weight:700}.wsh-table td{color:var(--text);white-space:nowrap;padding:9px 16px}.wsh-entry-row{cursor:pointer;transition:background .12s}.wsh-entry-row:hover{background:#0891b212}.wsh-total-cell{color:#0891b2;font-weight:700}.wsh-input{border:1.5px solid var(--border);background:var(--bg);color:var(--text);box-sizing:border-box;border-radius:6px;outline:none;width:100%;min-width:90px;padding:6px 10px;font-family:inherit;font-size:15px}.wsh-input:focus{border-color:#0891b2}.wsh-input-sm{width:70px;min-width:60px}.wsh-select{border:1.5px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;border-radius:6px;outline:none;padding:6px 10px;font-family:inherit;font-size:15px}.wsh-select:focus{border-color:#0891b2}.wsh-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:6px 16px;font-family:inherit;font-size:14px;font-weight:700}.wsh-btn-add{color:#fff;background:#0891b2}.wsh-btn-add:disabled{opacity:.4;cursor:not-allowed}.wsh-btn-save{color:#fff;background:#0891b2}.wsh-btn-cancel{background:var(--border);color:var(--text)}.wsh-btn-delete{color:var(--text-muted);background:0 0;padding:2px 8px;font-size:14px}.wsh-btn-delete:hover{color:#ef4444}.wsh-add-mobile{display:none}.wsh-add-desktop{display:block}.wsh-mob-field{box-sizing:border-box;width:100%}.wsh-mob-row{gap:10px;display:flex}.wsh-mob-half{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.wsh-mob-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:11px;font-weight:700}.wsh-mob-hours{color:#0891b2;border:1.5px solid var(--border);background:var(--bg);box-sizing:border-box;border-radius:6px;align-items:center;height:44px;padding:0 10px;font-size:16px;font-weight:700;display:flex}@media (width<=768px){.wsh-table th,.wsh-table td{padding:6px 8px}.wsh-employee-header{flex-wrap:wrap;gap:8px;padding:12px 14px 10px}.wsh-week-header{padding:8px 14px 6px}.wsh-add-desktop{display:none}.wsh-add-mobile{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.wsh-input,.wsh-select{min-height:44px;font-size:16px}.wsh-btn-add.wsh-mob-field{border-radius:8px;height:48px;font-size:16px}}.sl-supplier-chevron-btn,.sl-supplier-expanded-row,.sl-row-break{display:none}@media (width<=768px){.todo-item-row{flex-wrap:wrap;align-items:center;gap:4px 6px;padding:10px 12px;display:flex}.todo-title,.inline-edit-input{flex:1;min-width:0}.sl-priority-badge{flex-shrink:0}.sl-row-break{flex-basis:100%;height:0;display:block;overflow:hidden}.sl-qty-col{flex:none;margin-left:34px;width:auto!important}.sl-supplier-col{flex:auto;justify-content:flex-end;width:auto!important}.todo-meta{flex-shrink:0}.sl-supplier-desktop{display:none!important}.sl-supplier-chevron-btn{border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:8px;align-items:center;gap:4px;padding:3px 7px;font-size:11px;font-weight:600;display:flex}.sl-supplier-expanded-row{padding:4px 12px 8px 46px;display:flex}.btn-add-job-mobile{align-self:flex-end!important}}
