:root{color-scheme:light}*,*:before,*:after{box-sizing:border-box}html{font-family:var(--font-family-base);line-height:var(--line-height-base)}body{margin:0;min-height:100vh;background:var(--color-surface-strong);color:var(--color-text);font-family:var(--font-family-base)}a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}img,video{max-width:100%;height:auto}button,input,select,textarea{font:inherit}button{cursor:pointer}:focus-visible{outline:3px solid var(--color-primary-100);outline-offset:2px}*{box-sizing:border-box}.app-icon{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;flex-shrink:0;font-size:inherit}:root{--font-scale: 1;--space-scale: 1}body{margin:0;padding:0;font-family:var(--font-family-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-surface-strong);color:var(--color-text);line-height:var(--line-height-base);width:100%;overflow-x:auto}body[data-density=compact]{--font-scale: .85;--space-scale: .85}body[data-density=comfortable]{--font-scale: 1.05;--space-scale: 1.05}#root,.App{width:100%;min-height:100vh}.container-full{width:100%;padding:0 24px}.container-fluid{width:100%;padding:0 16px}.grid-auto-fit{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.grid-auto-fill{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.grid-responsive{display:grid;gap:1.5rem}@media (min-width: 640px){.grid-responsive{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.grid-responsive{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.grid-responsive{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1280px){.grid-responsive{grid-template-columns:repeat(5,1fr)}}@media (min-width: 1536px){.grid-responsive{grid-template-columns:repeat(6,1fr)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%{box-shadow:0 0 #3b82f6b3}70%{box-shadow:0 0 0 10px #3b82f600}to{box-shadow:0 0 #3b82f600}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.w-full{width:100%}.w-screen{width:100vw}.min-w-full{min-width:100%}.max-w-none{max-width:none}.h-full{height:100%}.h-screen{height:100vh}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-auto{flex:auto}.flex-none{flex:none}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.card{background:#fff;border-radius:16px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;width:100%}.card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.card-compact{padding:16px}.card-large{padding:32px}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.text-5xl{font-size:3rem}@media (min-width: 1024px){.text-responsive{font-size:1.125rem}.text-2xl{font-size:1.75rem}.text-3xl{font-size:2.25rem}.text-4xl{font-size:3rem}.text-5xl{font-size:4rem}}@media (min-width: 1280px){.text-responsive{font-size:1.25rem}.text-2xl{font-size:2rem}.text-3xl{font-size:2.5rem}.text-4xl{font-size:3.5rem}.text-5xl{font-size:4.5rem}}.text-gray-400{color:#9ca3af}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-800{color:#1f2937}.text-gray-900{color:#111827}.text-blue-500{color:#3b82f6}.text-blue-600{color:#2563eb}.text-green-500{color:#10b981}.text-green-600{color:#059669}.text-yellow-500{color:#f59e0b}.text-red-500{color:#ef4444}.text-purple-500{color:#8b5cf6}.bg-blue-50{background-color:#eff6ff}.bg-green-50{background-color:#f0fdf4}.bg-yellow-50{background-color:#fffbeb}.bg-red-50{background-color:#fef2f2}.bg-purple-50{background-color:#faf5ff}.bg-gray-50{background-color:#f9fafb}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}@media (min-width: 1024px){.lg\:p-8{padding:2rem}.lg\:p-12{padding:3rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:px-12{padding-left:3rem;padding-right:3rem}}@media (min-width: 1280px){.xl\:p-12{padding:3rem}.xl\:p-16{padding:4rem}.xl\:px-16{padding-left:4rem;padding-right:4rem}.xl\:px-24{padding-left:6rem;padding-right:6rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;text-decoration:none;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn-sm{padding:8px 16px;font-size:.8rem}.btn-lg{padding:16px 32px;font-size:1rem}.form-input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;background-color:#fff;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:6px}.table-container{width:100%;overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0}.table{width:100%;min-width:600px;border-collapse:collapse;background:#fff}.table th{padding:16px;text-align:left;font-size:.875rem;font-weight:600;color:#64748b;border-bottom:2px solid #f1f5f9;background-color:#f8fafc;position:sticky;top:0;z-index:10}.table td{padding:16px;border-bottom:1px solid #f1f5f9;font-size:.9rem}.table tr:hover{background-color:#f8fafc}@media (max-width: 768px){.desktop-only{display:none}.mobile-stack{flex-direction:column!important}.mobile-full{width:100%!important}.mobile-text-center{text-align:center!important}.container-full{padding:0 16px}.card{padding:16px}.btn{width:100%;justify-content:center}}@media (min-width: 769px){.mobile-only{display:none}}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f4f6;border-radius:50%;border-top-color:#3b82f6;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.badge{display:inline-flex;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:600;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}@media (min-width: 1920px){.container-full{padding:0 48px}.grid-ultra-wide{grid-template-columns:repeat(8,1fr)}.text-ultra{font-size:5rem}}@media (min-width: 2560px){.container-full{padding:0 64px}.grid-ultra-wide{grid-template-columns:repeat(10,1fr)}}.gpu-accelerated{transform:translateZ(0);backface-visibility:hidden;perspective:1000}.smooth-scroll{scroll-behavior:smooth}@media print{.no-print{display:none!important}.print-only{display:block!important}body{background:#fff;color:#000}.card{border:1px solid #ccc;box-shadow:none}}.main-nav{background-color:#fff;border-bottom:1px solid #e2e8f0;padding:0 48px;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:1000}.main-nav-content{width:100%;margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;height:80px}.nav-brand-link{text-decoration:none;display:flex;align-items:center;gap:12px;flex-shrink:0}.nav-brand-icon{background-color:#3b82f6;border-radius:12px;padding:12px;font-size:1.5rem;display:inline-flex;align-items:center;justify-content:center}.nav-brand-icon .app-icon{color:#fff}.nav-brand-title{font-size:1.5rem;font-weight:700;color:#0f172a}.nav-brand-subtitle{font-size:.75rem;color:#64748b;font-weight:500}.nav-links-center{display:flex;align-items:center;justify-content:center;gap:8px}.nav-link{text-decoration:none;display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:10px;font-size:1rem;font-weight:600;transition:all .2s ease;color:#64748b;border:2px solid transparent;white-space:nowrap}.nav-link .app-icon{margin-right:4px}.nav-link.active{background-color:#eff6ff;color:#3b82f6;border:2px solid #bfdbfe}.nav-link:hover:not(.active){background-color:#f1f5f9;color:#374151}.nav-right-group{display:flex;align-items:center;gap:16px;flex-shrink:0}.operating-status{display:none}.nav-user-section{display:flex;align-items:center;gap:12px;padding:8px 16px;background-color:#f8fafc;border-radius:10px;border:1px solid #e2e8f0;justify-content:space-between;cursor:pointer;flex-wrap:nowrap;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease;min-width:200px}.nav-user-section .app-icon{color:#3b82f6}.nav-user-section:hover{background-color:#eef2ff;border-color:#c7d2fe}.nav-user-menu{position:relative}.nav-user-trigger{background:transparent;border:none;padding:0;display:block;cursor:pointer}.nav-user-trigger:focus-visible{outline:none}.nav-user-trigger:focus-visible .nav-user-section{box-shadow:0 0 0 3px #3b82f640}.nav-user-menu.open .nav-user-section{background-color:#eef2ff;border-color:#c7d2fe;box-shadow:0 14px 32px #6366f129}.user-menu-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:min(280px,90vw);background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px;box-shadow:0 24px 48px #0f172a2e;display:grid;gap:16px;z-index:30}.user-menu-header{display:flex;flex-direction:column;gap:4px;border-bottom:1px solid #f1f5f9;padding-bottom:12px}.user-menu-role{font-weight:600;color:#1e293b}.user-menu-date{font-size:.75rem;color:#94a3b8}.user-menu-section{display:flex;flex-direction:column;gap:8px}.user-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;gap:12px;background:none;border:none;padding:10px 12px;border-radius:10px;cursor:pointer;font-size:.9rem;color:#1e293b;transition:background-color .2s ease,color .2s ease}.user-menu-item:hover{background-color:#f8fafc;color:#0f172a}.user-menu-icon{font-size:1rem;background-color:#eef2ff;border-radius:8px;padding:6px;display:inline-flex;align-items:center;justify-content:center;color:#4338ca}.user-menu-label{flex:1;text-align:left;font-weight:600}.user-menu-chevron{width:8px;height:8px;border:solid #64748b;border-width:0 2px 2px 0;transform:rotate(45deg);transition:transform .2s ease,border-color .2s ease}.user-menu-chevron.open{transform:rotate(-135deg);border-color:#4338ca}.user-menu-panel{border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;padding:12px}.user-menu-visual-settings{display:flex;flex-direction:column;gap:12px}.user-info-text{font-size:.875rem;color:#64748b;text-align:right;line-height:1.3}.user-info-text .name{font-weight:600;color:#374151;font-size:.9rem}.user-avatar{width:36px;height:36px;background-color:#e0e7ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;border:2px solid #c7d2fe;color:#6366f1;flex-shrink:0}@media (max-width: 1024px){.main-nav{padding:0 24px}.main-nav-content{gap:16px}.nav-right-group{gap:12px}.nav-links-center{gap:4px}.nav-link{padding:10px 16px;font-size:.9rem}}@media (max-width: 768px){.main-nav{padding:0 16px}.main-nav-content{grid-template-columns:auto auto;gap:8px}.nav-links-center{display:none}.nav-right-group{gap:8px}.user-info-text{display:none}.nav-user-section{padding:8px 12px;min-width:auto;background-color:#f8fafc;border:1px solid #e2e8f0}.user-avatar{width:32px;height:32px;font-size:1rem}}.nav-user-info{display:flex;align-items:center;gap:16px}.user-info-text{font-size:.875rem;color:#64748b;text-align:right}.user-info-text .name{font-weight:600;color:#374151}.user-info-text .date{font-size:.75rem;color:#9ca3af}.user-avatar{width:40px;height:40px;background-color:#e0e7ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;border:2px solid #c7d2fe;color:#6366f1}@media (max-width: 768px){.nav-user-info{gap:8px}.user-info-text{display:none}.nav-center-group{gap:16px}.nav-links{display:none}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;transition:none!important;transform:none!important;animation:none!important;backface-visibility:hidden;perspective:1000px;will-change:auto}.page-header-content h1{margin:0 0 4px;font-size:1.75rem;font-weight:600;color:#1f2937}.page-header-content p{margin:0;color:#6b7280;font-size:.9rem}.report-header{text-align:center;padding:24px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.company-info h2{margin:0 0 8px;color:#1f2937;font-size:1.5rem;font-weight:600}.company-info p{margin:0 0 12px;color:#6b7280;font-size:.9rem}.report-metadata{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;font-size:.85rem;color:#9ca3af}.report-metadata span{background:#f3f4f6;padding:4px 8px;border-radius:4px}.simple-summary{background:#fff;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.summary-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f3f4f6}.summary-item:last-child{border-bottom:none}.summary-label{color:#6b7280;font-weight:500}.summary-value{color:#1f2937;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.page-header-content h1{margin:0 0 8px;font-size:1.75rem;font-weight:600;color:#1f2937}.page-header-content p{margin:0;color:#6b7280;font-size:.9rem;line-height:1.4}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.page-header-content{flex:1}.page-header-content h1{margin:0 0 12px;font-size:1.8rem;font-weight:600;color:#1f2937;line-height:1.2}.page-header-content p{margin:0;color:#6b7280;font-size:.95rem;line-height:1.5;max-width:400px}.export-button{background:#10b981;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.export-button:hover{background:#059669}.filters-section{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px}.filters-section h3{margin:0 0 20px;font-size:1.1rem;font-weight:600;color:#374151}.date-range{display:flex;gap:16px}.filter-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.filter-chip{background:#f3f4f6;border:1px solid #d1d5db;color:#374151;padding:6px 12px;border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s}.filter-chip.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.generate-button{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;margin-top:16px}.a4-report{background:#fff;max-width:794px;margin:0 auto;padding:40px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;font-family:Times New Roman,serif;line-height:1.5;color:#000}.report-header-a4{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #000}.report-header-a4 h2{margin:0 0 8px;font-size:1.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.report-header-a4 p{margin:0 0 12px;font-size:1rem;font-weight:400}.report-meta{font-size:.9rem;color:#666;font-style:italic}.summary-header{margin-bottom:25px;padding:15px 0;border-top:1px solid #ccc;border-bottom:1px solid #ccc}.summary-line{display:flex;justify-content:space-between;margin-bottom:8px;font-size:1rem;font-weight:500}.summary-line:last-child{margin-bottom:0}.period-title{margin-bottom:20px}.period-title h3{margin:0 0 5px;font-size:1.2rem;font-weight:700;text-transform:uppercase}.period-title p{margin:0;font-size:.9rem;color:#666;font-style:italic}.expenses-data{margin-bottom:30px}.expense-line{margin-bottom:15px;border-bottom:1px dotted #ccc;padding-bottom:10px}.expense-line:last-child{border-bottom:none;margin-bottom:0}.expense-line-header{display:flex;align-items:flex-start;margin-bottom:5px}.expense-date{min-width:90px;font-weight:500;font-size:.95rem}.expense-title{flex:1;margin:0 15px;font-weight:400;font-size:1rem}.expense-title strong{font-weight:700;color:#333}.expense-amount{min-width:100px;text-align:right;font-weight:700;font-size:1rem;color:#d00}.expense-details-line{font-size:.85rem;color:#666;margin-left:90px;line-height:1.4}.expense-details-line strong{color:#000;font-weight:700;font-style:normal}.report-footer-a4{border-top:2px solid #000;padding-top:20px}.report-footer-a4 h3{margin:0 0 15px;font-size:1.2rem;font-weight:700;text-transform:uppercase}.total-line{display:flex;justify-content:space-between;font-size:1.3rem;font-weight:700;text-transform:uppercase;border-top:2px solid #000;border-bottom:2px solid #000;padding:15px 0;margin-top:10px}.total-line span:last-child{color:#d00}.empty-state,.error-state{background:#fff;padding:40px;text-align:center;border-radius:8px;box-shadow:0 1px 3px #0000001a;max-width:600px;margin:0 auto}.empty-state-icon{font-size:3rem;margin-bottom:16px}.empty-state h3,.error-state h3{margin:0 0 8px;color:#374151}.empty-state p,.error-state p{margin:0;color:#6b7280}@media (max-width: 868px){.a4-report{margin:0 16px;padding:20px;box-shadow:none;border:1px solid #e5e7eb}}@media (max-width: 600px){.page-header{flex-direction:column;gap:16px;align-items:stretch}.date-range{flex-direction:column}.expense-line-header{flex-direction:column;gap:5px}.expense-date{min-width:auto}.expense-title{margin:0}.expense-amount{min-width:auto;text-align:left;font-size:1.1rem}.expense-details-line{margin-left:0}.total-line{flex-direction:column;gap:10px;text-align:center}}@media print{.page-header,.filters-section{display:none!important}.a4-report{box-shadow:none;margin:0;padding:0;max-width:none}body{-webkit-print-color-adjust:exact}}.obra-card{display:flex;justify-content:space-between;align-items:center;transition:background-color .2s ease,box-shadow .2s ease}.obra-card:hover{background-color:var(--color-surface-alt);box-shadow:var(--shadow-md)}.obra-actions-menu{position:relative}.menu-icon-button{background:transparent;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;padding:4px 12px;border-radius:8px}.menu-icon-button:hover{background-color:#f1f5f9;color:#374151}.dropdown-menu{position:absolute;right:0;top:40px;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid #e2e8f0;padding:8px;z-index:10;width:200px}.dropdown-menu button{width:100%;background:none;border:none;padding:10px 12px;text-align:left;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:8px;color:#374151}.dropdown-menu button:hover{background-color:#f1f5f9}.enviado-badge{margin-left:auto}.form-group{display:flex;flex-direction:column;gap:calc(8px * var(--space-scale));width:100%}.form-label{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:600;color:#374151;display:inline-flex;align-items:center;gap:calc(6px * var(--space-scale))}.form-input,.form-select,.form-textarea{width:100%;padding:calc(12px * var(--space-scale)) calc(16px * var(--space-scale));border:2px solid #d1d5db;border-radius:calc(8px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);background-color:#f3f4f6;color:#1f2937;font-weight:600;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f64d}.form-help-text{font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);color:#64748b;margin-top:calc(-4px * var(--space-scale))}.form-container{background-color:#fff;border-radius:calc(12px * var(--space-scale));padding:calc(32px * var(--space-scale));border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;margin-top:calc(20px * var(--space-scale))}.form-header{font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);font-weight:600;color:#1e293b;margin-bottom:calc(24px * var(--space-scale));display:flex;align-items:center;gap:calc(12px * var(--space-scale));margin-top:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:calc(20px * var(--space-scale));margin-bottom:calc(24px * var(--space-scale))}.form-error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:calc(8px * var(--space-scale));padding:calc(12px * var(--space-scale)) calc(16px * var(--space-scale));margin-bottom:calc(20px * var(--space-scale));color:#b91c1c;font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);font-weight:600}.form-info-message{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:calc(8px * var(--space-scale));padding:calc(12px * var(--space-scale)) calc(16px * var(--space-scale));margin-bottom:calc(20px * var(--space-scale));color:#1e40af;font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);font-weight:600}.form-button{background-color:#10b981;color:#fff;border:none;border-radius:calc(8px * var(--space-scale));padding:calc(14px * var(--space-scale)) calc(32px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:600;cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;gap:calc(8px * var(--space-scale));box-shadow:0 1px 2px #0000000d}.form-button:hover{background-color:#059669}.form-button:disabled{background-color:#9ca3af;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-container{background-color:#fff;border-radius:calc(12px * var(--space-scale));padding:0;max-width:calc(600px * var(--space-scale));width:90%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{padding:calc(24px * var(--space-scale)) calc(32px * var(--space-scale));border-bottom:1px solid #e2e8f0;display:flex;align-items:flex-start;justify-content:space-between}.modal-title{font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);font-weight:600;color:#1e293b;margin:0 0 calc(4px * var(--space-scale)) 0;display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.modal-subtitle{font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);color:#64748b;margin:0}.modal-close-button{background-color:transparent;border:none;font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);cursor:pointer;color:#64748b;padding:calc(4px * var(--space-scale));line-height:1;border-radius:calc(4px * var(--space-scale));transition:all .2s ease}.modal-close-button:hover{background-color:#f1f5f9;color:#374151}.modal-body{padding:calc(32px * var(--space-scale));overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:calc(12px * var(--space-scale));padding-top:calc(24px * var(--space-scale));margin-top:calc(32px * var(--space-scale));border-top:1px solid #e2e8f0}.form-button-secondary{background-color:transparent;color:#64748b;border:1px solid #d1d5db;border-radius:calc(8px * var(--space-scale));padding:calc(12px * var(--space-scale)) calc(24px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:calc(8px * var(--space-scale))}.form-button-secondary:hover{background-color:#f8fafc;border-color:#9ca3af;color:#374151}.form-button-secondary:disabled{opacity:.6;cursor:not-allowed}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.icon-spin{animation:spin 1s linear infinite}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.5);cursor:pointer}.page-container{min-height:100vh;background-color:#f1f5f9}.page-container--compact .page-header{padding:var(--space-5, 24px) var(--space-6, 32px);margin-bottom:var(--space-5, 24px)}.page-container--compact .page-title{font-size:2.25rem}.page-container--compact .page-subtitle{font-size:1rem}.page-container--compact .page-header-actions{gap:var(--space-3, 12px)}.page-container--compact .page-content{padding:0 var(--space-6, 32px) var(--space-6, 32px)}.page-header{background-color:#fff;border-bottom:1px solid #e2e8f0;padding:calc(32px * var(--space-scale)) calc(48px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));box-shadow:0 1px 3px #0000000d}.page-header-content{max-width:calc(1400px * var(--space-scale));margin:0 auto;display:flex;justify-content:space-between;align-items:center}.page-title{font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);font-weight:800;color:#0f172a;margin:0 0 calc(8px * var(--space-scale)) 0;display:flex;align-items:center;gap:calc(16px * var(--space-scale))}.page-subtitle{font-size:clamp(1rem,calc(1.1rem * var(--font-scale)),1.25rem);color:#64748b;margin:0}.page-header-actions{display:flex;gap:calc(12px * var(--space-scale))}.page-content{width:100%;margin:0 auto;padding:0 calc(48px * var(--space-scale)) calc(48px * var(--space-scale))}.card{background-color:#fff;border-radius:calc(16px * var(--space-scale));padding:calc(32px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));box-shadow:0 4px 20px #0000000d;border:1px solid #e2e8f0}.card-header{font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);font-weight:700;color:#1e293b;margin:calc(-32px * var(--space-scale)) calc(-32px * var(--space-scale)) calc(24px * var(--space-scale)) calc(-32px * var(--space-scale));padding:calc(24px * var(--space-scale)) calc(32px * var(--space-scale));border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.filter-button-group{display:flex;flex-wrap:wrap;gap:calc(10px * var(--space-scale));margin-bottom:calc(24px * var(--space-scale))}.filter-button{padding:calc(8px * var(--space-scale)) calc(16px * var(--space-scale));border-radius:calc(20px * var(--space-scale));border:2px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:500;cursor:pointer;transition:all .2s ease}.filter-button:hover{border-color:#cbd5e1;color:#334155}.filter-button.active{border-color:#3b82f6;background-color:#eff6ff;color:#3b82f6;font-weight:600}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale))}.summary-card{background-color:#fff;border-radius:calc(16px * var(--space-scale));padding:calc(24px * var(--space-scale));box-shadow:0 4px 20px #0000000d;border:1px solid #e2e8f0;text-align:center}.summary-card-icon{font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);margin-bottom:calc(12px * var(--space-scale));display:inline-flex;align-items:center;justify-content:center}.summary-card-value{font-size:clamp(1.75rem,calc(2rem * var(--font-scale)),2.25rem);font-weight:800;margin-bottom:calc(8px * var(--space-scale))}.summary-card-label{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#64748b;font-weight:500}.report-table{overflow:hidden}.report-table-header,.report-table-row{display:grid;grid-template-columns:120px 1.5fr 1fr 2fr 130px 80px;gap:calc(16px * var(--space-scale));padding:calc(16px * var(--space-scale)) 0;align-items:center;border-bottom:1px solid #f1f5f9}.report-table-header{font-size:clamp(.75rem,calc(.85rem * var(--font-scale)),.95rem);font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;padding:calc(16px * var(--space-scale)) calc(24px * var(--space-scale));margin:0 calc(-32px * var(--space-scale))}.report-table-body{max-height:calc(600px * var(--space-scale));overflow-y:auto}.report-table-row{font-size:clamp(.85rem,calc(.95rem * var(--font-scale)),1.05rem)}.report-table-row:last-child{border-bottom:none}.report-table-row .currency{color:#059669;font-weight:700;text-align:right}.badge{display:inline-block;padding:calc(4px * var(--space-scale)) calc(10px * var(--space-scale));border-radius:calc(12px * var(--space-scale));font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);font-weight:600}.badge.success{background-color:#dcfce7;color:#166534}.badge.error{background-color:#fef2f2;color:#991b1b}.empty-state,.error-state{padding:calc(64px * var(--space-scale)) calc(32px * var(--space-scale));text-align:center}.empty-state-icon{font-size:clamp(3rem,calc(4rem * var(--font-scale)),5rem);margin-bottom:calc(20px * var(--space-scale));opacity:.5}.empty-state h3,.error-state h3{font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);font-weight:600;color:#64748b;margin-bottom:calc(12px * var(--space-scale))}.empty-state p,.error-state p{color:#9ca3af;font-size:clamp(1rem,calc(1.1rem * var(--font-scale)),1.25rem);max-width:clamp(360px,calc(450px * var(--space-scale)),520px);margin:0 auto calc(24px * var(--space-scale))}.error-state h3{color:#b91c1c}.error-state p{color:#991b1b}.form-button.error{background-color:#dc2626}.form-button.error:hover{background-color:#b91c1c}.page-container{width:100%;min-height:100vh;background-color:#f1f5f9}.breadcrumb{margin-bottom:calc(32px * var(--space-scale))}.breadcrumb-link{text-decoration:none;color:#3b82f6;font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:500;display:flex;align-items:center;gap:calc(8px * var(--space-scale));margin-bottom:calc(16px * var(--space-scale));transition:color .2s ease}.breadcrumb-link:hover{color:#2563eb}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:calc(24px * var(--space-scale))}.project-title-section{flex:1}.project-title{font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);font-weight:700;color:#0f172a;margin:0 0 calc(8px * var(--space-scale)) 0;line-height:1.2}.project-meta{display:flex;align-items:center;gap:calc(16px * var(--space-scale));flex-wrap:wrap}.project-location{font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);color:#64748b;font-weight:500;display:inline-flex;align-items:center;gap:calc(6px * var(--space-scale))}.status-badge{padding:calc(4px * var(--space-scale)) calc(12px * var(--space-scale));border-radius:calc(20px * var(--space-scale));font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);font-weight:600;border:1px solid;margin-left:calc(25px * var(--space-scale))}.status-planning{background-color:#fef3c7;color:#92400e;border-color:#f59e0b}.status-active{background-color:#d1fae5;color:#065f46;border-color:#10b981}.status-paused{background-color:#fed7aa;color:#9a3412;border-color:#f97316}.status-completed{background-color:#dbeafe;color:#1e40af;border-color:#3b82f6}.status-additive{background-color:#e5e7eb;color:#374151;border-color:#6b7280}.status-cancelled{background-color:#fecaca;color:#991b1b;border-color:#ef4444}.info-card{padding:calc(16px * var(--space-scale));border-radius:calc(8px * var(--space-scale));border:1px solid}.info-card-blue{background-color:#eff6ff;border-color:#bfdbfe}.info-card-green{background-color:#f0fdf4;border-color:#bbf7d0}.info-card-yellow{background-color:#fffbeb;border-color:#fbbf24}.info-card-red{background-color:#fef2f2;border-color:#fecaca}.info-card-header{display:flex;align-items:center;gap:calc(8px * var(--space-scale));margin-bottom:calc(8px * var(--space-scale))}.info-card-icon{font-size:clamp(1rem,calc(1.25rem * var(--font-scale)),1.5rem)}.info-card-title{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-card-blue .info-card-title{color:#1d4ed8}.info-card-green .info-card-title{color:#15803d}.info-card-yellow .info-card-title{color:#92400e}.info-card-red .info-card-title{color:#991b1b}.info-card-value{font-size:clamp(1.5rem,calc(1.75rem * var(--font-scale)),2rem);font-weight:700;margin-bottom:calc(4px * var(--space-scale))}.info-card-blue .info-card-value{color:#1e40af}.info-card-green .info-card-value{color:#166534}.info-card-yellow .info-card-value{color:#b45309}.info-card-red .info-card-value{color:#dc2626}.info-card-subtitle{font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);color:#64748b;text-transform:uppercase;font-weight:500}.info-card--compact{padding:var(--space-4, 12px);border-radius:var(--radius-sm, 6px)}.info-card--compact .info-card-header{gap:var(--space-2, 6px);margin-bottom:var(--space-2, 6px)}.info-card--compact .info-card-icon{font-size:var(--font-lg, 1.1rem)}.info-card--compact .info-card-title{font-size:.7rem}.info-card--compact .info-card-value{font-size:1.5rem;margin-bottom:var(--space-1, 4px)}.info-card--compact .info-card-subtitle{font-size:.75rem}.tabs-navigation{width:100%;margin:0 auto;padding:0 calc(48px * var(--space-scale));display:flex;gap:calc(8px * var(--space-scale))}.tab-button{padding:calc(16px * var(--space-scale)) calc(24px * var(--space-scale));border:none;border-bottom:3px solid transparent;background-color:transparent;font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:600;cursor:pointer;color:#64748b;transition:all .2s ease;margin-bottom:calc(-1px * var(--space-scale))}.tab-button:hover{background-color:#f1f5f9;color:#374151}.tab-button-active{color:#3b82f6;border-bottom-color:#3b82f6}.tabs-navigation--compact{padding:0 var(--space-5, 24px);gap:var(--space-2, 8px)}.tabs-navigation--compact .tab-button,.tab-button--compact{padding:var(--space-3, 12px) var(--space-4, 16px);border-radius:var(--radius-sm, 6px);font-size:.95rem}.tab-content-full{width:100%}.tab-button-active:hover{background-color:#2563eb}.tab-content{background-color:#fff;border-radius:0 0 calc(12px * var(--space-scale)) calc(12px * var(--space-scale));border:1px solid #e2e8f0;border-top:none;padding:calc(32px * var(--space-scale));box-shadow:0 1px 3px #0000001a}.section-container{background-color:#fff;border-radius:calc(12px * var(--space-scale));border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000001a;overflow:hidden}.section-container--compact{border-radius:var(--radius-md, 10px)}.section-header{padding:calc(24px * var(--space-scale)) calc(32px * var(--space-scale));border-bottom:1px solid #f1f5f9;background-color:#f8fafc;display:flex;justify-content:space-between;align-items:center}.section-container--compact .section-header{padding:var(--space-4, 16px) var(--space-5, 24px)}.section-title{font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);font-weight:600;color:#1e293b;margin:0;display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.section-container--compact .section-title{font-size:1.3rem;gap:var(--space-2, 8px)}.count-badge{background-color:#e0e7ff;color:#3730a3;padding:calc(4px * var(--space-scale)) calc(12px * var(--space-scale));border-radius:calc(20px * var(--space-scale));font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);font-weight:700}.section-container--compact .count-badge{padding:var(--space-1, 4px) var(--space-3, 10px);font-size:.8rem;border-radius:var(--radius-full, 9999px)}.section-body{padding:calc(32px * var(--space-scale))}.section-container--compact .section-body{padding:var(--space-5, 24px)}.empty-state{text-align:center;padding:calc(48px * var(--space-scale));color:#64748b}.empty-state-icon{font-size:clamp(2.5rem,calc(3rem * var(--font-scale)),3.5rem);margin-bottom:calc(16px * var(--space-scale))}.empty-state-title{font-size:clamp(1rem,calc(1.2rem * var(--font-scale)),1.4rem);margin-bottom:calc(8px * var(--space-scale));color:#374151}.empty-state-message,.empty-state-description{font-size:clamp(.95rem,calc(1.1rem * var(--font-scale)),1.25rem);margin:0}.loading-state{text-align:center;padding:calc(48px * var(--space-scale));font-size:clamp(1rem,calc(1.125rem * var(--font-scale)),1.25rem);color:#64748b}.contracts-list{display:grid;gap:calc(16px * var(--space-scale))}.contract-card{border:1px solid #e2e8f0;border-radius:calc(12px * var(--space-scale));padding:calc(24px * var(--space-scale));transition:all .2s ease;background-color:#fafafa}.contract-card:hover{background-color:#f8fafc;border-color:#c7d2fe;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.contract-card-content{display:grid;grid-template-columns:auto 1fr auto;gap:calc(20px * var(--space-scale));align-items:center}.contract-card-main{display:flex;align-items:center;gap:calc(16px * var(--space-scale))}.contract-card-icon{width:calc(48px * var(--space-scale));height:calc(48px * var(--space-scale));background-color:#eff6ff;border-radius:calc(12px * var(--space-scale));display:flex;align-items:center;justify-content:center;font-size:clamp(1.25rem,calc(1.5rem * var(--font-scale)),1.75rem);border:2px solid #bfdbfe}.contract-card-info{flex:1}.contract-card-title{font-size:clamp(1rem,calc(1.1rem * var(--font-scale)),1.25rem);font-weight:600;color:#1e293b;margin:0 0 calc(4px * var(--space-scale)) 0}.contract-card-period{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#64748b;margin:0}.contract-card-value{text-align:center;padding:calc(12px * var(--space-scale));background-color:#f0fdf4;border-radius:calc(8px * var(--space-scale));border:1px solid #bbf7d0}.contract-card-value-label{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);font-weight:600;color:#15803d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:calc(4px * var(--space-scale))}.contract-card-value-amount{font-size:clamp(1rem,calc(1.1rem * var(--font-scale)),1.25rem);font-weight:700;color:#166534}.contract-card-actions{display:flex;gap:calc(8px * var(--space-scale))}.expenses-list{display:flex;flex-direction:column;gap:0}.expense-row{border-bottom:1px solid #f1f5f9;padding:calc(20px * var(--space-scale)) 0;display:grid;grid-template-columns:2fr 1fr 1fr auto auto;align-items:center;gap:calc(16px * var(--space-scale))}.expense-row:last-child{border-bottom:none}.expense-description{font-weight:600;color:#1e293b;margin-bottom:calc(4px * var(--space-scale))}.expense-date{font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);color:#64748b}.expense-cost-center{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#475569}.expense-amount{font-weight:700;color:#dc2626}.attachment-link{color:#3b82f6;text-decoration:none;font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);font-weight:500;display:flex;align-items:center;gap:calc(4px * var(--space-scale));padding:calc(4px * var(--space-scale)) calc(8px * var(--space-scale));border-radius:calc(4px * var(--space-scale));border:1px solid #bfdbfe;background-color:#eff6ff;transition:all .2s ease}.action-button{border:none;border-radius:calc(4px * var(--space-scale));padding:calc(6px * var(--space-scale)) calc(12px * var(--space-scale));font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);cursor:pointer;transition:background-color .2s ease}.action-button-edit{background-color:#3b82f6;color:#fff}.action-button-delete{background-color:#ef4444;color:#fff}.form-button-danger{background-color:#ef4444;color:#fff;border:none;border-radius:calc(8px * var(--space-scale));padding:calc(14px * var(--space-scale)) calc(32px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:600;cursor:pointer;transition:background-color .2s ease;display:inline-flex;align-items:center;gap:calc(8px * var(--space-scale));box-shadow:0 1px 2px #0000000d}.form-button-danger:hover{background-color:#dc2626}.form-button-danger:disabled{background-color:#9ca3af;cursor:not-allowed}@media (max-width: 768px){.page-container{padding:calc(24px * var(--space-scale)) calc(16px * var(--space-scale))}.project-header{flex-direction:column;gap:calc(16px * var(--space-scale));align-items:flex-start}.project-title{font-size:clamp(1.6rem,calc(1.875rem * var(--font-scale)),2.1rem)}.tabs-navigation{flex-wrap:wrap}.tab-content{padding:calc(24px * var(--space-scale)) calc(16px * var(--space-scale))}.section-header{flex-direction:column;gap:calc(16px * var(--space-scale));align-items:flex-start;padding:calc(20px * var(--space-scale))}.section-body{padding:calc(20px * var(--space-scale))}.contract-card-content{grid-template-columns:1fr;gap:calc(16px * var(--space-scale));text-align:center}.expense-row{grid-template-columns:1fr;gap:calc(12px * var(--space-scale));text-align:left}.expense-actions{justify-content:flex-start}}@media (max-width: 480px){.form-grid{grid-template-columns:1fr}.project-meta{flex-direction:column;align-items:flex-start;gap:calc(8px * var(--space-scale))}}.filters-section{padding:calc(24px * var(--space-scale)) calc(32px * var(--space-scale));background-color:#fafbfc;border-bottom:1px solid #f1f5f9}.expenses-list{display:grid;gap:calc(12px * var(--space-scale))}.expense-row-card{border:1px solid #e2e8f0;border-radius:calc(12px * var(--space-scale));padding:calc(16px * var(--space-scale));transition:all .2s ease;background-color:#fff;display:grid;grid-template-columns:2fr 1fr 1fr auto auto;align-items:center;gap:calc(16px * var(--space-scale))}.expense-row-card:hover{background-color:#f8fafc;border-color:#c7d2fe;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.expense-info{flex:1}.expense-description{font-weight:600;color:#1e2d3b;margin-bottom:calc(2px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem)}.expense-date{font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);color:#64748b}.expense-cost-center{font-size:clamp(.75rem,calc(.85rem * var(--font-scale)),.95rem);color:#475569;font-weight:500}.expense-amount{font-weight:700;color:#dc2626;font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem)}.expense-attachment{display:flex;justify-content:center}.attachment-link{color:#3b82f6;text-decoration:none;font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);font-weight:500;display:flex;align-items:center;gap:calc(4px * var(--space-scale));padding:calc(4px * var(--space-scale)) calc(8px * var(--space-scale));border-radius:calc(4px * var(--space-scale));border:1px solid #bfdbfe;background-color:#eff6ff;transition:all .2s ease}.attachment-link:hover{background-color:#dbeafe;border-color:#93c5fd}.expense-actions{display:flex;gap:calc(8px * var(--space-scale))}.action-button-edit,.action-button-delete{border:none;border-radius:calc(6px * var(--space-scale));padding:calc(8px * var(--space-scale));font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);cursor:pointer;transition:background-color .2s ease;color:#fff;line-height:1}.action-button-edit{background-color:#3b82f6}.action-button-edit:hover{background-color:#2563eb}.action-button-delete{background-color:#ef4444}.action-button-delete:hover{background-color:#dc2626}.contract-header-display{display:flex;align-items:center;gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));padding:calc(24px * var(--space-scale));background-color:#f0fdf4;border-radius:calc(12px * var(--space-scale));border:1px solid #bbf7d0}.contract-header-icon{width:calc(80px * var(--space-scale));height:calc(80px * var(--space-scale));background-color:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);color:#fff;flex-shrink:0}.contract-header-title{font-size:clamp(1.3rem,calc(1.5rem * var(--font-scale)),1.7rem);font-weight:600;color:#166534;margin:0 0 calc(8px * var(--space-scale)) 0}.contract-header-subtitle{font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);color:#15803d;margin:0 0 calc(12px * var(--space-scale)) 0;font-weight:500}.section-divider{font-size:clamp(1.1rem,calc(1.25rem * var(--font-scale)),1.4rem);font-weight:600;color:#1e293b;margin-top:calc(32px * var(--space-scale));margin-bottom:calc(20px * var(--space-scale));display:flex;align-items:center;gap:calc(8px * var(--space-scale));padding-bottom:calc(8px * var(--space-scale));border-bottom:2px solid #f1f5f9}.employee-header-display{display:flex;align-items:center;gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));padding:calc(24px * var(--space-scale));background-color:#f8fafc;border-radius:calc(12px * var(--space-scale));border:1px solid #f1f5f9}.employee-header-avatar{width:calc(80px * var(--space-scale));height:calc(80px * var(--space-scale));background-color:#e0e7ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);color:#4338ca;flex-shrink:0;border:3px solid #c7d2fe}.employee-header-name{font-size:clamp(1.3rem,calc(1.5rem * var(--font-scale)),1.7rem);font-weight:600;color:#1e293b;margin:0 0 calc(8px * var(--space-scale)) 0}.employee-header-position{font-size:clamp(.95rem,calc(1.1rem * var(--font-scale)),1.25rem);color:#6366f1;font-weight:500;margin:0 0 calc(12px * var(--space-scale)) 0}.status-dot{width:calc(8px * var(--space-scale));height:calc(8px * var(--space-scale));border-radius:50%;margin-right:calc(8px * var(--space-scale))}.status-dot.active{background-color:#10b981}.status-dot.inactive{background-color:#f59e0b}.badge .status-dot{display:inline-block}.checkbox-label{display:flex;align-items:center;gap:calc(12px * var(--space-scale));font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);font-weight:500;color:#374151;cursor:pointer;background-color:#f8fafc;border:1px solid #f1f5f9;border-radius:calc(8px * var(--space-scale));padding:calc(16px * var(--space-scale));margin-top:calc(24px * var(--space-scale))}.form-checkbox{width:calc(18px * var(--space-scale));height:calc(18px * var(--space-scale));accent-color:#3b82f6}.expense-header-display{display:flex;align-items:center;gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));padding:calc(24px * var(--space-scale));background-color:#fefce8;border-radius:calc(12px * var(--space-scale));border:1px solid #fde047}.expense-header-icon{width:calc(80px * var(--space-scale));height:calc(80px * var(--space-scale));background-color:#f59e0b;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);color:#fff;flex-shrink:0}.expense-header-title{font-size:clamp(1.3rem,calc(1.5rem * var(--font-scale)),1.7rem);font-weight:600;color:#854d0e;margin:0 0 calc(12px * var(--space-scale)) 0}.expense-header-badges{display:flex;flex-wrap:wrap;gap:calc(12px * var(--space-scale))}.badge.info{background-color:#e0e7ff;color:#3730a3}.badge.warning{background-color:#fff7ed;color:#9a3412}.badge.purple{background-color:#f3e8ff;color:#7c3aed}.work-header-display{display:flex;align-items:center;gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale));padding:calc(24px * var(--space-scale));background-color:#f8fafc;border-radius:calc(12px * var(--space-scale));border:1px solid #f1f5f9}.work-header-icon{width:calc(80px * var(--space-scale));height:calc(80px * var(--space-scale));background-color:#e0e7ff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:clamp(2rem,calc(2.5rem * var(--font-scale)),3rem);color:#4338ca;flex-shrink:0;border:3px solid #c7d2fe}.work-header-title{font-size:clamp(1.3rem,calc(1.5rem * var(--font-scale)),1.7rem);font-weight:600;color:#1e293b;margin:0 0 calc(8px * var(--space-scale)) 0}.work-header-subtitle{font-size:clamp(.9rem,calc(1rem * var(--font-scale)),1.1rem);color:#64748b;margin:0 0 calc(8px * var(--space-scale)) 0}.work-header-cno{font-size:clamp(.75rem,calc(.875rem * var(--font-scale)),1rem);color:#6366f1;font-weight:500}.allocations-list{display:flex;flex-direction:column;gap:calc(12px * var(--space-scale))}.allocation-item{display:flex;justify-content:space-between;align-items:center;padding:calc(16px * var(--space-scale));background-color:#f8fafc;border:1px solid #f1f5f9;border-radius:calc(8px * var(--space-scale))}.allocation-project-name a{font-weight:600;color:#3b82f6;text-decoration:none;transition:color .2s ease}.allocation-project-name a:hover{color:#2563eb;text-decoration:underline}.allocation-dates{display:flex;gap:calc(24px * var(--space-scale));font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#64748b}.charts-grid-container{display:grid;gap:calc(32px * var(--space-scale));margin-top:calc(32px * var(--space-scale))}.charts-grid-double{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:calc(32px * var(--space-scale))}.bar-chart-container{display:flex;flex-direction:column;gap:calc(16px * var(--space-scale))}.bar-chart-row{display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.bar-chart-label{min-width:clamp(112px,calc(140px * var(--space-scale)),168px);font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:500;color:#374151}.bar-chart-bar-bg{flex:1;height:calc(24px * var(--space-scale));background-color:#f1f5f9;border-radius:calc(12px * var(--space-scale));overflow:hidden}.bar-chart-bar-fill{height:100%;border-radius:calc(12px * var(--space-scale));transition:width 1s ease-out;display:flex;align-items:center;justify-content:flex-end;padding-right:calc(8px * var(--space-scale))}.bar-chart-percentage{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.bar-chart-value{min-width:clamp(80px,calc(100px * var(--space-scale)),120px);text-align:right;font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:600;color:#059669}.pie-chart-container{display:flex;flex-direction:column;gap:calc(12px * var(--space-scale))}.pie-chart-item{display:flex;align-items:center;justify-content:space-between;padding:calc(12px * var(--space-scale));background-color:#fafbfc;border-radius:calc(8px * var(--space-scale));border:1px solid #f1f5f9}.pie-chart-legend{display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.pie-chart-color-dot{width:calc(12px * var(--space-scale));height:calc(12px * var(--space-scale));border-radius:50%}.pie-chart-name{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:500;color:#374151}.pie-chart-details{text-align:right}.pie-chart-value{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:600;color:#059669}.pie-chart-percentage{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);color:#64748b}.timeline-chart-container{position:relative;height:calc(200px * var(--space-scale));padding:20px 0}.timeline-chart-baseline{position:absolute;bottom:calc(40px * var(--space-scale));left:0;right:0;height:calc(2px * var(--space-scale));background-color:#e2e8f0}.timeline-chart-bars{display:flex;justify-content:space-around;align-items:flex-end;height:100%;gap:calc(8px * var(--space-scale))}.timeline-item{display:flex;flex-direction:column;align-items:center;flex:1;gap:calc(8px * var(--space-scale));padding-bottom:calc(22px * var(--space-scale));position:relative}.timeline-bar{width:100%;max-width:calc(40px * var(--space-scale));background-color:#3b82f6;border-radius:4px 4px 0 0;position:relative;transition:height 1s ease-out}.timeline-value-label{position:absolute;top:calc(-25px * var(--space-scale));left:50%;transform:translate(-50%);font-size:clamp(.595rem,calc(.7rem * var(--font-scale)),.805rem);font-weight:600;color:#3b82f6;white-space:nowrap}.timeline-month-label{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);color:#64748b;font-weight:500;text-align:center;white-space:nowrap;position:absolute;bottom:0;left:50%;transform:translate(-50%) rotate(-45deg);transform-origin:center}.project-list-container{display:flex;flex-direction:column;gap:calc(16px * var(--space-scale))}.project-card{display:grid;grid-template-columns:2fr 1.5fr auto;gap:calc(24px * var(--space-scale));align-items:center;background-color:#fff;border-radius:calc(12px * var(--space-scale));padding:calc(24px * var(--space-scale));border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;transition:all .2s ease-in-out;cursor:pointer}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a;border-color:#c7d2fe}.project-card-header{display:flex;align-items:center;gap:calc(12px * var(--space-scale));margin-bottom:calc(8px * var(--space-scale))}.project-card-title{margin:0;font-size:clamp(1.062rem,calc(1.25rem * var(--font-scale)),1.438rem);color:#1e293b}.project-card-meta{display:flex;gap:calc(16px * var(--space-scale));font-size:clamp(.744rem,calc(.875rem * var(--font-scale)),1.006rem);color:#64748b}.project-card-metrics{display:flex;gap:calc(16px * var(--space-scale));justify-content:space-around}.metric-block{text-align:center;padding:calc(12px * var(--space-scale));border-radius:calc(8px * var(--space-scale));background-color:#f8fafc;border:1px solid #f1f5f9;min-width:clamp(96px,calc(120px * var(--space-scale)),144px)}.metric-label{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#64748b;display:block;margin-bottom:calc(4px * var(--space-scale))}.metric-value{font-size:clamp(.935rem,calc(1.1rem * var(--font-scale)),1.265rem);font-weight:700;color:#1e293b}.project-card-actions{display:flex;gap:calc(8px * var(--space-scale));justify-content:flex-end}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:calc(24px * var(--space-scale));margin-bottom:calc(32px * var(--space-scale))}.dashboard-main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:calc(32px * var(--space-scale));align-items:start}.summary-card{background-color:#fff;border-radius:calc(12px * var(--space-scale));padding:calc(24px * var(--space-scale));border:1px solid #e2e8f0;text-align:center;box-shadow:0 1px 3px #0000000d}.summary-card-icon{font-size:clamp(1.7rem,calc(2rem * var(--font-scale)),2.3rem);line-height:1;width:calc(64px * var(--space-scale));height:calc(64px * var(--space-scale));margin:0 auto calc(16px * var(--space-scale));border-radius:50%;display:flex;align-items:center;justify-content:center}.summary-card-icon.blue{background-color:#eff6ff;color:#3b82f6}.summary-card-icon.green{background-color:#f0fdf4;color:#10b981}.summary-card-icon.yellow{background-color:#fefce8;color:#f59e0b}.summary-card-icon.red{background-color:#fef2f2;color:#ef4444}.summary-card-icon.purple{background-color:#f5f3ff;color:#8b5cf6}.summary-card-value{font-size:clamp(1.275rem,calc(1.5rem * var(--font-scale)),1.725rem);font-weight:700;color:#1e293b;margin-bottom:calc(4px * var(--space-scale))}.summary-card-label{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#64748b}.top-projects-list,.recent-activity-list{display:flex;flex-direction:column}.top-project-item,.recent-activity-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid #f1f5f9}.top-projects-list .top-project-item:last-child,.recent-activity-list .recent-activity-item:last-child{border-bottom:none}.project-link{text-decoration:none;color:#3b82f6;font-weight:500}.project-sub-info,.activity-project{font-size:clamp(.68rem,calc(.8rem * var(--font-scale)),.92rem);color:#64748b}.project-values{display:flex;gap:calc(24px * var(--space-scale));text-align:right;font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem)}.value-contracts{color:#3b82f6;font-weight:500}.value-expenses{color:#f59e0b;font-weight:500}.value-profit{font-weight:700}.value-profit.positive{color:#10b981}.value-profit.negative{color:#ef4444}.activity-description{font-weight:500;font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#1e293b}.activity-details{text-align:right}.activity-amount{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);font-weight:600;color:#f59e0b}.activity-date{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);color:#94a3b8}.form-section{margin-bottom:calc(24px * var(--space-scale));padding:calc(20px * var(--space-scale));background-color:#f8fafc;border-radius:calc(8px * var(--space-scale));border:1px solid #f1f5f9}.form-input.read-only{background-color:#f0f9ff;color:#0c4a6e;font-weight:600;cursor:default}.preview-modal{max-width:calc(800px * var(--space-scale))}.preview-content{padding:calc(24px * var(--space-scale));flex:1;overflow:hidden;display:flex;flex-direction:column}.preview-filename{margin:0 0 16px;padding:calc(8px * var(--space-scale)) calc(12px * var(--space-scale));background-color:#f8fafc;border-radius:calc(6px * var(--space-scale));font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#475569;border:1px solid #f1f5f9}.preview-container{flex:1;display:flex;justify-content:center;align-items:center;min-height:calc(300px * var(--space-scale));background-color:#f1f5f9;border-radius:calc(8px * var(--space-scale));padding:calc(16px * var(--space-scale))}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:calc(8px * var(--space-scale));box-shadow:0 4px 6px #0000001a}.preview-iframe{width:100%;height:calc(500px * var(--space-scale));border:1px solid #e2e8f0;border-radius:calc(8px * var(--space-scale))}.preview-iframe.text{height:calc(400px * var(--space-scale))}.modal-header .form-button,.modal-header .form-button-secondary{padding:calc(8px * var(--space-scale)) calc(16px * var(--space-scale));font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem)}.table-container{overflow-x:auto;border-radius:calc(8px * var(--space-scale));border:1px solid #e2e8f0}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:calc(16px * var(--space-scale)) calc(12px * var(--space-scale));font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);white-space:nowrap}.data-table thead{background-color:#f8fafc;border-bottom:2px solid #e2e8f0}.data-table th{text-align:left;color:#475569;font-size:clamp(.68rem,calc(.8rem * var(--font-scale)),.92rem);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.data-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background-color:#fafbfc}.data-table .text-danger{color:#dc2626;font-weight:500}.data-table .text-success{color:#166534;font-weight:600}.actions-container{display:flex;gap:calc(8px * var(--space-scale));justify-content:center;align-items:center}.action-button-icon{background-color:#f1f5f9;border:1px solid #e2e8f0;border-radius:calc(6px * var(--space-scale));padding:calc(8px * var(--space-scale));cursor:pointer;font-size:clamp(.85rem,calc(1rem * var(--font-scale)),1.15rem);line-height:1;transition:all .2s ease}.action-button-icon:hover{background-color:#e2e8f0;border-color:#cbd5e1}.action-button-icon.danger{background-color:#fef2f2;border-color:#fecaca;color:#ef4444}.action-button-icon.danger:hover{background-color:#fee2e2;border-color:#fca5a5}.form-button.small,.form-button-secondary.small{padding:calc(8px * var(--space-scale)) calc(12px * var(--space-scale));font-size:clamp(.744rem,calc(.875rem * var(--font-scale)),1.006rem)}.form-button-secondary.danger:hover{background-color:#fef2f2;border-color:#fca5a5;color:#b91c1c}.allocation-card{display:grid;grid-template-columns:minmax(200px,1.5fr) 2fr 1fr;align-items:center;padding:calc(16px * var(--space-scale));border-radius:calc(8px * var(--space-scale));gap:calc(16px * var(--space-scale));border:1px solid}.allocation-card.active{background-color:#f0fdf4;border-color:#bbf7d0}.allocation-card.inactive{background-color:#f8fafc;border-color:#e2e8f0}.allocation-employee-info{display:flex;align-items:center;gap:calc(12px * var(--space-scale))}.employee-avatar{width:calc(40px * var(--space-scale));height:calc(40px * var(--space-scale));background-color:#64748b;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:clamp(1.062rem,calc(1.25rem * var(--font-scale)),1.438rem);flex-shrink:0}.employee-name{font-weight:600;color:#1e293b}.allocation-details{display:flex;gap:calc(24px * var(--space-scale));align-items:center;flex-wrap:wrap}.detail-item{text-align:center}.detail-label{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.85rem);color:#64748b;font-weight:600;text-transform:uppercase;display:block;margin-bottom:calc(4px * var(--space-scale))}.detail-value{font-size:clamp(.8rem,calc(.9rem * var(--font-scale)),1rem);color:#1e293b;font-weight:500}.detail-value.cost{font-weight:700;color:#c2410c}.allocation-actions{display:flex;gap:calc(8px * var(--space-scale));justify-content:flex-end}.form-button-secondary.warning{background-color:#fffbeb;border-color:#fde047;color:#a16207}.form-button-secondary.warning:hover{background-color:#fefce8;border-color:#facc15}.status-badge.status-inactive{background-color:#fefce8;color:#a16207;border-color:#fde047}.expense-details-line{font-size:clamp(.722rem,calc(.85rem * var(--font-scale)),.977rem);color:#475569;margin-top:calc(4px * var(--space-scale));display:flex;flex-wrap:wrap;gap:calc(4px * var(--space-scale)) calc(16px * var(--space-scale))}.expense-detail-item strong{color:#1e293b}.project-summary{padding:var(--space-5, 24px) var(--space-6, 28px);display:flex;flex-direction:column;gap:var(--space-5, 20px)}.project-summary .project-header{margin-bottom:0;align-items:center;gap:var(--space-3, 12px);flex-wrap:wrap}.project-summary .project-title{font-size:clamp(1.6rem,calc(1.85rem * var(--font-scale)),2.25rem);margin-bottom:0}.project-summary .project-meta{gap:var(--space-2, 8px);font-size:clamp(.85rem,calc(.95rem * var(--font-scale)),1rem)}.project-summary .project-location{color:#334155}.project-summary .form-button.small{align-self:flex-start}.project-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3, 12px)}@media (min-width: 1280px){.project-summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}@media (max-width: 640px){.project-summary-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}.info-card-purple{background-color:#f5f3ff;border-color:#ddd6fe}.info-card-purple .info-card-title{color:#6d28d9}.info-card-purple .info-card-value{color:#5b21b6}.info-card-orange{background-color:#fff7ed;border-color:#fed7aa}.info-card-orange .info-card-title{color:#c2410c}.info-card-orange .info-card-value{color:#9a3412}.info-card--condensed{padding:var(--space-3, 12px) var(--space-4, 16px);border-radius:var(--radius-md, 10px);display:flex;flex-direction:column;gap:var(--space-2, 8px);min-height:100%}.info-card--condensed .info-card-header{margin-bottom:0;gap:var(--space-2, 8px)}.info-card--condensed .info-card-icon{font-size:var(--font-md, 1rem)}.info-card--condensed .info-card-title{font-size:clamp(.65rem,calc(.75rem * var(--font-scale)),.82rem)}.info-card--condensed .info-card-value{font-size:clamp(1.15rem,calc(1.3rem * var(--font-scale)),1.5rem);margin-bottom:0;line-height:1.2}.info-card--condensed .info-card-subtitle{font-size:clamp(.7rem,calc(.8rem * var(--font-scale)),.9rem);text-transform:none;letter-spacing:normal;color:#475569}:root{--login-primary-blue: #2c3e50;--login-button-blue: #007bff;--login-button-hover-blue: #0056b3;--login-light-gray: #ecf0f1;--login-text-color: #333;--login-border-color: #dcdcdc;--login-shadow-color: rgba(0, 0, 0, .08)}.login-page-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background-color:var(--login-light-gray);background-image:url(/sgo-login-background.png);background-size:cover;background-position:center center;background-repeat:no-repeat;padding:20px;box-sizing:border-box}.login-branding{text-align:center;z-index:2;margin-bottom:30px}.login-main-logo{width:220px;height:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));margin-bottom:10px}.login-tagline{font-size:1.2rem;font-weight:500;color:#2c3e50;text-shadow:0 1px 2px rgba(255,255,255,.6);margin:0;letter-spacing:.5px}.login-card{background-color:#fffffffa;border-radius:16px;box-shadow:0 10px 40px var(--login-shadow-color);padding:40px;width:100%;max-width:420px;text-align:center;z-index:1;border:none}.login-form .form-group{margin-bottom:20px;position:relative}.input-icon-group{display:flex;align-items:center;border:1px solid var(--login-border-color);border-radius:25px;padding:0 20px;background-color:#fff;transition:all .2s ease;height:52px}.input-icon-group:focus-within{border-color:var(--login-button-blue);box-shadow:0 0 0 3px #007bff26}.input-icon{color:#999;margin-right:12px;font-size:1.1em;flex-shrink:0}.login-input{border:none;outline:none;flex-grow:1;padding:0;font-size:1rem;color:var(--login-text-color);background-color:transparent;height:100%;width:100%}.login-input::placeholder{color:#aaa}.password-group{position:relative}.password-toggle-icon{cursor:pointer;color:#999;font-size:1.1em;padding:5px;margin-left:10px;flex-shrink:0}.login-button{background:linear-gradient(to right,#007bff,#0056b3);color:#fff;border:none;border-radius:25px;padding:14px 25px;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%;margin-top:30px;box-shadow:0 4px 15px #007bff40}.login-button:hover{background:linear-gradient(to right,#0056b3,#004085);transform:translateY(-2px);box-shadow:0 6px 20px #007bff59}.login-button:disabled{background:linear-gradient(to right,#ccc,#aaa);cursor:not-allowed;transform:none;box-shadow:none}.density-switcher{display:inline-flex;align-items:center;gap:calc(8px * var(--space-scale));font-size:clamp(.85rem,calc(.95rem * var(--font-scale)),1.05rem);color:#1e293b}.density-switcher__label{font-weight:600}.density-switcher__select{padding:calc(6px * var(--space-scale)) calc(12px * var(--space-scale));border-radius:calc(8px * var(--space-scale));border:1px solid #cbd5f5;font-size:clamp(.85rem,calc(.95rem * var(--font-scale)),1.05rem);background-color:#f8fafc;color:#1e293b}.user-menu-visual-settings .density-switcher{width:100%;flex-direction:column;align-items:flex-start;gap:calc(6px * var(--space-scale))}.user-menu-visual-settings .density-switcher__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.user-menu-visual-settings .density-switcher__select{width:100%}._wrapper_gqf5y_1{display:flex;flex-direction:column;gap:var(--space-6);font-family:var(--font-family-base);max-width:44rem;margin-left:auto;margin-right:auto}._header_gqf5y_11{display:flex;flex-direction:column;gap:var(--space-2)}._title_gqf5y_17{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin:0}._subtitle_gqf5y_23{margin:0;font-size:var(--font-size-lg);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}._progressWrapper_gqf5y_30{margin:var(--space-4) 0}._section_gqf5y_34{display:flex;flex-direction:column;gap:var(--space-5)}._sectionTitle_gqf5y_40{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}._fieldStack_gqf5y_46,._teamList_gqf5y_52{display:flex;flex-direction:column;gap:var(--space-4)}._teamMember_gqf5y_58{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}._teamRole_gqf5y_66{flex:1}._teamName_gqf5y_70{flex:2}._iconButton_gqf5y_74{min-width:auto;padding:var(--space-2) var(--space-3)}._timeField_gqf5y_79{flex:1;min-width:160px}._addButton_gqf5y_84{margin-top:var(--space-5)}._scheduleSection_gqf5y_88{display:flex;flex-direction:column;gap:var(--space-4)}._scheduleFieldset_gqf5y_94{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}._scheduleLegend_gqf5y_103{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}._scheduleRow_gqf5y_111{display:flex;gap:var(--space-4);flex-wrap:wrap}._timeInput_gqf5y_117{color-scheme:dark}._equipmentSection_gqf5y_121{border-top:1px solid var(--color-border);padding-top:var(--space-5);margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-4)}._equipmentList_gqf5y_130{display:flex;flex-direction:column;gap:var(--space-4)}._equipmentRow_gqf5y_136{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,3fr) auto;gap:var(--space-3);align-items:start}._equipmentType_gqf5y_143{display:flex;flex-direction:column;gap:var(--space-3)}._equipmentRemove_gqf5y_149{align-self:flex-start}._photoSection_gqf5y_153{display:flex;flex-direction:column;gap:var(--space-4)}._photoGrid_gqf5y_159{display:flex;flex-wrap:wrap;gap:var(--space-3)}._photoItem_gqf5y_165{position:relative}._photoButton_gqf5y_169{background:none;border:none;padding:0;cursor:pointer}._photoImage_gqf5y_176{width:100px;height:100px;object-fit:cover;border-radius:var(--radius-md);display:block}._photoPlaceholder_gqf5y_184{width:100px;height:100px;border-radius:var(--radius-md);background:var(--color-surface-alt);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm)}._photoRemove_gqf5y_196{position:absolute;top:6px;right:6px;background:#0f172abf;color:#fff;border:none;border-radius:var(--radius-pill);width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer}._actions_gqf5y_212{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--color-border);padding-top:var(--space-5);margin-top:var(--space-6)}@media (max-width: 768px){._teamMember_gqf5y_58{flex-direction:column;align-items:stretch}._scheduleRow_gqf5y_111{flex-direction:column}._equipmentRow_gqf5y_136{grid-template-columns:1fr}._actions_gqf5y_212{flex-direction:column;align-items:stretch;gap:var(--space-3)}}:root{--space-1: calc(4px * var(--space-scale));--space-2: calc(8px * var(--space-scale));--space-3: calc(12px * var(--space-scale));--space-4: calc(16px * var(--space-scale));--space-5: calc(24px * var(--space-scale));--space-6: calc(32px * var(--space-scale));--space-7: calc(40px * var(--space-scale));--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-300: #a5b4fc;--color-primary-400: #818cf8;--color-primary-500: #6366f1;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-primary-800: #3730a3;--color-primary-900: #312e81;--color-neutral-50: #f8fafc;--color-neutral-100: #f1f5f9;--color-neutral-200: #e2e8f0;--color-neutral-300: #cbd5e1;--color-neutral-400: #94a3b8;--color-neutral-500: #64748b;--color-neutral-600: #475569;--color-neutral-700: #334155;--color-neutral-800: #1e293b;--color-neutral-900: #0f172a;--color-success-50: #ecfdf5;--color-success-200: #bbf7d0;--color-success-500: #10b981;--color-success-600: #047857;--color-info-50: #eff6ff;--color-info-200: #bfdbfe;--color-info-500: #1d4ed8;--color-danger-50: #fef2f2;--color-danger-200: #fecaca;--color-danger-300: #fca5a5;--color-danger-500: #ef4444;--color-surface: #ffffff;--color-overlay: rgba(15, 23, 42, .08);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .12);--shadow-card: 0 18px 45px -25px rgba(15, 23, 42, .4), 0 10px 30px -20px rgba(79, 70, 229, .25);--shadow-card-hover: 0 26px 55px -24px rgba(79, 70, 229, .4);--shadow-ring: 0 0 0 4px rgba(99, 102, 241, .2);--radius-md: calc(12px * var(--space-scale));--radius-lg: calc(16px * var(--space-scale));--radius-xl: calc(20px * var(--space-scale))}.ds-card{background-color:var(--color-surface, #ffffff);border-radius:var(--radius-lg);border:1px solid var(--color-neutral-200, #e2e8f0);box-shadow:var(--shadow-card);padding:var(--space-5);transition:transform .2s ease,box-shadow .2s ease}.ds-card--interactive:hover,.ds-card--interactive:focus-within{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}.ds-grid-stack{display:grid;gap:var(--space-5)}@media (min-width: 768px){.ds-grid-stack{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}.ds-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:calc(12px * var(--space-scale)) calc(20px * var(--space-scale));border-radius:var(--radius-md);font-weight:600;font-size:clamp(.875rem,calc(.95rem * var(--font-scale)),1.05rem);border:1px solid transparent;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease,color .2s ease}.ds-button:focus-visible{outline:none;box-shadow:var(--shadow-ring)}.ds-button--primary{background:linear-gradient(135deg,var(--color-primary-500, #6366f1),var(--color-primary-700, #4338ca));color:#fff;box-shadow:var(--shadow-sm)}.ds-button--primary:hover{background:linear-gradient(135deg,var(--color-primary-600, #4f46e5),var(--color-primary-800, #3730a3))}.ds-button--secondary{background-color:transparent;color:var(--color-neutral-600, #475569);border-color:var(--color-neutral-300, #cbd5e1)}.ds-button--secondary:hover{background-color:var(--color-neutral-50, #f8fafc);border-color:var(--color-neutral-400, #94a3b8);color:var(--color-neutral-700, #334155)}.employees-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-5)}.employees-page-title{font-size:clamp(1.8rem,calc(2.2rem * var(--font-scale)),2.6rem);color:var(--color-neutral-900, #0f172a);margin:0;display:flex;align-items:center;gap:var(--space-3)}.employees-form-card{padding:var(--space-5)}.employees-section-title{margin-top:0;margin-bottom:var(--space-4);font-size:clamp(1.2rem,calc(1.4rem * var(--font-scale)),1.6rem);color:var(--color-neutral-800, #1e293b)}.employees-form-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.employees-form-actions{border-top:none;padding-top:var(--space-3);margin-top:var(--space-3);justify-content:flex-start;gap:var(--space-3)}.employees-card-list{margin-top:var(--space-5)}.employee-card{padding:0;overflow:hidden}.employee-card__header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,var(--color-neutral-50, #f8fafc),var(--color-neutral-100, #f1f5f9));border-bottom:1px solid var(--color-neutral-200, #e2e8f0)}.employee-card__identity{display:flex;align-items:center;gap:var(--space-4);flex:1;min-width:0}.employee-card__avatar{width:calc(56px * var(--space-scale));height:calc(56px * var(--space-scale));border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--color-primary-500, #6366f1),var(--color-primary-700, #4338ca));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:clamp(1rem,calc(1.2rem * var(--font-scale)),1.4rem);box-shadow:0 16px 32px -20px #4f46e599}.employee-card__initials{letter-spacing:.04em}.employee-card__info{display:flex;flex-direction:column;gap:4px;min-width:0}.employee-card__name{margin:0;font-size:clamp(1.1rem,calc(1.3rem * var(--font-scale)),1.6rem);font-weight:600;color:var(--color-neutral-900, #0f172a)}.employee-card__position{margin:0;font-size:clamp(.85rem,calc(.95rem * var(--font-scale)),1.1rem);color:var(--color-primary-500, #6366f1);font-weight:500}.employee-card__actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.employee-card__action{width:calc(36px * var(--space-scale));height:calc(36px * var(--space-scale));border-radius:calc(12px * var(--space-scale));display:inline-flex;align-items:center;justify-content:center;background-color:var(--color-surface, #ffffff);border:1px solid var(--color-neutral-200, #e2e8f0);color:var(--color-neutral-500, #64748b);text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,color .2s ease,background-color .2s ease}.employee-card__action:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover);border-color:var(--color-primary-200, #c7d2fe);color:var(--color-primary-600, #4f46e5)}.employee-card__action--danger:hover{background-color:var(--color-danger-50, #fef2f2);border-color:var(--color-danger-300, #fca5a5);color:var(--color-danger-500, #ef4444)}.employee-card__body{padding:var(--space-5)}.employee-card__info-grid{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.employee-card__info-item{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background-color:var(--color-neutral-50, #f8fafc);border:1px solid var(--color-neutral-200, #e2e8f0);min-height:calc(88px * var(--space-scale));transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.employee-card__info-item:hover{border-color:var(--color-primary-200, #c7d2fe);box-shadow:var(--shadow-sm);background-color:var(--color-neutral-100, #f1f5f9)}.employee-card__info-item--status{background:linear-gradient(135deg,var(--color-success-50, #ecfdf5),var(--color-neutral-50, #f8fafc));border-color:var(--color-success-200, #bbf7d0)}.employee-card__info-item--salary{background:linear-gradient(135deg,var(--color-primary-50, #eef2ff),var(--color-primary-100, #e0e7ff));border-color:var(--color-primary-200, #c7d2fe)}.employee-card__info-item--date{background:linear-gradient(135deg,var(--color-info-50, #eff6ff),var(--color-neutral-50, #f8fafc));border-color:var(--color-info-200, #bfdbfe)}.employee-card__info-label{font-size:clamp(.68rem,calc(.78rem * var(--font-scale)),.88rem);font-weight:700;letter-spacing:.08em;color:var(--color-neutral-500, #64748b);display:inline-flex;align-items:center;gap:var(--space-2);text-transform:uppercase}.employee-card__info-label svg{width:16px;height:16px;opacity:.7}.employee-card__info-value{font-size:clamp(.95rem,calc(1.05rem * var(--font-scale)),1.25rem);font-weight:600;color:var(--color-neutral-900, #0f172a)}.employee-card__info-value--salary{color:var(--color-success-600, #047857)}@media (max-width: 768px){.employees-page-header{flex-direction:column;align-items:stretch}.employee-card__header{flex-direction:column;align-items:stretch;gap:var(--space-3)}.employee-card__actions{justify-content:flex-end}}
