:root{--primary-50: #eef2ff;--primary-100: #dbe4ff;--primary-200: #bac8ff;--primary-300: #91a7ff;--primary-400: #748ffc;--primary-500: #5c7cfa;--primary-600: #4c6ef5;--primary-700: #4263eb;--primary-800: #3b5bdb;--primary-900: #364fc7;--accent-400: #ffa94d;--accent-500: #ff922b;--accent-600: #fd7e14;--success-400: #69db7c;--success-500: #51cf66;--success-600: #40c057;--warning-400: #ffd43b;--warning-500: #fcc419;--warning-600: #fab005;--danger-400: #ff8787;--danger-500: #ff6b6b;--danger-600: #fa5252;--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-tertiary: #1a2035;--bg-card: rgba(26, 32, 53, .8);--bg-glass: rgba(26, 32, 53, .6);--bg-hover: rgba(92, 124, 250, .08);--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .15);--border-focus: var(--primary-500);--text-primary: #f1f3f5;--text-secondary: #adb5bd;--text-tertiary: #868e96;--text-muted: #495057;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px rgba(92, 124, 250, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-primary: #f5f6fa;--bg-secondary: #ffffff;--bg-tertiary: #eef0f6;--bg-card: rgba(255, 255, 255, .85);--bg-glass: rgba(255, 255, 255, .7);--bg-hover: rgba(92, 124, 250, .06);--border-subtle: rgba(0, 0, 0, .06);--border-default: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .15);--text-primary: #1a1d2e;--text-secondary: #4a5068;--text-tertiary: #6b7280;--text-muted: #9ca3af;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--shadow-glow: 0 0 40px rgba(92, 124, 250, .08);--primary-300: #4263eb;--primary-400: #3b5bdb}[data-theme=light] .header{background:#ffffffd9}[data-theme=light] body:before{background:radial-gradient(circle,rgba(92,124,250,.04) 0%,transparent 70%)}[data-theme=light] body:after{background:radial-gradient(circle,rgba(255,146,43,.03) 0%,transparent 70%)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#0003}[data-theme=light] .header-icon-btn .notification-dot{border-color:var(--bg-secondary)}[data-theme=light] .sidebar-brand-name{background:linear-gradient(135deg,var(--primary-600),var(--primary-800));-webkit-background-clip:text;background-clip:text}[data-theme=light] .form-select option{background:#fff;color:#1a1d2e}html,body,.sidebar,.header,.card,.stat-card,.pipeline-column,.pipeline-card,.contractor-card,.modal,.toast,.form-input,.form-select,.form-textarea,.btn-secondary,.header-icon-btn,.filter-chip{transition:background-color .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:-30%;left:-10%;width:60%;height:60%;background:radial-gradient(circle,rgba(92,124,250,.06) 0%,transparent 70%);pointer-events:none;z-index:0}body:after{content:"";position:fixed;bottom:-20%;right:-10%;width:50%;height:50%;background:radial-gradient(circle,rgba(255,146,43,.04) 0%,transparent 70%);pointer-events:none;z-index:0}#app{position:relative;z-index:1}a{color:var(--primary-400);text-decoration:none}a:hover{color:var(--primary-300)}input,select,textarea,button{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-base)}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.sidebar-brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;box-shadow:0 4px 12px #5c7cfa4d}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-name{font-size:1.1rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--primary-300),var(--primary-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-brand-sub{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em;font-weight:500}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-section-title{font-size:.65rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.12em;padding:16px 12px 8px}.sidebar-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);position:relative;-webkit-user-select:none;user-select:none}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:#5c7cfa1f;color:var(--primary-400)}.sidebar-nav-item.active:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--primary-500);border-radius:0 3px 3px 0}.sidebar-nav-item .material-icons-round{font-size:20px;opacity:.8}.sidebar-nav-item .badge{margin-left:auto;background:var(--danger-500);color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);min-width:20px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--border-subtle)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent-500),var(--danger-500));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.7rem;color:var(--text-tertiary)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.header{height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 32px;border-bottom:1px solid var(--border-subtle);background:#0a0e1acc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:16px}.header-title{font-size:1.2rem;font-weight:700;letter-spacing:-.02em}.header-subtitle{font-size:.8rem;color:var(--text-tertiary)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:4px;border-radius:var(--radius-sm)}.header-right{display:flex;align-items:center;gap:12px}.header-search{position:relative}.header-search input{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-full);padding:8px 16px 8px 40px;color:var(--text-primary);width:240px;font-size:.85rem;transition:all var(--transition-fast);outline:none}.header-search input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #5c7cfa26;width:300px}.header-search input::placeholder{color:var(--text-muted)}.header-search .material-icons-round{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--text-muted)}.header-icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);position:relative}.header-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-default)}.header-icon-btn .notification-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;background:var(--danger-500);border-radius:50%;border:2px solid var(--bg-primary)}.page-content{padding:28px 32px}.card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-base)}.card:hover{border-color:var(--border-default)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:1rem;font-weight:700;letter-spacing:-.01em}.card-subtitle{font-size:.8rem;color:var(--text-tertiary);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:22px 24px;position:relative;overflow:hidden;transition:all var(--transition-base)}.stat-card:hover{border-color:var(--border-default);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card:after{content:"";position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:.06;transform:translate(30%,-30%)}.stat-card.purple:after{background:var(--primary-500)}.stat-card.orange:after{background:var(--accent-500)}.stat-card.green:after{background:var(--success-500)}.stat-card.red:after{background:var(--danger-500)}.stat-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px}.stat-card.purple .stat-card-icon{background:#5c7cfa1f;color:var(--primary-400)}.stat-card.orange .stat-card-icon{background:#ff922b1f;color:var(--accent-400)}.stat-card.green .stat-card-icon{background:#51cf661f;color:var(--success-400)}.stat-card.red .stat-card-icon{background:#ff6b6b1f;color:var(--danger-400)}.stat-card-trend{font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-full)}.stat-card-trend.up{color:var(--success-400);background:#51cf661a}.stat-card-trend.down{color:var(--danger-400);background:#ff6b6b1a}.stat-card-value{font-size:1.8rem;font-weight:800;letter-spacing:-.03em;line-height:1;margin-bottom:4px}.stat-card-label{font-size:.8rem;color:var(--text-tertiary);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);border:none;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn .material-icons-round{font-size:18px}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;box-shadow:0 2px 8px #5c7cfa4d}.btn-primary:hover{box-shadow:0 4px 16px #5c7cfa73;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,var(--danger-500),var(--danger-600));color:#fff}.btn-success{background:linear-gradient(135deg,var(--success-500),var(--success-600));color:#fff}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--text-secondary)}.form-label .required{color:var(--danger-500);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #5c7cfa1f}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-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 24 24' fill='none' stroke='%23868e96' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-textarea{min-height:100px;resize:vertical}.form-hint{font-size:.75rem;color:var(--text-tertiary);margin-top:4px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{font-size:.75rem;color:var(--danger-500);margin-top:4px}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-tertiary)}.data-table th{padding:12px 16px;text-align:left;font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.data-table td{padding:14px 16px;font-size:.87rem;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary)}.data-table tbody tr{transition:background var(--transition-fast);cursor:pointer}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}table{background:var(--bg-card)!important}table td,table th{background:inherit}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%}.status-badge.new{background:#5c7cfa1f;color:var(--primary-400)}.status-badge.new:before{background:var(--primary-400)}.status-badge.picked{background:#a855f71f;color:#c084fc}.status-badge.picked:before{background:#c084fc}.status-badge.contacted{background:#06b6d41f;color:#22d3ee}.status-badge.contacted:before{background:#22d3ee}.status-badge.quoted{background:#ff922b1f;color:var(--accent-400)}.status-badge.quoted:before{background:var(--accent-400)}.status-badge.confirmed{background:#51cf661f;color:var(--success-400)}.status-badge.confirmed:before{background:var(--success-400)}.status-badge.cancelled{background:#ff6b6b1f;color:var(--danger-400)}.status-badge.cancelled:before{background:var(--danger-400)}.status-badge.requested{background:#60a5fa1f;color:#60a5fa}.status-badge.requested:before{background:#60a5fa}.status-badge.approval_pending{background:#fbbf241f;color:#fbbf24}.status-badge.approval_pending:before{background:#fbbf24}.status-badge.completed{background:#868e961f;color:var(--text-tertiary)}.status-badge.completed:before{background:var(--text-tertiary)}.status-badge.pending{background:#fcc4191f;color:var(--warning-500)}.status-badge.pending:before{background:var(--warning-500)}.status-badge.won{background:#51cf6626;color:#4ade80}.status-badge.won:before{background:#4ade80}.status-badge.lost{background:#ff6b6b1f;color:var(--danger-400)}.status-badge.lost:before{background:var(--danger-400)}.pipeline-board{display:flex;gap:16px;overflow-x:auto;padding-bottom:16px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.pipeline-column{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);min-width:280px;width:280px;flex-shrink:0}.pipeline-column-header{padding:16px 18px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.pipeline-column-title{font-size:.82rem;font-weight:700;display:flex;align-items:center;gap:8px}.pipeline-column-count{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-tertiary)}.pipeline-column-body{padding:12px;display:flex;flex-direction:column;gap:10px;min-height:100px;max-height:65vh;overflow-y:auto}.pipeline-card{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px;cursor:pointer;transition:all var(--transition-fast)}.pipeline-card:hover{border-color:var(--primary-500);transform:translateY(-2px);box-shadow:var(--shadow-md)}.pipeline-card-name{font-size:.88rem;font-weight:600;margin-bottom:4px}.pipeline-card-route{font-size:.78rem;color:var(--text-tertiary);display:flex;align-items:center;gap:4px;margin-bottom:8px}.pipeline-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:.72rem;color:var(--text-muted)}.pipeline-card-meta-item{display:flex;align-items:center;gap:4px}.pipeline-card-meta-item .material-icons-round{font-size:14px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-subtle);margin-bottom:24px}.tab{padding:12px 18px;font-size:.85rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-400);border-bottom-color:var(--primary-500)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;box-shadow:var(--shadow-xl)}.modal-lg{max-width:900px}.modal-xl{max-width:1100px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px 16px;border-bottom:1px solid var(--border-subtle)}.modal-title{font-size:1.15rem;font-weight:700}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:none;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--danger-500);color:#fff}.modal-body{padding:24px 28px}.modal-footer{padding:16px 28px 24px;display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border-subtle)}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:14px 20px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);min-width:320px;animation:slideInRight .3s ease;font-size:.87rem}.toast.success{border-left:3px solid var(--success-500)}.toast.error{border-left:3px solid var(--danger-500)}.toast.info{border-left:3px solid var(--primary-500)}.toast.warning{border-left:3px solid var(--warning-500)}.toast-close{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.empty-state{text-align:center;padding:60px 20px}.empty-state-icon{font-size:48px;color:var(--text-muted);margin-bottom:16px}.empty-state-title{font-size:1.1rem;font-weight:600;margin-bottom:8px}.empty-state-text{font-size:.87rem;color:var(--text-tertiary);margin-bottom:20px}.detail-panel{display:grid;grid-template-columns:1fr 360px;gap:24px}.detail-section{margin-bottom:28px}.detail-section-title{font-size:.8rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.detail-row{display:flex;justify-content:space-between;padding:8px 0;font-size:.87rem}.detail-row-label{color:var(--text-tertiary)}.detail-row-value{font-weight:500;text-align:right}.timeline{position:relative;padding-left:28px}.timeline:before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--border-subtle)}.timeline-item{position:relative;padding-bottom:20px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-24px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--primary-500)}.timeline-dot.success{border-color:var(--success-500)}.timeline-dot.warning{border-color:var(--warning-500)}.timeline-dot.danger{border-color:var(--danger-500)}.timeline-content{font-size:.85rem;color:var(--text-secondary)}.timeline-time{font-size:.72rem;color:var(--text-muted);margin-top:3px}.contractor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.contractor-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;transition:all var(--transition-base);cursor:pointer}.contractor-card:hover{border-color:var(--primary-500);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.contractor-card-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.contractor-avatar{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff}.contractor-name{font-size:1rem;font-weight:700}.contractor-company{font-size:.78rem;color:var(--text-tertiary)}.contractor-details{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.contractor-detail{font-size:.8rem}.contractor-detail-label{color:var(--text-muted);font-size:.7rem;margin-bottom:2px}.contractor-detail-value{color:var(--text-secondary);font-weight:500}.contractor-tags{display:flex;flex-wrap:wrap;gap:6px}.contractor-tag{padding:3px 10px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-subtle);font-size:.7rem;color:var(--text-tertiary);font-weight:500}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);background:var(--bg-tertiary);border:1px solid var(--border-subtle);font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.filter-chip:hover{border-color:var(--border-default);color:var(--text-primary)}.filter-chip.active{background:#5c7cfa1f;border-color:var(--primary-500);color:var(--primary-400)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle)}.calendar-header-cell{background:var(--bg-tertiary);padding:10px;text-align:center;font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.calendar-cell{background:var(--bg-card);min-height:100px;padding:8px}.calendar-cell-date{font-size:.8rem;font-weight:600;margin-bottom:6px;color:var(--text-tertiary)}.calendar-cell.today .calendar-cell-date{color:var(--primary-400);background:#5c7cfa26;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%}.calendar-cell.other-month{opacity:.3}.calendar-event{padding:3px 6px;border-radius:4px;font-size:.68rem;font-weight:500;margin-bottom:3px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event.confirmed{background:#51cf6626;color:var(--success-400)}.calendar-event.quoted{background:#ff922b26;color:var(--accent-400)}.calendar-event.new{background:#5c7cfa26;color:var(--primary-400)}.public-form-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-primary);position:relative}.public-form-container{width:100%;max-width:720px}.public-form-header{text-align:center;margin-bottom:40px}.public-form-logo{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;margin:0 auto 20px;box-shadow:0 8px 24px #5c7cfa4d}.public-form-title{font-size:1.8rem;font-weight:800;letter-spacing:-.03em;margin-bottom:8px;background:linear-gradient(135deg,var(--text-primary),var(--primary-300));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.public-form-subtitle{font-size:.95rem;color:var(--text-tertiary)}.public-form-card{background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:36px;box-shadow:var(--shadow-xl)}.public-form-section-title{font-size:.85rem;font-weight:700;color:var(--primary-400);margin-bottom:16px;margin-top:8px;display:flex;align-items:center;gap:8px}.public-form-section-title .material-icons-round{font-size:18px}.public-form-submit{width:100%;padding:14px;margin-top:16px;font-size:1rem}.public-form-footer{text-align:center;margin-top:20px;font-size:.78rem;color:var(--text-muted)}.form-success{text-align:center;padding:60px 20px}.form-success-icon{width:80px;height:80px;background:#51cf661f;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:scaleIn .5s ease}.form-success-icon .material-icons-round{font-size:40px;color:var(--success-400)}.form-success-title{font-size:1.5rem;font-weight:800;margin-bottom:8px}.form-success-text{color:var(--text-tertiary);margin-bottom:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.status-badge.pending_approval{background:#fcc4191f;color:var(--warning-500)}.status-badge.pending_approval:before{background:var(--warning-500)}.status-badge.rejected{background:#ff6b6b1f;color:var(--danger-400)}.status-badge.rejected:before{background:var(--danger-400)}.status-badge.approved{background:#51cf661f;color:var(--success-400)}.status-badge.approved:before{background:var(--success-400)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.animate-in{animation:slideUp .4s ease both}.animate-in-delay-1{animation-delay:.05s}.animate-in-delay-2{animation-delay:.1s}.animate-in-delay-3{animation-delay:.15s}.animate-in-delay-4{animation-delay:.2s}@media(max-width:1024px){.detail-panel{grid-template-columns:1fr}.pipeline-board{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-btn{display:flex}.header{padding:0 16px}.header-search{display:none}.page-content{padding:20px 16px}.form-row,.pipeline-board{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.public-form-card{padding:24px}.filter-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99}@media(max-width:768px){.sidebar-overlay.visible{display:block}}.text-center{text-align:center}.text-right{text-align:right}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.gap-2{gap:8px}.gap-4{gap:16px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.hidden{display:none!important}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stepper{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;position:relative;overflow-x:auto;padding-bottom:10px}.stepper:before{content:"";position:absolute;top:14px;left:0;right:0;height:2px;background:var(--border-default);z-index:0}.step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:80px;cursor:pointer;transition:all var(--transition-base)}.step-circle{width:30px;height:30px;border-radius:50%;background:var(--bg-card);border:2px solid var(--border-default);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--text-tertiary);transition:all var(--transition-base)}.step-label{font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-align:center;white-space:nowrap}.step.active .step-circle,.step.completed .step-circle{background:var(--primary-500);border-color:var(--primary-500);color:#fff;box-shadow:0 0 0 4px #5c7cfa33}.step.completed .step-circle{background:var(--success-500);border-color:var(--success-500);box-shadow:none}.step.active .step-label,.step.completed .step-label{color:var(--text-primary)}.step-sub-badge{font-size:.65rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-full);border:1px solid;display:inline-flex;align-items:center;gap:3px;margin-top:4px;white-space:nowrap;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.step.lost .step-circle{background:var(--danger-500);border-color:var(--danger-500);color:#fff;box-shadow:0 0 0 4px #ff6b6b33}.step.completed+.step:before{content:"";position:absolute;top:14px;left:-50%;right:50%;height:2px;background:var(--success-500);z-index:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-glow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.page-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:20px}.page-loader-spinner{width:48px;height:48px;border:3px solid var(--border-subtle);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite}.page-loader-text{font-size:.9rem;color:var(--text-tertiary);animation:pulse-glow 1.5s ease-in-out infinite}.skeleton-bar{height:14px;border-radius:6px;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--border-subtle) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.stepper{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;position:relative;overflow-x:auto;padding-bottom:10px;padding-top:6px}.stepper:before{content:"";position:absolute;top:20px;left:0;right:0;height:5px;background:var(--border-default);z-index:0;border-radius:3px}.stepper-progress{position:absolute;top:20px;left:0;height:5px;background:linear-gradient(90deg,var(--success-500),var(--success-400));z-index:0;border-radius:3px;transition:width .4s ease}.step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px;cursor:pointer;transition:all var(--transition-base)}.step-circle{width:32px;height:32px;border-radius:50%;background:var(--bg-card);border:3px solid var(--border-default);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--text-tertiary);transition:all var(--transition-base);flex-shrink:0}.step-label{font-size:.72rem;font-weight:600;color:var(--text-tertiary);text-align:center;white-space:nowrap}.step.completed .step-circle{background:var(--success-500);border-color:var(--success-500);color:#fff;box-shadow:none}.step.completed .step-label{color:var(--text-primary)}.step.active .step-circle{background:var(--success-500);border-color:var(--success-500);color:#fff;box-shadow:0 0 0 4px #51cf6640}.step.active .step-label{color:var(--text-primary);font-weight:700}.step.error .step-circle{background:var(--danger-500);border-color:var(--danger-500);color:#fff}.step.won .step-circle{background:var(--success-500);border-color:var(--success-500);color:#fff;box-shadow:0 0 0 4px #51cf6640}.step.won .step-label{color:var(--success-400);font-weight:700}.step.lost .step-circle{background:var(--danger-500);border-color:var(--danger-500);color:#fff;box-shadow:0 0 0 4px #ff6b6b40}.step.lost .step-label{color:var(--danger-400);font-weight:700}.step-sub-badge{font-size:.65rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);border:1px solid;display:flex;align-items:center;gap:3px;white-space:nowrap}
