@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";.mobile-only{display:none!important}.desktop-only{display:block!important}.tablet-only{display:none!important}@media(min-width:768px)and (max-width:1023px){.tablet-only{display:block!important}}.mobile-only-flex{display:none!important}.desktop-only-flex{display:flex!important}@media(max-width:767px){.mobile-only-flex{display:flex!important}.desktop-only-flex{display:none!important}}@media(max-width:767px){.page-header{flex-direction:row!important;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);padding:0}.page-header-left{flex:1;min-width:0;flex-direction:row!important;align-items:center;gap:var(--spacing-3)}.page-header-icon{width:36px;height:36px;flex-shrink:0}.page-header-icon svg{width:18px;height:18px}.page-title{font-size:1.125rem!important;line-height:1.3;margin:0!important}.page-subtitle{display:none}.page-header-right{flex-shrink:0}.page-header-right .btn{padding:var(--spacing-2) var(--spacing-3);font-size:.75rem}}@media(max-width:767px){.filters-bar{flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.search-input-wrapper{width:100%;max-width:none}.search-input,.filter-select{width:100%;font-size:16px!important;padding:var(--spacing-3);min-height:44px}.filters-horizontal{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:var(--spacing-2);padding-bottom:var(--spacing-2);-webkit-overflow-scrolling:touch;scrollbar-width:none}.filters-horizontal::-webkit-scrollbar{display:none}.filters-horizontal .filter-select{flex-shrink:0;width:auto;min-width:120px}}.mobile-list{display:flex;flex-direction:column;gap:12px}.mobile-list-item{background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;display:flex;align-items:flex-start;gap:12px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.mobile-list-item.clickable{cursor:pointer}.mobile-list-item.clickable:active{transform:scale(.98);background:var(--slate-50)}.mobile-list-avatar{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:14px;color:#fff;background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-600) 100%)}.mobile-list-avatar.blue{background:linear-gradient(135deg,var(--info-400) 0%,var(--info-600) 100%)}.mobile-list-avatar.orange{background:linear-gradient(135deg,var(--warning-400) 0%,var(--warning-600) 100%)}.mobile-list-avatar.red{background:linear-gradient(135deg,var(--error-400) 0%,var(--error-600) 100%)}.mobile-list-avatar.slate{background:linear-gradient(135deg,var(--slate-400) 0%,var(--slate-600) 100%)}.mobile-list-content{flex:1;min-width:0}.mobile-list-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.mobile-list-title{font-size:15px;font-weight:600;color:var(--slate-900);margin:0;line-height:1.3}.mobile-list-subtitle{font-size:13px;color:var(--slate-500);margin:0 0 8px;line-height:1.4}.mobile-list-meta{display:flex;flex-wrap:wrap;gap:12px}.mobile-list-meta-item{display:flex;flex-direction:column;gap:2px}.mobile-list-meta-label{font-size:10px;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.05em}.mobile-list-meta-value{font-size:13px;font-weight:600;color:var(--slate-700)}.mobile-list-arrow{color:var(--slate-400);flex-shrink:0;align-self:center}.mobile-badge{display:inline-flex;padding:3px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border-radius:6px}.mobile-badge.success{background:var(--success-50);color:var(--success-700)}.mobile-badge.warning{background:var(--warning-50);color:var(--warning-600)}.mobile-badge.error{background:var(--error-50);color:var(--error-600)}.mobile-badge.info{background:var(--info-50);color:var(--info-600)}.mobile-badge.gray{background:var(--slate-100);color:var(--slate-600)}.mobile-stat{background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;display:flex;align-items:center;gap:12px}.mobile-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-stat-icon.emerald{background:var(--primary-100);color:var(--primary-600)}.mobile-stat-icon.blue{background:var(--info-100);color:var(--info-600)}.mobile-stat-icon.orange{background:var(--warning-100);color:var(--warning-600)}.mobile-stat-icon.red{background:var(--error-100);color:var(--error-600)}.mobile-stat-icon.slate{background:var(--slate-100);color:var(--slate-600)}.mobile-stat-content{flex:1;min-width:0}.mobile-stat-value{font-size:20px;font-weight:800;color:var(--slate-900);line-height:1;margin-bottom:4px}.mobile-stat-label{font-size:11px;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.03em}@media(max-width:767px){.card{border-radius:var(--radius-xl);margin-left:-12px;margin-right:-12px;width:calc(100% + 24px);border-left:none;border-right:none}.card-header{padding:var(--spacing-3) var(--spacing-4)}.card-title{font-size:.6875rem}.card-content{padding:var(--spacing-3) var(--spacing-4)}.card-footer{padding:var(--spacing-3) var(--spacing-4);flex-direction:column;gap:var(--spacing-2)}.card-footer .btn{width:100%;justify-content:center}}@media(max-width:767px){.table-container,.data-table,table.data-table{display:none!important}}@media(max-width:767px){.empty-state{padding:var(--spacing-8);margin:0 -12px;border-radius:0;border-left:none;border-right:none}.empty-state-icon{width:48px;height:48px}.empty-state-title{font-size:1rem}.error-state{padding:var(--spacing-6)}}@media(max-width:767px){.drawer{width:100%!important;max-width:100%!important;border-radius:20px 20px 0 0;top:auto!important;bottom:0;max-height:90vh;max-height:90dvh;animation:mobileSlideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes mobileSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer-header{padding:var(--spacing-3) var(--spacing-4);border-radius:20px 20px 0 0}.drawer-body{padding:var(--spacing-4);max-height:calc(90vh - 140px);max-height:calc(90dvh - 140px)}.drawer-footer{padding:var(--spacing-3) var(--spacing-4);padding-bottom:calc(var(--spacing-3) + env(safe-area-inset-bottom));flex-direction:column-reverse}.drawer-footer .btn{width:100%}}@media(max-width:767px){.form-grid,.form-row{grid-template-columns:1fr!important;gap:var(--spacing-3)}.form-input,.form-select,.form-textarea,input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{font-size:16px!important;min-height:48px;padding:var(--spacing-3)}.form-actions{flex-direction:column-reverse;gap:var(--spacing-2);margin-top:var(--spacing-4)}.form-actions .btn{width:100%;justify-content:center}}@media(max-width:767px){.tabs-container{margin:0 -12px;padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs-container::-webkit-scrollbar{display:none}.tabs{flex-wrap:nowrap}.tab{padding:var(--spacing-2) var(--spacing-3);font-size:.8125rem;white-space:nowrap}}@media(max-width:767px){.quick-actions-grid{grid-template-columns:repeat(4,1fr)!important;gap:var(--spacing-2)}.quick-action{padding:var(--spacing-2);flex-direction:column;gap:var(--spacing-1)}.quick-action-icon{width:36px;height:36px}.quick-action span{font-size:.625rem;text-align:center}}.mobile-skeleton{background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-200) 50%,var(--slate-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.mobile-skeleton-card{background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;margin-bottom:12px}.mobile-skeleton-line{height:14px;background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-200) 50%,var(--slate-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px;margin-bottom:8px}.mobile-skeleton-line.short{width:60%}.mobile-skeleton-line.tiny{width:40%;height:10px}@media(max-width:767px){button,.btn,a.btn,[role=button]{min-height:44px}.btn:active:not(:disabled),button:active:not(:disabled){transform:scale(.97);opacity:.9}}@media(hover:none){.btn:hover,button:hover,.card:hover,.table-row-clickable:hover{transform:none;box-shadow:inherit}}@media(max-height:500px)and (orientation:landscape){.mobile-stats-grid{grid-template-columns:repeat(4,1fr)}.mobile-stat{padding:12px}.mobile-stat-value{font-size:16px}}:root{--primary-50: #ecfdf5;--primary-100: #d1fae5;--primary-200: #a7f3d0;--primary-300: #6ee7b7;--primary-400: #34d399;--primary-500: #10b981;--primary-600: #059669;--primary-700: #047857;--primary-800: #065f46;--primary-900: #064e3b;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success-50: #ecfdf5;--success-500: #10b981;--success-600: #059669;--success-700: #047857;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--info-50: #eff6ff;--info-100: #dbeafe;--info-500: #3b82f6;--info-600: #2563eb;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--sidebar-width: 280px;--sidebar-collapsed-width: 80px;--header-height: 72px;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--slate-50);color:var(--slate-900);line-height:1.5;overflow-x:hidden}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--slate-700);border-radius:10px}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}a{color:var(--primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);font-size:.875rem;font-weight:600;border-radius:var(--radius-xl);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-transform:uppercase;letter-spacing:.05em}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--primary-500);color:var(--slate-900);box-shadow:0 10px 20px -10px var(--primary-500)}.btn-primary:hover:not(:disabled){background-color:var(--primary-400);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background-color:#fff;color:var(--slate-700);border-color:var(--slate-200)}.btn-secondary:hover:not(:disabled){background-color:var(--slate-50);border-color:var(--slate-300)}.btn-danger{background-color:var(--error-500);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--error-600)}.btn-ghost{background-color:transparent;color:var(--slate-600)}.btn-ghost:hover:not(:disabled){background-color:var(--slate-100)}.btn-sm{padding:var(--spacing-2) var(--spacing-3);font-size:.75rem}.btn-lg{padding:var(--spacing-4) var(--spacing-6);font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.form-label{font-size:.625rem;font-weight:800;color:var(--slate-500);text-transform:uppercase;letter-spacing:.1em;margin-left:var(--spacing-1)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-4);font-size:.875rem;font-weight:500;border:1px solid var(--slate-200);border-radius:var(--radius-2xl);background-color:#fff;transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-input::placeholder{color:var(--slate-400)}.form-error{font-size:.75rem;color:var(--error-500)}.card{background-color:#fff;border-radius:var(--radius-2xl);border:1px solid var(--slate-100);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--slate-100)}.card-title{font-size:.625rem;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.15em}.card-content{padding:var(--spacing-6)}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--slate-100);background-color:var(--slate-50);border-radius:0 0 var(--radius-2xl) var(--radius-2xl)}.table{width:100%;border-collapse:collapse;font-size:.875rem}.table th{text-align:left;padding:var(--spacing-3) var(--spacing-4);font-size:.625rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--slate-400);background-color:var(--slate-50);border-bottom:1px solid var(--slate-200)}.table td{padding:var(--spacing-4);border-bottom:1px solid var(--slate-100);color:var(--slate-700)}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--slate-50)}.badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:20px;white-space:nowrap}.badge-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;box-shadow:0 1px 2px #10b98126}.badge-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309;box-shadow:0 1px 2px #f59e0b26}.badge-error{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c;box-shadow:0 1px 2px #ef444426}.badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;box-shadow:0 1px 2px #3b82f626}.badge-primary{background:linear-gradient(135deg,#d1fae5,#6ee7b7);color:#047857;box-shadow:0 1px 2px #10b98133}.badge-secondary,.badge-gray{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;box-shadow:0 1px 2px #64748b1a}.status-PLANNING,.status-DRAFT{background-color:var(--slate-100);color:var(--slate-700)}.status-ACTIVE,.status-APPROVED{background-color:var(--primary-50);color:var(--primary-700)}.status-ON_HOLD,.status-PENDING_APPROVAL,.status-SUBMITTED{background-color:var(--warning-50);color:var(--warning-600)}.status-COMPLETED{background-color:var(--info-50);color:var(--info-700)}.status-CANCELLED,.status-REJECTED{background-color:var(--error-50);color:var(--error-600)}.loader{display:inline-block;width:20px;height:20px;border:2px solid var(--slate-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-6)}.page-title{font-size:1.5rem;font-weight:800;color:var(--slate-900)}.page-subtitle{font-size:.875rem;color:var(--slate-500);margin-top:var(--spacing-1)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);text-align:center}.empty-state-icon{width:64px;height:64px;color:var(--slate-300);margin-bottom:var(--spacing-4)}.empty-state-title{font-size:1rem;font-weight:600;color:var(--slate-900);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:.875rem;color:var(--slate-500);margin-bottom:var(--spacing-4)}.grid{display:grid;gap:var(--spacing-4)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.justify-center{justify-content:center}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-6{margin-bottom:var(--spacing-6)}.p-4{padding:var(--spacing-4)}.p-6{padding:var(--spacing-6)}.text-xs{font-size:.75rem}.text-2xs{font-size:.625rem}.text-slate-400{color:var(--slate-400)}.text-slate-500{color:var(--slate-500)}.text-slate-600{color:var(--slate-600)}.text-slate-800{color:var(--slate-800)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-black{font-weight:900}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.leading-none{line-height:1}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stat-card{background:#fff;border-radius:var(--radius-2xl);border:1px solid var(--slate-100);padding:var(--spacing-5);transition:all var(--transition-normal)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-3)}.stat-card-icon.emerald{background-color:var(--primary-100);color:var(--primary-600)}.stat-card-icon.blue{background-color:var(--info-100);color:var(--info-600)}.stat-card-icon.orange{background-color:var(--warning-100);color:var(--warning-600)}.stat-card-icon.slate{background-color:var(--slate-100);color:var(--slate-600)}.stat-card-label{font-size:.625rem;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.15em;margin-bottom:var(--spacing-1)}.stat-card-value{font-size:1.75rem;font-weight:800;color:var(--slate-900);line-height:1}.stat-card-change{font-size:.75rem;font-weight:600;margin-top:var(--spacing-2)}.stat-card-change.positive{color:var(--primary-500)}.stat-card-change.negative{color:var(--error-500)}.sidebar-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:40;opacity:0;animation:fadeIn .25s ease forwards}@keyframes fadeIn{to{opacity:1}}@media(min-width:1024px){.sidebar-overlay{display:none}}.sidebar{position:fixed;inset-y:0;left:0;z-index:50;width:72px;background:linear-gradient(180deg,#0f172afa,#0f172af2,#1e293bfa);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:#fff;display:flex;flex-direction:column;transform:translate(-100%);transition:all .35s cubic-bezier(.4,0,.2,1);overflow:hidden;border-right:1px solid rgba(255,255,255,.05);box-shadow:4px 0 24px #0000004d,inset -1px 0 #ffffff05}@media(min-width:1024px){.sidebar{transform:translate(0)}.sidebar:hover{width:260px;box-shadow:8px 0 40px #0006,inset -1px 0 #ffffff0d}}@media(max-width:1023px){.sidebar{width:280px}.sidebar.open{transform:translate(0);box-shadow:10px 0 50px #00000080}}@media(min-width:1024px){.sidebar-logo-text,.sidebar-link span,.sidebar-section-title,.sidebar-user-info{opacity:0;visibility:hidden;width:0;overflow:hidden;transition:all .25s ease}.sidebar:hover .sidebar-logo-text,.sidebar:hover .sidebar-link span,.sidebar:hover .sidebar-section-title,.sidebar:hover .sidebar-user-info{opacity:1;visibility:visible;width:auto}}.sidebar-header{padding:1.25rem;display:flex;align-items:center;justify-content:center;min-height:72px;border-bottom:1px solid rgba(255,255,255,.06);position:relative;background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 100%)}@media(min-width:1024px){.sidebar:hover .sidebar-header{justify-content:flex-start;padding:1.25rem 1.5rem}}.sidebar-logo{display:flex;align-items:center;gap:.875rem}.sidebar-logo-icon{width:42px;height:42px;min-width:42px;background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-600) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.375rem;font-weight:800;color:#fff;box-shadow:0 8px 24px -4px #10b98166,0 0 0 1px #ffffff1a inset;transition:all .3s ease}.sidebar:hover .sidebar-logo-icon{transform:scale(1.05);box-shadow:0 12px 32px -4px #10b98180,0 0 0 1px #ffffff26 inset}.sidebar-logo-text{display:flex;flex-direction:column;white-space:nowrap}.sidebar-logo-title{font-size:1.375rem;font-weight:700;letter-spacing:-.03em;line-height:1;background:linear-gradient(135deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo-subtitle{font-size:.6875rem;font-weight:600;color:var(--primary-400);text-transform:uppercase;letter-spacing:.12em;margin-top:3px}.sidebar-close{position:absolute;right:1rem;top:50%;transform:translateY(-50%);padding:.5rem;color:var(--slate-400);background:#ffffff0d;border:1px solid rgba(255,255,255,.08);cursor:pointer;border-radius:10px;transition:all .2s ease;display:none}.sidebar-close:hover{color:#fff;background:#ffffff1a}@media(max-width:1023px){.sidebar-close{display:flex;align-items:center;justify-content:center}}.sidebar-nav{flex:1;padding:.75rem;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:4px;max-height:calc(100vh - 180px)}.sidebar-link{display:flex;align-items:center;gap:.875rem;padding:.75rem;border-radius:12px;font-size:.875rem;font-weight:500;color:#94a3b8e6;text-decoration:none;transition:all .2s ease;white-space:nowrap;min-height:46px;position:relative;overflow:hidden}@media(min-width:1024px){.sidebar-link{justify-content:center}.sidebar:hover .sidebar-link{justify-content:flex-start;padding:.75rem 1rem}}.sidebar-link svg{flex-shrink:0;min-width:20px;transition:all .25s ease}.sidebar-link:hover{background:linear-gradient(90deg,#ffffff14,#ffffff0a);color:#fff}.sidebar-link:hover svg{transform:scale(1.1);color:var(--primary-400)}.sidebar-link.active{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;font-weight:600;box-shadow:0 8px 20px -4px #10b98159,0 0 0 1px #ffffff1a inset}.sidebar-link.active svg{color:#fff;transform:scale(1)}.sidebar-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:24px;background:#fff;border-radius:0 4px 4px 0;box-shadow:0 0 12px #ffffff80}@media(min-width:1024px){.sidebar:not(:hover) .sidebar-link[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) translate(-4px);padding:8px 14px;background:#1e293bf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;font-size:.8125rem;font-weight:500;border-radius:10px;white-space:nowrap;opacity:0;visibility:hidden;pointer-events:none;transition:all .2s ease;z-index:100;box-shadow:0 8px 24px #0006,0 0 0 1px #ffffff14}.sidebar:not(:hover) .sidebar-link[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translateY(-50%) translate(0)}}.sidebar-section{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.sidebar-section-title{font-size:.6875rem;font-weight:700;color:#94a3b899;text-transform:uppercase;letter-spacing:.1em;padding:.5rem .75rem;white-space:nowrap}@media(min-width:1024px){.sidebar:not(:hover) .sidebar-section-title{text-align:center;padding:.5rem}}.sidebar-footer{padding:.75rem;margin-top:auto;border-top:1px solid rgba(255,255,255,.06);background:linear-gradient(0deg,rgba(255,255,255,.02) 0%,transparent 100%)}.sidebar-user{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:14px;transition:all .25s ease}.sidebar-user:hover{background:#ffffff0f;border-color:#ffffff14}@media(min-width:1024px){.sidebar:hover .sidebar-user{justify-content:flex-start}}.sidebar-user-avatar{width:38px;height:38px;min-width:38px;background:linear-gradient(135deg,var(--info-400) 0%,var(--info-600) 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.9375rem;font-weight:700;color:#fff;box-shadow:0 6px 16px -2px #3b82f659,0 0 0 1px #ffffff1a inset;transition:all .3s ease}.sidebar:hover .sidebar-user-avatar{transform:scale(1.05)}.sidebar-user-info{min-width:0;white-space:nowrap}.sidebar-user-name{display:block;font-size:.8125rem;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.sidebar-logout-btn{display:flex;align-items:center;gap:.375rem;margin-top:4px;padding:0;background:none;border:none;font-size:.6875rem;font-weight:600;color:#94a3b8b3;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .2s ease}.sidebar-logout-btn:hover{color:var(--error-400)}.sidebar-logout-btn svg{transition:transform .2s ease}.sidebar-logout-btn:hover svg{transform:translate(-2px)}.lg-hidden{display:block}@media(min-width:1024px){.lg-hidden{display:none}}.sidebar-nav{scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.3) transparent}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent;margin:8px 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:10px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#94a3b880}@media(max-width:767px){.sidebar{width:85vw;max-width:320px;transition:transform .35s cubic-bezier(.32,.72,0,1);padding-bottom:env(safe-area-inset-bottom,0)}.sidebar.open{transform:translate(0)}.sidebar-header{justify-content:flex-start;padding:1.25rem;min-height:64px}.sidebar-logo-text{opacity:1;visibility:visible;width:auto}.sidebar-nav{padding:.75rem;gap:4px;max-height:calc(100vh - 150px - env(safe-area-inset-bottom));max-height:calc(100dvh - 150px - env(safe-area-inset-bottom))}.sidebar-link{justify-content:flex-start;padding:.875rem 1rem;min-height:50px;border-radius:14px}.sidebar-link span{opacity:1;visibility:visible;width:auto}.sidebar-link.active:before{display:none}.sidebar-section-title{opacity:1;visibility:visible;width:auto;padding:.75rem 1rem .5rem}.sidebar-footer{padding:.75rem}.sidebar-user{justify-content:flex-start;padding:1rem}.sidebar-user-info{opacity:1;visibility:visible;width:auto}.sidebar-link:active{transform:scale(.98);opacity:.9}}@media(max-width:359px){.sidebar{width:90vw}.sidebar-link{font-size:.8125rem;padding:.75rem}}@media(min-width:768px)and (max-width:1023px){.sidebar{width:300px}}@media(max-height:500px)and (orientation:landscape){.sidebar-nav{max-height:calc(100vh - 100px)}.sidebar-link{min-height:42px;padding:.5rem 1rem}.sidebar-footer{padding:.5rem}}.sidebar-link{animation:slideIn .4s ease backwards}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.sidebar-nav .sidebar-link:nth-child(1){animation-delay:.02s}.sidebar-nav .sidebar-link:nth-child(2){animation-delay:.04s}.sidebar-nav .sidebar-link:nth-child(3){animation-delay:.06s}.sidebar-nav .sidebar-link:nth-child(4){animation-delay:.08s}.sidebar-nav .sidebar-link:nth-child(5){animation-delay:.1s}.sidebar-nav .sidebar-link:nth-child(6){animation-delay:.12s}.sidebar-nav .sidebar-link:nth-child(7){animation-delay:.14s}.sidebar-nav .sidebar-link:nth-child(8){animation-delay:.16s}.sidebar-nav .sidebar-link:nth-child(9){animation-delay:.18s}.sidebar-nav .sidebar-link:nth-child(10){animation-delay:.2s}.sidebar-nav .sidebar-link:nth-child(11){animation-delay:.22s}.sidebar-nav .sidebar-link:nth-child(12){animation-delay:.24s}.sidebar-nav .sidebar-link:nth-child(13){animation-delay:.26s}.sidebar-nav .sidebar-link:nth-child(14){animation-delay:.28s}.sidebar-nav .sidebar-link:nth-child(15){animation-delay:.3s}.sidebar-nav .sidebar-link:nth-child(16){animation-delay:.32s}.sidebar-nav .sidebar-link:nth-child(17){animation-delay:.34s}.sidebar-nav .sidebar-link:nth-child(18){animation-delay:.36s}.sidebar-nav .sidebar-link:nth-child(19){animation-delay:.38s}.sidebar-nav .sidebar-link:nth-child(20){animation-delay:.4s}.notification-dropdown-container{position:relative}.notification-bell{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:var(--slate-500);border-radius:10px;cursor:pointer;transition:all .2s;position:relative}.notification-bell:hover{background:var(--slate-100);color:var(--slate-700)}.notification-bell.active{background:var(--primary-100);color:var(--primary-600)}.notification-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ef44444d;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-height:500px;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d;overflow:hidden;z-index:1000;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--slate-100)}.notification-dropdown-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--slate-800)}.mark-all-read-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--primary-50);color:var(--primary-600);border:none;border-radius:8px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.mark-all-read-btn:hover:not(:disabled){background:var(--primary-100)}.mark-all-read-btn:disabled{opacity:.5;cursor:not-allowed}.notification-list{max-height:380px;overflow-y:auto}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:transparent}.notification-list::-webkit-scrollbar-thumb{background:var(--slate-200);border-radius:3px}.notification-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 2rem;color:var(--slate-400)}.notification-loading .spin{animation:spin 1s linear infinite}.notification-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem 2rem;text-align:center;color:var(--slate-400)}.notification-empty svg{color:var(--slate-300);margin-bottom:.5rem}.notification-empty h4{margin:0;font-size:.95rem;font-weight:600;color:var(--slate-600)}.notification-empty p{margin:0;font-size:.8rem}.notification-item{display:flex;align-items:flex-start;gap:.75rem;width:100%;padding:1rem 1.25rem;background:transparent;border:none;text-align:left;cursor:pointer;transition:background .15s;position:relative;border-bottom:1px solid var(--slate-50)}.notification-item:hover{background:var(--slate-50)}.notification-item:last-child{border-bottom:none}.notification-item.unread{background:linear-gradient(90deg,var(--primary-50) 0%,white 100%)}.notification-item.unread:hover{background:linear-gradient(90deg,var(--primary-100) 0%,var(--slate-50) 100%)}.notification-item.priority-urgent{border-left:3px solid #ef4444}.notification-item.priority-high{border-left:3px solid #f59e0b}.notification-item.priority-medium{border-left:3px solid #3b82f6}.notification-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--slate-100);color:var(--slate-600);border-radius:10px;flex-shrink:0}.notification-item.unread .notification-icon{background:var(--primary-100);color:var(--primary-600)}.notification-content{flex:1;min-width:0}.notification-title{font-size:.875rem;font-weight:600;color:var(--slate-800);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-message{font-size:.8rem;color:var(--slate-600);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:.7rem;color:var(--slate-400);margin-top:4px}.notification-unread-dot{width:8px;height:8px;background:var(--primary-500);border-radius:50%;flex-shrink:0;margin-top:6px}.notification-dropdown-footer{padding:.75rem 1.25rem;border-top:1px solid var(--slate-100);background:var(--slate-50)}.view-all-btn{display:block;width:100%;padding:.625rem 1rem;background:#fff;border:1px solid var(--slate-200);border-radius:10px;color:var(--slate-700);font-size:.8rem;font-weight:600;text-align:center;cursor:pointer;transition:all .15s}.view-all-btn:hover{background:var(--slate-100);border-color:var(--slate-300)}@media(max-width:480px){.notification-dropdown{position:fixed;inset:auto 0 0;width:100%;max-height:70vh;border-radius:20px 20px 0 0;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{padding:1.25rem}.notification-dropdown-header h3{font-size:1.125rem}.notification-item{padding:1rem}.notification-title{font-size:.9rem}.notification-message{font-size:.8rem}}.header{height:var(--header-height);background-color:#fff;border-bottom:1px solid var(--slate-200);padding:0 var(--spacing-4);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:30;box-shadow:var(--shadow-sm)}@media(min-width:1024px){.header{padding:0 var(--spacing-6)}}.header-left{display:flex;align-items:center;gap:var(--spacing-4)}.header-menu-btn{padding:var(--spacing-2);color:var(--slate-500);background:none;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.header-menu-btn:hover{background-color:var(--slate-50);color:var(--slate-700)}@media(min-width:1024px){.header-menu-btn{display:none}}.header-project-selector{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-4);background-color:var(--slate-50);border:1px solid var(--slate-100);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);max-width:200px}.header-project-selector:hover{background-color:var(--slate-100)}@media(min-width:1024px){.header-project-selector{max-width:none}}.header-project-icon{padding:var(--spacing-1);background-color:var(--primary-100);color:var(--primary-700);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.header-project-info{display:flex;flex-direction:column;text-align:left;overflow:hidden}.header-project-label{font-size:.5rem;font-weight:900;color:var(--slate-400);text-transform:uppercase;letter-spacing:.15em;line-height:1;margin-bottom:2px}.header-project-name{font-size:.75rem;font-weight:700;color:var(--slate-800);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-project-chevron{color:var(--slate-400);flex-shrink:0}.header-center{display:none}@media(min-width:1024px){.header-center{display:block;position:absolute;left:50%;transform:translate(-50%)}}.header-title{font-size:1rem;font-weight:700;color:var(--slate-800)}.header-right{display:flex;align-items:center;gap:var(--spacing-2)}@media(min-width:1024px){.header-right{gap:var(--spacing-4)}}.header-search{position:relative;display:none}@media(min-width:1024px){.header-search{display:block}}.header-search-icon{position:absolute;left:var(--spacing-3);top:50%;transform:translateY(-50%);color:var(--slate-400);pointer-events:none}.header-search-input{width:200px;padding:var(--spacing-2) var(--spacing-3);padding-left:2.5rem;background-color:var(--slate-50);border:1px solid var(--slate-100);border-radius:var(--radius-xl);font-size:.875rem;color:var(--slate-700);transition:all var(--transition-fast)}.header-search-input:focus{outline:none;background-color:#fff;border-color:var(--primary-300);box-shadow:0 0 0 3px var(--primary-50);width:280px}.header-search-input::placeholder{color:var(--slate-400)}.header-notification{position:relative;padding:var(--spacing-2);background-color:var(--slate-50);border:none;border-radius:var(--radius-xl);color:var(--slate-500);cursor:pointer;transition:all var(--transition-fast)}.header-notification:hover{background-color:var(--slate-100);color:var(--slate-700)}.header-notification-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background-color:var(--error-500);border:2px solid white;border-radius:50%}.header-chat{position:relative;padding:var(--spacing-2);background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:var(--radius-xl);color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #3b82f640}.header-chat:hover{transform:scale(1.05);box-shadow:0 4px 12px #3b82f659}.header-chat-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;background-color:#ef4444;color:#fff;font-size:.6rem;font-weight:700;border-radius:8px;display:flex;align-items:center;justify-content:center;border:2px solid white}.header-divider{height:24px;width:1px;background-color:var(--slate-100);display:none}@media(min-width:1024px){.header-divider{display:block}}.header-user{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1);background:none;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:background-color var(--transition-fast)}.header-user:hover{background-color:var(--slate-50)}.header-user-avatar{width:32px;height:32px;background-color:var(--slate-900);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.header-user-info{display:none;flex-direction:column;text-align:left}@media(min-width:1024px){.header-user-info{display:flex}}.header-user-name{font-size:.75rem;font-weight:700;color:var(--slate-800);line-height:1}.header-user-email{font-size:.625rem;color:var(--slate-400);font-weight:500;margin-top:2px}@media(max-width:767px){.header{height:56px;padding:0 var(--spacing-3);background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.header-left{gap:var(--spacing-2);flex-shrink:0}.header-menu-btn{display:flex;width:40px;height:40px;align-items:center;justify-content:center;border-radius:10px}.header-menu-btn:active{background:var(--slate-100);transform:scale(.95)}.header-project-selector{padding:6px 10px;max-width:none;gap:var(--spacing-2);border-radius:10px}.header-project-info{display:none}.header-project-icon{margin:0;width:24px;height:24px}.header-project-chevron{display:block;margin-left:-4px}.header-center{display:block;flex:1;text-align:center;overflow:hidden;padding:0 var(--spacing-2)}.header-title{font-size:.9375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--slate-800)}.header-right{gap:6px;flex-shrink:0}.header-search,.header-divider,.header-user-info,.header-user-chevron{display:none!important}.header-notification,.header-chat{width:38px;height:38px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:10px}.header-notification:active,.header-chat:active{transform:scale(.95)}.header-notification svg,.header-chat svg{width:18px;height:18px}.header-notification-badge{top:4px;right:4px;width:8px;height:8px}.header-user{padding:4px;border-radius:10px}.header-user:active{background:var(--slate-100)}.header-user-avatar{width:32px;height:32px;font-size:.8rem}}@media(max-width:359px){.header{padding:0 var(--spacing-2)}.header-project-selector{padding:4px 8px}.header-project-icon{width:20px;height:20px}.header-title{font-size:.8125rem}.header-notification,.header-chat{width:34px;height:34px}.header-user-avatar{width:28px;height:28px}}@media(max-height:500px)and (orientation:landscape){.header{height:48px}.header-title{font-size:.8125rem}.header-menu-btn,.header-notification,.header-chat{width:36px;height:36px}}.header-project-dropdown,.header-user-dropdown{position:relative}.header-project-selector.active,.header-user.active{background-color:var(--slate-100)}.header-project-chevron.rotate,.header-user-chevron.rotate{transform:rotate(180deg)}.header-project-chevron,.header-user-chevron{transition:transform .2s ease}.header-user-chevron{color:var(--slate-400);display:none}@media(min-width:1024px){.header-user-chevron{display:block}}.header-dropdown-panel{position:absolute;top:calc(100% + 8px);background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease;min-width:220px}.project-dropdown{left:0;width:280px}.user-dropdown{right:0;width:260px}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:.875rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--slate-400);border-bottom:1px solid var(--slate-100)}.dropdown-items{padding:.5rem;max-height:300px;overflow-y:auto}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;background:transparent;border:none;border-radius:10px;color:var(--slate-700);font-size:.875rem;font-weight:500;text-align:left;cursor:pointer;transition:all .15s}.dropdown-item:hover{background:var(--slate-50)}.dropdown-item.selected{background:var(--primary-50);color:var(--primary-700)}.dropdown-item.danger{color:#ef4444}.dropdown-item.danger:hover{background:#fef2f2}.dropdown-item svg{flex-shrink:0;opacity:.7}.dropdown-item-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.dropdown-item-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-item-code{font-size:.7rem;color:var(--slate-400);font-weight:400}.dropdown-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--slate-400);font-size:.8rem}.dropdown-loading .spin{animation:spinAnimation 1s linear infinite}@keyframes spinAnimation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dropdown-divider{height:1px;background:var(--slate-100);margin:.5rem 0}.dropdown-user-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,var(--slate-50),var(--slate-100))}.dropdown-user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--primary-600),var(--primary-700));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-weight:700;flex-shrink:0}.dropdown-user-info{overflow:hidden}.dropdown-user-name{font-size:.9rem;font-weight:600;color:var(--slate-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-user-email{font-size:.75rem;color:var(--slate-500)}.header-search{position:relative}.header-search form{display:flex;align-items:center}.header-search.focused .header-search-input{width:320px;background:#fff;border-color:var(--primary-300);box-shadow:0 0 0 3px var(--primary-50)}.header-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--slate-200);border:none;border-radius:50%;color:var(--slate-500);cursor:pointer;transition:all .15s}.header-search-clear:hover{background:var(--slate-300);color:var(--slate-700)}.header-search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:12px;box-shadow:0 20px 50px #0000001f,0 0 0 1px #0000000d;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease}.search-dropdown-header{padding:.75rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--slate-400);border-bottom:1px solid var(--slate-100)}.search-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem 1rem;background:transparent;border:none;color:var(--slate-700);font-size:.8rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s}.search-dropdown-item:hover{background:var(--slate-50)}.search-dropdown-item svg{color:var(--slate-400)}@media(max-width:767px){.header-project-dropdown:before,.header-user-dropdown:before{content:"";display:none}.header-dropdown-panel{position:fixed;inset:auto 0 0;width:100%;max-height:80vh;border-radius:24px 24px 0 0;animation:slideUpMobile .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -10px 40px #0003;z-index:9999}.header-dropdown-panel:before{content:"";display:block;width:40px;height:4px;background:var(--slate-300);border-radius:2px;margin:12px auto 8px}@keyframes slideUpMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.project-dropdown,.user-dropdown{width:100%;min-width:100%}.dropdown-header{padding:1rem 1.25rem;font-size:.9rem;font-weight:700;text-transform:none;letter-spacing:0;color:var(--slate-800);border-bottom:1px solid var(--slate-100)}.dropdown-items{max-height:55vh;padding:.75rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.dropdown-item{padding:1rem 1.25rem;font-size:1rem;border-radius:12px;margin-bottom:4px;gap:1rem}.dropdown-item:last-child{margin-bottom:0}.dropdown-item svg{width:20px;height:20px}.dropdown-item.selected{background:var(--primary-50);border:1px solid var(--primary-100)}.dropdown-item-info{gap:4px}.dropdown-item-name{font-size:1rem;font-weight:600}.dropdown-item-code{font-size:.8rem}.dropdown-user-header{padding:1.25rem;margin-top:8px}.dropdown-user-avatar{width:48px;height:48px;font-size:1.25rem}.dropdown-user-name{font-size:1.1rem}.dropdown-user-email{font-size:.875rem}.dropdown-divider{margin:.75rem 0}.dropdown-loading{padding:2rem;font-size:.9rem}.dropdown-loading svg{width:20px;height:20px}.header-dropdown-panel{padding-bottom:env(safe-area-inset-bottom,16px)}}@media(max-width:767px){.mobile-dropdown-overlay{position:fixed;inset:0;background:#0006;z-index:9998;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.mobile-dock{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:#0f172af2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 30px #0000004d}.dock-container{display:flex;align-items:center;justify-content:space-around;max-width:500px;margin:0 auto;padding:8px 4px;gap:2px}.dock-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 12px;min-width:60px;border-radius:16px;text-decoration:none;color:var(--slate-400);transition:all .2s ease;position:relative;background:transparent;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.dock-item:active{transform:scale(.92)}.dock-item.active{color:var(--primary-400)}.dock-item.active .dock-icon{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:var(--slate-900);box-shadow:0 4px 15px #10b98166}.dock-icon{display:flex;align-items:center;justify-content:center;width:44px;height:32px;border-radius:12px;position:relative;transition:all .2s ease}.dock-label{font-size:10px;font-weight:600;margin-top:4px;letter-spacing:.02em;opacity:.9}.dock-indicator{position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary-400);animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 4px var(--primary-400)}50%{box-shadow:0 0 8px var(--primary-400),0 0 16px var(--primary-500)}}.dock-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:10px;display:flex;align-items:center;justify-content:center;animation:badge-pop .3s ease}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.dock-menu-btn .dock-icon{background:#ffffff14;border:1px solid rgba(255,255,255,.1)}.dock-menu-btn:active .dock-icon{background:#ffffff26}.dock-backdrop{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.dock-expanded{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0));left:16px;right:16px;z-index:1001;background:#1e293bfa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;border:1px solid rgba(255,255,255,.1);box-shadow:0 -10px 40px #0006;animation:slide-up .25s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dock-expanded-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.dock-expanded-header span{font-size:13px;font-weight:700;color:var(--slate-300);text-transform:uppercase;letter-spacing:.1em}.dock-expanded-header button{width:28px;height:28px;border-radius:50%;background:#ffffff1a;border:none;color:var(--slate-400);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.dock-expanded-header button:hover{background:#ffffff26;color:#fff}.dock-expanded-grid{display:grid;grid-template-columns:repeat(3,1fr);padding:16px;gap:12px}.dock-expanded-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 8px;border-radius:16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);text-decoration:none;color:var(--slate-300);transition:all .2s ease;gap:8px}.dock-expanded-item:active{transform:scale(.95);background:#ffffff1a}.dock-expanded-item.active{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:var(--slate-900);border-color:transparent}.dock-expanded-item span{font-size:11px;font-weight:600;text-align:center}@media(min-width:768px){.mobile-dock,.dock-backdrop,.dock-expanded{display:none}}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-dock{padding-bottom:max(8px,env(safe-area-inset-bottom))}}@media(max-height:500px)and (orientation:landscape){.dock-container{padding:4px}.dock-icon{height:28px;width:40px}.dock-label{display:none}}.floating-chat-fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border:none;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border-radius:50%;cursor:pointer;box-shadow:0 6px 20px #7c3aed66,0 0 0 4px #7c3aed1a;z-index:9999;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.floating-chat-fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 10px 30px #7c3aed80,0 0 0 6px #7c3aed26}.floating-chat-fab:active{transform:scale(.98)}.fab-badge{position:absolute;top:-4px;right:-4px;min-width:22px;height:22px;padding:0 6px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;border-radius:11px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #ef444480;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.floating-chat-overlay{position:fixed;inset:0;background:#0f172a4d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:9998;animation:fadeIn .2s ease}.floating-chat-widget{position:fixed;bottom:24px;right:24px;width:380px;max-width:calc(100vw - 32px);height:520px;max-height:calc(100vh - 100px);background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;z-index:9999;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.fchat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff}.fchat-header-left{display:flex;align-items:center;gap:10px}.fchat-back{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#fff3;color:#fff;border-radius:8px;cursor:pointer;transition:all .15s}.fchat-back:hover{background:#ffffff4d}.fchat-title{font-size:1rem;font-weight:700}.fchat-header-right{display:flex;align-items:center;gap:6px}.fchat-expand,.fchat-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:#ffffff26;color:#fff;border-radius:8px;cursor:pointer;transition:all .15s}.fchat-expand:hover,.fchat-close:hover{background:#ffffff40}.fchat-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.fchat-list{flex:1;display:flex;flex-direction:column;overflow:hidden}.fchat-search-bar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.fchat-search{flex:1;display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.fchat-search svg{color:#94a3b8;flex-shrink:0}.fchat-search input{flex:1;border:none;background:transparent;font-size:.8rem;color:#1e293b}.fchat-search input:focus{outline:none}.fchat-search input::placeholder{color:#94a3b8}.fchat-new-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border-radius:10px;cursor:pointer;transition:all .15s}.fchat-new-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #7c3aed4d}.fchat-conv-list{flex:1;overflow-y:auto;padding:8px}.fchat-conv-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:#fff;border-radius:12px;cursor:pointer;text-align:left;transition:all .15s;margin-bottom:4px}.fchat-conv-item:hover{background:#f1f5f9}.fchat-conv-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#f0e7ff,#e0e7ff);color:#7c3aed;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fchat-conv-content{flex:1;min-width:0}.fchat-conv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.fchat-conv-name{font-size:.85rem;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fchat-conv-time{font-size:.65rem;color:#94a3b8;flex-shrink:0}.fchat-conv-preview{font-size:.75rem;color:#64748b;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fchat-unread{min-width:20px;height:20px;padding:0 6px;background:#7c3aed;color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;display:flex;align-items:center;justify-content:center}.fchat-skeleton{height:58px;border-radius:12px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:8px}.fchat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;color:#94a3b8;text-align:center}.fchat-empty p{margin:8px 0 16px;font-size:.85rem;color:#64748b}.fchat-empty button{padding:8px 16px;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.fchat-empty button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.fchat-empty.compact{padding:24px}.fchat-thread{flex:1;display:flex;flex-direction:column;overflow:hidden}.fchat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:#fafafa}.fchat-message{display:flex;gap:8px;max-width:85%}.fchat-message.own{align-self:flex-end;flex-direction:row-reverse}.fchat-msg-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fchat-msg-content{display:flex;flex-direction:column;gap:2px}.fchat-msg-sender{font-size:.65rem;font-weight:600;color:#64748b;margin-left:8px}.fchat-msg-bubble{padding:10px 14px;background:#fff;border-radius:16px 16px 16px 4px;font-size:.85rem;color:#1e293b;line-height:1.4;box-shadow:0 1px 2px #0000000d}.fchat-message.own .fchat-msg-bubble{background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border-radius:16px 16px 4px}.fchat-msg-time{font-size:.6rem;color:#94a3b8;margin-left:8px}.fchat-message.own .fchat-msg-time{margin-left:0;margin-right:8px;text-align:right}.fchat-msg-skeleton{height:44px;width:60%;border-radius:16px;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.fchat-msg-skeleton.own{align-self:flex-end}.fchat-composer{display:flex;align-items:center;gap:6px;padding:12px;border-top:1px solid #e2e8f0;background:#fff}.fchat-priority-wrap{position:relative}.fchat-priority-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e2e8f0;background:#fff;color:#64748b;border-radius:8px;cursor:pointer;transition:all .15s}.fchat-priority-btn:hover{border-color:#7c3aed;color:#7c3aed}.fchat-priority-btn.active-safety{border-color:#dc2626;background:#fef2f2;color:#dc2626}.fchat-priority-btn.active-delay{border-color:#ea580c;background:#fff7ed;color:#ea580c}.fchat-priority-btn.active-issue{border-color:#ca8a04;background:#fefce8;color:#ca8a04}.fchat-priority-btn.active-urgent{border-color:#7c3aed;background:#f5f3ff;color:#7c3aed}.fchat-priority-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border-radius:10px;box-shadow:0 10px 40px #00000026;padding:6px;min-width:130px;z-index:10}.fchat-priority-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;border-radius:6px;font-size:.75rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s}.fchat-priority-menu button:hover,.fchat-priority-menu button.selected{background:#f1f5f9}.priority-dot{width:8px;height:8px;border-radius:50%}.fchat-attach-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:#94a3b8;border-radius:8px;cursor:pointer;transition:all .15s}.fchat-attach-btn:hover{background:#f1f5f9;color:#64748b}.fchat-input{flex:1;padding:8px 12px;border:1px solid #e2e8f0;border-radius:20px;font-size:.8rem;color:#1e293b;transition:all .15s}.fchat-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.fchat-input::placeholder{color:#94a3b8}.fchat-input:disabled{background:#f8fafc}.fchat-send-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:linear-gradient(135deg,#7c3aed,#6366f1);color:#fff;border-radius:50%;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #7c3aed4d}.fchat-send-btn:hover:not(:disabled){transform:scale(1.05)}.fchat-send-btn:disabled{background:#cbd5e1;box-shadow:none;cursor:not-allowed}.fchat-new-selector{flex:1;overflow-y:auto;padding:16px}.fchat-new-hint{font-size:.8rem;color:#64748b;margin:0 0 12px}.fchat-entity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.fchat-entity-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:1px solid #e2e8f0;background:#fff;border-radius:12px;cursor:pointer;text-align:center;transition:all .2s}.fchat-entity-card:hover{border-color:#7c3aed;background:#faf5ff;transform:translateY(-2px);box-shadow:0 4px 12px #7c3aed1f}.fchat-entity-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#f0e7ff,#e0e7ff);color:#7c3aed;display:flex;align-items:center;justify-content:center}.fchat-entity-label{font-size:.8rem;font-weight:600;color:#1e293b}.fchat-entity-desc{font-size:.65rem;color:#94a3b8;line-height:1.3}@media(max-width:480px){.floating-chat-widget{bottom:0;right:0;width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}.floating-chat-fab{bottom:16px;right:16px}}.layout{display:flex;min-height:100vh;min-height:100dvh;background-color:var(--slate-50)}.layout-main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh;height:100dvh;overflow:hidden;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}@media(min-width:768px){.layout-main{margin-left:72px}}.layout-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--spacing-4);padding-bottom:calc(80px + env(safe-area-inset-bottom,16px));-webkit-overflow-scrolling:touch}@media(min-width:768px){.layout-content{padding:var(--spacing-8);padding-bottom:var(--spacing-8)}}@media(min-width:1024px){.layout-content{padding:var(--spacing-10);padding-bottom:var(--spacing-10)}}.layout-content-inner{width:100%!important;max-width:100%!important}.animate-fade-in{animation:fadeIn .5s ease forwards}.layout-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:var(--slate-50)}.loading-spinner{width:40px;height:40px;border:3px solid var(--slate-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s ease-in-out infinite}.layout-mobile .layout-main{margin-left:0}@media(max-width:767px){.layout-content{padding:var(--spacing-3);padding-bottom:calc(90px + env(safe-area-inset-bottom,16px))}.layout-content-inner{padding-bottom:20px}}@media(max-width:767px){.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:var(--spacing-4)}.page-header .btn{width:100%;justify-content:center}.page-title{font-size:1.25rem}}@media(max-width:767px){.card{border-radius:var(--radius-xl);border-left:none;border-right:none;margin-left:-12px;margin-right:-12px;width:calc(100% + 24px)}.card-header{padding:var(--spacing-4);flex-direction:column;align-items:flex-start;gap:8px}.card-content{padding:var(--spacing-4)}.card-footer{padding:var(--spacing-3) var(--spacing-4);flex-direction:column;gap:8px}.card-footer .btn{width:100%}}@media(max-width:767px){.table-container,.table{display:none}}@media(max-width:767px){.form-group{margin-bottom:var(--spacing-3)}.form-input,.form-select,.form-textarea{padding:var(--spacing-3);font-size:16px;border-radius:var(--radius-xl)}}@media(max-width:767px){.btn{padding:var(--spacing-3) var(--spacing-4);font-size:.8125rem}.btn-lg{padding:var(--spacing-4) var(--spacing-5)}}@media(max-width:767px){.grid{gap:var(--spacing-3)}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@media(max-width:767px){.stat-card{padding:var(--spacing-4)}.stat-card-icon{width:40px;height:40px}.stat-card-value{font-size:1.5rem}}@media(max-width:767px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-height:90vh;max-height:90dvh;width:100%}}@media(max-width:767px){.empty-state{padding:var(--spacing-8)}.empty-state-icon{width:48px;height:48px}}@media(max-width:767px){button,a,input,select,textarea,[role=button]{min-height:44px}}@media(max-width:767px){.btn:active,.card.clickable:active,button:active{opacity:.8;transform:scale(.98)}}@media(hover:none){.btn:hover,.card:hover,.table tbody tr:hover{background-color:inherit;transform:none;box-shadow:none}}.layout{padding-top:env(safe-area-inset-top,0)}@supports (padding: max(0px)){.layout-content{padding-left:max(var(--spacing-4),env(safe-area-inset-left));padding-right:max(var(--spacing-4),env(safe-area-inset-right))}}.no-overscroll{overscroll-behavior:none}.no-select{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}@media(max-height:500px)and (orientation:landscape){.layout-content{padding-bottom:60px}.page-title{font-size:1.125rem}}.login-page{min-height:100vh;display:flex;position:relative;overflow:hidden;background:#0a0a0f}.login-bg{position:absolute;inset:0;pointer-events:none;z-index:0}.login-bg-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(16,185,129,.15),transparent),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(59,130,246,.1),transparent)}.login-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%);mask-image:radial-gradient(ellipse at center,black 40%,transparent 80%)}.login-bg-glow{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4;animation:float 20s ease-in-out infinite}.login-bg-glow-1{top:10%;left:20%;width:400px;height:400px;background:linear-gradient(135deg,#10b981,#059669);animation-delay:0s}.login-bg-glow-2{bottom:10%;right:20%;width:350px;height:350px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);animation-delay:-7s}.login-bg-glow-3{top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:linear-gradient(135deg,#10b981,#3b82f6);opacity:.15;animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(20px,30px) scale(1.02)}}.login-content{position:relative;z-index:10;display:flex;width:100%;min-height:100vh}.login-branding{display:none;flex:1;padding:3rem;background:linear-gradient(135deg,#10b9810d,#3b82f60d);border-right:1px solid rgba(255,255,255,.05)}@media(min-width:1024px){.login-branding{display:flex;align-items:center;justify-content:center}}.login-branding-inner{max-width:480px;width:100%}.login-brand-header{margin-bottom:3rem}.login-logo{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.login-logo-icon{width:56px;height:56px;background:linear-gradient(135deg,#10b981,#059669);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 20px 40px -10px #10b98166}.login-logo-icon svg{width:32px;height:32px}.login-logo-icon.small{width:40px;height:40px;border-radius:12px}.login-logo-icon.small svg{width:24px;height:24px}.login-logo-text h1{font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1}.login-logo-text span{font-size:.75rem;color:#10b981;font-weight:600;text-transform:uppercase;letter-spacing:.1em}.login-tagline{font-size:1.125rem;color:#fff9;line-height:1.6;font-weight:400}.login-features{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:3rem}.login-feature{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:16px;transition:all .3s ease;animation:fadeInUp .5s ease forwards;opacity:0}.login-feature:hover{background:#ffffff0a;border-color:#10b98133;transform:translate(4px)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-feature-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#10b98133,#10b9811a);display:flex;align-items:center;justify-content:center;color:#10b981;flex-shrink:0}.login-feature-content h3{font-size:.9375rem;font-weight:600;color:#fff;margin-bottom:.25rem}.login-feature-content p{font-size:.8125rem;color:#ffffff80;line-height:1.4}.login-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}@media(min-width:1024px){.login-form-panel{max-width:560px}}.login-form-container{width:100%;max-width:400px}.login-mobile-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem}.login-mobile-header h1{font-size:1.5rem;font-weight:800;color:#fff}@media(min-width:1024px){.login-mobile-header{display:none}}.login-form-header{margin-bottom:2rem}.login-form-header h2{font-size:1.75rem;font-weight:700;color:#fff;margin-bottom:.5rem}.login-form-header p{font-size:.9375rem;color:#ffffff80}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form-group{display:flex;flex-direction:column;gap:.5rem}.login-form-group label{font-size:.8125rem;font-weight:600;color:#ffffffb3}.login-label-row{display:flex;justify-content:space-between;align-items:center}.login-forgot{font-size:.8125rem;color:#10b981;font-weight:500;text-decoration:none}.login-forgot:hover{text-decoration:underline}.login-input-wrapper{position:relative}.login-input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#ffffff4d;pointer-events:none;transition:color .2s ease}.login-input-wrapper:focus-within .login-input-icon{color:#10b981}.login-input-wrapper input{width:100%;padding:.875rem 1rem .875rem 2.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:.9375rem;font-weight:500;transition:all .2s ease}.login-input-wrapper input::placeholder{color:#ffffff4d}.login-input-wrapper input:focus{outline:none;border-color:#10b981;background:#10b9810d;box-shadow:0 0 0 3px #10b9811a}.login-password-toggle{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff6;font-size:.75rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.05em}.login-password-toggle:hover{color:#10b981}.login-error{padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:10px;color:#f87171;font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:.5rem;animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;margin-top:.5rem;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;color:#fff;font-size:.9375rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 10px 30px -10px #10b98180}.login-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 40px -10px #10b98199}.login-submit:active:not(:disabled){transform:translateY(0)}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-submit .spin{animation:spin 1s linear infinite}.login-demo{margin-top:2rem}.login-demo-divider{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.login-demo-divider:before,.login-demo-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.login-demo-divider span{font-size:.6875rem;color:#fff6;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.login-demo-card{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:12px}.login-demo-info{display:flex;align-items:center;gap:.75rem}.login-demo-icon{color:#fbbf24}.login-demo-title{font-size:.8125rem;font-weight:600;color:#fff;margin-bottom:.125rem}.login-demo-creds{font-size:.75rem;color:#ffffff80}.login-demo-creds code{background:#10b98126;color:#10b981;padding:.125rem .375rem;border-radius:4px;font-family:JetBrains Mono,monospace;font-size:.6875rem}.login-demo-btn{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.login-demo-btn:hover{background:#10b98126;border-color:#10b9814d;color:#10b981}.login-credit{margin-top:3rem;text-align:center}.login-credit p{font-size:.8125rem;color:#fff6}.login-credit a{color:#10b981;text-decoration:none;transition:color .2s ease}.login-credit a:hover{color:#34d399;text-decoration:underline}.login-credit strong{font-weight:700}.login-version{margin-top:.5rem;font-size:.6875rem!important;color:#ffffff40!important;text-transform:uppercase;letter-spacing:.1em}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--slate-900);padding:var(--spacing-6);position:relative;overflow:hidden}.auth-bg-blur{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none}.auth-bg-blur-1{top:-10%;left:-10%;width:50%;height:50%;background-color:#10b9811a}.auth-bg-blur-2{bottom:-10%;right:-10%;width:50%;height:50%;background-color:#3b82f61a}.auth-container{width:100%;max-width:420px;background-color:var(--slate-800);border:1px solid var(--slate-700);border-radius:2.5rem;padding:var(--spacing-8);position:relative;z-index:10;box-shadow:var(--shadow-2xl)}.auth-header{text-align:center;margin-bottom:var(--spacing-10)}.auth-logo{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background-color:var(--primary-500);border-radius:var(--radius-2xl);color:var(--slate-900);font-size:2rem;font-weight:900;margin-bottom:var(--spacing-4);box-shadow:0 20px 40px -10px #10b9814d}.auth-title{font-size:1.875rem;font-weight:900;color:#fff;letter-spacing:-.025em}.auth-subtitle{font-size:.75rem;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.15em;margin-top:var(--spacing-2);opacity:.7}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-5)}.auth-form .form-group{gap:var(--spacing-2)}.auth-form .form-label{color:var(--slate-500);margin-left:var(--spacing-1)}.auth-input-wrapper{position:relative}.auth-input-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--slate-500);pointer-events:none;transition:color var(--transition-fast)}.auth-input-wrapper:focus-within .auth-input-icon{color:var(--primary-500)}.auth-input{width:100%;background-color:#1e293b66;border:1px solid var(--slate-700);color:#fff;padding:var(--spacing-4);padding-left:3rem;border-radius:var(--radius-2xl);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.auth-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #10b98133}.auth-input::placeholder{color:var(--slate-500)}.auth-error{padding:var(--spacing-4);background-color:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#f87171;font-size:.625rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-xl);text-align:center}.auth-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-4);background-color:var(--primary-500);color:var(--slate-900);font-size:.75rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;border:none;border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 20px 40px -10px #10b9814d}.auth-submit:hover:not(:disabled){background-color:var(--primary-400);transform:translateY(-2px)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-demo-box{margin-top:var(--spacing-10);padding:var(--spacing-5);background-color:#1e293b4d;border:1px solid var(--slate-700);border-radius:var(--radius-3xl)}.auth-demo-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3);font-size:.625rem;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.15em}.auth-demo-creds{display:flex;flex-direction:column;gap:var(--spacing-2)}.auth-demo-row{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.auth-demo-label{color:var(--slate-500);font-weight:500}.auth-demo-value{color:var(--slate-300);font-weight:700;font-family:monospace}.auth-demo-btn{width:100%;margin-top:var(--spacing-4);padding:var(--spacing-2);background-color:var(--slate-700);border:1px solid rgba(71,85,105,.5);color:var(--slate-400);font-size:.5625rem;font-weight:900;text-transform:uppercase;letter-spacing:.15em;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast)}.auth-demo-btn:hover{color:var(--primary-400);background-color:var(--slate-600)}.auth-footer{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);margin-top:var(--spacing-8);color:var(--slate-600)}.auth-footer p{font-size:.5625rem;font-weight:900;text-transform:uppercase;letter-spacing:.2em}.auth-register-link{text-align:center;margin-top:var(--spacing-4);font-size:.875rem;color:var(--slate-500)}.auth-register-link a{color:var(--primary-400);font-weight:600}.auth-register-link a:hover{text-decoration:underline}.text-primary-500{color:var(--primary-500)}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-6)}.dashboard-stats{display:grid;grid-template-columns:repeat(1,1fr);gap:var(--spacing-4)}@media(min-width:640px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.dashboard-stats{grid-template-columns:repeat(4,1fr)}}.dashboard-error-full{grid-column:1 / -1}.dashboard-secondary-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-6);padding:var(--spacing-4) var(--spacing-6);background:#fff;border-radius:var(--radius-2xl);border:1px solid var(--slate-100)}.secondary-stat{display:flex;align-items:center;gap:var(--spacing-2);color:var(--slate-500)}.secondary-stat svg{color:var(--slate-400)}.secondary-stat-value{font-size:.875rem;font-weight:700;color:var(--slate-800)}.secondary-stat-label{font-size:.75rem;color:var(--slate-500)}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-6)}@media(min-width:1024px){.dashboard-grid{grid-template-columns:1.5fr 1fr}}.activity-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.activity-item{display:flex;gap:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--slate-100)}.activity-item:last-child{padding-bottom:0;border-bottom:none}.activity-icon{width:40px;height:40px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.success{background-color:var(--primary-100);color:var(--primary-600)}.activity-icon.warning{background-color:var(--warning-100);color:var(--warning-600)}.activity-icon.info{background-color:var(--info-100);color:var(--info-600)}.activity-icon.error{background-color:var(--error-100);color:var(--error-600)}.activity-content{flex:1;min-width:0}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.activity-title{font-size:.875rem;font-weight:700;color:var(--slate-800)}.activity-time{font-size:.625rem;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.05em}.activity-desc{font-size:.75rem;color:var(--slate-500);font-weight:500;line-height:1.5}.pending-sections{display:flex;flex-direction:column;gap:var(--spacing-5)}.pending-section{display:flex;flex-direction:column;gap:var(--spacing-2)}.pending-section-title{display:flex;align-items:center;gap:var(--spacing-2);font-size:.75rem;font-weight:700;color:var(--slate-600);margin-bottom:var(--spacing-1)}.pending-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);background-color:var(--slate-50);border-radius:var(--radius-lg);font-size:.75rem}.pending-item-type{font-weight:700;color:var(--slate-700);background-color:var(--slate-200);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:.625rem}.pending-item-level{font-weight:600;color:var(--slate-500)}.pending-item-name{font-weight:600;color:var(--slate-700)}.pending-item-qty{font-weight:700}.pending-item-vendor{font-weight:500;color:var(--slate-500)}.text-error{color:var(--error-600)}.skeleton{background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-200) 50%,var(--slate-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-icon{width:48px;height:48px;border-radius:var(--radius-xl);margin-bottom:var(--spacing-3)}.skeleton-icon-sm{width:40px;height:40px;border-radius:var(--radius-xl);flex-shrink:0}.skeleton-label{width:80px;height:12px;margin-bottom:var(--spacing-2)}.skeleton-value{width:60px;height:28px;margin-bottom:var(--spacing-2)}.skeleton-change{width:100px;height:14px}.skeleton-title{width:120px;height:14px;margin-bottom:var(--spacing-2)}.skeleton-desc{width:180px;height:12px}.skeleton-item{width:100%;height:40px;margin-bottom:var(--spacing-2)}.empty-state-sm{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-6);text-align:center;color:var(--slate-400)}.empty-state-sm svg{margin-bottom:var(--spacing-2)}.empty-state-title-sm{font-size:.875rem;font-weight:600;color:var(--slate-600);margin-bottom:var(--spacing-1)}.empty-state-desc-sm{font-size:.75rem;color:var(--slate-500)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-6);text-align:center;color:var(--error-600);background-color:var(--error-50);border-radius:var(--radius-xl);gap:var(--spacing-2)}.error-state p{font-size:.875rem;font-weight:500}.quick-actions{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-4) var(--spacing-5);border:1px solid var(--slate-100)}.quick-actions-title{font-size:.875rem;font-weight:600;color:var(--slate-700);margin:0 0 var(--spacing-3)}.quick-actions-grid{display:flex;gap:var(--spacing-3);flex-wrap:wrap}.quick-action{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--slate-50);border-radius:var(--radius-lg);text-decoration:none;transition:all .2s ease}.quick-action:hover{background:var(--slate-100);transform:translateY(-1px)}.quick-action span{font-size:.8125rem;font-weight:600;color:var(--slate-700)}.quick-action-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.quick-action-icon.blue{background:#3b82f626;color:#3b82f6}.quick-action-icon.purple{background:#8b5cf626;color:#8b5cf6}.quick-action-icon.orange{background:#f59e0b26;color:#f59e0b}.quick-action-icon.green{background:#10b98126;color:#10b981}@media(max-width:767px){.dashboard{gap:var(--spacing-4)}.dashboard-stats{gap:var(--spacing-3)}.stat-card{padding:var(--spacing-3);flex-direction:column;align-items:flex-start;text-align:left;gap:var(--spacing-2)}.stat-card-icon{width:36px;height:36px}.stat-card-value{font-size:1.25rem}.stat-card-label{font-size:.6875rem}.stat-card-change{font-size:.625rem}.dashboard-secondary-stats{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none}.dashboard-secondary-stats::-webkit-scrollbar{display:none}.secondary-stat{flex-shrink:0;min-width:120px}.quick-actions{margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none;padding:var(--spacing-3) var(--spacing-4)}.quick-actions-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500)}.quick-actions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-2)}.quick-action{flex-direction:column;padding:var(--spacing-3) var(--spacing-2);text-align:center;gap:var(--spacing-2)}.quick-action-icon{width:40px;height:40px;margin:0 auto}.quick-action span{font-size:.625rem;line-height:1.2}.dashboard-grid{gap:var(--spacing-3)}.dashboard-grid .card{margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none}.activity-item{gap:var(--spacing-3);padding-bottom:var(--spacing-3)}.activity-icon{width:36px;height:36px}.activity-title{font-size:.8125rem}.activity-desc{font-size:.6875rem}.pending-item{padding:var(--spacing-2)}.pending-section-title{font-size:.6875rem}}@media(max-width:359px){.dashboard-stats{grid-template-columns:1fr 1fr}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-height:500px)and (orientation:landscape){.dashboard-stats{grid-template-columns:repeat(4,1fr)}.stat-card{flex-direction:row;align-items:center}}.mobile-card{background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;transition:all .2s ease;margin-bottom:12px}.mobile-card.clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-card.clickable:active{transform:scale(.98);background:var(--slate-50)}.mobile-card.highlighted{border-color:var(--primary-200);background:linear-gradient(135deg,var(--primary-50) 0%,white 100%)}.mobile-card-main{display:flex;align-items:flex-start;gap:12px}.mobile-card-left{flex-shrink:0}.mobile-card-avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--primary-400) 0%,var(--primary-600) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px}.mobile-card-icon{width:44px;height:44px;border-radius:12px;background:var(--slate-100);display:flex;align-items:center;justify-content:center;color:var(--slate-600)}.mobile-card-center{flex:1;min-width:0}.mobile-card-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.mobile-card-title{font-size:15px;font-weight:600;color:var(--slate-900);margin:0;line-height:1.3}.mobile-card-subtitle{font-size:13px;color:var(--slate-500);margin:0 0 8px;line-height:1.4}.mobile-card-badge{display:inline-flex;padding:3px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;border-radius:6px}.mobile-card-badge.badge-success{background:var(--success-50);color:var(--success-700)}.mobile-card-badge.badge-warning{background:var(--warning-50);color:var(--warning-600)}.mobile-card-badge.badge-error{background:var(--error-50);color:var(--error-600)}.mobile-card-badge.badge-info{background:var(--info-50);color:var(--info-600)}.mobile-card-badge.badge-gray{background:var(--slate-100);color:var(--slate-600)}.mobile-card-details{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.mobile-card-detail{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:10px;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:13px;font-weight:600;color:var(--slate-700)}.mobile-card-right{flex-shrink:0;display:flex;align-items:center}.mobile-card-arrow{color:var(--slate-400);transition:transform .2s ease}.mobile-card.clickable:active .mobile-card-arrow{transform:translate(4px)}.mobile-card-actions{display:flex;gap:8px}.mobile-card-list{padding:0}.mobile-card-list-title{font-size:12px;font-weight:800;color:var(--slate-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;padding:0 4px}.mobile-card-list-items{display:flex;flex-direction:column}.mobile-card-empty{text-align:center;padding:40px 20px;color:var(--slate-400);font-size:14px}.mobile-stat-card{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;transition:all .2s ease}.mobile-stat-card.clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-stat-card.clickable:active{transform:scale(.98)}.mobile-stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-stat-card.color-emerald .mobile-stat-icon{background:var(--primary-100);color:var(--primary-600)}.mobile-stat-card.color-blue .mobile-stat-icon{background:var(--info-100);color:var(--info-600)}.mobile-stat-card.color-orange .mobile-stat-icon{background:var(--warning-100);color:var(--warning-600)}.mobile-stat-card.color-red .mobile-stat-icon{background:var(--error-100);color:var(--error-600)}.mobile-stat-card.color-slate .mobile-stat-icon{background:var(--slate-100);color:var(--slate-600)}.mobile-stat-content{display:flex;flex-direction:column;gap:2px}.mobile-stat-value{font-size:24px;font-weight:800;color:var(--slate-900);line-height:1}.mobile-stat-label{font-size:12px;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.mobile-stat-change{font-size:11px;font-weight:700;margin-top:2px}.mobile-stat-change.positive{color:var(--success-600)}.mobile-stat-change.negative{color:var(--error-600)}.mobile-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}@media(max-width:400px){.mobile-stats-grid{grid-template-columns:1fr}}.mobile-card-swipe-hint{font-size:11px;color:var(--slate-400);text-align:center;padding:8px;margin-top:12px}.mobile-pull-indicator{display:flex;align-items:center;justify-content:center;padding:12px;color:var(--slate-400);font-size:13px;gap:8px}.mobile-pull-indicator svg{animation:spin 1s linear infinite}@media(min-width:768px){.mobile-only{display:none!important}}@media(max-width:767px){.desktop-only{display:none!important}}.projects-page{animation:fadeInUp .4s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-6)}.page-header-left{display:flex;flex-direction:column;gap:var(--spacing-1)}.page-title{font-size:1.75rem;font-weight:800;color:var(--slate-800);margin:0;letter-spacing:-.03em}.page-subtitle{font-size:.9375rem;color:var(--slate-500);margin:0}.page-header-right{display:flex;gap:var(--spacing-3)}.filters-bar{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-5);flex-wrap:wrap;padding:var(--spacing-4);background:#fff;border-radius:var(--radius-2xl);border:1px solid var(--slate-100);box-shadow:0 2px 8px #0000000a}.search-input-wrapper{position:relative;flex:1;min-width:200px;max-width:360px}.search-icon{position:absolute;left:var(--spacing-4);top:50%;transform:translateY(-50%);color:var(--slate-400);transition:color .2s}.search-input-wrapper:focus-within .search-icon{color:var(--primary-500)}.search-input{width:100%;padding:var(--spacing-3) var(--spacing-3) var(--spacing-3) var(--spacing-10);border:1px solid var(--slate-200);border-radius:var(--radius-xl);font-size:.875rem;background:var(--slate-50);transition:all .25s ease}.search-input:focus{outline:none;background:#fff;border-color:var(--primary-400);box-shadow:0 0 0 4px #10b9811a}.filter-select{padding:var(--spacing-3) var(--spacing-4);padding-right:var(--spacing-10);border:1px solid var(--slate-200);border-radius:var(--radius-xl);font-size:.875rem;font-weight:500;background:var(--slate-50);min-width:150px;cursor:pointer;transition:all .2s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' 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 12px center}.filter-select:focus{outline:none;background-color:#fff;border-color:var(--primary-400);box-shadow:0 0 0 4px #10b9811a}.filter-select:hover{background-color:#fff;border-color:var(--slate-300)}.table-container{background:#fff;border-radius:var(--radius-2xl);border:1px solid rgba(0,0,0,.06);overflow:hidden;box-shadow:0 4px 24px #0000000f,0 1px 2px #0000000a}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:var(--spacing-4) var(--spacing-5);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--slate-500);background:linear-gradient(180deg,var(--slate-50) 0%,rgba(241,245,249,.5) 100%);border-bottom:1px solid var(--slate-100);white-space:nowrap}.data-table th:first-child{padding-left:var(--spacing-6)}.data-table th:last-child{padding-right:var(--spacing-6)}.data-table td{padding:var(--spacing-4) var(--spacing-5);font-size:.875rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100);vertical-align:middle}.data-table td:first-child{padding-left:var(--spacing-6)}.data-table td:last-child{padding-right:var(--spacing-6)}.data-table tbody tr:last-child td{border-bottom:none}.table-row-clickable{cursor:pointer;transition:all .2s ease}.table-row-clickable:hover{background:linear-gradient(90deg,rgba(16,185,129,.04) 0%,rgba(16,185,129,.02) 50%,transparent 100%)}.table-row-clickable:hover td:first-child{box-shadow:inset 3px 0 0 var(--primary-500)}.table-cell-code{font-family:JetBrains Mono,SF Mono,Monaco,monospace;font-size:.8125rem;font-weight:600;color:var(--slate-500);background:var(--slate-50);padding:var(--spacing-1) var(--spacing-2)!important;border-radius:var(--radius-md);display:inline-block}.table-cell-name{font-weight:600;color:var(--slate-800)}.project-name-cell{display:flex;flex-direction:column;gap:6px}.project-name{font-weight:600;font-size:.9375rem;color:var(--slate-800);letter-spacing:-.01em;transition:color .2s}.table-row-clickable:hover .project-name{color:var(--primary-600)}.project-location{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--slate-500);padding:2px 8px;background:var(--slate-50);border-radius:20px;width:fit-content}.project-location svg{color:var(--slate-400)}.table-cell-date{white-space:nowrap;color:var(--slate-600);font-size:.8125rem}.table-cell-amount{font-weight:700;font-family:JetBrains Mono,SF Mono,Monaco,monospace;font-size:.875rem;color:var(--slate-800);letter-spacing:-.02em}.table-cell-action{color:var(--slate-400);width:40px;transition:all .2s}.table-row-clickable:hover .table-cell-action{color:var(--primary-500);transform:translate(2px)}.category-label{display:inline-block;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);background:var(--slate-100);padding:2px 8px;border-radius:var(--radius-md);margin-top:4px}.table-row-skeleton td{padding:var(--spacing-4)}.skeleton-text{width:80px;height:16px}.skeleton-text-lg{width:160px;height:16px}.skeleton-text-sm{width:60px;height:16px}.skeleton-badge{width:70px;height:24px;border-radius:var(--radius-full)}.skeleton-icon{width:24px;height:24px;border-radius:var(--radius-md)}.empty-state-icon{color:var(--slate-300);margin-bottom:var(--spacing-4)}.empty-state-title{font-size:1.125rem;font-weight:700;color:var(--slate-700);margin:0 0 var(--spacing-2)}.empty-state-desc{font-size:.875rem;color:var(--slate-500);margin:0 0 var(--spacing-6);max-width:320px}.error-state-full{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16);text-align:center;color:var(--slate-600)}.error-state-full svg{color:var(--slate-300);margin-bottom:var(--spacing-4)}.error-state-full h3{margin:0 0 var(--spacing-2);font-size:1.125rem;font-weight:700}.error-state-full p{margin:0 0 var(--spacing-6);color:var(--slate-500)}.error-actions{display:flex;gap:var(--spacing-3)}.drawer-overlay{position:fixed;inset:0;background:#00000080;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;bottom:0;height:100vh;width:480px;max-width:100%;background:#fff;z-index:101;display:flex;flex-direction:column;animation:slideIn .25s ease}.drawer-right{right:0;box-shadow:-4px 0 24px #0000001a}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--slate-100);background:#fff}.drawer-title{font-size:1.125rem;font-weight:700;color:var(--slate-800);margin:0}.drawer-close{padding:var(--spacing-2);border:none;background:none;color:var(--slate-500);cursor:pointer;border-radius:var(--radius-md);transition:background .15s}.drawer-close:hover{background:var(--slate-100)}.drawer-body{flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-4)}.drawer-footer{flex-shrink:0;display:flex;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--slate-100);background:#fff}.form-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.form-label{font-size:.75rem;font-weight:700;color:var(--slate-600);text-transform:uppercase;letter-spacing:.05em}.form-label .required{color:var(--error-500)}.form-input{padding:var(--spacing-3);border:1px solid var(--slate-200);border-radius:var(--radius-lg);font-size:.875rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-input:disabled{background:var(--slate-50);color:var(--slate-500);cursor:not-allowed}.form-input.input-error{border-color:var(--error-500)}.form-error{font-size:.75rem;color:var(--error-600)}.form-hint{font-size:.75rem;color:var(--slate-500)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.form-error-banner{padding:var(--spacing-3);background:var(--error-50);border:1px solid var(--error-200);border-radius:var(--radius-lg);color:var(--error-700);font-size:.875rem}.form-warning-banner{padding:var(--spacing-3);background:var(--warning-50);border:1px solid var(--warning-200);border-radius:var(--radius-lg);color:var(--warning-700);font-size:.875rem}.back-link{display:inline-flex;align-items:center;gap:var(--spacing-2);color:var(--slate-600);font-size:.875rem;font-weight:500;padding:0;border:none;background:none;cursor:pointer;margin-bottom:var(--spacing-4);transition:color .15s}.back-link:hover{color:var(--slate-800)}.project-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-6);gap:var(--spacing-4)}.project-detail-title-row{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.project-detail-title{font-size:1.5rem;font-weight:800;color:var(--slate-800);margin:0}.badge-lg{font-size:.75rem;padding:var(--spacing-1) var(--spacing-3)}.project-detail-meta{display:flex;align-items:center;gap:var(--spacing-4);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--spacing-1);font-size:.875rem;color:var(--slate-600)}.tabs-container{margin-bottom:var(--spacing-6);border-bottom:1px solid var(--slate-200)}.tabs{display:flex;gap:var(--spacing-1)}.tab{padding:var(--spacing-3) var(--spacing-4);font-size:.875rem;font-weight:600;color:var(--slate-500);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab:hover{color:var(--slate-700)}.tab-active{color:var(--primary-600);border-bottom-color:var(--primary-600)}.tab-content{min-height:300px}.overview-tab{display:flex;flex-direction:column;gap:var(--spacing-6)}.overview-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4)}.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-4)}@media(max-width:768px){.detail-grid{grid-template-columns:repeat(2,1fr)}}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-1)}.detail-item.full-width{grid-column:1 / -1;margin-top:var(--spacing-2);padding-top:var(--spacing-4);border-top:1px solid var(--slate-100)}.detail-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500)}.tab-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16);text-align:center;color:var(--slate-400)}.tab-placeholder svg{margin-bottom:var(--spacing-3)}.tab-placeholder h4{margin:0 0 var(--spacing-1);font-size:1rem;font-weight:600;color:var(--slate-600)}.tab-placeholder p{margin:0;font-size:.875rem}.skeleton-title-lg{width:240px;height:32px}.page-form{max-width:900px}.page-header-icon{width:48px;height:48px;background:var(--primary-100);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--primary-600)}.page-header-left{display:flex;align-items:flex-start;gap:var(--spacing-4)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}@media(max-width:768px){.form-grid{grid-template-columns:1fr}}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-3);padding-top:var(--spacing-4);border-top:1px solid var(--slate-100)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16);color:var(--slate-500);gap:var(--spacing-4)}.loading-state svg{color:var(--primary-500)}.budget-tab{padding:var(--spacing-4) 0}.budget-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}@media(max-width:768px){.budget-cards{grid-template-columns:1fr}}.budget-card{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-6);background:#fff;border-radius:var(--radius-xl);border:1px solid var(--slate-200);text-decoration:none;transition:all .2s ease;cursor:pointer}.budget-card:hover{border-color:var(--primary-300);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.budget-card-icon{width:64px;height:64px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0}.budget-card-cost .budget-card-icon{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0284c7}.budget-card-material .budget-card-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.budget-card-content{flex:1}.budget-card-content h3{margin:0 0 var(--spacing-1);font-size:1.125rem;font-weight:700;color:var(--slate-800)}.budget-card-content p{margin:0;font-size:.875rem;color:var(--slate-500)}.budget-card-arrow{color:var(--slate-400);transition:color .15s,transform .15s;flex-shrink:0}.budget-card:hover .budget-card-arrow{color:var(--primary-500);transform:translate(4px)}.discussion-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background:var(--primary-50);color:var(--primary-600);border:1px solid var(--primary-200);border-radius:var(--radius-lg);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.discussion-btn:hover{background:var(--primary-100);border-color:var(--primary-300)}.project-detail-header-right{display:flex;gap:var(--spacing-3);align-items:center}.project-detail-page{animation:fadeInUp .4s ease}.tabs-container{margin-bottom:var(--spacing-6);padding:var(--spacing-2);background:#fff;border-radius:var(--radius-2xl);border:1px solid var(--slate-100);box-shadow:0 2px 8px #0000000a}.tabs{display:flex;gap:var(--spacing-1);flex-wrap:wrap}.tab{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);font-size:.8125rem;font-weight:600;color:var(--slate-500);background:transparent;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:all .25s ease}.tab:hover{color:var(--slate-700);background:var(--slate-50)}.tab-active{background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);color:#fff;box-shadow:0 4px 12px #10b9814d}.tab-active svg{color:#fff}.tab svg{flex-shrink:0;transition:color .2s}.badge-outline{background:transparent;border:1px solid var(--slate-300);color:var(--slate-600)}.badge-primary{background:linear-gradient(135deg,#d1fae5,#6ee7b7);color:#047857}.badge-lg{padding:6px 14px;font-size:.75rem}.rera-badge{background:linear-gradient(135deg,#10b9811a,#10b9810d);color:#059669;padding:4px 10px;border-radius:20px;font-weight:600;font-size:.75rem;border:1px solid rgba(16,185,129,.2)}.progress-cards{display:grid;grid-template-columns:1fr;gap:var(--spacing-4);margin-bottom:var(--spacing-5)}.progress-card{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-6);border:1px solid rgba(0,0,0,.05);box-shadow:0 4px 20px #0000000a,0 1px 3px #00000008}.progress-card-header{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-5);font-weight:700;font-size:.9375rem;color:var(--slate-800)}.progress-card-header svg{color:var(--primary-500);padding:8px;background:linear-gradient(135deg,#10b9811a,#10b9810d);border-radius:var(--radius-lg);width:36px;height:36px}.progress-item{margin-bottom:var(--spacing-4)}.progress-item:last-child{margin-bottom:0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2)}.progress-label{font-size:.8125rem;font-weight:600;color:var(--slate-600)}.progress-value{font-size:.875rem;font-weight:700;color:var(--slate-800);font-family:JetBrains Mono,SF Mono,monospace}.progress-bar{height:10px;background:var(--slate-100);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-bar:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:progressShine 2s ease-in-out infinite}@keyframes progressShine{0%,to{transform:translate(-100%)}50%{transform:translate(100%)}}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}.progress-fill.primary{background:linear-gradient(90deg,#3b82f6,#1d4ed8);box-shadow:0 2px 8px #3b82f666}.progress-fill.emerald{background:linear-gradient(90deg,#10b981,#059669);box-shadow:0 2px 8px #10b98166}.overview-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-5)}@media(max-width:1024px){.overview-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.overview-cards{grid-template-columns:1fr}}.stat-card{background:#fff;border-radius:var(--radius-2xl);padding:var(--spacing-5);border:1px solid rgba(0,0,0,.05);box-shadow:0 2px 12px #0000000a;display:flex;align-items:center;gap:var(--spacing-4);transition:all .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;opacity:0;transition:opacity .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.stat-card:hover:before{opacity:1}.stat-card-icon{width:56px;height:56px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .3s}.stat-card:hover .stat-card-icon{transform:scale(1.1)}.stat-card-icon.emerald{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.stat-card:has(.stat-card-icon.emerald):before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card-icon.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-card:has(.stat-card-icon.blue):before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-card-icon.orange{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.stat-card:has(.stat-card-icon.orange):before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card-icon.slate{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569}.stat-card:has(.stat-card-icon.slate):before{background:linear-gradient(90deg,#64748b,#94a3b8)}.stat-card-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--slate-500);margin-bottom:4px}.stat-card-value{font-size:1.375rem;font-weight:800;color:var(--slate-800);letter-spacing:-.02em}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-5)}@media(max-width:768px){.details-grid{grid-template-columns:1fr}}.details-grid .card.full-width{grid-column:1 / -1}.details-grid .card{background:#fff;border-radius:var(--radius-2xl);border:1px solid rgba(0,0,0,.05);box-shadow:0 2px 12px #0000000a;overflow:hidden}.details-grid .card-header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4) var(--spacing-5);background:linear-gradient(180deg,var(--slate-50) 0%,transparent 100%);border-bottom:1px solid var(--slate-100)}.details-grid .card-header svg{color:var(--slate-400);padding:6px;background:#fff;border-radius:var(--radius-md);box-shadow:0 1px 3px #00000014}.details-grid .card-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--slate-600)}.details-grid .card-content{padding:var(--spacing-5)}.highlight-card{border-left:4px solid var(--primary-500);background:linear-gradient(135deg,rgba(16,185,129,.02),transparent)}.info-item{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3);border-radius:var(--radius-lg);transition:background .2s}.info-item:hover{background:var(--slate-50)}.info-icon{color:var(--slate-400);flex-shrink:0;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:4px}.info-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--slate-400)}.info-value{font-size:.9375rem;font-weight:600;color:var(--slate-800);letter-spacing:-.01em}.detail-grid.two-col{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-2)}@media(max-width:640px){.detail-grid.two-col{grid-template-columns:1fr}}.address-text{font-size:.9375rem;color:var(--slate-700);line-height:1.7;margin:0}.empty-text{font-size:.875rem;color:var(--slate-400);font-style:italic;margin:0}.description-text{font-size:.875rem;color:var(--slate-700);line-height:1.7;margin:0;white-space:pre-wrap}.client-tab,.compliance-tab,.documents-tab,.milestones-tab{padding:var(--spacing-2) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16);background:#fff;border-radius:var(--radius-xl);border:1px solid var(--slate-100);text-align:center}.empty-state svg{color:var(--slate-300);margin-bottom:var(--spacing-4)}.empty-state h3{margin:0 0 var(--spacing-2);font-size:1.125rem;font-weight:700;color:var(--slate-700)}.empty-state p{margin:0 0 var(--spacing-6);font-size:.875rem;color:var(--slate-500);max-width:320px}.stat-card-icon.blue{background-color:#3b82f626;color:#3b82f6}.category-label{display:block;font-size:.7rem;color:var(--slate-500);margin-top:var(--spacing-1)}.form-section{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--slate-100);margin-bottom:var(--spacing-4);overflow:hidden}.form-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-5);background:var(--slate-50);border:none;cursor:pointer;transition:background .15s}.form-section-title{display:flex;align-items:center;gap:var(--spacing-3);font-size:.875rem;font-weight:700;color:var(--slate-700)}.form-section-title svg{color:var(--slate-400)}.required-badge{font-size:.65rem;font-weight:600;padding:2px 8px;background:var(--error-100);color:var(--error-600);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em}.form-section-content{padding:var(--spacing-5);border-top:1px solid var(--slate-100)}.form-section .form-grid{margin-bottom:0}.page-form>form{display:flex;flex-direction:column;gap:0}.page-form .form-actions{margin-top:var(--spacing-6)}.form-hint{font-size:.7rem;color:var(--slate-400);margin-top:var(--spacing-1)}.milestones-header,.documents-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.milestones-summary,.documents-summary{display:flex;align-items:center;gap:var(--spacing-4)}.milestone-progress-ring{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-100),var(--primary-200));border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.progress-percent{font-size:1rem;font-weight:800;color:var(--primary-700)}.milestones-summary h3,.documents-summary h3{margin:0;font-size:1rem;font-weight:700;color:var(--slate-800)}.milestones-summary p{margin:0;font-size:.75rem;color:var(--slate-500)}.milestones-timeline{display:flex;flex-direction:column}.milestone-item{display:flex;gap:var(--spacing-4);position:relative}.milestone-connector{display:flex;flex-direction:column;align-items:center;width:32px;flex-shrink:0}.milestone-dot{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}.milestone-dot.badge-success{background:var(--success-100);color:var(--success-600)}.milestone-dot.badge-info{background:var(--primary-100);color:var(--primary-600)}.milestone-dot.badge-secondary{background:var(--slate-100);color:var(--slate-500)}.milestone-dot.badge-error{background:var(--error-100);color:var(--error-600)}.milestone-dot.badge-warning{background:var(--warning-100);color:var(--warning-600)}.milestone-line{width:2px;flex:1;min-height:24px;background:var(--slate-200);margin-top:var(--spacing-2)}.milestone-content{flex:1;background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-4);border:1px solid var(--slate-100);margin-bottom:var(--spacing-4)}.milestone-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2)}.milestone-header h4{margin:0;font-size:.875rem;font-weight:700;color:var(--slate-800)}.milestone-actions{display:flex;align-items:center;gap:var(--spacing-2)}.milestone-description{font-size:.8rem;color:var(--slate-600);margin-bottom:var(--spacing-2)}.milestone-meta{display:flex;gap:var(--spacing-4);font-size:.7rem;color:var(--slate-500)}.milestone-meta span{display:flex;align-items:center;gap:var(--spacing-1)}.milestone-meta .delayed{color:var(--error-600);font-weight:600}.document-alerts{display:flex;gap:var(--spacing-2)}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-4)}.document-category{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--slate-100);overflow:hidden}.document-category-header{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:var(--slate-50);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--slate-600)}.document-category-header svg{color:var(--slate-400)}.doc-count{margin-left:auto;background:var(--slate-200);padding:2px 8px;border-radius:var(--radius-full);font-size:.65rem}.document-list{padding:var(--spacing-2)}.document-item{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-3);border-radius:var(--radius-md);transition:background .15s}.document-item:hover{background:var(--slate-50)}.document-item.expired{border-left:3px solid var(--error-500);background:var(--error-50)}.document-item.expiring{border-left:3px solid var(--warning-500);background:var(--warning-50)}.document-info{flex:1}.document-number{font-size:.875rem;font-weight:600;color:var(--slate-800);margin-bottom:2px}.document-description{font-size:.75rem;color:var(--slate-600);margin-bottom:var(--spacing-1)}.document-dates{display:flex;gap:var(--spacing-3);font-size:.65rem;color:var(--slate-500)}.document-dates span{display:flex;align-items:center;gap:4px}.text-error{color:var(--error-600)!important;font-weight:600}.text-warning{color:var(--warning-600)!important;font-weight:600}.document-actions{display:flex;gap:var(--spacing-1)}.btn-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--slate-400);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.btn-icon:hover{background:var(--slate-100);color:var(--slate-600)}.file-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-6);border:2px dashed var(--slate-200);border-radius:var(--radius-lg);color:var(--slate-400);font-size:.75rem}.mobile-only{display:none}.desktop-only{display:block}@media(max-width:767px){.mobile-only{display:block!important}.desktop-only{display:none!important}}@media(max-width:767px){.page-header{flex-direction:row;align-items:center;margin-bottom:var(--spacing-4);gap:var(--spacing-2)}.page-header-left{flex:1;min-width:0}.page-title{font-size:1.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-subtitle{font-size:.75rem}.page-header-right .btn{padding:var(--spacing-2) var(--spacing-3)}.page-header-right .btn svg{margin-right:0}}@media(max-width:767px){.filters-bar{flex-direction:column;gap:var(--spacing-2)}.search-input-wrapper{max-width:none;width:100%}.search-input{font-size:16px}.filter-select{width:100%;min-width:0;font-size:16px;padding:var(--spacing-3)}}@media(max-width:767px){.filters-bar-inline{flex-direction:row;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-2);margin-bottom:var(--spacing-2)}.filters-bar-inline::-webkit-scrollbar{display:none}.filters-bar-inline .filter-select{flex-shrink:0;min-width:120px}}@media(max-width:767px){.table-container{display:none}}@media(max-width:767px){.empty-state{padding:var(--spacing-8);margin:0 calc(-1 * var(--spacing-3));border-radius:0;border-left:none;border-right:none}.empty-state-icon{width:40px;height:40px}.empty-state-title{font-size:1rem}.empty-state-desc{font-size:.8125rem}.error-state{padding:var(--spacing-6)}}@media(max-width:767px){.drawer{width:100%;max-width:100%;border-radius:20px 20px 0 0;top:auto;bottom:0;max-height:90vh;max-height:90dvh;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer-header{padding:var(--spacing-3) var(--spacing-4);border-radius:20px 20px 0 0}.drawer-title{font-size:1rem}.drawer-body{padding:var(--spacing-4)}.drawer-footer{padding:var(--spacing-3) var(--spacing-4);padding-bottom:calc(var(--spacing-3) + env(safe-area-inset-bottom));flex-direction:column-reverse}.drawer-footer .btn{width:100%;justify-content:center}}@media(max-width:767px){.form-grid,.form-row{grid-template-columns:1fr;gap:var(--spacing-3)}.form-input,.form-select,select{font-size:16px!important;padding:var(--spacing-3);min-height:48px}.form-actions{flex-direction:column-reverse;gap:var(--spacing-2)}.form-actions .btn{width:100%;justify-content:center}}@media(max-width:767px){.tabs-container{margin:0 calc(-1 * var(--spacing-3));padding:0 var(--spacing-3);overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs-container::-webkit-scrollbar{display:none}.tabs{flex-wrap:nowrap}.tab{padding:var(--spacing-2) var(--spacing-3);font-size:.8125rem;white-space:nowrap}}@media(max-width:767px){.project-detail-header{flex-direction:column}.project-detail-title{font-size:1.25rem}.project-detail-title-row{flex-wrap:wrap}.project-detail-meta{gap:var(--spacing-2)}.meta-item{font-size:.75rem}}@media(max-width:767px){.overview-cards{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.detail-grid{grid-template-columns:1fr 1fr;gap:var(--spacing-3)}.budget-cards{grid-template-columns:1fr}.budget-card{padding:var(--spacing-4)}.budget-card-icon{width:48px;height:48px}}.mobile-card-skeleton{background:#fff;border-radius:16px;border:1px solid var(--slate-100);padding:16px;margin-bottom:12px}.mobile-card-skeleton .skeleton-line{height:14px;background:linear-gradient(90deg,var(--slate-100) 25%,var(--slate-200) 50%,var(--slate-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px;margin-bottom:8px}.mobile-card-skeleton .skeleton-line.short{width:60%}.mobile-card-skeleton .skeleton-line.tiny{width:40%;height:10px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:767px){button,.btn,a.btn{min-height:44px}.table-row-clickable:active,.mobile-card:active,.budget-card:active{background-color:var(--slate-100)}}.tab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.tab-section-title{font-size:1rem;font-weight:700;color:var(--slate-800);margin:0}.site-name-cell{display:flex;flex-direction:column;gap:var(--spacing-1)}.site-address{font-size:.75rem;color:var(--slate-500)}.table-cell-actions{display:flex;gap:var(--spacing-1)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:transparent;color:var(--slate-500);border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s,color .15s}.icon-btn:hover{background:var(--slate-100);color:var(--slate-700)}.icon-btn-success:hover{background:var(--success-50);color:var(--success-600)}.icon-btn-warning:hover{background:var(--warning-50);color:var(--warning-600)}.icon-btn-danger:hover{background:var(--error-50);color:var(--error-600)}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.empty-state-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);background:var(--slate-50);border-radius:var(--radius-xl);border:1px dashed var(--slate-200);text-align:center}.empty-state-inline .empty-state-icon{color:var(--slate-300);margin-bottom:var(--spacing-3)}.empty-state-inline h4{font-size:1rem;font-weight:600;color:var(--slate-700);margin:0 0 var(--spacing-1)}.empty-state-inline p{font-size:.875rem;color:var(--slate-500);margin:0 0 var(--spacing-4)}.dialog-overlay{position:fixed;inset:0;background:#00000080;z-index:200;animation:fadeIn .15s ease}.dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-6);width:400px;max-width:90vw;z-index:201;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.dialog-title{font-size:1.125rem;font-weight:700;color:var(--slate-800);margin:0 0 var(--spacing-2)}.dialog-message{font-size:.875rem;color:var(--slate-600);margin:0 0 var(--spacing-6);line-height:1.5}.btn-danger{background:var(--error-600);color:#fff}.btn-danger:hover{background:var(--error-700)}.form-section-title{display:flex;align-items:center;gap:var(--spacing-2);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--slate-100)}.form-textarea{resize:vertical;min-height:80px}.panel-overlay{position:fixed;inset:0;background:#0006;z-index:100}.side-panel{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:100%;background:#fff;z-index:101;display:flex;flex-direction:column;box-shadow:-4px 0 24px #0000001a;animation:slideIn .25s ease}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--slate-100)}.panel-title{font-size:1rem;font-weight:700;color:var(--slate-800);margin:0}.panel-subtitle{font-size:.875rem;color:var(--slate-500);margin:var(--spacing-1) 0 0}.panel-body{flex:1;overflow-y:auto;padding:var(--spacing-4) var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-4)}.users-list{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-4)}.user-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3);background:var(--slate-50);border-radius:var(--radius-lg)}.user-info{display:flex;align-items:center;gap:var(--spacing-3)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--primary-100);color:var(--primary-700);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.user-details{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:.875rem;color:var(--slate-800)}.user-email{font-size:.75rem;color:var(--slate-500)}.user-role{font-size:.75rem;color:var(--primary-600);font-weight:500}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);color:var(--slate-400)}.loading-state p{margin:var(--spacing-2) 0 0;font-size:.875rem}.error-state-sm{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-6);text-align:center;color:var(--slate-500)}.error-state-sm svg{color:var(--slate-300);margin-bottom:var(--spacing-2)}.error-state-sm p{margin:0 0 var(--spacing-3);font-size:.875rem}.assign-user-form{background:var(--slate-50);border-radius:var(--radius-lg);padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-2);margin-top:var(--spacing-2)}.btn-full-width{width:100%;justify-content:center}.skeleton-actions{width:100px;height:28px}.estimation-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.estimation-hero{background:linear-gradient(135deg,#1e293b,#0f172a,#020617);padding:2rem;border-radius:var(--radius-xl);margin-bottom:1.5rem;position:relative;overflow:visible}.estimation-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(16,185,129,.15) 0%,transparent 60%);pointer-events:none}.estimation-hero:after{content:"";position:absolute;bottom:-50%;left:-20%;width:50%;height:200%;background:radial-gradient(ellipse,rgba(59,130,246,.1) 0%,transparent 60%);pointer-events:none}.estimation-hero-content{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.estimation-hero-left{display:flex;align-items:center;gap:1.25rem}.estimation-hero-icon{width:64px;height:64px;background:linear-gradient(135deg,#10b981,#059669);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 32px #10b98166}.estimation-hero-text h1{font-size:1.75rem;font-weight:800;color:#fff;margin:0 0 .375rem;letter-spacing:-.025em}.estimation-hero-text p{font-size:.9375rem;color:#94a3b8;margin:0}.estimation-hero-actions{display:flex;gap:.75rem}.estimation-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1200px){.estimation-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.estimation-stats-grid{grid-template-columns:1fr}}.estimation-stat-card{background:#fff;border-radius:16px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;border:1px solid rgba(0,0,0,.04);box-shadow:0 1px 3px #0000000a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.estimation-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--stat-color, var(--primary-500));opacity:0;transition:opacity .3s ease}.estimation-stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000014}.estimation-stat-card:hover:before{opacity:1}.estimation-stat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.estimation-stat-icon.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.estimation-stat-icon.emerald{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.estimation-stat-icon.amber{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.estimation-stat-icon.purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#7c3aed}.estimation-stat-content{flex:1;min-width:0}.estimation-stat-value{font-size:1.875rem;font-weight:800;color:#0f172a;line-height:1.1;margin-bottom:.25rem;letter-spacing:-.025em}.estimation-stat-label{font-size:.8125rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.estimation-stat-trend{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:20px;margin-top:.5rem}.estimation-stat-trend.up{background:#dcfce7;color:#15803d}.estimation-stat-trend.down{background:#fee2e2;color:#dc2626}.estimation-tabs{background:#fff;border-radius:20px;padding:8px;margin-bottom:1.5rem;display:inline-flex;gap:4px;box-shadow:0 4px 16px #0000000f}.tabs-container{display:flex;gap:4px}.tab-btn{display:flex;align-items:center;gap:12px;padding:14px 24px;border:none;background:transparent;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.tab-btn:hover:not(.active){background:#f1f5f9}.tab-btn.active{background:linear-gradient(135deg,var(--tab-color, #10b981) 0%,color-mix(in srgb,var(--tab-color, #10b981) 85%,black) 100%);box-shadow:0 4px 16px color-mix(in srgb,var(--tab-color, #10b981) 40%,transparent)}.tab-icon{width:40px;height:40px;background:#0000000f;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .3s ease}.tab-btn.active .tab-icon{background:#fff3;color:#fff}.tab-label{font-size:.9375rem;font-weight:700;color:#475569;transition:color .3s ease}.tab-btn.active .tab-label{color:#fff}.tab-count{min-width:32px;height:28px;padding:0 10px;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:800;border-radius:20px;background:#0000000f;color:#475569;transition:all .3s ease}.tab-btn.active .tab-count{background:#ffffff40;color:#fff}.tab-indicator{display:none}@media(max-width:768px){.estimation-tabs{width:100%}.tabs-container{width:100%;display:grid;grid-template-columns:repeat(3,1fr)}.tab-btn{flex-direction:column;padding:12px 8px;gap:6px}.tab-label{font-size:.75rem;text-align:center}.tab-icon{width:36px;height:36px}.tab-count{position:absolute;top:4px;right:4px;min-width:22px;height:22px;padding:0 6px;font-size:.6875rem}}.estimation-toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.estimation-search{flex:1;min-width:280px;position:relative}.estimation-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.estimation-search-input{width:100%;padding:14px 14px 14px 48px;border:2px solid #e2e8f0;border-radius:14px;font-size:.9375rem;background:#fff;transition:all .2s ease}.estimation-search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px #10b9811a}.estimation-filter-btn{display:flex;align-items:center;gap:.5rem;padding:14px 20px;border:2px solid #e2e8f0;background:#fff;border-radius:14px;font-size:.875rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s ease}.estimation-filter-btn:hover{border-color:var(--primary-500);color:var(--primary-600)}.estimation-filter-badge{min-width:22px;height:22px;padding:0 6px;background:var(--primary-500);color:#fff;border-radius:11px;font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center}.estimation-table-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #0000000f}.estimation-table-header{padding:1.5rem 2rem;background:linear-gradient(to right,#fafafa,#f8fafc);border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.estimation-table-title{display:flex;align-items:center;gap:1rem}.estimation-table-title h2{font-size:1.125rem;font-weight:800;color:#0f172a;margin:0}.estimation-table-count{background:#e2e8f0;color:#475569;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:700}.estimation-table-filters{display:flex;gap:.5rem}.estimation-status-filter{padding:8px 16px;border:2px solid transparent;background:#f1f5f9;border-radius:10px;font-size:.8125rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s ease}.estimation-status-filter:hover{background:#e2e8f0}.estimation-status-filter.active{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.estimation-table-wrapper{overflow-x:auto}.estimation-table{width:100%;border-collapse:collapse}.estimation-table thead{background:linear-gradient(to bottom,#f8fafc,#f1f5f9)}.estimation-table th{padding:16px 20px;font-size:.6875rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#64748b;text-align:left;border-bottom:2px solid #e2e8f0;white-space:nowrap}.estimation-table th:first-child{padding-left:2rem}.estimation-table th:last-child{padding-right:2rem}.estimation-table tbody tr{cursor:pointer;transition:all .2s ease;border-bottom:1px solid #f1f5f9}.estimation-table tbody tr:hover{background:linear-gradient(to right,#f0fdf4,#ecfdf5)}.estimation-table tbody tr:last-child{border-bottom:none}.estimation-table td{padding:18px 20px;font-size:.875rem;color:#334155;vertical-align:middle}.estimation-table td:first-child{padding-left:2rem}.estimation-table td:last-child{padding-right:2rem}.cell-boq-number{display:flex;align-items:center;gap:.75rem}.cell-boq-icon{width:40px;height:40px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#0284c7;flex-shrink:0}.cell-boq-info{display:flex;flex-direction:column;gap:.125rem}.cell-boq-code{font-weight:700;color:#0f172a;font-size:.9375rem}.cell-boq-project{font-size:.75rem;color:#64748b}.cell-project-name{font-weight:600;color:#334155}.cell-items-count{display:inline-flex;align-items:center;gap:.375rem;padding:5px 12px;background:#f1f5f9;border-radius:20px;font-size:.8125rem;font-weight:600;color:#475569}.cell-amount{font-family:JetBrains Mono,SF Mono,monospace;font-weight:700;font-size:.9375rem;color:#0f172a}.cell-amount-highlight{color:#059669}.cell-date{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.8125rem}.cell-date svg{opacity:.5}.estimation-status{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.estimation-status svg{width:12px;height:12px}.estimation-status.draft{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#475569;border:1px solid #cbd5e1}.estimation-status.submitted{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid #93c5fd}.estimation-status.approved{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border:1px solid #86efac}.estimation-status.converted{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#047857;border:1px solid #6ee7b7}.estimation-status.revised{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d}.estimation-actions{display:inline-flex;align-items:center;gap:6px;opacity:.7;transition:opacity .2s ease}.estimation-actions.visible,.estimation-table tbody tr:hover .estimation-actions{opacity:1}.estimation-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:none;background:#f1f5f9;border-radius:10px;color:#64748b;cursor:pointer;transition:all .2s ease}.estimation-action-btn:hover{background:#e2e8f0;color:#0f172a}.estimation-action-btn.danger:hover{background:#fee2e2;color:#dc2626}.estimation-action-btn.primary:hover{background:#dcfce7;color:#15803d}.action-btn{width:32px;height:32px;min-width:32px;min-height:32px;display:inline-flex!important;align-items:center!important;justify-content:center!important;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;padding:6px;flex-shrink:0;box-sizing:border-box;position:relative}.action-btn svg{display:block!important;width:16px!important;height:16px!important;flex-shrink:0;stroke-width:2}.action-btn:hover{transform:scale(1.1)}.action-btn.action-view{background:#dbeafe;color:#2563eb}.action-btn.action-view:hover{background:#2563eb;color:#fff}.action-btn.action-revise,.action-btn.action-edit{background:#fef3c7;color:#d97706}.action-btn.action-revise:hover,.action-btn.action-edit:hover{background:#d97706;color:#fff}.action-btn.action-export{background:#ede9fe;color:#7c3aed}.action-btn.action-export:hover{background:#7c3aed;color:#fff}.action-btn.action-budget{background:#dcfce7;color:#16a34a}.action-btn.action-budget:hover{background:#16a34a;color:#fff}.action-btn.action-submit{background:#dbeafe;color:#2563eb}.action-btn.action-submit:hover{background:#2563eb;color:#fff}.action-btn.action-approve{background:#dcfce7;color:#16a34a}.action-btn.action-approve:hover{background:#16a34a;color:#fff}.action-btn.action-delete{background:#fee2e2;color:#dc2626}.action-btn.action-delete:hover{background:#dc2626;color:#fff}.estimation-empty{padding:4rem 2rem;text-align:center}.estimation-empty-icon{width:80px;height:80px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#94a3b8}.estimation-empty h3{font-size:1.25rem;font-weight:700;color:#334155;margin:0 0 .5rem}.estimation-empty p{font-size:.9375rem;color:#64748b;margin:0 0 1.5rem;max-width:400px;margin-left:auto;margin-right:auto}.rate-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem}.rate-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;transition:all .3s ease}.rate-card:hover{border-color:var(--primary-300);box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.rate-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.rate-card-title{font-weight:700;color:#0f172a;font-size:1rem}.rate-card-unit{background:#f1f5f9;padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:600;color:#64748b}.rate-card-breakdown{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px dashed #e2e8f0}.rate-item{text-align:center}.rate-item-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin-bottom:.25rem}.rate-item-value{font-family:JetBrains Mono,monospace;font-weight:700;color:#334155}.rate-card-footer{display:flex;justify-content:space-between;align-items:center}.rate-final{font-size:1.25rem;font-weight:800;color:#059669}.rate-card-actions{display:flex;gap:.25rem}.stat-card{background:#fff;border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;border:1px solid rgba(0,0,0,.04);box-shadow:0 1px 3px #0000000a;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000000f}.stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}.stat-value{font-size:1.5rem;font-weight:800;color:#0f172a}.stat-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.estimation-form-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #0000000f;margin-bottom:1.5rem}.estimation-form-header{padding:1.5rem 2rem;background:linear-gradient(to right,#fafafa,#fff);border-bottom:1px solid #e2e8f0}.estimation-form-header h3{font-size:1rem;font-weight:700;color:#0f172a;margin:0}.estimation-form-body{padding:2rem}.estimation-form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media(max-width:768px){.estimation-form-grid{grid-template-columns:1fr}}.estimation-summary{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:20px;padding:2rem;color:#fff;margin-bottom:1.5rem}.estimation-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media(max-width:768px){.estimation-summary-grid{grid-template-columns:1fr;gap:1.5rem}}.estimation-summary-item{text-align:center}.estimation-summary-label{font-size:.875rem;color:#94a3b8;margin-bottom:.5rem}.estimation-summary-value{font-size:2rem;font-weight:800;font-family:JetBrains Mono,monospace}.estimation-summary-value.highlight{color:#34d399}.search-box{position:relative;margin-bottom:1.5rem}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8}.search-input{width:100%;max-width:320px;padding:12px 12px 12px 44px;border:2px solid #e2e8f0;border-radius:12px;font-size:.875rem;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #10b9811a}.table-container table{width:100%;border-collapse:collapse}.table-container th{padding:14px 16px;font-size:.6875rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#64748b;text-align:left;background:#f8fafc;border-bottom:2px solid #e2e8f0}.table-container td{padding:14px 16px;font-size:.875rem;color:#334155;border-bottom:1px solid #f1f5f9}.table-container tbody tr{transition:background .2s ease}.table-container tbody tr:hover{background:#f0fdf4}.action-buttons{display:flex;gap:.25rem}.action-btn{padding:8px;background:transparent;border:none;border-radius:8px;color:#64748b;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:#f1f5f9;color:#0f172a}.summary-section{border-top:2px solid #e2e8f0;padding-top:1.5rem;margin-top:1.5rem}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px dashed #e2e8f0}.summary-row:last-child{border-bottom:none}.summary-row span{color:#64748b}.summary-row strong{font-size:1.125rem;color:#0f172a}.summary-row.total{background:linear-gradient(to right,#ecfdf5,#d1fae5);margin:.5rem -1rem -1rem;padding:1rem;border-radius:0 0 16px 16px}.summary-row.total strong{font-size:1.5rem;color:#059669}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:5px 12px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:capitalize}.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:100;padding:1rem}.modal-content{background:#fff;border-radius:20px;padding:2rem;width:100%;max-width:480px;box-shadow:0 24px 48px #0003}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-sm{padding:8px 16px;font-size:.8125rem}.bg-blue-100{background:#dbeafe}.bg-emerald-100{background:#d1fae5}.bg-amber-100{background:#fef3c7}.bg-purple-100{background:#ede9fe}.bg-red-100{background:#fee2e2}.text-emerald-600{color:#059669}.text-amber-600{color:#d97706}.text-purple-600{color:#7c3aed}.text-red-600{color:#dc2626}.bg-amber-500{background:#f59e0b!important}.bg-purple-500{background:#8b5cf6!important}.text-white{color:#fff!important}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.text-sm{font-size:.875rem}.empty-state{text-align:center;padding:3rem 2rem}.empty-icon{color:#cbd5e1;margin-bottom:1rem}.empty-state p{color:#64748b;margin-bottom:1.5rem}.excel-table-wrapper{overflow-x:auto;border-radius:12px}.excel-table{width:100%;border-collapse:collapse}.excel-table th{background:linear-gradient(to bottom,#f8fafc,#f1f5f9);padding:0;font-size:.6875rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-bottom:2px solid #e2e8f0}.excel-th-content{display:flex;flex-direction:column}.excel-th-label{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 8px;cursor:pointer}.excel-filter-input{width:100%;padding:8px 12px;border:none;border-top:1px solid #e2e8f0;background:#fff;font-size:.75rem}.excel-filter-input:focus{background:#fffbeb;outline:none}.excel-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-size:.8125rem}.excel-table .cell-currency{font-family:JetBrains Mono,monospace;font-weight:700;color:#059669}.excel-table .cell-badge{display:inline-flex;padding:4px 10px;border-radius:20px;font-size:.6875rem;font-weight:700;text-transform:uppercase}.excel-table .badge-material{background:#dbeafe;color:#1e40af}.excel-table .badge-labor{background:#fef3c7;color:#b45309}.excel-table .badge-equipment{background:#ede9fe;color:#7c3aed}.excel-no-data{text-align:center;padding:3rem;color:#94a3b8}.excel-no-data svg{margin:0 auto 1rem;opacity:.5}.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;border-radius:10px;transition:all .2s ease;cursor:pointer;font-size:.875rem}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:.625rem 1.25rem;box-shadow:0 4px 12px #10b98133}.btn-primary:hover{box-shadow:0 6px 16px #10b9814d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:#475569;border:1px solid #e2e8f0;padding:.625rem 1.25rem}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.625rem 1.25rem}.btn-danger-outline{background:#fff;color:#ef4444;border:1px solid #fee2e2;padding:.625rem 1.25rem}.btn-danger-outline:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.btn-sm{padding:.4rem .875rem;font-size:.75rem;border-radius:8px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.cost-breakdown{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;padding:1.5rem;margin-top:1.5rem}.summary-title{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 1rem;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.summary-divider{height:1px;background:#e2e8f0;margin:.75rem 0}.cost-price{background:linear-gradient(135deg,#dbeafe,#bfdbfe);padding:.75rem 1rem;border-radius:10px;margin:.5rem 0}.cost-price span{font-weight:700;color:#1e40af}.cost-price strong{font-size:1.125rem}.selling-price{background:linear-gradient(135deg,#dcfce7,#bbf7d0);padding:.75rem 1rem;border-radius:10px;margin-top:.5rem}.selling-price span{font-size:1rem;font-weight:700;color:#15803d}.selling-price strong{font-size:1.25rem;color:#166534}.text-blue{color:#2563eb!important}.estimations-page{width:100%}.estimation-name-cell{display:flex;align-items:center;gap:var(--spacing-3)}.estimation-name-cell svg{color:var(--primary-500);flex-shrink:0}.estimation-name{font-weight:600;color:var(--slate-800);display:block}.estimation-ref{font-size:.75rem;color:var(--slate-500)}.table-cell-amount{font-weight:600;font-family:var(--font-mono)}.table-cell-date{font-size:.8rem;color:var(--slate-500)}.price-comparison-modal{background:#fff;border-radius:16px;width:90%;max-width:1000px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.price-comparison-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#f0fdf4,#ecfdf5)}.price-comparison-modal .modal-title-group{display:flex;align-items:center;gap:1rem}.price-comparison-modal .modal-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#059669,#10b981);display:flex;align-items:center;justify-content:center;color:#fff}.price-comparison-modal .modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.price-comparison-modal .modal-header p{margin:.25rem 0 0;font-size:.875rem;color:#64748b}.price-comparison-modal .btn-close{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:8px;color:#64748b;transition:all .2s}.price-comparison-modal .btn-close:hover{background:#f1f5f9;color:#1e293b}.price-comparison-modal .modal-body{padding:1.5rem;overflow-y:auto;flex:1}.comparison-search-form{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input-wrapper{flex:1;position:relative}.search-input-wrapper .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8}.search-input-wrapper .search-input{width:100%;padding:.875rem 2.5rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .2s}.search-input-wrapper .search-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.search-input-wrapper .clear-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#94a3b8;padding:.25rem;border-radius:50%}.search-input-wrapper .clear-btn:hover{background:#f1f5f9;color:#64748b}.suggestions-container{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}.suggestions-label{font-size:.75rem;color:#64748b;font-weight:500}.suggestions-list{display:flex;gap:.5rem;flex-wrap:wrap}.suggestion-chip,.popular-chip{padding:.375rem .75rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:9999px;font-size:.8125rem;cursor:pointer;transition:all .2s;color:#475569}.suggestion-chip:hover,.popular-chip:hover{background:#e0f2fe;border-color:#0ea5e9;color:#0284c7}.savings-banner{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0;border-radius:12px;margin-bottom:1.5rem}.savings-icon{width:48px;height:48px;border-radius:50%;background:#10b981;color:#fff;display:flex;align-items:center;justify-content:center}.savings-content h4{margin:0;font-size:.875rem;color:#065f46;font-weight:600}.savings-content p{margin:.25rem 0 0;font-size:.9375rem;color:#047857}.savings-content strong{font-size:1.25rem;color:#059669}.savings-percent{margin-left:.5rem;font-size:.875rem;color:#10b981;background:#10b9811a;padding:.125rem .5rem;border-radius:9999px}.comparison-results{border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.results-header{padding:1rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.results-header h3{margin:0;font-size:.9375rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:.5rem}.comparison-table{width:100%;border-collapse:collapse}.comparison-table th{padding:.75rem 1rem;background:#f8fafc;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid #e2e8f0}.comparison-table td{padding:1rem;border-bottom:1px solid #e2e8f0;font-size:.875rem;color:#1e293b}.comparison-table tr:last-child td{border-bottom:none}.comparison-table tr:hover{background:#f8fafc}.comparison-table tr.best-price{background:linear-gradient(135deg,#ecfdf5,#f0fdf4)}.comparison-table tr.best-price:hover{background:linear-gradient(135deg,#d1fae5,#ecfdf5)}.rank-cell{text-align:center}.rank-number{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#f1f5f9;font-weight:600;color:#64748b}.best-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.supplier-cell{display:flex;align-items:center;gap:.5rem}.supplier-icon{color:#64748b}.supplier-name{font-weight:500}.item-cell{display:flex;flex-direction:column;gap:.125rem}.item-name{font-weight:500}.item-spec{font-size:.75rem;color:#64748b}.brand-cell{color:#64748b}.rate-cell,.total-rate-cell{font-family:JetBrains Mono,monospace}.rate-value{font-weight:600;color:#1e293b}.rate-unit{font-size:.75rem;color:#64748b;margin-left:.125rem}.total-rate-cell{font-weight:700;color:#059669}.gst-cell{color:#64748b;font-size:.8125rem}.loading-state,.error-state,.empty-state,.initial-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#64748b}.loading-state p,.empty-state p,.initial-state p{margin:1rem 0 0;font-size:.9375rem}.empty-state h3,.initial-state h3{margin:1rem 0 0;font-size:1.125rem;font-weight:600;color:#1e293b}.empty-icon,.initial-icon{color:#cbd5e1}.error-state{color:#ef4444}.popular-items{margin-top:2rem}.popular-label{font-size:.8125rem;color:#64748b;margin-bottom:.75rem;display:block}.popular-list{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}@media(max-width:768px){.price-comparison-modal{width:95%;margin:1rem}.comparison-search-form{flex-direction:column}.comparison-table th,.comparison-table td{padding:.5rem;font-size:.75rem}}.vendors-page{width:100%}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}@media(min-width:1024px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#fff;border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 12px #00000014;border-color:#10b981}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.5rem;font-weight:900;color:#0f172a;line-height:1.2}.stat-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.025em}.vendor-rating{display:flex;gap:2px}.star-filled{color:#f59e0b;fill:#f59e0b}.star-empty{color:#e2e8f0}.empty-state-card{text-align:center;padding:3rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.empty-state-card svg{color:#cbd5e1;margin-bottom:1rem}.empty-state-card h3{color:#0f172a;margin:0 0 .5rem}.empty-state-card p{color:#64748b;margin:0 0 1rem}.error-state-card{text-align:center;padding:3rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0}.error-state-card svg{color:#ef4444;margin-bottom:1rem}.error-state-card h3{color:#0f172a;margin:0 0 1rem}.filters-bar{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.search-input-wrapper{display:flex;align-items:center;gap:.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem 1rem;flex:1;min-width:200px;max-width:300px}.search-input-wrapper svg{color:#94a3b8}.search-input{border:none;background:transparent;outline:none;flex:1;font-size:.875rem;color:#0f172a}.search-input::placeholder{color:#94a3b8}.filter-select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:.875rem;color:#0f172a;outline:none;cursor:pointer}.filter-select:focus{border-color:#10b981}.dialog-overlay{position:fixed;inset:0;background:#00000080;z-index:100}.dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:16px;padding:1.5rem;max-width:400px;width:90%;z-index:101;box-shadow:0 25px 50px -12px #00000040}.dialog-title{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.dialog-message{color:#64748b;margin:0 0 1.5rem}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end}.excel-table-wrapper{overflow-x:auto;border-radius:0 0 12px 12px;background:#fff}.excel-table{width:100%;border-collapse:collapse;font-size:.8125rem}.excel-table th{position:sticky;top:0;background:linear-gradient(to bottom,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;text-align:left;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#475569;padding:0;z-index:10}.excel-th-content{display:flex;flex-direction:column;min-width:80px}.excel-th-label{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 6px;cursor:pointer;transition:background .2s}.excel-th-label:hover{background:#e2e8f0}.excel-th-label span{display:flex;align-items:center;gap:4px}.excel-filter-input{width:100%;padding:6px 10px;border:none;border-top:1px solid #e2e8f0;background:#fff;font-size:.75rem;color:#334155;outline:none;transition:background .2s}.excel-filter-input:focus{background:#fffbeb;box-shadow:inset 0 1px 3px #0000000d}.excel-filter-input::placeholder{color:#94a3b8;font-style:italic}.excel-table td{padding:12px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.excel-table tbody tr{transition:background .15s ease}.excel-table tbody tr:hover{background:#f0fdf4!important}.excel-table tbody tr:nth-child(2n){background:#fafafa}.excel-table tbody tr:nth-child(2n):hover{background:#f0fdf4!important}.cell-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase}.badge-draft{background:#f1f5f9;color:#64748b}.badge-approved{background:#dcfce7;color:#15803d}.badge-material{background:#dbeafe;color:#1e40af}.badge-labor{background:#fef3c7;color:#b45309}.badge-equipment{background:#ede9fe;color:#7c3aed}.excel-actions{display:flex;gap:4px;justify-content:center}.excel-action-btn{padding:6px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#64748b;transition:all .2s}.excel-action-btn:hover{background:#f1f5f9;color:#0f172a}.excel-action-btn.delete:hover{background:#fee2e2;color:#dc2626}.excel-no-data{text-align:center;padding:40px 20px;color:#94a3b8}.excel-no-data svg{margin:0 auto 12px;opacity:.5}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.card-header h3{margin:0;font-size:.875rem;font-weight:700;color:#0f172a}.card-content{padding:1.25rem}.text-slate-400{color:#94a3b8}.text-blue-600{color:#2563eb}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.btn-warning{background:#d97706;color:#fff}.btn-warning:hover{background:#b45309}.mobile-vendor-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--slate-100)}.mobile-action-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid var(--slate-200);background:#fff;border-radius:8px;font-size:11px;font-weight:600;color:var(--slate-600);cursor:pointer;transition:all .15s ease}.mobile-action-btn:active{transform:scale(.95)}.mobile-action-btn.success{border-color:var(--success-200);color:var(--success-600);background:var(--success-50)}.mobile-action-btn.warning{border-color:var(--warning-200);color:var(--warning-600);background:var(--warning-50)}.mobile-action-btn.danger{border-color:var(--error-200);color:var(--error-600);background:var(--error-50)}.mobile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--slate-500);gap:12px}@media(max-width:767px){.excel-table-wrapper,.excel-table,.stats-grid{display:none}.dialog{inset:auto 0 0;transform:none;width:100%;max-width:100%;border-radius:20px 20px 0 0;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))}.dialog-actions{flex-direction:column-reverse}.dialog-actions .btn{width:100%;justify-content:center}}.procurement-page{width:100%}.procurement-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-4);border-bottom:2px solid var(--slate-200);padding-bottom:0}.procurement-tab{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;color:var(--slate-500);font-weight:600;cursor:pointer;transition:all .2s}.procurement-tab:hover{color:var(--slate-700);background:var(--slate-50)}.procurement-tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);background:transparent}.tab-badge{padding:2px 8px;font-size:.75rem;font-weight:700;border-radius:var(--radius-full);background:var(--slate-100);color:var(--slate-600)}.tab-badge-alert{background:var(--error-500);color:#fff;animation:pulse-badge 2s infinite}.pending-requests-section{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--slate-200);overflow:hidden}.section-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--slate-100);background:linear-gradient(to right,#f0fdf4,#dcfce7)}.section-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--slate-800)}.section-header p{margin:var(--spacing-1) 0 0;font-size:.8125rem;color:var(--slate-500)}.empty-state-sm{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8) var(--spacing-4);text-align:center;gap:var(--spacing-2)}.empty-state-sm p{font-weight:600;color:var(--slate-600);margin:0}.empty-state-sm span{font-size:.875rem}.table-row-highlight{background:linear-gradient(to right,rgba(34,197,94,.05),transparent)}.table-row-highlight:hover{background:linear-gradient(to right,#22c55e1a,#22c55e05)}.cell-with-code{display:flex;flex-direction:column}.code-sub{font-size:.75rem;font-family:SF Mono,Monaco,monospace;color:var(--slate-400)}.item-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:var(--slate-100);border-radius:var(--radius-full);font-size:.8125rem;font-weight:600}.project-groups{display:flex;flex-direction:column;gap:var(--spacing-3)}.project-group{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--slate-200);overflow:hidden}.project-group-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3) var(--spacing-4);background:var(--slate-50);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.project-group-header:hover{background:var(--slate-100)}.project-group-left{display:flex;align-items:center;gap:var(--spacing-3)}.project-icon{color:var(--primary-500)}.project-code{font-family:SF Mono,Monaco,monospace;font-weight:700;font-size:.875rem;color:var(--primary-600);background:var(--primary-50);padding:2px 8px;border-radius:var(--radius-md)}.project-name{font-weight:600;color:var(--slate-700)}.project-group-stats{display:flex;align-items:center;gap:var(--spacing-4)}.po-count{font-size:.8125rem;color:var(--slate-500);font-weight:500}.po-total{font-weight:700;font-size:.9375rem;color:var(--slate-800)}.project-group-content{border-top:1px solid var(--slate-100)}.project-group-content .data-table{margin:0;border-radius:0}.project-group-content .data-table thead{background:var(--slate-25, #fafafa)}.actions-right{display:flex;gap:var(--spacing-2)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) var(--spacing-4);gap:var(--spacing-3);color:var(--slate-500)}.spinner{width:32px;height:32px;border:3px solid var(--slate-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}.actions-bar{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-4);margin-bottom:var(--spacing-4);flex-wrap:wrap}.tabs .tab{display:flex;align-items:center;gap:var(--spacing-2)}.drawer-wide{width:640px}.form-section{margin-bottom:var(--spacing-6)}.line-items-table{margin-bottom:var(--spacing-4);overflow-x:auto}.data-table-compact{font-size:.8125rem}.data-table-compact th,.data-table-compact td{padding:var(--spacing-2) var(--spacing-3)}.form-input-sm{padding:var(--spacing-1) var(--spacing-2);font-size:.8125rem;min-width:80px}.form-input-number{width:80px;text-align:right}.line-item-amount{font-weight:600;text-align:right;white-space:nowrap}.po-summary{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-4);background:var(--slate-50);border-radius:var(--radius-lg);margin-top:var(--spacing-4)}.summary-row{display:flex;justify-content:space-between;font-size:.875rem;color:var(--slate-600)}.summary-total{font-size:1rem;font-weight:700;color:var(--slate-800);padding-top:var(--spacing-2);border-top:1px solid var(--slate-200);margin-top:var(--spacing-2)}.po-detail-page{width:100%}.po-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-6);gap:var(--spacing-4)}.po-detail-title-row{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.po-detail-title{font-size:1.5rem;font-weight:800;color:var(--slate-800);margin:0;font-family:SF Mono,Monaco,monospace}.po-detail-meta{display:flex;align-items:center;gap:var(--spacing-4);flex-wrap:wrap}.po-total{text-align:right}.po-total-label{display:block;font-size:.75rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.po-total-value{display:block;font-size:1.5rem;font-weight:800;color:var(--primary-600)}.po-actions{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap}.po-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-6);margin-bottom:var(--spacing-6)}@media(max-width:1024px){.po-detail-grid{grid-template-columns:1fr}}.item-name-cell{display:flex;flex-direction:column}.item-code,.item-unit{font-size:.75rem;color:var(--slate-500)}.card-count{background:var(--slate-100);color:var(--slate-600);font-size:.75rem;font-weight:600;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full)}.grn-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.grn-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);background:var(--slate-50);border-radius:var(--radius-md)}.grn-info{display:flex;flex-direction:column}.grn-number{font-weight:600;font-size:.875rem;color:var(--slate-800)}.grn-date{font-size:.75rem;color:var(--slate-500)}.grn-site{font-size:.75rem;color:var(--slate-600)}.pending-items{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--slate-100)}.pending-items-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--warning-600);margin:0 0 var(--spacing-3)}.pending-item{display:flex;justify-content:space-between;padding:var(--spacing-2) 0;font-size:.875rem;border-bottom:1px solid var(--slate-100)}.pending-item:last-child{border-bottom:none}.pending-qty{font-weight:600;color:var(--warning-600)}.grn-items-table{overflow-x:auto}.text-center{text-align:center}.text-success{color:var(--success-600);font-weight:600}.drawer-subtitle{font-size:.875rem;color:var(--slate-500);margin:var(--spacing-1) 0 0}.form-warning-banner{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--warning-50);border:1px solid var(--warning-200);border-radius:var(--radius-lg);color:var(--warning-700);font-size:.875rem;margin-bottom:var(--spacing-4)}.form-error-inline{padding:var(--spacing-2);color:var(--error-600);font-size:.875rem;margin-bottom:var(--spacing-2)}.info-banner{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4);font-size:.875rem}.info-banner svg{flex-shrink:0;margin-top:2px}.info-banner-warning{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.info-banner-info{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.info-banner-success{background:#dcfce7;border:1px solid #86efac;color:#166534}.part-number-tag{display:inline-block;padding:.2rem .5rem;background:linear-gradient(135deg,#dbeafe,#e0e7ff);color:#3b82f6;font-size:.7rem;font-weight:600;font-family:SF Mono,Monaco,monospace;border-radius:4px;border:1px solid #93c5fd}@media(max-width:767px){.procurement-page{padding-bottom:20px}.procurement-tabs{margin:0 -12px;padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.procurement-tabs::-webkit-scrollbar{display:none}.procurement-tab{padding:.625rem 1rem;font-size:.8125rem;white-space:nowrap}.project-group-header{flex-direction:column;align-items:flex-start;gap:.5rem}.project-group-stats{flex-wrap:wrap}.project-code{font-size:.75rem}.project-name{font-size:.875rem}.po-detail-header{flex-direction:column;gap:1rem}.po-detail-title{font-size:1.125rem}.po-detail-title-row{flex-wrap:wrap}.po-detail-meta{gap:.75rem}.po-total{text-align:left}.po-total-value{font-size:1.25rem}.po-actions{flex-direction:column;gap:.5rem}.po-actions .btn{width:100%;justify-content:center}.po-detail-grid{grid-template-columns:1fr}.actions-bar{flex-direction:column;gap:.75rem}.actions-bar .btn{width:100%;justify-content:center}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem;padding:1rem}.section-header h3{font-size:.875rem}.section-header p{font-size:.75rem}.line-items-table{overflow-x:auto}.data-table-compact th,.data-table-compact td{padding:var(--spacing-1) var(--spacing-2);font-size:.75rem}.po-summary{padding:1rem;margin:0 -12px;width:calc(100% + 24px);border-radius:0}.grn-item{flex-direction:column;align-items:flex-start;gap:.5rem}.info-banner{font-size:.8125rem;padding:.875rem}.form-section{margin-bottom:1.25rem}.form-section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.drawer-wide{width:100%}}@media(max-width:359px){.procurement-tab{padding:.5rem .75rem;font-size:.75rem}.po-detail-title{font-size:1rem}}.inventory-page{width:100%}.tabs-container{margin-bottom:1rem}.tabs{display:flex;gap:.5rem;border-bottom:2px solid #e2e8f0;padding-bottom:0}.tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;font-size:.875rem;font-weight:600;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.tab:hover{color:#0f172a;background:#f8fafc}.tab.active{color:#16a34a;border-bottom-color:#16a34a}.tab.active svg{color:#16a34a}.inventory-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:1024px){.inventory-grid{grid-template-columns:1fr}}.filters-bar{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.search-box{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;max-width:300px}.search-box input::placeholder{color:#94a3b8}.excel-table .empty-row{text-align:center;color:#94a3b8;padding:2rem!important}.part-number-badge{display:inline-block;padding:.25rem .625rem;background:linear-gradient(135deg,#dbeafe,#e0e7ff);color:#3b82f6;font-size:.75rem;font-weight:600;font-family:SF Mono,Monaco,monospace;border-radius:4px;border:1px solid #93c5fd}.text-muted{color:#94a3b8}.category-badge{display:inline-block;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:100px;background:#e2e8f0;color:#475569}.category-badge.cement{background:#dbeafe;color:#1d4ed8}.category-badge.steel{background:#fef3c7;color:#b45309}.category-badge.sand{background:#fef9c3;color:#a16207}.category-badge.aggregate{background:#e0e7ff;color:#4338ca}.category-badge.brick{background:#fee2e2;color:#b91c1c}.category-badge.electrical{background:#ddd6fe;color:#7c3aed}.category-badge.plumbing{background:#cffafe;color:#0891b2}.category-badge.paint{background:#fbcfe8;color:#be185d}.category-badge.wood{background:#fde68a;color:#92400e}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:100px}.btn-icon{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#64748b;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#f1f5f9;color:#16a34a}.low-qty{color:#d97706!important;font-weight:600}.text-warning{color:#d97706}.text-warning svg{color:#d97706}.text-success{color:#16a34a}.link-btn{background:none;border:none;padding:0;font-size:inherit;color:#16a34a;cursor:pointer;text-align:left;font-weight:500}.link-btn:hover{text-decoration:underline}.empty-state-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:#94a3b8}.empty-state-inline svg{margin-bottom:.75rem;opacity:.5}.empty-state-inline h4{margin:0;font-size:1rem;font-weight:600;color:#64748b}.empty-state-inline p{margin:.25rem 0 0;font-size:.875rem}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#dc2626}.error-state svg{margin-bottom:.5rem}.error-state p{margin:0 0 .75rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#64748b}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0}.card-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:700;color:#0f172a}.card-title svg{color:#64748b}.card-content{padding:0}.page-header-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:1rem}.breadcrumb-link{display:flex;align-items:center;gap:.25rem;color:#64748b;text-decoration:none}.breadcrumb-link:hover{color:#16a34a}.breadcrumb-separator{color:#cbd5e1}.breadcrumb-current{display:flex;align-items:center;gap:.25rem;color:#0f172a;font-weight:500}.tab-badge{padding:2px 8px;font-size:.75rem;font-weight:700;border-radius:100px;background:#e2e8f0;color:#64748b;margin-left:4px}.tab-badge-alert{background:#dc2626;color:#fff;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}.card-count{padding:4px 10px;font-size:.75rem;font-weight:600;border-radius:100px;background:#f1f5f9;color:#64748b}.grn-po-summary{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:12px;padding:1.25rem;margin-bottom:1.5rem}.grn-po-info{display:flex;gap:2.5rem;flex-wrap:wrap}.grn-po-detail{display:flex;flex-direction:column;gap:4px}.grn-po-detail .label{font-size:.75rem;font-weight:600;color:#16a34a;text-transform:uppercase;letter-spacing:.05em}.grn-po-detail .value{font-size:1rem;font-weight:700;color:#0f172a}.grn-items-table tbody td{padding:.75rem .5rem}.grn-items-table .form-input-sm{width:90px;text-align:center}.form-input-center{text-align:center!important}.input-rejected{border-color:#fca5a5!important}.input-rejected:focus{border-color:#dc2626!important;box-shadow:0 0 0 3px #dc262626}.row-filled{background:linear-gradient(to right,rgba(34,197,94,.08),transparent)}.row-filled td{border-bottom-color:#dcfce7}.accepted-value{display:inline-block;min-width:32px;padding:4px 8px;background:#f1f5f9;border-radius:6px;font-weight:600}.accepted-value.text-success{background:#dcfce7;color:#16a34a}.excel-table tfoot .summary-row td{padding:1rem;background:#f8fafc;border-top:2px solid #e2e8f0;font-size:.875rem}.form-actions-sticky{position:sticky;bottom:0;display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;background:#fff;border-top:1px solid #e2e8f0;margin:1.5rem -1.5rem -1.5rem;box-shadow:0 -4px 12px #0000000d}.error-state-full{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.error-state-full svg{color:#f59e0b;margin-bottom:1rem}.error-state-full h3{margin:0 0 .5rem;font-size:1.25rem;color:#0f172a}.error-state-full p{margin:0 0 1.5rem;color:#64748b}.form-warning-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin:.5rem 1rem;background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;color:#92400e;font-size:.875rem}.form-error-banner{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-bottom:1rem;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;color:#b91c1c;font-size:.875rem}.page-container{width:100%;max-width:100%;padding:1.5rem}.form-grid{display:grid;gap:1.5rem}.form-grid-3{grid-template-columns:repeat(3,1fr)}@media(max-width:768px){.form-grid-3{grid-template-columns:1fr}}.empty-state-sm{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;gap:.5rem}.empty-state-sm p{font-weight:600;color:#64748b;margin:0}.empty-state-sm span{font-size:.875rem;color:#94a3b8}.mobile-cards{display:none}.mobile-card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;padding:1rem;margin-bottom:.75rem}.mobile-card:active{background:#f8fafc}.mobile-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.mobile-card-title{font-weight:600;color:#0f172a;font-size:.9375rem;margin:0;line-height:1.3}.mobile-card-subtitle{font-size:.75rem;color:#64748b;margin-top:.25rem}.mobile-card-badge{flex-shrink:0}.mobile-card-row{display:flex;justify-content:space-between;padding:.5rem 0;border-top:1px solid #f1f5f9}.mobile-card-row:first-of-type{border-top:none}.mobile-card-label{font-size:.75rem;color:#64748b;font-weight:500}.mobile-card-value{font-size:.8125rem;color:#0f172a;font-weight:500;text-align:right}.mobile-card-value.mono{font-family:SF Mono,Monaco,monospace}.mobile-card-value.success{color:#16a34a}.mobile-card-value.warning{color:#d97706}.mobile-card-value.danger{color:#dc2626}.mobile-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #f1f5f9}.mobile-card-action{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:#f1f5f9;border:none;border-radius:6px;font-size:.75rem;font-weight:600;color:#16a34a;cursor:pointer}.mobile-card-action:hover{background:#e2e8f0}@media(max-width:767px){.inventory-page{padding-bottom:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.stat-card{padding:.875rem;flex-direction:column;align-items:flex-start;gap:.5rem}.stat-card-icon{width:36px;height:36px}.stat-card-value{font-size:1.25rem}.stat-card-label{font-size:.6875rem}.tabs-container{margin:0 -12px;padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs-container::-webkit-scrollbar{display:none}.tabs{flex-wrap:nowrap;min-width:max-content}.tab{padding:.625rem .875rem;font-size:.75rem;white-space:nowrap}.tab svg{width:14px;height:14px}.inventory-grid{grid-template-columns:1fr;gap:1rem}.filters-bar{flex-direction:column;gap:.75rem;padding:.875rem}.search-box{max-width:none;width:100%}.search-box input{font-size:16px}.filter-group{width:100%}.filter-select{width:100%;font-size:16px}.filter-results{margin-left:0;font-size:.75rem}.mobile-cards{display:block;padding:.75rem}.table-container,.excel-table{display:none}.card{margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none}.card-header{padding:.875rem 1rem}.card-title{font-size:.8125rem}.empty-state-inline{padding:1.5rem}.empty-state-inline svg{width:32px;height:32px}.empty-state-inline h4{font-size:.875rem}.empty-state-inline p{font-size:.75rem}.loading-state{padding:2rem}.page-header-actions{flex-direction:column;gap:.5rem}.page-header-actions .btn{width:100%;justify-content:center}.grn-po-summary{padding:1rem;margin-bottom:1rem}.grn-po-info{gap:1rem}.grn-po-detail .label{font-size:.625rem}.grn-po-detail .value{font-size:.875rem}.form-actions-sticky{padding:1rem;flex-direction:column-reverse;gap:.5rem}.form-actions-sticky .btn{width:100%;justify-content:center}}@media(max-width:359px){.stats-grid{grid-template-columns:1fr 1fr}.stat-card{padding:.75rem}.stat-card-value{font-size:1.125rem}}@media(max-height:500px)and (orientation:landscape){.stats-grid{grid-template-columns:repeat(4,1fr)}.stat-card{flex-direction:row;align-items:center;padding:.75rem}}.material-transfers-page{padding:1.5rem;width:100%;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header-content h1{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--slate-800);margin:0}.page-header-content p{font-size:.875rem;color:var(--slate-500);margin:.25rem 0 0}.transfer-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.transfer-stat{background:#fff;border-radius:12px;padding:1rem 1.25rem;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;gap:.25rem}.transfer-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--slate-800)}.transfer-stat .stat-label{font-size:.75rem;color:var(--slate-500)}.transfer-stat.pending{border-left:4px solid #f59e0b}.transfer-stat.transit{border-left:4px solid #8b5cf6}.transfer-stat.completed{border-left:4px solid #10b981}.filters-bar{display:flex;gap:.75rem;margin-bottom:1.5rem}.filter-select{padding:.625rem 1rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem;color:var(--slate-700);background:#fff;min-width:150px}.transfers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1rem}.transfer-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;cursor:pointer;transition:all .2s ease}.transfer-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.transfer-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.transfer-number{font-size:.95rem;font-weight:600;color:var(--slate-700)}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:100px;font-size:.7rem;font-weight:600;text-transform:uppercase}.status-badge.slate{background:var(--slate-100);color:var(--slate-600)}.status-badge.amber{background:#f59e0b1a;color:#d97706}.status-badge.blue{background:#3b82f61a;color:#2563eb}.status-badge.purple{background:#8b5cf61a;color:#7c3aed}.status-badge.cyan{background:#06b6d41a;color:#0891b2}.status-badge.emerald{background:#10b9811a;color:#059669}.status-badge.red{background:#ef44441a;color:#dc2626}.transfer-route{display:flex;align-items:center;justify-content:space-between;padding:.875rem 0;border-top:1px solid var(--slate-100);border-bottom:1px solid var(--slate-100);margin-bottom:.75rem}.site-info{display:flex;align-items:center;gap:.5rem}.site-info>svg{color:var(--slate-400)}.site-info div{display:flex;flex-direction:column}.site-label{font-size:.65rem;color:var(--slate-400);text-transform:uppercase;letter-spacing:.025em}.site-name{font-size:.875rem;font-weight:600;color:var(--slate-700)}.route-arrow{color:var(--primary-500)}.transfer-meta{display:flex;gap:1rem;margin-bottom:.75rem}.meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:var(--slate-500)}.transfer-actions{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--slate-100)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem;background:#fff;border-radius:12px;text-align:center}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--slate-700);margin:0}.loading-state{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--slate-500)}@media(max-width:1024px){.transfer-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.transfer-stats{grid-template-columns:1fr 1fr}.filters-bar{flex-wrap:wrap}.transfers-grid{grid-template-columns:1fr}}.stock-alerts-widget{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.stock-alerts-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--slate-100)}.stock-alerts-header h3{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:var(--slate-700);margin:0}.alert-count{background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;padding:.125rem .5rem;border-radius:100px}.stock-alerts-list{max-height:300px;overflow-y:auto}.stock-alert-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid var(--slate-50)}.stock-alert-item:last-child{border-bottom:none}.alert-level-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}.alert-level-icon.critical{background:#ef44441a;color:#ef4444}.alert-level-icon.low{background:#f59e0b1a;color:#f59e0b}.alert-level-icon.out{background:#ef444426;color:#dc2626}.stock-alert-info{flex:1}.stock-alert-material{font-size:.875rem;font-weight:600;color:var(--slate-700)}.stock-alert-site{font-size:.75rem;color:var(--slate-500)}.stock-alert-qty{font-size:.875rem;font-weight:600}.stock-alert-qty.critical{color:#ef4444}.stock-alert-qty.low{color:#f59e0b}.create-transfer-page,.transfer-detail-page{padding:1.5rem;width:100%}.transfer-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.form-section h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--slate-700);margin:0 0 1rem;padding-bottom:.75rem;border-bottom:1px solid var(--slate-100)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-group label{font-size:.75rem;font-weight:600;color:var(--slate-500);text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{padding:.625rem .875rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem;color:var(--slate-700);background:#fff}.transfer-route-form{display:flex;align-items:center;gap:1.5rem}.route-site{flex:1;display:flex;gap:1rem;align-items:flex-start}.route-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.route-icon.from{background:#ef44441a;color:#ef4444}.route-icon.to{background:#10b9811a;color:#10b981}.route-site .form-group{flex:1}.transfer-route-form .route-arrow{color:var(--slate-400)}.add-material-row{display:flex;gap:.75rem;margin-bottom:1rem}.material-select{flex:1;padding:.625rem .875rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem}.items-table{width:100%;border-collapse:collapse}.items-table th,.items-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--slate-100)}.items-table th{font-size:.75rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;background:var(--slate-50)}.items-table tfoot td{font-weight:600;background:var(--slate-50)}.qty-input,.rate-input{width:80px;padding:.5rem;border:1px solid var(--slate-200);border-radius:6px;font-size:.875rem;text-align:right}.value-cell{text-align:right;font-weight:500}.empty-items{display:flex;flex-direction:column;align-items:center;padding:2rem;color:var(--slate-400);text-align:center}.empty-items p{margin:.5rem 0 0;font-size:.875rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem}.transfer-detail-page .page-header{gap:1rem}.header-title-row{display:flex;align-items:center;gap:1rem}.header-title-row h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--slate-800)}.status-badge.large{padding:.375rem 1rem;font-size:.75rem}.transfer-detail-content{display:flex;flex-direction:column;gap:1.5rem}.detail-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.detail-card h3{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--slate-700);margin:0 0 1rem}.route-card{background:linear-gradient(135deg,var(--slate-50) 0%,white 100%)}.route-display{display:flex;align-items:center;justify-content:space-between}.route-display .route-site{flex:1;display:flex;align-items:center;gap:1rem}.route-display .route-icon{width:48px;height:48px;border-radius:12px}.route-info{display:flex;flex-direction:column}.route-label{font-size:.65rem;font-weight:600;color:var(--slate-400);text-transform:uppercase}.route-name{font-size:1rem;font-weight:600;color:var(--slate-800)}.route-code{font-size:.75rem;color:var(--slate-500)}.route-arrow-large{color:var(--primary-500);padding:0 2rem}.info-grid{display:flex;gap:2rem;flex-wrap:wrap;background:#fff;padding:1.25rem 1.5rem;border-radius:12px;box-shadow:0 1px 3px #00000014}.info-item{display:flex;align-items:center;gap:.75rem}.info-item>svg{color:var(--slate-400)}.info-item>div{display:flex;flex-direction:column}.info-label{font-size:.7rem;font-weight:600;color:var(--slate-400);text-transform:uppercase}.info-value{font-size:.95rem;font-weight:600;color:var(--slate-700)}.info-value.lg{font-size:1.125rem;color:var(--primary-600)}.items-detail-table{width:100%;border-collapse:collapse;font-size:.875rem}.items-detail-table th,.items-detail-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--slate-100)}.items-detail-table th{font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;background:var(--slate-50)}.transport-info{display:flex;gap:2rem}.transport-item{display:flex;flex-direction:column;gap:.25rem}.transport-label{font-size:.7rem;font-weight:600;color:var(--slate-400);text-transform:uppercase}.transport-value{font-size:.95rem;font-weight:500;color:var(--slate-700)}.timeline{display:flex;flex-direction:column;gap:1rem;padding-left:1rem}.timeline-item{display:flex;gap:1rem;position:relative}.timeline-item:before{content:"";position:absolute;left:5px;top:20px;bottom:-1rem;width:2px;background:var(--slate-200)}.timeline-item:last-child:before{display:none}.timeline-marker{width:12px;height:12px;border-radius:50%;background:var(--slate-300);flex-shrink:0;margin-top:4px}.timeline-item.completed .timeline-marker{background:var(--primary-500)}.timeline-title{font-weight:600;color:var(--slate-700)}.timeline-meta{font-size:.8rem;color:var(--slate-500);margin-left:.5rem}.modal{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal.modal-sm{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--slate-100)}.modal-header h2{font-size:1.125rem;font-weight:600;color:var(--slate-800);margin:0}.modal-close{background:none;border:none;color:var(--slate-400);cursor:pointer;padding:.25rem;border-radius:4px}.modal-close:hover{color:var(--slate-600);background:var(--slate-100)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--slate-100);background:var(--slate-50)}.receive-table{width:100%;border-collapse:collapse}.receive-table th,.receive-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--slate-100)}.receive-table th{font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;background:var(--slate-50)}.error-state{display:flex;flex-direction:column;align-items:center;padding:4rem;text-align:center}.error-state svg{color:var(--slate-300);margin-bottom:1rem}.error-state h3{font-size:1.125rem;font-weight:600;color:var(--slate-700);margin:0 0 1rem}.transfers-table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.transfers-table{width:100%;border-collapse:collapse;font-size:.875rem}.transfers-table thead{background:linear-gradient(135deg,var(--slate-50) 0%,#f8fafc 100%)}.transfers-table th{padding:1rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--slate-200)}.transfers-table tbody tr{cursor:pointer;transition:all .15s ease}.transfers-table tbody tr:hover{background:#6366f10a}.transfers-table td{padding:1rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100);vertical-align:middle}.transfer-number-cell .transfer-number{display:block;font-weight:600;color:var(--primary-600)}.transfer-number-cell .vehicle-info{display:flex;align-items:center;gap:.375rem;font-size:.7rem;color:var(--slate-500);margin-top:.25rem}.date-cell svg,.site-cell svg,.items-cell svg{display:inline-block;vertical-align:middle;margin-right:.375rem}.date-cell{color:var(--slate-600);white-space:nowrap}.site-cell{font-size:.85rem}.site-cell .from-icon{color:#ef4444}.site-cell .to-icon{color:#10b981}.project-cell{font-size:.8rem;color:var(--slate-600);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.items-cell{font-weight:600;color:var(--slate-700)}.actions-cell{white-space:nowrap}.actions-cell .btn{margin-right:.375rem}.completed-label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;color:#10b981}.btn-xs{padding:.375rem .75rem;font-size:.7rem;border-radius:6px}@media(max-width:1200px){.transfers-table-container{overflow-x:auto}.transfers-table{min-width:900px}}@media(max-width:768px){.transfers-table th,.transfers-table td{padding:.75rem .5rem}.transfers-table{font-size:.8rem}}.labour-page{width:100%}.trade-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--slate-100);color:var(--slate-700);font-size:.75rem;font-weight:500;border-radius:var(--radius-md);text-transform:capitalize}.attendance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.site-attendance-section{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-xl);padding:var(--spacing-6)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.section-title{display:flex;align-items:center;gap:var(--spacing-2);font-size:1rem;font-weight:700;color:var(--slate-800);margin:0}.site-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--slate-100)}.bulk-action-bar{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--slate-50);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;font-size:.875rem;color:var(--slate-700)}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.attendance-mark-table{max-height:calc(100vh - 400px);overflow-y:auto}.row-disabled{opacity:.5;background:var(--slate-50)}.worker-cell{display:flex;flex-direction:column}.worker-name{font-weight:500;color:var(--slate-800)}.worker-trade{font-size:.75rem;color:var(--slate-500);text-transform:capitalize}.worker-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.summary-card{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center}.summary-label{display:block;font-size:.75rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-1)}.summary-value{display:block;font-size:1.5rem;font-weight:800;color:var(--slate-800)}.overtime-badge{display:inline-block;margin-left:var(--spacing-2);padding:var(--spacing-0) var(--spacing-1);background:var(--info-100);color:var(--info-700);font-size:.625rem;font-weight:600;border-radius:var(--radius-sm)}.table-cell-trade{font-size:.75rem;text-transform:capitalize;color:var(--slate-600)}.labour-tabs-container{margin-bottom:1.5rem}.labour-tabs{display:flex;gap:.5rem;background:#f1f5f9;padding:.5rem;border-radius:12px;overflow-x:auto}.labour-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-radius:8px;font-size:.875rem;font-weight:600;color:#64748b;white-space:nowrap;cursor:pointer;transition:all .2s}.labour-tab:hover{background:#fff;color:#334155}.labour-tab-active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card-compact{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem}.stat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px}.stat-info .stat-value{font-size:1.5rem;font-weight:800;color:#0f172a}.stat-info .stat-label{font-size:.75rem;color:#64748b;font-weight:500}.actions-bar{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-width:200px}.search-box input{flex:1;border:none;outline:none;background:transparent;font-size:.875rem}.gangs-grid{display:flex;flex-direction:column;gap:2rem}.trade-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}.trade-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.trade-indicator{width:8px;height:24px;border-radius:4px}.trade-header h3{margin:0;font-size:1rem;font-weight:700;color:#0f172a}.trade-count{margin-left:auto;font-size:.75rem;color:#64748b;background:#f1f5f9;padding:.25rem .75rem;border-radius:100px}.gang-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.gang-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:1rem;cursor:pointer;transition:all .2s;position:relative}.gang-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f614}.gang-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.gang-avatar{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center}.gang-info{flex:1}.gang-info h4{margin:0;font-size:.95rem;font-weight:600;color:#0f172a}.gang-code{font-size:.7rem;color:#64748b;font-family:SF Mono,Monaco,monospace}.gang-arrow{color:#94a3b8;opacity:0;transition:opacity .2s}.gang-card:hover .gang-arrow{opacity:1}.gang-card-body{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.gang-stat{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#64748b}.gang-rate{font-weight:600;color:#16a34a}.gang-status{position:absolute;top:.75rem;right:.75rem;font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:100px;display:flex;align-items:center;gap:.25rem}.gang-deployed{background:#fef3c7;color:#d97706}.gang-available{background:#dcfce7;color:#16a34a}.week-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.week-display{display:flex;flex-direction:column;align-items:center}.week-label{font-size:.7rem;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.week-dates{font-size:1.25rem;font-weight:700;color:#0f172a}.planning-stats{display:flex;align-items:center;justify-content:center;gap:2rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 2rem;margin-bottom:1.5rem}.planning-stat{display:flex;flex-direction:column;align-items:center}.planning-stat-value{font-size:2rem;font-weight:800;color:#0f172a}.planning-stat-label{font-size:.75rem;color:#64748b}.planning-alert{display:flex;align-items:center;gap:.5rem;background:#fee2e2;color:#dc2626;padding:.5rem 1rem;border-radius:100px;font-size:.75rem;font-weight:600}.planning-matrix{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.matrix-header,.matrix-row{display:grid;grid-template-columns:200px repeat(10,1fr) 80px}.matrix-header{background:#f8fafc;border-bottom:2px solid #e2e8f0}.matrix-header>div{padding:.75rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#64748b;text-align:center;border-right:1px solid #e2e8f0}.matrix-project-col{text-align:left!important;padding-left:1rem!important}.matrix-row{border-bottom:1px solid #f1f5f9}.matrix-row:hover{background:#f8fafc}.matrix-row>div{padding:.75rem .5rem;font-size:.8rem;text-align:center;border-right:1px solid #f1f5f9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.matrix-cell-empty{color:#cbd5e1}.matrix-cell-pending{background:#fef3c7}.matrix-cell-partially-filled{background:#dbeafe}.matrix-cell-fulfilled{background:#dcfce7}.matrix-cell-shortage{background:#fee2e2}.cell-count{font-weight:700;color:#0f172a}.cell-planned{font-size:.65rem;color:#64748b}.cell-icon{opacity:.6}.matrix-cell-total{font-weight:700;background:#f1f5f9}.matrix-cell-grand-total{font-size:1rem;color:#0f172a}.matrix-row-total{background:#f8fafc;border-top:2px solid #e2e8f0}.project-code{font-size:.7rem;font-family:SF Mono,Monaco,monospace;color:#3b82f6;display:block}.project-name{font-weight:600;color:#0f172a;display:block;font-size:.8rem}.deployment-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.deployment-stat{display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.5rem}.deployment-stat.active{border-color:#16a34a;background:linear-gradient(135deg,#dcfce7,#f0fdf4);color:#16a34a}.deployment-stat.planned{border-color:#3b82f6;background:linear-gradient(135deg,#dbeafe,#eff6ff);color:#3b82f6}.deployment-projects{display:flex;flex-direction:column;gap:1.5rem}.deployment-project-group{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.project-group-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b}.project-group-header .project-code{font-weight:700;color:#3b82f6}.project-group-header .project-name{color:#0f172a}.project-group-header .deployment-count{margin-left:auto;font-size:.75rem;color:#64748b}.deployment-cards{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.deployment-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s}.deployment-card:hover{border-color:#3b82f6}.deployment-card-left{display:flex;align-items:center;gap:.75rem;flex:1}.deployment-avatar{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.deployment-info h4{margin:0;font-size:.9rem;font-weight:600;color:#0f172a}.deployment-type{font-size:.7rem;color:#64748b}.deployment-activity{display:block;font-size:.75rem;color:#3b82f6}.deployment-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.deployment-dates{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#64748b}.deployment-status{display:flex;align-items:center;gap:.25rem;font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:100px}.deployment-arrow{color:#94a3b8}.contractor-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.contractor-stat{display:flex;align-items:center;gap:.75rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.5rem;color:#64748b}.view-toggle-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.view-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:.25rem}.toggle-btn{padding:.5rem 1.25rem;border:none;background:transparent;font-size:.875rem;font-weight:600;color:#64748b;border-radius:6px;cursor:pointer;transition:all .2s}.contractors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.contractor-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:all .2s}.contractor-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f614}.contractor-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.contractor-avatar{width:44px;height:44px;background:linear-gradient(135deg,#dbeafe,#e0e7ff);color:#3b82f6;border-radius:10px;display:flex;align-items:center;justify-content:center}.contractor-info h4{margin:0;font-size:.95rem;font-weight:600;color:#0f172a}.contractor-code{font-size:.7rem;color:#64748b;font-family:SF Mono,Monaco,monospace}.status-badge{margin-left:auto;font-size:.65rem;font-weight:600;padding:.2rem .5rem;border-radius:100px}.status-active{background:#dcfce7;color:#16a34a}.status-inactive{background:#f1f5f9;color:#64748b}.contractor-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem}.contractor-contact{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#475569}.contractor-trades{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.trade-tag{font-size:.65rem;font-weight:600;padding:.2rem .5rem;background:#f1f5f9;color:#64748b;border-radius:4px}.trade-more{background:#dbeafe;color:#3b82f6}.contractor-gstin{font-size:.7rem;color:#94a3b8;margin-top:.25rem}.contractor-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;background:#f8fafc;border-top:1px solid #e2e8f0}.contract-count{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#64748b}.contracts-list{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.contract-row{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .2s}.contract-row:hover{background:#f8fafc}.contract-main{flex:1}.contract-number{font-size:.7rem;font-family:SF Mono,Monaco,monospace;color:#3b82f6;font-weight:600}.contract-details{display:flex;align-items:center;gap:.75rem}.contract-details .contractor-name{font-weight:600;color:#0f172a}.contract-details .project-name{font-size:.75rem;color:#64748b;display:flex;align-items:center;gap:.25rem}.contract-trades{display:flex;gap:.375rem}.contract-value{text-align:right}.value-amount{font-weight:700;color:#0f172a;display:block}.value-label{font-size:.65rem;color:#64748b}.contract-status .status-badge{text-transform:capitalize}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#64748b;gap:1rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#fff;border:2px dashed #e2e8f0;border-radius:12px;color:#64748b;text-align:center}.empty-state h3{margin:1rem 0 .5rem;color:#334155}.empty-state p{margin:0 0 1.5rem;color:#94a3b8}.btn-icon{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#f8fafc;color:#0f172a}.payroll-tab{display:flex;flex-direction:column;gap:1.5rem}.payroll-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.month-nav{display:flex;align-items:center;gap:1rem}.month-display{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#0f172a;min-width:200px;justify-content:center}.payroll-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.payroll-summary .summary-card{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem}.payroll-summary .summary-card.workers{border-left:4px solid #3b82f6;color:#3b82f6}.payroll-summary .summary-card.days{border-left:4px solid #8b5cf6;color:#8b5cf6}.payroll-summary .summary-card.overtime{border-left:4px solid #f59e0b;color:#f59e0b}.payroll-summary .summary-card.total{border-left:4px solid #16a34a;color:#16a34a;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.payroll-summary .summary-info{display:flex;flex-direction:column}.payroll-summary .summary-value{font-size:1.75rem;font-weight:800;color:#0f172a}.payroll-summary .summary-label{font-size:.75rem;color:#64748b;font-weight:500}.payroll-filters{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#f8fafc;border-radius:8px}.filter-results{margin-left:auto;font-size:.8rem;color:#64748b}.payroll-table-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.payroll-table{width:100%;border-collapse:collapse;font-size:.875rem}.payroll-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.payroll-table th{padding:.875rem 1rem;text-align:left;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;color:#64748b}.payroll-table td{padding:.875rem 1rem;border-bottom:1px solid #f1f5f9;vertical-align:middle}.payroll-table tbody tr:hover{background:#f8fafc}.payroll-table .text-right{text-align:right}.payroll-table .text-center{text-align:center}.payroll-table .font-mono{font-family:SF Mono,Monaco,monospace}.payroll-table .font-bold{font-weight:700}.payroll-table .worker-cell{display:flex;flex-direction:column}.payroll-table .worker-name{font-weight:600;color:#0f172a}.payroll-table .worker-phone{font-size:.7rem;color:#94a3b8}.payroll-table .overtime-badge{display:inline-block;padding:.15rem .5rem;background:#fef3c7;color:#d97706;border-radius:100px;font-size:.75rem;font-weight:600}.payroll-table .ot-amount{color:#f59e0b}.payroll-table .status-badge{display:inline-block;padding:.2rem .5rem;border-radius:100px;font-size:.65rem;font-weight:600}.payroll-table .status-pending{background:#fef3c7;color:#d97706}.payroll-table .status-paid{background:#dcfce7;color:#16a34a}.payroll-table tfoot{background:#f1f5f9;border-top:2px solid #e2e8f0}.payroll-table .totals-row td{padding:1rem;border:none}.payroll-table .grand-total{font-size:1.125rem;color:#16a34a}.payroll-table .empty-row{text-align:center;padding:3rem;color:#94a3b8}.payroll-actions{display:flex;justify-content:flex-end;gap:1rem}.btn-outline{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.btn-outline:hover{background:#f8fafc;border-color:#3b82f6;color:#3b82f6}.btn-success{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:8px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}@media(max-width:1024px){.payroll-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.payroll-summary{grid-template-columns:1fr}.payroll-header{flex-direction:column;gap:1rem}}.create-page{padding:0}.create-page .page-header{margin-bottom:1.5rem}.form-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden}.form-card form{display:flex;flex-direction:column}.form-card .form-section{padding:1.5rem 2rem;border-bottom:1px solid #f1f5f9}.form-card .form-section:last-of-type{border-bottom:none}.form-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.25rem 2rem;background:#f8fafc;border-top:1px solid #e2e8f0}.worker-selection{max-height:400px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:12px}.trade-group{border-bottom:1px solid #f1f5f9}.trade-group-header{padding:.75rem 1rem;background:#f8fafc;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.worker-option{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s}.worker-option:hover{background:#f1f5f9}.worker-option.leader{background:#fef3c7;border:1px solid #f59e0b}.worker-checkbox{width:20px;height:20px;border:2px solid #cbd5e1;border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s}.worker-option.selected .worker-checkbox{background:#3b82f6;border-color:#3b82f6}.worker-details{flex:1;display:flex;flex-direction:column;gap:.125rem}.worker-name{font-weight:600;color:#0f172a}.worker-wage{font-size:.75rem;color:#64748b}.leader-btn{padding:.375rem .75rem;border:1px solid #e2e8f0;border-radius:6px;background:#fff;font-size:.7rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.leader-btn:hover{border-color:#f59e0b;color:#f59e0b}.leader-btn.is-leader{background:#f59e0b;border-color:#f59e0b;color:#fff}.member-search{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:1rem;background:#f8fafc}.member-search input{flex:1;border:none;background:transparent;outline:none;font-size:.875rem}.no-workers{padding:2rem;text-align:center;color:#64748b}.selection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.selection-card{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s}.selection-card:hover{border-color:#3b82f6;background:#f8fafc}.selection-card.selected{border-color:#3b82f6;background:#dbeafe}.selection-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.selection-name{font-weight:600;color:#0f172a}.selection-meta{font-size:.75rem;color:#64748b}.assign-type-toggle{display:flex;gap:1rem}.toggle-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;font-weight:600;color:#64748b}.toggle-option:hover{border-color:#94a3b8}.toggle-option.active{border-color:#3b82f6;background:#dbeafe;color:#1d4ed8}.trades-selection{display:flex;flex-wrap:wrap;gap:.5rem}.trade-chip{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:20px;background:#fff;font-size:.8rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .2s}.trade-chip:hover{border-color:#3b82f6}.trade-chip.selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.worker-info-card{margin-top:1rem;padding:1rem;background:#f8fafc;border-radius:8px;display:flex;gap:2rem}.worker-info-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569}.worker-info-row strong{color:#0f172a}.emi-preview{display:flex;align-items:center;gap:.5rem;padding:1rem;background:#dcfce7;border-radius:8px;font-size:.875rem;color:#166534}.emi-amount{font-size:1.125rem;font-weight:700}.purpose-suggestions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.purpose-chip{padding:.375rem .75rem;border:1px solid #e2e8f0;border-radius:16px;background:#fff;font-size:.75rem;color:#64748b;cursor:pointer;transition:all .2s}.purpose-chip:hover{border-color:#f59e0b;color:#f59e0b}.purpose-chip.selected{background:#f59e0b;border-color:#f59e0b;color:#fff}@media(max-width:768px){.form-card .form-section{padding:1rem}.form-footer{flex-direction:column;padding:1rem}.form-footer .btn{width:100%;justify-content:center}.assign-type-toggle{flex-direction:column}.selection-grid{grid-template-columns:1fr}.worker-info-card{flex-direction:column;gap:.5rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px #00000040}.contractor-modal{max-width:700px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-title{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:700;color:#0f172a}.modal-close{width:36px;height:36px;border:none;background:#f1f5f9;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#64748b;cursor:pointer;transition:all .2s}.modal-close:hover{background:#e2e8f0;color:#0f172a}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc}.form-section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #f1f5f9}.form-group.full-width{grid-column:span 2}.form-group label{display:flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:600;color:#475569}.form-group input,.form-group textarea,.form-group select{padding:.625rem .875rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group textarea.error{border-color:#dc2626}.error-text{font-size:.7rem;color:#dc2626}.trades-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.trade-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.8rem;cursor:pointer;transition:all .2s}.trade-checkbox:hover{background:#f1f5f9}.trade-checkbox.selected{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8}.trade-checkbox input{margin:0}.btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-weight:600;color:#475569;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f8fafc}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.trades-grid{grid-template-columns:repeat(2,1fr)}}.payroll-summary-extended{display:flex;flex-direction:column;gap:1rem}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.payroll-summary-extended .summary-card{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem}.summary-card.gross{border-left:4px solid #3b82f6;color:#3b82f6}.deductions-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.deduction-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:.875rem 1.25rem}.deduction-card.pf{border-left:3px solid #ef4444}.deduction-card.esic{border-left:3px solid #f59e0b}.deduction-card.total-deductions{border-left:3px solid #64748b;background:#f8fafc}.deduction-card.net-payable{border-left:3px solid #16a34a;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.deduction-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.deduction-value{font-size:1rem;font-weight:800;color:#0f172a;font-family:SF Mono,Monaco,monospace}.deduction-card.net-payable .deduction-value{color:#16a34a;font-size:1.125rem}.deduction-col{background:#fef2f2!important}.deduction-amount{color:#dc2626;font-size:.8rem}.net-pay{color:#16a34a!important}.compliance-info{display:flex;gap:2rem;padding:.75rem 1.25rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.compliance-note{font-size:.75rem;color:#64748b}.compliance-note strong{color:#475569}@media(max-width:1024px){.summary-row,.deductions-summary{grid-template-columns:repeat(2,1fr)}.compliance-info{flex-direction:column;gap:.5rem}}.gang-modal{max-width:800px;max-height:90vh}.gang-form{max-height:65vh;overflow-y:auto}.member-count{font-size:.75rem;font-weight:500;color:#3b82f6;margin-left:.5rem}.member-search{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:1rem}.member-search input{flex:1;border:none;background:transparent;font-size:.875rem;outline:none}.worker-selection{max-height:300px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:10px}.trade-group{border-bottom:1px solid #e2e8f0}.trade-group:last-child{border-bottom:none}.trade-group-header{padding:.5rem 1rem;background:#f8fafc;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;position:sticky;top:0}.worker-list{padding:.5rem}.worker-option{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:8px;margin-bottom:.25rem;transition:all .2s}.worker-option:hover{background:#f8fafc}.worker-option.selected{background:#dbeafe}.worker-option.leader{background:#fef3c7;border:1px solid #fcd34d}.worker-checkbox{width:20px;height:20px;border:2px solid #e2e8f0;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.worker-option.selected .worker-checkbox{background:#3b82f6;border-color:#3b82f6;color:#fff}.worker-details{flex:1;display:flex;flex-direction:column}.worker-option .worker-name{font-weight:600;font-size:.875rem;color:#0f172a}.worker-wage{font-size:.7rem;color:#64748b;font-family:SF Mono,Monaco,monospace}.leader-btn{padding:.25rem .625rem;border:1px solid #e2e8f0;border-radius:100px;font-size:.65rem;font-weight:600;background:#fff;color:#64748b;cursor:pointer;transition:all .2s}.leader-btn:hover{border-color:#fcd34d;color:#d97706}.leader-btn.is-leader{background:linear-gradient(135deg,#fcd34d,#f59e0b);border-color:#f59e0b;color:#fff}.no-workers{padding:2rem;text-align:center;color:#94a3b8;font-size:.875rem}.advances-tab{display:flex;flex-direction:column;gap:1.5rem}.advance-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.advance-stat{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem}.advance-stat.pending{border-left:4px solid #f59e0b;color:#f59e0b}.advance-stat.active{border-left:4px solid #8b5cf6;color:#8b5cf6}.advance-stat.total{border-left:4px solid #3b82f6;color:#3b82f6}.advance-stat.balance{border-left:4px solid #dc2626;color:#dc2626}.advance-stat .stat-info{display:flex;flex-direction:column}.advance-stat .stat-value{font-size:1.5rem;font-weight:800;color:#0f172a}.advance-stat .stat-label{font-size:.7rem;color:#64748b;font-weight:500}.advances-list{display:flex;flex-direction:column;gap:1rem}.advance-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.advance-card-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid #f1f5f9}.advance-avatar{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center}.advance-info{flex:1}.advance-info h4{margin:0;font-size:1rem;font-weight:700;color:#0f172a}.advance-trade{font-size:.75rem;color:#64748b;text-transform:capitalize}.advance-status{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:100px;font-size:.7rem;font-weight:600}.advance-card-body{padding:1rem 1.25rem}.advance-details{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1rem}.advance-amount{display:flex;flex-direction:column}.advance-amount .amount-label{font-size:.65rem;color:#64748b;text-transform:uppercase;letter-spacing:.03em}.advance-amount .amount-value{font-size:1.5rem;font-weight:800;color:#0f172a;font-family:SF Mono,Monaco,monospace}.advance-purpose,.advance-date,.advance-emi{font-size:.8rem;color:#64748b}.advance-purpose .purpose-label{font-weight:600}.advance-progress{background:#f8fafc;border-radius:8px;padding:1rem}.progress-header{display:flex;justify-content:space-between;font-size:.75rem;color:#64748b;margin-bottom:.5rem}.progress-bar{height:8px;background:#e2e8f0;border-radius:100px;overflow:hidden}.progress-fill{height:100%;border-radius:100px;transition:width .3s ease}.progress-footer{font-size:.75rem;color:#64748b;margin-top:.5rem}.progress-footer strong{color:#0f172a}.advance-card-actions{display:flex;gap:.5rem;padding:.75rem 1.25rem;background:#f8fafc;border-top:1px solid #f1f5f9}.btn-success{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none}.btn-outline{background:#fff;border:1px solid #e2e8f0;color:#475569}.emi-preview{background:#f0fdf4;border:1px solid #dcfce7;border-radius:8px;padding:.75rem 1rem;color:#166534;font-size:.875rem;margin-bottom:1rem}.emi-preview strong{font-size:1.125rem}@media(max-width:1024px){.advance-stats{grid-template-columns:repeat(2,1fr)}}.deployment-modal{max-width:700px}.assign-type-toggle{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.toggle-option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s;font-weight:600;color:#64748b}.toggle-option:hover{border-color:#3b82f6}.toggle-option.active{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8}.selection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;max-height:200px;overflow-y:auto}.selection-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s}.selection-card:hover{border-color:#3b82f6}.selection-card.selected{background:#dbeafe;border-color:#3b82f6}.selection-info{display:flex;flex-direction:column}.selection-name{font-weight:600;font-size:.875rem;color:#0f172a}.selection-meta{font-size:.7rem;color:#64748b}@media(max-width:640px){.assign-type-toggle,.selection-grid{grid-template-columns:1fr}}.workers-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.worker-stat-card{display:flex;flex-direction:column;align-items:center;padding:1rem 1.5rem;background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg)}.worker-stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--slate-800);line-height:1}.worker-stat-card .stat-value.green{color:var(--green-600)}.worker-stat-card .stat-value.blue{color:var(--blue-600)}.worker-stat-card .stat-value.purple{color:#7c3aed}.worker-stat-card .stat-label{font-size:.75rem;color:var(--slate-500);margin-top:.25rem}.compliance-badges{display:flex;gap:.375rem}.mini-badge{display:inline-flex;align-items:center;padding:.125rem .375rem;font-size:.65rem;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.02em}.mini-badge-pf{background:#dbeafe;color:#1d4ed8}.mini-badge-esic{background:#f3e8ff;color:#7c3aed}.table-cell-worker{min-width:180px}.worker-info{display:flex;flex-direction:column;gap:.125rem}.worker-name{font-weight:600;color:var(--slate-800)}.worker-code{font-size:.7rem;color:var(--slate-500);font-family:var(--font-mono)}.trade-info{display:flex;flex-direction:column;gap:.25rem}.skill-level{font-size:.7rem;color:var(--slate-500)}.form-section{background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg);margin-bottom:1rem;overflow:hidden}.form-section-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1rem 1.25rem;background:var(--slate-50);border:none;cursor:pointer;transition:background .15s}.form-section-header:hover{background:var(--slate-100)}.form-section-title{display:flex;align-items:center;gap:.75rem;font-size:.9375rem;font-weight:600;color:var(--slate-800)}.form-section-title svg{color:var(--slate-500)}.required-badge{font-size:.65rem;font-weight:500;padding:.125rem .5rem;background:var(--red-50);color:var(--red-600);border-radius:9999px}.form-section-content{padding:1.25rem;border-top:1px solid var(--slate-200)}.compliance-info-banner{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:linear-gradient(135deg,#dbeafe,#f3e8ff);border-radius:var(--radius-md);margin-bottom:1rem;font-size:.8125rem;color:var(--slate-700)}.compliance-info-banner svg{color:var(--blue-600);flex-shrink:0}.form-hint{display:block;margin-top:.25rem;font-size:.7rem;color:var(--slate-500)}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.drawer-lg{width:520px}.drawer-title-section{display:flex;align-items:center;gap:1rem}.worker-avatar-lg{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;overflow:hidden}.worker-avatar-lg img{width:100%;height:100%;object-fit:cover}.drawer-subtitle{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--slate-500);margin-top:.25rem}.worker-emp-code{font-family:var(--font-mono);background:var(--slate-100);padding:.125rem .5rem;border-radius:var(--radius-sm)}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.active{background:var(--green-500)}.status-dot.inactive{background:var(--slate-400)}.worker-compliance-banner{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem}.compliance-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.8125rem;font-weight:500}.compliance-item.active{background:var(--green-50);color:var(--green-700)}.compliance-item.inactive{background:var(--slate-100);color:var(--slate-500)}.compliance-item svg{flex-shrink:0}.detail-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--slate-100)}.detail-section:last-child{border-bottom:none;margin-bottom:0}.detail-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.8125rem;font-weight:600;color:var(--slate-600);text-transform:uppercase;letter-spacing:.05em}.detail-section-header svg{color:var(--slate-400)}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full-width{grid-column:1 / -1}.detail-label{font-size:.7rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.03em}.detail-value{font-size:.875rem;color:var(--slate-800)}.detail-value.mono{font-family:var(--font-mono)}.detail-value.amount{font-weight:600;color:var(--green-600)}.detail-value.phone-value a{color:var(--primary-600);text-decoration:none}.detail-value.phone-value a:hover{text-decoration:underline}@media(max-width:768px){.workers-stats-bar{grid-template-columns:repeat(2,1fr)}.drawer-lg{width:100%}.detail-grid,.worker-compliance-banner{grid-template-columns:1fr}}@media(max-width:480px){.workers-stats-bar{grid-template-columns:1fr}}.contractor-badges{display:flex;flex-direction:column;align-items:flex-end;gap:.375rem}.rating-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:.7rem;font-weight:600;border-radius:9999px}.contact-person{font-size:.75rem;color:var(--slate-500);margin-left:.25rem}.contractor-compliance{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0;padding:.75rem;background:var(--slate-50);border-radius:var(--radius-md)}.compliance-badge{display:flex;flex-direction:column;gap:.125rem;padding:.375rem .5rem;background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-sm);font-size:.7rem}.compliance-badge.bocw{border-color:var(--blue-200);background:var(--blue-50)}.compliance-badge .badge-label{font-weight:600;color:var(--blue-700);text-transform:uppercase;letter-spacing:.03em}.compliance-badge .badge-value{color:var(--slate-600);font-family:var(--font-mono);font-size:.65rem}.compliance-badge .expiry{font-size:.6rem;color:var(--green-600)}.compliance-badge .expiry.expired{color:var(--red-600);font-weight:600}.contractor-meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--slate-100)}.meta-item{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;color:var(--slate-500)}.meta-item.gstin{font-family:var(--font-mono)}.contract-count .completed{color:var(--green-600);margin-left:.25rem}.payroll-summary-extended{margin-bottom:1.5rem}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid var(--slate-200);border-radius:var(--radius-lg)}.summary-card svg{color:var(--slate-400)}.summary-card.workers svg{color:var(--blue-500)}.summary-card.days svg{color:var(--green-500)}.summary-card.overtime svg{color:var(--orange-500)}.summary-card.gross svg{color:var(--purple-500)}.summary-info{display:flex;flex-direction:column}.summary-value{font-size:1.25rem;font-weight:700;color:var(--slate-800);line-height:1.2}.summary-label{font-size:.75rem;color:var(--slate-500)}.deductions-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.deduction-card{display:flex;flex-direction:column;padding:.875rem 1rem;background:var(--slate-50);border-radius:var(--radius-md);text-align:center}.deduction-card.pf{border-left:3px solid var(--blue-500)}.deduction-card.esic{border-left:3px solid #7c3aed}.deduction-card.total-deductions{border-left:3px solid var(--red-500);background:var(--red-50)}.deduction-card.net-payable{border-left:3px solid var(--green-500);background:var(--green-50)}.deduction-label{font-size:.7rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.03em}.deduction-value{font-size:1rem;font-weight:600;color:var(--slate-800);margin-top:.25rem}.deduction-card.total-deductions .deduction-value{color:var(--red-600)}.deduction-card.net-payable .deduction-value{color:var(--green-600);font-size:1.125rem}.payroll-table{width:100%;border-collapse:collapse}.payroll-table th,.payroll-table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid var(--slate-100)}.payroll-table th{background:var(--slate-50);font-size:.7rem;font-weight:600;color:var(--slate-600);text-transform:uppercase;letter-spacing:.03em}.payroll-table .deduction-col{background:var(--red-50)}.deduction-amount{color:var(--red-600)}.ot-amount{color:var(--green-600)}.overtime-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;padding:.125rem .375rem;background:var(--orange-100);color:var(--orange-700);font-size:.75rem;font-weight:600;border-radius:var(--radius-sm)}.net-pay{color:var(--green-700)}.grand-total{color:var(--green-700);font-size:1rem}.totals-row{background:var(--slate-100);font-weight:600}.compliance-info{display:flex;gap:2rem;padding:1rem;background:var(--slate-50);border-radius:var(--radius-md);margin-top:1rem}.compliance-note{font-size:.75rem;color:var(--slate-600)}.compliance-note strong{color:var(--slate-800)}.payroll-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--slate-200)}@media(max-width:1024px){.summary-row,.deductions-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.summary-row,.deductions-summary{grid-template-columns:1fr}.compliance-info{flex-direction:column;gap:.5rem}}.contractor-modal-lg{width:700px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column}.contractor-modal-lg .modal-body{flex:1;overflow-y:auto;padding:.5rem 1.5rem}.collapsible-section{border:1px solid var(--slate-200);border-radius:var(--radius-lg);margin-bottom:.75rem;overflow:hidden}.section-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.875rem 1rem;background:var(--slate-50);border:none;cursor:pointer;transition:background .15s}.section-toggle:hover{background:var(--slate-100)}.section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--slate-700)}.section-title svg{color:var(--slate-500)}.required-indicator{font-size:.65rem;font-weight:500;padding:.125rem .5rem;background:var(--red-50);color:var(--red-600);border-radius:9999px;margin-left:auto}.section-content{padding:1rem;border-top:1px solid var(--slate-200)}.compliance-info-box{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#dbeafe,#f3e8ff);border-radius:var(--radius-md);margin-bottom:1rem;font-size:.8125rem;color:var(--slate-700)}.compliance-info-box svg{color:var(--blue-600);flex-shrink:0}.mb-2{margin-bottom:.5rem;display:block}.trades-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.trade-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--slate-50);border:1px solid var(--slate-200);border-radius:var(--radius-md);cursor:pointer;font-size:.8125rem;transition:all .15s}.trade-checkbox:hover{border-color:var(--primary-300)}.trade-checkbox.selected{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.trade-checkbox input[type=checkbox]{display:none}@media(max-width:640px){.contractor-modal-lg{width:100%;max-height:100vh;border-radius:0}.trades-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.labour-page{padding-bottom:20px}.labour-tabs-container{margin:0 -12px;padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.labour-tabs-container::-webkit-scrollbar{display:none}.labour-tabs{flex-wrap:nowrap;padding:.375rem}.labour-tab{padding:.625rem 1rem;font-size:.75rem}.stats-row{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card-compact{flex-direction:column;align-items:flex-start;padding:.875rem;gap:.5rem}.stat-icon{width:36px;height:36px}.stat-info .stat-value{font-size:1.25rem}.stat-info .stat-label{font-size:.6875rem}.actions-bar{flex-direction:column;gap:.75rem;padding:.875rem}.search-box{width:100%;min-width:unset}.search-box input{font-size:16px}.filter-select{width:100%;font-size:16px}.gang-cards{grid-template-columns:1fr}.gang-card{padding:.875rem}.gang-avatar{width:40px;height:40px}.deployment-card{flex-direction:column;align-items:stretch}.deployment-card-left{flex-direction:row}.deployment-card-right{flex-direction:row;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--slate-200);margin-top:.5rem}.planning-matrix{overflow-x:auto;margin:0 -12px;width:calc(100% + 24px)}.matrix-header,.matrix-row{min-width:1000px}.week-nav{gap:.5rem}.week-dates{font-size:1rem}.planning-stats{flex-direction:column;padding:1rem;gap:.75rem}.planning-stat{flex-direction:row;gap:.75rem;width:100%;justify-content:space-between}.planning-stat-value{font-size:1.5rem}.site-attendance-section{padding:1rem;margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none}.section-header{flex-direction:column;align-items:flex-start;gap:.75rem}.site-selector{grid-template-columns:1fr}.bulk-action-bar{flex-direction:column;gap:.5rem}.worker-summary-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.summary-card{padding:.875rem}.summary-value{font-size:1.25rem}.trade-section{margin:0 -12px;width:calc(100% + 24px);border-radius:0;border-left:none;border-right:none}.deployment-stats{flex-direction:column}.deployment-stat{padding:.875rem}}@media(max-width:359px){.stats-row{grid-template-columns:1fr 1fr}.worker-summary-cards{grid-template-columns:repeat(2,1fr)}.labour-tab{padding:.5rem .75rem;font-size:.6875rem}}@media(max-width:768px){.modal-overlay{padding:0;align-items:flex-end}.modal-content{max-width:100%;max-height:95vh;border-radius:16px 16px 0 0;animation:slideUp .3s ease}.gang-modal,.deployment-modal,.contractor-modal,.contractor-modal-lg,.advance-modal,.worker-modal{max-width:100%}.modal-header{padding:1rem}.modal-title{font-size:1rem}.modal-body{padding:1rem;max-height:calc(95vh - 140px)}.modal-footer{padding:1rem;flex-direction:column;gap:.5rem}.modal-footer .btn{width:100%;justify-content:center}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.worker-selection{max-height:300px}.worker-option{flex-wrap:wrap;gap:.5rem}.worker-details{flex:1;min-width:120px}.leader-btn{font-size:.65rem;padding:.25rem .5rem}.member-search{margin-bottom:.75rem}.trade-group-header{font-size:.7rem;padding:.5rem}.date-range-picker{flex-direction:column;gap:.75rem}.date-range-picker .form-group{width:100%}.contractor-tabs{gap:.25rem}.contractor-tab{padding:.5rem .75rem;font-size:.75rem}.contact-grid,.bank-grid,.stat-grid,.documents-grid{grid-template-columns:1fr}}@media(max-width:480px){.modal-content{max-height:100vh;min-height:60vh;border-radius:0}.modal-header{padding:.875rem;position:sticky;top:0;background:#fff;z-index:10}.modal-title{font-size:.9rem;gap:.5rem}.modal-title svg{width:18px;height:18px}.modal-close{width:32px;height:32px}.modal-body{padding:.875rem}.form-section-title{font-size:.7rem;margin-bottom:.75rem}.form-group label{font-size:.75rem}.form-group input,.form-group textarea,.form-group select{padding:.5rem .625rem;font-size:.8rem}.worker-option{padding:.625rem}.worker-checkbox{width:24px;height:24px}.worker-name{font-size:.8rem}.worker-wage{font-size:.7rem}.contractor-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.contractor-tabs::-webkit-scrollbar{display:none}.contractor-tab{flex-shrink:0}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.tasks-page{width:100%}.task-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.priority-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-2);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;border-radius:var(--radius-md)}.priority-low{background:var(--slate-100);color:var(--slate-600)}.priority-medium{background:var(--info-100);color:var(--info-700)}.priority-high{background:var(--warning-100);color:var(--warning-700)}.priority-urgent{background:var(--error-100);color:var(--error-700)}.priority-badge-lg{font-size:.75rem;padding:var(--spacing-1) var(--spacing-3)}.progress-cell{display:flex;align-items:center;gap:var(--spacing-2)}.progress-bar-mini{width:60px;height:6px;background:var(--slate-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--primary-500);border-radius:var(--radius-full);transition:width .3s ease}.progress-text{font-size:.75rem;color:var(--slate-500);min-width:32px}.row-overdue{background:var(--error-50)!important}.overdue-tag{display:inline-flex;align-items:center;gap:var(--spacing-1);margin-left:var(--spacing-2);padding:var(--spacing-0) var(--spacing-2);background:var(--error-100);color:var(--error-600);font-size:.625rem;font-weight:600;border-radius:var(--radius-full)}.overdue-alert{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);background:var(--error-100);color:var(--error-700);font-size:.75rem;font-weight:500;border-radius:var(--radius-full);margin-top:var(--spacing-2)}.task-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6);margin-bottom:var(--spacing-6);flex-wrap:wrap}.task-detail-title-section{flex:1;min-width:300px}.task-detail-title-row{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.task-detail-title{font-size:1.5rem;font-weight:800;color:var(--slate-800);margin:0}.task-progress-section{min-width:200px;max-width:300px}.task-progress-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-2)}.task-progress-label{font-size:.75rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.task-progress-value{font-size:.875rem;font-weight:700;color:var(--primary-600)}.progress-bar{height:8px;background:var(--slate-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-2)}.progress-update{display:flex;flex-direction:column;gap:var(--spacing-2)}.form-range{width:100%;cursor:pointer}.task-actions{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap}.btn-success{background:var(--success-600);color:#fff}.btn-success:hover{background:var(--success-700)}.btn-danger-outline{background:transparent;color:var(--error-600);border:1px solid var(--error-200)}.btn-danger-outline:hover{background:var(--error-50)}.task-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.detail-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) 0;border-bottom:1px solid var(--slate-100)}.detail-item:last-child{border-bottom:none}.detail-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:.75rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-weight:500;color:var(--slate-800)}.detail-sub{font-weight:400;color:var(--slate-500)}.task-description{font-size:.875rem;line-height:1.6;color:var(--slate-600);white-space:pre-wrap}.table-cell-title{font-weight:500;color:var(--slate-800)}.kanban-board{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;min-height:500px}.kanban-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--slate-500)}.kanban-column{background:var(--slate-50);border-radius:12px;padding:0;display:flex;flex-direction:column;min-height:400px}.kanban-column.dragging{background:var(--slate-100)}.kanban-column-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border-radius:12px 12px 0 0;border-bottom:3px solid}.column-title{font-weight:700;font-size:.875rem;color:var(--slate-800)}.column-count{margin-left:auto;background:var(--slate-200);color:var(--slate-600);font-size:.7rem;font-weight:700;padding:.25rem .5rem;border-radius:100px}.kanban-column-content{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;max-height:600px}.kanban-empty{text-align:center;padding:2rem;color:var(--slate-400);font-size:.875rem}.kanban-card{background:#fff;border-radius:8px;padding:1rem;cursor:grab;transition:all .2s;border:1px solid var(--slate-200);box-shadow:0 1px 3px #0000000d}.kanban-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--primary-300)}.kanban-card:active{cursor:grabbing}.kanban-card.overdue{border-left:3px solid var(--error-500);background:#fffbfb}.kanban-card-header{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.kanban-card-title{flex:1;font-size:.875rem;font-weight:600;color:var(--slate-800);margin:0;line-height:1.4}.kanban-card-menu{padding:.25rem;border:none;background:transparent;color:var(--slate-400);cursor:pointer;border-radius:4px}.kanban-card-menu:hover{background:var(--slate-100);color:var(--slate-600)}.kanban-card-desc{font-size:.75rem;color:var(--slate-500);line-height:1.4;margin-bottom:.75rem}.kanban-card-meta{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.75rem}.meta-tag{font-size:.65rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.meta-tag.project{background:var(--primary-100);color:var(--primary-700)}.meta-tag.site{background:var(--slate-100);color:var(--slate-600)}.kanban-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:var(--slate-500)}.assignee,.due-date{display:flex;align-items:center;gap:.25rem}.due-date.overdue{color:var(--error-600)}.kanban-progress{margin-top:.75rem;height:4px;background:var(--slate-200);border-radius:100px;overflow:hidden}.kanban-progress-fill{height:100%;background:var(--primary-500);border-radius:100px}.view-toggle{display:flex;gap:.25rem;background:var(--slate-100);padding:.25rem;border-radius:8px}.view-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--slate-600);font-size:.8rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s}.view-toggle-btn.active{background:#fff;color:var(--primary-600);box-shadow:0 1px 3px #0000001a}@media(max-width:1024px){.kanban-board{grid-template-columns:1fr;gap:1rem}.kanban-column{min-height:auto}.kanban-column-content{max-height:300px}}.checklist-card .card-header{display:flex;align-items:center;justify-content:space-between}.checklist-card .card-title{display:flex;align-items:center;gap:.5rem}.checklist-progress-badge{font-size:.7rem;font-weight:600;padding:.25rem .5rem;background:var(--primary-100);color:var(--primary-700);border-radius:100px}.checklist-loading{display:flex;justify-content:center;padding:2rem;color:var(--slate-400)}.checklist-progress{height:6px;background:var(--slate-200);border-radius:100px;overflow:hidden;margin-bottom:1rem}.checklist-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:100px;transition:width .3s ease}.checklist-items{display:flex;flex-direction:column;gap:.5rem}.checklist-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--slate-50);border-radius:8px;transition:all .2s}.checklist-item:hover{background:var(--slate-100)}.checklist-item.completed{opacity:.7}.checklist-item.completed .checklist-title{text-decoration:line-through;color:var(--slate-500)}.checklist-toggle{padding:0;border:none;background:transparent;color:var(--slate-400);cursor:pointer;transition:color .2s}.checklist-toggle:hover{color:var(--primary-500)}.checklist-toggle .checked{color:var(--success-500)}.checklist-title{flex:1;font-size:.875rem;color:var(--slate-700)}.checklist-delete{padding:.375rem;border:none;background:transparent;color:var(--slate-400);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s}.checklist-item:hover .checklist-delete{opacity:1}.checklist-delete:hover{background:var(--error-100);color:var(--error-600)}.checklist-add-form{display:flex;gap:.5rem;margin-top:.75rem}.checklist-add-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--slate-300);border-radius:6px;font-size:.875rem}.checklist-add-form input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.checklist-add-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px dashed var(--slate-300);background:transparent;color:var(--slate-500);font-size:.8rem;border-radius:6px;cursor:pointer;transition:all .2s;margin-top:.75rem}.checklist-add-btn:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.checklist-empty{text-align:center;padding:1.5rem;color:var(--slate-400);font-size:.875rem}.comments-card .card-header{display:flex;align-items:center;justify-content:space-between}.comments-card .card-title{display:flex;align-items:center;gap:.5rem}.comments-count{font-size:.7rem;font-weight:600;padding:.25rem .5rem;background:var(--slate-200);color:var(--slate-600);border-radius:100px}.comment-form{margin-bottom:1rem}.comment-input-wrapper{display:flex;gap:.5rem;align-items:flex-end}.comment-input-wrapper textarea{flex:1;padding:.75rem;border:1px solid var(--slate-300);border-radius:8px;font-size:.875rem;resize:none;font-family:inherit}.comment-input-wrapper textarea:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.comment-submit-btn{padding:.75rem;border:none;background:var(--primary-500);color:#fff;border-radius:8px;cursor:pointer;transition:all .2s}.comment-submit-btn:hover:not(:disabled){background:var(--primary-600)}.comment-submit-btn:disabled{opacity:.5;cursor:not-allowed}.comments-loading{display:flex;justify-content:center;padding:2rem;color:var(--slate-400)}.comments-empty{text-align:center;padding:1.5rem;color:var(--slate-400);font-size:.875rem}.comments-list{display:flex;flex-direction:column;gap:1rem}.comment-item{display:flex;gap:.75rem}.comment-avatar{width:32px;height:32px;border-radius:50%;background:var(--slate-200);display:flex;align-items:center;justify-content:center;color:var(--slate-500);flex-shrink:0;overflow:hidden}.comment-avatar img{width:100%;height:100%;object-fit:cover}.comment-content{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.comment-author{font-weight:600;font-size:.8rem;color:var(--slate-800)}.comment-time{font-size:.7rem;color:var(--slate-400)}.comment-delete-btn{margin-left:auto;padding:.25rem;border:none;background:transparent;color:var(--slate-400);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s}.comment-item:hover .comment-delete-btn{opacity:1}.comment-delete-btn:hover{background:var(--error-100);color:var(--error-600)}.comment-text{font-size:.875rem;color:var(--slate-600);line-height:1.5;margin:0;white-space:pre-wrap}.gantt-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.gantt-controls{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--slate-50);border-bottom:1px solid var(--slate-200);flex-wrap:wrap}.gantt-project-select select{min-width:250px}.gantt-nav{display:flex;gap:.25rem}.gantt-zoom{display:flex;gap:.25rem;margin-left:auto}.gantt-loading,.gantt-empty,.gantt-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--slate-400)}.gantt-chart{overflow-x:auto}.gantt-header{display:flex;border-bottom:2px solid var(--slate-200);position:sticky;top:0;background:#fff;z-index:10}.gantt-task-column{width:280px;min-width:280px;padding:.75rem 1rem;font-weight:600;font-size:.75rem;color:var(--slate-600);text-transform:uppercase;letter-spacing:.05em;background:var(--slate-50);border-right:1px solid var(--slate-200);display:flex;align-items:center;gap:.5rem}.gantt-timeline{flex:1;display:flex;position:relative;min-width:600px}.gantt-date-cell{flex:1;padding:.5rem 0;text-align:center;border-right:1px solid var(--slate-100);font-size:.65rem;color:var(--slate-500)}.gantt-date-cell.weekend{background:var(--slate-50)}.gantt-date-cell.today{background:var(--primary-50);border-bottom:2px solid var(--primary-500)}.date-day{display:block;text-transform:uppercase;font-weight:600}.date-num{display:block;font-size:.75rem;font-weight:700;color:var(--slate-700)}.gantt-body{max-height:500px;overflow-y:auto}.gantt-row{display:flex;border-bottom:1px solid var(--slate-100)}.gantt-row:hover{background:var(--slate-50)}.gantt-row .gantt-task-column{font-weight:500;font-size:.8rem;color:var(--slate-700);cursor:pointer;text-transform:none;letter-spacing:0}.gantt-row .gantt-task-column:hover{background:var(--primary-50)}.task-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-assignee{display:flex;align-items:center;gap:.25rem;font-size:.7rem;color:var(--slate-400)}.gantt-row .gantt-timeline{position:relative}.gantt-grid-cell{flex:1;border-right:1px solid var(--slate-100)}.gantt-grid-cell.weekend{background:var(--slate-50)}.gantt-grid-cell.today{background:var(--primary-50)}.gantt-bar{position:absolute;top:50%;transform:translateY(-50%);height:24px;border-radius:4px;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:flex-end;padding:0 .5rem;transition:all .2s;z-index:5}.gantt-bar:hover{filter:brightness(1.1);box-shadow:0 2px 8px #0003}.gantt-bar-progress{position:absolute;left:0;top:0;height:100%;background:#0003}.gantt-bar-label{position:relative;font-size:.65rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.gantt-legend{display:flex;gap:1.5rem;padding:1rem 1.5rem;border-top:1px solid var(--slate-200);background:var(--slate-50)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--slate-600)}.legend-dot{width:12px;height:12px;border-radius:3px}.time-tracking-card .card-title{display:flex;align-items:center;gap:.5rem}.time-badge{font-size:.7rem;font-weight:600;padding:.25rem .5rem;background:var(--primary-100);color:var(--primary-700);border-radius:100px}.time-summary{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--slate-200)}.time-summary-header{display:flex;gap:1.5rem;margin-bottom:.75rem}.time-stat{display:flex;flex-direction:column}.time-stat-label{font-size:.65rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.time-stat-value{font-size:1rem;font-weight:700;color:var(--slate-800)}.time-stat-value.over-budget{color:var(--error-600)}.time-stat-value.under-budget{color:var(--success-600)}.time-progress{height:6px;background:var(--slate-200);border-radius:100px;overflow:hidden}.time-progress-fill{height:100%;background:var(--primary-500);border-radius:100px;transition:width .3s}.time-progress-fill.over{background:var(--error-500)}.time-warning{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.75rem;color:var(--error-600)}.time-loading{display:flex;justify-content:center;padding:2rem;color:var(--slate-400)}.time-empty{text-align:center;padding:1.5rem;color:var(--slate-400);font-size:.875rem}.time-entries{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.time-entry{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem;background:var(--slate-50);border-radius:8px;position:relative}.time-entry-main{display:flex;align-items:center;gap:1rem}.entry-date{font-size:.75rem;color:var(--slate-500)}.entry-hours{font-weight:700;color:var(--primary-600)}.entry-description{width:100%;margin:.25rem 0 0;font-size:.8rem;color:var(--slate-600)}.entry-delete{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);padding:.375rem;border:none;background:transparent;color:var(--slate-400);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s}.time-entry:hover .entry-delete{opacity:1}.entry-delete:hover{background:var(--error-100);color:var(--error-600)}.time-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--slate-50);border-radius:8px}.time-form-row{display:flex;gap:.5rem}.time-form input{flex:1;padding:.5rem .75rem;border:1px solid var(--slate-300);border-radius:6px;font-size:.875rem}.time-form input:focus{outline:none;border-color:var(--primary-400)}.time-form-actions{display:flex;gap:.5rem}.time-add-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px dashed var(--slate-300);background:transparent;color:var(--slate-500);font-size:.8rem;border-radius:6px;cursor:pointer;transition:all .2s}.time-add-btn:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}.dependencies-card .card-header{display:flex;justify-content:space-between;align-items:center}.dependencies-card .card-title{display:flex;align-items:center;gap:.5rem}.blocked-badge{font-size:.65rem;font-weight:600;padding:.25rem .5rem;background:var(--error-100);color:var(--error-700);border-radius:100px}.dependency-section{margin-bottom:1rem}.dependency-section:last-child{margin-bottom:0}.dependency-section-title{display:flex;align-items:center;gap:.5rem;font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.deps-loading{display:flex;justify-content:center;padding:1.5rem;color:var(--slate-400)}.deps-empty{text-align:center;padding:1rem;color:var(--slate-400);font-size:.8rem}.dependency-list{display:flex;flex-direction:column;gap:.5rem}.dependency-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--slate-50);border-radius:6px;position:relative}.dependency-item.successor{background:var(--warning-50)}.dep-title{flex:1;font-size:.8rem;color:var(--slate-700);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dep-title:hover{color:var(--primary-600);text-decoration:underline}.dep-type{font-size:.65rem;color:var(--slate-400)}.dep-lag{font-size:.65rem;color:var(--primary-600);font-weight:600}.dep-remove{padding:.25rem;border:none;background:transparent;color:var(--slate-400);cursor:pointer;border-radius:4px;opacity:0;transition:all .2s}.dependency-item:hover .dep-remove{opacity:1}.dep-remove:hover{background:var(--error-100);color:var(--error-600)}.add-dependency-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--slate-50);border-radius:8px;margin-top:.5rem}.add-dependency-form select{padding:.5rem .75rem;border:1px solid var(--slate-300);border-radius:6px;font-size:.8rem}.add-dep-actions{display:flex;gap:.5rem}.add-dep-btn{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border:1px dashed var(--slate-300);background:transparent;color:var(--slate-500);font-size:.75rem;border-radius:4px;cursor:pointer;transition:all .2s;margin-top:.5rem}.add-dep-btn:hover{border-color:var(--primary-400);color:var(--primary-600);background:var(--primary-50)}@media(max-width:768px){.task-detail-header{flex-direction:column;gap:var(--spacing-4)}.task-detail-title-section{min-width:100%}.task-detail-title{font-size:1.25rem}.task-detail-title-row{flex-wrap:wrap;gap:var(--spacing-2)}.task-progress-section{width:100%;max-width:none}.task-actions{flex-wrap:wrap;gap:var(--spacing-2)}.task-actions .btn{flex:1 1 calc(50% - var(--spacing-2));min-width:140px;justify-content:center;padding:.75rem 1rem}.task-detail-grid{grid-template-columns:1fr;gap:var(--spacing-4)}.detail-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-1)}.detail-value{width:100%}.breadcrumb{flex-wrap:wrap;gap:.25rem}.task-stats{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.kanban-board{grid-template-columns:1fr}.table-responsive{margin:0 -1rem;width:calc(100% + 2rem)}.discussion-btn{width:100%;justify-content:center}}@media(max-width:480px){.tasks-page{padding:var(--spacing-3)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.page-header .btn{width:100%;justify-content:center}.task-stats{grid-template-columns:1fr}.stat-card{padding:var(--spacing-3)}.task-detail-title{font-size:1.125rem;word-break:break-word}.task-detail-title-row{align-items:flex-start}.badge,.priority-badge{font-size:.65rem;padding:.25rem .5rem}.priority-badge-lg{font-size:.7rem}.task-actions{flex-direction:column}.task-actions .btn{width:100%;flex:none;padding:.875rem 1rem;font-size:.9rem}.back-link{padding:.5rem .75rem;font-size:.8rem}.card{border-radius:8px}.card-header,.card-content{padding:var(--spacing-3)}.comment-input-wrapper textarea,.checklist-add-form input{padding:.875rem;font-size:1rem}.comment-submit-btn{padding:.875rem;min-width:48px}.checklist-item{padding:1rem}.checklist-toggle{padding:.5rem}.checklist-title{font-size:1rem}.comment-item{flex-direction:column;gap:.5rem}.comment-avatar{width:28px;height:28px}.comment-content{margin-left:0;width:100%}.filters-bar{flex-direction:column;gap:var(--spacing-2)}.filters-bar select,.filters-bar .search-input,.view-toggle{width:100%}.view-toggle-btn{flex:1;justify-content:center;padding:.625rem}.progress-bar{height:10px}.progress-bar-mini{width:50px;height:8px}.kanban-card{padding:.875rem}.kanban-card-title{font-size:.9rem}.time-entry-form{flex-direction:column;gap:var(--spacing-2)}.time-entry-form input,.time-entry-form textarea{width:100%}.dependency-item{flex-wrap:wrap;gap:var(--spacing-2)}.dep-icon{margin-right:0}.dep-info{flex:1;min-width:calc(100% - 50px)}.dep-remove{opacity:1}.add-dependency-form{padding:.5rem}}@media(hover:none)and (pointer:coarse){.btn{min-height:44px;padding:.75rem 1rem}.btn-sm{min-height:36px;padding:.5rem .75rem}.kanban-card:hover{transform:none}.checklist-delete,.dep-remove,.comment-delete{opacity:1}.checklist-item,.comment-item,.dependency-item{padding:1rem}.checklist-toggle{padding:.75rem;margin:-.5rem}}@supports (padding-bottom: env(safe-area-inset-bottom)){.tasks-page{padding-bottom:calc(var(--spacing-6) + env(safe-area-inset-bottom))}}@media(max-width:768px){.table-container{margin:0 calc(-1 * var(--spacing-3));overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.data-table{min-width:800px}.table-container:after{content:"";position:absolute;right:0;top:0;bottom:0;width:40px;background:linear-gradient(to left,rgba(255,255,255,.9),transparent);pointer-events:none}.actions-bar{flex-direction:column;gap:var(--spacing-3)}.filters-bar{display:grid;grid-template-columns:1fr;gap:var(--spacing-2);width:100%}.search-input-wrapper{grid-column:1 / -1}.filter-select{width:100%;padding:.75rem;font-size:1rem}.page-header{flex-direction:column;align-items:stretch;gap:var(--spacing-3)}.page-header>div:last-child{flex-direction:column;width:100%}.view-toggle{width:100%;overflow-x:auto}.view-toggle-btn{flex:1;white-space:nowrap}}@media(max-width:480px){.filters-bar{grid-template-columns:1fr 1fr}.search-input-wrapper{grid-column:1 / -1}.checkbox-label{grid-column:1 / -1;padding:.75rem;background:var(--slate-50);border-radius:8px}.task-stats{display:flex;gap:var(--spacing-3);overflow-x:auto;padding-bottom:var(--spacing-2);-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}.stat-card{flex:0 0 auto;min-width:140px;scroll-snap-align:start}.empty-state{padding:var(--spacing-6) var(--spacing-3)}.empty-state-title{font-size:1.125rem}.empty-state-desc{font-size:.875rem}.error-state{padding:var(--spacing-6) var(--spacing-3)}}@media(prefers-color-scheme:dark){.kanban-card{background:#1e293b;border-color:#334155}.kanban-column{background:#0f172a}}.task-chat-panel{display:flex;flex-direction:column;height:450px;overflow:hidden}.task-chat-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.task-chat-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-color, #1f2937)}.task-chat-meta{display:flex;align-items:center;gap:.5rem}.members-btn{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#f1f5f9;border:none;border-radius:4px;font-size:.75rem;color:#475569;cursor:pointer;transition:all .2s}.members-btn:hover{background:#e2e8f0}.members-dropdown{background:#fff;border-bottom:1px solid var(--border-color, #e5e7eb);max-height:200px;overflow:hidden}.members-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:#f8fafc;font-size:.75rem;font-weight:600;color:#64748b}.members-dropdown-header button{background:none;border:none;cursor:pointer;color:#64748b;padding:.25rem}.members-list{padding:.5rem;max-height:150px;overflow-y:auto}.member-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:4px}.member-item:hover{background:#f1f5f9}.member-avatar{font-size:1rem}.member-info{display:flex;flex-direction:column;gap:.125rem}.member-name{font-size:.8rem;color:var(--text-color, #1f2937)}.member-role{font-size:.65rem;text-transform:uppercase;font-weight:600}.member-role.admin{color:#f59e0b}.member-role.member{color:#64748b}.no-members{padding:1rem;text-align:center;font-size:.8rem;color:#94a3b8}.task-chat-content{flex:1;overflow-y:auto;padding:1rem;background:#fafafa}.chat-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;height:100%;color:#64748b;font-size:.875rem}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;height:100%;color:#94a3b8;text-align:center}.chat-empty h4{margin:0;font-size:1rem;color:#64748b}.chat-empty p{font-size:.8rem;max-width:250px;margin:0}.messages-list{display:flex;flex-direction:column;gap:.75rem}.message-item{background:#fff;border-radius:8px;padding:.75rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb}.message-item.message-priority{border-left-width:3px}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.message-sender-info{display:flex;align-items:center;gap:.375rem}.message-sender{font-weight:600;font-size:.8rem;color:var(--text-color, #1f2937)}.message-priority-icon{display:flex;align-items:center}.message-content{margin:0;font-size:.875rem;line-height:1.5;color:var(--text-color, #374151);white-space:pre-wrap;word-break:break-word}.chat-input-section{padding:.75rem 1rem;background:#fff;border-top:1px solid var(--border-color, #e5e7eb)}.priority-selector{margin-bottom:.5rem}.priority-select{width:100%;padding:.375rem .5rem;font-size:.8rem;border:1px solid #e5e7eb;border-radius:4px;background:#f8fafc}.chat-input-row{display:flex;gap:.5rem;align-items:flex-end}.chat-textarea{flex:1;padding:.625rem;font-size:.875rem;border:1px solid #e5e7eb;border-radius:8px;resize:none;font-family:inherit;transition:border-color .2s}.chat-textarea:focus{outline:none;border-color:#3b82f6}.send-btn{display:flex;align-items:center;justify-content:center;width:42px;height:42px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.send-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.task-chat-compact{background:#fff;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;overflow:hidden}.task-chat-compact-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8fafc;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.task-chat-compact-header:hover{background:#f1f5f9}.task-chat-compact-title{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.875rem;color:var(--text-color, #1f2937)}.message-count-badge{background:#3b82f6;color:#fff;font-size:.65rem;padding:.125rem .375rem;border-radius:10px;font-weight:700}.task-chat-compact-content{padding:.75rem;max-height:300px;overflow-y:auto}.messages-list-compact{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.message-item-compact{padding:.5rem .625rem;border-radius:6px;background:#f8fafc;border:1px solid #e5e7eb}.message-header-compact{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.message-header-compact .message-sender{font-size:.75rem}.message-header-compact .message-time{font-size:.65rem}.message-content-compact{margin:0;font-size:.8rem;line-height:1.4;color:var(--text-color, #374151)}.more-messages{text-align:center;font-size:.75rem;color:#3b82f6;padding:.375rem;background:#f0f9ff;border-radius:4px}.chat-input-compact{display:flex;gap:.5rem}.chat-input-field{flex:1;padding:.5rem .75rem;font-size:.8rem;border:1px solid #e5e7eb;border-radius:6px}.chat-input-field:focus{outline:none;border-color:#3b82f6}.send-btn-compact{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.send-btn-compact:hover:not(:disabled){background:#2563eb}.send-btn-compact:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.task-chat-panel{height:400px;border-radius:8px}.task-chat-header{padding:.625rem .875rem}.task-chat-title{font-size:.9rem}.task-chat-content{padding:.75rem}.messages-list{gap:.625rem}.message-item{padding:.625rem}.chat-input-section{padding:.625rem .875rem}.chat-textarea{padding:.75rem;font-size:1rem}.send-btn{width:48px;height:48px}}@media(max-width:480px){.task-chat-panel{height:350px;margin:0 -.5rem;width:calc(100% + 1rem);border-radius:0;border-left:none;border-right:none}.task-chat-header{padding:.75rem;flex-wrap:wrap;gap:.5rem}.task-chat-title{font-size:.875rem}.members-btn{padding:.5rem .75rem;font-size:.8rem}.members-dropdown{max-height:150px}.member-item,.task-chat-content{padding:.5rem}.message-item{padding:.75rem}.message-sender{font-size:.85rem}.message-content{font-size:.9rem}.message-time{font-size:.65rem}.chat-input-section{padding:.5rem}.priority-selector{margin-bottom:.375rem}.priority-select{padding:.5rem;font-size:.9rem}.chat-input-row{gap:.375rem}.chat-textarea{padding:.75rem;font-size:1rem;border-radius:6px}.send-btn{width:50px;height:50px;border-radius:6px}.task-chat-compact{margin:0;border-radius:8px}.task-chat-compact-header{padding:.875rem}.task-chat-compact-title{font-size:.9rem}.task-chat-compact-content{padding:.625rem;max-height:250px}.message-item-compact{padding:.625rem}.message-content-compact{font-size:.85rem}.chat-input-compact{gap:.375rem}.chat-input-field{padding:.75rem;font-size:1rem}.send-btn-compact{padding:.75rem 1rem}.chat-empty{padding:1.5rem}.chat-empty h4{font-size:.95rem}.chat-empty p{font-size:.8rem}}@media(hover:none)and (pointer:coarse){.members-btn{min-height:36px;padding:.5rem .75rem}.chat-textarea,.chat-input-field{font-size:16px;min-height:48px}.send-btn,.send-btn-compact{min-width:48px;min-height:48px}.message-item{padding:.875rem}.send-btn:hover:not(:disabled){transform:none}}@supports (padding-bottom: env(safe-area-inset-bottom)){.chat-input-section{padding-bottom:calc(.75rem + env(safe-area-inset-bottom))}}.daily-progress-page{width:100%}.coming-soon-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--slate-200);padding:var(--spacing-12);text-align:center;max-width:600px;margin:0 auto}.coming-soon-icon{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary-100),var(--primary-50));display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-6)}.coming-soon-icon svg{color:var(--primary-500)}.coming-soon-card h2{font-size:1.5rem;font-weight:700;color:var(--slate-800);margin:0 0 var(--spacing-2)}.coming-soon-card>p{color:var(--slate-500);margin:0 0 var(--spacing-6)}.coming-soon-features{text-align:left;background:var(--slate-50);padding:var(--spacing-5);border-radius:var(--radius-md)}.coming-soon-features h3{font-size:.875rem;font-weight:600;color:var(--slate-700);margin:0 0 var(--spacing-3)}.coming-soon-features ul{margin:0;padding-left:var(--spacing-5)}.coming-soon-features li{color:var(--slate-600);font-size:.875rem;margin-bottom:var(--spacing-2)}.coming-soon-features li::marker{color:var(--primary-500)}.subcontracts-page{width:100%}.table-cell-dates{font-size:.75rem;color:var(--slate-600);white-space:nowrap}.subcontract-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6);margin-bottom:var(--spacing-6);flex-wrap:wrap}.subcontract-header-left{flex:1}.subcontract-title-row{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap;margin-bottom:var(--spacing-2)}.subcontract-title{font-size:1.5rem;font-weight:800;color:var(--slate-800);margin:0}.subcontract-meta{display:flex;align-items:center;gap:var(--spacing-4);flex-wrap:wrap}.subcontract-vendor,.subcontract-amount{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:.875rem;color:var(--slate-600)}.subcontract-amount{font-weight:600;color:var(--slate-800)}.subcontract-actions{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap}.subcontract-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.scope-text{font-size:.875rem;line-height:1.7;color:var(--slate-600);white-space:pre-wrap;margin:0}.form-hint{display:block;margin-top:var(--spacing-1);font-size:.75rem;color:var(--slate-500)}.ra-bills-list{padding:1.5rem}.ra-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.ra-summary-card{background:#fff;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #00000014}.ra-summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.ra-summary-icon.blue{background:#3b82f61a;color:#3b82f6}.ra-summary-icon.green{background:#10b9811a;color:#10b981}.ra-summary-icon.purple{background:#8b5cf61a;color:#8b5cf6}.ra-summary-icon.orange{background:#f59e0b1a;color:#f59e0b}.ra-summary-content{display:flex;flex-direction:column;gap:.25rem}.ra-summary-value{font-size:1.25rem;font-weight:700;color:var(--slate-800)}.ra-summary-label{font-size:.75rem;color:var(--slate-500)}.ra-progress-container{background:#fff;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014}.ra-progress-header{display:flex;justify-content:space-between;font-size:.875rem;color:var(--slate-600);margin-bottom:.5rem}.ra-progress-bar{height:10px;background:var(--slate-200);border-radius:100px;overflow:hidden}.ra-progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:100px;transition:width .5s ease}.ra-bills-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.ra-bills-header h3{font-size:1.125rem;font-weight:600;color:var(--slate-800);margin:0}.ra-bills-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #00000014}.ra-bills-table table{width:100%;border-collapse:collapse}.ra-bills-table th{text-align:left;padding:.875rem 1rem;font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;background:var(--slate-50);border-bottom:1px solid var(--slate-200)}.ra-bills-table td{padding:.875rem 1rem;font-size:.875rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100)}.ra-bills-table tr:hover td{background:var(--slate-50)}.ra-bill-number{display:flex;align-items:center;gap:.5rem;color:var(--primary-600);font-weight:600;text-decoration:none}.ra-bill-number:hover{text-decoration:underline}.date-cell{display:flex;align-items:center;gap:.5rem;color:var(--slate-500)}.amount-cell{font-weight:600;color:var(--slate-700)}.amount-cell.deduction{color:#ef4444}.amount-cell.net{color:#10b981}.status-badge{display:inline-flex;padding:.25rem .75rem;border-radius:100px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.actions-cell{display:flex;gap:.5rem}.paid-badge{display:inline-flex;align-items:center;gap:.25rem;color:#10b981;font-size:.8rem;font-weight:600}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;background:#fff;border-radius:12px;text-align:center}.empty-state svg{color:var(--slate-300)}.empty-state h4{font-size:1.125rem;font-weight:600;color:var(--slate-700);margin:0}.empty-state p{font-size:.875rem;color:var(--slate-500);max-width:300px;margin:0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{background:#fff;border-radius:16px;padding:1.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px #0003}.modal-content h3{font-size:1.125rem;font-weight:600;color:var(--slate-800);margin:0 0 .5rem}.modal-content p{font-size:.875rem;color:var(--slate-600);margin:0 0 1rem}.remarks-input{width:100%;min-height:80px;padding:.75rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem;resize:vertical;margin-bottom:1rem}.remarks-input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}@media(max-width:1024px){.ra-summary-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.ra-summary-grid{grid-template-columns:1fr}.ra-bills-table{overflow-x:auto}.ra-bills-table table{min-width:800px}}.create-ra-modal{background:#fff;border-radius:16px;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--slate-200);position:sticky;top:0;background:#fff;z-index:10}.modal-title{display:flex;align-items:center;gap:.75rem}.modal-title h2{font-size:1.125rem;font-weight:600;color:var(--slate-800);margin:0}.modal-title p{font-size:.8rem;color:var(--slate-500);margin:0}.close-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--slate-400);border-radius:8px}.close-btn:hover{background:var(--slate-100);color:var(--slate-600)}.form-section{padding:1.25rem 1.5rem;border-bottom:1px solid var(--slate-100)}.form-section h3{font-size:.95rem;font-weight:600;color:var(--slate-700);margin:0 0 .75rem}.section-hint{font-size:.8rem;color:var(--slate-500);margin:0 0 1rem}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-group label{font-size:.75rem;font-weight:600;color:var(--slate-600)}.form-group input,.form-group select,.form-group textarea{padding:.625rem .75rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.items-table{overflow-x:auto;margin:0 -1.5rem;padding:0 1.5rem}.items-table table{width:100%;border-collapse:collapse;min-width:900px}.items-table th{text-align:left;padding:.625rem .5rem;font-size:.65rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;background:var(--slate-50);border-bottom:1px solid var(--slate-200)}.items-table td{padding:.5rem;font-size:.8rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100);vertical-align:middle}.items-table .desc-col{min-width:200px}.items-table .number{text-align:right;font-family:SF Mono,Monaco,monospace}.items-table .balance{color:var(--primary-600);font-weight:600}.items-table .amount{font-weight:600;color:var(--slate-700)}.items-table tr.has-qty td{background:#10b9810d}.item-description{display:flex;flex-direction:column;gap:.125rem}.item-description .rate{font-size:.7rem;color:var(--slate-400)}.qty-input{width:80px;padding:.375rem .5rem!important;text-align:right;font-family:SF Mono,Monaco,monospace}.mb-input{width:70px;padding:.375rem .5rem!important}.items-table tfoot td{background:var(--slate-50);font-weight:600}.total-label{text-align:right;color:var(--slate-600)}.total-amount{text-align:right;color:var(--primary-600);font-size:1rem}.bill-summary{padding:1rem 1.5rem;background:var(--slate-50);border-top:1px solid var(--slate-200)}.summary-row{display:flex;justify-content:space-between;padding:.375rem 0;font-size:.875rem}.summary-row span{color:var(--slate-600)}.summary-row strong{color:var(--slate-800)}.summary-row .gross{color:var(--slate-700)}.summary-row .deduction{color:#ef4444}.summary-row.total{border-top:1px solid var(--slate-300);margin-top:.5rem;padding-top:.75rem;font-size:1rem}.summary-row.total strong{color:var(--primary-600)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--slate-200);position:sticky;bottom:0;background:#fff}.ra-bill-detail{padding:1.5rem;width:100%;margin:0 auto}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.back-btn{background:#fff;border:1px solid var(--slate-200);border-radius:8px;padding:.5rem;cursor:pointer;color:var(--slate-600)}.back-btn:hover{background:var(--slate-50)}.header-info h1{font-size:1.5rem;font-weight:700;color:var(--slate-800);margin:0}.header-info p{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--slate-500);margin:0}.header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.info-card{background:#fff;border-radius:12px;padding:1rem 1.25rem;box-shadow:0 1px 3px #00000014}.info-card.highlight{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff}.info-card.highlight .info-label{color:#fffc}.info-card.highlight .info-value{color:#fff}.info-label{font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.025em}.info-value{font-size:1.125rem;font-weight:700;color:var(--slate-800);margin:.25rem 0}.info-sub{font-size:.8rem;color:var(--slate-500)}.section-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1.5rem;overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--slate-100)}.section-header h2{font-size:1rem;font-weight:600;color:var(--slate-700);margin:0}.deductions-table table{width:100%;border-collapse:collapse}.deductions-table th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;background:var(--slate-50)}.deductions-table td{padding:.75rem 1rem;font-size:.875rem;border-bottom:1px solid var(--slate-100)}.deduction-amount{color:#ef4444;font-weight:600}.total-deduction{color:#ef4444;font-weight:700;font-size:1rem}.icon-btn{background:none;border:none;padding:.375rem;cursor:pointer;border-radius:6px;color:var(--slate-400)}.icon-btn:hover{background:var(--slate-100)}.icon-btn.danger:hover{background:#ef44441a;color:#ef4444}.bill-summary-card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px #00000014;margin-bottom:1.5rem}.bill-summary-card h2{font-size:1rem;font-weight:600;color:var(--slate-700);margin:0 0 1rem}.summary-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.summary-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:var(--slate-50);border-radius:8px}.summary-item span{font-size:.75rem;color:var(--slate-500)}.summary-item strong{font-size:1.125rem;color:var(--slate-800)}.summary-item.highlight{background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.summary-item.highlight span,.summary-item.highlight strong{color:#fff}.summary-item .deduction{color:#ef4444}.timeline{padding:1rem 1.25rem}.timeline-item{display:flex;gap:1rem;padding-bottom:1.5rem;position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:15px;top:32px;bottom:0;width:2px;background:var(--slate-200)}.timeline-item.completed:before{background:var(--primary-400)}.timeline-icon{width:32px;height:32px;border-radius:50%;background:var(--slate-100);color:var(--slate-500);display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-item.completed .timeline-icon{background:var(--primary-500);color:#fff}.timeline-content{flex:1}.timeline-content strong{display:block;font-size:.875rem;color:var(--slate-700)}.timeline-content span{font-size:.8rem;color:var(--slate-500)}.timeline-content p{font-size:.8rem;color:var(--slate-600);margin:.25rem 0 0;font-style:italic}@media(max-width:1024px){.info-cards{grid-template-columns:repeat(2,1fr)}.summary-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.detail-header{flex-direction:column;align-items:flex-start}.info-cards{grid-template-columns:1fr}.summary-grid{grid-template-columns:1fr 1fr}}.expenses-page{width:100%}.expense-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.filters-bar-wrap{flex-wrap:wrap}.filter-input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--slate-200);border-radius:var(--radius-md);font-size:.875rem;background:#fff;color:var(--slate-700)}.filter-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 2px var(--primary-100)}.category-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--slate-100);color:var(--slate-600);font-size:.7rem;font-weight:500;border-radius:var(--radius-md);text-transform:uppercase;letter-spacing:.02em}.category-badge-lg{font-size:.75rem;padding:var(--spacing-1) var(--spacing-3)}.table-cell-ref{font-size:.75rem;color:var(--slate-500);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expense-detail-header{margin-bottom:var(--spacing-6)}.expense-header-left{display:flex;flex-direction:column;gap:var(--spacing-3)}.expense-amount-display{font-size:2rem;font-weight:800;color:var(--slate-800);letter-spacing:-.02em}.expense-header-meta{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.expense-actions{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap}.expense-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--spacing-6);margin-bottom:var(--spacing-6)}.expense-description{font-size:.875rem;line-height:1.7;color:var(--slate-600);white-space:pre-wrap;margin:0}.dialog-form{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.dialog-wide{max-width:400px}@media(max-width:767px){.expenses-page{padding-bottom:20px}.expense-stats{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.expense-stats .stat-card{padding:.875rem;flex-direction:column;align-items:flex-start;gap:.5rem}.expense-stats .stat-card-icon{width:36px;height:36px}.expense-stats .stat-card-value{font-size:1.25rem}.expense-stats .stat-card-label{font-size:.6875rem}.filters-bar-wrap{flex-direction:column;gap:.5rem}.filter-input{width:100%;font-size:16px}.expense-actions{flex-direction:column;gap:.5rem}.expense-actions .btn{width:100%;justify-content:center}.expense-detail-header{margin-bottom:1.25rem}.expense-amount-display{font-size:1.5rem}.expense-header-meta{gap:.5rem}.expense-detail-grid{grid-template-columns:1fr;gap:1rem}}@media(max-width:359px){.expense-stats{grid-template-columns:1fr 1fr}.expense-amount-display{font-size:1.25rem}}.petty-cash-page{width:100%}.table-cell-balance{font-weight:600}.wallet-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6);margin-bottom:var(--spacing-6);flex-wrap:wrap}.wallet-header-left{flex:1;min-width:250px}.wallet-title{font-size:1.5rem;font-weight:800;color:var(--slate-800);margin:0 0 var(--spacing-2) 0}.wallet-meta{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.wallet-site,.wallet-holder{font-size:.875rem;color:var(--slate-600)}.wallet-balance-display{display:flex;flex-direction:column;align-items:flex-end;padding:var(--spacing-4) var(--spacing-6);background:var(--slate-50);border-radius:var(--radius-lg);border:1px solid var(--slate-200)}.wallet-balance-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);margin-bottom:var(--spacing-1)}.wallet-balance-amount{font-size:2rem;font-weight:800;letter-spacing:-.02em}.wallet-limit{font-size:.75rem;color:var(--slate-400);margin-top:var(--spacing-1)}.wallet-actions{display:flex;gap:var(--spacing-3);margin-bottom:var(--spacing-6);flex-wrap:wrap}.balance-info-banner{padding:var(--spacing-3) var(--spacing-4);background:var(--info-50);border:1px solid var(--info-200);border-radius:var(--radius-md);color:var(--info-700);font-size:.875rem;margin-bottom:var(--spacing-6)}.ledger-card{margin-bottom:var(--spacing-6)}.ledger-table-container{overflow-x:auto}.ledger-table{width:100%;border-collapse:collapse;font-size:.875rem}.ledger-table thead{background:var(--slate-50)}.ledger-table th,.ledger-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--slate-100)}.ledger-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);font-weight:600}.ledger-date{font-size:.75rem;color:var(--slate-600);white-space:nowrap}.ledger-desc{font-weight:500;color:var(--slate-700);max-width:250px}.ledger-ref{font-size:.75rem;color:var(--slate-500)}.ledger-amount{font-weight:700;font-family:var(--font-mono);white-space:nowrap}.ledger-user{font-size:.75rem;color:var(--slate-500)}.txn-type-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-md);font-size:.7rem;font-weight:600;text-transform:uppercase}.txn-issue{background:var(--success-100);color:var(--success-700)}.txn-spend{background:var(--error-100);color:var(--error-700)}.txn-refund{background:var(--warning-100);color:var(--warning-700)}.txn-adjustment{background:var(--info-100);color:var(--info-700)}.loading-state-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-8);color:var(--slate-500)}.settings-page{width:100%!important;max-width:100%!important;padding:0}.user-name-cell{display:flex;align-items:center;gap:var(--spacing-3)}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.user-name{font-weight:600;color:var(--slate-800)}.user-contact{display:flex;align-items:center;gap:var(--spacing-2);font-size:.875rem;color:var(--slate-600)}.user-contact svg{color:var(--slate-400)}.user-roles{font-size:.8rem;color:var(--slate-600);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-name-cell{display:flex;align-items:center;gap:var(--spacing-2)}.role-name-cell svg{color:var(--primary-500)}.role-name{font-weight:600;color:var(--slate-800);font-family:var(--font-mono)}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:40px}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--slate-400);cursor:pointer;padding:4px}.role-checkbox-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.checkbox-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--slate-50);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.checkbox-item:hover{background:var(--slate-100)}.checkbox-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-500)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:.875rem;color:var(--slate-700)}.badge-sm{font-size:.65rem;padding:.125rem .375rem}.form-info-box{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius-md);padding:var(--spacing-4);margin-top:var(--spacing-4)}.form-info-box p{margin:0;font-size:.875rem;color:var(--blue-700)}.table-actions{display:flex;gap:var(--spacing-2)}.skeleton-actions{width:100px;height:32px}.role-header-title{display:flex;align-items:flex-start;gap:var(--spacing-3)}.role-header-title svg{color:var(--primary-500);flex-shrink:0;margin-top:4px}.role-header-meta{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-1)}.role-name-tag{font-family:var(--font-mono);font-size:.75rem;color:var(--slate-500);background:var(--slate-100);padding:.125rem .5rem;border-radius:var(--radius-sm)}.system-role-banner{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:var(--amber-50);border:1px solid var(--amber-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);color:var(--amber-700);font-size:.875rem}.system-role-banner svg{flex-shrink:0}.permissions-actions{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.permissions-card{padding:0}.permissions-table-container{overflow-x:auto}.permissions-table th,.permissions-table td{padding:var(--spacing-3);border-bottom:1px solid var(--slate-100);text-align:center}.permissions-table th{background:var(--slate-50);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-600)}.resource-column{text-align:left!important;width:200px;min-width:200px}.action-column{width:80px}.row-actions-column{width:50px}.resource-cell{text-align:left!important}.resource-label{font-weight:500;color:var(--slate-700)}.action-cell{vertical-align:middle}.permission-checkbox{display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.permission-checkbox input{position:absolute;opacity:0;cursor:pointer}.checkbox-visual{width:20px;height:20px;border:2px solid var(--slate-300);border-radius:var(--radius-sm);background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.permission-checkbox input:checked+.checkbox-visual{background:var(--primary-500);border-color:var(--primary-500)}.permission-checkbox input:checked+.checkbox-visual:after{content:"✓";color:#fff;font-size:12px;font-weight:700}.permission-checkbox input:disabled+.checkbox-visual{opacity:.5;cursor:not-allowed}.permission-checkbox:hover .checkbox-visual:not(:disabled){border-color:var(--primary-400)}.row-actions-cell{padding:var(--spacing-2)}.btn-xs{padding:.25rem .375rem;font-size:.75rem}.btn-ghost{background:transparent;border:none;color:var(--slate-400)}.btn-ghost:hover{color:var(--slate-600);background:var(--slate-100)}.unsaved-changes-bar{position:fixed;bottom:0;left:var(--sidebar-width);right:0;background:#fff;border-top:1px solid var(--slate-200);padding:var(--spacing-3) var(--spacing-6);display:flex;align-items:center;justify-content:space-between;box-shadow:0 -4px 12px #0000001a;z-index:100}.unsaved-changes-bar span{font-weight:500;color:var(--slate-700)}.unsaved-changes-actions{display:flex;gap:var(--spacing-2)}@media(max-width:1024px){.unsaved-changes-bar{left:0}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);color:var(--slate-500)}.loading-state svg{color:var(--primary-500);margin-bottom:var(--spacing-4)}.error-state-full{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);text-align:center}.error-state-full svg{color:var(--red-500);margin-bottom:var(--spacing-4)}.error-state-full h3{color:var(--slate-800);margin:0 0 var(--spacing-4)}@media(max-width:767px){.settings-page{padding-bottom:20px}.user-avatar{width:32px;height:32px;font-size:.75rem}.permissions-table-container{margin:0 -12px;padding:0 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.permissions-table{min-width:600px}.permissions-actions{flex-direction:column;gap:.5rem}.permissions-actions .btn{width:100%;justify-content:center}.unsaved-changes-bar{left:0;padding:.875rem;flex-direction:column;gap:.75rem;padding-bottom:calc(.875rem + env(safe-area-inset-bottom))}.unsaved-changes-bar span{font-size:.875rem}.unsaved-changes-actions{width:100%}.unsaved-changes-actions .btn{flex:1;justify-content:center}.role-checkbox-list{gap:.5rem}.checkbox-item{padding:.75rem}.system-role-banner{padding:.75rem;font-size:.8125rem}.table-actions{flex-direction:column}}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card-compact{background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem}.stat-card-compact .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.stat-card-compact .stat-info{flex:1}.stat-card-compact .stat-value{font-size:1.25rem;font-weight:700;color:var(--slate-800);line-height:1.2}.stat-card-compact .stat-label{font-size:.75rem;color:var(--slate-500);text-transform:uppercase;letter-spacing:.025em}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.role-checkbox{transition:all .2s ease}.role-checkbox:hover{border-color:var(--primary-300)!important}.role-checkbox.selected{box-shadow:0 0 0 3px rgba(var(--primary-500-rgb),.1)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.input-with-icon{position:relative}.input-with-icon>svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--slate-400);pointer-events:none}.table-row-clickable{cursor:pointer;transition:background .15s ease}.table-row-clickable:hover{background:var(--slate-50)}.back-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--slate-600);background:none;border:none;cursor:pointer;padding:.5rem .75rem;margin-left:-.75rem;border-radius:8px;transition:all .15s ease}.back-link:hover{background:var(--slate-100);color:var(--slate-800)}.page-header-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--primary-500) 0%,var(--primary-600) 100%);display:flex;align-items:center;justify-content:center;color:#fff}.form-hint{display:block;font-size:.75rem;color:var(--slate-500);margin-top:.25rem}@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr);gap:.75rem}.form-grid{grid-template-columns:1fr;gap:1rem}.roles-grid{grid-template-columns:1fr}.page-header-icon{width:36px;height:36px;border-radius:10px}.page-header-icon svg{width:18px;height:18px}}.settings-page{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.settings-header{margin-bottom:1.5rem}.settings-header h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.settings-header p{color:#64748b;font-size:.875rem;margin:.5rem 0 0}.settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#64748b}.settings-loading svg{color:#3b82f6;margin-bottom:1rem}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:1.5rem}.settings-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000014;border:1px solid rgba(0,0,0,.04);overflow:hidden}.settings-card.full-width{grid-column:1 / -1}.settings-card-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.settings-card-header svg{color:#3b82f6}.settings-card-header h2{font-size:1rem;font-weight:600;color:#1e293b;margin:0}.settings-card-body{padding:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.375rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s;background:#fff}.toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500}.toggle-label input[type=checkbox]{display:none}.toggle-switch{width:44px;height:24px;background:#d1d5db;border-radius:12px;position:relative;transition:all .3s}.toggle-switch:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:all .3s;box-shadow:0 1px 3px #0003}.toggle-label input[type=checkbox]:checked+.toggle-switch{background:linear-gradient(135deg,#3b82f6,#2563eb)}.toggle-label input[type=checkbox]:checked+.toggle-switch:after{left:22px}.mode-selector{display:flex;gap:1rem}.mode-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s;background:#fff}.mode-option input{display:none}.mode-option:hover{border-color:#94a3b8}.mode-option.active{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.mode-option.active svg{color:#2563eb}.mode-option span{font-weight:500;color:#64748b}.mode-option.active span{color:#1e40af}.api-credentials{padding:1.5rem;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.api-credentials.production{background:#fefce8;border-color:#fde68a}.credentials-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.credentials-header h4{margin:0;font-size:.875rem;font-weight:600;color:#1e293b}.sandbox-badge{padding:.25rem .625rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-radius:6px;font-size:.6875rem;font-weight:600;text-transform:uppercase}.production-badge{padding:.25rem .625rem;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border-radius:6px;font-size:.6875rem;font-weight:600;text-transform:uppercase}.credentials-hint{font-size:.8125rem;color:#64748b;margin:0 0 1rem}.credentials-hint a{color:#2563eb;text-decoration:none}.credentials-hint a:hover{text-decoration:underline}.sandbox-note,.production-warning{display:flex;align-items:flex-start;gap:.625rem;padding:.875rem;border-radius:8px;font-size:.8125rem;margin-top:1rem}.sandbox-note{background:#fffbeb;color:#92400e}.sandbox-note svg{flex-shrink:0;margin-top:1px}.production-warning{background:#dcfce7;color:#166534}.production-warning svg{flex-shrink:0;margin-top:1px}.test-connection{display:flex;align-items:center;gap:1rem}.test-result{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:8px;font-size:.875rem;font-weight:500}.test-result.success{background:#dcfce7;color:#166534}.test-result.error{background:#fee2e2;color:#b91c1c}.settings-footer{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000014}.save-success{display:flex;align-items:center;gap:.5rem;color:#16a34a;font-weight:500;font-size:.875rem}.btn-lg{padding:.875rem 1.5rem;font-size:1rem}.animate-spin{animation:spin 1s linear infinite}@media(max-width:768px){.settings-grid{grid-template-columns:1fr}.mode-selector{flex-direction:column}.test-connection{flex-direction:column;align-items:flex-start}.settings-footer{flex-direction:column}.settings-footer .btn-lg{width:100%}}.role-permissions-page{padding:1.5rem;width:100%;margin:0 auto}.permissions-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.permissions-header-left{display:flex;align-items:flex-start;gap:1rem}.role-info{display:flex;flex-direction:column;gap:.25rem}.role-title{display:flex;align-items:center;gap:.75rem}.role-title h1{margin:0;font-size:1.5rem;font-weight:700;color:var(--slate-800)}.role-title svg:first-child{color:var(--primary-600)}.system-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--slate-100);color:var(--slate-600);font-size:.7rem;font-weight:600;border-radius:20px}.role-subtitle{margin:0;color:var(--slate-500);font-size:.875rem}.permissions-header-right{display:flex;align-items:center;gap:1rem}.info-banner{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--amber-50);color:var(--amber-700);font-size:.8rem;font-weight:500;border-radius:8px;border:1px solid var(--amber-200)}.permissions-stats{display:flex;align-items:center;gap:2rem;padding:1rem 1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1.5rem}.stat-item{display:flex;flex-direction:column;gap:.125rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--primary-600)}.stat-label{font-size:.75rem;font-weight:500;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.stat-divider{width:1px;height:40px;background:var(--slate-200)}.quick-actions{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--slate-50);border-radius:10px;margin-bottom:1.5rem}.quick-actions-label{font-size:.8rem;font-weight:600;color:var(--slate-600)}.quick-actions-buttons{display:flex;align-items:center;gap:.5rem}.template-select{padding:.5rem 2rem .5rem .75rem;background:#fff;border:1px solid var(--slate-200);border-radius:8px;font-size:.8rem;color:var(--slate-700);cursor:pointer;appearance:none;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 .5rem center;background-repeat:no-repeat;background-size:1em 1em}.category-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1rem;overflow:hidden}.category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.25rem;background:transparent;border:none;cursor:pointer;transition:background .15s}.category-header:hover{background:var(--slate-50)}.category-left{display:flex;align-items:center;gap:.5rem}.category-left svg{color:var(--slate-400)}.category-name{font-size:.9rem;font-weight:600;color:var(--slate-700)}.category-stats{display:flex;align-items:center;gap:1rem}.category-count{font-size:.75rem;color:var(--slate-400)}.category-permissions{font-size:.75rem;padding:2px 8px;background:var(--slate-100);color:var(--slate-500);border-radius:12px}.category-permissions.active{background:var(--primary-100);color:var(--primary-700)}.category-content{border-top:1px solid var(--slate-100)}.permissions-table{width:100%;border-collapse:collapse}.permissions-table th{padding:.75rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate-500);background:var(--slate-50);border-bottom:1px solid var(--slate-100);text-align:center}.permissions-table th.module-header{text-align:left;padding-left:1.25rem;width:35%}.permissions-table th.action-header{width:9%}.permission-row{border-bottom:1px solid var(--slate-100)}.permission-row:last-child{border-bottom:none}.permission-row:hover{background:var(--slate-50)}.module-cell{padding:.875rem 1.25rem}.module-info{display:flex;flex-direction:column;gap:.125rem}.module-name{font-weight:600;color:var(--slate-800);font-size:.875rem}.module-desc{font-size:.75rem;color:var(--slate-500)}.action-cell{padding:.75rem .5rem;text-align:center}.action-cell.disabled-cell{color:var(--slate-300);font-size:.75rem}.permission-checkbox{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:2px solid var(--slate-300);border-radius:6px;cursor:pointer;transition:all .15s;padding:0}.permission-checkbox:hover:not(.disabled){border-color:var(--primary-400);background:var(--primary-50)}.permission-checkbox.checked{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.permission-checkbox.disabled{opacity:.5;cursor:not-allowed}.assigned-users{margin-top:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014}.assigned-users h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--slate-700)}.assigned-users h3 svg{color:var(--slate-400)}.users-list{display:flex;flex-wrap:wrap;gap:.75rem}.user-chip{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem .5rem .5rem;background:var(--slate-50);border-radius:30px}.user-chip-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:600}.user-chip-info{display:flex;flex-direction:column}.user-chip-name{font-size:.8rem;font-weight:600;color:var(--slate-700)}.user-chip-email{font-size:.7rem;color:var(--slate-500)}.unsaved-banner{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:1rem;padding:.875rem 1.5rem;background:var(--slate-900);color:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;z-index:100;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.unsaved-banner svg{color:var(--amber-400)}.unsaved-banner span{font-size:.875rem;font-weight:500}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--slate-500)}.error-state svg{color:var(--error-500)}.btn-sm{padding:.375rem .75rem;font-size:.8rem}@media(max-width:1024px){.permissions-header{flex-direction:column}.permissions-stats{flex-wrap:wrap;gap:1rem}.stat-divider{display:none}.quick-actions{flex-direction:column;align-items:flex-start}.permissions-table{font-size:.8rem}.permissions-table th.module-header{width:40%}.module-desc{display:none}}@media(max-width:768px){.role-permissions-page,.permissions-stats{padding:1rem}.stat-value{font-size:1.25rem}.permission-checkbox{width:20px;height:20px}.action-cell{padding:.5rem .25rem}.unsaved-banner{left:1rem;right:1rem;transform:none}}.settings-page{padding:2rem;max-width:900px;margin:0 auto}.settings-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.settings-header-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-100),var(--primary-50));border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--primary-600)}.settings-header h1{font-size:1.75rem;font-weight:700;color:var(--slate-800);margin:0}.settings-header p{color:var(--slate-500);margin:.25rem 0 0;font-size:.9rem}.settings-content{display:flex;flex-direction:column;gap:2rem}.settings-section h2{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--slate-700);margin:0 0 1rem}.settings-section h2 svg{color:var(--slate-400)}.settings-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000014;overflow:hidden}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--slate-100)}.settings-row:last-child{border-bottom:none}.settings-row-info{display:flex;flex-direction:column;gap:.25rem}.settings-row-title{font-weight:600;color:var(--slate-800)}.settings-row-desc{font-size:.8rem;color:var(--slate-500)}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--slate-200);border-radius:26px;transition:.3s}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary-600)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.theme-selector{display:flex;gap:.5rem}.theme-option{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--slate-100);border:2px solid transparent;border-radius:10px;font-size:.875rem;font-weight:500;color:var(--slate-600);cursor:pointer;transition:all .15s}.theme-option:hover{background:var(--slate-200)}.theme-option.active{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.settings-select{padding:.625rem 2.5rem .625rem 1rem;background:var(--slate-50);border:1px solid var(--slate-200);border-radius:10px;font-size:.875rem;color:var(--slate-700);cursor:pointer;appearance:none;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 .75rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;min-width:160px}.settings-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.settings-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.settings-link-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-radius:14px;text-decoration:none;box-shadow:0 1px 3px #00000014;transition:all .2s}.settings-link-card:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0000001a}.settings-link-card.disabled{opacity:.7;cursor:not-allowed}.settings-link-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--slate-100),var(--slate-50));border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--slate-600);flex-shrink:0}.settings-link-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.settings-link-title{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--slate-800)}.settings-link-desc{font-size:.8rem;color:var(--slate-500)}.settings-link-arrow{color:var(--slate-400)}.settings-badge{display:inline-block;padding:.125rem .5rem;background:var(--amber-100);color:var(--amber-700);font-size:.65rem;font-weight:600;border-radius:20px;text-transform:uppercase}.settings-app-info{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,var(--slate-50),white);border-radius:16px}.app-logo{width:48px;height:48px;background:linear-gradient(135deg,var(--primary-600),var(--primary-700));border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;font-weight:700}.app-details{display:flex;flex-direction:column;gap:.125rem}.app-name{font-weight:700;color:var(--slate-800)}.app-version{font-size:.8rem;color:var(--slate-500)}.app-copyright{font-size:.75rem;color:var(--slate-400)}@media(max-width:640px){.settings-page{padding:1rem}.settings-header{flex-direction:column;text-align:center}.settings-row{flex-direction:column;align-items:flex-start;gap:1rem}.theme-selector{width:100%}.theme-option{flex:1;justify-content:center}.settings-select{width:100%}.settings-cards-grid{grid-template-columns:1fr}}.user-edit-page{padding:1.5rem;width:100%;margin:0 auto}.user-edit-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:1rem}.back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--slate-200);border-radius:10px;color:var(--slate-600);cursor:pointer;transition:all .15s}.user-header-info{display:flex;align-items:center;gap:1rem}.user-avatar-lg{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0}.user-header-details h1{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--slate-800)}.user-header-meta{display:flex;align-items:center;gap:.75rem}.user-header-meta .email{color:var(--slate-500);font-size:.875rem}.status-badge{padding:2px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.status-badge.active{background:var(--success-100);color:var(--success-700)}.status-badge.inactive{background:var(--slate-100);color:var(--slate-600)}.header-actions{display:flex;gap:.5rem}.inactive-banner{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:var(--danger-50);border:1px solid var(--danger-200);border-radius:10px;color:var(--danger-700);margin-bottom:1.5rem}.user-edit-content{display:grid;grid-template-columns:1fr 320px;gap:1.5rem}.user-edit-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{background:#fff;border-radius:14px;box-shadow:0 1px 3px #00000014;overflow:hidden}.section-header{display:flex;align-items:center;gap:.625rem;padding:1rem 1.25rem;border-bottom:1px solid var(--slate-100)}.section-header svg{color:var(--slate-400)}.section-header h2{margin:0;font-size:1rem;font-weight:600;color:var(--slate-700)}.section-badge{margin-left:auto;padding:2px 10px;background:var(--primary-100);color:var(--primary-700);font-size:.7rem;font-weight:600;border-radius:20px}.section-content{padding:1.25rem}.section-description{margin:0 0 1rem;font-size:.875rem;color:var(--slate-500);line-height:1.5}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--slate-700)}.form-group label .required{color:var(--danger-500)}.form-input,.form-select{width:100%;padding:.625rem .875rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.9rem;transition:all .15s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.form-input.disabled{background:var(--slate-50);color:var(--slate-500);cursor:not-allowed}.form-input.error{border-color:var(--danger-400)}.form-select{appearance:none;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 .75rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;padding-right:2.5rem}.form-error{font-size:.75rem;color:var(--danger-500)}.form-hint{font-size:.75rem;color:var(--slate-400)}.input-icon-wrapper{position:relative;display:flex;align-items:center}.input-icon-wrapper svg{position:absolute;left:.875rem;color:var(--slate-400);pointer-events:none}.input-icon-wrapper input{padding-left:2.5rem}.input-icon-wrapper.password input{padding-right:2.5rem;padding-left:.875rem}.password-toggle{position:absolute;right:.5rem;background:transparent;border:none;color:var(--slate-400);cursor:pointer;padding:.25rem}.password-toggle:hover{color:var(--slate-600)}.error-banner{padding:.75rem 1rem;background:var(--danger-50);border:1px solid var(--danger-200);border-radius:8px;margin-bottom:1rem;color:var(--danger-600);font-size:.875rem}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.role-card{position:relative;padding:1rem;border:2px solid var(--slate-200);border-radius:12px;cursor:pointer;transition:all .2s;background:#fff}.role-card:hover{border-color:var(--slate-300);background:var(--slate-50)}.role-card.selected{border-color:var(--primary-500);background:var(--primary-50)}.role-card-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.role-checkbox{width:22px;height:22px;flex-shrink:0;border:2px solid var(--slate-300);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;transition:all .15s}.role-checkbox.checked{background:var(--primary-600);border-color:var(--primary-600)}.role-info{flex:1}.role-name{display:block;font-weight:600;color:var(--slate-800);margin-bottom:.125rem}.role-code{font-size:.7rem;color:var(--slate-500);font-family:var(--font-mono)}.role-card-footer{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.role-scope{padding:2px 8px;background:var(--slate-100);color:var(--slate-600);font-size:.65rem;font-weight:600;border-radius:12px;text-transform:uppercase}.role-permissions{display:flex;align-items:center;gap:4px;padding:2px 8px;background:var(--info-100);color:var(--info-700);font-size:.65rem;font-weight:600;border-radius:12px}.role-system{padding:2px 8px;background:var(--amber-100);color:var(--amber-700);font-size:.65rem;font-weight:600;border-radius:12px}.role-link{display:flex;align-items:center;gap:4px;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--slate-100);font-size:.75rem;font-weight:500;color:var(--primary-600);text-decoration:none}.role-link:hover{color:var(--primary-700)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem}.user-edit-sidebar{display:flex;flex-direction:column;gap:1rem}.info-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;padding:1.25rem}.info-card h3{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--slate-700)}.info-card h3 svg{color:var(--slate-400)}.info-rows{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between;align-items:center}.info-label{font-size:.8rem;color:var(--slate-500)}.info-value{font-size:.8rem;color:var(--slate-700);font-weight:500}.access-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.access-stat{text-align:center;padding:1rem;background:var(--slate-50);border-radius:10px}.access-stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--primary-600)}.access-stat-label{font-size:.7rem;font-weight:500;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.selected-roles-list{display:flex;flex-direction:column;gap:.5rem}.selected-role-item{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:var(--slate-50);border-radius:8px}.selected-role-name{font-size:.8rem;font-weight:500;color:var(--slate-700)}.selected-role-link{font-size:.75rem;color:var(--primary-600);text-decoration:none}.selected-role-link:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #3b82f64d}.btn-success{background:linear-gradient(135deg,var(--success-600),var(--success-700));color:#fff}.btn-danger-outline{background:transparent;border:1px solid var(--danger-300);color:var(--danger-600)}.btn-danger-outline:hover{background:var(--danger-50)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;text-align:center;color:var(--slate-500)}.error-state svg{color:var(--danger-400)}.error-state h3{margin:0;color:var(--slate-700)}.error-state p{margin:0;color:var(--slate-500)}@media(max-width:1024px){.user-edit-content{grid-template-columns:1fr}.user-edit-sidebar{order:-1}}@media(max-width:768px){.user-edit-page{padding:1rem}.user-edit-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center}.form-grid,.roles-grid{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%;justify-content:center}}.material-requests-page{width:100%}.mr-number-cell{display:flex;align-items:center;gap:var(--spacing-2)}.mr-number-cell svg{color:var(--primary-500)}.mr-number{font-weight:700;font-family:var(--font-mono);color:var(--slate-800)}.mr-purpose{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--slate-600)}.items-summary{display:flex;align-items:center;gap:var(--spacing-2)}.items-count{color:var(--slate-600)}.shortage-indicator{display:inline-flex;align-items:center;gap:2px;color:var(--error-600);font-size:.75rem;font-weight:600}.mr-detail-header{display:flex;align-items:flex-start;gap:var(--spacing-3)}.mr-detail-header svg{color:var(--primary-500);flex-shrink:0;margin-top:4px}.mr-header-meta{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-1)}.mr-purpose-tag{font-size:.875rem;color:var(--slate-500)}.material-cell{display:flex;flex-direction:column;gap:2px}.material-name{font-weight:500;color:var(--slate-800)}.material-code{font-size:.75rem;color:var(--slate-500);font-family:var(--font-mono)}.stock-value{display:inline-flex;align-items:center;gap:var(--spacing-1);font-weight:500}.stock-value.insufficient{color:var(--error-600)}.stock-value.insufficient svg{color:var(--error-500)}.row-shortage{background:var(--red-50)}.row-shortage:hover{background:var(--red-100)!important}.issue-input{width:80px;text-align:center;padding:var(--spacing-2)}.form-section{border:1px solid var(--slate-200);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-top:var(--spacing-2)}.form-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.empty-items{text-align:center;padding:var(--spacing-6);color:var(--slate-500);background:var(--slate-50);border-radius:var(--radius-md)}.empty-items p{margin:0}.items-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.item-row{display:grid;grid-template-columns:1fr 150px 100px 40px;gap:var(--spacing-3);align-items:center;padding:var(--spacing-3);background:var(--slate-50);border-radius:var(--radius-md)}.item-material{flex:1}.item-qty{display:flex;align-items:center;gap:var(--spacing-2)}.item-qty .form-input{width:80px;text-align:right}.item-unit{font-size:.75rem;color:var(--slate-500);min-width:40px}.item-stock{min-width:100px}.stock-indicator{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;padding:2px 8px;border-radius:var(--radius-sm)}.stock-indicator.available{background:var(--green-50);color:var(--green-700)}.stock-indicator.shortage{background:var(--red-50);color:var(--red-700)}.mb-4{margin-bottom:var(--spacing-4)}.card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--slate-100)}.card-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--slate-800)}.text-right{text-align:right}.dialog-overlay{position:fixed;inset:0;background:#00000080;z-index:200}.dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:var(--radius-xl);padding:var(--spacing-6);width:400px;max-width:90%;z-index:201;box-shadow:var(--shadow-xl)}.dialog-title{margin:0 0 var(--spacing-3);font-size:1.125rem;font-weight:700;color:var(--slate-800)}.dialog-message{margin:0 0 var(--spacing-6);color:var(--slate-600);line-height:1.5}.dialog-actions{display:flex;justify-content:flex-end;gap:var(--spacing-3)}.btn-success{background:var(--success-500);color:#fff}.btn-success:hover{background:var(--success-600)}.btn-danger-outline{background:transparent;color:var(--error-600);border:1px solid var(--error-300)}.btn-danger-outline:hover{background:var(--error-50);border-color:var(--error-400)}.btn-icon{padding:var(--spacing-2)}.mention-input-container{position:relative;flex:1}.mention-input{width:100%;padding:.625rem .875rem;border:2px solid #e2e8f0;border-radius:12px;background:#f8fafc;color:#0f172a;font-size:.9375rem;transition:all .2s ease}.mention-input:focus{outline:none;border-color:#a78bfa;background:#fff;box-shadow:0 0 0 4px #a78bfa1a}.mention-input:disabled{background:#f1f5f9;cursor:not-allowed;opacity:.7}.mention-input::placeholder{color:#94a3b8}.mention-suggestions{position:absolute;bottom:100%;left:0;right:0;margin-bottom:8px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 10px 40px #0000001f;max-height:280px;overflow-y:auto;z-index:1000;animation:mentionSlideUp .2s ease}@keyframes mentionSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mention-suggestions::-webkit-scrollbar{width:6px}.mention-suggestions::-webkit-scrollbar-track{background:transparent}.mention-suggestions::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:3px}.mention-hint{display:flex;align-items:center;gap:.625rem;padding:1rem 1.25rem;color:#64748b;font-size:.8125rem}.mention-hint svg{color:#a78bfa}.mention-empty{padding:1.25rem;text-align:center;color:#94a3b8;font-size:.8125rem}.mention-item{display:flex;align-items:center;gap:.875rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;cursor:pointer;text-align:left;transition:all .15s ease}.mention-item:hover,.mention-item.selected{background:linear-gradient(135deg,#a78bfa14,#8b5cf60d)}.mention-item:first-child{border-radius:14px 14px 0 0}.mention-item:last-child{border-radius:0 0 14px 14px}.mention-item:only-child{border-radius:14px}.mention-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#7c3aed,#6d28d9);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:0 2px 8px #7c3aed40}.mention-avatar img{width:100%;height:100%;object-fit:cover}.mention-avatar span{color:#fff;font-size:.8125rem;font-weight:700}.mention-info{display:flex;flex-direction:column;gap:2px;min-width:0}.mention-name{font-size:.875rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-email{font-size:.75rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-mention{color:#7c3aed;font-weight:600;background:#7c3aed1a;padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .15s}.communication-page{height:calc(100vh - 64px);display:flex;margin:-1.5rem;background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e);overflow:hidden}.comm-sidebar{width:300px;background:#0f0f23f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.05);display:flex;flex-direction:column;flex-shrink:0}.comm-sidebar-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.06)}.comm-sidebar-header h2{margin:0;font-size:1.25rem;font-weight:700;color:#fff;display:flex;align-items:center;gap:.5rem}.comm-sidebar-header h2 svg{color:#a78bfa}.ws-connected{color:#10b981;font-size:8px;margin-left:4px;animation:pulse 2s infinite ease-in-out}.comm-search{padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;background:#ffffff08;margin:.75rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);transition:all .2s ease}.comm-search:focus-within{border-color:#a78bfa66;background:#ffffff0d;box-shadow:0 0 0 3px #a78bfa1a}.comm-search svg{color:#64748b;flex-shrink:0}.comm-search input{flex:1;background:transparent;border:none;color:#e2e8f0;font-size:.875rem;outline:none}.comm-search input::placeholder{color:#64748b}.comm-channels{flex:1;overflow-y:auto;padding:.5rem .75rem 1rem}.comm-channels::-webkit-scrollbar{width:6px}.comm-channels::-webkit-scrollbar-track{background:transparent}.comm-channels::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.comm-channels::-webkit-scrollbar-thumb:hover{background:#fff3}.comm-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#64748b;font-size:.8rem}.channel-section{margin-bottom:1.25rem}.channel-section-title{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;cursor:pointer;transition:color .2s}.channel-section-title:hover{color:#94a3b8}.channel-section-title:before{content:"";width:6px;height:6px;background:currentColor;border-radius:2px;opacity:.5}.channel-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;background:transparent;border:none;border-radius:8px;color:#94a3b8;font-size:.875rem;cursor:pointer;transition:all .15s ease;text-align:left;position:relative}.channel-item:hover{background:#ffffff0d;color:#e2e8f0}.channel-item.active{background:linear-gradient(135deg,#a78bfa33,#8b5cf626);color:#fff;box-shadow:inset 0 0 0 1px #a78bfa4d}.channel-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,#a78bfa,#7c3aed);border-radius:0 3px 3px 0}.channel-item svg{opacity:.6;flex-shrink:0}.channel-item.active svg{opacity:1;color:#a78bfa}.channel-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.channel-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-sub{font-size:.7rem;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-item.active .channel-sub{color:#fff9}.channel-unread{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ef44444d}.comm-main{flex:1;display:flex;flex-direction:column;background:linear-gradient(180deg,#f8fafc,#f1f5f9);overflow:hidden}.comm-header{padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #00000005}.comm-back-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:#64748b;border-radius:10px;cursor:pointer;transition:all .15s;margin-right:.5rem}.comm-back-btn:hover{background:#f1f5f9;color:#0f172a}.comm-header-info{display:flex;align-items:center;gap:.75rem}.comm-header-info svg{color:#7c3aed;padding:8px;background:#7c3aed1a;border-radius:10px}.comm-header h3{margin:0;font-size:1rem;font-weight:700;color:#0f172a}.comm-header-sub{font-size:.75rem;color:#64748b;display:block}.comm-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column}.comm-messages::-webkit-scrollbar{width:8px}.comm-messages::-webkit-scrollbar-track{background:transparent}.comm-messages::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.comm-messages::-webkit-scrollbar-thumb:hover{background:#94a3b8}.comm-messages-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#64748b}.comm-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;text-align:center;color:#94a3b8}.comm-empty svg{color:#cbd5e1}.comm-empty h3{margin:0;color:#64748b;font-size:1.125rem}.comm-empty p{margin:0;font-size:.875rem}.message-date-divider{display:flex;align-items:center;justify-content:center;margin:1.5rem 0;position:relative}.message-date-divider:before,.message-date-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,#e2e8f0,transparent)}.message-date-divider span{padding:.375rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.message-item{display:flex;gap:.75rem;padding:.625rem .75rem;border-radius:12px;margin-bottom:.25rem;transition:background .15s ease}.message-item:hover{background:#00000005}.message-avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0;box-shadow:0 2px 8px #7c3aed40}.message-avatar img{width:100%;height:100%;object-fit:cover;border-radius:12px}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:center;gap:.5rem;margin-bottom:4px;flex-wrap:wrap}.message-sender{font-weight:600;font-size:.875rem;color:#0f172a}.message-time{font-size:.7rem;color:#94a3b8}.message-read-status{display:flex;align-items:center}.message-read-status svg{color:#10b981;width:14px;height:14px}.message-text{font-size:.9375rem;color:#334155;line-height:1.6;word-wrap:break-word}.message-mention{color:#7c3aed;font-weight:600;background:#7c3aed1a;padding:1px 6px;border-radius:4px;cursor:pointer;transition:all .15s}.message-mention:hover{background:#7c3aed33}.message-priority{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.message-priority.priority-safety{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;border:1px solid rgba(220,38,38,.2)}.message-priority.priority-delay{background:linear-gradient(135deg,#fff7ed,#ffedd5);color:#ea580c;border:1px solid rgba(234,88,12,.2)}.message-priority.priority-issue{background:linear-gradient(135deg,#fefce8,#fef08a);color:#ca8a04;border:1px solid rgba(202,138,4,.2)}.message-priority.priority-urgent{background:linear-gradient(135deg,#f5f3ff,#ede9fe);color:#7c3aed;border:1px solid rgba(124,58,237,.2)}.message-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.message-attachments .attachment-item{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.8rem;color:#334155;text-decoration:none;transition:all .2s;box-shadow:0 1px 2px #0000000a}.message-attachments .attachment-item:hover{border-color:#a78bfa;box-shadow:0 2px 8px #7c3aed1a;transform:translateY(-1px)}.message-attachments .attachment-item svg{color:#7c3aed}.message-attachments .attachment-size{color:#94a3b8;font-size:.7rem}.typing-indicator{display:flex;align-items:center;gap:10px;padding:.75rem 1rem;margin-top:.5rem;font-size:.8rem;color:#64748b;animation:fadeSlideIn .3s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.typing-dots{display:flex;gap:4px}.typing-dots span{width:8px;height:8px;background:linear-gradient(135deg,#a78bfa,#7c3aed);border-radius:50%;animation:typingPulse 1.4s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.15s}.typing-dots span:nth-child(3){animation-delay:.3s}@keyframes typingPulse{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.attachments-preview{display:flex;gap:8px;padding:.75rem 1.5rem;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-top:1px solid #e2e8f0;flex-wrap:wrap}.attachment-preview-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.8rem;color:#334155;box-shadow:0 1px 3px #0000000a}.attachment-preview-item svg{color:#7c3aed}.attachment-preview-item span{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.remove-attachment{width:20px;height:20px;border-radius:50%;border:none;background:#fee2e2;color:#ef4444;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .15s}.remove-attachment:hover{background:#fecaca;transform:scale(1.1)}.comm-composer{padding:1rem 1.5rem 1.25rem;background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:12px;align-items:flex-end}.composer-toolbar{display:flex;align-items:center;gap:4px}.composer-btn{width:40px;height:40px;border-radius:10px;border:none;background:#f1f5f9;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.composer-btn:hover{background:#e2e8f0;color:#7c3aed}.composer-btn:disabled{opacity:.5;cursor:not-allowed}.priority-selector{position:relative}.priority-btn{width:40px;height:40px;border-radius:10px;border:2px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.priority-btn:hover{border-color:#cbd5e1}.priority-btn.active-safety{color:#dc2626;border-color:#dc2626;background:#fef2f2}.priority-btn.active-delay{color:#ea580c;border-color:#ea580c;background:#fff7ed}.priority-btn.active-issue{color:#ca8a04;border-color:#ca8a04;background:#fefce8}.priority-btn.active-urgent{color:#7c3aed;border-color:#7c3aed;background:#f5f3ff}.priority-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 40px #0000001f;padding:6px;z-index:100;min-width:160px;animation:menuSlideUp .2s ease}@keyframes menuSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.priority-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;font-size:.8rem;font-weight:500;color:#334155;cursor:pointer;border-radius:8px;transition:all .15s}.priority-menu button:hover{background:#f1f5f9}.priority-menu button.selected{background:#7c3aed1a;color:#7c3aed}.priority-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 2px 4px #00000026}.composer-input-wrap{flex:1;display:flex;align-items:center;gap:12px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:16px;padding:4px 4px 4px 16px;transition:all .2s}.composer-input-wrap:focus-within{border-color:#a78bfa;background:#fff;box-shadow:0 0 0 4px #a78bfa1a}.composer-mention-input{flex:1}.composer-mention-input .mention-input{background:transparent;border:none;padding:10px 0;font-size:.9375rem}.composer-mention-input .mention-input:focus{box-shadow:none}.composer-send{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.composer-send:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:scale(1.05);box-shadow:0 4px 15px #7c3aed66}.composer-send:disabled{opacity:.5;cursor:not-allowed}.comm-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:linear-gradient(180deg,#f8fafc,#f1f5f9);text-align:center;padding:2rem}.comm-placeholder svg{color:#cbd5e1;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.comm-placeholder h2{margin:0;font-size:1.5rem;font-weight:700;color:#334155}.comm-placeholder p{margin:0;font-size:.9375rem;color:#64748b;max-width:300px}.ws-status{margin-top:.5rem;font-size:.8rem;color:#10b981;display:flex;align-items:center;gap:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@media(max-width:1024px){.comm-sidebar{width:260px}}@media(max-width:768px){.communication-page{position:relative;height:100vh;height:100dvh;overflow:hidden}.comm-sidebar{position:absolute;inset:0;width:100%;height:100%;z-index:10;border-right:none;display:flex;flex-direction:column;transition:transform .3s ease,opacity .3s ease}.communication-page.chat-open .comm-sidebar{transform:translate(-100%);opacity:0;pointer-events:none}.comm-main{position:absolute;inset:0;width:100%;height:100%;z-index:5;transform:translate(100%);transition:transform .3s ease}.communication-page.chat-open .comm-main{transform:translate(0);z-index:20}.comm-back-btn{display:flex}.comm-sidebar-header{padding:1rem;border-bottom:1px solid rgba(255,255,255,.08)}.comm-sidebar-header h2{font-size:1.25rem}.comm-search{margin:.75rem;padding:.75rem 1rem;border-radius:12px}.comm-search input{font-size:16px}.comm-channels{flex:1;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.5rem;gap:.25rem}.channel-section{display:flex;flex-direction:column;margin-bottom:.5rem}.channel-section-title{display:block;padding:.5rem .75rem;font-size:.7rem;color:#ffffff80}.channel-item{display:flex;align-items:center;width:100%;padding:.875rem 1rem;border-radius:12px;gap:.75rem;background:transparent;font-size:.9rem;transition:background .15s}.channel-item:active{background:#ffffff1a}.channel-item.active{background:#a78bfa26}.channel-item.active:before{display:none}.channel-item svg{width:20px;height:20px;flex-shrink:0}.channel-info{display:flex;flex-direction:column;flex:1;min-width:0}.channel-name{font-size:.95rem;font-weight:500;color:#e2e8f0}.channel-sub{display:block;font-size:.75rem;color:#ffffff80;margin-top:2px}.channel-unread{min-width:20px;height:20px;font-size:.7rem}.comm-header{padding:.75rem 1rem;gap:.5rem}.comm-header h3{font-size:1rem;font-weight:600}.comm-header-info{flex:1}.comm-header-info svg{padding:6px;width:32px;height:32px}.comm-messages{padding:.75rem}.message-item{padding:.5rem .25rem;gap:.625rem}.message-avatar{width:36px;height:36px;border-radius:10px;font-size:.8rem}.message-sender{font-size:.85rem}.message-text{font-size:.9rem}.message-time{font-size:.65rem}.message-date-divider span{font-size:.65rem;padding:.25rem .75rem}.comm-composer{padding:.75rem;gap:8px}.composer-btn,.priority-btn{width:40px;height:40px;border-radius:10px}.composer-mention-input{font-size:16px!important}.composer-send{width:44px;height:44px;border-radius:12px}.priority-menu{left:auto;right:0;min-width:140px}.comm-placeholder{display:none}}@media(max-width:480px){.communication-page{margin:-1rem}.comm-sidebar-header{padding:.875rem}.comm-sidebar-header h2{font-size:1.125rem}.comm-search{margin:.5rem .75rem;padding:.625rem .875rem}.comm-channels{padding:.25rem .5rem}.channel-item{padding:.75rem;border-radius:10px}.channel-name{font-size:.9rem}.channel-sub{font-size:.7rem}.comm-header{padding:.625rem .75rem}.comm-back-btn{width:36px;height:36px}.comm-header h3{font-size:.95rem}.comm-header-sub{font-size:.65rem}.comm-header-info svg{padding:5px;width:28px;height:28px}.comm-messages{padding:.5rem}.message-item{gap:.5rem}.message-avatar{width:32px;height:32px;border-radius:8px}.message-header{gap:.375rem}.message-sender{font-size:.8rem}.message-text{font-size:.85rem;line-height:1.5}.message-attachments .attachment-item{padding:6px 10px;font-size:.7rem}.comm-composer{padding:.5rem;gap:6px}.composer-toolbar{gap:2px}.composer-btn,.priority-btn{width:36px;height:36px}.composer-send{width:42px;height:42px}.priority-menu{position:fixed;bottom:60px;left:8px;right:8px;width:auto;border-radius:16px}.attachments-preview{padding:.5rem}.attachment-preview-item{padding:6px 10px;font-size:.75rem}.attachment-preview-item span{max-width:100px}}@media(hover:none)and (pointer:coarse){.channel-item{min-height:52px}.composer-btn,.priority-btn{min-width:44px;min-height:44px}.composer-send{min-width:48px;min-height:48px}.comm-back-btn{min-width:44px;min-height:44px}.message-item{padding:.75rem .5rem}.channel-item:hover{background:transparent}.channel-item.active:hover{background:#a78bfa26}.message-item:hover{background:transparent}}@supports (padding: env(safe-area-inset-top)){@media(max-width:768px){.comm-sidebar-header{padding-top:calc(.875rem + env(safe-area-inset-top))}.comm-header{padding-top:calc(.625rem + env(safe-area-inset-top))}.comm-composer{padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}}}.comm-sidebar::-webkit-scrollbar{width:6px}.comm-sidebar::-webkit-scrollbar-track{background:transparent}.comm-sidebar::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.comm-composer .mention-input-container{flex:1}.comm-composer .mention-suggestions{bottom:100%;margin-bottom:8px;border-radius:12px;box-shadow:0 10px 40px #00000026}@media(max-width:480px){.comm-composer .mention-suggestions{position:fixed;left:8px;right:8px;bottom:60px;width:auto}}.material-budget-page{width:100%}.btn-back:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.project-link{color:#16a34a;text-decoration:none;font-weight:500}.project-link:hover{text-decoration:underline}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}}.stat-card{display:flex;gap:1rem;padding:1.25rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.stat-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-content{display:flex;flex-direction:column;justify-content:center}.stat-card-value{font-size:1.5rem;font-weight:800;color:#0f172a;line-height:1.2}.stat-card-label{font-size:.8rem;color:#64748b;font-weight:500}.budget-alerts{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.alert{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-radius:10px;font-size:.875rem;font-weight:500}.budget-table tbody tr.row-warning{background:#fffbeb}.budget-table tbody tr.row-exceeded{background:#fef2f2}.budget-table tbody tr.row-warning:hover{background:#fef9c3}.budget-table tbody tr.row-exceeded:hover{background:#fee2e2}.utilization-bar{position:relative;width:80px;height:24px;background:#f1f5f9;border-radius:4px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center}.utilization-fill{position:absolute;left:0;top:0;height:100%;border-radius:4px;transition:width .3s}.utilization-ok .utilization-fill{background:linear-gradient(90deg,#86efac,#22c55e)}.utilization-warning .utilization-fill{background:linear-gradient(90deg,#fcd34d,#f59e0b)}.utilization-exceeded .utilization-fill{background:linear-gradient(90deg,#fca5a5,#ef4444)}.utilization-text{position:relative;z-index:1;font-size:.75rem;font-weight:700;color:#0f172a}.status-badge.status-success{background:#dcfce7;color:#16a34a}.status-badge.status-warning{background:#fef3c7;color:#d97706}.status-badge.status-danger{background:#fee2e2;color:#dc2626}.text-danger{color:#dc2626!important;font-weight:600}.card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.table-container{overflow-x:auto}.excel-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.excel-table thead th.sortable:hover{color:#0f172a;background:#f1f5f9}.excel-table thead th.sortable svg{opacity:.4;margin-left:4px;vertical-align:middle}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#64748b}.loading-state .spin{animation:spin 1s linear infinite}.loading-state p,.error-state p{margin:.75rem 0}.error-state{color:#dc2626}.view-toggle{display:flex;background:#f1f5f9;border-radius:8px;padding:4px}.toggle-btn{display:flex;align-items:center;gap:6px;padding:.5rem 1rem;border:none;background:transparent;font-size:.8rem;font-weight:500;color:#64748b;cursor:pointer;border-radius:6px;transition:all .2s}.toggle-btn:hover{color:#334155}.toggle-btn.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001a}@media(max-width:1024px){.budget-summary-cards{grid-template-columns:repeat(2,1fr)}}.budget-summary-card{display:flex;gap:1rem;padding:1.5rem;border-radius:12px;background:#fff;border:1px solid #e2e8f0}.budget-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.budget-card-total .budget-card-icon{background:#e0e7ff;color:#4f46e5}.budget-card-consumed .budget-card-icon{background:#dbeafe;color:#2563eb}.budget-card-balance .budget-card-icon{background:#dcfce7;color:#16a34a}.budget-card-status .budget-card-icon{background:#fef3c7;color:#d97706}.budget-card-content{display:flex;flex-direction:column;justify-content:center}.budget-card-label{font-size:.75rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.budget-card-value{font-size:1.5rem;font-weight:800;color:#0f172a;line-height:1.3}.budget-card-sub{font-size:.8rem;color:#94a3b8}.budget-card-alerts{display:flex;flex-direction:column;gap:4px;margin-top:4px}.alert-count{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-block}.alert-count.alert-danger{background:#fee2e2;color:#dc2626}.alert-count.alert-warning{background:#fef3c7;color:#d97706}.alert-count.alert-success{background:#dcfce7;color:#16a34a}.overall-utilization-bar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem}.utilization-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.875rem;font-weight:600;color:#334155}.utilization-percent{font-size:1.25rem;font-weight:800;color:#0f172a}.utilization-track{position:relative;height:24px;background:#f1f5f9;border-radius:12px;overflow:visible}.utilization-progress{position:absolute;left:0;top:0;height:100%;border-radius:12px;transition:width .5s ease}.utilization-progress.utilization-ok{background:linear-gradient(90deg,#86efac,#22c55e)}.utilization-progress.utilization-warning{background:linear-gradient(90deg,#fcd34d,#f59e0b)}.utilization-progress.utilization-exceeded{background:linear-gradient(90deg,#fca5a5,#ef4444)}.utilization-markers{position:absolute;inset:0;pointer-events:none}.utilization-markers .marker{position:absolute;top:-18px;font-size:.65rem;font-weight:600;color:#94a3b8;transform:translate(-50%)}.utilization-markers .marker.danger{color:#dc2626}.totals-row{background:#f8fafc;border-top:2px solid #e2e8f0}.totals-row td{padding:1rem!important;font-size:.9rem}.font-bold{font-weight:700}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;padding:1rem 0}.project-budget-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s}.project-budget-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a;border-color:#cbd5e1}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.project-info h3{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0 0 .25rem}.budget-row{display:flex;justify-content:space-between;margin-bottom:.75rem;font-size:.875rem}.budget-row .label{color:#64748b}.budget-row .value{font-weight:600;color:#1e293b;font-family:SF Mono,Monaco,monospace}.balance-row{margin-top:1rem;padding-top:1rem;border-top:1px dashed #e2e8f0}.balance-row .value{font-size:1rem;font-weight:700}.progress-bar-container{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;margin:1.25rem 0}.progress-bar{height:100%;border-radius:4px;transition:width .3s ease}.progress-bar.utilization-ok{background:#22c55e}.progress-bar.utilization-warning{background:#f59e0b}.progress-bar.utilization-exceeded{background:#ef4444}.alerts-row{display:flex;gap:.5rem}.alert-tag{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;padding:2px 8px;border-radius:4px;font-weight:600}.pr-list-page,.pr-create-page,.pr-detail-page{width:100%}.stats-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1024px){.stats-grid-5{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.stats-grid-5{grid-template-columns:repeat(2,1fr)}}.stat-card-sm{padding:1rem 1.25rem;background:#fff;border-radius:10px;border:1px solid #e2e8f0;text-align:center}.stat-card-sm .stat-value{font-size:1.75rem;font-weight:800;color:#0f172a}.stat-card-sm .stat-label{font-size:.75rem;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.text-warning{color:#d97706!important}.text-info{color:#2563eb!important}.text-success{color:#16a34a!important}.text-danger{color:#dc2626!important}.text-muted{color:#94a3b8!important}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:.25rem .625rem;font-size:.7rem;font-weight:600;border-radius:100px;white-space:nowrap}.status-draft{background:#f1f5f9;color:#64748b}.status-submitted{background:#dbeafe;color:#2563eb}.status-warning{background:#fef3c7;color:#d97706}.status-success{background:#dcfce7;color:#16a34a}.status-danger{background:#fee2e2;color:#dc2626}.status-info{background:#ede9fe;color:#8b5cf6}.status-cancelled{background:#f1f5f9;color:#94a3b8}.status-badge-large{display:inline-flex;align-items:center;gap:6px;padding:.375rem .875rem;font-size:.8rem;font-weight:600;border-radius:100px}.over-budget-tag{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:#fef3c7;color:#d97706;border-radius:50%;margin-left:.5rem;vertical-align:middle}.over-budget-badge{display:inline-flex;align-items:center;gap:6px;margin-left:1rem;padding:.375rem .875rem;background:#fef3c7;color:#d97706;font-size:.75rem;font-weight:600;border-radius:100px}.row-over-budget{background:#fffbeb!important}.row-over-budget:hover{background:#fef9c3!important}.table-row-clickable{cursor:pointer}.row-chevron{color:#94a3b8;opacity:0;transition:opacity .2s}.table-row-clickable:hover .row-chevron{opacity:1}.form-group-full{grid-column:1 / -1}.form-group label{display:block;font-size:.8rem;font-weight:600;color:#374151;margin-bottom:.375rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.form-group textarea{resize:vertical;min-height:60px}.table-input{width:100%;padding:.5rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;background:#fff}.table-input:focus{outline:none;border-color:#4f46e5}.input-warning{border-color:#f59e0b!important;background:#fffbeb!important}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;cursor:pointer;transition:all .2s;background:transparent}.btn-icon:hover{background:#f1f5f9}.btn-icon-danger{color:#94a3b8}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626}.info-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:1024px){.info-cards-grid{grid-template-columns:repeat(2,1fr)}}.info-card{display:flex;gap:.875rem;padding:1rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:10px}.info-card-icon{width:40px;height:40px;background:#f1f5f9;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#64748b;flex-shrink:0}.info-card-content{flex:1;min-width:0}.info-card-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600}.info-card-value{font-size:.95rem;font-weight:700;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.info-card-sub{font-size:.75rem;color:#94a3b8}.info-row{margin-bottom:.5rem}.info-row:last-child{margin-bottom:0}.approval-info{display:flex;align-items:center;gap:.5rem;color:#16a34a;font-weight:500}.alert{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:10px;font-size:.875rem;margin-bottom:1.5rem}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.alert svg{flex-shrink:0;margin-top:2px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;width:100%;max-width:480px;box-shadow:0 20px 25px -5px #0000001a}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:1.125rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:.75rem}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:none}.btn-success:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.btn-danger-outline{background:#fff;color:#dc2626;border:1px solid #fca5a5}.btn-danger-outline:hover{background:#fee2e2}.card{background:#fff;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:1.5rem}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.card-title{font-weight:600;font-size:.95rem;color:#0f172a;display:flex;align-items:center;gap:.5rem}.card-body{padding:1.25rem}.loading-page,.error-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#64748b;gap:1rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.excel-table{width:100%;border-collapse:collapse;font-size:.875rem}.excel-table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;background:#f8fafc;border-bottom:2px solid #e2e8f0;white-space:nowrap}.excel-table tbody td{padding:.75rem 1rem;border-bottom:1px solid #f1f5f9;color:#334155}.excel-table .table-row-hover:hover{background:#f8fafc}.excel-table .font-medium{font-weight:600;color:#0f172a}.excel-table .font-bold{font-weight:700}.excel-table .font-mono{font-family:SF Mono,Monaco,monospace}.excel-table .text-right{text-align:right}.excel-table .text-center{text-align:center}.excel-table .empty-row{text-align:center;color:#94a3b8;padding:3rem 1rem!important}.code-badge{display:inline-block;padding:.25rem .5rem;background:#f1f5f9;color:#64748b;font-size:.75rem;font-family:SF Mono,Monaco,monospace;border-radius:4px}.filters-bar{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex:1;max-width:280px;min-width:200px}.search-box svg{color:#94a3b8}.search-box input{flex:1;border:none;outline:none;font-size:.875rem;background:transparent}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-select{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;color:#334155;cursor:pointer}.filter-results{font-size:.8rem;color:#64748b;margin-left:auto}.btn-back{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-right:.75rem}.btn-back:hover{background:#f8fafc;color:#0f172a}.mt-1{margin-top:.25rem}.summary-row{background:#f8fafc;font-weight:600}.summary-row td{padding-top:1rem!important;padding-bottom:1rem!important;border-top:2px solid #e2e8f0}.grand-total{display:flex;align-items:center;justify-content:space-between;font-size:1.25rem;font-weight:700}.grand-total-value{font-size:2rem;color:#16a34a}.part-number-sm{display:inline-block;padding:.15rem .4rem;background:linear-gradient(135deg,#dbeafe,#e0e7ff);color:#3b82f6;font-size:.65rem;font-weight:600;font-family:SF Mono,Monaco,monospace;border-radius:3px;border:1px solid #93c5fd}.budget-quick-select{padding:1rem 1.25rem;background:linear-gradient(135deg,#f0fdf4,#ecfeff);border-bottom:1px solid #d1fae5}.budget-chips{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.budget-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#fff;border:1px solid #a7f3d0;border-radius:6px;font-size:.75rem;color:#065f46;cursor:pointer;transition:all .15s}.budget-chip:hover:not(:disabled){background:#d1fae5;border-color:#34d399;transform:translateY(-1px)}.budget-chip:disabled{opacity:.5;cursor:not-allowed;background:#f1f5f9;border-color:#e2e8f0;color:#94a3b8}.chip-balance{font-weight:600;color:#047857}.material-name-sm{font-size:.8rem;color:#1e293b;font-weight:500}.toggle-label{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}.project-cost-budget-page{padding:1.5rem}.budget-summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:12px;background:#fff;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000000d}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.summary-content{display:flex;flex-direction:column}.summary-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.summary-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.summary-sub{font-size:.875rem;color:var(--text-secondary)}.card-contract .summary-icon{background:#e0f2fe;color:#0284c7}.card-budget .summary-icon{background:#fef3c7;color:#d97706}.card-actual .summary-icon{background:#fee2e2;color:#dc2626}.card-variance-positive .summary-icon{background:#dcfce7;color:#16a34a}.card-variance-positive .summary-value{color:#16a34a}.card-variance-negative .summary-icon{background:#fee2e2;color:#dc2626}.card-variance-negative .summary-value{color:#dc2626}.budget-breakdown-table{width:100%}.budget-breakdown-table th{background:#3b82f6;color:#fff;font-weight:600;padding:.875rem 1rem;text-align:left;font-size:.875rem}.budget-breakdown-table th.text-right{text-align:right}.budget-breakdown-table th.text-center{text-align:center}.category-row{background:#f8fafc!important}.category-row td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color)}.category-cell{display:flex;align-items:center;gap:.5rem}.category-cell svg{color:#64748b}.item-row td{padding:.625rem 1rem;border-bottom:1px solid #f1f5f9;color:var(--text-secondary)}.item-name{color:var(--text-primary)}.item-unit{font-size:.75rem;color:var(--text-muted);margin-left:.25rem}.variance-positive{color:#16a34a!important}.variance-negative{color:#dc2626!important}.totals-row{background:#1e293b!important}.totals-row td{color:#fff!important;padding:.875rem 1rem;font-weight:600}.empty-state-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#fff;border-radius:12px;border:2px dashed var(--border-color);text-align:center}.empty-state-card svg{color:#94a3b8;margin-bottom:1rem}.empty-state-card h3{margin:0 0 .5rem;color:var(--text-primary)}.empty-state-card p{color:var(--text-secondary);margin:0 0 1.5rem;max-width:320px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.card-header h2{margin:0;font-size:1rem;font-weight:600}.status-active{background:#dcfce7!important;color:#16a34a!important}.status-closed{background:#e2e8f0!important;color:#64748b!important}.status-draft{background:#f1f5f9!important;color:#64748b!important}@media(max-width:1200px){.budget-summary-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.budget-summary-cards{grid-template-columns:1fr}.project-cost-budget-page{padding:1rem}}.budget-report{padding:var(--spacing-6);width:100%;margin:0 auto}.budget-report-loading,.budget-report-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-4);color:var(--slate-600)}.budget-report-error h2{margin:0;color:var(--error-600)}.budget-report-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-8);gap:var(--spacing-4);flex-wrap:wrap}.header-left{display:flex;align-items:flex-start;gap:var(--spacing-4)}.back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);background:var(--white);border:1px solid var(--slate-200);cursor:pointer;transition:all .2s}.back-btn:hover{background:var(--slate-50);border-color:var(--slate-300)}.budget-report-header h1{margin:0;font-size:1.75rem;font-weight:700;color:var(--slate-900)}.budget-report-header .subtitle{margin:var(--spacing-1) 0 0;color:var(--slate-500);font-size:.95rem}.header-right{display:flex;align-items:center;gap:var(--spacing-4)}.report-date{display:flex;align-items:center;gap:var(--spacing-2);color:var(--slate-500);font-size:.875rem}.kpi-section{margin-bottom:var(--spacing-8)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-4)}.kpi-card{display:flex;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-5);background:var(--white);border-radius:var(--radius-xl);border:1px solid var(--slate-200);transition:all .2s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);flex-shrink:0}.kpi-icon.budget{background:linear-gradient(135deg,var(--indigo-500),var(--indigo-600));color:#fff}.kpi-icon.ordered{background:linear-gradient(135deg,var(--amber-500),var(--amber-600));color:#fff}.kpi-icon.received{background:linear-gradient(135deg,var(--blue-500),var(--blue-600));color:#fff}.kpi-icon.consumed{background:linear-gradient(135deg,var(--purple-500),var(--purple-600));color:#fff}.kpi-card.variance .kpi-icon{background:linear-gradient(135deg,var(--success-500),var(--success-600));color:#fff}.kpi-card.variance.negative .kpi-icon{background:linear-gradient(135deg,var(--error-500),var(--error-600))}.kpi-card.progress .kpi-icon{background:linear-gradient(135deg,var(--teal-500),var(--teal-600));color:#fff}.kpi-content{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:0}.kpi-label{font-size:.8rem;font-weight:500;color:var(--slate-500);text-transform:uppercase;letter-spacing:.5px}.kpi-value{font-size:1.35rem;font-weight:700;color:var(--slate-900)}.kpi-badge{font-size:.75rem;color:var(--slate-600);background:var(--slate-100);padding:2px 8px;border-radius:var(--radius-full);width:fit-content}.kpi-card.variance.positive .kpi-badge{background:var(--success-100);color:var(--success-700)}.kpi-card.variance.negative .kpi-badge{background:var(--error-100);color:var(--error-700)}.progress-bar-container{width:100%;height:8px;background:var(--slate-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--teal-400),var(--teal-600));border-radius:var(--radius-full);transition:width .5s ease}.alerts-section{margin-bottom:var(--spacing-8)}.alert-card{display:flex;gap:var(--spacing-4);padding:var(--spacing-4);border-radius:var(--radius-lg);background:var(--warning-50);border:1px solid var(--warning-200);color:var(--warning-800)}.alert-card.warning svg{color:var(--warning-600);flex-shrink:0}.alert-content{flex:1}.alert-content ul{margin:var(--spacing-2) 0 0;padding-left:var(--spacing-5);font-size:.875rem}.alert-content li{margin-bottom:var(--spacing-1)}.status-section,.category-section,.line-items-section{margin-bottom:var(--spacing-8);background:var(--white);border-radius:var(--radius-xl);border:1px solid var(--slate-200);padding:var(--spacing-6)}.status-section h2,.category-section h2,.line-items-section h2{display:flex;align-items:center;gap:var(--spacing-2);margin:0 0 var(--spacing-5);font-size:1.1rem;font-weight:600;color:var(--slate-800)}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-4)}.status-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-4);background:var(--slate-50);border-radius:var(--radius-lg);border-left:4px solid}.status-count{font-size:2rem;font-weight:700;color:var(--slate-900)}.status-label{font-size:.75rem;font-weight:500;color:var(--slate-600);text-transform:uppercase;letter-spacing:.5px}.category-table,.line-items-table{overflow-x:auto}.category-table table,.line-items-table table{width:100%;border-collapse:collapse;font-size:.875rem}.category-table th,.line-items-table th{text-align:left;padding:var(--spacing-3) var(--spacing-4);background:var(--slate-50);color:var(--slate-600);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--slate-200)}.category-table td,.line-items-table td{padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--slate-100);color:var(--slate-700)}.category-table .right,.line-items-table .right{text-align:right;font-variant-numeric:tabular-nums}.category-name{font-weight:600;color:var(--slate-800)}.category-table tfoot td,.line-items-table tfoot td{background:var(--slate-50);border-top:2px solid var(--slate-200)}.positive{color:var(--success-600)!important}.negative{color:var(--error-600)!important}.neutral{color:var(--slate-500)}.item-code{font-family:var(--font-mono);font-size:.8rem;color:var(--indigo-600);font-weight:500}.item-desc{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-exceeded{background:var(--error-50)}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.budget-report{padding:var(--spacing-4)}.budget-report-header{flex-direction:column}.header-right{width:100%;justify-content:space-between}.kpi-grid{grid-template-columns:repeat(2,1fr)}.kpi-card{flex-direction:column;text-align:center}.kpi-icon{margin:0 auto}.kpi-content{align-items:center}}.btn-secondary{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background:var(--white);border:1px solid var(--slate-300);border-radius:var(--radius-lg);color:var(--slate-700);font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--slate-50);border-color:var(--slate-400)}.loading-spinner{width:40px;height:40px;border:3px solid var(--slate-200);border-top-color:var(--indigo-600);border-radius:50%;animation:spin .8s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.reports-page{padding:0;width:100%;margin:0 auto;background:linear-gradient(180deg,#0f172a,#1e293b 300px,#f1f5f9 300px);min-height:100vh}.reports-page .page-header{display:flex;align-items:center;justify-content:space-between;padding:2rem 2rem 3rem;background:linear-gradient(135deg,#0f172a,#1e293b);position:relative;overflow:hidden}.reports-page .page-header:before{content:"";position:absolute;top:-50%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(99,102,241,.3) 0%,transparent 70%);border-radius:50%;pointer-events:none}.reports-page .page-header:after{content:"";position:absolute;bottom:-40%;left:10%;width:300px;height:300px;background:radial-gradient(circle,rgba(16,185,129,.2) 0%,transparent 70%);border-radius:50%;pointer-events:none}.reports-page .page-title{color:#fff;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.reports-page .page-subtitle{color:#fff9;font-size:.875rem;margin-top:.25rem}.header-actions{display:flex;gap:.75rem;position:relative;z-index:10}.header-actions .btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-actions .btn:hover{background:#fff3;border-color:#ffffff4d}.export-btn{display:flex;align-items:center;gap:.5rem}.reports-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem;color:var(--slate-400);background:#f1f5f9}#reports-content{padding:0 2rem 2rem;margin-top:-2rem;position:relative;z-index:5}.filters-container{margin-bottom:2rem;position:relative;z-index:5}.report-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.375rem;border-radius:12px;width:fit-content;border:1px solid rgba(255,255,255,.1)}.report-tab{padding:.625rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;color:#ffffffb3;background:transparent;border:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.report-tab:hover{color:#fff;background:#ffffff1a}.report-tab.active{background:#fff;color:var(--primary-600);box-shadow:0 4px 12px #0000001a}.filters-bar{display:flex;align-items:flex-end;gap:1.5rem;padding:1rem 1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;flex-wrap:wrap;border:1px solid var(--slate-100)}.filter-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.animated-tab{animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:2rem}.kpi-card{background:#fff;border-radius:20px;padding:1.5rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;box-shadow:0 4px 24px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.8);position:relative}.kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001f}.kpi-card.highlight{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none}.kpi-card.highlight .kpi-value,.kpi-card.highlight .kpi-label{color:#fff}.kpi-card.highlight .kpi-icon,.kpi-card.highlight .kpi-trend{background:#fff3;color:#fff}.kpi-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-icon.blue{background:#3b82f61a;color:#3b82f6}.kpi-icon.green{background:#10b9811a;color:#10b981}.kpi-icon.orange{background:#f59e0b1a;color:#f59e0b}.kpi-icon.red{background:#ef44441a;color:#ef4444}.kpi-icon.purple{background:#8b5cf61a;color:#8b5cf6}.kpi-icon.cyan{background:#06b6d41a;color:#06b6d4}.kpi-icon.indigo{background:#6366f11a;color:#6366f1}.kpi-icon.pink{background:#ec48991a;color:#ec4899}.kpi-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.kpi-value{font-size:1.5rem;font-weight:700;color:var(--slate-800);line-height:1.2}.kpi-label{font-size:.75rem;color:var(--slate-500)}.kpi-trend{position:absolute;top:.75rem;right:.75rem;display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;padding:.25rem .5rem;border-radius:12px}.kpi-trend.up{background:#10b9811a;color:#10b981}.kpi-trend.down{background:#ef44441a;color:#ef4444}.kpi-progress{width:100%;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-top:.5rem}.kpi-progress-bar{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:3px;transition:width 1s ease-out}.charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:1.5rem}.chart-card{background:#fff;border-radius:20px;box-shadow:0 4px 24px #0000000f;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(226,232,240,.8)}.chart-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0000001f}.chart-card.wide{grid-column:span 2}.chart-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:linear-gradient(180deg,#f8fafccc,#f8fafc00);border-bottom:1px solid var(--slate-100)}.chart-title{display:flex;align-items:center;gap:.625rem;font-size:.95rem;font-weight:600;color:var(--slate-700);margin:0}.chart-title svg{color:var(--primary-500)}.chart-subtitle{font-size:.75rem;color:var(--slate-400);background:var(--slate-100);padding:.25rem .75rem;border-radius:100px}.chart-badge{font-size:.7rem;font-weight:600;padding:.375rem .875rem;border-radius:100px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.chart-badge.red{background:#ef444426;color:#dc2626}.chart-content{padding:1.5rem}.recharts-tooltip-wrapper .recharts-default-tooltip{background:#1e293bf2!important;border:none!important;border-radius:8px!important;box-shadow:0 4px 12px #00000026!important}.recharts-tooltip-item{color:#fff!important}.recharts-tooltip-label{color:#ffffffb3!important;font-weight:600!important}.recharts-legend-wrapper{padding-top:1rem!important}.recharts-legend-item-text{color:var(--slate-600)!important;font-size:.75rem!important}.report-table{width:100%;border-collapse:collapse}.report-table th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--slate-200)}.report-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100)}.report-table tr:last-child td{border-bottom:none}.report-table tr:hover td{background:var(--slate-50)}.trend-up{display:inline-flex;align-items:center;gap:.25rem;color:#10b981;font-size:.75rem;font-weight:600}.trend-down{display:inline-flex;align-items:center;gap:.25rem;color:#ef4444;font-size:.75rem;font-weight:600}@media(max-width:1400px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.charts-grid{grid-template-columns:repeat(2,1fr)}.chart-card.wide{grid-column:span 2}}@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:span 1}}@media(max-width:640px){.reports-page{padding:1rem}.kpi-grid{grid-template-columns:1fr}.kpi-card{padding:1rem}.kpi-value{font-size:1.5rem}}.mini-stat{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--slate-50);border-radius:8px}.mini-stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.mini-stat-content{flex:1}.mini-stat-value{font-size:1.25rem;font-weight:700;color:var(--slate-800)}.mini-stat-label{font-size:.75rem;color:var(--slate-500)}.progress-cell{display:flex;align-items:center;gap:.5rem}.progress-bar-mini{flex:1;height:6px;background:var(--slate-200);border-radius:100px;overflow:hidden}.progress-bar-mini-fill{height:100%;border-radius:100px;transition:width .3s}.progress-bar-mini-fill.green{background:#10b981}.progress-bar-mini-fill.yellow{background:#f59e0b}.progress-bar-mini-fill.red{background:#ef4444}.progress-value{font-size:.75rem;font-weight:600;color:var(--slate-600);min-width:40px;text-align:right}.variance-positive{color:#10b981;font-weight:600}.variance-negative{color:#ef4444;font-weight:600}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem;color:var(--slate-400)}.chart-empty span{font-size:.875rem}.date-presets{display:flex;background:#f1f5f9;border-radius:50px;padding:4px;border:1px solid #e2e8f0}.preset-btn{padding:6px 14px;border-radius:100px;font-size:.75rem;font-weight:600;color:#64748b;background:transparent;border:none;cursor:pointer;transition:all .2s;white-space:nowrap}.preset-btn:hover{color:#0f172a;background:#ffffff80}.preset-btn.active{background:#fff;color:#3b82f6;box-shadow:0 1px 4px #0000001a}.section-header{margin:2rem 0 1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(226,232,240,.8);display:flex;justify-content:space-between;align-items:center}.section-title{font-size:1.25rem;font-weight:700;color:var(--slate-800);display:flex;align-items:center;gap:.75rem}.section-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.section-grid.three-cols{grid-template-columns:repeat(3,1fr)}@media(max-width:1200px){.section-grid,.section-grid.three-cols{grid-template-columns:1fr}}.gst-reports-page{padding:1.5rem;width:100%;margin:0 auto}.gst-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.375rem}.filter-group label{font-size:.75rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.025em}.filter-input,.filter-select{padding:.625rem 1rem;border:1px solid var(--slate-200);border-radius:8px;font-size:.875rem;color:var(--slate-700);background:#fff;min-width:140px}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.gst-tabs{display:flex;gap:.25rem;background:var(--slate-100);padding:.25rem;border-radius:10px;margin-bottom:1.5rem;overflow-x:auto}.gst-tab{flex:1;min-width:fit-content;padding:.75rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;color:var(--slate-600);background:transparent;cursor:pointer;transition:all .2s ease;white-space:nowrap}.gst-tab:hover{color:var(--slate-800)}.gst-tab.active{background:#fff;color:var(--primary-600);box-shadow:0 1px 3px #00000014}.gst-content{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #00000014}.gst-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.gst-card{background:linear-gradient(135deg,var(--slate-50) 0%,white 100%);border-radius:12px;padding:1.5rem;border:1px solid var(--slate-100)}.gst-card.output{border-left:4px solid #f59e0b}.gst-card.input{border-left:4px solid #10b981}.gst-card.liability{border-left:4px solid #6366f1}.gst-card-header{display:flex;align-items:center;gap:.5rem;color:var(--slate-500);font-size:.875rem;font-weight:500;margin-bottom:.75rem}.gst-card.output .gst-card-header svg{color:#f59e0b}.gst-card.input .gst-card-header svg{color:#10b981}.gst-card.liability .gst-card-header svg{color:#6366f1}.gst-card-value{font-size:1.75rem;font-weight:700;color:var(--slate-800);margin-bottom:.75rem}.gst-card-breakdown{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.gst-card-breakdown span{font-size:.75rem;color:var(--slate-500)}.gst-card-meta{font-size:.75rem;color:var(--slate-400);padding-top:.5rem;border-top:1px dashed var(--slate-200)}.gst-section{margin-top:2rem}.gst-section h3{font-size:1rem;font-weight:600;color:var(--slate-700);margin-bottom:1rem}.gst-chart-container{background:var(--slate-50);border-radius:12px;padding:1.5rem;margin-top:1rem}.gst-table{width:100%;border-collapse:collapse;font-size:.875rem}.gst-table thead{background:var(--slate-50)}.gst-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--slate-600);border-bottom:1px solid var(--slate-200)}.gst-table td{padding:.75rem 1rem;color:var(--slate-700);border-bottom:1px solid var(--slate-100)}.gst-table td.gstin{font-family:monospace;font-size:.8rem}.gst-table td.credit{color:#10b981;font-weight:600}.gst-table td.debit{color:#f59e0b;font-weight:600}.gst-table tr.ineligible{opacity:.6}.gst-table tr.unregistered{background:#ef444405}.eligible-icon{color:#10b981}.ineligible-icon{color:#ef4444}.detail-summary{display:flex;gap:2rem;padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--slate-100)}.detail-stat{display:flex;flex-direction:column;gap:.25rem}.detail-stat .stat-label{font-size:.75rem;color:var(--slate-500);text-transform:uppercase}.detail-stat .stat-value{font-size:1.25rem;font-weight:700;color:var(--slate-800)}.detail-stat.eligible .stat-value,.detail-stat.registered .stat-value{color:#10b981}.detail-stat.unregistered .stat-value{color:#f59e0b}.status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:100px;font-size:.65rem;font-weight:600;text-transform:uppercase}.status-badge.registered{background:#10b9811a;color:#10b981}.status-badge.unregistered{background:#f59e0b1a;color:#f59e0b}.gst-trend-chart{display:flex;gap:.5rem;padding:1rem;background:var(--slate-50);border-radius:8px;overflow-x:auto}.trend-bar{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:50px}.trend-label{font-size:.7rem;color:var(--slate-500);font-weight:500}.trend-values{display:flex;gap:4px;align-items:flex-end;height:80px}.trend-output{width:16px;background:linear-gradient(180deg,#f59e0b,#fb923c);border-radius:4px 4px 0 0;min-height:4px}.trend-input{width:16px;background:linear-gradient(180deg,#10b981,#34d399);border-radius:4px 4px 0 0;min-height:4px}.trend-legend{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.legend-output,.legend-input{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--slate-600)}.legend-output:before{content:"";width:12px;height:12px;background:#f59e0b;border-radius:2px}.legend-input:before{content:"";width:12px;height:12px;background:#10b981;border-radius:2px}.empty-state{display:flex;flex-direction:column;align-items:center;padding:4rem;text-align:center}.empty-state svg{color:var(--slate-300);margin-bottom:1rem}.empty-state h3{font-size:1.125rem;font-weight:600;color:var(--slate-700);margin:0 0 .5rem}.empty-state p{font-size:.875rem;color:var(--slate-500);margin:0}.loading-state{display:flex;justify-content:center;align-items:center;padding:4rem;color:var(--slate-500)}@media(max-width:1024px){.gst-cards{grid-template-columns:1fr}.detail-summary{flex-wrap:wrap;gap:1rem}}@media(max-width:768px){.gst-tabs{overflow-x:auto}.gst-table{font-size:.8rem}.gst-table th,.gst-table td{padding:.5rem}.gst-content{padding:1rem}}.profile-page{padding:2rem;max-width:800px;margin:0 auto}.profile-header{margin-bottom:2rem}.profile-header h1{font-size:1.75rem;font-weight:700;color:var(--slate-800);margin:0 0 .5rem}.profile-header p{color:var(--slate-500);margin:0}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.profile-card-header{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-bottom:1px solid var(--slate-100)}.profile-avatar-large{position:relative;width:80px;height:80px;background:linear-gradient(135deg,var(--primary-600),var(--primary-700));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700;flex-shrink:0}.profile-avatar-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;background:#fff;border:2px solid var(--primary-600);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary-600);cursor:pointer;transition:all .15s}.profile-avatar-edit:hover{background:var(--primary-50)}.profile-identity h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--slate-800)}.profile-role{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;background:#fff;border-radius:20px;font-size:.8rem;font-weight:600;color:var(--primary-700)}.profile-card-title{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--slate-100)}.profile-card-title svg{color:var(--slate-400)}.profile-card-title h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--slate-800)}.profile-card-body{padding:1.5rem}.profile-field{display:flex;flex-direction:column;gap:.5rem;padding:1rem 0;border-bottom:1px solid var(--slate-100)}.profile-field:last-of-type{border-bottom:none}.profile-field label{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.05em}.profile-field label svg{color:var(--slate-400)}.profile-field span{font-size:1rem;color:var(--slate-800)}.profile-field small{font-size:.75rem;color:var(--slate-400)}.profile-field input{padding:.75rem 1rem;border:1px solid var(--slate-200);border-radius:10px;font-size:1rem;transition:all .15s}.profile-field input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.profile-actions{display:flex;gap:1rem;padding-top:1.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-600-rgb),.3)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--slate-100);color:var(--slate-700)}.btn-secondary:hover{background:var(--slate-200)}.btn-outline{background:transparent;border:1px solid var(--slate-200);color:var(--slate-700)}.btn-outline:hover{background:var(--slate-50);border-color:var(--slate-300)}.password-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--slate-700)}.form-group input{padding:.75rem 1rem;border:1px solid var(--slate-200);border-radius:10px;font-size:1rem}.form-group input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.password-input{position:relative;display:flex}.password-input input{flex:1;padding-right:3rem}.password-input button{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--slate-400);cursor:pointer}.password-input button:hover{color:var(--slate-600)}.password-form-actions{display:flex;gap:1rem;padding-top:.5rem}.profile-success{display:flex;align-items:center;gap:.5rem;padding:1rem;margin-top:1rem;background:#ecfdf5;color:#059669;border-radius:10px;font-size:.875rem;font-weight:500}.profile-error{padding:1rem;margin-top:1rem;background:#fef2f2;color:#dc2626;border-radius:10px;font-size:.875rem}@media(max-width:640px){.profile-page{padding:1rem}.profile-card-header{flex-direction:column;text-align:center;padding:1.5rem}.profile-avatar-large{width:70px;height:70px;font-size:1.75rem}.profile-actions,.password-form-actions{flex-direction:column}.btn{width:100%;justify-content:center}}.finance-page{padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);min-height:100vh}.finance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.finance-header-left h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.finance-header-left p{color:#64748b;font-size:.875rem;margin:.25rem 0 0}.finance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.finance-stat-card{background:#fff;border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #00000014;border:1px solid rgba(0,0,0,.04);transition:all .2s ease}.finance-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.finance-stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.finance-stat-icon.blue{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.finance-stat-icon.green{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.finance-stat-icon.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.finance-stat-icon.orange{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.finance-stat-content{flex:1}.finance-stat-value{font-size:1.5rem;font-weight:700;color:#1e293b;line-height:1.2}.finance-stat-label{font-size:.75rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.finance-table-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000014;border:1px solid rgba(0,0,0,.04);overflow:hidden}.finance-table-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;gap:1rem}.finance-table-title{display:flex;align-items:center;gap:.75rem}.finance-table-title h2{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0}.finance-table-title .count-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.25rem .625rem;border-radius:20px;font-size:.75rem;font-weight:600}.finance-table-actions{display:flex;align-items:center;gap:.75rem}.finance-search{position:relative}.finance-search input{width:240px;padding:.5rem .75rem .5rem 2.25rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .2s}.finance-search input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.finance-search .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#94a3b8}.finance-table{width:100%;border-collapse:collapse}.finance-table th{text-align:left;padding:.875rem 1rem;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.finance-table td{padding:1rem;font-size:.875rem;color:#334155;border-bottom:1px solid #f1f5f9}.finance-table tr:hover td{background:#f8fafc}.finance-table tr:last-child td{border-bottom:none}.order-number-cell{display:flex;flex-direction:column;gap:.25rem}.order-number{font-weight:600;color:#1e293b;font-family:JetBrains Mono,Fira Code,monospace}.internal-number{font-size:.75rem;color:#94a3b8;font-family:JetBrains Mono,Fira Code,monospace}.client-cell{display:flex;flex-direction:column;gap:.125rem}.client-name{font-weight:500;color:#1e293b}.client-gstin{font-size:.75rem;color:#64748b;font-family:monospace}.amount-cell{text-align:right}.amount-value{font-weight:600;color:#1e293b;font-family:JetBrains Mono,Fira Code,monospace}.amount-gst{font-size:.75rem;color:#64748b}.finance-status{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.finance-status.draft{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#64748b}.finance-status.sent{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.finance-status.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.finance-status.on-hold{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.finance-status.completed{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5}.finance-status.cancelled{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626}.finance-status.paid{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.finance-status.partially-paid{background:linear-gradient(135deg,#ffedd5,#fed7aa);color:#ea580c}.finance-status.approved{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.finance-status.pending-approval{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.finance-actions{display:flex;align-items:center;gap:.5rem;opacity:.7;transition:opacity .2s}.finance-table tr:hover .finance-actions{opacity:1}.action-btn{width:32px;height:32px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#f1f5f9;color:#64748b}.action-btn:hover{background:#e2e8f0;color:#334155}.action-btn.view:hover{background:#dbeafe;color:#2563eb}.action-btn.edit:hover{background:#fef3c7;color:#d97706}.action-btn.delete:hover{background:#fee2e2;color:#dc2626}.finance-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.finance-modal{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.finance-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}.finance-modal-header h2{font-size:1.25rem;font-weight:600;color:#1e293b;margin:0;display:flex;align-items:center;gap:.5rem}.finance-modal-close{width:36px;height:36px;border-radius:8px;border:none;background:#f1f5f9;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.finance-modal-close:hover{background:#e2e8f0;color:#334155}.finance-modal-body{padding:1.5rem}.finance-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8fafc;position:sticky;bottom:0}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:.875rem;font-weight:500;color:#374151}.form-group label .required{color:#ef4444}.form-group input,.form-group select,.form-group textarea{padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.form-section{margin-bottom:1.5rem}.form-section-title{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.einvoice-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d;border-radius:6px;font-size:.75rem;font-weight:600}.einvoice-badge.pending{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.einvoice-badge.failed{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f8fafc;border-radius:8px;border:1px dashed #e2e8f0}.qr-code-container img{width:120px;height:120px}.qr-code-container .irn-text{font-size:.625rem;color:#64748b;font-family:monospace;word-break:break-all;text-align:center}.finance-empty-state{text-align:center;padding:4rem 2rem}.finance-empty-state .icon{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#94a3b8}.finance-empty-state h3{font-size:1.125rem;font-weight:600;color:#1e293b;margin:0 0 .5rem}.finance-empty-state p{color:#64748b;font-size:.875rem;margin:0 0 1.5rem}@media(max-width:768px){.finance-page{padding:1rem}.finance-header{flex-direction:column;align-items:flex-start}.finance-stats{grid-template-columns:repeat(2,1fr)}.finance-table-header{flex-direction:column;align-items:flex-start}.finance-search input{width:100%}.form-grid{grid-template-columns:1fr}.finance-modal{max-height:100vh;border-radius:0}}.detail-header{margin-bottom:1.5rem}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:none;border:none;color:#64748b;cursor:pointer;font-size:.875rem;border-radius:8px;transition:all .2s;margin-bottom:1rem}.back-btn:hover{background:#f1f5f9;color:#1e293b}.detail-header-content{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.detail-header-left h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0;display:flex;align-items:center;gap:.75rem}.detail-subtitle{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.detail-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.detail-column{display:flex;flex-direction:column;gap:1.5rem}.detail-card{background:#fff;border-radius:16px;box-shadow:0 1px 3px #00000014;border:1px solid rgba(0,0,0,.04);overflow:hidden}.detail-card.full-width{grid-column:1 / -1}.detail-card.warning-card{border-left:4px solid #f59e0b}.detail-card-header{display:flex;align-items:center;gap:.625rem;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;background:#f8fafc}.detail-card-header svg{color:#3b82f6}.detail-card-header h3{flex:1;font-size:.875rem;font-weight:600;color:#1e293b;margin:0}.detail-card-header .count-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.6875rem;font-weight:600}.detail-card-body{padding:1.25rem}.info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.625rem 0;border-bottom:1px solid #f1f5f9}.info-row:last-child{border-bottom:none}.info-row.highlight{background:linear-gradient(135deg,#eff6ff,#dbeafe);margin:.5rem -1.25rem;padding:.75rem 1.25rem;border-bottom:none}.info-label{font-size:.8125rem;color:#64748b;font-weight:500}.info-value{font-size:.875rem;color:#1e293b;font-weight:500;text-align:right}.info-value.code{font-family:JetBrains Mono,monospace;font-size:.8125rem;color:#6366f1}.info-value.amount{font-family:JetBrains Mono,monospace;font-weight:600}.info-value .link{display:inline-flex;align-items:center;gap:.375rem;color:#2563eb;text-decoration:none}.info-value .link:hover{text-decoration:underline}.info-divider{height:1px;background:#e2e8f0;margin:.75rem -1.25rem}.contact-details{display:flex;flex-direction:column;gap:.5rem}.contact-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#64748b}.contact-item svg{color:#94a3b8}.contact-item .designation{color:#94a3b8;font-size:.75rem}.scope-text{font-size:.875rem;color:#475569;line-height:1.6;margin:0}.empty-table{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;color:#94a3b8}.empty-table svg{margin-bottom:.75rem}.empty-table p{margin:0 0 1rem;font-size:.875rem}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857)}.btn-sm{padding:.375rem .75rem;font-size:.75rem}.item-row{display:flex;gap:.5rem;margin-bottom:.5rem}.item-row input{padding:.5rem .625rem;border:1px solid #d1d5db;border-radius:6px;font-size:.8125rem}.total-row{margin-top:1rem;text-align:right;padding:.75rem 1rem;background:#f1f5f9;border-radius:8px}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.filter-select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#3b82f6}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}.detail-header-content{flex-direction:column}.detail-header-actions{width:100%}.detail-header-actions .btn{flex:1}}
