@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300&display=swap";:root{--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"DM Mono", "Fira Code", "Cascadia Code", ui-monospace, monospace;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;--r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-2xl:20px;--r-3xl:24px;--r-pill:9999px;--text-2xs:10px;--text-xs:11px;--text-sm:12px;--text-md:13px;--text-base:14px;--text-lg:16px;--text-xl:18px;--text-2xl:20px;--text-3xl:24px;--text-4xl:28px;--text-5xl:36px;--fw-normal:400;--fw-medium:500;--fw-semi:600;--fw-bold:700;--fw-black:800;--accent:#c9a84c;--accent-soft:#c9a84c1a;--accent-fg:#9a7530;--accent-hover:#b8963a;--neutral-0:#fff;--neutral-50:#faf9f7;--neutral-100:#f4f2ee;--neutral-200:#eae7e1;--neutral-300:#d8d4cc;--neutral-400:#b8b2a8;--neutral-500:#908880;--neutral-600:#686058;--neutral-700:#484038;--neutral-800:#2e2820;--neutral-900:#1c1610;--n-0:#fff;--n-25:#fdfcfb;--n-50:#f8f6f3;--n-100:#f0ede8;--n-150:#e8e4dd;--n-200:#dedad2;--n-300:#c8c3b8;--n-400:#a09890;--n-500:#787068;--n-600:#565049;--n-700:#3a3530;--n-800:#242019;--n-900:#141210;--bg:#f6f4f0;--bg-elevated:#fff;--bg-sunken:#f0ede8;--bg-overlay:#0000000a;--fg-1:#1c1610;--fg-2:#484038;--fg-3:#908880;--fg-muted:#c8c3b8;--fg-on-accent:#fff;--border:#e4e0d8;--border-strong:#d0cbc0;--border-focus:#c9a84c;--success-50:#edfaf3;--success-100:#d0f5e3;--success-400:#22a854;--success-500:#22a854;--success-600:#1a8a42;--success-700:#166b34;--warning-50:#fff8eb;--warning-100:#feefc7;--warning-400:#e8a020;--warning-500:#e8a020;--warning-600:#c8841a;--warning-700:#a06814;--danger-50:#fef2f0;--danger-100:#fdddd8;--danger-200:#fbbbb0;--danger-300:#f89080;--danger-400:#dc3d28;--danger-500:#dc3d28;--danger-600:#b83020;--danger-700:#922418;--info-50:#eef5ff;--info-100:#d8eaff;--info-400:#3b82f6;--info-500:#3b82f6;--info-600:#2d6fd4;--info-700:#1f5cb0;--gold-50:#faf6eb;--gold-100:#f2e8c6;--gold-200:#e6d49a;--gold-300:#d9bf6e;--gold-400:#c9a84c;--gold-500:#b8963a;--gold-600:#96782b;--gold-700:#6f591f;--gold-800:#483b14;--brand-gold-50:#faf6eb;--brand-gold-100:#f2e8c6;--brand-gold-200:#e6d49a;--brand-gold-500:#b8963a;--brand-gold-600:#96782b;--brand-gold-700:#6f591f;--shadow-xs:0 1px 2px #1c16100f;--shadow-sm:0 1px 3px #1c161014, 0 1px 2px #1c16100d;--shadow-md:0 4px 8px #1c161014, 0 2px 4px #1c16100d;--shadow-lg:0 12px 24px #1c16101a, 0 4px 8px #1c16100f;--shadow-xl:0 24px 48px #1c16101f, 0 8px 16px #1c161014;--shadow-focus:0 0 0 3px #c9a84c40;--shadow-focus-danger:0 0 0 3px #dc3d2833;--dur-fast:.1s;--dur-base:.18s;--dur-slow:.28s;--dur-xslow:.4s;--dur-enter:.32s;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in:cubic-bezier(.4, 0, 1, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--sidebar-w:240px}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#141210;--bg-elevated:#1e1c18;--bg-sunken:#0e0c0a;--bg-overlay:#ffffff0e;--fg-1:#f0ede8;--fg-2:#b0a898;--fg-3:#706860;--fg-muted:#4a443c;--border:#2a2620;--border-strong:#3a3530;--border-focus:#c9a84c;--accent-soft:#c9a84c24;--accent-fg:#d4b86a;--n-0:#1e1c18;--n-25:#1a1814;--n-50:#141210;--n-100:#1e1c18;--n-150:#242019;--n-200:#2e2a24;--n-300:#3e3830;--n-400:#686058;--n-500:#a09890;--n-600:#c8c3b8;--n-700:#dedad2;--n-800:#f0ede8;--n-900:#f8f6f3;--neutral-50:#141210;--neutral-100:#1e1c18;--neutral-200:#2a2620;--neutral-300:#3a3530;--neutral-400:#706860;--neutral-500:#b0a898;--neutral-600:#d0c8b8;--neutral-700:#e0d8c8;--neutral-800:#f0ede8;--neutral-900:#f8f6f3;--success-50:#22a8541f;--success-100:#22a85433;--warning-50:#e8a0201f;--warning-100:#e8a02033;--danger-50:#dc3d281f;--danger-100:#dc3d2833;--danger-200:#dc3d2847;--info-50:#3b82f61f;--info-100:#3b82f633;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 1px 4px #0006, 0 1px 2px #00000040;--shadow-md:0 4px 12px #00000080, 0 2px 4px #0000004d;--shadow-lg:0 12px 32px #0009, 0 4px 12px #0006;--shadow-xl:0 24px 64px #000000b3, 0 8px 24px #00000080;--shadow-focus:0 0 0 3px #c9a84c59}.force-light,.pdf-preview,.quote-preview,.invoice-preview{--bg:#fff!important;--bg-elevated:#fff!important;--bg-sunken:#f8f6f3!important;--fg-1:#141210!important;--fg-2:#565049!important;--fg-3:#a09890!important;--border:#e8e4dd!important;--lightningcss-light:initial!important;--lightningcss-dark: !important;color-scheme:light!important}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:var(--fg-1);background:0 0}[data-theme=dark] select{background:var(--bg-elevated);color:var(--fg-1);border-color:var(--border)}[data-theme=dark] select option{background:var(--bg-elevated);color:var(--fg-1)}[data-theme=dark] input[type=date],[data-theme=dark] input[type=time],[data-theme=dark] input[type=datetime-local]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=dark]{scrollbar-color:var(--border-strong) var(--bg-sunken)}[data-theme=dark] ::-webkit-scrollbar{width:8px;height:8px}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--bg-sunken)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--fg-3)}[data-theme=dark] .recharts-default-tooltip{background:var(--bg-elevated)!important;border-color:var(--border)!important;color:var(--fg-1)!important}[data-theme=dark] .recharts-text{fill:var(--fg-3)!important}[data-theme=dark] .recharts-cartesian-grid line{stroke:var(--border)!important}[data-theme=dark] .recharts-legend-item-text{color:var(--fg-2)!important}[data-theme=dark] .b-paid{color:#6dd98a;background:#22a8542e}[data-theme=dark] .b-pending{color:#f0c060;background:#e8a0202e}[data-theme=dark] .b-overdue{color:#f08070;background:#dc3d282e}[data-theme=dark] .b-draft{color:#80b4e8;background:#3b82f62e}[data-theme=dark] .b-sent{color:#c0b8b0;background:#a098902e}[data-theme=dark] .b-cancelled{color:#908880;background:#6860582e}[data-theme=dark] .b-accepted{color:#6dd98a;background:#22a8542e}[data-theme=dark] .b-denied{color:#f08070;background:#dc3d282e}[data-theme=dark] .b-active{color:#6dd98a;background:#22a8542e}[data-theme=dark] .b-confirmed{color:#80b4e8;background:#3b82f62e}[data-theme=dark] .b-received{color:#6dd98a;background:#22a8542e}[data-theme=dark] .stat-card,[data-theme=dark] .panel,[data-theme=dark] .proj-card{background:var(--bg-elevated);border-color:var(--border)}[data-theme=dark] .sb-item.is-active{color:#d4b86a;background:#c9a84c29}[data-theme=dark] .toast{background:var(--bg-elevated);border-color:var(--border-strong);color:var(--fg-1)}[data-theme=dark] .toast-error{border-color:var(--danger-400);color:#ffd0c8;background:#8c2d15e6}[data-theme=dark] .toast-success{border-color:var(--success-400);color:#b0f0c8;background:#1f6640e6}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);font-family:var(--font-sans);color:var(--fg-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--dur-slow), color var(--dur-slow);font-size:14px;line-height:1.5}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}table{border-collapse:collapse;width:100%}a{color:inherit;text-decoration:none}.app{grid-template-columns:var(--sidebar-w) 1fr;height:100vh;display:grid;overflow:hidden}.main{flex-direction:column;min-width:0;display:flex;overflow:hidden}.main-scroll{scroll-behavior:smooth;flex:1;padding:32px 40px 60px;overflow-y:auto}.page{width:100%;animation:page-enter var(--dur-enter) var(--ease-out);flex-direction:column;gap:24px;display:flex}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.cal-month-label{letter-spacing:-.02em;color:var(--fg-1);white-space:nowrap;margin-left:4px;font-size:17px;font-weight:700}.cal-kind-filters{flex-wrap:wrap;flex:1;gap:4px;display:flex}.cal-body{flex:1;grid-template-columns:1fr 280px;gap:16px;min-height:0;display:grid;overflow:hidden}.cal-main{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;display:flex;overflow:hidden}.cal-dow-row{border-bottom:1px solid var(--border);background:var(--bg-sunken);flex-shrink:0;grid-template-columns:repeat(7,1fr);display:grid}.cal-cell.other{background:var(--bg-sunken);opacity:.5}.cal-cell.selected{background:var(--bg-sunken);outline:2px solid var(--accent);outline-offset:-2px}.cal-date-num{color:var(--fg-2);border-radius:50%;flex-shrink:0;place-items:center;width:26px;height:26px;font-size:13px;font-weight:600;display:grid}.cal-event-pill{border-radius:var(--r-sm);cursor:pointer;transition:opacity var(--dur-fast);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:5px;padding:3px 7px;font-size:11.5px;font-weight:600;display:flex;overflow:hidden}.cal-side{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;display:flex;overflow:hidden}.cal-side-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:16px 18px;display:flex}.cal-side-date{color:var(--fg-1);text-transform:capitalize;font-size:14px;font-weight:700}.cal-side-weather{color:var(--fg-3);margin-top:3px;font-size:12px}.cal-side-events{flex-direction:column;flex:1;gap:10px;padding:14px;display:flex;overflow-y:auto}.cal-side-event{background:var(--bg-sunken);border-radius:var(--r-lg);flex-direction:column;gap:6px;padding:12px 14px;display:flex}.cal-side-event-head{justify-content:space-between;align-items:center;display:flex}.cal-side-event-title{color:var(--fg-1);font-size:13.5px;font-weight:700}.cal-side-event-meta{color:var(--fg-3);flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.cal-side-event-addr{color:var(--fg-3);align-items:center;gap:4px;font-size:12px;display:flex}.cal-side-event-notes{color:var(--fg-2);font-size:12.5px;font-style:italic}.cal-side-empty{color:var(--fg-3);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:20px;font-size:13px;display:flex}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);flex-direction:column;padding:0;display:flex;overflow:hidden auto}.sb-brand{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;margin-bottom:8px;padding:20px 16px 16px;display:flex}.sb-logo{background:var(--accent);color:#fff;border-radius:var(--r-md);letter-spacing:.04em;flex-shrink:0;place-items:center;width:34px;height:34px;font-size:13px;font-weight:800;display:grid;box-shadow:0 2px 8px #c9a84c59}.sb-brand-text{flex-direction:column;line-height:1.2;display:flex}.sb-brand-sm{letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);font-size:9px;font-weight:600}.sb-brand-lg{letter-spacing:-.01em;color:var(--fg-1);font-size:15px;font-weight:800}.sb-nav{flex-direction:column;flex:1;gap:0;padding:4px 10px;display:flex}.sb-section{margin-bottom:4px}.sb-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--fg-muted);padding:14px 8px 5px;font-size:9.5px;font-weight:700}.sb-item{border-radius:var(--r-md);color:var(--fg-2);text-align:left;width:100%;transition:all var(--dur-fast) var(--ease-out);white-space:nowrap;background:0 0;border:0;align-items:center;gap:9px;padding:8px 10px;font-size:13.5px;font-weight:500;display:flex;position:relative}.sb-item svg{stroke-width:1.75px;width:16px;height:16px;color:var(--fg-3);transition:color var(--dur-fast);flex-shrink:0}.sb-item:hover{background:var(--bg-overlay);color:var(--fg-1)}.sb-item:hover svg{color:var(--fg-2)}.sb-item.is-active{background:var(--accent-soft);color:var(--accent-fg);font-weight:600}.sb-item.is-active svg{color:var(--accent)}.sb-item.is-active:before{content:"";background:var(--accent);border-radius:0 var(--r-xs) var(--r-xs) 0;width:3px;height:60%;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.sb-item-danger:hover{background:var(--danger-50);color:var(--danger-500)}.sb-item-danger:hover svg{color:var(--danger-500)}.sb-foot{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:4px;padding:10px 10px 16px;display:flex}.sb-user{border-radius:var(--r-md);cursor:pointer;transition:background var(--dur-fast);align-items:center;gap:10px;margin-top:4px;padding:8px 10px;display:flex}.sb-user:hover{background:var(--bg-overlay)}.sb-avatar{border-radius:var(--r-pill);background:var(--accent);color:#fff;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:11.5px;font-weight:700;display:grid}.sb-user-name{color:var(--fg-1);font-size:13px;font-weight:600;line-height:1.2}.sb-user-role{color:var(--fg-3);font-size:11px}.topbar{border-bottom:1px solid var(--border);background:var(--bg-elevated);z-index:10;flex-shrink:0;align-items:center;gap:16px;height:58px;padding:0 40px;display:flex;position:sticky;top:0}.tb-title{letter-spacing:-.02em;color:var(--fg-1);white-space:nowrap;font-size:17px;font-weight:700}.tb-subtitle{color:var(--fg-3);font-size:12px}.tb-search{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-pill);max-width:480px;height:36px;transition:all var(--dur-base);flex:1;align-items:center;gap:8px;padding:0 14px;display:flex}.tb-search:focus-within{background:var(--bg-elevated);border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.tb-search svg{width:15px;height:15px;color:var(--fg-3);flex-shrink:0}.tb-search input{color:var(--fg-1);background:0 0;border:0;outline:0;flex:1;min-width:0;font-size:13.5px}.tb-search input::placeholder{color:var(--fg-3)}.tb-kbd{font-family:var(--font-mono);color:var(--fg-3);border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-elevated);white-space:nowrap;padding:2px 6px;font-size:10px}.tb-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.tb-icon{border-radius:var(--r-md);width:34px;height:34px;color:var(--fg-2);transition:all var(--dur-fast);background:0 0;border:0;place-items:center;display:grid;position:relative}.tb-icon:hover{background:var(--bg-overlay);color:var(--fg-1)}.tb-icon svg{stroke-width:1.75px;width:18px;height:18px}.lang-pill{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-pill);gap:2px;padding:3px;display:inline-flex}.lang-pill button{font-family:var(--font-mono);color:var(--fg-3);border-radius:var(--r-pill);transition:all var(--dur-fast);cursor:pointer;letter-spacing:.04em;background:0 0;border:0;padding:4px 10px;font-size:11px;font-weight:600}.lang-pill button:hover{color:var(--fg-1)}.lang-pill button.on{background:var(--bg-elevated);color:var(--fg-1);box-shadow:var(--shadow-xs)}.lang-switch{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-pill);gap:2px;padding:3px;display:inline-flex}.lang-switch button{font-family:var(--font-mono);color:var(--fg-3);border-radius:var(--r-pill);transition:all var(--dur-fast);cursor:pointer;background:0 0;border:0;padding:4px 10px;font-size:11px;font-weight:600}.lang-switch button:hover{color:var(--fg-1)}.lang-switch button.on{background:var(--bg-elevated);color:var(--fg-1);box-shadow:var(--shadow-xs)}.btn{border-radius:var(--r-lg);transition:all var(--dur-base) var(--ease-out);white-space:nowrap;cursor:pointer;letter-spacing:-.01em;border:1px solid #0000;align-items:center;gap:7px;padding:9px 16px;font-size:13.5px;font-weight:600;line-height:1;display:inline-flex}.btn svg{stroke-width:2px;flex-shrink:0;width:15px;height:15px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--gold-500);box-shadow:0 1px 3px #c9a84c66,inset 0 1px #ffffff26}.btn-primary:hover{background:var(--gold-500);box-shadow:0 2px 8px #c9a84c80}.btn-primary:active{box-shadow:none;transform:translateY(1px)}.btn-secondary{background:var(--bg-elevated);color:var(--fg-1);border-color:var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-sunken);border-color:var(--border-strong)}.btn-ghost{color:var(--fg-2);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-overlay);color:var(--fg-1)}.btn-danger{background:var(--bg-elevated);color:var(--danger-500);border-color:var(--danger-100)}.btn-danger:hover{background:var(--danger-50);border-color:var(--danger-400)}.btn-success{background:var(--success-50);color:var(--success-700);border-color:var(--success-100)}.btn-success:hover{background:var(--success-100)}.btn-sm{border-radius:var(--r-md);padding:6px 12px;font-size:12.5px}.btn-sm svg{width:14px;height:14px}.btn-xs{border-radius:var(--r-sm);padding:4px 10px;font-size:11.5px}.btn[disabled],.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.icon-btn{border-radius:var(--r-md);color:var(--fg-3);cursor:pointer;transition:all var(--dur-fast);background:0 0;border:0;justify-content:center;align-items:center;padding:6px;line-height:1;display:inline-flex}.icon-btn.success:hover{background:var(--success-50);color:var(--success-500)}.field{flex-direction:column;gap:6px;min-width:0;display:flex}.field label{color:var(--fg-2);letter-spacing:.01em;font-size:12px;font-weight:600}.input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);height:40px;transition:all var(--dur-base);align-items:center;gap:8px;padding:0 14px;display:flex}.input:focus-within{border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.input input,.input select{font-family:var(--font-sans);color:var(--fg-1);background:0 0;border:0;outline:0;flex:1;min-width:0;font-size:14px}.input input::placeholder{color:var(--fg-3)}.input svg{width:15px;height:15px;color:var(--fg-3);flex-shrink:0}.input.error{border-color:var(--danger-400)}.input textarea{font-family:var(--font-sans);color:var(--fg-1);resize:vertical;background:0 0;border:0;outline:0;flex:1;min-height:80px;padding:10px 0;font-size:14px}.err-msg{color:var(--danger-500);font-size:12px}.two-field{grid-template-columns:1fr 1fr;gap:14px;display:grid}.badge{border-radius:var(--r-pill);letter-spacing:.01em;white-space:nowrap;align-items:center;gap:5px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge .dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.b-paid{background:var(--success-50);color:var(--success-700)}.b-paid .dot{background:var(--success-400)}.b-pending{background:var(--warning-50);color:var(--warning-700)}.b-pending .dot{background:var(--warning-400)}.b-overdue{background:var(--danger-50);color:var(--danger-700)}.b-overdue .dot{background:var(--danger-400)}.b-draft{background:var(--info-50);color:var(--info-700)}.b-draft .dot{background:var(--info-400)}.b-sent{background:var(--n-100);color:var(--n-600)}.b-sent .dot{background:var(--n-400)}.b-cancelled{background:var(--n-100);color:var(--n-500)}.b-cancelled .dot{background:var(--n-300)}.b-accepted{background:var(--success-50);color:var(--success-700)}.b-accepted .dot{background:var(--success-400)}.b-denied{background:var(--danger-50);color:var(--danger-700)}.b-denied .dot{background:var(--danger-400)}.b-active{background:var(--success-50);color:var(--success-700)}.b-active .dot{background:var(--success-400)}.b-confirmed{background:var(--info-50);color:var(--info-700)}.b-confirmed .dot{background:var(--info-400)}.b-received{background:var(--success-50);color:var(--success-700)}.b-received .dot{background:var(--success-400)}.panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);flex-direction:column;gap:16px;padding:22px;display:flex}.panel.flush{padding:0;overflow:hidden}.panel-head{justify-content:space-between;align-items:center;display:flex}.panel-title{color:var(--fg-1);letter-spacing:-.01em;font-size:14px;font-weight:700}.stat-grid{grid-template-columns:repeat(4,1fr);gap:16px;width:100%;display:grid}.stat-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-base), transform var(--dur-base);cursor:default;flex-direction:column;gap:8px;padding:20px 22px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.sc-head{justify-content:space-between;align-items:center;display:flex}.sc-label{color:var(--fg-3);letter-spacing:.02em;font-size:12px;font-weight:600}.sc-icon{border-radius:var(--r-md);background:var(--bg-sunken);width:30px;height:30px;color:var(--fg-2);place-items:center;display:grid}.sc-icon svg{stroke-width:1.75px;width:15px;height:15px}.sc-value{letter-spacing:-.04em;font-variant-numeric:tabular-nums;color:var(--fg-1);letter-spacing:-.03em;font-family:DM Mono,ui-monospace,monospace;font-size:28px;font-weight:500;line-height:1}.sc-value.positive{color:var(--success-500)}.sc-value.negative{color:var(--danger-500)}.sc-delta{align-items:center;gap:4px;font-size:12px;font-weight:500;display:inline-flex}.sc-delta-up{color:var(--success-500)}.sc-delta-down{color:var(--danger-500)}.sc-delta-neutral{color:var(--fg-3)}.tbl{width:100%;font-size:13.5px}.tbl th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--fg-3);border-bottom:1px solid var(--border);background:var(--bg-sunken);white-space:nowrap;padding:12px 16px;font-size:10.5px;font-weight:700}.tbl td{border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 16px}.tbl tr:last-child td{border-bottom:0}.tbl tbody tr:hover td{background:var(--bg-sunken)}.tbl .id{font-family:var(--font-mono);color:var(--fg-3);font-size:12px;font-weight:500}.tbl .name-cell{color:var(--fg-1);font-weight:600}.tbl .mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.tbl .num{text-align:right;font-weight:600}.tbl .meta{color:var(--fg-2);font-size:12.5px}.tbl .muted{color:var(--fg-2)}.tbl .amount-positive{font-family:var(--font-mono);color:var(--success-500);text-align:right;font-weight:600}.tbl .amount-negative{font-family:var(--font-mono);color:var(--danger-500);text-align:right;font-weight:600}.tbl .amount-neutral{font-family:var(--font-mono);color:var(--fg-1);text-align:right;font-weight:600}.tbl .row-actions{opacity:0;transition:opacity var(--dur-fast);justify-content:flex-end;gap:4px;display:flex}.tbl tbody tr:hover .row-actions{opacity:1}.tbl-full{width:100%}.page-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.page-bar-right{align-items:center;gap:8px;display:flex}.chips{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-wrap:wrap;gap:4px;padding:4px;display:flex}.chip{color:var(--fg-2);border-radius:var(--r-lg);transition:all var(--dur-fast);cursor:pointer;white-space:nowrap;background:0 0;border:0;align-items:center;gap:5px;padding:6px 14px;font-size:12.5px;font-weight:600;display:inline-flex}.chip:hover{color:var(--fg-1)}.chip.is-on{background:var(--bg-sunken);color:var(--fg-1);box-shadow:var(--shadow-xs)}.modal-scrim{z-index:200;animation:fade-in var(--dur-base) ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1412108c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;animation:slide-up var(--dur-slow) var(--ease-out);overflow-y:auto}.modal-xl{max-width:1060px}.modal-head{border-bottom:1px solid var(--border);background:var(--bg-elevated);z-index:1;justify-content:space-between;align-items:center;padding:22px 26px 18px;display:flex;position:sticky;top:0}.modal-head h2{letter-spacing:-.02em;font-size:16px;font-weight:700}.modal-body{flex-direction:column;gap:16px;padding:22px 26px;display:flex}.modal-foot{border-top:1px solid var(--border);background:var(--bg-elevated);justify-content:flex-end;gap:10px;padding:18px 26px;display:flex;position:sticky;bottom:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.toast{background:var(--n-800);color:var(--n-50);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);z-index:500;animation:toast-in var(--dur-slow) var(--ease-spring);border:1px solid var(--n-700);align-items:center;gap:10px;max-width:380px;padding:13px 18px;font-size:13.5px;font-weight:500;display:flex;position:fixed;bottom:28px;right:28px}.toast-error{background:var(--danger-700);border-color:var(--danger-500)}.toast-success{background:var(--success-700);border-color:var(--success-500)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:none}}.weather-alert-bar{background:var(--warning-50);border-bottom:1px solid var(--warning-100);color:var(--warning-700);align-items:center;gap:10px;padding:10px 40px;font-size:13px;font-weight:500;display:flex}.weather-chip{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-pill);color:var(--fg-2);align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.lien-alert{background:var(--danger-50);border:1px solid var(--danger-100);border-radius:var(--r-lg);color:var(--danger-700);align-items:center;gap:10px;padding:13px 18px;font-size:13px;font-weight:500;display:flex}.login-screen{background:var(--bg);background-image:radial-gradient(at 20%,#c9a84c0f 0%,#0000 60%),radial-gradient(at 80% 20%,#c9a84c0a 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:420px;animation:slide-up var(--dur-enter) var(--ease-out);flex-direction:column;gap:32px;padding:48px 44px;display:flex}.login-brand{flex-direction:column;align-items:center;gap:8px;display:flex}.login-logo{background:var(--accent);color:#fff;letter-spacing:.04em;border-radius:20px;place-items:center;width:68px;height:68px;margin-bottom:6px;font-size:24px;font-weight:800;display:grid;box-shadow:0 8px 24px #c9a84c66}.login-brand-name{letter-spacing:-.02em;font-size:22px;font-weight:800}.login-brand-sub{color:var(--fg-3);font-size:13px}.login-form{flex-direction:column;gap:14px;display:flex}.proj-card-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.proj-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);cursor:pointer;transition:all var(--dur-base) var(--ease-out);flex-direction:column;gap:14px;padding:22px;display:flex;position:relative;overflow:hidden}.proj-card:before{content:"";background:var(--border);width:4px;transition:background var(--dur-base);position:absolute;top:0;bottom:0;left:0}.proj-card.status-active:before{background:var(--success-400)}.proj-card.status-pending:before{background:var(--warning-400)}.proj-card.status-completed:before{background:var(--n-300)}.proj-card.status-overdue:before{background:var(--danger-400)}.proj-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-2px)}.proj-card-name{color:var(--fg-1);letter-spacing:-.01em;font-size:15px;font-weight:700}.proj-card-client{color:var(--fg-3);align-items:center;gap:4px;margin-top:2px;font-size:12.5px;display:flex}.proj-card-head{justify-content:space-between;align-items:flex-start;padding-left:12px;display:flex}.proj-card-stats{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:8px;margin-left:12px;padding:14px 0 0;display:grid}.proj-card-stat-label{text-transform:uppercase;letter-spacing:.07em;color:var(--fg-3);margin-bottom:3px;font-size:10px;font-weight:700}.proj-card-stat-value{font-family:var(--font-mono);color:var(--fg-1);font-size:13px;font-weight:500}.proj-card-footer{color:var(--accent-fg);justify-content:space-between;align-items:center;margin-left:12px;font-size:12px;font-weight:600;display:flex}.proj-tabs{border-bottom:1px solid var(--border);scrollbar-width:none;gap:2px;padding-bottom:0;display:flex;overflow-x:auto}.proj-tabs::-webkit-scrollbar{display:none}.proj-tab{color:var(--fg-2);cursor:pointer;white-space:nowrap;transition:all var(--dur-fast);background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:600;display:inline-flex}.proj-tab svg{width:14px;height:14px}.proj-tab:hover{color:var(--fg-1)}.proj-tab.is-active{color:var(--accent-fg);border-bottom-color:var(--accent)}.proj-tab-content{padding-top:8px}.kpi-revenue .sc-icon{background:var(--success-50);color:var(--success-500)}.kpi-pending .sc-icon{background:var(--warning-50);color:var(--warning-500)}.kpi-overdue .sc-icon{background:var(--danger-50);color:var(--danger-500)}.kpi-expenses .sc-icon{background:var(--info-50);color:var(--info-500)}.activity{flex-direction:column;list-style:none;display:flex}.activity li{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:11px 4px;display:flex}.activity li:last-child{border-bottom:0}.act-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.act-text{color:var(--fg-1);font-size:13.5px;line-height:1.4}.act-time{color:var(--fg-3);margin-top:2px;font-size:11.5px}.editor-grid{grid-template-columns:1fr;gap:16px;display:grid}.tbl-lines td{vertical-align:middle;padding:9px 12px}.cell-in{width:100%;font:inherit;color:var(--fg-1);transition:all var(--dur-fast);background:0 0;border:0;outline:0;padding:3px 0;font-size:13.5px}.cell-sku{color:var(--fg-3);font-size:10.5px;font-family:var(--font-mono);margin-top:2px}.totals{border-top:1px solid var(--border);flex-direction:column;gap:4px;width:300px;margin-left:auto;padding-top:14px;display:flex}.totals .tr{color:var(--fg-2);justify-content:space-between;padding:5px 0;font-size:13.5px;display:flex}.totals .tr span:last-child{font-family:var(--font-mono)}.totals .tr-total{color:var(--fg-1);border-top:1px solid var(--border-strong);margin-top:6px;padding-top:12px;font-size:18px;font-weight:700}.totals .tr-total span:last-child{color:var(--accent-fg);font-family:var(--font-mono)}.totals .tr-deposit{background:var(--accent-soft);border-radius:var(--r-md);color:var(--accent-fg);margin-top:8px;padding:8px 12px;font-weight:700}.editor-foot{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);justify-content:flex-start;align-items:center;gap:10px;padding:14px 18px;display:flex;position:sticky;bottom:0}.overhead-suggestion{background:var(--warning-50);border:1px solid var(--warning-100);border-radius:var(--r-lg);color:var(--warning-700);align-items:center;gap:12px;padding:12px 16px;font-size:13px;display:flex}.overhead-suggestion strong{font-family:var(--font-mono);font-size:15px}.finances-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.chart-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);padding:22px}.chart-title{color:var(--fg-1);letter-spacing:-.01em;margin-bottom:16px;font-size:14px;font-weight:700}.empty svg{opacity:.3}.pinned-note{background:var(--warning-50);border:1px solid var(--warning-100);border-radius:var(--r-lg);padding:14px 16px}.logo-upload-area{border:2px dashed var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-base);color:var(--fg-3);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;font-size:13px;display:flex}.logo-upload-area:hover{border-color:var(--accent);background:var(--accent-soft)}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.ai-pill{color:var(--accent-fg);background:var(--accent-soft);border-radius:var(--r-pill);letter-spacing:.03em;align-items:center;gap:4px;margin-left:6px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-flex}.doc-lang-bar{background:var(--accent-soft);border-radius:var(--r-lg);border:1px solid #c9a84c40;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.po-number{font-family:var(--font-mono);color:var(--fg-3);font-size:12px;font-weight:500}.search-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;animation:slide-up var(--dur-slow) var(--ease-out);overflow:hidden}.search-input-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 20px;display:flex}.search-input-row input{font-size:16px;font-family:var(--font-sans);color:var(--fg-1);background:0 0;border:0;outline:0;flex:1}.search-results{max-height:420px;overflow-y:auto}.search-group-label{text-transform:uppercase;letter-spacing:.1em;color:var(--fg-3);padding:12px 20px 4px;font-size:10px;font-weight:700}.search-result-item{cursor:pointer;transition:background var(--dur-fast);align-items:center;gap:12px;padding:10px 20px;font-size:13.5px;display:flex}.search-result-item:hover{background:var(--bg-sunken)}.search-result-item .label{color:var(--fg-1);font-weight:600}.search-result-item .sub{color:var(--fg-3);margin-top:1px;font-size:12px}.amount,.tbl .num,.totals .tr span:last-child{font-variant-numeric:tabular-nums;letter-spacing:-.03em;font-family:DM Mono,ui-monospace,monospace}.gantt-root{flex-direction:column;gap:16px;display:flex}.gantt-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.gantt-task-count{color:var(--fg-2);font-size:13px;font-weight:600}.gantt-legend{flex-wrap:wrap;gap:10px;margin-left:12px;display:flex}.gantt-legend-item{color:var(--fg-3);align-items:center;gap:5px;font-size:11.5px;font-weight:500;display:flex}.gantt-wrap{border:1px solid var(--border);border-radius:var(--r-xl);background:var(--bg-elevated);grid-template-columns:280px 1fr;display:grid;overflow:hidden}.gantt-left{border-right:1px solid var(--border);background:var(--bg-elevated)}.gantt-left-head{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em;height:56px;color:var(--fg-3);background:var(--bg-sunken);justify-content:space-between;align-items:flex-end;padding:0 14px 8px;font-size:10.5px;font-weight:700;display:flex}.gantt-task-row{border-bottom:1px solid var(--border);height:34px;transition:background var(--dur-fast);justify-content:space-between;align-items:center;padding:0 10px;display:flex}.gantt-task-row:hover{background:var(--bg-sunken)}.gantt-task-row:hover .gantt-del-btn{opacity:1!important}.gantt-task-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.gantt-task-phase-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.gantt-task-name-input{font:inherit;color:var(--fg-1);background:0 0;border:0;outline:0;flex:1;min-width:0;font-size:13px}.gantt-task-meta{align-items:center;gap:6px;display:flex}.gantt-task-days{font-family:var(--font-mono);color:var(--fg-3);font-size:11px}.gantt-del-btn{opacity:0;transition:opacity var(--dur-fast)}.gantt-chart-scroll{position:relative;overflow-x:auto}.gantt-chart{min-height:100px;position:relative}.gantt-months{background:var(--bg-sunken);border-bottom:1px solid var(--border);position:relative}.gantt-month-label{color:var(--fg-2);white-space:nowrap;letter-spacing:.02em;padding-left:8px;font-size:11px;font-weight:700;position:absolute;top:6px}.gantt-days-row{border-bottom:1px solid var(--border);background:var(--bg-sunken);height:28px;display:flex}.gantt-day-header{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:1px;display:flex}.gantt-day-header.weekend{background:var(--bg-overlay,#00000008)}.gantt-day-num{color:var(--fg-3);font-size:10px;font-weight:600;font-family:var(--font-mono)}.gantt-day-weather{font-size:10px;line-height:1}.gantt-bg{pointer-events:none;position:absolute;top:56px;left:0;right:0}.gantt-weekend-col{background:var(--bg-overlay,#00000008);position:absolute;top:0}.gantt-today-line{background:var(--accent);opacity:.7;z-index:2;width:2px;position:absolute;top:0}.gantt-today-line:before{content:"";background:var(--accent);border-radius:50%;width:10px;height:10px;position:absolute;top:-4px;left:-4px}.gantt-bar-row{align-items:center;display:flex;position:absolute;left:0;right:0}.gantt-bar{border-radius:var(--r-sm);cursor:pointer;height:22px;transition:opacity var(--dur-fast);align-items:center;display:flex;position:absolute;overflow:hidden}.gantt-bar:hover{opacity:.85}.gantt-bar-fill{transition:width .5s var(--ease-out);position:absolute;top:0;bottom:0;left:0}.gantt-bar-label{z-index:1;white-space:nowrap;text-overflow:ellipsis;padding:0 8px;font-size:11px;font-weight:600;position:relative;overflow:hidden}.sel-stats-bar{flex-wrap:wrap;gap:8px;display:flex}.sel-stat-pill{border-radius:var(--r-pill);border:1px solid var(--border);background:var(--bg-elevated);color:var(--fg-2);align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.sel-stat-approved{background:var(--success-50,#f0fdf4);color:var(--success-700,#15803d);border-color:var(--success-100,#dcfce7)}.sel-stat-pending{background:var(--warning-50,#fffbeb);color:var(--warning-700,#b45309);border-color:var(--warning-100,#fef3c7)}.sel-room-tabs{border-bottom:1px solid var(--border);gap:0;display:flex;overflow-x:auto}.sel-room-tab{color:var(--fg-2);cursor:pointer;transition:all var(--dur-fast);white-space:nowrap;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:13px;font-weight:600}.sel-room-tab:hover{color:var(--fg-1)}.sel-room-tab.active{color:var(--accent-fg);border-bottom-color:var(--accent)}.sel-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);transition:all var(--dur-base) var(--ease-out);flex-direction:column;display:flex;overflow:hidden}.sel-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.sel-card-swatch{justify-content:center;align-items:center;height:140px;display:flex;position:relative;overflow:hidden}.sel-card-img{object-fit:cover;width:100%;height:100%}.sel-card-upload-hint{cursor:pointer;width:100%;height:100%;transition:background var(--dur-fast);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.sel-card-upload-hint:hover{background:#00000014}.sel-card-sku{font-family:var(--font-mono);color:#fff;border-radius:var(--r-pill);letter-spacing:.04em;background:#00000073;padding:2px 7px;font-size:9.5px;font-weight:600;position:absolute;top:8px;left:8px}.sel-card-status-overlay{position:absolute;bottom:8px;right:8px}.sel-card-body{flex-direction:column;flex:1;gap:8px;padding:14px;display:flex}.sel-card-tags{flex-wrap:wrap;gap:5px;display:flex}.sel-card-room{color:var(--accent-fg);background:var(--accent-soft);border-radius:var(--r-pill);padding:2px 8px;font-size:10.5px;font-weight:700}.sel-card-cat{color:var(--fg-3);background:var(--bg-sunken);border-radius:var(--r-pill);padding:2px 8px;font-size:10.5px}.sel-card-name{color:var(--fg-1);font-size:13.5px;font-weight:700;line-height:1.3}.sel-card-price{align-items:baseline;gap:3px;display:flex}.sel-card-price-val{font-family:var(--font-mono);color:var(--fg-1);font-size:15px;font-weight:600}.sel-card-price-unit{color:var(--fg-3);font-size:11px}.sel-card-note{color:var(--fg-3);font-size:11.5px;font-style:italic;line-height:1.4}.sel-card-actions{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.sel-add-card{border:2px dashed var(--border);border-radius:var(--r-xl);cursor:pointer;min-height:200px;color:var(--fg-3);transition:all var(--dur-base);background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.sel-add-card:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-fg)}.proj-margin-badge{font-family:var(--font-mono);border-radius:var(--r-pill);padding:3px 8px;font-size:11px;font-weight:700}.proj-margin-badge.good{background:var(--success-50,#f0fdf4);color:var(--success-700,#15803d)}.proj-margin-badge.warn{background:var(--warning-50,#fffbeb);color:var(--warning-700,#b45309)}.proj-margin-badge.bad{background:var(--danger-50,#fef2f2);color:var(--danger-700,#b91c1c)}.margin-alert{background:var(--warning-50,#fffbeb);border:1px solid var(--warning-100,#fef3c7);border-radius:var(--r-lg);color:var(--warning-700,#b45309);align-items:center;gap:10px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.skeleton{background:linear-gradient(90deg, var(--n-100) 25%, var(--n-150) 50%, var(--n-100) 75%);border-radius:var(--r-md);background-size:200% 100%;animation:1.4s infinite skeleton-shine}@keyframes skeleton-shine{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;margin:4px 0}.skeleton-title{width:60%;height:20px;margin:4px 0}.skeleton-card{border-radius:var(--r-xl);height:120px}.quick-fab-wrap,.quick-menu,.quick-menu-item,.quick-menu-icon,.quick-menu-label{display:none}.tb-notif-badge{background:var(--danger-500,#ef4444);color:#fff;border:2px solid var(--bg-elevated);border-radius:50%;place-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:grid;position:absolute;top:4px;right:4px}.ba-slider{aspect-ratio:16/9;border-radius:var(--r-xl);cursor:ew-resize;-webkit-user-select:none;user-select:none;width:100%;position:relative;overflow:hidden}.ba-img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.ba-divider{background:#fff;width:2px;position:absolute;top:0;bottom:0;transform:translate(-50%)}.ba-handle{width:36px;height:36px;box-shadow:var(--shadow-md);background:#fff;border-radius:50%;place-items:center;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.morning-card{background:linear-gradient(135deg, var(--accent-soft) 0%, var(--bg-elevated) 100%);border:1px solid var(--accent);border-radius:var(--r-xl);flex-direction:column;gap:12px;padding:20px 24px;display:flex;position:relative}.morning-dismiss{position:absolute;top:14px;right:14px}.morning-title{color:var(--accent-fg);letter-spacing:-.02em;font-size:16px;font-weight:800}.morning-items{flex-wrap:wrap;gap:10px;display:flex}.morning-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:600;display:flex}@media (width<=1400px){.stat-grid{grid-template-columns:repeat(2,1fr)}.finances-grid{grid-template-columns:1fr}}@media (width<=1100px){:root{--sidebar-w:200px}.main-scroll{padding:24px 24px 48px}}@media (width<=900px){.stat-grid{grid-template-columns:repeat(2,1fr)}.two-field{grid-template-columns:1fr}.finances-grid-2col{grid-template-columns:1fr!important}}@media (width<=768px){.app{grid-template-columns:1fr}.sidebar{display:none}.main-scroll{padding:16px 16px 48px}.stat-grid{grid-template-columns:1fr 1fr}.proj-card-grid{grid-template-columns:1fr}.topbar{padding:0 16px}.btn{min-height:44px;padding:0 18px}.btn-sm{min-height:36px}.icon-btn{width:44px;height:44px}.sb-item{min-height:44px}.chip{min-height:36px;padding:6px 14px}.tbl td,.tbl th{padding:12px 10px}.input input,.input select,.input textarea{min-height:44px;font-size:16px}.proj-tab{min-height:40px;padding:8px 14px}.row-actions{gap:8px!important}.two-field{grid-template-columns:1fr}.page-bar{flex-wrap:wrap;gap:8px}.page-bar-right{flex-wrap:wrap;gap:6px}.quick-card{width:calc(100vw - 24px);bottom:100px;right:12px}.quick-fab{width:52px;height:52px;bottom:16px;right:12px}}@media (width<=480px){.stat-grid{grid-template-columns:1fr}.login-card{padding:32px 24px}.modal{margin:8px;max-width:calc(100vw - 16px)!important}}.theme-picker{gap:10px;padding-top:8px;display:flex}.theme-option{border:1.5px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);color:var(--fg-2);cursor:pointer;transition:all var(--dur-base);font-size:13px;font-weight:600;font-family:var(--font-sans);flex-direction:column;flex:1;align-items:center;gap:8px;padding:16px 12px;display:flex;position:relative}.theme-option:hover{border-color:var(--border-strong);color:var(--fg-1)}.theme-option.active{border-color:var(--accent);color:var(--accent-fg);background:var(--accent-soft)}.sup-layout{grid-template-columns:280px 1fr;align-items:start;gap:16px;display:grid}.sup-list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden}.sup-list-head{background:var(--bg-sunken);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.07em;color:var(--fg-3);padding:10px 14px;font-size:10.5px;font-weight:700}.sup-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur-fast);align-items:center;gap:10px;padding:11px 14px;display:flex}.sup-item:last-child{border-bottom:0}.sup-item:hover{background:var(--bg-sunken)}.sup-item.is-active{background:var(--accent-soft)}.sup-item-icon{border-radius:var(--r-md);background:var(--bg-sunken);width:34px;height:34px;color:var(--fg-2);flex-shrink:0;place-items:center;display:grid}.sup-item.is-active .sup-item-icon{background:var(--accent-soft);color:var(--accent-fg)}.sup-item-name{color:var(--fg-1);font-size:13px;font-weight:600;line-height:1.3}.sup-item-type{color:var(--fg-3);font-size:11px}.sup-detail{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);overflow:hidden}.sup-detail-head{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:20px 22px;display:flex}.sup-detail-icon{border-radius:var(--r-lg);background:var(--accent-soft);width:48px;height:48px;color:var(--accent-fg);flex-shrink:0;place-items:center;display:grid}.sup-detail-name{letter-spacing:-.02em;color:var(--fg-1);font-size:16px;font-weight:700}.sup-detail-type{color:var(--fg-3);margin-top:2px;font-size:12px}.sup-detail-tabs{border-bottom:1px solid var(--border);background:var(--bg-sunken);gap:0;display:flex}.sup-tab{color:var(--fg-2);cursor:pointer;transition:all var(--dur-fast);white-space:nowrap;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 18px;font-size:13px;font-weight:600}.sup-tab:hover{color:var(--fg-1)}.sup-tab.is-active{color:var(--accent-fg);border-bottom-color:var(--accent)}.sup-tab-body{padding:20px 22px}.sup-info-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.sup-info-field{flex-direction:column;gap:3px;display:flex}.sup-info-label{text-transform:uppercase;letter-spacing:.07em;color:var(--fg-3);font-size:10.5px;font-weight:700}.sup-info-value{color:var(--fg-1);font-size:13.5px;font-weight:500}.preset-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:20px;display:grid}.preset-row{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-base);text-align:left;flex-direction:column;gap:4px;padding:14px;display:flex}.preset-row:hover{border-color:var(--accent);background:var(--accent-soft)}.preset-name{color:var(--fg-1);font-size:13px;font-weight:700}.preset-ref{color:var(--fg-3);font-size:11px;font-family:var(--font-mono)}@media (width<=900px){.sup-layout{grid-template-columns:1fr}}.email-layout{flex:1;grid-template-columns:320px 1fr;display:grid;overflow:hidden}.email-list-panel{border-right:1px solid var(--border);background:var(--bg-elevated);flex-direction:column;display:flex;overflow:hidden}.email-list-head{border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;padding:12px 16px 10px;display:flex}.email-list-title{justify-content:space-between;align-items:center;display:flex}.email-list-label{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-size:11px;font-weight:700}.email-last-updated{color:var(--fg-muted,var(--fg-3));font-size:11px}.email-filter-chips{flex-wrap:wrap;gap:4px;display:flex}.email-list-scroll{flex:1;overflow-y:auto}.email-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur-fast);align-items:flex-start;gap:12px;padding:12px 14px 12px 20px;display:flex;position:relative}.email-item:hover{background:var(--bg-sunken)}.email-item:hover .email-item-actions{opacity:1}.email-item.active{background:var(--accent-soft)}.email-item.unread .email-sender,.email-item.unread .email-subject{color:var(--fg-1);font-weight:700}.email-avatar{color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;margin-top:2px;font-size:12px;font-weight:700;display:grid}.email-content{flex:1;min-width:0}.email-item-head{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.email-sender{color:var(--fg-1);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.email-date{color:var(--fg-3);font-size:11px;font-family:var(--font-mono);flex-shrink:0;margin-left:8px}.email-subject{color:var(--fg-2);text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:12.5px;overflow:hidden}.email-snippet{color:var(--fg-3);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.email-tag{border-radius:var(--r-pill);text-transform:uppercase;letter-spacing:.04em;margin-top:5px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-block}.email-tag-quote_request{background:var(--accent-soft);color:var(--accent-fg)}.email-tag-payment{background:var(--success-50,#f0fdf4);color:var(--success-700,#15803d)}.email-tag-inspection{background:var(--warning-50,#fffbeb);color:var(--warning-700,#b45309)}.email-tag-supplier{background:var(--info-50,#eff6ff);color:var(--info-700,#1d4ed8)}.email-tag-change_order{background:var(--danger-50,#fef2f2);color:var(--danger-700,#b91c1c)}.email-tag-contract{background:var(--neutral-100,#f3f4f6);color:var(--neutral-600,#4b5563)}.email-tag-permit{color:#6c3483;background:#9b59b61a}.email-tag-delivery{color:#0e6655;background:#1abc9c1a}.email-item-actions{opacity:0;transition:opacity var(--dur-fast);background:var(--bg-elevated);border-radius:var(--r-md);box-shadow:var(--shadow-sm);gap:2px;padding:2px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.email-unread-dot{background:var(--info-500,#3b82f6);border-radius:50%;width:7px;height:7px;position:absolute;top:50%;left:7px;transform:translateY(-50%)}.email-detail{flex-direction:column;display:flex;overflow:hidden}.email-detail-head{border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:16px;padding:18px 24px;display:flex}.email-detail-subject{letter-spacing:-.02em;color:var(--fg-1);margin-bottom:6px;font-size:17px;font-weight:700}.email-detail-from{color:var(--fg-2);font-size:13px}.email-actions-bar{border-bottom:1px solid var(--border);background:var(--bg-sunken);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 24px;display:flex}.email-body-wrap{background:var(--bg-elevated);flex:1;padding:20px 24px;overflow-y:auto}.email-reply-panel{border-top:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0;padding:14px 24px}.email-reply-input{border:1px solid var(--border);border-radius:var(--r-lg);width:100%;font:inherit;color:var(--fg-1);background:var(--bg-sunken);resize:vertical;transition:border-color var(--dur-base);outline:0;padding:12px 14px;font-size:14px}.email-reply-input:focus{border-color:var(--accent);background:var(--bg-elevated)}.compose-panel{flex-direction:column;gap:14px;max-width:720px;display:flex}.email-new-badge{background:var(--info-50,#eff6ff);color:var(--info-700,#1d4ed8);border:1px solid var(--info-500,#3b82f6);border-radius:var(--r-pill);align-items:center;gap:6px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.chip-count{background:var(--danger-500,#ef4444);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:15px;height:15px;margin-left:3px;font-size:9px;font-weight:700;display:inline-flex}[data-theme=dark] .email-list-panel{background:var(--bg-elevated)}[data-theme=dark] .email-item:hover{background:#ffffff0a}[data-theme=dark] .email-item.active{background:#c9a84c1f}[data-theme=dark] .email-detail-head{background:var(--bg-elevated)}[data-theme=dark] .email-actions-bar{background:var(--bg-sunken)}[data-theme=dark] .email-body-wrap{background:var(--bg-elevated)}[data-theme=dark] .email-item-actions{background:var(--bg-card,var(--bg-elevated))}[data-theme=dark] .email-reply-input{background:var(--bg-sunken);color:var(--fg-1)}[data-theme=dark] .email-reply-panel{background:var(--bg-elevated)}.ccq-toggle-bar{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}.ccq-toggle-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.ccq-badge{border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-fg);white-space:nowrap;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.toggle-btn{border-radius:var(--r-pill);background:var(--border-strong);cursor:pointer;width:44px;height:24px;transition:background var(--dur-base);border:0;flex-shrink:0;position:relative}.toggle-btn.active{background:var(--accent)}.toggle-knob{width:20px;height:20px;box-shadow:var(--shadow-sm);transition:transform var(--dur-base) var(--ease-out);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px}.toggle-btn.active .toggle-knob{transform:translate(20px)}.labor-line-card{background:var(--bg-sunken);border-radius:var(--r-lg);border:1px solid var(--border);flex-direction:column;gap:10px;margin:4px 0;padding:14px 16px;display:flex}.labor-line-head{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.labor-type-badge{border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-fg);white-space:nowrap;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.labor-select{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elevated);height:34px;color:var(--fg-1);transition:border-color var(--dur-fast);outline:0;padding:0 10px;font-size:13px}.labor-select:focus{border-color:var(--accent)}.labor-line-rates{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;padding-top:8px;display:flex}.labor-cost-info{align-items:center;gap:6px;display:flex}.labor-client-rate{align-items:center;gap:8px;display:flex}.labor-rate-input{width:140px;height:34px}.labor-warning{border-radius:var(--r-pill);align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.labor-warning.danger{background:var(--danger-50);color:var(--danger-700)}.labor-warning.warning{background:var(--warning-50);color:var(--warning-700)}.labor-warning.good{background:var(--success-50);color:var(--success-700)}.labor-breakdown{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);margin-top:4px;padding:16px}.breakdown-title{margin-bottom:4px;font-size:13px;font-weight:700}.breakdown-disclaimer{color:var(--warning-700);background:var(--warning-50);border-radius:var(--r-sm);margin-bottom:10px;padding:6px 10px;font-size:11px}.breakdown-grid{flex-direction:column;gap:4px;display:flex}.breakdown-row{color:var(--fg-2);border-bottom:1px solid var(--border);justify-content:space-between;padding:3px 0;font-size:12.5px;display:flex}.breakdown-row:last-child{border-bottom:0}.breakdown-row.total{color:var(--fg-1);border-top:2px solid var(--border-strong);border-bottom:0;padding-top:8px;font-size:13px;font-weight:600}.breakdown-row.recommended{color:var(--accent-fg);font-weight:700}.labor-summary{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);margin-top:16px;padding:16px}.labor-summary-title{align-items:center;gap:6px;margin-bottom:12px;font-size:13px;font-weight:700;display:flex}.labor-summary-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.ls-label{color:var(--fg-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;font-size:11px;font-weight:600}.ls-value{font-family:var(--font-mono);color:var(--fg-1);font-size:16px;font-weight:600}.ls-value.positive{color:var(--success-500)}.ls-value.warning{color:var(--warning-500)}.ls-value.negative{color:var(--danger-500)}.line-add-buttons{flex-wrap:wrap;gap:6px;padding:10px 0;display:flex}.btn-xs{border-radius:var(--r-sm);cursor:pointer;padding:3px 8px;font-size:11px}.sub-response-card{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;gap:8px;padding:14px 16px;display:flex}.sub-response-card.approved{background:var(--success-50);border-color:var(--success-100)}.compliance-badge{border-radius:var(--r-pill);align-items:center;gap:4px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-flex}.compliance-badge.good{background:var(--success-50);color:var(--success-700)}.compliance-badge.bad{background:var(--danger-50);color:var(--danger-700)}.sub-selector{border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-fast);align-items:center;gap:10px;padding:10px 12px;display:flex}.sub-selector:hover{border-color:var(--border-strong);background:var(--bg-sunken)}.sub-selector.selected{border-color:var(--accent);background:var(--accent-soft)}.email-tags-wrap{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elevated);cursor:text;min-height:36px;transition:border-color var(--dur-fast);flex-wrap:wrap;align-items:center;gap:4px;padding:4px 8px;display:flex}.email-tags-wrap:focus-within{border-color:var(--accent)}.email-recipient-tag{border-radius:var(--r-pill);background:var(--accent-soft);color:var(--accent-fg);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;max-width:220px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex;overflow:hidden}.email-recipient-tag button{cursor:pointer;color:inherit;opacity:.7;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.email-recipient-tag button:hover{opacity:1}.email-tag-input{min-width:100px;color:var(--fg-1);font-size:13px;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1;padding:0}.tb-notif-badge{background:var(--danger-500,#ef4444);color:#fff;text-align:center;pointer-events:none;border-radius:999px;min-width:16px;padding:2px 4px;font-size:9px;font-weight:700;line-height:1;position:absolute;top:2px;right:2px}.notif-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl,14px);width:340px;max-height:480px;box-shadow:var(--shadow-lg);z-index:2000;flex-direction:column;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notif-body{flex:1;overflow-y:auto}.notif-item{align-items:flex-start;gap:10px;padding:10px 14px;display:flex}.notif-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}@media print{.sidebar,.topbar,.editor-foot,.page-bar{display:none!important}.main-scroll{padding:0}.app{grid-template-columns:1fr}}[data-theme=dark] .input,[data-theme=dark] .input input,[data-theme=dark] .input textarea,[data-theme=dark] .input select{color:#f0ede8!important;background:#2e2a24!important}[data-theme=dark] input:not([type=checkbox]):not([type=radio]):not([type=range]),[data-theme=dark] textarea,[data-theme=dark] select{color:#f0ede8!important;background-color:#2e2a24!important;border-color:#3e3830!important}[data-theme=dark] .panel,[data-theme=dark] .modal,[data-theme=dark] .stat-card,[data-theme=dark] .proj-card,[data-theme=dark] .sel-card,[data-theme=dark] .sup-detail,[data-theme=dark] .sup-list,[data-theme=dark] .cal-main,[data-theme=dark] .cal-side,[data-theme=dark] .gantt-wrap,[data-theme=dark] .gantt-left,[data-theme=dark] .labor-line-card,[data-theme=dark] .labor-breakdown,[data-theme=dark] .labor-summary,[data-theme=dark] .sub-response-card,[data-theme=dark] .chart-panel,[data-theme=dark] .editor-foot,[data-theme=dark] .pinned-note{color:#f0ede8!important;background-color:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .tbl th{color:#686058!important;background-color:#161410!important}[data-theme=dark] .tbl td{color:#f0ede8!important;border-color:#2e2a24!important}[data-theme=dark] .tbl tbody tr:hover td{background-color:#2e2a24!important}[data-theme=dark] label,[data-theme=dark] .chip{color:#a09890!important}[data-theme=dark] .labor-select{color:#f0ede8!important;background:#2e2a24!important;border-color:#3e3830!important}[data-theme=dark] .breakdown-row{color:#a09890!important;border-color:#2e2a24!important}[data-theme=dark] .breakdown-row.total{color:#f0ede8!important}[data-theme=dark] .cal-kind-btn{color:#a09890!important;background:#242019!important;border-color:#3e3830!important}[data-theme=dark] .cal-kind-btn:hover{color:#f0ede8!important;background:#2e2a24!important}[data-theme=dark] .page-bar-right .btn-secondary,[data-theme=dark] .btn-secondary{color:#f0ede8!important;background:#242019!important;border-color:#3e3830!important}[data-theme=dark] .lang-pill button{color:#686058!important}[data-theme=dark] .lang-pill button.on{color:#f0ede8!important;background:#2e2a24!important}[data-theme=dark] .sb-section-label{color:#4a443c!important}[data-theme=dark] .tb-search{background:#161410!important;border-color:#2e2a24!important}[data-theme=dark] .tb-search input{color:#f0ede8!important;background:0 0!important}.quick-fab{background:var(--accent);color:#fff;cursor:pointer;z-index:90;width:52px;height:52px;transition:all var(--dur-base) var(--ease-spring);border:0;border-radius:50%;place-items:center;display:grid;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #c9a84c80}.quick-fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #c9a84ca6}.quick-fab.open{background:#3a3530;transform:rotate(45deg);box-shadow:0 4px 16px #0000004d}[data-theme=dark] .quick-fab{box-shadow:0 4px 20px #c9a84c59}[data-theme=dark] .quick-fab.open{background:#2e2a24}.quick-card{background:var(--bg-elevated);border:1px solid var(--border);width:280px;box-shadow:var(--shadow-xl);z-index:89;animation:slide-up var(--dur-slow) var(--ease-out);border-radius:20px;position:fixed;bottom:92px;right:28px;overflow:hidden}[data-theme=dark] .quick-card{background:#242019!important;border-color:#2e2a24!important}.quick-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.quick-card-title{text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-size:11px;font-weight:700}.quick-card-item{border:0;border-bottom:1px solid var(--border);text-align:left;cursor:pointer;width:100%;transition:background var(--dur-fast);font-family:var(--font-sans);background:0 0;align-items:center;gap:12px;padding:12px 16px;display:flex}.quick-card-item:last-child{border-bottom:0}.quick-card-item:hover{background:var(--bg-sunken)}.quick-card-icon{border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.quick-card-text{flex:1;min-width:0}.quick-card-label{color:var(--fg-1);font-size:13.5px;font-weight:600}.quick-card-sub{color:var(--fg-3);margin-top:1px;font-size:11.5px}[data-theme=dark] .quick-card-sub,[data-theme=dark] .quick-card-title{color:#686058!important}.ai-drawer-scrim{z-index:149;background:0 0;position:fixed;inset:0}.ai-drawer{background:var(--bg-elevated);border-left:1px solid var(--border);width:380px;box-shadow:var(--shadow-xl);z-index:150;animation:slide-in-right var(--dur-slow) var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0}.ai-drawer-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}[data-theme=dark] .ai-drawer-head{border-color:#2e2a24!important}.ai-drawer-avatar{background:var(--accent-soft);width:32px;height:32px;color:var(--accent);border-radius:10px;place-items:center;display:grid}@keyframes slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:none}}[data-theme=dark] .finances-grid-2col>.panel{background:#242019!important;border-color:#2e2a24!important}.cal-root{flex-direction:column;gap:12px;height:calc(100vh - 58px);padding:20px 32px 0;display:flex;overflow:hidden}.cal-toolbar{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;display:flex}.cal-nav{align-items:center;gap:4px;display:flex}.cal-month-label{letter-spacing:-.02em;color:var(--fg-1);white-space:nowrap;text-transform:capitalize;margin-left:6px;font-size:16px;font-weight:700}.cal-view-switcher{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-xl);gap:2px;padding:3px;display:flex}.cal-view-btn{color:var(--fg-2);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-fast);white-space:nowrap;background:0 0;border:0;align-items:center;gap:5px;padding:6px 12px;font-size:12.5px;font-weight:600;display:inline-flex}.cal-view-btn:hover{color:var(--fg-1)}.cal-view-btn.active{background:var(--bg-elevated);color:var(--fg-1);box-shadow:var(--shadow-xs)}.cal-filters{flex-wrap:wrap;flex-shrink:0;gap:4px;display:flex}.cal-kind-btn{border-radius:var(--r-pill);border:1px solid var(--border);background:var(--bg-elevated);color:var(--fg-2);cursor:pointer;transition:all var(--dur-fast);white-space:nowrap;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-flex}.cal-kind-btn:hover{border-color:var(--border-strong);color:var(--fg-1)}.cal-kind-btn.active{font-weight:700}.cal-stats-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);flex-wrap:wrap;flex-shrink:0;gap:16px;padding:10px 16px;display:flex}.cal-stat{align-items:center;gap:6px;display:flex}.cal-stat-value{font-family:var(--font-mono);color:var(--fg-1);font-size:14px;font-weight:600}.cal-stat-label{color:var(--fg-3);font-size:11.5px}.cal-view-container{flex:1;min-height:0;overflow:hidden}.cal-month-grid{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;height:100%;display:flex;overflow:hidden}.cal-dow-row{background:var(--bg-sunken);border-bottom:1px solid var(--border);flex-shrink:0;grid-template-columns:repeat(7,1fr);display:grid}.cal-dow{text-align:center;text-transform:uppercase;letter-spacing:.07em;color:var(--fg-3);padding:10px 0;font-size:11px;font-weight:700}.cal-grid{flex:1;grid-template-columns:repeat(7,1fr);display:grid;overflow-y:auto}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--dur-fast);flex-direction:column;gap:3px;min-height:80px;padding:6px;display:flex}.cal-cell.other{opacity:.4;background:var(--bg-sunken)}.cal-cell.weekend{background:#00000004}[data-theme=dark] .cal-cell.weekend{background:#ffffff05}.cal-cell.today{background:var(--accent-soft)}.cal-cell.selected{outline:2px solid var(--accent);outline-offset:-2px}.cal-cell-head{justify-content:space-between;align-items:center;display:flex}.cal-date-num{color:var(--fg-2);border-radius:50%;place-items:center;width:26px;height:26px;font-size:13px;font-weight:600;display:grid}.cal-date-num.today-dot{background:var(--accent);color:#fff;font-weight:700}.cal-weather-icon{align-items:center;gap:2px;font-size:12px;display:flex}.cal-temp{color:var(--fg-3);font-size:9.5px;font-family:var(--font-mono)}.cal-project-bar{border-radius:2px;align-items:center;height:14px;margin:1px 0;padding:0 4px;font-size:9px;display:flex;overflow:hidden}.cal-events{flex-direction:column;gap:2px;display:flex}.cal-event-pill{border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:4px;padding:2px 6px;font-size:11px;font-weight:600;display:flex;overflow:hidden}.cal-event-pill:hover{opacity:.8}.cal-event-time{font-family:var(--font-mono);opacity:.8;flex-shrink:0;font-size:9.5px}.cal-event-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-event-more{color:var(--fg-3);padding:2px 4px;font-size:10px;font-weight:600}.cal-week-root{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;height:100%;display:flex;overflow:hidden}.cal-week-header{border-bottom:1px solid var(--border);background:var(--bg-sunken);flex-shrink:0;grid-template-columns:56px repeat(7,1fr);display:grid}.cal-week-time-gutter{border-right:1px solid var(--border)}.cal-week-day-header{text-align:center;border-right:1px solid var(--border);padding:10px 8px}.cal-week-day-header:last-child{border-right:0}.cal-week-day-header.today{background:var(--accent-soft)}.cal-week-dow{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-3);font-size:11px;font-weight:700}.cal-week-date{color:var(--fg-1);margin-top:2px;font-size:18px;font-weight:700}.cal-week-date.today-dot{color:var(--accent)}.cal-week-weather{color:var(--fg-3);margin-top:2px;font-size:10px}.cal-week-body{flex:1;grid-template-columns:56px repeat(7,1fr);display:grid;position:relative;overflow-y:auto}.cal-week-gutter{border-right:1px solid var(--border)}.cal-week-hour-label{height:56px;font-size:11px;font-family:var(--font-mono);color:var(--fg-3);flex-shrink:0;justify-content:flex-end;align-items:flex-start;padding:4px 8px 0 0;display:flex}.cal-week-col{border-right:1px solid var(--border);position:relative}.cal-week-col:last-child{border-right:0}.cal-week-col.today{background:#c9a84c0a}.cal-week-col.weekend{background:#00000004}[data-theme=dark] .cal-week-col.weekend{background:#ffffff05}.cal-week-slot{border-bottom:1px solid var(--border);cursor:pointer;height:56px;transition:background var(--dur-fast)}.cal-week-slot:hover{background:var(--bg-sunken)}.cal-week-slot:nth-child(2n){border-bottom-color:var(--border);opacity:.6}.cal-week-event{border-radius:var(--r-md);cursor:pointer;transition:opacity var(--dur-fast);z-index:1;padding:4px 6px;position:absolute;left:2px;right:2px;overflow:hidden}.cal-week-event:hover{opacity:.85;z-index:2}.cal-week-event-title{text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.cal-week-event-time{opacity:.8;font-size:10.5px;font-family:var(--font-mono);margin-top:2px}.cal-week-event-client{opacity:.7;text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:3px;margin-top:1px;font-size:10.5px;display:flex;overflow:hidden}.cal-today-line{background:var(--danger-500,#ef4444);z-index:3;pointer-events:none;height:2px;position:absolute;left:0;right:0}.cal-today-dot{background:var(--danger-500,#ef4444);border-radius:50%;width:8px;height:8px;position:absolute;top:-3px;left:-4px}.cal-day-root{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;height:100%;display:flex;overflow:hidden}.cal-day-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.cal-day-title{color:var(--fg-1);text-transform:capitalize;font-size:18px;font-weight:700}.cal-day-sub{color:var(--fg-3);margin-top:3px;font-size:12px}.cal-day-weather-card{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);align-items:center;gap:12px;padding:10px 16px;display:flex}.cal-day-grid{flex:1;grid-template-columns:56px 1fr;display:grid;overflow-y:auto}.cal-day-gutter{border-right:1px solid var(--border)}.cal-day-col{position:relative}.cal-year-grid{grid-template-columns:repeat(4,1fr);gap:16px;height:100%;padding-bottom:20px;display:grid;overflow-y:auto}@media (width<=1200px){.cal-year-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.cal-year-grid{grid-template-columns:repeat(2,1fr)}}.cal-year-month{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px}.cal-year-month-header{cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cal-year-month-name{color:var(--fg-1);text-transform:capitalize;font-size:13px;font-weight:700}.cal-year-month-count{background:var(--accent-soft);color:var(--accent-fg);border-radius:var(--r-pill);padding:2px 8px;font-size:11px;font-weight:700}.cal-year-dow-row{grid-template-columns:repeat(7,1fr);margin-bottom:4px;display:grid}.cal-year-dow{text-transform:uppercase;color:var(--fg-3);text-align:center;padding:2px 0;font-size:9px;font-weight:700}.cal-year-cells{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-year-cell{aspect-ratio:1;color:var(--fg-2);border-radius:var(--r-sm);cursor:pointer;transition:all var(--dur-fast);place-items:center;font-size:10.5px;font-weight:500;display:grid}.cal-year-cell:hover{background:var(--bg-sunken);color:var(--fg-1)}.cal-year-cell.other{color:#0000;cursor:default;pointer-events:none}.cal-year-cell.today{background:var(--accent);font-weight:700;color:#fff!important}.cal-agenda{flex-direction:column;gap:0;height:100%;padding-bottom:20px;display:flex;overflow-y:auto}.cal-agenda-day{flex-direction:column;display:flex}.cal-agenda-date-header{border-bottom:2px solid var(--border);background:var(--bg);z-index:2;justify-content:space-between;align-items:center;margin-bottom:8px;padding:16px 0 8px;display:flex;position:sticky;top:0}.cal-agenda-date-label{color:var(--fg-1);text-transform:capitalize;font-size:14px;font-weight:700}.cal-agenda-date-label.today{color:var(--accent-fg)}.cal-agenda-weather{color:var(--fg-3);font-size:12px}.cal-agenda-events{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.cal-agenda-event{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all var(--dur-fast);align-items:flex-start;gap:12px;padding:12px 16px;display:flex}.cal-agenda-event:hover{box-shadow:var(--shadow-md);transform:translate(2px)}.cal-agenda-event-time{min-width:52px;font-family:var(--font-mono);color:var(--fg-1);flex-direction:column;flex-shrink:0;gap:2px;padding-top:2px;font-size:13px;font-weight:600;display:flex}.cal-agenda-event-body{flex:1;min-width:0}.cal-agenda-event-kind{border-radius:var(--r-pill);align-items:center;gap:4px;margin-bottom:4px;padding:2px 8px;font-size:10.5px;font-weight:700;display:inline-flex}.cal-agenda-event-title{color:var(--fg-1);font-size:14px;font-weight:700}.cal-agenda-event-meta{color:var(--fg-3);align-items:center;gap:4px;margin-top:3px;font-size:12px;display:flex}.cal-agenda-event-notes{color:var(--fg-2);margin-top:4px;font-size:12px;font-style:italic}.cal-agenda-past{margin-top:16px}[data-theme=dark] .cal-month-grid,[data-theme=dark] .cal-week-root,[data-theme=dark] .cal-day-root{background:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .cal-dow-row,[data-theme=dark] .cal-week-header{background:#161410!important}[data-theme=dark] .cal-cell{border-color:#2e2a24!important}[data-theme=dark] .cal-cell:hover{background:#2e2a24!important}[data-theme=dark] .cal-week-slot{border-color:#2e2a24!important}[data-theme=dark] .cal-week-slot:hover{background:#2e2a24!important}[data-theme=dark] .cal-agenda-event,[data-theme=dark] .cal-year-month,[data-theme=dark] .cal-stats-bar{background:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .cal-day-weather-card{background:#161410!important;border-color:#2e2a24!important}[data-theme=dark] .cal-agenda-date-header{background:#1a1712!important}@media (width<=768px){.cal-root{padding:12px 12px 0}.cal-toolbar{gap:6px}.cal-view-switcher{display:none}.cal-month-label{font-size:14px}.cal-year-grid{grid-template-columns:repeat(2,1fr)}.cal-stats-bar{display:none}}@media print{.cal-toolbar,.cal-filters,.cal-stats-bar,.sidebar,.topbar{display:none!important}.cal-root{height:auto!important;padding:0!important}.cal-view-container{height:auto!important;overflow:visible!important}.cal-week-body{overflow:visible!important}.cal-week-root{height:auto!important}}.quote-section-row td{padding:0}.quote-section-header{background:var(--accent-soft);border-top:2px solid var(--accent);border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 16px;display:flex}.quote-section-input{color:var(--accent-fg);letter-spacing:.02em;background:0 0;border:0;outline:0;flex:1;font-size:13px;font-weight:700}[data-theme=dark] .quote-section-header{background:#c9a84c1f!important}.visibility-panel{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);margin-top:8px;overflow:hidden}.visibility-panel-trigger{cursor:pointer;color:var(--fg-2);transition:background var(--dur-fast);align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:600;list-style:none;display:flex}.visibility-panel-trigger:hover{background:var(--bg-overlay)}.visibility-grid{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:10px;padding:14px 16px;display:grid}.vis-toggle{color:var(--fg-2);cursor:pointer;align-items:center;gap:7px;font-size:12.5px;display:flex}@media (width<=768px){.visibility-grid{grid-template-columns:repeat(2,1fr)}}[data-theme=dark] .visibility-panel{background:#161410!important;border-color:#2e2a24!important}.client-preview-overlay{z-index:200;animation:fade-in var(--dur-base) ease;background:#e8e4dd;flex-direction:column;display:flex;position:fixed;inset:0}.client-preview-toolbar{background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 32px;display:flex}.client-preview-body{flex:1;justify-content:center;align-items:flex-start;padding:40px 20px;display:flex;overflow-y:auto}.receipt-upload-area{border:2px dashed var(--border);border-radius:var(--r-lg);transition:all var(--dur-base);cursor:pointer;background:var(--bg-sunken)}.receipt-upload-area:hover{border-color:var(--accent);background:var(--accent-soft)}[data-theme=dark] .receipt-upload-area{background:#161410!important;border-color:#2e2a24!important}.expense-category-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.expense-cat-btn{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-elevated);color:var(--fg-2);cursor:pointer;transition:all var(--dur-fast);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:10.5px;font-weight:600;display:flex}.expense-cat-btn:hover{border-color:var(--border-strong);color:var(--fg-1)}.expense-cat-btn.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-fg)}[data-theme=dark] .expense-cat-btn{background:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .expense-cat-btn.active{background:#c9a84c24!important}.expense-summary-bar{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);flex-shrink:0;gap:0;display:flex;overflow:hidden}.exp-sum-item{border-right:1px solid var(--border);flex-direction:column;flex:1;gap:3px;padding:12px 16px;display:flex}.exp-sum-item:last-child{border-right:0}.exp-sum-label{color:var(--fg-3);font-size:11px;font-weight:600}.exp-sum-value{font-family:var(--font-mono);color:var(--fg-1);font-size:16px;font-weight:600}[data-theme=dark] .expense-summary-bar{background:#242019!important;border-color:#2e2a24!important}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.b-partial{color:#0e8a6e;background:#1abc9c24}.b-partial .dot{background:#1abc9c}.getting-started-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);padding:20px}.gs-head{justify-content:space-between;align-items:flex-start;display:flex}.gs-item{border-bottom:1px solid var(--border);cursor:pointer;color:var(--fg-1);transition:all var(--dur-fast);align-items:center;gap:10px;padding:10px 4px;font-size:13.5px;display:flex}.gs-item:last-child{border-bottom:0}.gs-item:hover:not(.done){color:var(--accent-fg)}.gs-item.done{color:var(--fg-3);cursor:default;text-decoration:line-through}.gs-check{border:2px solid var(--border);border-radius:50%;flex-shrink:0;place-items:center;width:20px;height:20px;display:grid}.gs-check.done{background:var(--success-500,#22c55e);border-color:var(--success-500,#22c55e);color:#fff}[data-theme=dark] .getting-started-card{background:#242019!important;border-color:#2e2a24!important}.catalog-dropdown{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xl);z-index:50;max-height:280px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto}[data-theme=dark] .catalog-dropdown{background:#242019!important;border-color:#2e2a24!important}.catalog-suggestion{cursor:pointer;transition:background var(--dur-fast);border-bottom:1px solid var(--border);padding:10px 14px}.catalog-suggestion:last-child{border-bottom:0}.catalog-suggestion:hover{background:var(--bg-sunken)}.catalog-sug-main{align-items:center;gap:6px;display:flex}.catalog-sug-meta{align-items:center;gap:10px;margin-top:2px;display:flex}.catalog-add-new{background:var(--accent-soft);align-items:center;gap:8px;display:flex}.catalog-add-new:hover{opacity:.85}.internal-summary-panel{border-radius:var(--r-lg);background:#1a1a1a;border:1px dashed #3a3a3a;margin-top:16px;padding:16px}[data-theme=light] .internal-summary-panel{background:#1c1a17;border-color:#2e2a24}.internal-summary-badge{color:#686058;text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;margin-bottom:12px;font-size:10px;font-weight:700;display:flex}.internal-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;display:grid}.int-sum-section{flex-direction:column;gap:5px;display:flex}.int-sum-title{text-transform:uppercase;letter-spacing:.07em;color:#686058;margin-bottom:4px;font-size:10px;font-weight:700}.int-sum-row{color:#a09890;justify-content:space-between;font-size:12px;display:flex}.int-sum-row.total{color:#f0ede8;border-top:1px solid #2e2a24;margin-top:3px;padding-top:5px;font-weight:700}.margin-alert{border-radius:8px;align-items:center;gap:8px;margin-top:12px;padding:10px 14px;font-size:12.5px;font-weight:600;display:flex}.margin-alert.danger{color:#f08070;background:#c94a3226;border:1px solid #c94a324d}.margin-alert.warning{color:#f0c060;background:#f0a03026;border:1px solid #f0a0304d}.markup-profile-bar{background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-lg);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;padding:10px 16px;display:flex}.billing-progress-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px}.billing-progress-header{justify-content:space-between;align-items:flex-start;display:flex}[data-theme=dark] .billing-progress-card{background:#242019!important;border-color:#2e2a24!important}.billing-method-grid{flex-direction:column;gap:6px;display:flex}.billing-method-card{border:1.5px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);cursor:pointer;transition:all var(--dur-fast);text-align:left;align-items:center;gap:12px;width:100%;padding:12px 16px;display:flex}.billing-method-card:hover{border-color:var(--border-strong)}.billing-method-card.active{border-color:var(--accent);background:var(--accent-soft)}.billing-method-icon{background:var(--bg-sunken);width:36px;height:36px;color:var(--fg-2);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.billing-method-card.active .billing-method-icon{background:var(--accent);color:#fff}.billing-method-text{flex:1;min-width:0}.billing-method-label{color:var(--fg-1);font-size:13.5px;font-weight:600}.billing-method-desc{color:var(--fg-3);margin-top:1px;font-size:11.5px}[data-theme=dark] .billing-method-card{background:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .billing-method-card.active{background:#c9a84c1f!important;border-color:#c9a84c!important}.billing-line-row{border:1.5px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);transition:all var(--dur-fast);align-items:center;gap:12px;padding:10px 14px;display:flex}.billing-line-row.selected{border-color:var(--accent);background:var(--accent-soft)}.billing-line-row.fully-billed{opacity:.5;cursor:not-allowed;background:var(--bg-sunken)}[data-theme=dark] .billing-line-row{background:#242019!important;border-color:#2e2a24!important}[data-theme=dark] .billing-line-row.selected{background:#c9a84c1a!important;border-color:#c9a84c!important}.billing-summary-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);padding:18px}[data-theme=dark] .billing-summary-card{background:#242019!important;border-color:#2e2a24!important}.billing-tracker-table th{font-size:10.5px}.billing-tracker-table td{vertical-align:middle}.cell-select{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-elevated);height:28px;color:var(--fg-1);outline:0;padding:0 6px;font-size:11.5px}.cell-input-wrap{align-items:center;display:flex;position:relative}[data-theme=dark] .cell-select{color:#f0ede8!important;background:#2e2a24!important;border-color:#3e3830!important}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{box-shadow:var(--shadow-lg);border-color:var(--border-strong);transform:translateY(-3px)}.stat-card.clickable .sc-arrow{color:var(--accent);opacity:0;transition:opacity var(--dur-fast);margin-left:auto}.stat-card.clickable:hover .sc-arrow{opacity:1}.tbl th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:color var(--dur-fast)}.tbl th.sortable:hover{color:var(--fg-2);background:var(--bg-elevated)}.tbl th.sortable .sort-icon{opacity:.35;vertical-align:middle;margin-left:4px;font-size:9px;line-height:1;display:inline-block}.tbl th.sortable.asc .sort-icon,.tbl th.sortable.desc .sort-icon{opacity:.85;color:var(--accent)}.tbl tbody tr.row-pending>td:first-child{box-shadow:inset 3px 0 0 var(--warning-400)}.badge-new{color:var(--info-700);background:var(--info-50);border:1px solid var(--info-100);border-radius:var(--r-pill);letter-spacing:.04em;text-transform:uppercase;vertical-align:middle;align-items:center;margin-left:5px;padding:1px 5px;font-size:9px;font-weight:800;display:inline-flex}[data-theme=dark] .badge-new{color:#80b4e8!important;background:#3b82f62e!important;border-color:#3b82f64d!important}.tag-cat{color:var(--fg-3);background:var(--bg-sunken);border:1px solid var(--border);border-radius:var(--r-pill);align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.price-foot{border-top:1px solid var(--border);background:var(--bg-sunken);color:var(--fg-3);align-items:center;gap:10px;padding:10px 16px;font-size:12px;display:flex}.price-foot .meta{color:var(--fg-3);font-size:12px}.tb-titles{flex-direction:column;display:flex}.tb-title{letter-spacing:-.02em;color:var(--fg-1);white-space:nowrap;font-size:17px;font-weight:700;line-height:1.15}.tb-subtitle{color:var(--fg-3);margin-top:1px;font-size:11.5px}.btn,.proj-card,.sel-card,.stat-card,.chip,.panel{will-change:auto}.btn:not(:disabled):active{transition-duration:60ms!important;transform:scale(.97)!important}.icon-btn:active{transform:scale(.88)!important}.proj-card:hover{transition-duration:.12s!important}.sb-item,.icon-btn{transition:background 80ms,color 80ms!important}.tbl tbody tr{transition:background 80ms!important}.quick-card,.quick-fab{pointer-events:auto}.main{z-index:1}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-feature-settings:"kern" 1, "liga" 1}.num,.price,.amount,[class*=-amount],[class*=-value],[class*=-price],[class*=-total],[class*=-balance],.stat-value,.totals-amount,.price-item-amount,td.amount,.cell-num,.invoice-amount{font-variant-numeric:tabular-nums!important;font-feature-settings:"tnum" 1, "zero" 1!important;-webkit-font-smoothing:antialiased!important;letter-spacing:-.025em!important;font-family:DM Mono,SF Mono,ui-monospace,monospace!important;font-weight:600!important}.tbl td:last-child,.tbl .col-amount,.tbl .col-total{font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;letter-spacing:-.02em;font-family:DM Mono,ui-monospace,monospace;font-weight:600}.tbl tbody tr.row-overdue>td:first-child{box-shadow:inset 4px 0 0 var(--danger-500)!important}.tbl tbody tr.row-paid>td:first-child{box-shadow:inset 4px 0 0 var(--success-500)!important}.tbl tbody tr.row-draft>td:first-child{box-shadow:inset 4px 0 0 var(--fg-muted)!important}.tbl tbody tr.row-sent>td:first-child{box-shadow:inset 4px 0 0 var(--info-500)!important}.tbl tbody tr.row-partial>td:first-child{box-shadow:inset 4px 0 0 var(--warning-500)!important}.tbl tbody tr.row-accepted>td:first-child{box-shadow:inset 4px 0 0 var(--success-500)!important}.tbl tbody tr.row-cancelled>td:first-child{box-shadow:inset 4px 0 0 var(--fg-muted)!important}.stat-card.clickable{cursor:pointer;transition:all var(--dur-base) var(--ease-out)!important}.stat-card.clickable:hover{border-color:var(--accent)!important;box-shadow:var(--shadow-md)!important;transform:translateY(-2px)!important}.stat-card.clickable:active{transform:translateY(0)scale(.99)!important}.tbl tbody tr.clickable{cursor:pointer}.tbl tbody tr.clickable:hover td{background:var(--bg-sunken)}.tbl tbody tr.clickable:hover .row-actions{opacity:1}.row-actions{opacity:0;transition:opacity var(--dur-fast);align-items:center;gap:4px;display:flex}.cal-stats-bar{flex-wrap:wrap;flex-shrink:0;gap:8px;margin-bottom:12px;display:flex}.cal-stat-pill{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-xl);align-items:center;gap:10px;padding:8px 14px;display:flex}.cal-stat-pill-icon{border-radius:var(--r-md);flex-shrink:0;place-items:center;width:32px;height:32px;display:grid}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme=dark] input:not([type=checkbox]):not([type=radio]):not([type=range]),[data-theme=dark] textarea{color:#f0ede8!important;background-color:#0000!important}[data-theme=dark] select{color:#f0ede8!important;background-color:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] select option{color:#f0ede8;background:#1e1c18}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:#4a443c!important;opacity:1!important}[data-theme=dark] .input{background:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] .input:focus-within{border-color:#c9a84c!important;box-shadow:0 0 0 3px #c9a84c33!important}[data-theme=dark] .panel,[data-theme=dark] .stat-card,[data-theme=dark] .proj-card,[data-theme=dark] .modal,[data-theme=dark] .editor-section,[data-theme=dark] .billing-summary-card,[data-theme=dark] .cal-stats-bar,[data-theme=dark] .cal-stat-pill,[data-theme=dark] .report-card{background:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] .panel-head,[data-theme=dark] .tbl th{background:#141210!important;border-color:#2a2620!important}[data-theme=dark] .tbl td{border-color:#1e1c18!important}[data-theme=dark] .tbl tbody tr.clickable:hover td{background:#2a2620!important}[data-theme=dark] .chip{background:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] .chip.is-on{color:#141210!important;background:#f0ede8!important}[data-theme=dark] .quick-card,[data-theme=dark] .quick-menu-item{background:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] .quick-card-label{color:#f0ede8!important}[data-theme=dark] .quick-card-sub{color:#706860!important}[data-theme=dark] .quick-card-item:hover{background:#2a2620!important}[data-theme=dark] .ai-drawer,[data-theme=dark] .cal-week-root,[data-theme=dark] .cal-month-grid,[data-theme=dark] .cal-day-root{background:#1e1c18!important;border-color:#2a2620!important}.doc-number{white-space:nowrap!important;font-variant-numeric:tabular-nums!important;letter-spacing:-.01em!important;-webkit-font-smoothing:antialiased!important;-moz-osx-font-smoothing:grayscale!important;font-family:DM Mono,ui-monospace,monospace!important;font-size:13px!important;font-weight:700!important}.dash-section+.dash-section{margin-top:24px}[data-theme=dark] .pricedb-sidebar{background:#1e1c18!important;border-color:#2a2620!important}[data-theme=dark] .pricedb-cat-btn{color:#b0a898!important}[data-theme=dark] .pricedb-cat-btn.active{color:#d4b86a!important;background:#c9a84c24!important}[data-theme=dark] .sup-list-item{border-color:#2a2620!important}[data-theme=dark] .sup-list-item:hover{background:#2a2620!important}[data-theme=dark] .sup-list-item.active{background:#c9a84c1a!important}[data-theme=dark] .report-card:hover{border-color:#c9a84c!important}.takeoff-grid{grid-template-columns:420px 1fr;align-items:start;gap:16px;display:grid}@media (width<=1100px){.takeoff-grid{grid-template-columns:1fr}}.ta{resize:vertical;border:1px solid var(--border);width:100%;font:inherit;color:var(--fg-1);background:#fff;border-radius:10px;min-height:100px;padding:12px 14px;font-size:13.5px;line-height:1.55;transition:all .18s}.ta:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:0}.dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--neutral-50);border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:36px 20px;transition:all .18s;display:flex}.dropzone:hover{border-color:var(--accent);background:var(--brand-gold-50)}.dz-title{color:var(--fg-1);font-size:14px;font-weight:600}.dz-sub{color:var(--fg-3);font-size:12px}.empty{color:var(--fg-3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:60px 20px;font-size:13px;display:flex}.tag-cat{letter-spacing:.04em;color:var(--brand-gold-700);background:var(--brand-gold-50);border:1px solid var(--brand-gold-100);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.tbl-lines tr.is-off td{opacity:.35}.chk{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}.takeoff-foot{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;margin-top:2px;padding-top:14px;display:flex}.takeoff-sum{flex-direction:column;gap:2px;display:flex}.ai-summary{background:var(--brand-gold-50);border:1px solid var(--brand-gold-100);color:var(--fg-2);border-radius:10px;align-items:flex-start;gap:8px;padding:10px 12px;font-size:12.5px;line-height:1.45;display:flex}.margins{border-top:1px dashed var(--border);grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px;padding-top:14px;display:grid}.margin-field label{text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3);margin-bottom:5px;font-size:11px;font-weight:600;display:block}.totals .tr.muted-tr{color:var(--fg-3);font-size:12.5px}.totals .tr.tr-pretax{border-top:1px dashed var(--border);color:var(--fg-1);margin-top:4px;padding-top:8px;font-weight:500}.totals .tr.tr-deposit{background:var(--brand-gold-50);color:var(--brand-gold-700);border-radius:6px;margin-top:6px;padding:6px 10px;font-weight:600}.cell-in{width:100%;font:inherit;color:var(--fg-1);background:0 0;border:0;outline:0;padding:2px 0;font-size:13px}.cell-in:focus{background:var(--neutral-50);border-radius:4px;padding:2px 6px}.cell-sku{color:var(--fg-3);letter-spacing:.03em;margin-top:2px;font-size:10.5px}.edit-lines td{vertical-align:middle;padding:8px 10px}.picker-list{border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:2px;max-height:420px;padding:6px;display:flex;overflow-y:auto}.picker-row{text-align:left;cursor:pointer;font:inherit;color:var(--fg-1);background:0 0;border:0;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:all .12s;display:flex}.picker-row:hover{background:var(--brand-gold-50)}.picker-name{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.picker-name>span:first-child{font-size:13px;font-weight:500}.picker-sku{color:var(--fg-3);font-size:10.5px}.selectish{border:1px solid var(--border);font:inherit;color:var(--fg-1);cursor:pointer;background:#fff;border-radius:8px;min-width:140px;padding:8px 12px;font-size:13px}.selectish:focus{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:0}.icon-btn{color:var(--fg-3);cursor:pointer;background:0 0;border:0;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:all .14s;display:inline-flex}.icon-btn:hover{background:var(--neutral-100);color:var(--fg-1)}.icon-btn.danger:hover{background:var(--danger-50);color:var(--danger-500)}.price-foot{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:4px;padding-top:12px;display:flex}.preview-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.preview-head h3{font-size:13px;font-weight:600}.err{color:var(--danger-500);background:var(--danger-50);border-radius:8px;padding:8px 12px;font-size:12px}.col-map{grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin-bottom:14px;display:grid}.modal-scrim{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.14s fade-in;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;animation:.18s slide-up;overflow-y:auto;box-shadow:0 24px 64px #0000002e}.modal-lg{max-width:760px}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-head h2{font-size:15px;font-weight:700}.modal-body{padding:20px 24px}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.pdf-overlay{z-index:300;background:#e8e8e8;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.pdf-toolbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;height:52px;padding:0 20px;display:flex}.pdf-toolbar-left{align-items:center;gap:10px;display:flex}.pdf-toolbar-right{align-items:center;gap:8px;display:flex}.pdf-scroll{flex:1;justify-content:center;padding:32px 20px;display:flex;overflow-y:auto}.pdf-page{background:#fff;flex-direction:column;width:816px;min-height:1056px;padding:64px 72px;display:flex;box-shadow:0 4px 24px #00000024}.pdf-header{border-bottom:2px solid var(--brand-gold-500);justify-content:space-between;align-items:flex-start;margin-bottom:36px;padding-bottom:24px;display:flex}.pdf-co-name{letter-spacing:-.02em;color:var(--fg-1);font-size:18px;font-weight:800}.pdf-co-sub{color:var(--fg-3);font-size:11px}.pdf-doc-meta{text-align:right}.pdf-doc-type{text-transform:uppercase;letter-spacing:.04em;color:var(--brand-gold-600);font-size:22px;font-weight:800}.pdf-doc-num{color:var(--fg-3);margin-top:2px;font-size:13px}.pdf-doc-date{color:var(--fg-3);font-size:12px}.pdf-parties{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:32px;display:grid}.pdf-party-label{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-3);margin-bottom:6px;font-size:10px;font-weight:700}.pdf-party-name{color:var(--fg-1);font-size:14px;font-weight:600}.pdf-party-addr{color:var(--fg-2);margin-top:3px;font-size:12px;line-height:1.5}.pdf-table{border-collapse:collapse;width:100%;margin-bottom:24px;font-size:12.5px}.pdf-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-3);border-bottom:1px solid var(--border);padding:0 10px 8px;font-size:10px;font-weight:700}.pdf-table td{border-bottom:1px solid var(--neutral-100);vertical-align:top;padding:9px 10px}.pdf-table tr:last-child td{border-bottom:none}.pdf-totals{width:280px;margin-bottom:32px;margin-left:auto}.pdf-total-row{justify-content:space-between;padding:5px 0;font-size:12.5px;display:flex}.pdf-total-row.strong{border-top:2px solid var(--fg-1);margin-top:4px;padding-top:10px;font-size:14px;font-weight:700}.pdf-total-row.gold{color:var(--brand-gold-700);font-weight:600}.pdf-sig{border-top:1px solid var(--border);grid-template-columns:1fr 1fr;gap:40px;margin-top:auto;padding-top:32px;display:grid}.pdf-sig-line{border-top:1px solid var(--fg-2);color:var(--fg-3);margin-top:48px;padding-top:6px;font-size:11px}.pdf-legal{border-top:1px solid var(--neutral-100);color:var(--fg-3);margin-top:24px;padding-top:16px;font-size:10.5px;line-height:1.5}@media print{.pdf-overlay{background:#fff;position:static}.pdf-toolbar{display:none}.pdf-scroll{padding:0;overflow:visible}.pdf-page{box-shadow:none;width:100%;padding:20mm 25mm}}.cal-toolbar{align-items:center;gap:10px;margin-bottom:16px;display:flex}.cal-toolbar h2{flex:1;font-size:16px;font-weight:700}.cal-grid{border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}.cal-dow{background:var(--neutral-50);grid-template-columns:repeat(7,1fr);display:grid}.cal-dow span{text-transform:uppercase;letter-spacing:.05em;color:var(--fg-3);text-align:center;padding:8px 10px;font-size:11px;font-weight:700}.cal-cells{grid-template-columns:repeat(7,1fr);display:grid}.cal-cell{border-top:1px solid var(--border);border-right:1px solid var(--border);cursor:pointer;min-height:96px;padding:6px 8px;transition:all .1s;position:relative}.cal-cell:nth-child(7n){border-right:none}.cal-cell:hover,.cal-cell.is-today{background:var(--brand-gold-50)}.cal-cell.is-today .cal-day{background:var(--brand-gold-500);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.cal-cell.other-month{background:var(--neutral-50)}.cal-day{color:var(--fg-2);margin-bottom:4px;font-size:12px;font-weight:600}.cal-event{white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:4px;margin-bottom:2px;padding:2px 6px;font-size:11px;font-weight:500;overflow:hidden}.appt-peek{z-index:150;border:1px solid var(--border);pointer-events:none;background:#fff;border-radius:12px;min-width:220px;max-width:280px;padding:14px 16px;position:fixed;box-shadow:0 8px 32px #00000024}.appt-peek-title{margin-bottom:6px;font-size:13px;font-weight:600}.appt-peek-row{color:var(--fg-2);align-items:center;gap:6px;margin-bottom:3px;font-size:12px;display:flex}.day-strip{margin-top:16px}.day-strip h3{color:var(--fg-2);margin-bottom:10px;font-size:13px;font-weight:700}.day-appt{border:1px solid var(--border);background:#fff;border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:10px 14px;display:flex}.day-appt-dot{border-radius:999px;flex-shrink:0;width:10px;height:10px}.day-appt-info{flex:1;min-width:0}.day-appt-title{font-size:13px;font-weight:500}.day-appt-sub{color:var(--fg-3);margin-top:1px;font-size:11.5px}.day-appt-time{color:var(--fg-3);white-space:nowrap;font-size:12px}.ai-fab{z-index:180;background:var(--brand-gold-500);color:#fff;cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;width:52px;height:52px;transition:all .16s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 16px #0003}.ai-fab:hover{background:var(--brand-gold-600);transform:scale(1.06)}.ai-fab.is-open{background:var(--neutral-700)}.ai-panel{z-index:180;border:1px solid var(--border);background:#fff;border-radius:20px;flex-direction:column;width:380px;max-height:560px;animation:.2s slide-up;display:flex;position:fixed;bottom:92px;right:28px;overflow:hidden;box-shadow:0 16px 48px #00000029}.ai-panel-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.ai-panel-head-title{align-items:center;gap:8px;font-size:13.5px;font-weight:700;display:flex}.ai-scroll{flex-direction:column;flex:1;gap:10px;padding:14px 16px;display:flex;overflow-y:auto}.ai-msg{align-items:flex-end;gap:8px;display:flex}.ai-msg.user{flex-direction:row-reverse}.ai-bubble{border-radius:14px;max-width:82%;padding:9px 13px;font-size:13px;line-height:1.48}.ai-msg.assistant .ai-bubble{background:var(--neutral-100);color:var(--fg-1);border-bottom-left-radius:4px}.ai-msg.user .ai-bubble{background:var(--brand-gold-500);color:#fff;border-bottom-right-radius:4px}.ai-avatar{background:var(--brand-gold-100);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.ai-typing{align-items:center;gap:4px;padding:10px 14px;display:flex}.ai-typing span{background:var(--fg-3);border-radius:999px;width:7px;height:7px;animation:1.2s ease-in-out infinite ai-bounce}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.ai-chips{flex-wrap:wrap;flex-shrink:0;gap:6px;padding:6px 16px 10px;display:flex}.ai-chip{background:var(--brand-gold-50);border:1px solid var(--brand-gold-100);color:var(--brand-gold-700);cursor:pointer;border-radius:999px;padding:4px 10px;font-size:11.5px;font-weight:500;transition:all .12s}.ai-chip:hover{background:var(--brand-gold-100)}.ai-input-row{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:10px 12px;display:flex}.ai-input{border:1px solid var(--border);font:inherit;resize:none;border-radius:10px;outline:none;flex:1;padding:8px 12px;font-size:13px;transition:all .14s}.ai-input:focus{border-color:var(--accent);box-shadow:var(--shadow-focus)}.gantt-wrap{border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:0;display:flex;overflow:hidden}.gantt-head{background:var(--neutral-50);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.gantt-head h2{font-size:14px;font-weight:700}.gantt-body{grid-template-columns:200px 1fr;display:grid;overflow-x:auto}.gantt-side{border-right:1px solid var(--border)}.gantt-side-head{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;height:48px;color:var(--fg-3);align-items:center;padding:0 14px;font-size:11px;font-weight:700;display:flex}.gantt-side-row{border-bottom:1px solid var(--neutral-100);height:36px;color:var(--fg-1);white-space:nowrap;text-overflow:ellipsis;align-items:center;padding:0 14px;font-size:12.5px;display:flex;overflow:hidden}.gantt-side-row.is-group{text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3);background:var(--neutral-50);font-size:11px;font-weight:700}.gantt-chart{min-width:0;overflow-x:auto}.gantt-months{border-bottom:1px solid var(--border);height:28px;display:flex}.gantt-month-cell{border-right:1px solid var(--border);color:var(--fg-3);white-space:nowrap;flex-shrink:0;align-items:center;padding:0 8px;font-size:10.5px;font-weight:700;display:flex}.gantt-days{border-bottom:1px solid var(--border);height:20px;display:flex}.gantt-day-cell{width:24px;color:var(--fg-4);border-right:1px solid var(--neutral-100);flex-shrink:0;justify-content:center;align-items:center;font-size:9px;display:flex}.gantt-day-cell.is-weekend{background:var(--neutral-50)}.gantt-day-cell.is-today{background:var(--brand-gold-50);color:var(--brand-gold-700);font-weight:700}.gantt-row{border-bottom:1px solid var(--neutral-100);align-items:center;height:36px;display:flex;position:relative}.gantt-row.is-group{background:var(--neutral-50)}.gantt-row-bg{height:100%;display:flex}.gantt-day-bg{border-right:1px solid var(--neutral-100);flex-shrink:0;width:24px;height:100%}.gantt-day-bg.is-weekend{background:var(--neutral-50)}.g-bar-wrap{height:20px;position:absolute;top:8px}.g-bar{cursor:pointer;border-radius:4px;height:100%;transition:filter .12s;position:relative;overflow:hidden}.g-bar:hover{filter:brightness(.93)}.g-bar-fill{opacity:.35;border-radius:4px 0 0 4px;height:100%;position:absolute;top:0;left:0}.g-bar-label{color:#fff;white-space:nowrap;text-overflow:ellipsis;align-items:center;padding:0 7px;font-size:10.5px;font-weight:600;display:flex;position:absolute;inset:0;overflow:hidden}.today-line{background:var(--brand-gold-500);opacity:.8;pointer-events:none;z-index:2;width:2px;position:absolute;top:0;bottom:0}.sel-builder{grid-template-columns:1fr 340px;align-items:start;gap:20px;display:grid}@media (width<=1100px){.sel-builder{grid-template-columns:1fr}}.sel-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;display:grid}.sel-card{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:14px;transition:all .18s;overflow:hidden}.sel-card:hover{border-color:var(--brand-gold-300);box-shadow:0 4px 16px #00000017}.sel-card.is-selected{border-color:var(--brand-gold-500);box-shadow:0 0 0 3px var(--brand-gold-100)}.sel-swatch{background:var(--neutral-100);height:100px;position:relative;overflow:hidden}.sel-swatch-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:28px;display:flex}.sel-card-body{padding:10px 12px}.sel-card-name{color:var(--fg-1);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:13px;font-weight:600;overflow:hidden}.sel-card-sku{color:var(--fg-3);font-size:11px}.sel-card-price{color:var(--brand-gold-700);margin-top:4px;font-size:12.5px;font-weight:600}.sel-card-actions{border-top:1px solid var(--border);gap:4px;padding:6px 8px;display:flex}.sel-preview-panel{position:sticky;top:20px}.sel-phone-frame{border:8px solid var(--neutral-800);background:#fff;border-radius:36px;width:280px;height:560px;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 16px 48px #0003}.sel-phone-screen{width:100%;height:100%;overflow-y:auto}.sel-phone-notch{background:var(--neutral-800);border-radius:0 0 14px 14px;width:90px;height:20px;margin:0 auto 10px}.client-board{padding:14px}.client-board-title{margin-bottom:12px;font-size:14px;font-weight:700}.client-board-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.client-board-item{border:2px solid var(--border);border-radius:10px;overflow:hidden}.client-board-item.is-selected{border-color:var(--brand-gold-500)}.client-board-thumb{background:var(--neutral-100);height:60px}.client-board-label{white-space:nowrap;text-overflow:ellipsis;padding:5px 7px;font-size:10px;font-weight:600;overflow:hidden}.send-opt{border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:12px 14px;transition:all .12s;display:flex}.send-opt:hover,.send-opt.is-selected{border-color:var(--accent);background:var(--brand-gold-50)}.send-opt-icon{background:var(--neutral-100);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.send-opt-label{font-size:13px;font-weight:600}.send-opt-sub{color:var(--fg-3);margin-top:1px;font-size:11.5px}.proj-header{margin-bottom:20px}.proj-title{letter-spacing:-.02em;color:var(--fg-1);font-size:22px;font-weight:800}.proj-meta{color:var(--fg-3);flex-wrap:wrap;gap:14px;margin-top:6px;font-size:13px;display:flex}.proj-meta span{align-items:center;gap:5px;display:flex}.proj-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width<=900px){.proj-stats{grid-template-columns:repeat(2,1fr)}}.proj-grid{grid-template-columns:340px 1fr;align-items:start;gap:20px;display:grid}@media (width<=1100px){.proj-grid{grid-template-columns:1fr}}.proj-team{flex-direction:column;gap:10px;display:flex}.proj-team-item{align-items:center;gap:12px;display:flex}.proj-team-name{color:var(--fg-1);font-size:13px;font-weight:600}.proj-team-role{color:var(--fg-3);margin-top:1px;font-size:11.5px}.proj-budget-bar{margin-top:16px}.proj-budget-track{background:var(--neutral-100);border-radius:999px;height:8px;position:relative;overflow:hidden}.proj-budget-fill{background:var(--brand-gold-500);border-radius:999px;height:100%;position:absolute;top:0;left:0}.proj-budget-fill-pending{background:var(--brand-gold-200);border-radius:999px;height:100%;position:absolute;top:0}
