:root{--bg-abyss:#f5f2ed;--bg-deep:#eceae5;--bg-stratum:#e3e0da;--bg-surface:#ffffff;--bg-elevated:#ffffff;--bg-glass:rgba(255,255,255,0.92);--bg-glass-hover:rgba(255,255,255,0.96);--bg-input:#ffffff;--bg-hover:rgba(20,184,166,0.05);--amber:#14b8a6;--amber-light:#5eead4;--amber-dim:#0d9488;--amber-glow:rgba(20,184,166,0.07);--amber-glow-strong:rgba(20,184,166,0.15);--amber-gradient:linear-gradient(135deg, #14b8a6 0%, #0d9488 100%);--amber-gradient-soft:linear-gradient(135deg, rgba(20,184,166,0.08) 0%, rgba(13,148,136,0.04) 100%);--text-bright:#1a1a1a;--text-primary:#374151;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-ghost:#d1d5db;--border-subtle:rgba(0,0,0,0.06);--border:rgba(0,0,0,0.10);--border-strong:rgba(0,0,0,0.18);--border-amber:rgba(20,184,166,0.25);--success:#16a34a;--success-bg:rgba(22,163,74,0.08);--danger:#dc2626;--danger-bg:rgba(220,38,38,0.06);--warning:#ca8a04;--warning-bg:rgba(202,138,4,0.08);--info:#2563eb;--info-bg:rgba(37,99,235,0.06);--cat-equipment:#ef4444;--cat-materials:#3b82f6;--cat-labor:#14b8a6;--cat-restoration:#a855f7;--cat-admin:#f59e0b;--radius-xs:6px;--radius-sm:10px;--radius:14px;--radius-lg:18px;--radius-xl:22px;--shadow-sm:0 1px 2px rgba(0,0,0,0.04);--shadow:0 2px 8px rgba(0,0,0,0.06);--shadow-lg:0 8px 32px rgba(0,0,0,0.10);--shadow-glow:0 0 20px rgba(20,184,166,0.08);--shadow-inset:inset 0 1px 0 rgba(255,255,255,0.8);--sidebar-w:232px;--header-h:52px;--bottom-h:62px;--ease:cubic-bezier(0.4, 0, 0.2, 1);--ease-spring:cubic-bezier(0.34, 1.56, 0.64, 1);--dur:0.25s}*,::after,::before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",sans-serif;background:var(--bg-abyss);color:var(--text-primary);min-height:100vh;overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}#app{display:none;min-height:100vh;position:relative;z-index:1}#app.active{display:flex}a{color:var(--amber);text-decoration:none;transition:color var(--dur) var(--ease)}a:hover{color:var(--amber-dim)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.25)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;background:#1a1a1a;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;z-index:100;transition:transform var(--dur) var(--ease)}.sidebar::after{display:none;content:'';position:absolute;top:0;right:0;width:2px;height:100%;background:linear-gradient(180deg,rgba(20,184,166,.3) 0,transparent 30%,transparent 70%,rgba(20,184,166,.2) 100%)}.sidebar-header{padding:18px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:28px;height:28px;filter:drop-shadow(0 0 6px rgba(20,184,166,.3))}.logo-text{font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:-.02em}.nav-menu{list-style:none;padding:16px 10px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;cursor:pointer;color:rgba(255,255,255,.5);transition:all var(--dur) var(--ease);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;position:relative}.nav-item:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85)}.nav-item.active{color:#fff;background:rgba(20,184,166,.15)}.nav-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--amber-gradient);border-radius:0 3px 3px 0}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.5}.nav-item.active svg{opacity:1}.sidebar-footer{padding:16px 12px;border-top:1px solid rgba(255,255,255,.08)}.btn-export{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;background:rgba(20,184,166,.1);border:1px solid rgba(20,184,166,.22);color:#5eead4;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:600;font-family:inherit;transition:all var(--dur) var(--ease)}.btn-export:hover{background:rgba(20,184,166,.18);border-color:#14b8a6}.btn-export svg{width:18px;height:18px}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--header-h);background:rgba(245,242,237,.9);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);align-items:center;justify-content:space-between;padding:0 18px;z-index:90}.menu-toggle{width:36px;height:36px;background:0 0;border:none;cursor:pointer;display:flex;flex-direction:column;justify-content:center;gap:5px;padding:6px}.menu-toggle span{display:block;width:22px;height:2px;background:var(--text-bright);border-radius:2px;transition:all var(--dur) var(--ease)}.mobile-title{font-size:1.2rem;font-weight:700;color:var(--text-bright);letter-spacing:-.02em}.mobile-add-btn{width:38px;height:38px;border-radius:50%;background:var(--amber-gradient);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 16px rgba(20,184,166,.25);transition:all var(--dur) var(--ease)}.mobile-add-btn:hover{transform:scale(1.05);box-shadow:0 6px 24px rgba(20,184,166,.35)}.mobile-add-btn svg{width:20px;height:20px}.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.25);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:95}.overlay.active{display:block;animation:fadeIn .25s var(--ease)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-h);background:rgba(245,242,237,.94);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border);justify-content:space-around;align-items:center;z-index:90;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;background:0 0;border:none;color:var(--text-muted);cursor:pointer;font-size:.65rem;font-weight:500;font-family:inherit;letter-spacing:.3px;padding:8px 14px;transition:all var(--dur) var(--ease)}.bottom-nav-item svg{width:22px;height:22px}.bottom-nav-item.active{color:var(--amber)}.bottom-nav-item.add-btn{display:none!important}.bottom-nav-item.add-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(20,184,166,.4)}.bottom-nav-item.add-btn svg{width:24px;height:24px}.main-content{margin-left:var(--sidebar-w);flex:1;padding:20px 24px;min-height:100vh}.page{display:none}.page.active{display:block;animation:pageIn .45s var(--ease)}@keyframes pageIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header h2{font-size:1.75rem;font-weight:700;color:var(--text-bright);letter-spacing:-.03em}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:6px;transition:all var(--dur) var(--ease);position:relative;overflow:hidden}.card-link{cursor:pointer}.card:hover{transform:translateY(-2px);border-color:var(--border-strong)}.card-link:hover{border-color:var(--amber)}.card-icon{display:none}.card-label{font-size:.7rem;color:var(--text-secondary);letter-spacing:.8px;font-weight:700;text-transform:uppercase}.card-value{font-family:"SF Mono",Menlo,Monaco,monospace;font-size:1.5rem;font-weight:700;color:var(--text-bright);letter-spacing:-.5px}.card-trend{font-size:.75rem;font-weight:600;letter-spacing:.2px}.card-trend.trend-up{color:var(--success)}.card-trend.trend-down{color:var(--danger)}.card-trend.trend-flat{color:var(--text-muted)}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:16px;position:relative;overflow:hidden}.panel h3{font-size:1.05rem;font-weight:600;margin-bottom:18px;color:var(--text-bright);letter-spacing:-.01em}.panel-heading{font-size:.7rem!important;font-weight:700!important;text-transform:uppercase;letter-spacing:.8px!important;color:var(--text-secondary)!important}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.panel-header h3{margin-bottom:0}.dashboard-grid{display:grid;grid-template-columns:3fr 2fr;gap:20px;margin-bottom:20px}.chart-container{position:relative;height:260px}.chart-container canvas{width:100%!important;height:100%!important}.chart-legend{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:14px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-item strong{color:var(--text-bright);font-family:"SF Mono",Menlo,Monaco,monospace;font-size:.78rem}.page-subtitle{font-size:.85rem;color:var(--text-secondary);font-weight:400;margin-top:2px}.page-header-right{display:flex;align-items:center;gap:12px}.live-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(22,163,74,.08);color:#16a34a;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:4px 12px;border-radius:980px}.live-dot{width:7px;height:7px;border-radius:50%;background:#16a34a;animation:livePulse 2s ease-in-out infinite}@keyframes livePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.donut-container{position:relative;width:220px;height:220px;margin:16px auto}.donut-container canvas{width:100%!important;height:100%!important}.donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;display:flex;flex-direction:column;gap:2px}.donut-center-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600}.donut-center-value{font-family:"SF Mono",Menlo,Monaco,monospace;font-size:1.15rem;font-weight:700;color:var(--text-bright)}.donut-legend{display:flex;flex-direction:column;gap:8px;margin-top:16px}.donut-legend-row{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary)}.donut-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.donut-legend-name{flex:1;font-weight:500}.donut-legend-amount{font-family:"SF Mono",Menlo,Monaco,monospace;font-weight:600;color:var(--text-bright);font-size:.78rem}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:980px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--dur) var(--ease);text-decoration:none;position:relative;overflow:hidden}.btn svg{width:16px;height:16px}.btn-primary{background:var(--amber-gradient);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(20,184,166,.2)}.btn-primary:hover{box-shadow:0 4px 16px rgba(20,184,166,.3);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--amber);color:var(--text-bright)}.btn-danger{background:var(--danger-bg);border:1px solid rgba(220,38,38,.12);color:var(--danger)}.btn-danger:hover{background:rgba(220,38,38,.12);border-color:var(--danger)}.btn-sm{padding:7px 16px;font-size:.84rem}.btn-link{background:0 0;border:none;color:var(--amber-dim);cursor:pointer;font-size:.85rem;font-weight:600;font-family:inherit;padding:0;transition:color var(--dur) var(--ease)}.btn-link:hover{color:var(--amber)}.btn-icon{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:0 0;border:1px solid transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--dur) var(--ease);padding:0}.btn-icon:hover{border-color:var(--border-strong);color:var(--text-bright);background:var(--bg-abyss)}.btn-icon.delete:hover{border-color:rgba(220,38,38,.3);color:var(--danger);background:var(--danger-bg)}.btn-icon svg{width:16px;height:16px}.expense-form{max-width:620px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:7px;letter-spacing:.1px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.9rem;font-family:inherit;transition:all var(--dur) var(--ease)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:0;border-color:var(--amber);box-shadow:0 0 0 3px rgba(20,184,166,.1)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-ghost)}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8578' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.form-group textarea{resize:vertical;min-height:64px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.calendar-field{position:relative}.calendar-trigger{width:100%;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);cursor:pointer;font-family:inherit;font-size:.9rem;transition:all var(--dur) var(--ease)}.calendar-trigger svg{width:17px;height:17px;color:var(--amber-dim);flex-shrink:0}.calendar-trigger:hover{border-color:var(--amber-dim)}.calendar-field.open .calendar-trigger{border-color:var(--amber);box-shadow:0 0 0 3px rgba(20,184,166,.1)}.calendar-dropdown{position:absolute;top:calc(100% + 8px);left:0;width:min(320px,100%);background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:16px;z-index:30;display:none}.calendar-field.open .calendar-dropdown{display:block;animation:dropIn .2s var(--ease-spring)}@keyframes dropIn{from{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.calendar-head strong{font-size:.92rem;color:var(--text-bright)}.calendar-nav{width:30px;height:30px;border-radius:50%;border:1px solid var(--border);background:0 0;color:var(--text-primary);cursor:pointer;font-size:1.1rem;line-height:1;font-family:inherit;transition:all var(--dur) var(--ease)}.calendar-nav:hover{border-color:var(--amber);color:var(--amber-dim)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}.calendar-weekdays span{text-align:center;font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.calendar-day{width:100%;aspect-ratio:1;border:1px solid transparent;border-radius:50%;background:0 0;color:var(--text-primary);cursor:pointer;font-size:.82rem;font-family:inherit;transition:all .15s var(--ease)}.calendar-day:hover{border-color:var(--amber-dim);background:var(--amber-glow)}.calendar-day.muted{color:var(--text-ghost)}.calendar-day.today{border-color:var(--amber);background:var(--amber);color:#1a0800;font-weight:700}.calendar-day.selected{border-color:var(--amber);background:var(--amber-glow-strong);color:var(--amber-dim);font-weight:700}.calendar-foot{margin-top:10px;display:flex;justify-content:space-between}.calendar-action{font-size:.82rem}.filters-bar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px;align-items:center}.search-box{position:relative;flex:1;min-width:200px}.search-box svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted)}.search-box input{width:100%;padding:10px 16px 10px 40px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.9rem;font-family:inherit;transition:all var(--dur) var(--ease)}.search-box input:focus{outline:0;border-color:var(--amber);box-shadow:0 0 0 3px rgba(20,184,166,.1)}.filters-bar select{padding:10px 36px 10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.85rem;font-family:inherit;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8578' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:all var(--dur) var(--ease)}.filters-bar select:focus{outline:0;border-color:var(--amber)}.filters-bar input[type=date]{padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.85rem;font-family:inherit;cursor:pointer;transition:all var(--dur) var(--ease)}.filters-bar input[type=date]:focus{outline:0;border-color:var(--amber)}.date-range{display:flex;align-items:center;gap:10px}.date-range input{padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.85rem;font-family:inherit}.date-range input:focus{outline:0;border-color:var(--amber)}.date-range span{color:var(--text-muted);font-size:.82rem;font-weight:600}.expenses-table-wrapper{overflow-x:auto;border-radius:var(--radius)}.table-wrap{overflow-x:auto;border-radius:var(--radius)}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border-subtle);font-size:.88rem;white-space:nowrap}.data-table th{font-weight:600;color:var(--text-secondary);font-size:.72rem;letter-spacing:.2px;background:var(--bg-abyss);position:sticky;top:0}.data-table tbody tr{transition:background var(--dur) var(--ease)}.data-table tbody tr:hover{background:rgba(20,184,166,.04)}.expenses-table{width:100%;border-collapse:collapse}.expenses-table td,.expenses-table th{padding:14px 18px;text-align:left;border-bottom:1px solid var(--border-subtle);font-size:.88rem;white-space:nowrap}.expenses-table th{font-weight:600;color:var(--text-secondary);font-size:.72rem;letter-spacing:.2px;background:var(--bg-abyss);position:sticky;top:0}.expenses-table th.sortable{cursor:pointer;user-select:none}.expenses-table th.sortable:hover{color:var(--amber-dim)}.sort-icon::after{content:'';display:inline-block;margin-left:4px}.expenses-table th.sort-asc .sort-icon::after{content:'\25B2';font-size:.55em}.expenses-table th.sort-desc .sort-icon::after{content:'\25BC';font-size:.55em}.expenses-table tbody tr{transition:background var(--dur) var(--ease)}.expenses-table tbody tr:hover{background:rgba(20,184,166,.04)}.text-right{text-align:right}.amount-cell{font-family:"SF Mono",Menlo,Monaco,monospace;font-weight:600;font-size:.85rem;color:var(--text-bright)}.category-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.3px}.badge-equipment{background:rgba(239,68,68,.08);color:var(--cat-equipment);border:1px solid rgba(239,68,68,.15)}.badge-materials{background:rgba(59,130,246,.08);color:var(--cat-materials);border:1px solid rgba(59,130,246,.15)}.badge-labor{background:rgba(20,184,166,.08);color:var(--cat-labor);border:1px solid rgba(20,184,166,.15)}.badge-restoration{background:rgba(168,85,247,.08);color:var(--cat-restoration);border:1px solid rgba(168,85,247,.15)}.badge-admin{background:rgba(245,158,11,.08);color:var(--cat-admin);border:1px solid rgba(245,158,11,.15)}.action-btns{display:flex;gap:4px}.report-table{width:100%;border-collapse:collapse}.report-table td,.report-table th{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-subtle);font-size:.88rem}.report-table th{font-weight:600;color:var(--text-secondary);font-size:.72rem;letter-spacing:.2px}.report-table .total-row td{border-top:2px solid var(--amber);border-bottom:none;padding-top:16px}.report-table .total-row td strong{font-family:"SF Mono",Menlo,Monaco,monospace;color:var(--amber-dim)}.table-footer{padding:14px 0;text-align:right}.expenses-total{font-family:"SF Mono",Menlo,Monaco,monospace;font-size:.88rem;font-weight:600;color:var(--amber-dim)}.pagination{display:flex;gap:4px;justify-content:center;margin-top:18px}.pagination button{min-width:38px;height:38px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);border-radius:50%;cursor:pointer;font-size:.85rem;font-family:"SF Mono",Menlo,Monaco,monospace;transition:all var(--dur) var(--ease)}.pagination button:hover{border-color:var(--amber);color:var(--amber-dim)}.pagination button.active{background:var(--amber-gradient);color:#fff;border-color:var(--amber);font-weight:700}.expense-list{display:flex;flex-direction:column}.expense-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-subtle);transition:all .15s var(--ease)}.expense-item:last-child{border-bottom:none}.expense-item:hover{padding-left:8px}.expense-item-left{display:flex;align-items:center;gap:14px;min-width:0}.expense-item-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}.expense-item-info{min-width:0}.expense-item-info .title{font-weight:600;font-size:.9rem;color:var(--text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-item-info .meta,.expense-meta{font-size:.76rem;color:var(--text-muted);font-weight:500;margin-top:2px}.expense-amount,.expense-item-amount{font-family:"SF Mono",Menlo,Monaco,monospace;font-weight:700;font-size:.92rem;white-space:nowrap;color:var(--text-bright)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all var(--dur) var(--ease);position:relative;overflow:hidden}.project-card:hover{transform:translateY(-3px);border-color:var(--border-strong)}.project-card h4{font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:12px}.project-card p{font-size:.85rem;color:var(--text-secondary);margin-bottom:6px}.project-card p strong{color:var(--text-primary);font-weight:600}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.project-card-header h4{margin-bottom:0}.project-status{padding:4px 12px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-active{background:var(--success-bg);color:var(--success);border:1px solid rgba(22,163,74,.18)}.status-completed{background:var(--info-bg);color:var(--info);border:1px solid rgba(37,99,235,.18)}.status-on-hold{background:var(--warning-bg);color:var(--warning);border:1px solid rgba(202,138,4,.18)}.project-card-details{display:flex;flex-direction:column;gap:6px;font-size:.83rem;color:var(--text-secondary);margin-bottom:16px}.project-card-details span{display:flex;align-items:center;gap:6px}.project-budget-bar{height:5px;background:var(--border);border-radius:10px;overflow:hidden;margin-bottom:8px}.project-budget-fill{height:100%;border-radius:10px;background:var(--amber-gradient);transition:width .6s var(--ease)}.project-budget-fill.over-budget{background:linear-gradient(90deg,var(--danger),#f87171)}.project-budget-text{display:flex;justify-content:space-between;font-family:"SF Mono",Menlo,Monaco,monospace;font-size:.73rem;color:var(--text-muted);margin-bottom:14px}.project-actions,.project-card-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.subcategory-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.sub-box,.subcat-card{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px;transition:all var(--dur) var(--ease)}.sub-box:hover,.subcat-card:hover{border-color:var(--border-strong);background:var(--bg-deep)}.sub-box h4,.subcat-card h4{font-size:.88rem;font-weight:700;margin-bottom:14px;color:var(--text-bright);display:flex;align-items:center;gap:8px}.sub-box p{font-family:"SF Mono",Menlo,Monaco,monospace;font-size:1.05rem;font-weight:700;color:var(--amber-dim)}.subcat-card h4 .cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subcat-item{display:flex;justify-content:space-between;padding:7px 0;font-size:.83rem;border-bottom:1px solid var(--border-subtle)}.subcat-item:last-child{border-bottom:none}.subcat-item span:first-child{color:var(--text-secondary)}.subcat-item span:last-child{font-family:"SF Mono",Menlo,Monaco,monospace;font-weight:600;color:var(--text-bright)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.settings-actions{display:flex;flex-direction:column;gap:12px}.about-text{font-size:.9rem;color:var(--text-secondary);line-height:1.7}.about-text strong{color:var(--amber-dim);font-weight:700}.about-text small{color:var(--text-muted);font-style:italic}.category-manager-list{display:flex;flex-direction:column;gap:12px}.category-manager-item{background:var(--bg-abyss);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;transition:all var(--dur) var(--ease)}.category-manager-item:hover{border-color:var(--border-strong)}.category-manager-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.category-manager-header strong{flex:1;font-size:.9rem;color:var(--text-bright)}.category-manager-actions{display:flex;gap:4px;flex-shrink:0}.category-manager-actions button{padding:4px 10px;font-size:.72rem;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-weight:600;transition:all var(--dur) var(--ease)}.category-manager-actions button:hover{border-color:var(--amber);color:var(--amber-dim)}.category-manager-actions button.delete-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.cat-inline-input{padding:3px 8px;border:1px solid var(--amber);border-radius:var(--radius-xs);background:var(--bg-surface);font-family:inherit;font-size:.82rem;color:var(--text-bright);outline:0;min-width:120px}.cat-inline-input:focus{box-shadow:0 0 0 2px var(--amber-glow)}.cat-edit-wrap,.sub-edit-wrap{display:inline-flex;align-items:center;gap:6px;flex:1}.btn-xs{padding:3px 10px;font-size:.72rem;font-weight:600;font-family:inherit;border-radius:980px;border:1px solid;cursor:pointer;transition:all var(--dur) var(--ease);white-space:nowrap}.btn-xs.btn-save{background:var(--amber-gradient);border-color:var(--amber);color:#1a1a2e}.btn-xs.btn-save:hover{opacity:.85}.btn-xs.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-xs.btn-cancel{background:var(--bg-surface);border-color:var(--border-strong);color:var(--text-secondary)}.btn-xs.btn-cancel:hover{border-color:var(--border-strong);background:var(--bg-deep)}.category-subs{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:4px}.category-sub-item{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;font-size:.82rem;color:var(--text-secondary);border-radius:var(--radius-xs);transition:background var(--dur) var(--ease)}.category-sub-item:hover{background:rgba(20,184,166,.05)}.category-sub-item .sub-actions{display:flex;gap:4px}.category-sub-item .sub-actions button{padding:2px 8px;font-size:.68rem;border-radius:4px;border:1px solid transparent;background:0 0;color:var(--text-muted);cursor:pointer;font-family:inherit;font-weight:600;transition:all var(--dur) var(--ease)}.category-sub-item .sub-actions button:hover{border-color:var(--border);color:var(--text-bright)}.category-sub-item .sub-actions button.delete-btn:hover{color:var(--danger)}.empty-state{text-align:center;padding:52px 20px;color:var(--text-muted)}.empty-state svg{width:52px;height:52px;margin-bottom:14px;opacity:.3}.empty-state p{margin-bottom:18px;font-size:1.05rem;font-weight:500;color:var(--text-secondary)}.empty-copy{color:var(--text-muted);font-size:.88rem;text-align:center;padding:20px 0;font-weight:500}.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;align-items:center;justify-content:center;padding:20px}.modal.active{display:flex;overflow-y:auto;align-items:flex-start}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:480px;max-height:calc(100vh - 40px);overflow-y:auto;margin:auto;animation:modalIn .3s var(--ease-spring);box-shadow:var(--shadow-lg);position:relative}.modal-content::before{display:none;content:'';position:absolute;top:0;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--amber),transparent)}.modal-sm{max-width:400px}@keyframes modalIn{from{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h3{font-size:1.1rem;font-weight:700;color:var(--text-bright);letter-spacing:-.01em}.modal-close{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:0 0;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--dur) var(--ease);font-family:inherit}.modal-close:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.toast-container{position:fixed;top:24px;right:24px;z-index:600;display:flex;flex-direction:column;gap:10px}.toast{padding:14px 22px;border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;color:#fff;box-shadow:var(--shadow);animation:toastIn .35s var(--ease-spring);display:flex;align-items:center;gap:10px;max-width:380px;background:var(--success);border:1px solid rgba(255,255,255,.1);font-family:inherit}.toast.success{background:rgba(22,163,74,.95)}.toast.error{background:rgba(220,38,38,.95)}.toast.info{background:rgba(37,99,235,.95)}.toast.hide{animation:toastOut .3s var(--ease) forwards}@keyframes toastIn{from{opacity:0;transform:translateX(60px) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(60px)}}.date-filter select,.report-controls select{padding:8px 34px 8px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-bright);font-size:.85rem;font-family:inherit;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8578' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:all var(--dur) var(--ease)}.report-controls{display:flex;gap:12px;align-items:center}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}.mobile-header{display:flex}.bottom-nav{display:flex}.main-content{margin-left:0;padding:14px;padding-top:calc(var(--header-h) + 14px);padding-bottom:calc(var(--bottom-h) + 24px);overflow-x:hidden;max-width:100vw}.page-header{gap:8px}.page-header h2{font-size:1.2rem}.page-header .btn{font-size:.78rem;padding:8px 12px;white-space:nowrap}.page-header-right{gap:8px}.trial-banner{padding:10px 14px;position:relative}.trial-banner-inner{flex-wrap:wrap;gap:8px;padding-right:28px}.trial-banner-text{font-size:.78rem;flex:1 1 100%}.trial-banner-upgrade{font-size:.75rem;padding:6px 14px}.trial-banner-dismiss{position:absolute;top:10px;right:10px}.summary-cards{grid-template-columns:1fr 1fr;gap:10px}.card{padding:14px;gap:4px}.card-value{font-size:1.1rem}.card-label{font-size:.65rem}.production-summary{gap:8px}.prod-stat{min-width:0;padding:12px 14px}.prod-stat-value{font-size:1.1rem}.form-row{grid-template-columns:1fr;gap:0}.filters-bar{flex-direction:column;align-items:stretch}.search-box{min-width:0}.date-range{flex-direction:column;gap:8px}.date-range>span{display:none}.calendar-dropdown{width:min(300px,calc(100vw - 28px))!important;left:0!important;right:auto!important}.date-range-calendar .calendar-dropdown{width:min(300px,calc(100vw - 28px))!important}.expenses-table-wrapper,.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -14px;padding:0 14px}.data-table,.expenses-table{min-width:520px}.data-table td,.data-table th,.expenses-table td,.expenses-table th{padding:10px 10px;font-size:.78rem}.action-btns{gap:4px}.action-btns .btn-sm{padding:5px 8px;font-size:.72rem}.projects-grid{grid-template-columns:1fr}.settings-grid{grid-template-columns:1fr}.modal{padding:12px}.modal-content{padding:18px;border-radius:var(--radius-lg);max-width:calc(100vw - 24px);max-height:calc(100vh - 24px);overflow-y:auto}.toast-container{top:calc(var(--header-h) + 10px);right:14px;left:14px}.toast{max-width:100%}.subcategory-grid{grid-template-columns:1fr}.report-controls{flex-wrap:wrap;gap:8px}.report-controls select{width:100%}.payroll-tabs,.tab-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0}.payroll-tabs button,.tab-nav button{flex-shrink:0;font-size:.8rem;padding:10px 14px}.panel{padding:14px}}@media (max-width:480px){.main-content{padding:10px;padding-top:calc(var(--header-h) + 10px);padding-bottom:calc(var(--bottom-h) + 20px)}.page-header{flex-direction:column;align-items:stretch}.page-header h2{font-size:1.1rem}.page-header .btn{font-size:.78rem;padding:8px 12px;text-align:center;justify-content:center}.page-header-right{width:100%}.page-header-right .btn{flex:1}.production-summary{display:grid;grid-template-columns:1fr 1fr}.prod-stat:last-child{grid-column:1/-1}.summary-cards{grid-template-columns:1fr}.card-label{font-size:.65rem}.card-value{font-size:1.05rem}.donut-container{width:180px;height:180px}.expenses-table-wrapper,.table-wrap{margin:0 -10px;padding:0 10px}.trial-banner-text{font-size:.72rem}.trial-banner-upgrade{padding:5px 10px;font-size:.7rem}}@media print{.action-btns,.bottom-nav,.btn,.filters-bar,.mobile-header,.modal,.sidebar,.toast-container{display:none!important}.main-content{margin-left:0!important;padding:0!important}body{background:#fff!important;color:#000!important}.card,.panel{border:1px solid #ddd;background:#fff;box-shadow:none}.expenses-table td,.expenses-table th,.report-table td,.report-table th{border-bottom:1px solid #ddd}}.date-range-calendar .calendar-trigger{min-width:130px;font-size:.85rem;padding:10px 14px}.date-range-calendar .calendar-dropdown{width:300px;right:0;left:auto}.auth-page,.subscribe-page{position:fixed;inset:0;z-index:500;display:none;background:#111}.page.active.auth-page{display:flex}.page.active.subscribe-page{display:flex;align-items:center;justify-content:center;padding:40px 20px}.auth-split{display:flex;width:100%;height:100%;min-height:100vh}.auth-brand-panel{position:relative;flex:0 0 42%;display:flex;align-items:center;padding:60px 48px;background:#111;border-right:1px solid rgba(20,184,166,.1);overflow:hidden}.auth-brand-panel::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber)}.auth-brand-panel::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(20,184,166,.06) 1px,transparent 1px);background-size:26px 26px;pointer-events:none}.auth-brand-inner{position:relative;z-index:1;width:100%}.auth-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:40px}.auth-brand-name{font-size:1.15rem;font-weight:700;color:#fff;letter-spacing:-.01em}.auth-brand-tagline{font-size:1rem;color:rgba(255,255,255,.42);line-height:1.7;margin-bottom:28px;max-width:290px}.auth-brand-rule{width:40px;height:2px;background:var(--amber);border-radius:1px;margin-bottom:24px}.auth-brand-list{list-style:none;display:flex;flex-direction:column;gap:14px;padding:0}.auth-brand-list li{display:flex;align-items:flex-start;gap:10px;font-size:.875rem;color:rgba(255,255,255,.52);line-height:1.5}.auth-brand-list li::before{content:'→';color:var(--amber);font-weight:700;flex-shrink:0;margin-top:1px;font-size:.85rem}.auth-trial-pill{display:inline-flex;align-items:center;background:rgba(20,184,166,.12);border:1px solid rgba(20,184,166,.28);color:var(--amber);font-family:"SF Mono",Menlo,Monaco,monospace;font-size:.68rem;font-weight:700;letter-spacing:.14em;padding:5px 12px;border-radius:4px;margin-bottom:14px;text-transform:uppercase}.auth-trial-headline{font-size:2.1rem;font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.03em;margin-bottom:28px}.auth-form-panel{flex:1;background:#faf8f5;display:flex;align-items:center;justify-content:center;padding:48px 40px;overflow-y:auto}.auth-form-inner{width:100%;max-width:380px}.auth-form-mobile-logo{display:none;align-items:center;gap:8px;font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:28px}.auth-form-title{font-size:1.7rem;font-weight:800;color:var(--text-bright);letter-spacing:-.025em;margin-bottom:6px}.auth-form-sub{font-size:.875rem;color:var(--text-secondary);margin-bottom:28px}.auth-form .form-group{margin-bottom:16px}.btn-amber{background:var(--amber-gradient);color:#fff;border:none;font-weight:700;letter-spacing:.01em;box-shadow:0 4px 16px rgba(20,184,166,.22);transition:transform .15s var(--ease),box-shadow .15s var(--ease),opacity .15s}.btn-amber:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 24px rgba(20,184,166,.32)}.btn-amber:active{transform:translateY(0);opacity:1}.btn-amber:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-full{width:100%;justify-content:center;margin-top:8px}.cf-turnstile-wrapper{margin:16px 0 8px;display:flex;justify-content:center}.auth-divider{display:flex;align-items:center;margin:20px 0;color:var(--text-muted,#999);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.auth-divider::after,.auth-divider::before{content:'';flex:1;height:1px;background:var(--border,#e0e0e0)}.auth-divider span{padding:0 12px}.btn-google{display:flex;align-items:center;justify-content:center;padding:10px 16px;border:1px solid var(--border,#dadce0);border-radius:8px;background:#fff;color:#3c4043;font-size:.9rem;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,box-shadow .15s}.btn-google:hover{background:#f8f9fa;box-shadow:0 1px 3px rgba(0,0,0,.12)}.auth-switch{text-align:center;margin-top:20px;font-size:.875rem;color:var(--text-secondary)}.auth-switch-link{color:var(--amber-dim);font-weight:600;background:0 0;border:none;cursor:pointer;font-family:inherit;font-size:inherit;padding:0}.auth-switch-link:hover{text-decoration:underline}@media (max-width:768px){.auth-split{flex-direction:column}.auth-brand-panel{flex:0 0 auto;padding:28px 24px 22px;border-right:none;border-bottom:1px solid rgba(20,184,166,.1)}.auth-brand-panel::before{left:0;right:0;top:0;bottom:auto;width:auto;height:3px}.auth-brand-logo{margin-bottom:12px}.auth-brand-list,.auth-brand-rule,.auth-brand-tagline{display:none}.auth-trial-headline{font-size:1.35rem;margin-bottom:0}.auth-trial-pill{margin-bottom:8px}.auth-form-panel{flex:1;padding:28px 24px 32px;align-items:flex-start}.auth-form-inner{max-width:100%}.auth-form-mobile-logo{display:flex}}.landing{display:none;flex-direction:column;min-height:100vh;background:var(--bg-abyss)}.landing.active{display:flex}.landing-container{max-width:1080px;margin:0 auto;padding:0 24px;width:100%}.landing-nav{position:sticky;top:0;z-index:100;background:var(--bg-glass);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle)}.landing-nav-inner{max-width:1080px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.landing-logo{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;color:var(--text-bright);letter-spacing:-.01em}.landing-logo .logo-icon{width:28px;height:28px}.landing-nav-link{font-size:.875rem;font-weight:600;color:#0a7569;text-decoration:none;padding:8px 20px;border:1px solid var(--border-amber);border-radius:var(--radius-sm);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.landing-nav-link:hover{background:var(--amber);color:#fff;border-color:var(--amber)}.landing-hero{padding:80px 0 64px;text-align:center}.landing-hero-pill{display:inline-flex;align-items:center;background:var(--amber-glow-strong);border:1px solid var(--border-amber);color:#0a7569;padding:6px 16px;font-size:.75rem;font-weight:700;border-radius:100px;text-transform:uppercase;letter-spacing:.04em;margin-bottom:24px}.landing-hero-title{font-size:clamp(2rem, 5vw, 3.2rem);font-weight:900;color:var(--text-bright);line-height:1.1;letter-spacing:-.03em;margin-bottom:20px}.landing-hero-sub{font-size:1.1rem;color:var(--text-primary);max-width:560px;margin:0 auto 32px;line-height:1.6}.landing-hero-actions{display:flex;flex-direction:column;align-items:center;gap:12px}.landing-hero-btn{padding:14px 36px;font-size:1rem;font-weight:700;border-radius:var(--radius-sm);text-decoration:none;display:inline-flex;align-items:center}.landing-hero-note{font-size:.8rem;color:var(--text-secondary)}.landing-features{padding:64px 0;background:var(--bg-deep)}.landing-section-title{text-align:center;font-size:1.8rem;font-weight:800;color:var(--text-bright);letter-spacing:-.02em;margin-bottom:8px}.landing-section-sub{text-align:center;font-size:1rem;color:var(--text-secondary);margin-bottom:48px}.landing-features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.landing-feature-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:28px 24px;transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}.landing-feature-card:hover{border-color:var(--border-amber);box-shadow:var(--shadow-glow)}.landing-feature-icon{width:40px;height:40px;background:var(--amber-glow-strong);border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--amber)}.landing-feature-icon svg{width:20px;height:20px}.landing-feature-card h3{font-size:.95rem;font-weight:700;color:var(--text-bright);margin-bottom:8px}.landing-feature-card p{font-size:.825rem;color:var(--text-secondary);line-height:1.55}.landing-steps{padding:64px 0}.landing-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}.landing-step{text-align:center;padding:0 16px}.landing-step-num{width:48px;height:48px;border-radius:50%;background:var(--amber-gradient);color:#fff;font-size:1.2rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.landing-step h3{font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:8px}.landing-step p{font-size:.875rem;color:var(--text-secondary);line-height:1.55}.landing-cta-banner{padding:56px 0;background:var(--bg-deep);text-align:center}.landing-cta-banner h2{font-size:1.6rem;font-weight:800;color:var(--text-bright);margin-bottom:8px}.landing-cta-banner p{font-size:.95rem;color:var(--text-secondary);margin-bottom:24px}.landing-auth{padding:64px 0 80px}.landing-auth .landing-container{max-width:460px}.landing-auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}.landing-auth-tabs{display:flex;gap:4px;background:var(--bg-deep);border-radius:var(--radius-sm);padding:4px;margin-bottom:24px}.landing-auth-tab{flex:1;padding:10px 16px;font-size:.875rem;font-weight:600;color:var(--text-secondary);background:0 0;border:none;border-radius:var(--radius-xs);cursor:pointer;transition:all var(--dur) var(--ease);font-family:inherit}.landing-auth-tab.active{background:var(--bg-surface);color:var(--text-bright);box-shadow:var(--shadow-sm)}.landing-auth-pane{display:none}.landing-auth-pane.active{display:block}.landing-auth-sub{font-size:.875rem;color:var(--text-secondary);margin-bottom:20px}.landing-footer{padding:32px 0;border-top:1px solid var(--border-subtle);text-align:center}.landing-footer p{font-size:.8rem;color:var(--text-muted)}.landing-footer-links{margin-top:8px}.landing-footer-links a{color:var(--text-secondary);font-size:.8rem;text-decoration:none}.landing-footer-links a:hover{color:var(--amber)}@media (max-width:900px){.landing-features-grid{grid-template-columns:repeat(2,1fr)}.landing-hero{padding:60px 0 48px}.landing-auth,.landing-features,.landing-steps{padding:48px 0}.landing-cta-banner{padding:40px 0}.landing-section-title{font-size:1.5rem}.landing-section-sub{margin-bottom:36px}}@media (max-width:600px){.landing-container{padding:0 16px}.landing-nav-inner{padding:0 16px;height:48px}.landing-logo{font-size:.95rem;gap:8px}.landing-logo .logo-icon{width:24px;height:24px}.landing-nav-link{font-size:.8rem;padding:6px 14px}.landing-hero{padding:40px 0 32px}.landing-hero-pill{font-size:.65rem;padding:5px 12px;margin-bottom:16px}.landing-hero-title{font-size:1.7rem;margin-bottom:14px}.landing-hero-sub{font-size:.9rem;margin-bottom:24px}.landing-hero-btn{padding:12px 28px;font-size:.95rem;width:100%;justify-content:center}.landing-features,.landing-steps{padding:40px 0}.landing-section-title{font-size:1.3rem}.landing-section-sub{font-size:.875rem;margin-bottom:28px}.landing-features-grid{grid-template-columns:1fr;gap:14px}.landing-feature-card{padding:20px 18px;display:flex;gap:14px;align-items:flex-start}.landing-feature-icon{margin-bottom:0;flex-shrink:0}.landing-feature-card h3{margin-bottom:4px}.landing-feature-card p{font-size:.8rem}.landing-steps-grid{grid-template-columns:1fr;gap:20px}.landing-step{display:flex;align-items:flex-start;gap:16px;text-align:left;padding:0}.landing-step-num{margin:0;flex-shrink:0;width:40px;height:40px;font-size:1rem}.landing-cta-banner{padding:36px 0}.landing-cta-banner h2{font-size:1.25rem}.landing-cta-banner p{font-size:.85rem}.landing-cta-banner .landing-hero-btn{width:100%;justify-content:center}.landing-auth{padding:40px 0 48px}.landing-auth-card{padding:20px 16px;border-radius:var(--radius)}.landing-auth-tabs{margin-bottom:20px}.landing-auth-tab{padding:8px 12px;font-size:.825rem}.landing-footer{padding:24px 0}}.subscribe-container{width:100%;max-width:720px;text-align:center}.subscribe-header h2{font-size:1.8rem;font-weight:800;color:#fff;margin-bottom:8px}.subscribe-header p{color:rgba(255,255,255,.6);margin-bottom:36px}.plan-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;padding-top:16px}@media (max-width:520px){.plan-cards{grid-template-columns:1fr}}.plan-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;text-align:left;position:relative;box-shadow:var(--shadow);display:flex;flex-direction:column}.plan-card .btn-full{margin-top:auto}.plan-card-featured{border-color:var(--amber);box-shadow:0 0 0 2px var(--amber-glow-strong),var(--shadow-lg)}.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--amber-gradient);color:#000;font-size:.75rem;font-weight:700;padding:4px 14px;border-radius:99px;white-space:nowrap}.plan-name{font-size:1rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.plan-price{font-size:2.4rem;font-weight:800;color:var(--text-bright);margin-bottom:4px;line-height:1}.plan-price span{font-size:1rem;font-weight:500;color:var(--text-secondary)}.plan-savings{font-size:.82rem;color:var(--success);font-weight:600;margin-bottom:16px}.plan-features{list-style:none;margin:16px 0 24px;padding:0}.plan-features li{font-size:.9rem;color:var(--text-primary);padding:5px 0;display:flex;align-items:center;gap:8px}.plan-features li::before{content:'✓';color:var(--success);font-weight:700;font-size:.85rem}.subscribe-footer{color:rgba(255,255,255,.45);font-size:.85rem}.sub-status{font-size:.95rem;font-weight:500;padding:10px 14px;border-radius:var(--radius-sm);margin:8px 0}.sub-trial{background:var(--info-bg);color:var(--info)}.sub-active{background:var(--success-bg);color:var(--success)}.sub-danger{background:var(--danger-bg);color:var(--danger)}.trial-banner{background:linear-gradient(135deg,#0c1a18 0,#122220 100%);border-bottom:1px solid rgba(240,165,0,.18);padding:10px 20px;flex-shrink:0;position:relative;z-index:10}.trial-banner-inner{display:flex;align-items:center;gap:12px;max-width:1200px;margin:0 auto}.trial-banner-text{flex:1;font-size:.84rem;color:rgba(255,255,255,.72);line-height:1.4}.trial-banner-text strong{color:var(--amber);font-weight:700}.trial-banner-upgrade{flex-shrink:0;background:var(--amber-gradient);color:#0a0800;border:none;border-radius:980px;padding:7px 16px;font-size:.78rem;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:opacity .15s}.trial-banner-upgrade:hover{opacity:.88}.trial-banner-dismiss{flex-shrink:0;background:0 0;border:none;color:rgba(255,255,255,.32);font-size:1.25rem;line-height:1;cursor:pointer;padding:4px 6px;transition:color .15s}.trial-banner-dismiss:hover{color:rgba(255,255,255,.6)}.btn-sign-out{color:var(--text-secondary)!important;margin-top:4px}.btn-sign-out:hover{color:var(--danger)!important;background:var(--danger-bg)!important}.production-summary{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.prod-stat{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 20px;min-width:130px;flex:1}.prod-stat-label{display:block;font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.prod-stat-value{display:block;font-size:1.25rem;font-weight:700;color:var(--amber);font-family:"SF Mono",Menlo,Monaco,monospace}.prod-lf-value{color:var(--amber-dim);font-weight:600;font-family:"SF Mono",Menlo,Monaco,monospace}.prod-map{width:100%;height:240px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--bg-deep)}.production-table td:nth-child(4),.production-table th:nth-child(4){text-align:right;font-family:"SF Mono",Menlo,Monaco,monospace;color:var(--amber-dim);font-weight:600}.crew-checklist{max-height:150px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px}.crew-check-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;cursor:pointer}.crew-check-item:hover{background:var(--bg-hover)}.crew-check-item input[type=checkbox]{accent-color:var(--amber);width:16px;height:16px;flex-shrink:0}.crew-empty-note{color:var(--text-muted);font-size:.82rem;padding:8px;margin:0}.status-badge{display:inline-block;padding:3px 10px;border-radius:980px;font-size:.72rem;font-weight:600}.status-badge.active{background:rgba(22,163,74,.08);color:#16a34a}.status-badge.inactive{background:var(--bg-hover);color:var(--text-muted)}.status-badge.expired{background:rgba(220,38,38,.06);color:#dc2626}.status-badge.recalled{background:rgba(202,138,4,.08);color:#ca8a04}.status-badge.completed{background:rgba(37,99,235,.06);color:#2563eb}.payroll-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--border);padding-bottom:0}.payroll-tab{padding:8px 20px;border:none;background:0 0;color:var(--text-muted);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color var(--dur),border-color var(--dur)}.payroll-tab.active{color:var(--amber);border-bottom-color:var(--amber)}.payroll-tab:hover:not(.active){color:var(--text-primary)}.ptab-content{display:none}.ptab-content.active{display:block}.employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.employee-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.employee-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.employee-name{font-weight:600;font-size:1rem}.employee-meta{font-size:.82rem;color:var(--text-muted);margin-top:2px}.employee-tax-summary{display:flex;gap:12px;font-size:.78rem;color:var(--text-secondary);margin-bottom:8px}.employee-notes{font-size:.82rem;color:var(--text-muted);margin-bottom:10px}.employee-card-actions{display:flex;gap:8px;margin-top:12px}.badge-active{background:rgba(22,163,74,.08);color:#16a34a;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.badge-inactive{background:rgba(0,0,0,.04);color:var(--text-muted);padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600}.te-gross-preview{background:var(--bg-hover);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:12px}.te-preview-grid{display:grid;grid-template-columns:1fr auto;gap:4px 16px;font-size:.88rem}.payroll-summary-note{background:#fef9c3;border:1px solid #fde047;border-radius:var(--radius-sm);padding:10px 14px;font-size:.83rem;margin-bottom:16px;color:#713f12}.payroll-summary-table td,.payroll-summary-table th{vertical-align:top}.payroll-net{color:#166534;font-weight:600}.payroll-cost{color:var(--text-primary);font-weight:600}.payroll-totals{background:var(--bg-abyss);font-size:.95rem}.pw-lookup-panel{margin-bottom:24px}.pw-description{font-size:.86rem;color:var(--text-muted);margin-bottom:14px}.pw-lookup-result{margin-top:12px}.pw-lookup-match{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.pw-lookup-match p{font-size:.85rem;color:var(--text-muted);margin:8px 0 12px}.pw-total-cell{font-weight:600;color:var(--amber)}.pw-total-preview{background:var(--bg-hover);border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:12px}.pw-total-preview .te-preview-grid strong{color:var(--amber)}