:root{--bg-primary: #0f1419;--bg-secondary: #1a2332;--bg-surface: #1e2a3a;--bg-surface-hover: #243447;--bg-elevated: #253548;--bg-overlay: rgba(15, 20, 25, .85);--residential: #d4915e;--residential-light: #e8b48a;--residential-dim: rgba(212, 145, 94, .15);--commercial: #5b8fb9;--commercial-light: #7eb3d8;--commercial-dim: rgba(91, 143, 185, .15);--success: #4caf7d;--success-dim: rgba(76, 175, 125, .15);--warning: #e8a44a;--warning-dim: rgba(232, 164, 74, .15);--danger: #cf6679;--danger-dim: rgba(207, 102, 121, .15);--info: #5b8fb9;--text-primary: #e8e6e3;--text-secondary: #8a9bb5;--text-muted: #5a6b82;--text-inverse: #0f1419;--border-subtle: rgba(138, 155, 181, .12);--border-default: rgba(138, 155, 181, .2);--border-strong: rgba(138, 155, 181, .35);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow-res: 0 0 20px rgba(212, 145, 94, .15);--shadow-glow-com: 0 0 20px rgba(91, 143, 185, .15);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--z-base: 1;--z-nav: 100;--z-modal-backdrop: 500;--z-modal: 600;--z-fab: 400;--z-toast: 700}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}h1{font-size:1.75rem;font-weight:800;letter-spacing:-.03em}h2{font-size:1.375rem;font-weight:700;letter-spacing:-.02em}h3{font-size:1.125rem;font-weight:600;letter-spacing:-.01em}h4{font-size:1rem;font-weight:600}.app-header{position:sticky;top:0;z-index:var(--z-nav);background:#0f1419eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);padding:var(--space-sm) var(--space-md)}.app-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto}.app-logo{display:flex;align-items:center;gap:var(--space-sm);font-weight:800;font-size:1.125rem;color:var(--text-primary);text-decoration:none;letter-spacing:-.02em}.app-logo svg{width:28px;height:28px}.app-logo span{background:linear-gradient(135deg,var(--residential) 0%,var(--commercial) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-tabs{display:flex;gap:var(--space-xs)}.nav-tab{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);border:none;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);min-height:44px;display:flex;align-items:center;gap:var(--space-xs)}.nav-tab:hover,.nav-tab.active{background:var(--bg-surface);color:var(--text-primary)}.nav-tab .nav-icon{width:18px;height:18px;opacity:.7}.nav-tab.active .nav-icon{opacity:1}.main-content{flex:1;max-width:1400px;width:100%;margin:0 auto;padding:var(--space-md)}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);transition:all var(--transition-fast)}.card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md)}.card-glass{background:#1e2a3a99;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.kanban-board{display:flex;gap:var(--space-md);overflow-x:auto;padding-bottom:var(--space-md);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;min-height:calc(100vh - 140px)}.kanban-column{min-width:300px;width:300px;flex-shrink:0;scroll-snap-align:start;display:flex;flex-direction:column}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm);border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-subtle);position:sticky;top:0}.kanban-column-title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.kanban-column-count{font-size:.75rem;font-weight:700;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-secondary)}.kanban-cards{flex:1;display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-xs);border-radius:var(--radius-md);min-height:100px;transition:background var(--transition-fast)}.kanban-cards.drag-over{background:#d4915e0f;outline:2px dashed var(--border-default);outline-offset:-2px;border-radius:var(--radius-md)}.kanban-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);cursor:grab;transition:all var(--transition-fast);position:relative;overflow:hidden}.kanban-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:4px 0 0 4px}.kanban-card.residential:before{background:var(--residential)}.kanban-card.commercial:before{background:var(--commercial)}.kanban-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card:active{cursor:grabbing;transform:scale(.98);box-shadow:var(--shadow-lg)}.kanban-card.dragging{opacity:.5;transform:rotate(2deg)}.card-customer-name{font-weight:600;font-size:.9375rem;margin-bottom:var(--space-xs);display:flex;align-items:center;gap:var(--space-sm)}.card-type-badge{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 8px;border-radius:var(--radius-full);line-height:1.4}.badge-residential{background:var(--residential-dim);color:var(--residential)}.badge-commercial{background:var(--commercial-dim);color:var(--commercial)}.card-address{font-size:.8125rem;color:var(--text-secondary);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.card-address svg{width:14px;height:14px;flex-shrink:0;opacity:.5}.card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);font-size:.75rem}.card-fence-type{color:var(--text-muted);text-transform:capitalize}.card-value{font-weight:600;color:var(--success)}.card-decision-date{font-size:.6875rem;color:var(--warning);margin-top:var(--space-xs);display:flex;align-items:center;gap:var(--space-xs)}.card-overdue-badge{position:absolute;top:var(--space-sm);right:var(--space-sm);width:8px;height:8px;border-radius:var(--radius-full);background:var(--danger);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #cf667966}50%{opacity:.8;box-shadow:0 0 0 6px #cf667900}}.fab{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:var(--z-fab);width:56px;height:56px;border-radius:var(--radius-full);border:none;background:linear-gradient(135deg,var(--residential) 0%,#c07a45 100%);color:#fff;font-size:1.5rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #d4915e66;transition:all var(--transition-normal)}.fab:hover{transform:scale(1.08);box-shadow:0 6px 28px #d4915e80}.fab:active{transform:scale(.95)}.fab svg{width:24px;height:24px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal-backdrop);background:var(--bg-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.modal-backdrop.active{opacity:1;pointer-events:auto}.modal{position:fixed;z-index:var(--z-modal);background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl) var(--radius-xl) 0 0;bottom:0;left:0;right:0;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform var(--transition-slow);padding-bottom:env(safe-area-inset-bottom,0px)}.modal.active{transform:translateY(0)}.modal-handle{width:36px;height:4px;border-radius:var(--radius-full);background:var(--border-strong);margin:var(--space-sm) auto var(--space-md)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg) var(--space-md)}.modal-title{font-size:1.25rem;font-weight:700}.modal-close{width:36px;height:36px;border-radius:var(--radius-full);border:none;background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-body{padding:0 var(--space-lg) var(--space-lg)}@media(min-width:768px){.modal{top:50%;left:50%;right:auto;bottom:auto;transform:translate(-50%,-50%) scale(.95);opacity:0;border-radius:var(--radius-xl);max-width:560px;width:100%;max-height:85vh}.modal.active{transform:translate(-50%,-50%) scale(1);opacity:1}.modal-handle{display:none}}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);min-height:48px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:1rem;transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--residential);box-shadow:0 0 0 3px #d4915e26}.form-input::placeholder{color:var(--text-muted)}.form-textarea{min-height:80px;resize:vertical}.form-select{background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238a9bb5' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md)}@media(max-width:480px){.form-row,.form-row-3{grid-template-columns:1fr}}.type-toggle{display:flex;gap:0;background:var(--bg-surface);border-radius:var(--radius-md);padding:4px;border:1px solid var(--border-subtle)}.type-toggle-btn{flex:1;min-height:44px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.type-toggle-btn.active-residential{background:var(--residential-dim);color:var(--residential);box-shadow:var(--shadow-sm)}.type-toggle-btn.active-commercial{background:var(--commercial-dim);color:var(--commercial);box-shadow:var(--shadow-sm)}.stepper{display:flex;align-items:center;gap:0;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.stepper-btn{width:48px;height:48px;border:none;background:transparent;color:var(--text-primary);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.stepper-btn:hover{background:var(--bg-elevated)}.stepper-value{flex:1;text-align:center;font-size:1rem;font-weight:600;min-width:48px;color:var(--text-primary)}.toggle-switch{position:relative;display:inline-flex;align-items:center;gap:var(--space-sm);cursor:pointer;min-height:44px}.toggle-switch input{position:absolute;opacity:0;width:0;height:0}.toggle-track{width:44px;height:24px;border-radius:var(--radius-full);background:var(--bg-elevated);border:1px solid var(--border-default);position:relative;transition:all var(--transition-fast);flex-shrink:0}.toggle-track:after{content:"";position:absolute;width:18px;height:18px;border-radius:var(--radius-full);background:var(--text-secondary);top:2px;left:2px;transition:all var(--transition-fast)}.toggle-switch input:checked+.toggle-track{background:var(--success-dim);border-color:var(--success)}.toggle-switch input:checked+.toggle-track:after{background:var(--success);transform:translate(20px)}.toggle-label{font-size:.875rem;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);min-height:48px;padding:var(--space-sm) var(--space-lg);border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--residential) 0%,#c07a45 100%);color:#fff;box-shadow:0 2px 12px #d4915e4d}.btn-primary:hover{box-shadow:0 4px 20px #d4915e66;transform:translateY(-1px)}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-surface);color:var(--text-primary)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(207,102,121,.2)}.btn-danger:hover{background:#cf667940}.btn-success{background:var(--success-dim);color:var(--success);border:1px solid rgba(76,175,125,.2)}.btn-success:hover{background:#4caf7d40}.btn-sm{min-height:36px;padding:var(--space-xs) var(--space-md);font-size:.8125rem}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.job-detail{max-width:800px;margin:0 auto}.job-detail-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.job-detail-header .back-btn{width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.job-detail-header .back-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.stage-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--bg-elevated);color:var(--text-secondary)}.stage-new_lead{background:var(--info);color:#fff;background:#5b8fb933;color:var(--info)}.stage-site_visit_scheduled{background:#9c81e633;color:#9c81e6}.stage-estimate_sent{background:var(--warning-dim);color:var(--warning)}.stage-job_approved{background:var(--success-dim);color:var(--success)}.stage-scheduled{background:#5b8fb933;color:var(--commercial)}.stage-in_progress{background:#d4915e33;color:var(--residential)}.stage-complete{background:var(--success-dim);color:var(--success)}.stage-follow_up{background:#e8a44a33;color:var(--warning)}.detail-section{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-md);overflow:hidden}.detail-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-md) var(--space-sm)}.detail-section-title{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.detail-section-body{padding:0 var(--space-md) var(--space-md)}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm) var(--space-md)}@media(max-width:480px){.field-grid{grid-template-columns:1fr}}.field-item{display:flex;flex-direction:column;gap:2px}.field-label{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.field-value{font-size:.9375rem;color:var(--text-primary);padding:var(--space-xs) 0;border-bottom:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);min-height:32px}.field-value:hover{border-bottom-color:var(--border-default)}.field-value.editing{padding:var(--space-xs) var(--space-sm);background:var(--bg-primary);border:1px solid var(--residential);border-radius:var(--radius-sm)}.field-value-empty{color:var(--text-muted);font-style:italic}.field-full{grid-column:1 / -1}.permit-checklist{display:flex;flex-direction:column;gap:var(--space-sm)}.permit-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);min-height:48px}.permit-item-label{font-size:.875rem;color:var(--text-primary)}.permit-status-select{min-height:36px;padding:4px 32px 4px 12px;font-size:.8125rem;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%238a9bb5' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.notes-log{display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto}.note-item{padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);border-left:3px solid var(--border-default)}.note-text{font-size:.875rem;color:var(--text-primary);margin-bottom:var(--space-xs)}.note-timestamp{font-size:.6875rem;color:var(--text-muted)}.note-input-row{display:flex;gap:var(--space-sm);margin-top:var(--space-sm)}.note-input-row .form-input{flex:1;min-height:44px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-sm)}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-primary);border:1px solid var(--border-subtle)}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-label-badge{position:absolute;bottom:var(--space-xs);left:var(--space-xs);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:var(--radius-sm);background:#000000b3;color:#fff}.photo-delete-btn{position:absolute;top:var(--space-xs);right:var(--space-xs);width:24px;height:24px;border-radius:var(--radius-full);border:none;background:#000000b3;color:var(--danger);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:.75rem}.photo-item:hover .photo-delete-btn{display:flex}.photo-upload-area{aspect-ratio:1;border:2px dashed var(--border-default);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs);cursor:pointer;transition:all var(--transition-fast);color:var(--text-muted);font-size:.75rem}.photo-upload-area:hover{border-color:var(--residential);color:var(--residential);background:var(--residential-dim)}.photo-upload-area svg{width:24px;height:24px}.quote-summary{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.quote-line{display:flex;justify-content:space-between;padding:var(--space-xs) 0;font-size:.875rem}.quote-line-label{color:var(--text-secondary)}.quote-line-value{font-weight:600;color:var(--text-primary)}.quote-total{grid-column:1 / -1;display:flex;justify-content:space-between;padding:var(--space-md) 0;border-top:1px solid var(--border-default);font-size:1.125rem;margin-top:var(--space-sm)}.quote-total-label{font-weight:600;color:var(--text-primary)}.quote-total-value{font-weight:800;color:var(--success)}.reminder-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border-radius:var(--radius-sm);border-left:3px solid var(--border-default);min-height:48px}.reminder-item.overdue{border-left-color:var(--danger);background:var(--danger-dim)}.reminder-item.upcoming{border-left-color:var(--warning)}.reminder-check{width:22px;height:22px;border-radius:var(--radius-full);border:2px solid var(--border-strong);background:transparent;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.reminder-check:hover{border-color:var(--success);background:var(--success-dim)}.reminder-check.completed{border-color:var(--success);background:var(--success)}.reminder-content{flex:1;min-width:0}.reminder-note{font-size:.875rem;color:var(--text-primary)}.reminder-date{font-size:.6875rem;color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs);transition:all var(--transition-fast)}.stat-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.stat-value{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.stat-value.revenue{color:var(--success)}.stat-value.warning{color:var(--warning)}.stat-subtext{font-size:.8125rem;color:var(--text-secondary)}.pipeline-bar{display:flex;gap:2px;height:8px;border-radius:var(--radius-full);overflow:hidden;background:var(--bg-primary);margin-top:var(--space-sm)}.pipeline-bar-segment{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.overdue-list{display:flex;flex-direction:column;gap:var(--space-sm)}.overdue-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid var(--danger)}.overdue-item:hover{background:var(--bg-surface-hover);border-color:var(--border-default)}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.text-res{color:var(--residential)}.text-com{color:var(--commercial)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-muted);text-align:center}.empty-state svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.4}.empty-state p{font-size:.875rem;max-width:240px}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-sm)}.toast{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);font-size:.875rem;color:var(--text-primary);animation:slideIn .3s ease-out,fadeOut .3s ease-in 2.7s forwards;max-width:360px}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.spinner{width:24px;height:24px;border:3px solid var(--border-subtle);border-top-color:var(--residential);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.estimator-page{max-width:900px;margin:0 auto}.estimator-header{margin-bottom:var(--space-lg)}.estimator-title{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.estimator-title-icon{width:28px;height:28px;color:var(--residential)}.estimator-subtitle{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.estimator-form-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.estimator-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md)}@media(max-width:640px){.estimator-form-grid{grid-template-columns:1fr 1fr}}@media(max-width:400px){.estimator-form-grid{grid-template-columns:1fr}}.form-hint{display:block;font-size:.6875rem;color:var(--text-muted);margin-top:var(--space-xs);min-height:16px;transition:all var(--transition-fast)}.form-hint-active{color:var(--residential)}.estimator-results{animation:fadeSlideUp .4s ease-out}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.soil-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg);position:relative;overflow:hidden}.soil-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--residential),var(--commercial))}.soil-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.soil-icon-wrapper{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;border:1px solid;flex-shrink:0}.soil-icon{font-size:1.5rem}.soil-info{flex:1;min-width:0}.soil-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin-bottom:0}.soil-nickname{font-size:.8125rem;color:var(--text-muted);font-style:italic}.soil-difficulty{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.soil-diff-label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.soil-diff-value{font-size:1rem;font-weight:800}.soil-diff-multiplier{font-size:.6875rem;color:var(--text-muted)}.soil-description{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-md)}.soil-tips{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-md)}.soil-tips-title{font-size:.8125rem;font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.soil-tips-list{padding-left:var(--space-lg);margin:0;display:flex;flex-direction:column;gap:var(--space-xs)}.soil-tips-list li{font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.soil-tips-hidden{display:none}.soil-tips-expand{margin-top:var(--space-sm)}.estimate-inputs-summary{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.estimate-input-tag{display:inline-flex;align-items:center;gap:var(--space-xs);padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:500;background:var(--bg-surface);border:1px solid var(--border-subtle);color:var(--text-secondary)}.tier-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}@media(max-width:768px){.tier-cards-grid{grid-template-columns:1fr}}.tier-card{background:var(--bg-surface);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.tier-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-2px)}.tier-card-selected{border-color:var(--residential)!important;box-shadow:0 0 0 2px #d4915e33,var(--shadow-lg)!important;transform:translateY(-4px)!important}.tier-card-selected:after{content:"✓";position:absolute;top:var(--space-sm);right:var(--space-sm);width:24px;height:24px;border-radius:var(--radius-full);background:var(--residential);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.tier-card-ribbon{position:absolute;top:0;left:0;right:0;height:4px}.tier-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);margin-top:var(--space-xs)}.tier-card-icon{font-size:1.5rem}.tier-card-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:0;line-height:1.2}.tier-card-subtitle{font-size:.6875rem;color:var(--text-muted);font-weight:500}.tier-card-total{text-align:center;padding:var(--space-md) 0;margin-bottom:var(--space-md);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.tier-total-amount{display:block;font-size:1.75rem;font-weight:800;letter-spacing:-.03em;line-height:1.2}.tier-total-perfoot{font-size:.75rem;color:var(--text-muted);font-weight:500}.tier-breakdown{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.tier-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.8125rem}.tier-breakdown-label{color:var(--text-secondary)}.tier-breakdown-value{font-weight:600;color:var(--text-primary)}.tier-card-footer{border-top:1px solid var(--border-subtle);padding-top:var(--space-sm)}.tier-card-desc{font-size:.75rem;color:var(--text-muted);line-height:1.5}.estimate-actions{text-align:center;padding:var(--space-lg) 0}.estimate-action-hint{font-size:.75rem;color:var(--text-muted);margin-top:var(--space-sm)}.job-picker{max-height:400px;overflow-y:auto}.job-picker-summary{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.5}.job-picker-list{display:flex;flex-direction:column;gap:var(--space-sm)}.job-picker-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:left;font-family:inherit;color:inherit}.job-picker-item:hover{background:var(--bg-surface-hover);border-color:var(--border-default);box-shadow:var(--shadow-sm)}.job-picker-item-name{font-size:.9375rem;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-picker-item-meta{font-size:.75rem;color:var(--text-muted);text-transform:capitalize;white-space:nowrap}.job-picker-item-stage{flex-shrink:0}.pricing-source-banner{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.8125rem;flex-wrap:wrap}.pricing-source-default{background:#e8a44a1a;border:1px solid rgba(232,164,74,.25);color:var(--warning)}.pricing-source-supplier{background:#4caf7d1a;border:1px solid rgba(76,175,125,.25);color:var(--success)}.pricing-source-icon{font-size:1rem;flex-shrink:0}.pricing-source-text{flex:1;min-width:0}.tier-source-badge{font-size:.5625rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:var(--radius-full);margin-left:auto;flex-shrink:0;white-space:nowrap}.tier-source-default{background:#e8a44a26;color:var(--warning)}.tier-source-supplier{background:#4caf7d26;color:var(--success)}.pricing-config-modal{max-height:60vh;overflow-y:auto}.pricing-config-intro{font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.6}.pricing-tier-section{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle)}.pricing-tier-section:last-of-type{border-bottom:none}.pricing-tier-title{font-size:.9375rem;font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.pricing-fields-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-sm)}@media(max-width:480px){.pricing-fields-row{grid-template-columns:1fr}}.pricing-field label{display:block;font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:2px}.pricing-field .form-input{min-height:40px;font-size:.875rem}.pricing-config-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md);flex-wrap:wrap}.wiki-layout{display:flex;gap:var(--space-md);height:calc(100vh - 120px)}@media(max-width:768px){.wiki-layout{flex-direction:column;height:auto}}.wiki-sidebar{width:320px;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}@media(max-width:768px){.wiki-sidebar{width:100%;height:400px}}.wiki-sidebar-header{padding:var(--space-md);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle);background:var(--bg-elevated)}.wiki-sidebar-header h2{font-size:1.125rem;margin:0}.wiki-search{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-subtle)}.wiki-search input{width:100%;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary)}.wiki-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.wiki-list-empty{padding:var(--space-md);text-align:center;color:var(--text-muted);font-style:italic}.wiki-list-item{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wiki-list-item:hover{background:#ffffff0d}.wiki-list-item.active{background:var(--residential-dim);color:var(--residential-light);border-left:3px solid var(--residential)}.wiki-main{flex:1;background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);display:flex;flex-direction:column;overflow:hidden;position:relative}.wiki-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center;padding:var(--space-lg)}.wiki-content-view,.wiki-editor{display:flex;flex-direction:column;height:100%;padding:var(--space-lg);overflow-y:auto}.wiki-content-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle)}.wiki-content-header h2{margin:0;color:var(--residential-light);font-size:1.5rem}.wiki-content-actions{display:flex;gap:var(--space-sm)}.wiki-content-body{flex:1;white-space:pre-wrap;line-height:1.6;font-size:1rem;color:var(--text-primary);overflow-wrap:break-word}.wiki-editor h2{margin-bottom:var(--space-md);color:var(--text-primary)}.wiki-editor-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-md)}
