.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;animation:none!important}.loading-spinner>svg,.loading-spinner .spinner-icon{color:var(--primary);animation:spinner-rotate 1s linear infinite!important}.loading-spinner.spinner-small>svg,.loading-spinner.spinner-small .spinner-icon{width:20px;height:20px}.loading-spinner.spinner-medium>svg,.loading-spinner.spinner-medium .spinner-icon{width:32px;height:32px}.loading-spinner.spinner-large>svg,.loading-spinner.spinner-large .spinner-icon{width:48px;height:48px}.loading-spinner>span,.loading-spinner .spinner-text{font-size:14px;color:var(--text-secondary);font-weight:500;animation:none!important;transform:none!important;white-space:nowrap;text-align:center}@keyframes spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hayvee-bubble{position:fixed;bottom:24px;right:24px;z-index:9999;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#1a73e8,#0d47a1);box-shadow:0 4px 20px #1a73e866;transition:transform .2s,box-shadow .2s}.hayvee-bubble:hover{transform:scale(1.08);box-shadow:0 6px 28px #1a73e88c}.hayvee-window{position:fixed;bottom:24px;right:24px;z-index:10000;width:400px;height:560px;background:#fff;border-radius:16px;box-shadow:0 12px 48px #0000002e;display:flex;flex-direction:column;overflow:hidden;animation:hayvee-slide-up .25s ease-out}@keyframes hayvee-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hayvee-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,#1a73e8,#0d47a1);color:#fff;flex-shrink:0}.hayvee-header-info{display:flex;align-items:center;gap:10px}.hayvee-avatar{width:36px;height:36px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.hayvee-title{font-weight:600;font-size:15px}.hayvee-subtitle{font-size:11px;opacity:.8}.hayvee-context-badge{display:inline-block;background:#ffffff40;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.3px}.hayvee-header-actions{display:flex;gap:4px}.hayvee-icon-btn{background:#ffffff26;border:none;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.hayvee-icon-btn:hover{background:#ffffff4d}.hayvee-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f7f8fa}.hayvee-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 8px 8px}.hayvee-welcome-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#1a73e8,#0d47a1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin-bottom:12px}.hayvee-welcome-title{font-size:18px;font-weight:600;color:#1a1a1a;margin:0 0 6px}.hayvee-welcome-text{font-size:13px;color:#666;margin:0 0 18px;line-height:1.5}.hayvee-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.hayvee-suggestion{background:#fff;border:1px solid #e0e0e0;border-radius:20px;padding:7px 14px;font-size:12px;color:#1a73e8;cursor:pointer;transition:all .15s}.hayvee-suggestion:hover{background:#e8f0fe;border-color:#1a73e8}.hayvee-msg{display:flex;gap:8px;max-width:92%}.hayvee-msg.user{align-self:flex-end;flex-direction:row-reverse}.hayvee-msg.assistant{align-self:flex-start}.hayvee-msg-avatar{width:28px;height:28px;min-width:28px;border-radius:50%;background:linear-gradient(135deg,#1a73e8,#0d47a1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-top:2px}.hayvee-msg-content{display:flex;flex-direction:column;gap:4px;max-width:100%}.hayvee-msg-bubble{padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.55;word-break:break-word}.hayvee-msg.user .hayvee-msg-bubble{background:#1a73e8;color:#fff;border-bottom-right-radius:4px}.hayvee-msg.assistant .hayvee-msg-bubble{background:#fff;color:#1a1a1a;border:1px solid #e8e8e8;border-bottom-left-radius:4px}.hayvee-actions-badge{display:flex;flex-wrap:wrap;gap:4px;padding-left:2px}.hayvee-action-chip{font-size:10px;color:#1a73e8;background:#e8f0fe;border-radius:10px;padding:2px 8px;font-weight:500}.hayvee-clickable-option{cursor:pointer;color:#1a73e8;padding:3px 0;border-radius:4px;transition:background .15s}.hayvee-clickable-option:hover{background:#e8f0fe;padding-left:4px}.hayvee-msg-bubble p{margin:0 0 6px}.hayvee-msg-bubble p:last-child{margin-bottom:0}.hayvee-msg-bubble ul{margin:4px 0;padding-left:18px}.hayvee-msg-bubble li{margin-bottom:3px}.hayvee-msg-bubble strong{font-weight:600}.hayvee-thinking{display:flex;align-items:center;gap:10px;padding:10px 14px!important}.hayvee-thinking-text{font-size:12px;color:#1a73e8;font-weight:500;white-space:nowrap}.hayvee-thinking-dots{display:flex;gap:4px}.hayvee-thinking-dots span{width:6px;height:6px;border-radius:50%;background:#1a73e8;animation:hayvee-bounce 1.2s infinite}.hayvee-thinking-dots span:nth-child(2){animation-delay:.15s}.hayvee-thinking-dots span:nth-child(3){animation-delay:.3s}@keyframes hayvee-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.hayvee-input-area{display:flex;align-items:center;padding:12px 14px;border-top:1px solid #eee;background:#fff;flex-shrink:0;gap:8px}.hayvee-input-area input{flex:1;border:1px solid #e0e0e0;border-radius:24px;padding:10px 16px;font-size:13px;outline:none;transition:border-color .15s;background:#f7f8fa}.hayvee-input-area input:focus{border-color:#1a73e8;background:#fff}.hayvee-input-area input:disabled{opacity:.6}.hayvee-send-btn{width:38px;height:38px;border-radius:50%;border:none;background:#1a73e8;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,opacity .15s;flex-shrink:0}.hayvee-send-btn:hover:not(:disabled){background:#0d47a1}.hayvee-send-btn:disabled{opacity:.4;cursor:default}.hayvee-messages::-webkit-scrollbar{width:5px}.hayvee-messages::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}@media(max-width:480px){.hayvee-window{width:calc(100vw - 16px);height:calc(100vh - 80px);bottom:8px;right:8px;border-radius:12px}.hayvee-bubble{bottom:16px;right:16px;width:50px;height:50px}}.layout{display:flex;min-height:100vh;background:var(--background)}.sidebar{width:280px;background:linear-gradient(180deg,#1e293b,#0f172a);display:flex;flex-direction:column;transition:width .3s ease;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar.collapsed{width:80px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.logo{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#fff}.logo-text{font-size:22px;font-weight:700;color:#fff}.sidebar-toggle{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#ffffffb3;transition:all .2s ease}.sidebar-toggle:hover{background:#ffffff1a;color:#fff}.sidebar.collapsed .sidebar-toggle{margin:0 auto}.sidebar-nav{flex:1;padding:20px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:#ffffffb3;font-weight:500;font-size:14px;transition:all .2s ease}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.nav-arrow{margin-left:auto;opacity:0;transition:all .2s ease}.nav-item:hover .nav-arrow,.nav-item.active .nav-arrow{opacity:1;transform:translate(4px)}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-arrow{display:none}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-avatar{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff}.user-details{display:flex;flex-direction:column}.user-name{font-size:14px;font-weight:600;color:#fff}.user-role{font-size:12px;color:#fff9;text-transform:capitalize}.logout-btn{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border-radius:10px;color:#ffffffb3;font-weight:500;font-size:14px;transition:all .2s ease}.logout-btn:hover{background:#ef444433;color:#fca5a5}.sidebar.collapsed .user-info{justify-content:center}.sidebar.collapsed .user-details{display:none}.sidebar.collapsed .logout-btn{justify-content:center;padding:12px}.sidebar.collapsed .logout-btn span{display:none}.main-content{flex:1;margin-left:280px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease}.sidebar.collapsed+.main-content,.sidebar.collapsed~.main-content{margin-left:80px}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.top-bar-left{display:flex;align-items:center;gap:16px}.page-title{font-size:24px;font-weight:700;color:var(--text)}.top-bar-right{display:flex;align-items:center;gap:8px}.top-bar-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.top-bar-btn:hover{background:var(--background);color:var(--text)}.top-bar-user{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--background);border-radius:10px;font-size:14px;font-weight:500;color:var(--text);margin-left:8px}.page-content{flex:1;padding:32px;overflow-y:auto}@media(max-width:1024px){.sidebar{width:80px}.sidebar .logo-text,.sidebar .nav-item span,.sidebar .nav-arrow,.sidebar .user-details,.sidebar .logout-btn span{display:none}.sidebar .nav-item,.sidebar .logout-btn{justify-content:center;padding:12px}.sidebar .user-info{justify-content:center}.main-content{margin-left:80px}}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);width:280px}.main-content{margin-left:0}.page-content{padding:20px}}.notification-wrapper,.top-bar-btn.has-badge{position:relative}.notification-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026;border:1px solid var(--border);z-index:1000;overflow:hidden}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--border)}.notification-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.mark-read-btn{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--primary);padding:4px 8px;border-radius:var(--radius-sm);transition:background .2s}.mark-read-btn:hover{background:#f973161a}.notification-list{max-height:400px;overflow-y:auto}.notification-empty{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:var(--text-tertiary)}.notification-empty p{margin:12px 0 0;font-size:14px}.notification-item{display:flex;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);transition:background .2s;cursor:pointer}.notification-item:hover{background:var(--background)}.notification-item.unread{background:#f973160d;border-left:3px solid var(--primary)}.notification-icon{width:36px;height:36px;border-radius:50%;background:var(--background);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-size:13px;font-weight:600;color:var(--text);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-body{font-size:12px;color:var(--text-secondary);margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:11px;color:var(--text-tertiary)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#eef2ff);padding:20px}.auth-container{display:flex;width:100%;max-width:1000px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000026;overflow:hidden}.auth-branding{flex:1;background:linear-gradient(135deg,#1e293b,#0f172a);padding:60px 48px;display:flex;flex-direction:column;justify-content:center;color:#fff}.brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.brand-logo .logo-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff}.brand-logo .logo-text{font-size:28px;font-weight:700}.auth-branding h1{font-size:36px;font-weight:700;margin-bottom:16px;color:#fff}.auth-branding>p{font-size:16px;opacity:.8;line-height:1.6;margin-bottom:40px;color:#fff}.brand-features{display:flex;flex-direction:column;gap:16px}.feature{display:flex;align-items:center;gap:12px;font-size:15px;opacity:.9;color:#fff}.feature-icon{width:24px;height:24px;background:#f973164d;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--primary)}.auth-form-container{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 48px;background:#fff}.auth-form-wrapper{width:100%;max-width:380px}.auth-header{text-align:center;margin-bottom:32px}.auth-header h2{font-size:28px;font-weight:700;color:var(--text);margin-bottom:8px}.auth-header p{font-size:15px;color:var(--text-secondary)}.auth-error{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#fee2e2;border:1px solid #FECACA;border-radius:var(--radius-md);margin-bottom:24px;color:#991b1b;font-size:14px}.auth-success{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#d1fae5;border:1px solid #A7F3D0;border-radius:var(--radius-md);margin-bottom:24px;color:#065f46;font-size:14px}.auth-info{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:var(--radius-md);margin-bottom:24px;color:#1e40af;font-size:14px;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:20px}.auth-form .form-group{margin-bottom:0}.auth-form label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.auth-input{width:100%;padding:14px 16px;background:#f8fafc;border:2px solid #E2E8F0;border-radius:var(--radius-md);font-size:15px;color:var(--text);transition:all .2s ease}.auth-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #f973161a}.auth-input::placeholder{color:#94a3b8}.auth-input.error{border-color:#ef4444}.password-input-wrapper{position:relative}.password-input-wrapper .auth-input{padding-right:48px}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);padding:8px;color:#64748b;cursor:pointer;transition:color .2s;background:none;border:none;display:flex;align-items:center;justify-content:center}.otp-input-wrapper{display:flex;gap:12px;justify-content:center}.otp-input{width:52px;height:60px;text-align:center;font-size:24px;font-weight:700;background:#f8fafc;border:2px solid #E2E8F0;border-radius:var(--radius-md);transition:all .2s ease}.otp-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #f973161a}.form-options{display:flex;justify-content:flex-end;margin-top:-8px}.forgot-link{font-size:13px;color:var(--primary);font-weight:500;transition:color .2s;text-decoration:none}.forgot-link:hover{color:var(--primary-dark)}.submit-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #f973164d}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.secondary-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;background:#fff;color:var(--primary);border:2px solid var(--primary);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.secondary-btn:hover:not(:disabled){background:#fff7ed}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.resend-section{text-align:center;margin-top:20px;font-size:14px;color:var(--text-secondary)}.resend-btn{color:var(--primary);font-weight:600;cursor:pointer;background:none;border:none;padding:0;margin-left:4px}.resend-btn:hover{text-decoration:underline}.resend-btn:disabled{color:var(--text-tertiary);cursor:not-allowed}.auth-footer{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.auth-footer p{font-size:14px;color:var(--text-secondary)}.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none;margin-left:4px}.auth-footer a:hover{text-decoration:underline}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px;text-decoration:none;transition:color .2s}.back-link:hover{color:var(--primary)}.email-display{display:flex;align-items:center;gap:12px;padding:16px;background:#f8fafc;border:2px solid #E2E8F0;border-radius:var(--radius-md);margin-bottom:24px}.email-display .email-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.email-display .email-text{flex:1}.email-display .email-label{font-size:12px;color:var(--text-tertiary);margin-bottom:2px}.email-display .email-value{font-size:14px;font-weight:600;color:var(--text)}.step-indicator{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:32px}.step{display:flex;align-items:center;gap:8px}.step-number{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;background:#e2e8f0;color:#64748b}.step-number.active{background:var(--primary);color:#fff}.step-number.completed{background:#10b981;color:#fff}.step-line{width:40px;height:2px;background:#e2e8f0}.step-line.completed{background:#10b981}.company-form-section{background:#f8fafc;border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.section-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #E2E8F0}.logo-upload{display:flex;flex-direction:column;align-items:center;padding:32px;background:#fff;border:2px dashed #E2E8F0;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.logo-upload:hover{border-color:var(--primary);background:#fff7ed}.logo-upload .upload-icon{width:64px;height:64px;background:#f1f5f9;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.logo-upload .upload-text{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.logo-upload .upload-hint{font-size:12px;color:var(--text-tertiary)}.logo-preview{width:100px;height:100px;border-radius:var(--radius-lg);object-fit:cover;margin-bottom:12px}@media(max-width:768px){.auth-container{flex-direction:column}.auth-branding{padding:40px 32px}.auth-branding h1{font-size:28px}.auth-branding>p{margin-bottom:24px}.brand-features{display:none}.auth-form-container{padding:40px 24px}.form-row{grid-template-columns:1fr}.otp-input{width:44px;height:52px;font-size:20px}}.dashboard{max-width:1400px;margin:0 auto}.dashboard-loading,.dashboard-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-secondary)}.dashboard-error h2{font-size:20px;font-weight:600;color:var(--text)}.dashboard-error p{color:var(--text-secondary);margin-bottom:16px}.welcome-section{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-xl);padding:32px;margin-bottom:32px;color:#fff}.welcome-text h1{font-size:28px;font-weight:700;margin-bottom:8px}.welcome-text p{font-size:16px;opacity:.9}.welcome-actions{display:flex;gap:12px}.welcome-actions .btn{background:#fff3;color:#fff;border:none}.welcome-actions .btn:hover{background:#ffffff4d}.welcome-actions .refresh-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;gap:6px}.welcome-actions .refresh-btn:hover{background:#ffffff40}.welcome-actions .refresh-btn:disabled{opacity:.7;cursor:not-allowed}.welcome-actions .refresh-btn .spin{animation:spin 1s linear infinite}.section{margin-bottom:32px}.section-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:16px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.stats-grid.three-col{grid-template-columns:repeat(3,1fr)}.stat-card{background:var(--surface);border-radius:var(--radius-xl);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-md);transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-card.highlight{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}.stat-card.highlight .stat-value,.stat-card.highlight .stat-label{color:#fff}.stat-card.highlight .stat-icon{background:#fff3;color:#fff}.stat-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.total{background:#3b82f626;color:#3b82f6}.stat-icon.assigned,.stat-icon.complete{background:#10b98126;color:#10b981}.stat-icon.unassigned{background:#f59e0b26;color:#f59e0b}.stat-icon.due{background:#f9731626;color:#f97316}.stat-icon.overdue{background:#ef444426;color:#ef4444}.stat-icon.progress{background:#6366f126;color:#6366f1}.stat-value{font-size:28px;font-weight:700;color:var(--text);line-height:1.2}.stat-label{font-size:14px;color:var(--text-secondary);margin-top:4px}.main-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.main-col{display:flex;flex-direction:column;gap:24px}.card-header h3{font-size:16px;font-weight:600;color:var(--text);flex:1}.card-link{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:500;color:var(--primary);transition:gap .2s}.card-link:hover{gap:8px}.week-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.week-stat{text-align:center;padding:20px;background:var(--background);border-radius:var(--radius-lg)}.week-value{display:block;font-size:24px;font-weight:700;color:var(--text)}.week-label{font-size:13px;color:var(--text-secondary);margin-top:4px}.attention-card{background:linear-gradient(135deg,#fef3c7,#fffbeb);border:1px solid #F59E0B30}.attention-items{display:flex;flex-direction:column;gap:12px}.attention-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fffc;border-radius:var(--radius-md)}.attention-count{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.attention-count.warning{background:#fef3c7;color:#92400e}.attention-count.info{background:#dbeafe;color:#1e40af}.attention-count.error{background:#fee2e2;color:#991b1b}.attention-count.success{background:#d1fae5;color:#065f46}.attention-label{flex:1;font-size:14px;color:var(--text)}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--background);border-radius:var(--radius-md)}.activity-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff}.activity-info{flex:1;display:flex;flex-direction:column}.activity-user{font-size:14px;font-weight:600;color:var(--text)}.activity-action{font-size:13px;color:var(--text-secondary)}.activity-time{font-size:12px;color:var(--text-tertiary)}.activity-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--text-tertiary);gap:12px}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.quick-action{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:var(--background);border-radius:var(--radius-lg);transition:all .2s ease}.quick-action:hover{background:var(--border-light);transform:translateY(-2px)}.quick-action span{font-size:13px;font-weight:500;color:var(--text)}.qa-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.qa-icon.create{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.qa-icon.import{background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));color:#fff}.qa-icon.clients{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.qa-icon.team{background:linear-gradient(135deg,var(--success),#059669);color:#fff}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.main-grid{grid-template-columns:1fr}.welcome-section{flex-direction:column;text-align:center;gap:24px}}@media(max-width:600px){.stats-grid,.stats-grid.three-col,.week-stats,.quick-actions-grid{grid-template-columns:1fr}}.work-orders-page{max-width:1200px;margin:0 auto}.work-orders-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.wo-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.wo-header-left{display:flex;align-items:center;gap:12px;flex:1}.search-box input::placeholder{color:var(--text-tertiary)}.clear-search{padding:4px;color:var(--text-tertiary);transition:color .2s}.clear-search:hover{color:var(--text)}.filter-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.filter-btn:hover,.filter-btn.active{border-color:var(--primary);color:var(--primary)}.wo-header-right{display:flex;align-items:center;gap:12px}.filters-panel{background:var(--surface);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px;display:flex;gap:20px;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}.filter-group select{padding:8px 12px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);min-width:160px}.status-filter-group{position:relative}.status-multi-select{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);min-width:160px;cursor:pointer;-webkit-user-select:none;user-select:none}.status-multi-select:hover{border-color:var(--primary)}.status-select-label{flex:1}.dropdown-arrow{transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(90deg)}.status-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:280px;overflow-y:auto}.status-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .15s ease}.status-option:hover{background:var(--background)}.status-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.status-option span{font-size:14px;color:var(--text)}.wo-stats{display:flex;gap:16px;margin-bottom:24px;overflow-x:auto;padding-bottom:8px}.wo-stat{display:flex;flex-direction:column;align-items:center;padding:16px 24px;background:var(--surface);border-radius:var(--radius-lg);min-width:100px;box-shadow:var(--shadow-sm)}.wo-stat-value{font-size:24px;font-weight:700;color:var(--text)}.wo-stat-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.wo-error{display:flex;align-items:center;gap:10px;padding:16px;background:#fee2e2;border-radius:var(--radius-lg);margin-bottom:24px;color:#991b1b}.wo-list{display:flex;flex-direction:column;gap:12px}.wo-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--surface);border-radius:var(--radius-xl);text-align:center;color:var(--text-tertiary)}.wo-empty h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.wo-empty p{font-size:14px;margin-bottom:24px}.wo-card{display:flex;align-items:center;padding:20px 24px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s ease;border:1px solid transparent}.wo-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.wo-card.overdue{border-left:4px solid var(--error)}.wo-card-main{flex:1}.wo-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.wo-title{font-size:16px;font-weight:600;color:var(--text)}.wo-card-info{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.wo-info-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.wo-info-item svg{color:var(--text-tertiary)}.wo-card-meta{display:flex;flex-wrap:wrap;gap:20px}.wo-meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary)}.wo-meta-item svg{flex-shrink:0}.overdue-text{color:var(--error);font-weight:500}.wo-card-arrow{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);background:var(--background);transition:all .2s ease}.wo-card:hover .wo-card-arrow{background:var(--primary);color:#fff}@media(max-width:768px){.wo-header{flex-direction:column;align-items:stretch}.wo-header-left{flex-direction:column}.search-box{max-width:none}.wo-header-right{justify-content:stretch}.wo-header-right .btn{flex:1;justify-content:center}.wo-stats{justify-content:flex-start}.wo-card{padding:16px}.wo-card-header{flex-direction:column;align-items:flex-start}}.btn-ghost{display:flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-radius:var(--radius-md);transition:all .2s}.btn-ghost:hover{background:var(--surface);color:var(--primary)}.btn-ghost svg{color:var(--text-tertiary)}.btn-ghost:hover svg{color:var(--primary)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.export-buttons{display:flex;gap:8px}.filter-btn.has-filters{background:var(--primary-light)}.filter-badge{background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;margin-left:4px}.filters-row{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;flex:1}.clear-filters-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.clear-filters-btn:hover{background:var(--error);color:#fff;border-color:var(--error)}.bulk-actions-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--primary);border-radius:var(--radius-lg);margin-bottom:16px;color:#fff}.bulk-info{display:flex;align-items:center;gap:10px;font-weight:500}.bulk-buttons{display:flex;gap:8px}.bulk-buttons .btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff}.bulk-buttons .btn:hover{background:#ffffff40}.wo-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;margin-bottom:8px}.select-all-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:none;font-size:14px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all .2s}.select-all-btn:hover{background:var(--surface);color:var(--primary)}.select-all-btn svg{color:var(--text-tertiary)}.select-all-btn:hover svg{color:var(--primary)}.wo-count{font-size:13px;color:var(--text-tertiary)}.wo-card-checkbox{padding:12px;margin-right:8px;cursor:pointer;color:var(--text-tertiary);transition:color .2s}.wo-card-checkbox:hover,.wo-card-checkbox .checked{color:var(--primary)}.wo-card.selected{background:var(--primary-light);border-color:var(--primary)}.wo-title-row{display:flex;align-items:center;gap:12px;flex:1}.client-wo-number{font-size:12px;font-weight:600;color:var(--primary);background:var(--primary-light);padding:4px 10px;border-radius:var(--radius-md)}.wo-meta-item.unassigned{color:var(--warning);font-style:italic}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.modal-header h3{font-size:18px;font-weight:600}.modal-header button{padding:8px;color:var(--text-tertiary);transition:color .2s}.modal-header button:hover{color:var(--text)}.modal-body{padding:20px 24px;overflow-y:auto}.modal-loading{display:flex;justify-content:center;padding:40px}.assign-options{display:flex;flex-direction:column;gap:8px}.assign-option{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;text-align:left}.assign-option:hover{border-color:var(--primary);background:var(--primary-light)}.assign-option.unassign{color:var(--text-secondary)}.member-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.member-info{display:flex;flex-direction:column}.member-name{font-weight:500;color:var(--text)}.member-role{font-size:12px;color:var(--text-secondary);text-transform:capitalize}.status-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.status-option{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;font-weight:500}.status-option:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.status-option.status-unassigned{color:var(--warning)}.status-option.status-unassigned:hover{background:#fef3c7;border-color:var(--warning)}.status-option.status-assigned{color:#3b82f6}.status-option.status-assigned:hover{background:#dbeafe;border-color:#3b82f6}.status-option.status-in_progress{color:#8b5cf6}.status-option.status-in_progress:hover{background:#ede9fe;border-color:#8b5cf6}.status-option.status-complete{color:var(--success)}.status-option.status-complete:hover{background:#d1fae5;border-color:var(--success)}.status-option.status-rework{color:var(--error)}.status-option.status-rework:hover{background:#fee2e2;border-color:var(--error)}.status-option.status-submitted{color:#0891b2}.status-option.status-submitted:hover{background:#cffafe;border-color:#0891b2}.status-option.status-paid{color:#059669}.status-option.status-paid:hover{background:#d1fae5;border-color:#059669}.status-option.status-cancelled{color:#6b7280}.status-option.status-cancelled:hover{background:#e5e7eb;border-color:#6b7280}.status-option.status-hold{color:#ea580c}.status-option.status-hold:hover{background:#fff7ed;border-color:#ea580c}@media(max-width:640px){.export-buttons{display:none}.filters-row{flex-direction:column}.filter-group,.filter-group select{width:100%}.bulk-actions-bar{flex-direction:column;gap:12px}.bulk-buttons{width:100%;justify-content:center}.status-options{grid-template-columns:1fr}}.live-update-controls{display:flex;align-items:center;gap:8px;margin-right:16px;padding-right:16px;border-right:1px solid var(--border)}.refresh-btn svg{transition:transform .3s ease}.refresh-btn.refreshing svg,.refresh-btn svg.spin{animation:spin 1s linear infinite}.auto-refresh-btn{display:flex;align-items:center;gap:6px}.auto-refresh-btn.active{color:var(--success)}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);transition:all .3s ease}.live-dot.active{background:var(--success);box-shadow:0 0 0 2px #10b98133;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 2px #10b98133}50%{box-shadow:0 0 0 4px #10b9811a}}.last-updated{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.date-filters{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.filter-group.date-range{min-width:280px}.date-inputs{display:flex;align-items:center;gap:8px}.date-inputs input[type=date]{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--background);color:var(--text);font-size:14px;transition:all .2s}.date-inputs input[type=date]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.date-inputs input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .2s}.date-inputs input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.date-separator{color:var(--text-tertiary);font-size:13px;flex-shrink:0}@media(max-width:768px){.live-update-controls{margin-right:8px;padding-right:8px}.last-updated{display:none}.date-filters{flex-direction:column}.filter-group.date-range{min-width:unset;width:100%}.date-inputs{flex-wrap:nowrap}.date-inputs input[type=date]{min-width:0}}.load-more-section{display:flex;justify-content:center;padding:20px;margin-top:16px}.load-more-btn{min-width:200px}.loading-more{display:flex;align-items:center;justify-content:center;padding:16px}.end-of-list{display:flex;justify-content:center;padding:16px;color:var(--text-tertiary);font-size:13px;border-top:1px solid var(--border);margin-top:16px}.wo-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.wo-list::-webkit-scrollbar{width:8px}.wo-list::-webkit-scrollbar-track{background:transparent}.wo-list::-webkit-scrollbar-thumb{background-color:var(--border);border-radius:4px}.wo-list::-webkit-scrollbar-thumb:hover{background-color:var(--text-tertiary)}.wo-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-radius:8px;margin-bottom:12px}.wo-list-header-left{display:flex;align-items:center;gap:16px}.wo-list-header-right{display:flex;align-items:center;gap:6px;font-size:14px}.selected-count{background:var(--primary);color:#fff;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600}.wo-count-showing{font-weight:700;color:var(--primary);font-size:15px}.wo-count-separator{color:var(--text-tertiary)}.wo-count-total{font-weight:600;color:var(--text-primary)}.wo-count-more{color:var(--text-tertiary);font-size:13px;margin-left:4px}.search-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.selected-count{background:#2563eb!important;color:#fff!important;padding:6px 14px!important;border-radius:20px!important;font-size:13px!important;font-weight:600!important;box-shadow:0 2px 4px #2563eb4d}.wo-list{position:relative}.wo-list-loading{opacity:.6;pointer-events:none}.wo-list-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:8px}.wo-list-spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.filter-loading{color:var(--primary);font-size:13px;font-weight:500;margin-right:8px;animation:pulse 1s ease-in-out infinite}.work-order-detail{max-width:1200px;margin:0 auto}.detail-loading,.detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center}.detail-error h2{font-size:20px;font-weight:600;color:var(--text)}.detail-error p{color:var(--text-secondary);margin-bottom:16px}.detail-header{display:flex;align-items:center;gap:24px;margin-bottom:24px}.header-meta{display:flex;align-items:center;gap:12px}.wo-number{font-size:14px;font-weight:600;color:var(--primary)}.work-type{font-size:14px;color:var(--text-secondary);padding:4px 12px;background:var(--background);border-radius:var(--radius-full)}.status-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-lg);color:#fff;font-size:14px;font-weight:600;transition:all .2s ease}.status-btn:hover{opacity:.9}.quick-info-bar{display:flex;flex-wrap:wrap;gap:16px;padding:16px 20px;background:var(--surface);border-radius:var(--radius-xl);margin-bottom:24px;box-shadow:var(--shadow-sm)}.quick-info-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.quick-info-item svg{color:var(--text-tertiary)}.quick-info-item.clickable{cursor:pointer;padding:6px 12px;border-radius:var(--radius-md);margin:-6px 0;transition:background .2s}.quick-info-item.clickable:hover{background:var(--background)}.quick-info-item.clickable svg:last-child{color:var(--primary)}.detail-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.tab-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s ease}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-badge{padding:2px 8px;background:var(--background);border-radius:var(--radius-full);font-size:12px;font-weight:600}.tab-btn.active .tab-badge{background:#f9731626;color:var(--primary)}.tab-content{min-height:400px}.details-tab{display:flex;flex-direction:column;gap:24px}.detail-card{background:var(--surface);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm)}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.detail-grid.three-col{grid-template-columns:repeat(3,1fr)}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item.full-width{grid-column:1 / -1}.detail-item label{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.detail-item span,.detail-item p{font-size:15px;color:var(--text)}.code-value{font-family:monospace;font-weight:600;background:var(--background);padding:8px 12px;border-radius:var(--radius-md);letter-spacing:1px}.description-text{line-height:1.6;white-space:pre-wrap}.tasks-tab{display:flex;flex-direction:column;gap:20px}.task-actions{display:flex;gap:12px;flex-wrap:wrap}.new-task-input{display:flex;gap:12px;padding:16px;background:var(--surface);border-radius:var(--radius-lg)}.new-task-input input{flex:1;padding:12px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px}.task-progress{background:var(--surface);border-radius:var(--radius-lg);padding:16px}.progress-info{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px;color:var(--text-secondary)}.progress-bar{height:8px;background:var(--background);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--success),#059669);border-radius:4px;transition:width .3s ease}.task-list{display:flex;flex-direction:column;gap:8px}.tasks-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;background:var(--surface);border-radius:var(--radius-xl);color:var(--text-tertiary)}.tasks-empty h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.task-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface);border-radius:var(--radius-lg);transition:all .2s ease}.task-item.completed{opacity:.7}.task-checkbox{width:24px;height:24px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease}.task-checkbox.checked{background:var(--success);border-color:var(--success)}.task-info{flex:1}.task-name{display:block;font-size:15px;color:var(--text)}.task-item.completed .task-name{text-decoration:line-through}.task-bucket{font-size:13px;color:var(--text-tertiary)}.task-delete{padding:8px;color:var(--text-tertiary);border-radius:var(--radius-md);transition:all .2s}.task-delete:hover{background:#ef44441a;color:var(--error)}.gallery-tab{display:flex;flex-direction:column;gap:20px}.gallery-actions{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}.gallery-mode-toggle{display:flex;background:var(--surface);border-radius:var(--radius-lg);padding:4px}.mode-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.mode-btn:hover{color:var(--text)}.mode-btn.active{background:var(--primary);color:#fff}.gallery-actions-right{display:flex;gap:12px;align-items:center}.gallery-actions-right .btn{padding:8px 14px!important;font-size:13px!important;height:36px!important;line-height:1!important}.dropdown-chevron{transition:transform .2s ease}.dropdown-chevron.open{transform:rotate(180deg)}.download-options{position:absolute;top:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;z-index:100;min-width:200px;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.download-options button{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--text);transition:all .15s ease}.download-options button:hover{background:var(--primary);color:#fff}.download-options button:hover svg{color:#fff}.download-options button svg{color:var(--text-secondary);transition:color .15s ease}.download-options button:first-child{border-bottom:1px solid var(--border)}.download-progress-container{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;display:flex;align-items:center;gap:16px}.download-progress-bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.download-progress-fill{height:100%;background:linear-gradient(90deg,#f97316,#fb923c);border-radius:4px;transition:width .3s ease}.download-progress-text{font-size:13px;color:var(--text-secondary);white-space:nowrap}.upload-progress-container{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;display:flex;align-items:center;gap:16px}.upload-progress-bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:4px;transition:width .3s ease}.upload-progress-text{font-size:13px;color:var(--text-secondary);white-space:nowrap}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--surface);border-radius:var(--radius-xl);color:var(--text-tertiary)}.gallery-empty h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.gallery-empty p{margin-bottom:24px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.photo-item{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer}.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-item:hover img{transform:scale(1.05)}.photo-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#fff}.photo-item:hover .photo-overlay{opacity:1}.photo-info{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(transparent,#000000b3);color:#fff;font-size:13px;font-weight:500}.photo-categories{display:flex;flex-direction:column;gap:24px}.photo-category{background:var(--surface);border-radius:var(--radius-xl);padding:20px}.category-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;color:var(--text-secondary)}.category-header h4{font-size:15px;font-weight:600;color:var(--text);flex:1}.category-count{font-size:13px;padding:4px 10px;background:var(--background);border-radius:var(--radius-full)}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.photo-item.small{aspect-ratio:1}.reports-tab{display:flex;flex-direction:column;gap:24px}.report-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.report-card{background:var(--surface);border-radius:var(--radius-xl);padding:32px;text-align:center;box-shadow:var(--shadow-md)}.report-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.report-icon.invoice{background:#10b98126;color:var(--success)}.report-icon.bid{background:#3b82f626;color:var(--secondary)}.report-icon.certificate{background:#8b5cf626;color:#8b5cf6}.report-card h3{font-size:18px;font-weight:600;color:var(--text);margin-bottom:12px}.report-card p{font-size:14px;color:var(--text-secondary);margin-bottom:24px;line-height:1.5}.report-card .btn{width:100%}.certificate-buttons{display:flex;gap:8px;flex-direction:column}.certificate-buttons .btn{flex:1}.certificate-info{margin-top:12px;padding:12px;background:var(--background);border-radius:8px;text-align:center}.certificate-info small{color:var(--text-secondary);font-size:12px;line-height:1.5}.modal-content{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:400px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.modal-body{padding:16px;overflow-y:auto}.status-option,.assign-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border-radius:var(--radius-md);text-align:left;transition:background .2s;cursor:pointer;pointer-events:auto;background:transparent;border:none}.status-option:hover,.assign-option:hover{background:var(--background)}.status-option.active,.assign-option.active{background:#f973161a}.status-dot{width:12px;height:12px;border-radius:50%}.status-option span:last-child,.assign-option svg:last-child{margin-left:auto;color:var(--primary)}.assign-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-dark));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff}.assign-avatar.unassigned{background:var(--border);color:var(--text-tertiary)}.assign-info{flex:1}.assign-name{display:block;font-size:15px;font-weight:600;color:var(--text)}.assign-role{font-size:13px;color:var(--text-secondary)}.viewer-content img{max-width:100%;max-height:calc(85vh - 80px);object-fit:contain;border-radius:var(--radius-lg)}.viewer-task{font-weight:600}.viewer-bucket{opacity:.7}.viewer-count{margin-left:auto}.viewer-download-actions{display:flex;gap:12px;margin-top:16px;justify-content:center}.viewer-download-actions .btn{display:flex;align-items:center;gap:6px;padding:8px 16px;font-size:13px;border-radius:6px}.viewer-download-actions .btn-primary{background-color:var(--primary);color:#fff;border:none}.viewer-download-actions .btn-secondary{background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.viewer-download-actions .btn:hover{transform:scale(1.02)}.documents-tab{display:flex;flex-direction:column;gap:24px}.section-description{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.documents-list{display:flex;flex-direction:column;gap:12px}.document-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--background);border-radius:var(--radius-lg);border:1px solid var(--border);transition:all .2s}.document-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.document-icon{width:48px;height:48px;border-radius:var(--radius-md);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.document-icon.pdf{background:#ef44441a;color:#ef4444}.document-info{flex:1;min-width:0}.document-name{display:block;font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-meta{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-tertiary);margin-top:4px}.document-tag{padding:2px 8px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-size:11px;font-weight:600}.document-actions{display:flex;gap:8px}.icon-btn{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s}.icon-btn:hover{background:var(--surface);color:var(--primary)}.icon-btn.danger:hover{background:#ef44441a;color:var(--error)}.empty-documents{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text-tertiary);text-align:center}.empty-documents svg{margin-bottom:12px}.empty-documents p{font-size:14px}.card-header .btn-sm{margin-left:auto}.task-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.task-type{font-size:12px;color:var(--text-tertiary);text-transform:capitalize}.task-price{font-size:13px;font-weight:700;color:var(--success);background:#10b9811a;padding:2px 8px;border-radius:var(--radius-sm)}.history-modal{max-width:500px;max-height:80vh}.history-modal .modal-body{max-height:60vh;overflow-y:auto}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--text-tertiary)}.history-empty svg{margin-bottom:12px}.history-timeline{display:flex;flex-direction:column;gap:16px}.history-item{display:flex;gap:12px}.history-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.history-content{flex:1;padding-bottom:16px;border-bottom:1px solid var(--border)}.history-item:last-child .history-content{border-bottom:none;padding-bottom:0}.history-title{display:block;font-size:14px;font-weight:600;color:var(--text)}.history-title.rework{color:var(--error)}.history-notes{font-size:13px;color:var(--text-secondary);margin:6px 0;line-height:1.5}.history-meta{font-size:12px;color:var(--text-tertiary)}.priority-badge{display:inline-flex;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;text-transform:capitalize}.priority-badge.priority-low{background:#10b98126;color:#10b981}.priority-badge.priority-medium{background:#f59e0b26;color:#f59e0b}.priority-badge.priority-high{background:#f9731626;color:#f97316}.priority-badge.priority-urgent{background:#ef444426;color:#ef4444}@media(max-width:768px){.detail-header{flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%}.status-btn{flex:1;justify-content:center}.quick-info-bar{flex-direction:column;gap:12px}.detail-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-btn{white-space:nowrap}.detail-grid,.detail-grid.three-col{grid-template-columns:1fr}.gallery-actions{flex-direction:column}.gallery-actions-right{width:100%}.gallery-actions-right .btn{flex:1}.photo-grid{grid-template-columns:repeat(2,1fr)}.report-cards{grid-template-columns:1fr}}.task-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}.task-type-option{display:flex;align-items:center;gap:8px;padding:12px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--background);cursor:pointer;transition:all .2s}.task-type-option:hover{border-color:var(--text-secondary)}.task-type-option.selected{border-width:2px}.type-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.type-label{font-size:13px;font-weight:500;color:var(--text)}.task-item{display:flex;align-items:center;gap:14px;padding:16px;background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:8px;transition:all .2s}.task-item:hover{border-color:var(--primary);box-shadow:0 2px 8px #00000014}.task-item.completed{background:var(--background);opacity:.7}.task-item.rework{border-left:4px solid #EF4444}.task-status-dot{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-name.completed{text-decoration:line-through;color:var(--text-tertiary)}.task-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.task-ai-badge{display:inline-flex;align-items:center;gap:3px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600}.task-type-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.task-price{font-size:12px;font-weight:600;color:var(--success)}.task-chevron{color:var(--text-tertiary);flex-shrink:0}@media(max-width:768px){.task-type-grid{grid-template-columns:repeat(2,1fr)}}.checkin-status{border:1px dashed #F59E0B;background:#f59e0b1a;transition:all .2s}.checkin-status:not(.checked-in):hover{background:#f59e0b33;border-style:solid}.checkin-status.checked-in{border:1px solid #10B981;background:#10b9811a;color:#10b981}.checkin-status.checked-in svg{color:#10b981}.mode-btn.manage{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}.mode-btn.manage:hover{opacity:.9}.mode-btn.manage.active{background:linear-gradient(135deg,#7c3aed,#4f46e5)}.manage-instructions{display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#8b5cf61a,#6366f11a);border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-lg);margin-bottom:20px;color:#7c3aed;font-size:13px}.manage-instructions svg{flex-shrink:0}.photo-manager{display:flex;flex-direction:column;gap:16px}.category-drop-zone{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-lg);padding:16px;transition:all .2s}.category-drop-zone.drag-over{border-color:var(--primary);background:#f973160d}.category-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}.category-header svg{color:var(--text-secondary)}.category-header h4{font-size:14px;font-weight:600;color:var(--text);margin:0;flex:1}.task-indicator{width:10px;height:10px;border-radius:50%}.task-type-label{font-size:11px;font-weight:600;text-transform:uppercase}.photo-count{font-size:12px;color:var(--text-tertiary)}.category-photos{display:flex;flex-wrap:wrap;gap:12px;min-height:100px}.draggable-photo{position:relative;width:140px;height:140px;border-radius:var(--radius-md);overflow:hidden;cursor:grab;transition:transform .2s,box-shadow .2s}.draggable-photo:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.draggable-photo.dragging{opacity:.5;transform:scale(.95)}.draggable-photo img{width:100%;height:100%;object-fit:cover}.draggable-photo .bucket-badge{position:absolute;bottom:4px;left:4px;right:4px;padding:2px 6px;background:#000000b3;color:#fff;font-size:9px;text-align:center;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drop-hint{width:100%;display:flex;align-items:center;justify-content:center;min-height:80px;color:var(--text-tertiary);font-size:12px;font-style:italic}.task-category-section{background:var(--surface);border-radius:var(--radius-lg);padding:16px;border:1px solid var(--border)}.task-category-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}.task-category-header h4{font-size:14px;font-weight:600;color:var(--text);margin:0;flex:1}.bucket-zones{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.bucket-zone{padding:12px;background:var(--background);border-radius:var(--radius-md);min-height:100px}.bucket-zone.drag-over{border-color:var(--primary);background:#f9731614}.bucket-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.bucket-name{font-size:12px;font-weight:600;color:var(--text);text-transform:capitalize}.bucket-photo-count{font-size:11px;color:var(--text-tertiary);background:var(--border);padding:2px 8px;border-radius:999px}.bucket-photos{min-height:60px}.drop-hint-small{font-size:11px;color:var(--text-tertiary);text-align:center;font-style:italic;padding:20px 10px}.status-modal-content{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:480px;padding:0;overflow:hidden;box-shadow:0 20px 40px #0000004d}.status-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.status-modal-title{display:flex;align-items:center;gap:12px}.status-modal-title h3{font-size:18px;font-weight:600;margin:0}.status-modal-title svg{color:var(--primary)}.status-modal-close{padding:8px;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all .2s}.status-modal-close:hover{background:var(--background);color:var(--text)}.status-modal-subtitle{font-size:14px;color:var(--text-secondary);padding:16px 24px 0;margin:0}.status-options-grid{display:flex;flex-direction:column;gap:8px;padding:16px 24px 24px}.status-option-card{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;border-radius:var(--radius-md);background:var(--background);border:2px solid transparent;transition:all .2s ease;text-align:left}.status-option-card:hover{border-color:var(--border);transform:translate(4px)}.status-option-card.active{background:#f973161a;border-color:var(--primary)}.status-option-indicator{width:14px;height:14px;border-radius:50%;flex-shrink:0}.status-option-content{flex:1;display:flex;align-items:center;gap:10px}.status-option-label{font-size:15px;font-weight:500;color:var(--text)}.status-current-badge{font-size:10px;font-weight:600;text-transform:uppercase;padding:2px 8px;background:var(--primary);color:#fff;border-radius:var(--radius-full)}.status-check{color:var(--primary);flex-shrink:0}.generate-tasks-modal{background:var(--surface);border-radius:var(--radius-lg);padding:40px;width:90%;max-width:400px;text-align:center;box-shadow:0 20px 40px #0000004d}.generate-tasks-icon{margin-bottom:20px}.generate-tasks-icon .ai-icon{color:var(--primary);animation:pulse 1.5s ease-in-out infinite}.generate-tasks-icon .success-icon{color:var(--success)}.generate-tasks-icon .error-icon{color:var(--danger)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.generate-tasks-modal h3{font-size:18px;font-weight:600;color:var(--text);margin:0 0 24px}.generate-progress-steps{display:flex;justify-content:center;gap:32px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:8px}.progress-step .step-dot{width:12px;height:12px;border-radius:50%;background:var(--border);transition:all .3s ease}.progress-step.active .step-dot{background:var(--primary);box-shadow:0 0 0 4px #f9731633}.progress-step.done .step-dot{background:var(--success);box-shadow:none}.progress-step span{font-size:12px;color:var(--text-tertiary);font-weight:500}.progress-step.active span,.progress-step.done span{color:var(--text)}.wo-number-internal{display:inline-flex;align-items:center;padding:4px 10px;background:linear-gradient(135deg,var(--primary),#EA580C);color:#fff;border-radius:var(--radius-full);font-size:12px;font-weight:600;letter-spacing:.5px}.btn-danger-outline{display:flex;align-items:center;justify-content:center;padding:10px 12px;background:transparent;border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.btn-danger-outline:hover{background:var(--danger);color:#fff}.delete-confirm-modal{background:var(--surface);border-radius:var(--radius-lg);padding:32px;width:90%;max-width:400px;text-align:center}.delete-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 20px;background:#ef44441a;border-radius:50%;color:var(--danger)}.delete-confirm-modal h2{font-size:20px;font-weight:600;color:var(--text);margin-bottom:12px}.delete-confirm-modal p{color:var(--text-secondary);font-size:14px;margin-bottom:8px}.delete-info{color:var(--text-tertiary)!important;font-size:13px!important}.delete-actions{display:flex;gap:12px;margin-top:24px}.delete-actions .btn{flex:1;padding:12px;display:flex;align-items:center;justify-content:center;gap:8px}.btn-danger{background:var(--danger);border:none;color:#fff}.photo-item{position:relative}.photo-info-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s;z-index:10}.photo-item:hover .photo-info-btn{opacity:1}.photo-info-btn.small{width:22px;height:22px;top:4px;right:4px}.modal .task-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.modal .task-type-option{display:flex;align-items:center;gap:8px;padding:12px;background:var(--background);border:2px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.modal .task-type-option:hover{background:var(--surface-hover)}.modal .task-type-option.selected{border-width:2px}.modal .task-type-option .type-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.modal .task-type-option .type-label{font-size:13px;font-weight:500;color:var(--text)}.modal .form-group{margin-bottom:16px}.modal .form-group label{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px}.modal .form-group input,.modal .form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--background);color:var(--text);font-size:14px;transition:all .2s}.modal .form-group input:focus,.modal .form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.modal .form-group input::placeholder,.modal .form-group textarea::placeholder{color:var(--text-tertiary)}.modal .modal-content{padding:20px;max-height:60vh;overflow-y:auto}.modal .modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);background:var(--background)}@media(max-width:640px){.modal .task-type-grid{grid-template-columns:repeat(2,1fr)}}.rework-modal{background:var(--surface);border-radius:var(--radius-xl);width:90%;max-width:500px;overflow:hidden;box-shadow:var(--shadow-xl)}.rework-modal-header{display:flex;align-items:flex-start;gap:16px;padding:20px;border-bottom:1px solid var(--border)}.rework-icon{width:48px;height:48px;border-radius:12px;background:#ef44441a;color:#ef4444;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rework-modal-header>div:nth-child(2){flex:1}.rework-modal-header h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text)}.rework-modal-header p{margin:0;font-size:14px;color:var(--text-secondary)}.rework-modal-content{padding:20px}.rework-items-section label{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.rework-hint{font-size:13px;color:var(--text-tertiary);margin:0 0 16px}.rework-item-input{display:flex;gap:8px;margin-bottom:12px}.rework-item-input input{flex:1;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--background);color:var(--text);font-size:14px}.rework-item-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.remove-item-btn{width:40px;height:40px;border:none;background:#ef44441a;color:#ef4444;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-item-btn:hover{background:#ef444433}.add-item-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px dashed var(--border);background:transparent;color:var(--primary);border-radius:var(--radius-md);cursor:pointer;font-size:14px;transition:all .2s}.add-item-btn:hover{border-color:var(--primary);background:#007aff0d}.rework-modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);background:var(--background)}.rework-modal-footer .btn-danger{background:#ef4444;color:#fff}.rework-modal-footer .btn-danger:hover{background:#dc2626}.rework-modal-footer .btn-danger:disabled{background:#fca5a5;cursor:not-allowed}.manage-toolbar{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.manage-instructions{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px}.selection-actions{display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--border)}.selected-count{font-size:14px;font-weight:600;color:var(--primary)}.selectable-photo{position:relative;width:140px;height:140px;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:3px solid transparent;transition:all .2s}.selectable-photo:hover{border-color:var(--primary);transform:scale(1.03)}.selectable-photo.selected{border-color:var(--primary);box-shadow:0 0 0 4px #f973164d}.selectable-photo img{width:100%;height:100%;object-fit:cover}.selectable-photo .photo-checkbox{position:absolute;top:8px;right:8px;background:#fffffff2;border-radius:6px;padding:4px;opacity:.8;transition:opacity .2s}.selectable-photo:hover .photo-checkbox,.selectable-photo.selected .photo-checkbox{opacity:1}.selectable-photo .photo-checkbox svg{color:var(--primary)}.select-all-btn{padding:4px 10px;font-size:11px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;margin-left:auto}.select-all-btn:hover{background:var(--primary-dark)}.select-all-btn-small{padding:2px 8px;font-size:10px;background:#f973161a;color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius-sm);cursor:pointer}.select-all-btn-small:hover{background:var(--primary);color:#fff}.move-photos-modal{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.move-photos-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.move-photos-modal .modal-header h3{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--text);margin:0}.move-modal-content{padding:20px;overflow-y:auto;flex:1}.move-instructions{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.selected-photos-preview{display:flex;gap:8px;margin-bottom:20px;padding:12px;background:var(--background);border-radius:var(--radius-md);flex-wrap:wrap}.selected-photos-preview img{width:70px;height:70px;object-fit:cover;border-radius:var(--radius-md)}.selected-photos-preview .more-count{display:flex;align-items:center;justify-content:center;width:70px;height:70px;background:var(--border);border-radius:var(--radius-md);font-size:14px;font-weight:600;color:var(--text-secondary)}.destination-list{display:flex;flex-direction:column;gap:8px}.destination-option{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:left;width:100%}.destination-option:hover{border-color:var(--primary);background:#f973160d}.destination-option:disabled{opacity:.5;cursor:not-allowed}.task-destination-group{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.task-destination-header{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--background);font-size:14px;font-weight:600;color:var(--text)}.task-indicator-small{width:8px;height:8px;border-radius:50%}.bucket-destinations{display:flex;flex-direction:column}.bucket-destinations .destination-option{border:none;border-top:1px solid var(--border);border-radius:0;padding-left:40px}.bucket-option{font-size:13px}.moving-status{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;margin-top:16px;background:#f973161a;border-radius:var(--radius-md);color:var(--primary);font-weight:500}.notes-tab{padding:24px;background:var(--surface);border-radius:var(--radius-lg)}.add-note-form{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.note-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;font-family:inherit;resize:vertical;transition:border-color .2s ease}.note-input:focus{outline:none;border-color:var(--primary)}.add-note-form .btn{align-self:flex-end}.notes-list{display:flex;flex-direction:column;gap:16px}.notes-loading,.notes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center;color:var(--text-secondary)}.notes-empty h3{margin:16px 0 8px;font-size:18px;font-weight:600;color:var(--text)}.notes-empty p{font-size:14px;color:var(--text-secondary)}.note-item{padding:16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md)}.note-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.note-author{display:flex;align-items:center;gap:8px;font-size:14px}.note-author .author-name{font-weight:600;color:var(--text)}.role-badge{padding:2px 8px;font-size:11px;font-weight:600;border-radius:var(--radius-sm);text-transform:uppercase}.role-badge.role-admin{background:#ef44441a;color:#ef4444}.role-badge.role-manager{background:#f59e0b1a;color:#f59e0b}.role-badge.role-field_crew{background:#10b9811a;color:#10b981}.note-actions{display:flex;gap:4px}.note-actions .btn-icon{padding:6px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s ease}.note-actions .btn-icon:hover{background:var(--surface);color:var(--text)}.note-actions .btn-icon.btn-danger:hover{background:#ef44441a;color:#ef4444}.note-content{font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word}.note-footer{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.note-timestamp{font-size:12px;color:var(--text-secondary)}.note-edited{font-size:12px;color:var(--text-secondary);font-style:italic}.note-edit-form{display:flex;flex-direction:column;gap:12px}.note-edit-actions{display:flex;justify-content:flex-end;gap:8px}.videos-tab{padding:24px;background:var(--surface);border-radius:var(--radius-lg)}.videos-loading,.videos-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center;color:var(--text-secondary)}.videos-empty h3{margin:16px 0 8px;font-size:18px;font-weight:600;color:var(--text)}.videos-empty p{font-size:14px;color:var(--text-secondary)}.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.video-card{background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.video-thumbnail{position:relative;height:120px;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.video-thumbnail:hover{background:linear-gradient(135deg,#2a2a3e,#26314e)}.video-thumbnail:hover .video-play-overlay{opacity:1}.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .2s ease;color:#fff}.video-duration{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;padding:2px 8px;border-radius:var(--radius-sm);font-size:12px;font-weight:600}.video-info{padding:12px;display:flex;flex-direction:column;gap:4px}.video-date{font-size:13px;color:var(--text);font-weight:500}.video-uploader{font-size:12px;color:var(--text-secondary)}.video-actions{display:flex;gap:4px;padding:8px 12px;border-top:1px solid var(--border);background:var(--surface)}.video-actions .btn-icon{padding:8px;border-radius:var(--radius-sm);color:var(--text-secondary);transition:all .2s ease}.video-actions .btn-icon:hover{background:var(--background);color:var(--primary)}.video-actions .btn-icon.btn-danger:hover{background:#ef44441a;color:#ef4444}.video-modal{background:var(--surface);border-radius:var(--radius-lg);width:90%;max-width:800px;max-height:90vh;overflow:hidden}.video-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.video-modal-header h3{font-size:18px;font-weight:600;color:var(--text)}.video-modal-content{padding:20px;background:#000;min-height:300px;display:flex;align-items:center;justify-content:center}.video-loading{display:flex;flex-direction:column;align-items:center;gap:12px;color:#fff}.video-player{width:100%;max-height:500px}.video-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border)}.rework-banner{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #EF4444;border-radius:var(--radius-xl);padding:20px 24px;margin-bottom:24px}.rework-banner-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.rework-banner-header svg{color:#b91c1c;flex-shrink:0}.rework-banner-title{font-size:16px;font-weight:700;color:#b91c1c;letter-spacing:.5px}.rework-banner-items{display:flex;flex-direction:column;gap:16px}.rework-banner-item{background:#fff;border-radius:var(--radius-lg);padding:16px;border-left:4px solid #EF4444}.rework-banner-reason{font-size:15px;color:#1f2937;line-height:1.6;margin:0 0 8px;white-space:pre-wrap;word-break:break-word}.rework-banner-meta{font-size:13px;color:#6b7280}.share-modal{background:#fff;border-radius:16px;max-width:500px;width:90%;max-height:90vh;overflow:auto;box-shadow:0 20px 40px #0003}.share-modal-content{padding:24px}.no-share-link{text-align:center;padding:32px 16px}.no-share-link .share-icon{color:var(--primary);opacity:.3;margin-bottom:16px}.no-share-link h4{font-size:20px;color:var(--text);margin:0 0 8px}.no-share-link p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0 0 24px}.generate-btn{display:inline-flex;align-items:center;gap:8px}.share-link-details{display:flex;flex-direction:column;gap:20px}.share-link-url{display:flex;gap:8px}.share-url-input{flex:1;padding:12px 16px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--background);color:var(--text)}.copy-btn{display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--primary);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;min-width:100px;justify-content:center}.copy-btn:hover{background:var(--primary-dark)}.copy-btn.copied{background:#10b981}.share-link-info{background:var(--background);border-radius:12px;padding:16px}.share-link-info .info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.share-link-info .info-row:last-child{border-bottom:none}.share-link-info .info-label{color:var(--text-secondary);font-size:14px}.share-link-info .info-value{color:var(--text);font-size:14px;font-weight:500}.share-link-actions{display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.share-link-actions .btn{display:flex;align-items:center;gap:6px}.create-work-order{max-width:800px;margin:0 auto}.create-header{display:flex;align-items:center;gap:24px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.back-btn:hover{background:var(--surface);color:var(--text)}.create-error{display:flex;align-items:center;gap:12px;padding:16px;background:#fee2e2;border-radius:var(--radius-lg);margin-bottom:24px;color:#991b1b}.create-error span{flex:1;font-size:14px;font-weight:500}.create-error button{padding:4px;border-radius:4px;transition:background .2s}.create-error button:hover{background:#0000001a}.create-content{display:flex;flex-direction:column;gap:24px}.client-select-btn.error{border-color:var(--error)}.mt-16{margin-top:16px}.create-btn{width:100%;padding:16px 24px;font-size:16px}.section-description{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.documents-preview{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.document-preview-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--background);border-radius:var(--radius-md);border:1px solid var(--border)}.document-preview-item svg:first-child{color:var(--primary)}.document-preview-item span{flex:1;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remove-doc-btn{padding:6px;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all .2s}.remove-doc-btn:hover{background:#ef44441a;color:var(--error)}.upload-btn-inline{width:100%;justify-content:center}.multi-select-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:16px;border:2px solid #e2e8f0;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);max-height:280px;overflow-y:auto}.multi-select-item:has(input:checked){background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.multi-select-item:has(input:checked) span{color:#1e40af;font-weight:600}.assigned-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.assigned-tag{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:999px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #3b82f64d;transition:all .2s ease}.assigned-tag:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.assigned-tag svg{cursor:pointer;opacity:.8;transition:opacity .15s ease}.assigned-tag svg:hover{opacity:1}.import-work-order{max-width:800px;margin:0 auto}.import-header{display:flex;align-items:center;gap:24px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all .2s ease}.header-info{flex:1}.header-info h1{font-size:24px;font-weight:700;color:var(--text);margin-bottom:4px}.header-info p{font-size:14px;color:var(--text-secondary)}.step-indicator{display:flex;align-items:center;gap:12px}.step-dot{width:32px;height:32px;border-radius:50%;background:var(--border);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;transition:all .3s ease}.step-dot.active{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}.step-line{width:40px;height:2px;background:var(--border)}.import-error{display:flex;align-items:center;gap:12px;padding:16px;background:#fee2e2;border-radius:var(--radius-lg);margin-bottom:24px;color:#991b1b}.import-error span{flex:1;font-size:14px;font-weight:500}.import-error button{padding:4px;border-radius:4px;transition:background .2s}.import-error button:hover{background:#0000001a}.import-content{display:flex;flex-direction:column;gap:24px}.info-card{background:linear-gradient(135deg,#fef3c7,#fffbeb);border:1px solid #F59E0B30}.steps-info{display:flex;flex-direction:column;gap:16px}.step-info{display:flex;align-items:center;gap:16px}.step-num{width:28px;height:28px;border-radius:50%;background:#f9731633;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.step-info span{font-size:15px;color:var(--text-secondary)}.client-select-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;transition:all .2s ease}.client-select-btn:hover{border-color:var(--primary)}.client-select-btn .placeholder{color:var(--text-tertiary)}.client-select-btn .selected{color:var(--text);font-weight:500}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:48px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--background)}.drop-zone:hover{border-color:var(--primary);background:#f973160d}.drop-zone.has-file{border-style:solid;border-color:var(--success);background:#10b9810d}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-icon-circle{width:64px;height:64px;border-radius:50%;background:#f9731626;display:flex;align-items:center;justify-content:center;color:var(--primary)}.upload-text{font-size:16px;font-weight:600;color:var(--text)}.upload-hint{font-size:14px;color:var(--text-tertiary)}.file-preview{display:flex;align-items:center;gap:16px}.file-icon-container{width:56px;height:56px;border-radius:var(--radius-md);background:#ef444426;display:flex;align-items:center;justify-content:center;color:var(--error)}.file-details{flex:1;text-align:left}.file-name{display:block;font-size:16px;font-weight:600;color:var(--text)}.file-size{font-size:14px;color:var(--success)}.remove-file{padding:8px;border-radius:var(--radius-md);color:var(--error);transition:background .2s}.remove-file:hover{background:#ef44441a}.parse-btn{width:100%;padding:16px 24px;font-size:16px}.review-content{padding-bottom:40px}.ai-notice{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(135deg,#f973161a,#f973160d);border-radius:var(--radius-lg);border:1px solid rgba(249,115,22,.2)}.ai-notice-text{flex:1}.ai-notice-text h4{font-size:15px;font-weight:600;color:var(--primary);margin-bottom:2px}.ai-notice-text p{font-size:13px;color:var(--text-secondary)}.confidence-legend{display:flex;gap:12px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.high{background:#10b981}.legend-dot.med{background:#f59e0b}.legend-dot.low{background:#ef4444}.confidence-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:20px}.icon-success{color:var(--success)}.icon-error{color:var(--error)}.read-only-field{margin-bottom:16px}.read-only-field label{display:block;font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.read-only-field span{font-size:16px;font-weight:500;color:var(--text)}.label-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.label-row label{font-size:13px;font-weight:600;color:var(--text-secondary)}.form-row.three-col{flex-wrap:wrap}.form-row.three-col .form-group{flex:1;min-width:150px}.textarea{min-height:100px;resize:vertical}.priority-chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.priority-chip{padding:10px 20px;border-radius:var(--radius-lg);background:var(--background);color:var(--text-secondary);font-size:14px;font-weight:600;transition:all .2s ease}.priority-chip:hover{background:var(--border)}.priority-chip.active{background:var(--secondary);color:#fff}.pdf-attachment-card{background:#10b9810d;border:1px solid rgba(16,185,129,.2)}.pdf-attachment-preview{display:flex;align-items:center;gap:16px;padding:16px;background:var(--surface);border-radius:var(--radius-md)}.pdf-icon{width:48px;height:48px;border-radius:var(--radius-md);background:#ef444426;display:flex;align-items:center;justify-content:center;color:var(--error)}.pdf-name{display:block;font-size:15px;font-weight:600;color:var(--text)}.pdf-note{font-size:13px;color:var(--success)}.create-btn{width:100%;padding:16px 24px;font-size:16px;margin-top:8px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000}.modal-content{background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.modal-header button{padding:4px;border-radius:4px;color:var(--text-secondary);transition:all .2s}.modal-search{padding:16px 24px}.modal-search input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px}.modal-list{flex:1;overflow-y:auto}.modal-item{display:flex;align-items:center;gap:16px;width:100%;padding:16px 24px;text-align:left;border-bottom:1px solid var(--border-light);transition:background .2s}.modal-item:hover{background:var(--background)}.modal-item.selected{background:#f973161a}.client-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff}.client-info{flex:1}.client-name{display:block;font-size:16px;font-weight:600;color:var(--text)}.client-type{font-size:14px;color:var(--text-secondary)}.modal-empty{padding:48px 24px;text-align:center;color:var(--text-secondary)}@media(min-width:768px){.modal-overlay{align-items:center}.modal-content{border-radius:var(--radius-xl);max-height:600px}}.multi-select-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;padding:16px;border:2px solid #e2e8f0;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);max-height:280px;overflow-y:auto}.multi-select-container::-webkit-scrollbar{width:6px}.multi-select-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.multi-select-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.multi-select-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.multi-select-item{display:flex!important;flex-direction:row!important;align-items:center!important;gap:12px!important;padding:14px 16px!important;background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .25s ease;box-shadow:0 1px 3px #0000000d;overflow:hidden}.multi-select-item:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.multi-select-item.selected{background:linear-gradient(135deg,#eff6ff,#dbeafe);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.multi-select-item input[type=checkbox]{width:20px!important;height:20px!important;min-width:20px!important;flex-shrink:0!important;accent-color:#3b82f6;cursor:pointer;margin:0!important}.multi-select-item span{font-size:14px;font-weight:500;color:#334155;line-height:1.4;overflow:hidden;text-overflow:ellipsis}.multi-select-item.selected span{color:#1e40af;font-weight:600}.selected-count{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 16px;font-size:14px;color:#3b82f6;font-weight:600;background:#eff6ff;border-radius:20px;border:1px solid #bfdbfe}.selected-count:before{content:"✓";font-size:12px}.deleted-wo-page{max-width:1000px;margin:0 auto;padding:24px}.deleted-wo-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.deleted-header{display:flex;align-items:center;gap:24px;margin-bottom:24px}.deleted-header .back-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.deleted-header .back-btn:hover{background:var(--background);color:var(--text)}.header-title{display:flex;align-items:center;gap:12px}.header-title svg{color:var(--danger)}.header-title h1{font-size:24px;font-weight:700;color:var(--text);margin:0}.count-badge{padding:4px 12px;background:var(--danger);color:#fff;border-radius:var(--radius-full);font-size:14px;font-weight:600}.info-banner{display:flex;gap:16px;padding:16px 20px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);margin-bottom:24px}.info-banner svg{color:#3b82f6;flex-shrink:0;margin-top:2px}.info-banner strong{display:block;color:var(--text);margin-bottom:4px}.info-banner p{color:var(--text-secondary);font-size:14px;margin:0}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--danger);margin-bottom:24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.empty-state svg{color:var(--border);margin-bottom:24px}.empty-state h3{font-size:20px;font-weight:600;color:var(--text);margin-bottom:8px}.empty-state p{color:var(--text-secondary);max-width:400px}.deleted-list{display:flex;flex-direction:column;gap:16px}.deleted-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;justify-content:space-between;gap:24px;transition:all .2s}.deleted-card:hover{border-color:var(--text-tertiary)}.deleted-card.urgent{border-color:#ef44444d;background:#ef444405}.deleted-card-main{flex:1;min-width:0}.deleted-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.wo-info{display:flex;flex-direction:column;gap:4px}.wo-number{font-size:12px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.wo-info h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.days-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--background);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.days-badge.urgent{background:#ef44441a;color:var(--danger)}.deleted-card-details{display:flex;flex-wrap:wrap;gap:16px}.detail-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.detail-item svg{color:var(--text-tertiary);flex-shrink:0}.detail-item.deleted-by{color:var(--text-tertiary);font-style:italic}.deleted-card-actions{display:flex;flex-direction:column;gap:10px;justify-content:center}.btn-restore{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-width:140px}.btn-restore:hover:not(:disabled){background:var(--primary-dark)}.btn-delete{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:transparent;color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;min-width:140px}.btn-delete:hover:not(:disabled){background:var(--danger);color:#fff}.loading-spinner{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.confirm-modal{background:var(--surface);border-radius:var(--radius-lg);padding:32px;width:90%;max-width:420px;text-align:center}.confirm-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 20px;background:#ef44441a;border-radius:50%;color:var(--danger)}.confirm-modal h2{font-size:20px;font-weight:600;color:var(--text);margin-bottom:12px}.confirm-modal p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.confirm-modal ul{text-align:left;padding-left:24px;margin:16px 0;color:var(--text-secondary);font-size:14px}.confirm-modal li{margin-bottom:6px}.warning-text{color:var(--danger)!important;font-weight:500}.confirm-actions{display:flex;gap:12px;margin-top:24px}.confirm-actions .btn{flex:1;padding:12px;font-size:14px;font-weight:500}.btn-secondary{background:var(--background);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger);border:none;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px}.btn-danger:hover:not(:disabled){background:#dc2626}@media(max-width:768px){.deleted-wo-page{padding:16px}.deleted-header{flex-direction:column;align-items:flex-start}.deleted-card{flex-direction:column;gap:16px}.deleted-card-actions{flex-direction:row;width:100%}.deleted-card-actions .btn{flex:1}}.task-detail{max-width:1000px;margin:0 auto}.task-detail-loading,.task-detail-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;text-align:center}.task-detail-error h2{font-size:20px;font-weight:600;color:var(--text)}.task-detail-error p{color:var(--text-secondary);margin-bottom:16px}.task-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.task-header .back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;transition:all .2s ease}.task-header .back-btn:hover{background:var(--surface);color:var(--text)}.header-actions{display:flex;gap:12px}.task-info-card{background:var(--surface);border-radius:var(--radius-xl);padding:28px;margin-bottom:24px;box-shadow:var(--shadow-md)}.task-status-row{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.task-checkbox{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .2s;flex-shrink:0}.task-checkbox:hover{border-color:var(--success);color:var(--success)}.task-checkbox.checked{background:var(--success);border-color:var(--success);color:#fff}.task-main-info{flex:1}.task-main-info h1{font-size:24px;font-weight:700;color:var(--text);margin-bottom:8px}.task-main-info h1.completed{text-decoration:line-through;opacity:.7}.edit-title-input{width:100%;font-size:24px;font-weight:700;padding:8px 12px;border:2px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px}.edit-title-input:focus{border-color:var(--primary);outline:none}.task-type-badge{display:inline-flex;padding:6px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:600}.task-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.detail-item{display:flex;align-items:flex-start;gap:12px}.detail-item svg{color:var(--text-tertiary);margin-top:2px}.detail-item label{display:block;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-item span{font-size:15px;color:var(--text);font-weight:500}.price-value{font-size:18px!important;font-weight:700!important;color:var(--success)!important}.edit-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px}.task-description{margin-top:24px}.task-description label{display:block;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.task-description p{font-size:15px;color:var(--text);line-height:1.6}.task-ai-instructions{margin-top:24px;background:linear-gradient(135deg,#10b98114,#10b98108);border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-lg);padding:20px}.task-ai-instructions label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#10b981;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.task-ai-instructions .ai-instructions-content{font-size:14px;color:var(--text);line-height:1.7}.task-ai-instructions .ai-instructions-content p{margin:4px 0}.task-ai-instructions .ai-instructions-content p:empty{display:none}.task-rework-items{margin-top:24px;background:linear-gradient(135deg,#dc262614,#dc262608);border:1px solid rgba(220,38,38,.2);border-radius:var(--radius-lg);padding:20px}.task-rework-items label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#dc2626;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.task-rework-items ul{margin:0;padding-left:20px}.task-rework-items li{font-size:14px;color:var(--text);line-height:1.7;margin:6px 0}.edit-textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;line-height:1.6;resize:vertical}.photo-buckets-section{background:var(--surface);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md)}.photo-buckets-section h2{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--text);margin-bottom:24px}.photo-buckets-section h2 svg{color:var(--primary)}.buckets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.bucket-card{background:var(--background);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border)}.bucket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.bucket-header h3{font-size:15px;font-weight:600;color:var(--text)}.bucket-count{font-size:13px;color:var(--text-secondary);background:var(--surface);padding:4px 10px;border-radius:var(--radius-full)}.bucket-description{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.bucket-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:16px}.bucket-photo{aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;position:relative}.bucket-photo img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.bucket-photo:hover img{transform:scale(1.05)}.bucket-photo .photo-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;color:#fff}.bucket-photo:hover .photo-overlay{opacity:1}.no-photos{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;color:var(--text-tertiary);gap:8px;background:var(--surface);border-radius:var(--radius-md);border:2px dashed var(--border)}.bucket-actions{display:flex;gap:8px}.upload-btn{flex:1;justify-content:center}.no-buckets{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;color:var(--text-tertiary);text-align:center}.no-buckets h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.photo-viewer-overlay{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center}.viewer-close{position:absolute;top:20px;right:20px;width:48px;height:48px;border-radius:50%;background:#ffffff1a;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}.viewer-close:hover{background:#fff3}.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border-radius:50%;background:#ffffff1a;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}.viewer-nav:hover{background:#fff3}.viewer-nav.prev{left:20px}.viewer-nav.next{right:20px}.viewer-content{max-width:90%;max-height:85%;display:flex;flex-direction:column;align-items:center}.viewer-content img{max-width:100%;max-height:calc(85vh - 60px);object-fit:contain;border-radius:var(--radius-lg)}.viewer-info{display:flex;align-items:center;gap:16px;margin-top:16px;color:#fffc;font-size:14px}.viewer-bucket{font-weight:600}@media(max-width:768px){.task-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .btn{flex:1}.task-details-grid{grid-template-columns:1fr 1fr}.buckets-grid{grid-template-columns:1fr}}.checkin-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-lg);margin-bottom:20px;border:1px solid #F59E0B}.checkin-info{display:flex;align-items:center;gap:12px}.checkin-info svg{color:#d97706;flex-shrink:0}.checkin-info strong{display:block;color:#92400e;font-size:14px}.checkin-info p{margin:0;font-size:12px;color:#b45309}.checked-in-badge{background:#10b981;color:#fff;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;margin-left:auto}.bucket-card.has-photos{border-color:#10b981}.bucket-card.has-photos .bucket-header{background:#10b9811a}.upload-btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}@media(max-width:640px){.checkin-banner{flex-direction:column;text-align:center}.checkin-info{flex-direction:column}}.bucket-photo{position:relative}.photo-info-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s;z-index:10}.bucket-photo:hover .photo-info-btn{opacity:1}.photo-info-btn:hover{background:#000c;transform:scale(1.1)}.viewer-info-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s;font-size:13px}.viewer-info-btn:hover{background:#fff3}.photo-info-modal{background:var(--surface);border-radius:var(--radius-xl);width:90%;max-width:420px;overflow:hidden;box-shadow:var(--shadow-xl)}.photo-info-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.photo-info-modal .modal-header h3{margin:0;font-size:18px;font-weight:600}.photo-info-modal .modal-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:6px;transition:all .2s}.photo-info-modal .modal-close:hover{background:var(--border);color:var(--text)}.photo-info-content{padding:20px}.info-section{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;align-items:flex-start;gap:12px}.info-item>svg{color:var(--primary);flex-shrink:0;margin-top:2px}.info-item>div{flex:1}.info-item label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:2px}.info-item span{display:block;font-size:14px;color:var(--text);word-break:break-word}.info-item .map-link{display:inline-block;margin-top:4px;font-size:13px;color:var(--primary);text-decoration:none}.info-item .map-link:hover{text-decoration:underline}.photo-buckets-section h2{display:flex;align-items:center;gap:8px}.bid-details-section{background:var(--surface);border-radius:var(--radius-lg);padding:20px;margin-top:20px;border:1px solid var(--border)}.bid-details-section h3{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text);margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.bid-details-section h3 svg{color:var(--warning)}.bid-field{margin-bottom:16px}.bid-field:last-child{margin-bottom:0}.bid-field label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.bid-field p{font-size:14px;color:var(--text);line-height:1.5;margin:0;padding:10px;background:var(--background);border-radius:var(--radius-md);min-height:60px}.bid-field .edit-textarea{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--background);color:var(--text);font-size:14px;resize:vertical}.bid-field .edit-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.invoice-page{max-width:900px;margin:0 auto}.invoice-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;transition:all .2s}.back-btn:hover{background:var(--background);color:var(--text)}.header-title{display:flex;align-items:center;gap:12px;flex:1}.header-title svg{color:var(--primary)}.header-title h1{font-size:20px;font-weight:700;color:var(--text);margin:0}.header-title span{font-size:14px;color:var(--text-secondary)}.edit-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;transition:all .2s}.edit-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.invoice-content{display:flex;flex-direction:column;gap:20px}.card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 3px #0000001a}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.card-header svg{color:var(--primary)}.card-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.empty-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 40px}.empty-icon{color:var(--text-tertiary);margin-bottom:16px}.empty-card h2{font-size:20px;font-weight:600;color:var(--text);margin:0 0 8px}.empty-card p{color:var(--text-secondary);margin:0 0 24px}.generate-btn{display:flex;align-items:center;gap:8px}.company-card{text-align:center}.company-card h2{font-size:22px;font-weight:700;color:var(--text);margin:0 0 8px}.company-card p{color:var(--text-secondary);margin:4px 0;font-size:14px}.info-grid{display:grid;gap:12px}.info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.info-row.full-width{flex-direction:column;gap:4px}.info-row .label{color:var(--text-secondary);font-size:14px}.info-row .value{color:var(--text);font-weight:500;font-size:14px}.line-items{display:flex;flex-direction:column}.line-item{padding:16px 0;border-bottom:1px solid var(--border)}.line-item-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.task-type-badge{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;color:#fff}.line-item-title{font-size:14px;font-weight:600;color:var(--text)}.title-input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-weight:600}.description-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;resize:vertical;margin-bottom:8px}.line-item-description{font-size:13px;color:var(--text-secondary);margin:0 0 8px}.photo-thumbnails{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.thumbnail{width:50px;height:50px;object-fit:cover;border-radius:var(--radius-sm)}.more-photos{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-secondary)}.line-item-amount{display:flex;align-items:center;justify-content:flex-end;gap:10px}.amount-label{color:var(--text-secondary);font-size:14px}.amount-value{font-size:16px;font-weight:600;color:var(--success)}.amount-input-container{display:flex;align-items:center;background:var(--background);border-radius:var(--radius-sm);padding:4px 8px}.amount-input-container .currency{font-size:14px;color:var(--text)}.amount-input{width:80px;padding:4px 8px;border:none;background:transparent;font-size:14px;font-weight:600;text-align:right}.total-row{display:flex;justify-content:space-between;align-items:center;padding-top:16px;margin-top:8px;border-top:2px solid var(--text)}.total-label{font-size:18px;font-weight:700;color:var(--text)}.total-value{font-size:24px;font-weight:700;color:var(--success)}.notes-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;resize:vertical;min-height:80px}.notes-text{color:var(--text-secondary);font-size:14px;margin:0}.action-buttons{display:flex;gap:12px}.btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;flex:1;justify-content:center}.btn-primary{background:var(--primary);color:#fff;border:none}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--background);color:var(--text)}.btn-outline{background:transparent;color:var(--primary);border:1px solid var(--primary)}.btn-outline:hover:not(:disabled){background:#f973161a}.btn:disabled{opacity:.6;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.pdf-card{display:flex;align-items:center;gap:16px;text-decoration:none;border-left:4px solid var(--error);transition:background .2s}.pdf-card:hover{background:var(--background)}.pdf-icon{color:var(--error)}.pdf-info{flex:1}.pdf-title{display:block;font-size:15px;font-weight:600;color:var(--text)}.pdf-subtitle{font-size:12px;color:var(--text-secondary)}.history-list{display:flex;flex-direction:column}.history-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.history-info{display:flex;flex-direction:column}.history-number{font-size:14px;font-weight:600;color:var(--text)}.history-date{font-size:12px;color:var(--text-secondary)}.history-actions{display:flex;align-items:center;gap:12px}.history-total{font-size:14px;font-weight:600;color:var(--success)}.history-actions a{color:var(--error)}.bid-report-page{max-width:900px;margin:0 auto}.bid-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}.bid-icon{color:#f59e0b}.bid-header .header-title svg{color:#f59e0b}.bid-content{display:flex;flex-direction:column;gap:20px}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none}.btn-warning:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.btn-outline-warning{background:transparent;color:#f59e0b;border:1px solid #F59E0B}.btn-outline-warning:hover:not(:disabled){background:#f59e0b1a}.ai-badge{display:flex;align-items:center;gap:4px;background:#f59e0b;color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;margin-left:auto}.task-number{font-size:14px;font-weight:700;color:#f59e0b;margin-right:8px}.measurement-container{display:flex;align-items:center;gap:8px;background:var(--background);padding:8px 12px;border-radius:var(--radius-sm);margin-bottom:12px}.measurement-container svg{color:var(--text-secondary)}.measurement-container span{font-size:12px;color:var(--text-secondary);font-style:italic}.bid-report-page .total-value,.bid-report-page .amount-value,.bid-report-page .history-total{color:#f59e0b}.bid-report-page .back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;transition:all .2s}.bid-report-page .back-btn:hover{background:var(--background);color:var(--text)}.bid-report-page .header-title{display:flex;align-items:center;gap:12px;flex:1}.bid-report-page .header-title h1{font-size:20px;font-weight:700;color:var(--text);margin:0}.bid-report-page .header-title>div>span{font-size:14px;color:var(--text-secondary)}.bid-report-page .edit-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;transition:all .2s}.bid-report-page .edit-btn:hover{background:#f59e0b;color:#fff;border-color:#f59e0b}.bid-report-page .card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 3px #0000001a}.bid-report-page .card-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.bid-report-page .card-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.bid-report-page .empty-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 40px}.bid-report-page .empty-icon{color:var(--text-tertiary);margin-bottom:16px}.bid-report-page .empty-card h2{font-size:20px;font-weight:600;color:var(--text);margin:0 0 8px}.bid-report-page .empty-card p{color:var(--text-secondary);margin:0 0 24px}.bid-report-page .generate-btn{display:flex;align-items:center;gap:8px}.bid-report-page .no-bid-tasks{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text-tertiary)}.bid-report-page .no-bid-tasks svg{color:#f59e0b;opacity:.5;margin-bottom:12px}.bid-report-page .no-bid-tasks p{font-size:16px;font-weight:600;color:var(--text-secondary);margin:0 0 8px}.bid-report-page .no-bid-tasks span{font-size:14px;color:var(--text-tertiary)}.bid-report-page .company-card{text-align:center}.bid-report-page .company-card h2{font-size:22px;font-weight:700;color:var(--text);margin:0 0 8px}.bid-report-page .company-card p{color:var(--text-secondary);margin:4px 0;font-size:14px}.bid-report-page .info-grid{display:grid;gap:12px}.bid-report-page .info-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}.bid-report-page .info-row.full-width{flex-direction:column;gap:4px}.bid-report-page .info-row .label{color:var(--text-secondary);font-size:14px}.bid-report-page .info-row .value{color:var(--text);font-weight:500;font-size:14px}.bid-report-page .line-items{display:flex;flex-direction:column}.bid-report-page .line-item{padding:16px 0;border-bottom:1px solid var(--border)}.bid-report-page .line-item-header{display:flex;align-items:center;margin-bottom:8px}.bid-report-page .line-item-title{font-size:14px;font-weight:600;color:var(--text)}.bid-report-page .title-input{flex:1;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-weight:600}.bid-report-page .description-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;resize:vertical;margin-bottom:8px}.bid-report-page .line-item-description{font-size:13px;color:var(--text-secondary);margin:0 0 8px;line-height:1.5}.bid-report-page .photo-thumbnails{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.bid-report-page .thumbnail{width:50px;height:50px;object-fit:cover;border-radius:var(--radius-sm)}.bid-report-page .more-photos{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--text-secondary)}.bid-report-page .line-item-amount{display:flex;align-items:center;justify-content:flex-end;gap:10px}.bid-report-page .amount-label{color:var(--text-secondary);font-size:14px}.bid-report-page .amount-input-container{display:flex;align-items:center;background:var(--background);border-radius:var(--radius-sm);padding:4px 8px}.bid-report-page .amount-input-container .currency{font-size:14px;color:var(--text)}.bid-report-page .amount-input{width:80px;padding:4px 8px;border:none;background:transparent;font-size:14px;font-weight:600;text-align:right}.bid-report-page .total-row{display:flex;justify-content:space-between;align-items:center;padding-top:16px;margin-top:8px;border-top:2px solid var(--text)}.bid-report-page .total-label{font-size:18px;font-weight:700;color:var(--text)}.bid-report-page .total-value{font-size:24px;font-weight:700}.bid-report-page .notes-input{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;resize:vertical;min-height:80px}.bid-report-page .notes-text{color:var(--text-secondary);font-size:14px;margin:0}.bid-report-page .action-buttons{display:flex;gap:12px}.bid-report-page .btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;flex:1;justify-content:center}.bid-report-page .btn-secondary{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.bid-report-page .btn-secondary:hover{background:var(--background);color:var(--text)}.bid-report-page .btn:disabled{opacity:.6;cursor:not-allowed}.bid-report-page .spinning{animation:spin 1s linear infinite}.bid-report-page .pdf-card{display:flex;align-items:center;gap:16px;text-decoration:none;border-left:4px solid var(--error);transition:background .2s}.bid-report-page .pdf-card:hover{background:var(--background)}.bid-report-page .pdf-icon{color:var(--error)}.bid-report-page .pdf-info{flex:1}.bid-report-page .pdf-title{display:block;font-size:15px;font-weight:600;color:var(--text)}.bid-report-page .pdf-subtitle{font-size:12px;color:var(--text-secondary)}.bid-report-page .history-list{display:flex;flex-direction:column}.bid-report-page .history-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.bid-report-page .history-info{display:flex;flex-direction:column}.bid-report-page .history-number{font-size:14px;font-weight:600;color:var(--text)}.bid-report-page .history-date{font-size:12px;color:var(--text-secondary)}.bid-report-page .history-actions{display:flex;align-items:center;gap:12px}.bid-report-page .history-actions a{color:var(--error)}.bid-report-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.bid-report-page .loading-container p{color:var(--text-secondary);margin:0}.team-page{max-width:1400px;margin:0 auto}.team-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.team-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.team-stats{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap;overflow-x:auto;padding-bottom:8px}.stat{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);min-width:140px}.stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-icon.total-icon{background:#3b82f626;color:#3b82f6}.stat-value{font-size:22px;font-weight:700;color:var(--text)}.stat-label{font-size:12px;color:var(--text-secondary)}.team-error{display:flex;align-items:center;gap:10px;padding:16px;background:#fee2e2;border-radius:var(--radius-lg);margin-bottom:24px;color:#991b1b}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.team-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--surface);border-radius:var(--radius-xl);text-align:center;color:var(--text-tertiary)}.team-empty h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.team-empty p{margin-bottom:24px}.member-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:all .2s ease}.member-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.member-card.inactive{opacity:.7}.member-card-header{display:flex;align-items:flex-start;gap:14px;padding:20px;background:linear-gradient(135deg,#3b82f60d,#3b82f605);border-bottom:1px solid var(--border-light)}.member-avatar{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0}.member-header-info{flex:1;min-width:0}.member-header-info h3{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-name-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.admin-protected-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background:#ef44441a;color:#ef4444;border-radius:var(--radius-sm);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.member-card.is-admin .member-card-header{background:linear-gradient(135deg,#ef444414,#ef444405)}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600}.member-actions{display:flex;gap:4px}.member-card-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.member-card-footer{padding:12px 20px;background:var(--background);border-top:1px solid var(--border-light)}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600}.status-badge.inactive{background:var(--border);color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.form-error{display:block;font-size:12px;color:var(--error);margin-top:6px}.role-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.role-option{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease}.role-option:hover{border-color:var(--role-color)}.role-option.active{border-width:2px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--text)}.checkbox-label input{width:18px;height:18px;accent-color:var(--primary)}.payment-rate-input{display:flex;align-items:center;gap:8px}.payment-rate-input .form-input{width:100px;text-align:center}.payment-rate-input .rate-suffix{font-size:16px;font-weight:600;color:var(--text-secondary)}.role-hint{display:block;font-size:11px;color:var(--text-tertiary);margin-top:8px;font-style:italic}@media(max-width:768px){.team-header{flex-direction:column;align-items:stretch}.search-box{max-width:none}.team-stats{flex-wrap:nowrap}.team-grid,.role-selector{grid-template-columns:1fr}}.success-modal{text-align:center;max-width:480px;padding:40px 32px}.success-icon{display:flex;align-items:center;justify-content:center;width:100px;height:100px;margin:0 auto 24px;background:#10b9811a;border-radius:50%;color:#10b981}.success-modal h2{font-size:24px;font-weight:700;color:var(--text);margin:0 0 8px}.success-message{color:var(--text-secondary);margin-bottom:24px}.temp-password-card{background:var(--background);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px;text-align:left}.temp-password-header{display:flex;align-items:center;gap:8px;color:#f59e0b;font-weight:600;margin-bottom:12px}.temp-password-box{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:2px solid rgba(245,158,11,.3);border-radius:var(--radius-md);padding:12px 16px;margin-bottom:12px}.temp-password-value{font-size:20px;font-weight:700;letter-spacing:2px;color:var(--text);font-family:monospace}.copy-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:#6366f11a;border:none;color:var(--primary);cursor:pointer;transition:all .2s}.copy-btn:hover{background:#6366f133}.temp-password-note{font-size:13px;color:var(--text-secondary);line-height:1.5;margin:0}.btn-lg{padding:14px 32px;font-size:16px}.extra-user-modal{max-width:420px}.extra-user-icon{display:flex;justify-content:center;margin-bottom:16px;color:var(--primary)}.extra-user-message{text-align:center;font-size:15px;color:var(--text);line-height:1.6;margin-bottom:16px}.extra-user-message strong{color:var(--primary);font-size:18px}.extra-user-note{display:flex;align-items:center;gap:8px;background:#f59e0b1a;border-radius:var(--radius-md);padding:12px;font-size:13px;color:#92400e}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border);margin-top:16px}.clients-page{max-width:1400px;margin:0 auto}.clients-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.clients-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex:1;max-width:400px}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-box input{flex:1;border:none;background:none;font-size:14px;color:var(--text);outline:none}.clear-search{padding:4px;color:var(--text-tertiary)}.clients-stats{display:flex;gap:20px;margin-bottom:24px;flex-wrap:wrap}.stat{display:flex;align-items:center;gap:16px;padding:20px 24px;background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);min-width:200px}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.stat-icon.clients-icon{background:#6366f126;color:#6366f1}.stat-icon.active-icon{background:#10b98126;color:#10b981}.stat-icon.wo-icon{background:#f9731626;color:#f97316}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:24px;font-weight:700;color:var(--text)}.stat-label{font-size:13px;color:var(--text-secondary)}.clients-error{display:flex;align-items:center;gap:10px;padding:16px;background:#fee2e2;border-radius:var(--radius-lg);margin-bottom:24px;color:#991b1b}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.clients-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;background:var(--surface);border-radius:var(--radius-xl);text-align:center;color:var(--text-tertiary)}.clients-empty h3{font-size:18px;font-weight:600;color:var(--text);margin:16px 0 8px}.clients-empty p{margin-bottom:24px}.client-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:all .2s ease}.client-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.client-card.inactive{opacity:.7}.client-card-header{display:flex;align-items:flex-start;gap:16px;padding:20px;background:linear-gradient(135deg,#6366f10d,#6366f105);border-bottom:1px solid var(--border-light)}.client-avatar{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0}.client-header-info{flex:1;min-width:0}.client-header-info h3{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-name-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.status-badge{padding:3px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.status-badge.active{background:#10b98126;color:#10b981}.status-badge.inactive{background:#6b728026;color:#6b7280}.type-badge{display:inline-block;padding:4px 10px;background:#6366f126;color:#6366f1;border-radius:var(--radius-full);font-size:11px;font-weight:600}.client-actions{display:flex;gap:4px}.action-btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .2s ease}.action-btn.edit:hover{background:#3b82f61a;color:var(--secondary)}.action-btn.toggle{transition:all .2s ease}.action-btn.toggle.active{color:#10b981}.action-btn.toggle.active:hover{background:#10b9811a;color:#059669}.action-btn.toggle.inactive{color:#6b7280}.action-btn.toggle.inactive:hover{background:#6b72801a;color:#4b5563}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.delete:hover{background:#ef44441a;color:var(--error)}.client-card-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.contact-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.contact-row svg{color:var(--text-tertiary);flex-shrink:0}.contact-row a{color:var(--secondary);text-decoration:none}.contact-row a:hover{text-decoration:underline}.client-card-footer{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--background);border-top:1px solid var(--border-light)}.client-stat{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.client-stat svg{color:var(--text-tertiary)}.fab{position:fixed;bottom:32px;right:32px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #f9731666;transition:all .3s ease;z-index:100}.fab:hover{transform:scale(1.1);box-shadow:0 6px 20px #f9731680}.fab:active{transform:scale(.95)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;overflow-y:auto}.modal-content{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-content.large{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:18px;font-weight:700;color:var(--text)}.modal-header button{padding:4px;color:var(--text-secondary);border-radius:4px;transition:all .2s}.modal-header button:hover{background:var(--background);color:var(--text)}.modal-body{padding:24px;overflow-y:auto}.form-section{margin-bottom:24px}.form-section:last-child{margin-bottom:0}.form-section h4{font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}.form-error-banner{padding:12px 16px;background:#fee2e2;color:#991b1b;border-radius:var(--radius-md);margin-bottom:20px;font-size:14px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;padding:10px 14px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);transition:all .2s ease}.form-error{display:block;font-size:12px;color:var(--error);margin-top:4px}.form-row{display:flex;gap:16px}.flex-1{flex:1}.flex-2{flex:2}.toggle-label{display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:14px;color:var(--text);padding:8px 0}.toggle-text{font-weight:500}.toggle-switch{position:relative;width:50px;height:26px;background:#d1d5db;border-radius:13px;cursor:pointer;transition:background .3s ease}.toggle-switch.active{background:#10b981}.toggle-slider{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(24px)}.toggle-hint{display:block;font-size:12px;color:var(--text-tertiary);margin-top:4px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border)}@media(max-width:768px){.clients-header{flex-direction:column;align-items:stretch}.search-box{max-width:none}.clients-stats{flex-direction:column}.stat{min-width:auto}.clients-grid{grid-template-columns:1fr}.form-row{flex-direction:column;gap:0}}.chat-page{display:flex;height:calc(100vh - 64px);background:var(--background);margin:-24px}.chat-sidebar{width:320px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:18px;font-weight:700;color:var(--text);margin:0}.sync-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--background);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s;border:1px solid var(--border)}.sync-btn:hover{background:var(--border);color:var(--text)}.sync-btn:disabled{opacity:.5;cursor:not-allowed}.sync-btn .spinning{animation:spin 1s linear infinite}.chat-list{flex:1;overflow-y:auto}.chat-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;text-align:left;border-bottom:1px solid var(--border);transition:background .2s}.chat-item:hover{background:var(--background)}.chat-item.active{background:#f9731614;border-left:3px solid var(--primary)}.chat-item.unread{background:#f973160d}.chat-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0;color:#fff}.chat-avatar.internal{background:var(--primary)}.chat-avatar.field-crew{background:var(--secondary)}.chat-info{flex:1;min-width:0}.chat-name-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.chat-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-name.unread{font-weight:700}.chat-time{font-size:11px;color:var(--text-tertiary);flex-shrink:0}.chat-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.chat-preview.unread{color:var(--text);font-weight:500}.unread-badge{min-width:20px;height:20px;padding:0 6px;background:var(--primary);color:#fff;font-size:11px;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center}.chat-window{flex:1;display:flex;flex-direction:column;background:var(--background)}.no-chat-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);gap:16px}.no-chat-selected h3{font-size:20px;font-weight:600;color:var(--text);margin:0}.no-chat-selected p{color:var(--text-secondary);margin:0}.chat-header{display:flex;align-items:center;gap:14px;padding:14px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.chat-header-info h3{font-size:15px;font-weight:600;color:var(--text);margin:0 0 2px}.chat-type-label{font-size:12px;color:var(--text-tertiary)}.chat-header-info{flex:1}.reminder-btn{width:40px;height:40px;border-radius:var(--radius-md);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;border:none;cursor:pointer;flex-shrink:0}.reminder-btn:hover{background:var(--primary-dark);transform:scale(1.05)}.reminder-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.reminder-btn .spinning{animation:spin 1s linear infinite}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;display:flex;flex-direction:column;gap:8px}.empty-messages{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-tertiary);gap:12px}.empty-messages p{margin:0}.message{display:flex;gap:10px;max-width:70%}.message.own{align-self:flex-end;flex-direction:row-reverse}.message.other{align-self:flex-start}.message-avatar{width:30px;height:30px;border-radius:50%;background:var(--secondary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.message-content{display:flex;flex-direction:column;gap:4px;min-width:0;max-width:100%;overflow:hidden}.sender-name{font-size:11px;font-weight:600;color:var(--text-secondary)}.message-text{background:var(--surface);padding:10px 14px;border-radius:14px;font-size:14px;color:var(--text);line-height:1.4;margin:0;word-break:break-word;overflow-wrap:break-word}.message.own .message-text{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message.other .message-text{border-bottom-left-radius:4px}.message-footer{display:flex;align-items:center;gap:8px;justify-content:flex-end}.message.own .message-footer{justify-content:flex-start}.message-time{font-size:10px;color:var(--text-tertiary)}.reply-btn{opacity:0;padding:4px;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);transition:all .2s;cursor:pointer;border:none}.message:hover .reply-btn{opacity:1}.reply-btn:hover{background:var(--background);color:var(--primary)}.reply-preview{display:flex;padding:8px 10px;background:#0000000d;border-radius:var(--radius-md);margin-bottom:4px;gap:8px;max-width:250px;overflow:hidden}.reply-preview.own{background:#0003}.reply-bar{width:3px;background:var(--secondary);border-radius:2px;flex-shrink:0}.reply-preview.own .reply-bar{background:#fff}.reply-content{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;overflow:hidden}.reply-name{font-size:11px;font-weight:600;color:var(--secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-preview.own .reply-name{color:#fff;font-weight:700}.reply-text{font-size:12px;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;line-height:1.4}.reply-preview.own .reply-text{color:#fff}.reply-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--background);border-radius:var(--radius-md);margin-bottom:10px;border-left:3px solid var(--primary)}.reply-banner-content{display:flex;align-items:center;gap:10px;color:var(--primary);flex:1;min-width:0}.reply-banner-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.reply-banner-title{font-size:12px;font-weight:600;color:var(--primary)}.reply-banner-text{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-banner-close{padding:4px;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);transition:all .2s;cursor:pointer;border:none}.reply-banner-close:hover{background:var(--border);color:var(--text)}.message.system{max-width:90%;align-self:stretch}.message.system .message-content{width:100%}.message.system .message-text{background:#fff3cd;border:1px solid #FFE083;border-left:4px solid #FFC107;color:#212529}.sender-name.system{display:flex;align-items:center;gap:4px;color:#856404}.message-attachments{display:flex;flex-wrap:wrap;gap:8px}.message-attachments img{max-width:200px;max-height:200px;border-radius:var(--radius-md);cursor:pointer}.file-attachment{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--background);border-radius:var(--radius-md);font-size:13px;color:var(--text)}.message-input-container{padding:14px 20px;background:var(--surface);border-top:1px solid var(--border)}.attachments-preview{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.attachment-item{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--background);border-radius:var(--radius-md);font-size:12px;color:var(--text)}.attachment-item button{color:var(--text-tertiary);transition:color .2s}.attachment-item button:hover{color:var(--error)}.input-row{display:flex;align-items:center;gap:10px}.input-row input[type=text]{flex:1;padding:10px 14px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:14px;color:var(--text)}.input-row input:focus{border-color:var(--primary);outline:none}.attach-btn,.send-btn{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;transition:all .2s}.attach-btn{color:var(--text-secondary);background:var(--background)}.attach-btn:hover{background:var(--border);color:var(--text)}.send-btn{background:var(--primary);color:#fff}.send-btn:hover:not(:disabled){background:var(--primary-dark)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-tertiary);gap:12px;text-align:center}.empty-state h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.empty-state p{font-size:13px;color:var(--text-secondary);margin:0;max-width:280px;line-height:1.5}.sync-btn-large{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--primary);color:#fff;border-radius:var(--radius-md);font-size:13px;font-weight:600;margin-top:8px;transition:background .2s}.sync-btn-large:hover{background:var(--primary-dark)}.sync-btn-large:disabled{opacity:.5;cursor:not-allowed}.back-btn.mobile-only{display:none}@media(max-width:768px){.chat-sidebar{width:100%;position:absolute;inset:0;z-index:10}.chat-sidebar.hide-mobile{display:none}.chat-window{position:absolute;inset:0;z-index:10}.chat-window.hide-mobile{display:none}.back-btn.mobile-only{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);color:var(--text-secondary)}.back-btn.mobile-only:hover{background:var(--background)}.message{max-width:85%}}.profile-page{max-width:800px;margin:0 auto}.profile-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.profile-header{display:flex;align-items:center;gap:24px;padding:32px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius-xl);margin-bottom:24px;color:#fff}.profile-avatar{width:80px;height:80px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;border:3px solid rgba(255,255,255,.3)}.profile-header-info h1{font-size:28px;font-weight:700;margin-bottom:8px}.profile-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.profile-meta .role-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#fff3;border-radius:var(--radius-full);font-size:13px;font-weight:600;text-transform:capitalize}.profile-meta .email{display:flex;align-items:center;gap:6px;font-size:14px;opacity:.9}.message{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:var(--radius-lg);margin-bottom:24px;font-size:14px;font-weight:500}.message.success{background:#10b98126;color:#065f46}.message.error{background:#fee2e2;color:#991b1b}.profile-content{display:flex;flex-direction:column;gap:24px}.card-header{display:flex;align-items:center;gap:10px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.card-header h3{font-size:16px;font-weight:600;color:var(--text)}.icon-primary{color:var(--primary)}.icon-secondary{color:var(--secondary)}.icon-warning{color:var(--warning)}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.form-input.disabled{background:var(--border-light);cursor:not-allowed;opacity:.7}.form-hint{display:block;font-size:12px;color:var(--text-tertiary);margin-top:6px}.input-wrapper{position:relative}.input-wrapper .form-input{padding-right:48px}.toggle-password{position:absolute;right:12px;top:50%;transform:translateY(-50%);padding:4px;color:var(--text-tertiary);transition:color .2s}.toggle-password:hover{color:var(--text)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.info-item span{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text)}.info-item .role-value{color:var(--primary);font-weight:600}.info-item .mono{font-family:monospace;font-size:12px;background:var(--background);padding:6px 10px;border-radius:var(--radius-sm);color:var(--text-secondary)}@media(max-width:600px){.profile-header{flex-direction:column;text-align:center}.profile-meta{justify-content:center}.info-grid{grid-template-columns:1fr}}.settings-page{max-width:1000px;margin:0 auto;padding-bottom:40px}.settings-header{margin-bottom:24px}.settings-header h1{font-size:24px;font-weight:700;color:var(--text);margin:0 0 8px}.settings-header p{color:var(--text-secondary);margin:0;font-size:14px}.current-plan-card{margin:-50px 0 24px;padding:24px;border-radius:var(--radius-xl);color:#fff;box-shadow:0 10px 40px #0003}.plan-card-header{display:flex;align-items:center;gap:16px}.plan-icon-box{width:56px;height:56px;border-radius:16px;background:#fff3;display:flex;align-items:center;justify-content:center}.plan-info{flex:1}.plan-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;opacity:.8}.plan-name{font-size:22px;font-weight:700;margin:4px 0 0}.status-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;background:#fff3;border-radius:999px;font-size:13px;font-weight:600}.status-dot{width:8px;height:8px;border-radius:50%;background:#4ade80}.status-badge.past_due .status-dot{background:#ef4444}.status-badge.canceled .status-dot{background:#9ca3af}.plan-stats{display:flex;justify-content:center;margin-top:24px}.stat-item{text-align:center;padding:0 32px}.stat-value{display:block;font-size:28px;font-weight:700}.stat-label{display:block;font-size:13px;opacity:.8;margin-top:4px}.stat-divider{width:1px;background:#ffffff4d;margin:8px 0}.progress-section{margin-top:20px}.progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#fff;border-radius:4px;transition:width .3s}.progress-text{display:block;text-align:center;font-size:12px;opacity:.8;margin-top:8px}.trial-warning{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fbbf2433;border-radius:var(--radius-md);margin-top:16px;font-size:13px;color:#fef3c7}.manage-billing-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;margin-top:16px;background:#fff3;border-radius:var(--radius-lg);color:#fff;font-size:14px;font-weight:600;transition:background .2s}.manage-billing-btn:hover{background:#ffffff4d}.settings-tabs{display:flex;gap:8px;margin-bottom:24px;padding:4px;background:var(--surface);border-radius:var(--radius-lg)}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s}.tab-btn:hover{color:var(--text)}.tab-btn.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px #00000014}.form-card{background:var(--surface);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm)}.admin-notice{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f59e0b1a;border:1px solid #F59E0B;border-radius:var(--radius-md);margin-bottom:20px;color:#b45309;font-size:13px}.logo-upload{display:flex;align-items:center;gap:16px;margin-bottom:8px}.logo-preview{width:80px;height:80px;object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--background)}.logo-placeholder{width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:2px dashed var(--border);background:var(--background);color:var(--text-tertiary)}.form-group label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);background:var(--background);transition:border-color .2s}.form-group input:focus{border-color:var(--primary);outline:none}.form-group input:disabled{background:var(--border);cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row.three-col{grid-template-columns:2fr 1fr 1fr}.plans-header{margin-bottom:24px}.plans-header h2{font-size:22px;font-weight:700;color:var(--text);margin:0 0 8px}.plans-header p{color:var(--text-secondary);margin:0}.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}.plan-card{position:relative;background:var(--surface);border-radius:var(--radius-xl);overflow:hidden;border:2px solid transparent;box-shadow:var(--shadow-sm);transition:all .2s}.plan-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.plan-card.current{border-color:#10b981}.plan-card.popular{border-color:#f59e0b}.popular-badge{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px;background:linear-gradient(90deg,#f59e0b,#d97706);color:#fff;font-size:10px;font-weight:700;letter-spacing:.5px}.current-badge{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px;background:#ecfdf5;color:#10b981;font-size:10px;font-weight:700;letter-spacing:.5px}.plan-card-content{padding:20px}.plan-header-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.plan-icon-bg{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.plan-title h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.plan-title p{font-size:12px;color:var(--text-secondary);margin:4px 0 0}.plan-price{margin-bottom:12px}.price-amount{font-size:32px;font-weight:700;color:var(--text)}.price-period{font-size:14px;color:var(--text-secondary)}.price-diff{font-size:12px;padding:4px 10px;border-radius:6px;margin-bottom:12px;display:inline-block}.price-diff.upgrade{background:#22c55e1a;color:#16a34a}.price-diff.downgrade{background:#3b82f61a;color:#2563eb}.user-info-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);margin-bottom:16px;flex-wrap:wrap}.extra-user{background:#f973161a;color:var(--primary);padding:2px 8px;border-radius:4px;font-size:11px}.features-list{padding-top:16px;border-top:1px solid var(--border)}.feature-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);margin-bottom:8px}.feature-check{color:#10b981;flex-shrink:0}.select-plan-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;margin-top:16px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;color:#fff;transition:opacity .2s}.select-plan-btn:hover:not(.disabled){opacity:.9}.select-plan-btn.disabled{background:#e5e7eb;color:#6b7280;cursor:not-allowed}.enterprise-card{background:linear-gradient(135deg,#1f2937,#374151);border-radius:var(--radius-xl);padding:24px;cursor:pointer;transition:transform .2s}.enterprise-card:hover{transform:translateY(-2px)}.enterprise-content{display:flex;align-items:center;gap:16px}.enterprise-icon{width:56px;height:56px;border-radius:16px;background:#ffffff1a;display:flex;align-items:center;justify-content:center}.enterprise-info{flex:1}.enterprise-info h3{font-size:18px;font-weight:600;color:#fff;margin:0}.enterprise-info p{font-size:13px;color:#ffffffb3;margin:4px 0 0}.enterprise-cta{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffffff1a;border-radius:var(--radius-lg);color:#fff;font-size:13px;font-weight:600}.faq-section{margin-top:32px}.faq-section h3{font-size:18px;font-weight:600;color:var(--text);margin:0 0 16px}.faq-list{display:flex;flex-direction:column;gap:12px}.faq-item{display:flex;gap:12px;padding:16px;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.faq-item svg{color:var(--primary);flex-shrink:0;margin-top:2px}.faq-content h4{font-size:14px;font-weight:600;color:var(--text);margin:0 0 4px}.faq-content p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.support-card{margin-top:32px;padding:32px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:var(--radius-xl);text-align:center}.support-card svg{color:var(--primary)}.support-card h3{font-size:18px;font-weight:600;color:var(--text);margin:12px 0 8px}.support-card p{font-size:14px;color:var(--text-secondary);margin:0 0 16px}.animate-fadeIn{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-container p{color:var(--text-secondary);margin:0}@media(max-width:1024px){.plans-grid{grid-template-columns:1fr}}@media(max-width:640px){.form-row,.form-row.three-col{grid-template-columns:1fr}.plan-stats{flex-direction:column;gap:16px}.stat-divider{width:50%;height:1px;margin:0 auto}}.welcome-modal{background:var(--surface);border-radius:var(--radius-lg);padding:40px;width:90%;max-width:480px;text-align:center;box-shadow:0 20px 40px #0000004d}.welcome-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,var(--primary),#EA580C);border-radius:50%;color:#fff}.welcome-modal h2{font-size:24px;font-weight:700;color:var(--text);margin-bottom:8px}.welcome-modal>p{color:var(--text-secondary);margin-bottom:8px}.welcome-subtitle{font-size:15px;margin-bottom:24px!important}.welcome-subtitle strong{color:var(--primary)}.welcome-features{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;text-align:left;padding:20px;background:var(--background);border-radius:var(--radius-md)}.welcome-feature{display:flex;align-items:center;gap:12px;color:var(--text);font-size:14px}.welcome-feature svg{color:var(--success);flex-shrink:0}.welcome-actions{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.welcome-actions .btn{opacity:1!important;visibility:visible!important}.welcome-actions .btn-primary{background:linear-gradient(135deg,#f97316,#ea580c)!important;color:#fff!important}.welcome-actions .btn-secondary{background:var(--surface)!important;color:var(--text)!important;border:1px solid var(--border)!important}.welcome-actions .btn-lg{padding:14px 24px;font-size:16px;display:flex;align-items:center;justify-content:center;gap:8px}.welcome-note{font-size:12px;color:var(--text-tertiary);margin:0}.current-subscription-card{background:var(--surface);border-radius:var(--radius-xl);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-md);border:1px solid var(--border)}.subscription-status-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.subscription-plan-info{display:flex;align-items:center;gap:16px}.plan-icon-large{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026}.plan-details h2{font-size:20px;font-weight:700;color:var(--text);margin:0 0 8px}.plan-details .status-badge{display:inline-flex;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600}.subscription-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding-top:16px;border-top:1px solid var(--border)}.subscription-detail-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--background);border-radius:var(--radius-lg)}.subscription-detail-item svg{color:var(--primary);flex-shrink:0;margin-top:2px}.subscription-detail-item .detail-label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:4px}.subscription-detail-item .detail-value{display:block;font-size:16px;font-weight:600;color:var(--text)}.subscription-detail-item .trial-days{color:#3b82f6}.subscription-detail-item.trial-info{background:#3b82f614;border:1px solid rgba(59,130,246,.2)}.subscription-detail-item.cancel-warning{background:#ef444414;border:1px solid rgba(239,68,68,.2)}.subscription-detail-item.cancel-warning svg{color:#ef4444}.subscription-detail-item.cancel-warning .detail-value{color:#ef4444}.user-progress-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:8px}.user-progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.subscription-incomplete-banner{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f9731614;border:1px solid rgba(249,115,22,.3);border-radius:var(--radius-lg);margin-top:16px}.subscription-incomplete-banner svg{color:#f97316;flex-shrink:0;margin-top:2px}.subscription-incomplete-banner strong{display:block;color:var(--text);margin-bottom:4px}.subscription-incomplete-banner p{font-size:13px;color:var(--text-secondary);margin:0}.all-features-banner{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#10b98114,#3b82f614);border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-lg);margin-bottom:24px}.all-features-banner svg{color:#10b981;flex-shrink:0;margin-top:2px}.all-features-banner strong{display:block;color:var(--text);font-size:14px;margin-bottom:4px}.all-features-banner p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}@media(max-width:768px){.subscription-status-header{flex-direction:column;align-items:flex-start}.subscription-details-grid{grid-template-columns:1fr}}.subscription-actions{display:flex;align-items:center;gap:8px}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:var(--radius-md);background:var(--background);border:1px solid var(--border);color:var(--text-secondary);transition:all .2s}.btn-icon:hover{background:var(--surface);color:var(--primary);border-color:var(--primary)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.ct-page{padding:0;animation:ctFadeIn .3s ease}.ct-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.ct-header-info h1{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;color:var(--text);margin:0 0 6px}.ct-header-icon{color:var(--primary)}.ct-header-info p{font-size:14px;color:var(--text-secondary);margin:0}.ct-btn-create{padding:10px 20px;gap:8px}.ct-alert{display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:var(--radius-lg);margin-bottom:20px;font-size:14px;font-weight:500;animation:ctSlideIn .25s ease}.ct-alert svg:first-child{flex-shrink:0}.ct-alert span{flex:1}.ct-alert button{background:none;border:none;cursor:pointer;opacity:.6;padding:4px;border-radius:var(--radius-sm);transition:opacity .15s}.ct-alert button:hover{opacity:1}.ct-alert-error{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#991b1b;border:1px solid #FECACA}.ct-alert-success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);color:#166534;border:1px solid #BBF7D0}.ct-tabs{display:flex;gap:4px;background:var(--surface);padding:4px;border-radius:var(--radius-xl);border:1px solid var(--border);margin-bottom:24px;box-shadow:var(--shadow-sm)}.ct-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;border-radius:var(--radius-lg);transition:all .2s ease;white-space:nowrap}.ct-tab:hover{color:var(--text);background:var(--background)}.ct-tab.active{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 2px 8px rgba(var(--primary-rgb),.3)}.ct-tab-count{background:#fff3;padding:2px 8px;border-radius:var(--radius-full);font-size:12px;font-weight:600}.ct-tab:not(.active) .ct-tab-count{background:var(--background);color:var(--text-tertiary)}.ct-content{animation:ctFadeIn .25s ease}.ct-empty{text-align:center;padding:80px 20px;background:var(--surface);border-radius:var(--radius-xl);border:2px dashed var(--border)}.ct-empty-icon{width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,var(--background) 0%,var(--surface) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary)}.ct-empty h3{color:var(--text);margin-bottom:8px;font-size:18px;font-weight:600}.ct-empty p{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.ct-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}.ct-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all .2s ease}.ct-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);border-color:var(--primary)}.ct-card-inactive{opacity:.6}.ct-card-inactive:hover{opacity:.8}.ct-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 18px 12px;gap:12px}.ct-card-title-wrap{flex:1;min-width:0}.ct-card-title-wrap h3{font-size:16px;font-weight:600;color:var(--text);margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ct-card-actions{display:flex;gap:4px;flex-shrink:0}.ct-icon-btn{background:none;border:none;padding:6px;cursor:pointer;border-radius:var(--radius-md);color:var(--text-tertiary);transition:all .15s}.ct-icon-btn:hover{background:var(--background);color:var(--text)}.ct-icon-btn.ct-active{color:var(--success)}.ct-icon-btn.ct-inactive{color:var(--text-tertiary)}.ct-icon-btn.ct-delete:hover{color:var(--error);background:#fef2f2}.ct-card-body{padding:0 18px 12px}.ct-instructions{font-size:13px;color:var(--text-secondary);margin:0 0 12px;line-height:1.5}.ct-card-stats{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:10px}.ct-stat{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);background:var(--background);padding:4px 10px;border-radius:var(--radius-full)}.ct-card-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary)}.ct-card-footer{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--border-light);background:var(--background)}.ct-card-footer .ct-btn{flex:1}.ct-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 10px;border-radius:var(--radius-full);font-weight:600}.ct-badge-all{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.ct-badge-client{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.ct-badge-keyword{background:#f3e8ff;color:#6b21a8}.ct-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ct-btn:disabled{opacity:.5;cursor:not-allowed}.ct-btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 2px 6px rgba(var(--primary-rgb),.25)}.ct-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-rgb),.35)}.ct-btn-outline{background:var(--surface);color:var(--text);border:1px solid var(--border)}.ct-btn-outline:hover:not(:disabled){background:var(--background);border-color:var(--primary);color:var(--primary)}.ct-btn-sm{padding:6px 12px;font-size:12px;background:var(--surface);color:var(--text);border:1px solid var(--border)}.ct-btn-sm:hover{background:var(--background);border-color:var(--primary)}.ct-btn-submit{width:100%;padding:14px 24px;font-size:15px;margin-top:24px}.ct-create-container{max-width:640px}.ct-create-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-md)}.ct-create-header{display:flex;gap:16px;margin-bottom:28px}.ct-create-icon{width:48px;height:48px;padding:12px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-lg);color:#fff;flex-shrink:0}.ct-create-header h2{font-size:18px;font-weight:600;margin:0 0 6px}.ct-create-header p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.ct-upload-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--background);margin-bottom:24px}.ct-upload-zone:hover{border-color:var(--primary);background:rgba(var(--primary-rgb),.03)}.ct-upload-zone.has-file{border-color:var(--success);background:#f0fdf4}.ct-file-input{display:none}.ct-upload-placeholder,.ct-upload-file-info{display:flex;flex-direction:column;align-items:center;gap:8px}.ct-upload-placeholder svg,.ct-upload-file-icon{color:var(--text-tertiary);margin-bottom:8px}.ct-upload-file-icon{color:var(--success)}.ct-upload-text{font-size:15px;font-weight:600;color:var(--text)}.ct-upload-filename{font-size:15px;font-weight:600;color:var(--success)}.ct-upload-formats,.ct-upload-change{font-size:13px;color:var(--text-tertiary)}.ct-form-section{margin-bottom:20px}.ct-form-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}.ct-form-label svg{color:var(--text-tertiary)}.ct-required{color:var(--error);font-weight:700}.ct-form-hint{display:block;font-size:12px;color:var(--text-tertiary);margin-top:6px}.ct-input,.ct-select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);background:var(--surface);transition:all .15s;box-sizing:border-box}.ct-input:focus,.ct-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.ct-select{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='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}.ct-select:disabled{background-color:var(--background);cursor:not-allowed;opacity:.6}.ct-checkbox-option{display:flex;align-items:center;gap:10px;font-size:14px;cursor:pointer;color:var(--text);padding:10px 14px;margin-top:12px;background:var(--background);border-radius:var(--radius-md);transition:all .15s}.ct-checkbox-option:hover{background:var(--border-light)}.ct-checkbox-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.ct-checkbox-option svg{color:var(--primary)}.ct-ai-progress{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:var(--radius-xl);padding:32px;color:#fff}.ct-ai-progress-header{display:flex;align-items:center;gap:12px;margin-bottom:28px;font-size:16px;font-weight:600}.ct-ai-icon{animation:ctPulse 1.5s ease-in-out infinite;color:#60a5fa}.ct-ai-steps{display:flex;flex-direction:column;gap:16px}.ct-ai-step{display:flex;align-items:center;gap:14px;opacity:.4;transition:all .3s ease}.ct-ai-step.active{opacity:1}.ct-ai-step.current .ct-ai-step-icon{animation:ctPulse 1s ease-in-out infinite}.ct-ai-step-icon{width:36px;height:36px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}.ct-ai-step.active .ct-ai-step-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.ct-ai-step-info{flex:1}.ct-ai-step-label{display:block;font-weight:600;font-size:14px}.ct-ai-step-desc{display:block;font-size:12px;color:#94a3b8;margin-top:2px}.ct-submissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.ct-submission-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:all .2s}.ct-submission-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.ct-submission-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.ct-submission-header h4{font-size:14px;font-weight:600;color:var(--text);margin:0}.ct-submission-date{font-size:12px;color:var(--text-tertiary)}.ct-submission-details{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.ct-submission-detail{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.ct-submission-detail svg{color:var(--text-tertiary);flex-shrink:0}.ct-submission-actions{display:flex;gap:8px}.ct-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:ctFadeIn .15s ease}.ct-modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;animation:ctSlideIn .2s ease;box-shadow:var(--shadow-xl)}.ct-modal-sm{max-width:460px}.ct-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.ct-modal-header h2{font-size:17px;font-weight:600;margin:0}.ct-close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:6px;border-radius:var(--radius-md);transition:all .15s}.ct-close-btn:hover{background:var(--background);color:var(--text)}.ct-modal-instructions{padding:12px 24px;font-size:13px;color:var(--text-secondary);background:var(--background);margin:0;line-height:1.6}.ct-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.ct-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px;border-top:1px solid var(--border);background:var(--background)}.ct-form-group{margin-bottom:16px}.ct-form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.ct-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;color:var(--text);background:var(--surface);resize:vertical;font-family:inherit;box-sizing:border-box}.ct-textarea:focus{outline:none;border-color:var(--primary)}.ct-yes-no{display:flex;gap:10px;margin-top:6px}.ct-yn-btn{padding:8px 24px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.ct-yn-btn:hover{border-color:var(--text-tertiary)}.ct-yn-btn.active-yes{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981;color:#065f46}.ct-yn-btn.active-no{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#ef4444;color:#991b1b}.ct-currency-wrap{display:flex;align-items:center;gap:6px}.ct-currency-symbol{font-size:15px;font-weight:600;color:var(--text-secondary)}.ct-currency-input{flex:1}.ct-section-header{background:linear-gradient(135deg,var(--background) 0%,var(--surface) 100%);padding:10px 14px;font-weight:600;font-size:14px;color:var(--text);border-radius:var(--radius-md);margin:20px 0 12px;border-left:3px solid var(--primary)}.ct-field{margin-bottom:16px}.ct-field-label{display:block;font-size:14px;font-weight:500;color:var(--text);margin-bottom:6px}.ct-field-label.ct-sub{font-size:13px;color:var(--text-secondary)}.ct-field-sublabel{display:block;font-size:12px;color:var(--text-tertiary);margin-bottom:6px}.ct-subfield{margin-left:16px;margin-top:10px;padding-left:14px;border-left:2px solid var(--border)}.ct-preview-body{display:flex;flex-direction:column;gap:8px}.ct-preview-field{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-md);transition:background .15s}.ct-preview-field:hover{background:var(--background)}.ct-preview-section{background:var(--background);font-weight:600}.ct-preview-type{font-size:10px;text-transform:uppercase;background:var(--border);color:var(--text-tertiary);padding:3px 8px;border-radius:var(--radius-sm);flex-shrink:0;letter-spacing:.5px;font-weight:600}.ct-preview-label{font-size:14px;color:var(--text)}.ct-spin{animation:ctSpin 1s linear infinite}@keyframes ctFadeIn{0%{opacity:0}to{opacity:1}}@keyframes ctSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes ctSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes ctPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.parsing-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.parsing-card{background:var(--surface);border-radius:var(--radius-xl);padding:48px;width:100%;max-width:400px}.parsing-header{text-align:center;margin-bottom:32px}.parsing-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f9731633,#f973161a);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--primary)}.parsing-header h2{font-size:20px;font-weight:700;color:var(--text);margin-bottom:8px}.parsing-header p{font-size:14px;color:var(--text-secondary)}.progress-bar-container{margin-bottom:32px}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-dark));border-radius:4px;transition:width .5s ease}.progress-steps{display:flex;flex-direction:column;gap:16px}.progress-step{display:flex;align-items:center;gap:16px}.step-icon-wrapper{width:36px;height:36px;border-radius:50%;background:var(--background);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all .3s ease}.progress-step.active .step-icon-wrapper{background:var(--success);color:#fff}.progress-step.current .step-icon-wrapper{background:var(--primary);color:#fff}.progress-step span{font-size:15px;color:var(--text-secondary);transition:all .3s ease}.progress-step.active span{color:var(--success);font-weight:600}.progress-step.current span{color:var(--primary);font-weight:600}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.ct-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:20px 24px;margin-bottom:20px}.ct-info-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.ct-info-header h3{font-size:15px;font-weight:600;color:var(--text);margin:0}.ct-icon-warning{color:#f59e0b}.ct-steps-info{display:flex;flex-direction:column;gap:12px}.ct-step-info{display:flex;align-items:center;gap:12px}.ct-step-num{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ct-step-info span{font-size:14px;color:var(--text-secondary)}.ct-file-icon-container{width:56px;height:56px;border-radius:var(--radius-md);background:#10b98126;display:flex;align-items:center;justify-content:center;color:var(--success);flex-shrink:0}.ct-file-details{flex:1;text-align:left}.ct-file-name{display:block;font-size:15px;font-weight:600;color:var(--text)}.ct-file-ready{font-size:13px;color:var(--success)}.ct-remove-file{padding:8px;border-radius:var(--radius-md);color:var(--error);background:none;border:none;cursor:pointer;transition:background .2s}.ct-remove-file:hover{background:#ef44441a}.ct-upload-icon-circle{width:64px;height:64px;border-radius:50%;background:#f9731626;display:flex;align-items:center;justify-content:center;color:var(--primary);margin-bottom:12px}.ct-upload-hint{font-size:14px;color:var(--text-tertiary)}@media(max-width:768px){.ct-header{flex-direction:column;gap:16px;align-items:flex-start}.ct-btn-create{width:100%}.ct-grid,.ct-submissions-grid{grid-template-columns:1fr}.ct-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.ct-modal{max-height:90vh;margin:10px}.ct-create-header{flex-direction:column;text-align:center}.ct-create-icon{margin:0 auto}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.map-view-page{padding:24px;height:calc(100vh - 120px);display:flex;flex-direction:column;gap:20px}.map-stats-bar{display:flex;gap:16px;flex-wrap:wrap}.stat-card{background:#fff;border-radius:12px;padding:16px 24px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #00000014;min-width:180px}.stat-card .stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-card .stat-icon.total{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.stat-card .stat-icon.with-coords{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-card .stat-icon.missing{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-card .stat-info{display:flex;flex-direction:column}.stat-card .stat-value{font-size:24px;font-weight:700;color:#1f2937;line-height:1.2}.stat-card .stat-label{font-size:13px;color:#6b7280}.geocode-btn{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;margin-left:auto}.geocode-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.geocode-btn:disabled{opacity:.6;cursor:not-allowed}.geocode-btn.loading{background:#9ca3af}.map-container-wrapper{flex:1;display:flex;flex-direction:column;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:visible}.map-toolbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.map-toolbar h3{margin:0;font-size:16px;font-weight:600;color:#1f2937}.map-filters{display:flex;gap:12px}.map-filters select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#374151;background:#fff;cursor:pointer}.map-filters select:focus{outline:none;border-color:#3b82f6}.map-container{flex:1;min-height:400px}.map-container .leaflet-container{height:100%;width:100%;border-radius:0 0 16px 16px}.work-order-popup{min-width:250px}.work-order-popup h4{margin:0 0 8px;font-size:15px;font-weight:600;color:#1f2937}.work-order-popup .popup-order-number{font-size:12px;color:#6b7280;margin-bottom:12px}.work-order-popup .popup-row{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px}.work-order-popup .popup-row .label{color:#6b7280}.work-order-popup .popup-row .value{color:#1f2937;font-weight:500}.work-order-popup .popup-status{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.work-order-popup .popup-status.unassigned{background:#fee2e2;color:#dc2626}.work-order-popup .popup-status.assigned{background:#fef3c7;color:#d97706}.work-order-popup .popup-status.in_progress{background:#dbeafe;color:#2563eb}.work-order-popup .popup-status.complete{background:#d1fae5;color:#059669}.work-order-popup .popup-status.rework{background:#fce7f3;color:#db2777}.work-order-popup .popup-status.submitted{background:#e0e7ff;color:#4f46e5}.work-order-popup .popup-status.paid{background:#ccfbf1;color:#0d9488}.work-order-popup .popup-address{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb;font-size:13px;color:#374151}.work-order-popup .popup-view-btn{display:block;width:100%;margin-top:12px;padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;text-align:center;text-decoration:none}.work-order-popup .popup-view-btn:hover{background:#2563eb}.map-legend{display:flex;gap:16px;padding:12px 20px;background:#f9fafb;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.unassigned{background:#dc2626}.legend-dot.assigned{background:#f59e0b}.legend-dot.in_progress{background:#3b82f6}.legend-dot.complete{background:#10b981}.legend-dot.rework{background:#ec4899}.legend-dot.submitted{background:#6366f1}.legend-dot.paid{background:#14b8a6}.map-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#6b7280}.map-loading .spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.map-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px;text-align:center}.map-empty svg{color:#d1d5db}.map-empty h3{margin:0;font-size:18px;color:#374151}.map-empty p{margin:0;color:#6b7280;max-width:400px}.geocode-results-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.geocode-results-modal{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.geocode-results-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.geocode-results-header h3{margin:0;font-size:18px;color:#1f2937}.geocode-results-header .close-btn{background:none;border:none;cursor:pointer;color:#6b7280;padding:4px}.geocode-results-header .close-btn:hover{color:#1f2937}.geocode-results-summary{padding:16px 24px;background:#f9fafb;display:flex;gap:24px}.geocode-results-summary .summary-item{display:flex;flex-direction:column}.geocode-results-summary .summary-value{font-size:24px;font-weight:700}.geocode-results-summary .summary-value.success{color:#059669}.geocode-results-summary .summary-value.failed{color:#dc2626}.geocode-results-summary .summary-label{font-size:12px;color:#6b7280}.geocode-results-list{flex:1;overflow-y:auto;padding:16px 24px}.geocode-result-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f3f4f6}.geocode-result-item:last-child{border-bottom:none}.geocode-result-item .wo-number{font-weight:500;color:#1f2937}.geocode-result-item .result-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.geocode-result-item .result-badge.success{background:#d1fae5;color:#059669}.geocode-result-item .result-badge.failed{background:#fee2e2;color:#dc2626}.geocode-results-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.geocode-results-footer button{padding:10px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer}.geocode-results-footer button:hover{background:#2563eb}@media(max-width:768px){.map-view-page{padding:16px}.map-stats-bar{flex-direction:column}.stat-card{width:100%}.geocode-btn{margin-left:0;width:100%;justify-content:center}.map-toolbar{flex-direction:column;gap:12px;align-items:stretch}.map-filters{flex-direction:column}.map-legend{flex-wrap:wrap}}.queue-monitor-page{padding:24px;max-width:1400px;margin:0 auto}.queue-monitor-page .loading-state,.queue-monitor-page .error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:var(--text-secondary)}.queue-monitor-page .error-state{color:var(--danger)}.queue-monitor-page .error-state h3{margin:0;color:var(--text)}.queue-monitor-page .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.queue-monitor-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.queue-monitor-page .header-left h1{display:flex;align-items:center;gap:12px;margin:0 0 4px;font-size:24px;color:var(--text)}.queue-monitor-page .subtitle{margin:0;color:var(--text-secondary);font-size:14px}.queue-monitor-page .header-actions{display:flex;align-items:center;gap:16px}.queue-monitor-page .last-refresh{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary)}.queue-monitor-page .summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.queue-monitor-page .summary-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease}.queue-monitor-page .summary-card:hover{box-shadow:0 4px 12px #00000014}.queue-monitor-page .summary-card.warning{border-color:var(--danger);background:#fef2f2}.queue-monitor-page .card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.queue-monitor-page .card-icon.users{background:#6366f1}.queue-monitor-page .card-icon.pending{background:#f59e0b}.queue-monitor-page .card-icon.uploading{background:#3b82f6}.queue-monitor-page .card-icon.failed{background:#ef4444}.queue-monitor-page .card-icon.issues{background:#f97316}.queue-monitor-page .card-content{display:flex;flex-direction:column}.queue-monitor-page .card-value{font-size:28px;font-weight:700;color:var(--text);line-height:1}.queue-monitor-page .card-label{font-size:13px;color:var(--text-secondary);margin-top:4px}.queue-monitor-page .queue-table-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:24px}.queue-monitor-page .queue-table{width:100%;border-collapse:collapse}.queue-monitor-page .queue-table th{background:#f8fafc;padding:14px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.queue-monitor-page .queue-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.queue-monitor-page .queue-table tr:last-child td{border-bottom:none}.queue-monitor-page .queue-table tr.has-issues{background:#fef2f2}.queue-monitor-page .queue-table tr:hover{background:#f8fafc}.queue-monitor-page .queue-table tr.has-issues:hover{background:#fee2e2}.queue-monitor-page .user-cell .user-info{display:flex;flex-direction:column}.queue-monitor-page .user-name{font-weight:600;color:var(--text)}.queue-monitor-page .user-email{font-size:12px;color:var(--text-secondary)}.queue-monitor-page .number-cell{text-align:center;font-weight:600}.queue-monitor-page .failed-count{color:var(--danger)}.queue-monitor-page .network-cell{display:flex;align-items:center;gap:8px}.queue-monitor-page .network-type{font-size:12px;color:var(--text-secondary);text-transform:capitalize}.queue-monitor-page .text-green{color:#10b981}.queue-monitor-page .text-yellow{color:#f59e0b}.queue-monitor-page .text-red{color:#ef4444}.queue-monitor-page .error-cell{max-width:200px}.queue-monitor-page .error-text{font-size:12px;color:var(--danger);cursor:help}.queue-monitor-page .no-error{color:var(--text-tertiary)}.queue-monitor-page .time-cell .stale{color:var(--danger)}.queue-monitor-page .actions-cell{text-align:right}.queue-monitor-page .status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:16px;font-size:12px;font-weight:600}.queue-monitor-page .status-badge.offline,.queue-monitor-page .status-badge.failed{background:#fee2e2;color:#991b1b}.queue-monitor-page .status-badge.uploading{background:#dbeafe;color:#1e40af}.queue-monitor-page .status-badge.pending{background:#fef3c7;color:#92400e}.queue-monitor-page .status-badge.ok{background:#d1fae5;color:#065f46}.queue-monitor-page .empty-state{text-align:center;padding:48px!important;color:var(--text-secondary)}.queue-monitor-page .empty-state svg{color:#10b981;margin-bottom:12px}.queue-monitor-page .empty-state p{margin:0}.queue-monitor-page .btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s ease}.queue-monitor-page .btn:disabled{opacity:.6;cursor:not-allowed}.queue-monitor-page .btn-primary{background:var(--primary);color:#fff}.queue-monitor-page .btn-primary:hover:not(:disabled){background:var(--primary-dark)}.queue-monitor-page .btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.queue-monitor-page .btn-secondary:hover:not(:disabled){background:#f1f5f9}.queue-monitor-page .btn-sm{padding:6px 12px;font-size:12px}.queue-monitor-page .btn-action{background:#eff6ff;color:#1e40af;border:1px solid #BFDBFE}.queue-monitor-page .btn-action:hover:not(:disabled){background:#dbeafe}.queue-monitor-page .info-banner{display:flex;gap:16px;padding:16px 20px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:12px;color:#1e40af}.queue-monitor-page .info-banner svg{flex-shrink:0;margin-top:2px}.queue-monitor-page .info-content strong{display:block;margin-bottom:4px}.queue-monitor-page .info-content p{margin:0;font-size:13px;line-height:1.5;opacity:.9}@media(max-width:768px){.queue-monitor-page{padding:16px}.queue-monitor-page .page-header{flex-direction:column}.queue-monitor-page .summary-cards{grid-template-columns:repeat(2,1fr)}.queue-monitor-page .queue-table-container{overflow-x:auto}.queue-monitor-page .queue-table{min-width:800px}}.accounting-page{padding:0;max-width:1400px;margin:0 auto}.accounting-page .loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.accounting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.accounting-header .header-content h1{font-size:28px;font-weight:700;color:#1a1a2e;margin:0}.accounting-header .header-content p{color:#64748b;margin:4px 0 0}.accounting-header .header-actions{display:flex;gap:12px}.accounting-header .btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.accounting-header .btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none}.accounting-header .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.accounting-header .btn-secondary{background:#fff;color:#334155;border:2px solid #e2e8f0}.accounting-header .btn-secondary:hover{border-color:#cbd5e1;background:#f8fafc}.pending-alert{display:flex;align-items:center;gap:12px;padding:14px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;margin-bottom:24px;cursor:pointer;transition:all .2s;border:1px solid #fbbf24}.pending-alert:hover{transform:translateY(-1px);box-shadow:0 4px 12px #fbbf2433}.pending-alert svg:first-child{color:#d97706}.pending-alert span{flex:1;color:#92400e}.pending-alert svg:last-child{color:#d97706}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-bottom:32px}.summary-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000000d;border:1px solid #e2e8f0;transition:all .2s}.summary-card:hover{box-shadow:0 4px 12px #00000014}.summary-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.summary-card .card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.summary-card .card-icon.ar{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.summary-card .card-icon.ap{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#db2777}.summary-card .card-icon.pnl{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.summary-card .card-header h3{font-size:16px;font-weight:600;color:#334155;margin:0}.summary-card .card-stats{display:flex;flex-direction:column;gap:12px}.summary-card .stat{display:flex;justify-content:space-between;align-items:center}.summary-card .stat.highlight{padding-top:12px;border-top:1px dashed #e2e8f0;margin-top:4px}.summary-card .stat-label{font-size:14px;color:#64748b}.summary-card .stat-value{font-size:18px;font-weight:700;color:#1a1a2e}.summary-card .stat-value.positive{color:#10b981}.summary-card .stat-value.negative{color:#ef4444}.summary-card .stat-value.warning{color:#f59e0b}.summary-card .stat-value.success{color:#10b981}.summary-card .card-footer{display:flex;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9}.summary-card .count-badge{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b;background:#f8fafc;padding:6px 10px;border-radius:6px}.summary-card .count-badge.partial{color:#d97706;background:#fffbeb}.summary-card .margin-badge{font-size:14px;font-weight:600;color:#059669;background:#d1fae5;padding:6px 12px;border-radius:6px}.quick-actions{margin-bottom:32px}.quick-actions h2{font-size:18px;font-weight:600;color:#1a1a2e;margin:0 0 16px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.action-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:24px;cursor:pointer;transition:all .2s;text-align:center}.action-card:hover{border-color:#3b82f6;background:#f8fafc;transform:translateY(-2px)}.action-card svg{color:#3b82f6;margin-bottom:12px}.action-card h4{font-size:16px;font-weight:600;color:#1a1a2e;margin:0 0 4px}.action-card p{font-size:13px;color:#64748b;margin:0}.recent-activity{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.activity-section{background:#fff;border-radius:16px;padding:20px;border:1px solid #e2e8f0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#334155;margin:0}.view-all-btn{display:flex;align-items:center;gap:4px;font-size:13px;color:#3b82f6;background:none;border:none;cursor:pointer;font-weight:500}.view-all-btn:hover{text-decoration:underline}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px}.activity-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.activity-icon.received{background:#d1fae5;color:#059669}.activity-icon.paid{background:#dbeafe;color:#2563eb}.activity-details{flex:1;min-width:0}.activity-title{display:flex;align-items:center;gap:8px;font-weight:500;color:#1a1a2e;font-size:14px}.ref-badge{font-size:11px;color:#64748b;background:#e2e8f0;padding:2px 6px;border-radius:4px;font-weight:500}.activity-meta{font-size:12px;color:#64748b}.activity-amount{font-weight:700;font-size:15px}.activity-amount.positive{color:#10b981}.activity-amount.negative{color:#ef4444}.empty-state{text-align:center;padding:32px;color:#94a3b8}.page-header{display:flex;align-items:center;gap:24px;margin-bottom:24px}.page-header .back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f1f5f9;border:none;border-radius:8px;color:#475569;cursor:pointer;font-weight:500;transition:all .2s}.page-header .back-btn:hover{background:#e2e8f0}.page-header .header-title{display:flex;align-items:center;gap:12px}.page-header .header-title svg{color:#3b82f6}.page-header .header-title h1{font-size:24px;font-weight:700;color:#1a1a2e;margin:0}.page-header .header-title span{display:block;font-size:14px;color:#64748b}.payment-layout{display:grid;grid-template-columns:1fr 400px;gap:24px}.invoices-panel,.payment-panel{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden}.panel-header{padding:20px;border-bottom:1px solid #e2e8f0}.panel-header h2{font-size:16px;font-weight:600;color:#1a1a2e;margin:0 0 12px}.panel-header h3{font-size:16px;font-weight:600;color:#1a1a2e;margin:0}.panel-header span{font-size:13px;color:#64748b}.filter-row{display:flex;gap:12px}.client-select{flex:1;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155}.invoice-list{max-height:calc(100vh - 300px);overflow-y:auto;padding:12px}.invoice-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:12px;border:2px solid transparent;transition:all .2s}.invoice-item.selected{border-color:#3b82f6;background:#eff6ff}.invoice-item:hover{background:#f1f5f9}.invoice-checkbox{padding-top:4px}.invoice-checkbox input{width:20px;height:20px;cursor:pointer}.invoice-info{flex:1;min-width:0}.invoice-header{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}.wo-number{font-weight:600;color:#1a1a2e}.client-name,.crew-name{font-size:13px;color:#64748b}.status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:4px}.status-badge.paid{background:#d1fae5;color:#059669}.status-badge.unpaid{background:#fef3c7;color:#d97706}.invoice-address{font-size:13px;color:#64748b;margin-bottom:8px}.invoice-amounts{display:flex;flex-wrap:wrap;gap:12px;font-size:13px}.invoice-amounts span{color:#475569}.invoice-amounts .paid{color:#10b981}.invoice-amounts .balance{font-weight:600;color:#f59e0b}.invoice-apply{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.invoice-apply label{font-size:12px;color:#64748b}.amount-input-wrapper{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.amount-input-wrapper .currency-symbol{padding:8px 8px 8px 12px;color:#64748b;font-weight:500}.amount-input-wrapper input{width:100px;padding:8px 12px 8px 0;border:none;font-size:14px;font-weight:600;color:#1a1a2e}.amount-input-wrapper input:focus{outline:none}.payment-form{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:#475569;margin-bottom:6px}.form-group select,.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;transition:border-color .2s}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.payment-summary{background:#f8fafc;border-radius:12px;padding:16px;margin:20px 0}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;color:#64748b}.summary-row.total{border-top:1px dashed #e2e8f0;margin-top:8px;padding-top:16px}.summary-row .total-amount{font-size:24px;font-weight:700;color:#1a1a2e}.submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.pending-layout{display:grid;grid-template-columns:1fr 400px;gap:24px}.pending-list{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:12px;max-height:calc(100vh - 200px);overflow-y:auto}.pending-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:12px;cursor:pointer;border:2px solid transparent;transition:all .2s}.pending-item:hover{background:#f1f5f9}.pending-item.active{border-color:#3b82f6;background:#eff6ff}.pending-info{flex:1}.pending-header{display:flex;align-items:center;gap:12px;margin-bottom:4px}.pending-client{font-weight:500;color:#334155;margin-bottom:2px}.pending-address{font-size:13px;color:#64748b;margin-bottom:8px}.pending-meta{display:flex;gap:16px;font-size:12px;color:#94a3b8}.pending-icon{color:#f59e0b;flex-shrink:0}.edit-panel{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden}.edit-form{padding:20px}.amount-input-large{display:flex;align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;overflow:hidden}.amount-input-large .currency-symbol{padding:16px;font-size:20px;font-weight:600;color:#64748b}.amount-input-large input{flex:1;padding:16px 16px 16px 0;border:none;background:transparent;font-size:24px;font-weight:700;color:#1a1a2e}.amount-input-large input:focus{outline:none}.bill-calculation{background:#f8fafc;border-radius:12px;padding:16px;margin:20px 0}.calc-header{display:flex;align-items:center;gap:8px;font-size:13px;color:#64748b;margin-bottom:8px}.calc-result{font-size:24px;font-weight:700;color:#3b82f6;margin-bottom:12px}.override-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:#64748b;cursor:pointer}.override-toggle input{width:auto}.profit-preview{background:#f0fdf4;border-radius:12px;padding:16px;margin:20px 0}.profit-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;color:#475569}.profit-row.total{border-top:1px dashed #a7f3d0;margin-top:8px;padding-top:12px;font-weight:600}.profit-amount{color:#059669;font-size:18px}.panel-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#94a3b8;text-align:center}.panel-placeholder svg{margin-bottom:12px;opacity:.5}.empty-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:60px;text-align:center}.empty-card .success-icon{color:#10b981;margin-bottom:16px}.empty-card h2{font-size:24px;color:#1a1a2e;margin:0 0 8px}.empty-card p{color:#64748b;margin:0 0 24px}.empty-card .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer}.empty-card .btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none}.report-tabs{display:flex;gap:8px;padding:16px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;margin-bottom:24px;overflow-x:auto}.report-tabs .tab{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;background:transparent;border-radius:8px;color:#64748b;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s}.report-tabs .tab:hover{background:#f1f5f9;color:#334155}.report-tabs .tab.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.report-content{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden}.report-section{padding:24px}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.report-header h2{font-size:20px;font-weight:600;color:#1a1a2e;margin:0}.report-period,.report-count{font-size:13px;color:#64748b;background:#f8fafc;padding:6px 12px;border-radius:6px}.empty-report{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#94a3b8;text-align:center}.empty-report svg{margin-bottom:16px;opacity:.5}.pnl-report{max-width:600px}.pnl-section{margin-bottom:24px}.pnl-section h3{font-size:14px;font-weight:600;color:#64748b;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.pnl-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border-radius:8px;margin-bottom:8px;font-size:15px;color:#334155}.pnl-row .amount{font-weight:600;font-family:SF Mono,Monaco,Consolas,monospace}.pnl-row.total{background:#e2e8f0;font-weight:600}.pnl-section.profit{background:linear-gradient(135deg,#d1fae5,#a7f3d0);padding:20px;border-radius:12px;margin-top:32px}.pnl-row.grand-total{background:transparent;padding:0 0 12px;border-bottom:2px solid #10b981;margin-bottom:12px}.pnl-row.grand-total .profit-amount{font-size:28px;color:#059669}.pnl-row.margin{background:transparent;padding:0}.pnl-row .percentage{font-size:24px;font-weight:700;color:#059669}.data-table{overflow-x:auto}.table-header,.table-row,.table-footer{display:grid;grid-template-columns:2fr 80px 60px 120px 120px 120px 150px;gap:12px;padding:12px 16px;align-items:center}.table-header{background:#f1f5f9;border-radius:8px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.table-row{border-bottom:1px solid #f1f5f9;font-size:14px;color:#334155}.table-row:hover{background:#f8fafc}.table-footer{background:#f8fafc;border-radius:8px;margin-top:8px;font-weight:600;font-size:14px;color:#1a1a2e}.col-name{font-weight:500}.col-rate,.col-orders{text-align:center}.col-amount{text-align:right;font-family:SF Mono,Monaco,Consolas,monospace}.col-amount.positive{color:#10b981}.col-amount.warning{color:#f59e0b}.col-percent{display:flex;align-items:center;gap:8px}.percent-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.percent-fill{height:100%;background:linear-gradient(135deg,#10b981,#059669);border-radius:4px;transition:width .3s}.percent-bar.expense .percent-fill{background:linear-gradient(135deg,#f59e0b,#d97706)}.ar-ap-summary{max-width:500px}.summary-card-large{background:#f8fafc;border-radius:12px;padding:24px;margin-bottom:20px}.summary-card-large .card-stat{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #e2e8f0}.summary-card-large .card-stat:last-child{border-bottom:none}.summary-card-large .stat-label{font-size:14px;color:#64748b}.summary-card-large .stat-value{font-size:20px;font-weight:700;color:#1a1a2e;font-family:SF Mono,Monaco,Consolas,monospace}.summary-card-large .stat-value.positive{color:#10b981}.summary-card-large .stat-value.warning{color:#f59e0b}.status-counts{display:flex;gap:24px;margin-bottom:20px}.status-item{display:flex;align-items:center;gap:8px}.status-dot{width:10px;height:10px;border-radius:50%}.status-dot.unpaid{background:#f59e0b}.status-dot.partial{background:#3b82f6}.status-label{font-size:14px;color:#64748b}.status-count{font-weight:700;color:#1a1a2e;font-size:16px}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.action-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.payments-list-container{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:16px}.payments-list{display:flex;flex-direction:column;gap:12px}.payment-card{background:#f8fafc;border-radius:12px;padding:16px;transition:all .2s}.payment-card:hover{background:#f1f5f9}.payment-main{display:flex;gap:16px}.payment-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.payment-icon.received{background:#d1fae5;color:#059669}.payment-icon.paid{background:#dbeafe;color:#2563eb}.payment-details{flex:1;min-width:0}.payment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.payer-name{font-weight:600;color:#1a1a2e;font-size:16px}.payment-amount{font-size:18px;font-weight:700;color:#10b981;font-family:SF Mono,Monaco,Consolas,monospace}.payment-amount.expense{color:#ef4444}.payment-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:8px}.meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#64748b}.meta-item svg{color:#94a3b8}.payment-memo{font-size:13px;color:#64748b;margin:8px 0 0;padding-top:8px;border-top:1px solid #e2e8f0}.empty-icon{color:#cbd5e1;margin-bottom:16px}.mode-toggle{display:flex;gap:12px;margin-bottom:24px}.mode-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#cbd5e1;background:#f8fafc}.mode-btn.active{border-color:#3b82f6;background:#eff6ff;color:#2563eb}.mode-btn.chargeback.active{border-color:#ef4444;background:#fef2f2;color:#dc2626}.chargeback-form-container{max-width:500px;margin:0 auto}.chargeback-form{background:#fff;border-radius:16px;border:2px solid #fecaca;padding:24px}.chargeback-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #fee2e2}.chargeback-header svg{color:#dc2626}.chargeback-header h2{font-size:20px;font-weight:600;color:#1a1a2e;margin:0}.chargeback-header p{font-size:13px;color:#64748b;margin:4px 0 0}.chargeback-btn{background:linear-gradient(135deg,#ef4444,#dc2626)!important}.chargeback-btn:hover:not(:disabled){box-shadow:0 4px 12px #ef44444d!important}.delete-payment-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;cursor:pointer;transition:all .2s;flex-shrink:0}.delete-payment-btn:hover:not(:disabled){background:#fee2e2;border-color:#f87171}.delete-payment-btn:disabled{opacity:.6;cursor:not-allowed}.payment-layout-v2{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}.invoices-panel-v2{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden}.panel-header-v2{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.panel-header-v2 h2{font-size:18px;font-weight:600;color:#1a1a2e;margin:0}.client-filter{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background:#fff;min-width:180px}.invoice-list-v2{padding:16px;max-height:calc(100vh - 280px);overflow-y:auto;display:flex;flex-direction:column;gap:12px}.empty-state-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#94a3b8}.empty-state-v2 svg{margin-bottom:12px;opacity:.5}.invoice-card-v2{display:flex;gap:16px;padding:16px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s}.invoice-card-v2:hover{background:#f1f5f9;border-color:#cbd5e1}.invoice-card-v2.selected{background:#eff6ff;border-color:#3b82f6}.invoice-checkbox-v2{padding-top:2px}.invoice-checkbox-v2 input{width:20px;height:20px;cursor:pointer;accent-color:#3b82f6}.invoice-content-v2{flex:1;min-width:0}.invoice-wo-number{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.invoice-wo-number svg{color:#64748b;flex-shrink:0}.invoice-wo-number .client-wo{font-size:18px;font-weight:700;color:#1a1a2e;letter-spacing:.5px}.invoice-wo-number .system-wo{font-size:13px;color:#94a3b8;font-weight:500}.invoice-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;margin-left:auto}.invoice-status-badge.paid{background:#d1fae5;color:#059669}.invoice-status-badge.unpaid{background:#fef3c7;color:#d97706}.invoice-client-name{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:500;color:#334155;margin-bottom:6px}.invoice-client-name svg{color:#94a3b8}.invoice-address-v2{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:#64748b;margin-bottom:12px}.invoice-address-v2 svg{color:#94a3b8;flex-shrink:0;margin-top:1px}.invoice-amounts-v2{display:flex;flex-wrap:wrap;gap:16px;padding-top:12px;border-top:1px dashed #e2e8f0}.invoice-amounts-v2 .amount-item{display:flex;flex-direction:column;gap:2px}.invoice-amounts-v2 .amount-label{font-size:11px;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.invoice-amounts-v2 .amount-value{font-size:15px;font-weight:700;color:#334155;font-family:SF Mono,Monaco,Consolas,monospace}.invoice-amounts-v2 .amount-item.paid .amount-value{color:#10b981}.invoice-amounts-v2 .amount-item.balance .amount-value{color:#f59e0b}.invoice-amounts-v2 .amount-item.bill-amt .amount-value{color:#6366f1}.invoice-apply-v2{display:flex;flex-direction:column;align-items:flex-end;gap:4px;padding-left:16px;border-left:2px solid #3b82f6}.invoice-apply-v2 label{font-size:11px;font-weight:600;color:#3b82f6;text-transform:uppercase}.invoice-apply-v2 .apply-input{display:flex;align-items:center;background:#fff;border:2px solid #3b82f6;border-radius:8px;overflow:hidden}.invoice-apply-v2 .apply-input span{padding:8px 8px 8px 12px;color:#3b82f6;font-weight:600}.invoice-apply-v2 .apply-input input{width:100px;padding:8px 12px 8px 0;border:none;font-size:16px;font-weight:700;color:#1a1a2e;text-align:right}.invoice-apply-v2 .apply-input input:focus{outline:none}.payment-form-v2{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:24px;position:sticky;top:24px}.payment-form-v2 h2{font-size:18px;font-weight:600;color:#1a1a2e;margin:0 0 20px;padding-bottom:16px;border-bottom:1px solid #e2e8f0}.payment-summary-v2{background:#f8fafc;border-radius:12px;padding:16px;margin:20px 0}.payment-summary-v2 .summary-line{display:flex;justify-content:space-between;align-items:center;padding:8px 0;color:#64748b;font-size:14px}.payment-summary-v2 .summary-line.total{padding-top:12px;margin-top:8px;border-top:1px dashed #e2e8f0}.payment-summary-v2 .summary-count{font-weight:600;color:#334155;background:#fff;padding:4px 12px;border-radius:6px}.payment-summary-v2 .summary-total{font-size:24px;font-weight:700;color:#1a1a2e;font-family:SF Mono,Monaco,Consolas,monospace}.submit-btn-v2{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.submit-btn-v2:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98159}.submit-btn-v2:disabled{opacity:.6;cursor:not-allowed}.large-input{font-size:18px!important;padding:14px 16px!important;font-weight:600}@media(max-width:1024px){.payment-layout-v2{grid-template-columns:1fr}.payment-form-v2{position:static}}.pending-layout-v2{display:grid;grid-template-columns:1fr 420px;gap:24px;align-items:start}.pending-list-v2{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 200px);overflow-y:auto;padding-right:8px}.pending-card-v2{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s}.pending-card-v2:hover{background:#f8fafc;border-color:#cbd5e1}.pending-card-v2.active{background:#eff6ff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.pending-content{flex:1;min-width:0}.pending-wo-number{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.pending-wo-number svg{color:#6366f1;flex-shrink:0}.pending-wo-number .client-wo{font-size:20px;font-weight:700;color:#1a1a2e;letter-spacing:.5px}.pending-wo-number .system-wo{font-size:13px;color:#94a3b8;font-weight:500}.status-badge-v2{font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;background:#dbeafe;color:#2563eb;text-transform:capitalize;margin-left:auto}.pending-client-v2{font-size:16px;font-weight:600;color:#334155;margin-bottom:6px}.pending-address-v2{display:flex;align-items:flex-start;gap:6px;font-size:14px;color:#64748b;margin-bottom:12px}.pending-address-v2 svg{color:#94a3b8;flex-shrink:0;margin-top:2px}.pending-meta-v2{display:flex;flex-wrap:wrap;gap:16px}.pending-meta-v2 .meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:#94a3b8}.pending-meta-v2 .meta-item svg{color:#cbd5e1}.pending-alert-icon{color:#f59e0b;flex-shrink:0}.edit-panel-v2{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;position:sticky;top:24px}.edit-panel-header{padding:20px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0}.edit-panel-header h3{font-size:14px;font-weight:600;color:#64748b;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.edit-wo-info{display:flex;align-items:center;gap:8px;margin-bottom:4px}.edit-wo-number{font-size:22px;font-weight:700;color:#1a1a2e}.edit-wo-system{font-size:14px;color:#94a3b8}.edit-wo-client{font-size:15px;color:#64748b}.edit-form-v2{padding:24px}.bill-calculation-v2{background:#f8fafc;border-radius:12px;padding:16px;margin:20px 0;border:1px solid #e2e8f0}.calc-header-v2{display:flex;align-items:center;gap:8px;font-size:13px;color:#64748b;margin-bottom:8px}.calc-header-v2 svg{color:#94a3b8}.calc-result-v2{font-size:28px;font-weight:700;color:#6366f1;margin-bottom:12px;font-family:SF Mono,Monaco,Consolas,monospace}.override-toggle-v2{display:flex;align-items:center;gap:8px;font-size:13px;color:#64748b;cursor:pointer}.override-toggle-v2 input{width:16px;height:16px;accent-color:#6366f1}.profit-preview-v2{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:12px;padding:16px;margin:20px 0;border:1px solid #a7f3d0}.profit-line{display:flex;justify-content:space-between;padding:8px 0;font-size:15px;color:#475569}.profit-line .bill-amount{color:#dc2626}.profit-line.total{border-top:2px dashed #a7f3d0;margin-top:8px;padding-top:12px;font-weight:600}.profit-line .profit-value{font-size:22px;font-weight:700;color:#059669;font-family:SF Mono,Monaco,Consolas,monospace}.panel-placeholder-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;color:#cbd5e1;text-align:center}.panel-placeholder-v2 svg{margin-bottom:16px;opacity:.4}.panel-placeholder-v2 p{font-size:15px;color:#94a3b8}@media(max-width:1024px){.pending-layout-v2{grid-template-columns:1fr}.edit-panel-v2{position:static}.pending-list-v2{max-height:400px}}@media(max-width:1024px){.table-header,.table-row,.table-footer{grid-template-columns:1.5fr 60px 50px 100px 100px 100px 120px;font-size:13px}}@media(max-width:768px){.payment-layout,.pending-layout{grid-template-columns:1fr}.report-tabs{flex-wrap:nowrap;padding:12px}.report-tabs .tab{padding:8px 12px;font-size:13px}.data-table{font-size:12px}.table-header,.table-row,.table-footer{grid-template-columns:1fr;gap:4px}}@media(max-width:768px){.accounting-header{flex-direction:column;align-items:flex-start}.accounting-header .header-actions{width:100%}.accounting-header .btn{flex:1;justify-content:center}.summary-grid,.recent-activity{grid-template-columns:1fr}}.report-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background:#fff;min-width:140px}.date-input{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155}.search-box{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-width:250px}.search-box input{border:none;background:transparent;font-size:14px;flex:1;outline:none}.search-box svg{color:#94a3b8}.search-box-inline{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1}.search-box-inline input{border:none;background:transparent;font-size:14px;flex:1;outline:none}.search-box-inline svg{color:#94a3b8}.filter-row-v2{display:flex;gap:12px;flex:1}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:500;color:#475569;cursor:pointer;transition:all .2s}.export-btn:hover{background:#f8fafc;border-color:#cbd5e1}.export-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.export-btn.primary:hover{background:#2563eb;border-color:#2563eb}.total-card.highlight-warning{background:#fef3c7;border-color:#f59e0b}.total-card.highlight-warning .total-label{color:#92400e;font-weight:600}.total-card.highlight-positive{background:#d1fae5;border-color:#10b981}.total-card.highlight-positive .total-label{color:#065f46;font-weight:600}.payroll-card.received-card .payroll-amount .amount{color:#10b981}.report-table .bold{font-weight:700}.report-totals{display:flex;gap:16px;margin-bottom:24px;flex-wrap:wrap}.total-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px 24px;display:flex;flex-direction:column;gap:4px;min-width:160px}.total-label{font-size:13px;color:#64748b}.total-value{font-size:22px;font-weight:700;color:#1a1a2e;font-family:SF Mono,Monaco,Consolas,monospace}.total-value.positive{color:#10b981}.total-value.warning{color:#f59e0b}.report-table-container{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px}.report-table{width:100%;border-collapse:collapse;font-size:14px}.report-table th{background:#f8fafc;padding:12px 16px;text-align:left;font-weight:600;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap}.report-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;color:#334155}.report-table tbody tr:hover{background:#f8fafc}.report-table .text-right{text-align:right}.report-table .text-center{text-align:center}.report-table .mono{font-family:SF Mono,Monaco,Consolas,monospace}.report-table .positive{color:#10b981}.report-table .warning{color:#f59e0b}.report-table .danger{color:#ef4444}.report-table .wo-cell{display:flex;flex-direction:column;gap:2px}.report-table .wo-cell .client-wo{font-weight:600;color:#1a1a2e}.report-table .wo-cell .system-wo{font-size:12px;color:#94a3b8}.report-table .address-cell{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.report-table .customer-name{font-weight:500}.report-table .status-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:11px;font-weight:600;text-transform:capitalize}.report-table .status-badge.paid{background:#d1fae5;color:#059669}.report-table .status-badge.unpaid{background:#fef3c7;color:#d97706}.report-table .status-badge.partial{background:#dbeafe;color:#2563eb}.report-table .margin-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600}.report-table .margin-badge.good{background:#d1fae5;color:#059669}.report-table .margin-badge.ok{background:#fef3c7;color:#d97706}.report-table .margin-badge.low{background:#fee2e2;color:#dc2626}.edit-input{width:100px;padding:6px 8px;border:2px solid #3b82f6;border-radius:6px;font-size:14px;font-weight:600;text-align:right}.edit-input:focus{outline:none}.edit-actions{display:flex;gap:6px}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.icon-btn.edit{background:#f1f5f9;color:#64748b}.icon-btn.edit:hover{background:#e2e8f0;color:#334155}.icon-btn.save{background:#d1fae5;color:#059669}.icon-btn.save:hover{background:#a7f3d0}.icon-btn.cancel{background:#fee2e2;color:#dc2626}.icon-btn.cancel:hover{background:#fecaca}.report-note{font-size:13px;color:#64748b;margin-bottom:16px;padding:12px;background:#f8fafc;border-radius:8px;border-left:3px solid #3b82f6}.pnl-row.sub{padding-left:32px;background:transparent;font-size:13px;color:#64748b}.pnl-row .collected{color:#10b981}.pnl-row.info{background:transparent;padding:0;font-size:13px;color:#64748b;margin-top:8px}.payroll-list{display:flex;flex-direction:column;gap:12px}.payroll-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.payroll-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;cursor:pointer;transition:background .2s}.payroll-header:hover{background:#f8fafc}.payroll-info{display:flex;flex-direction:column;gap:4px}.payroll-info .payee-name{font-size:16px;font-weight:600;color:#1a1a2e}.payroll-info .payment-meta{font-size:13px;color:#64748b}.payroll-amount{display:flex;align-items:center;gap:12px}.payroll-amount .amount{font-size:18px;font-weight:700;color:#1a1a2e;font-family:SF Mono,Monaco,Consolas,monospace}.expand-icon{color:#94a3b8;transition:transform .2s}.expand-icon.expanded{transform:rotate(180deg)}.payroll-details{padding:0 20px 20px;border-top:1px solid #e2e8f0;background:#f8fafc}.payroll-details .details-table{width:100%;border-collapse:collapse;margin-top:12px}.payroll-details .details-table th{padding:8px 12px;text-align:left;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;background:#e2e8f0;border-radius:4px}.payroll-details .details-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid #e2e8f0}.payment-card-v2{background:#fff;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s}.payment-card-v2.expanded{border-color:#3b82f6}.payment-card-v2 .payment-main{display:flex;gap:16px;padding:16px;cursor:pointer}.payment-card-v2 .payment-main:hover{background:#f8fafc}.payment-actions{display:flex;align-items:flex-start;gap:8px}.expand-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer}.expand-btn:hover{background:#e2e8f0}.payment-applications{padding:16px 20px;background:#f8fafc;border-top:1px solid #e2e8f0}.payment-applications h4{font-size:13px;font-weight:600;color:#475569;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.applications-table{width:100%;border-collapse:collapse}.applications-table th{padding:8px 12px;text-align:left;font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;background:#e2e8f0;border-radius:4px}.applications-table td{padding:10px 12px;font-size:13px;border-bottom:1px solid #e2e8f0}.applications-table .wo-cell{display:flex;align-items:center;gap:8px}.applications-table .wo-cell svg{color:#94a3b8}.applications-table .wo-cell .client-wo{font-weight:600;color:#1a1a2e}.applications-table .wo-cell .system-wo{font-size:11px;color:#94a3b8}.applications-table .address-cell{display:flex;align-items:center;gap:6px;color:#64748b}.applications-table .address-cell svg{color:#94a3b8;flex-shrink:0}.applications-table .text-right{text-align:right}.applications-table .mono{font-family:SF Mono,Monaco,Consolas,monospace}.loading-inline{display:flex;align-items:center;gap:12px;padding:20px;color:#64748b}.no-details{padding:20px;text-align:center;color:#94a3b8}.payments-toolbar{display:flex;gap:12px;margin-bottom:20px}.payments-toolbar .search-box{flex:1;max-width:400px}@media print{.page-header,.report-tabs,.report-filters,.export-btn,.back-btn{display:none!important}.report-content{border:none}.report-table{font-size:11px}.report-table th,.report-table td{padding:8px}}.basis-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:4px;gap:4px}.basis-toggle .toggle-btn{padding:8px 16px;border:none;background:transparent;font-size:13px;font-weight:500;color:#64748b;border-radius:6px;cursor:pointer;transition:all .2s}.basis-toggle .toggle-btn.active{background:#fff;color:#1a1a2e;box-shadow:0 1px 3px #0000001a}.basis-toggle .toggle-btn:hover:not(.active){color:#334155}.basis-note{font-size:13px;color:#64748b;padding:12px 16px;background:#f8fafc;border-radius:8px;margin-bottom:20px;border-left:3px solid #3b82f6}.pnl-row .negative{color:#ef4444}.pnl-row .positive{color:#10b981}.chargebacks-section{margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0}.chargebacks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.chargebacks-header h3{font-size:14px;font-weight:600;color:#475569;margin:0}.add-chargeback-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.add-chargeback-btn:hover{background:#fee2e2}.chargeback-form{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:12px}.chargeback-form .form-row{display:flex;gap:12px}.chargeback-form .form-group{margin-bottom:8px;flex:1}.chargeback-form .form-group label{display:block;font-size:11px;font-weight:600;color:#64748b;margin-bottom:4px;text-transform:uppercase}.chargeback-form .form-group input{width:100%;padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px}.amount-input-small{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.amount-input-small span{padding:8px 10px;background:#f1f5f9;color:#64748b;font-size:13px}.amount-input-small input{border:none;padding:8px 10px;font-size:13px;width:100%;outline:none}.chargeback-actions{display:flex;gap:8px;margin-top:8px}.chargeback-actions .btn-add{padding:6px 16px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer}.chargeback-actions .btn-add:hover{background:#059669}.chargeback-actions .btn-cancel{padding:6px 16px;background:#f1f5f9;color:#64748b;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer}.chargeback-actions .btn-cancel:hover{background:#e2e8f0}.chargebacks-list{display:flex;flex-direction:column;gap:8px}.chargeback-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.chargeback-item .cb-info{display:flex;flex-direction:column;gap:2px}.chargeback-item .cb-wo{font-size:13px;font-weight:600;color:#991b1b}.chargeback-item .cb-reason{font-size:11px;color:#b91c1c}.chargeback-item .cb-amount{display:flex;align-items:center;gap:10px}.chargeback-item .cb-amount .negative{font-size:14px;font-weight:700;color:#dc2626;font-family:SF Mono,Monaco,Consolas,monospace}.chargeback-item .remove-cb{width:24px;height:24px;background:#fecaca;border:none;border-radius:4px;color:#991b1b;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.chargeback-item .remove-cb:hover{background:#fca5a5}.payment-summary-v2 .summary-line .summary-amount{font-family:SF Mono,Monaco,Consolas,monospace;color:#1a1a2e}.payment-summary-v2 .summary-line.chargebacks{background:#fef2f2;border-radius:6px;padding:8px 12px;margin:8px 0}.payment-summary-v2 .summary-line.chargebacks span{color:#991b1b}.payment-summary-v2 .summary-line .summary-negative{font-family:SF Mono,Monaco,Consolas,monospace;font-weight:700;color:#dc2626}.load-more-container{display:flex;justify-content:center;padding:20px 0;border-top:1px solid #e2e8f0;margin-top:8px}.load-more-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d}.load-more-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.load-more-btn:disabled{background:#94a3b8;cursor:not-allowed;box-shadow:none}.report-table tbody tr:only-child td[colspan]{text-align:center;padding:40px;color:#64748b;font-style:italic}.empty-state{text-align:center;padding:60px 20px!important;color:#64748b;font-style:italic;font-size:14px;background:#f8fafc}.sort-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;padding-right:32px;min-width:160px;font-weight:500;color:#334155;border:1px solid #cbd5e1;transition:all .2s ease}.sort-select:hover{border-color:#3b82f6}.sort-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.public-share-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.share-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.share-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;text-align:center}.error-icon{font-size:64px;margin-bottom:16px}.share-error h2{font-size:24px;color:#1e293b;margin-bottom:8px}.share-error p{color:#64748b;margin-bottom:32px}.hayvee-branding{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:32px;border-top:1px solid #e2e8f0}.hayvee-branding .hayvee-logo{height:32px}.hayvee-branding p{font-size:14px;color:#94a3b8;margin:0}.share-header{background:#fff;padding:16px 24px;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100}.header-branding{display:flex;align-items:center;gap:16px;max-width:1200px;margin:0 auto}.company-logo{height:48px;max-width:200px;object-fit:contain}.company-name-badge{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700}.header-text h1{font-size:20px;color:#1e293b;margin:0 0 4px}.powered-by{font-size:12px;color:#94a3b8}.powered-by strong{color:#3b82f6}.public-wo-info{max-width:1200px;margin:24px auto;padding:0 24px}.public-wo-info-grid{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 6px #0000000d;display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:768px){.public-wo-info-grid{grid-template-columns:1fr}}.public-wo-number{font-size:14px;color:#3b82f6;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.public-wo-title{font-size:28px;color:#1e293b;margin:0 0 12px}.public-wo-status{display:inline-block;padding:6px 16px;border-radius:20px;font-size:14px;font-weight:500;text-transform:capitalize}.public-wo-status.status-complete{background:#d1fae5;color:#065f46}.public-wo-status.status-submitted{background:#e0e7ff;color:#3730a3}.public-wo-status.status-paid{background:#cffafe;color:#0e7490}.public-wo-status.status-in_progress{background:#fef3c7;color:#92400e}.public-wo-status.status-hold{background:#fff7ed;color:#ea580c}.public-wo-status.status-assigned{background:#dbeafe;color:#1e40af}.public-wo-status.status-rework{background:#fee2e2;color:#991b1b}.public-wo-info-details{display:flex;flex-direction:column;gap:16px}.public-info-item{display:flex;flex-direction:column;gap:4px}.public-info-label{font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.public-info-value{font-size:16px;color:#1e293b;line-height:1.4}.photo-gallery{max-width:1200px;margin:24px auto;padding:0 24px}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.gallery-header h3{font-size:20px;color:#1e293b;margin:0}.gallery-actions{display:flex;gap:12px}.download-dropdown{position:relative}.btn-download{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-download:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.btn-download:disabled{opacity:.7;cursor:not-allowed;transform:none}.download-options{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;overflow:hidden;display:none;z-index:10;min-width:180px}.download-dropdown:hover .download-options{display:block}.download-options button{display:block;width:100%;padding:12px 16px;text-align:left;background:none;border:none;cursor:pointer;font-size:14px;color:#1e293b;transition:background .2s}.download-options button:hover{background:#f1f5f9}.category-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.category-btn{padding:8px 16px;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:14px;color:#64748b;cursor:pointer;transition:all .2s}.category-btn:hover{border-color:#3b82f6;color:#3b82f6}.category-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}@media(max-width:600px){.photo-grid{grid-template-columns:repeat(2,1fr);gap:8px}}.photo-card{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;background:#f1f5f9}.photo-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.photo-card:hover img{transform:scale(1.05)}.photo-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:flex-start;justify-content:flex-end;padding:12px;gap:8px;opacity:0;transition:opacity .2s}.photo-card:hover .photo-overlay{opacity:1}.overlay-btn{width:36px;height:36px;border-radius:50%;background:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1e293b;transition:transform .2s}.overlay-btn:hover{transform:scale(1.1)}.photo-category-badge{position:absolute;bottom:8px;left:8px;background:#000000b3;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px}.no-photos{text-align:center;padding:48px;color:#94a3b8}.lightbox{position:fixed;inset:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.lightbox-content{max-width:90%;max-height:80vh;display:flex;align-items:center;justify-content:center}.lightbox-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;background:#fff;border:none;border-radius:50%;cursor:pointer;color:#1e293b;display:flex;align-items:center;justify-content:center}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;background:#ffffffe6;border:none;border-radius:50%;cursor:pointer;color:#1e293b;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-nav:hover{background:#fff}.lightbox-nav.prev{left:24px}.lightbox-nav.next{right:24px}.lightbox-actions{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;gap:12px}.lightbox-actions button{background:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .2s;display:flex;align-items:center;gap:8px}.lightbox-actions button:hover{transform:translateY(-2px)}.lightbox-counter{position:absolute;bottom:24px;right:24px;background:#ffffffe6;color:#1e293b;padding:8px 16px;border-radius:20px;font-size:14px}.exif-modal-overlay{position:fixed;inset:0;background:#00000080;z-index:1001;display:flex;align-items:center;justify-content:center;padding:24px}.exif-modal{background:#fff;border-radius:16px;max-width:400px;width:100%;overflow:hidden;box-shadow:0 20px 40px #0000004d}.exif-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0}.exif-header h3{margin:0;font-size:18px;color:#1e293b}.close-btn{width:32px;height:32px;background:#f1f5f9;border:none;border-radius:50%;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center}.exif-content{padding:20px}.exif-item{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid #f1f5f9}.exif-item:last-child{border-bottom:none}.exif-label{font-size:12px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.exif-value{font-size:15px;color:#1e293b}.map-link{display:inline-flex;align-items:center;gap:4px;margin-left:8px;color:#3b82f6;text-decoration:none;font-size:13px}.map-link:hover{text-decoration:underline}.share-footer{background:#1e293b;padding:32px 24px;margin-top:48px}.footer-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}.hayvee-promo p{color:#94a3b8;margin:0 0 8px;font-size:14px}.hayvee-promo strong{color:#fff}.learn-more{color:#3b82f6;text-decoration:none;font-size:14px;font-weight:500}.learn-more:hover{text-decoration:underline}.expiry-notice p{color:#64748b;font-size:13px;margin:0}:root{--primary: #F97316;--primary-dark: #EA580C;--secondary: #3B82F6;--secondary-dark: #2563EB;--success: #10B981;--warning: #F59E0B;--error: #EF4444;--info: #06B6D4;--background: #f0f2f5;--background-secondary: #e8eaed;--surface: #FFFFFF;--surface-elevated: #FFFFFF;--border: #dce0e5;--border-light: #e8eaed;--text: #1E293B;--text-secondary: #64748B;--text-tertiary: #94A3B8;--text-light: #FFFFFF;--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .08);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .08);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .12), 0 4px 6px -4px rgb(0 0 0 / .08);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;font-size:14px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--background);color:var(--text);line-height:1.4;font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}h4{font-size:1rem}input,select,textarea,button{font-size:13px}.card,.panel,.modal-content{padding:var(--spacing-md)}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--border-light)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-weight:600;font-size:14px;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:var(--text-light)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--background)}.btn-danger{background:var(--error);color:var(--text-light)}.btn-danger:hover{background:#dc2626}.btn-success{background:linear-gradient(135deg,var(--success),#059669);color:var(--text-light)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--text-light)}.btn-warning:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-sm{padding:8px 14px;font-size:13px;gap:6px}.btn-sm svg{width:16px;height:16px}.card{background:var(--surface);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-md)}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;padding:12px 16px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);font-size:15px;color:var(--text);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #f973161a}.form-input::placeholder{color:var(--text-tertiary)}.form-input.error{border-color:var(--error)}.form-error{font-size:12px;color:var(--error);margin-top:4px}.status-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;text-transform:capitalize}.status-unassigned{background:#fef3c7;color:#92400e}.status-assigned{background:#dbeafe;color:#1e40af}.status-in_progress{background:#fed7aa;color:#c2410c}.status-hold{background:#fff7ed;color:#ea580c}.status-complete{background:#d1fae5;color:#065f46}.status-rework{background:#fee2e2;color:#991b1b}.status-submitted{background:#e0e7ff;color:#3730a3}.status-paid{background:#cffafe;color:#0e7490}.status-cancelled{background:#e5e7eb;color:#4b5563}.priority-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;text-transform:capitalize}.priority-low{background:#e0e7ff;color:#3730a3}.priority-medium{background:#fef3c7;color:#92400e}.priority-high{background:#fed7aa;color:#c2410c}.priority-urgent{background:#fee2e2;color:#991b1b}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-spin{animation:spin 1s linear infinite}.animate-spin>*:not(svg):not(path):not(circle):not(line){animation:none!important;transform:none!important}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-slideUp{animation:slideUp .3s ease-out}.app{min-height:100vh;display:flex;flex-direction:column}
