:root{--primary-blue: #1e40af;--primary-blue-light: #3b82f6;--primary-blue-dark: #1e3a8a;--accent-green: #16a34a;--accent-green-light: #22c55e;--accent-red: #dc2626;--accent-red-light: #ef4444;--accent-orange: #ea580c;--accent-yellow: #eab308;--white: #ffffff;--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;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--border-color: #e2e8f0;--border-radius: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--font-family: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--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;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*: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-family);font-size:var(--font-size-base);line-height:1.6;color:var(--gray-800);background:var(--bg-primary);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--gray-900)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}p{margin-bottom:var(--spacing-4)}a{color:var(--primary-blue);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-blue-dark)}.app-container{max-width:1200px;margin:0 auto;padding:var(--spacing-4);width:100%}.page-header{margin-bottom:var(--spacing-6)}.page-title{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary-blue-dark);margin-bottom:var(--spacing-2)}.page-subtitle{color:var(--gray-500);font-size:var(--font-size-sm)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-5);margin-bottom:var(--spacing-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--border-color)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--gray-800)}.card-subtitle{font-size:var(--font-size-sm);color:var(--gray-500);margin-top:var(--spacing-1)}.card-body{padding:var(--spacing-2) 0}.card-footer{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-3)}.item-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-5);margin-bottom:var(--spacing-4);position:relative}.item-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4)}.item-card-title{font-size:var(--font-size-base);font-weight:600;color:var(--gray-700)}.item-delete-btn{background:none;border:none;color:var(--accent-red);cursor:pointer;padding:var(--spacing-2);border-radius:var(--border-radius);transition:background var(--transition-fast)}.item-delete-btn:hover{background:#dc26261a}.form-group{margin-bottom:var(--spacing-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--accent-red);margin-bottom:var(--spacing-2);text-transform:capitalize}.form-label-alt{color:var(--primary-blue)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);font-family:var(--font-family);font-size:var(--font-size-base);color:var(--gray-800);background:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-blue-light);box-shadow:0 0 0 3px #3b82f61a}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.form-input::placeholder,.form-textarea::placeholder{color:var(--gray-400)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--gray-100);cursor:not-allowed}.form-textarea{min-height:100px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr;gap:var(--spacing-4)}@media (min-width: 640px){.form-row-2{grid-template-columns:repeat(2,1fr)}.form-row-3{grid-template-columns:repeat(3,1fr)}.form-row-4{grid-template-columns:repeat(4,1fr)}}.form-hint{font-size:var(--font-size-xs);color:var(--gray-500);margin-top:var(--spacing-1)}.form-error{font-size:var(--font-size-xs);color:var(--accent-red);margin-top:var(--spacing-1)}.calculated-total{font-size:var(--font-size-xl);font-weight:700;color:var(--accent-green)}.calculated-label{font-size:var(--font-size-sm);font-weight:500;color:var(--gray-500);margin-bottom:var(--spacing-2);display:block}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-5);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--border-radius);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-blue);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--primary-blue-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-success{background:var(--accent-green);color:var(--white)}.btn-success:hover:not(:disabled){background:var(--accent-green-light)}.btn-danger{background:var(--accent-red);color:var(--white)}.btn-danger:hover:not(:disabled){background:var(--accent-red-light)}.btn-outline{background:transparent;border:1px solid var(--primary-blue);color:var(--primary-blue)}.btn-outline:hover:not(:disabled){background:var(--primary-blue);color:var(--white)}.btn-sm{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-4) var(--spacing-6);font-size:var(--font-size-base)}.btn-block{width:100%}.btn-icon{padding:var(--spacing-2);background:none;border:none;color:var(--gray-500);cursor:pointer;border-radius:var(--border-radius)}.btn-icon:hover{background:var(--gray-100);color:var(--gray-700)}.section{margin-bottom:var(--spacing-8)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:2px solid var(--primary-blue)}.section-title{font-size:var(--font-size-xl);font-weight:700;color:var(--primary-blue-dark)}.section-actions{display:flex;gap:var(--spacing-2)}.navbar{background:var(--white);border-bottom:1px solid var(--border-color);padding:var(--spacing-3) var(--spacing-4);position:sticky;top:0;z-index:100}.navbar-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.navbar-brand{display:flex;align-items:center;gap:var(--spacing-3)}.navbar-logo{height:40px;width:auto}.navbar-title{font-size:var(--font-size-lg);font-weight:700;color:var(--primary-blue-dark)}.navbar-nav{display:flex;align-items:center;gap:var(--spacing-4)}.navbar-link{color:var(--gray-600);font-weight:500;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--border-radius);transition:all var(--transition-fast)}.navbar-link:hover,.navbar-link.active{color:var(--primary-blue);background:#3b82f61a}.navbar-user{display:flex;align-items:center;gap:var(--spacing-3)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm)}.admin-layout{display:flex;min-height:calc(100vh - 65px)}.sidebar{width:250px;background:var(--white);border-right:1px solid var(--border-color);padding:var(--spacing-4);display:none}@media (min-width: 768px){.sidebar{display:block}}.sidebar-nav{list-style:none}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);color:var(--gray-600);border-radius:var(--border-radius);margin-bottom:var(--spacing-1);transition:all var(--transition-fast)}.sidebar-link:hover,.sidebar-link.active{background:var(--gray-100);color:var(--primary-blue)}.sidebar-link-icon{width:20px;height:20px}.main-content{flex:1;padding:var(--spacing-6);overflow-x:hidden}.table-container{overflow-x:auto;background:var(--white);border-radius:var(--border-radius-lg);border:1px solid var(--border-color)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--border-color)}.table th{background:var(--gray-50);font-weight:600;font-size:var(--font-size-sm);color:var(--gray-600);text-transform:uppercase;letter-spacing:.05em}.table td{font-size:var(--font-size-sm)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs);font-weight:500;border-radius:9999px}.badge-draft{background:var(--gray-100);color:var(--gray-600)}.badge-active{background:#16a34a1a;color:var(--accent-green)}.badge-completed{background:#3b82f61a;color:var(--primary-blue)}.save-status{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--gray-500)}.save-status-dot{width:8px;height:8px;border-radius:50%}.save-status-saved .save-status-dot{background:var(--accent-green)}.save-status-saving .save-status-dot{background:var(--accent-yellow);animation:pulse 1s infinite}.save-status-error .save-status-dot{background:var(--accent-red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-blue-dark) 0%,var(--primary-blue) 100%);padding:var(--spacing-4)}.auth-card{background:var(--white);border-radius:var(--border-radius-xl);padding:var(--spacing-8);width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:var(--spacing-6)}.auth-logo img{height:60px;width:auto}.auth-title{text-align:center;margin-bottom:var(--spacing-6)}.auth-title h1{font-size:var(--font-size-2xl);color:var(--gray-900);margin-bottom:var(--spacing-2)}.auth-title p{color:var(--gray-500);font-size:var(--font-size-sm);margin-bottom:0}.auth-form{margin-bottom:var(--spacing-4)}.auth-divider{text-align:center;color:var(--gray-400);font-size:var(--font-size-sm);margin:var(--spacing-4) 0;position:relative}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border-color)}.auth-divider:before{left:0}.auth-divider:after{right:0}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.dashboard-card{background:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-5);transition:all var(--transition-base);cursor:pointer}.dashboard-card:hover{border-color:var(--primary-blue-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-card-icon{width:48px;height:48px;background:#3b82f61a;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-4);color:var(--primary-blue)}.dashboard-card-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-2)}.dashboard-card-description{font-size:var(--font-size-sm);color:var(--gray-500);margin-bottom:0}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--spacing-8)}.spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--primary-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:1000}.empty-state{text-align:center;padding:var(--spacing-10)}.empty-state-icon{width:80px;height:80px;margin:0 auto var(--spacing-4);color:var(--gray-300)}.empty-state-title{font-size:var(--font-size-lg);color:var(--gray-600);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--gray-500);margin-bottom:var(--spacing-4)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:1000;animation:fadeIn var(--transition-fast)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--white);border-radius:var(--border-radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-base)}.modal-content{background:var(--white);border-radius:var(--border-radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp var(--transition-base);box-shadow:var(--shadow-lg)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:var(--spacing-5);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:var(--font-size-lg);font-weight:600}.modal-close{background:none;border:none;font-size:var(--font-size-xl);color:var(--gray-400);cursor:pointer;padding:var(--spacing-2)}.modal-close:hover{color:var(--gray-600)}.modal-body{padding:var(--spacing-5)}.modal-footer{padding:var(--spacing-4) var(--spacing-5);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:var(--spacing-3)}.alert{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--border-radius);margin-bottom:var(--spacing-4);font-size:var(--font-size-sm)}.alert-success{background:#16a34a1a;color:var(--accent-green);border:1px solid rgba(22,163,74,.2)}.alert-error{background:#dc26261a;color:var(--accent-red);border:1px solid rgba(220,38,38,.2)}.alert-warning{background:#eab3081a;color:var(--accent-orange);border:1px solid rgba(234,179,8,.2)}.alert-info{background:#3b82f61a;color:var(--primary-blue);border:1px solid rgba(59,130,246,.2)}.cost-sheet-header{background:var(--primary-blue-dark);color:var(--white);padding:var(--spacing-6);margin:calc(-1 * var(--spacing-6));margin-bottom:var(--spacing-6);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.cost-sheet-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-2)}.cost-sheet-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-4);font-size:var(--font-size-sm);opacity:.9}.cost-sheet-summary{background:var(--gray-50);border:2px solid var(--primary-blue);border-radius:var(--border-radius-lg);padding:var(--spacing-5);margin-top:var(--spacing-6)}.summary-row{display:flex;justify-content:space-between;padding:var(--spacing-2) 0;border-bottom:1px solid var(--border-color)}.summary-row:last-child{border-bottom:none;font-weight:700;font-size:var(--font-size-lg)}.summary-label{color:var(--gray-600)}.summary-value{font-weight:600}.summary-total{color:var(--accent-green);font-size:var(--font-size-xl)}.grand-total-row{background:var(--accent-green);color:var(--white);padding:var(--spacing-4);border-radius:var(--border-radius);display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-lg);font-weight:700;margin-top:var(--spacing-4)}.field-builder{background:var(--gray-50);border-radius:var(--border-radius-lg);padding:var(--spacing-4)}.field-item{background:var(--white);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:var(--spacing-3);margin-bottom:var(--spacing-2);display:flex;justify-content:space-between;align-items:center}.field-item-info{display:flex;align-items:center;gap:var(--spacing-3)}.field-item-drag{color:var(--gray-400);cursor:grab}.field-item-label{font-weight:500}.field-item-type{font-size:var(--font-size-xs);color:var(--gray-500);background:var(--gray-100);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius)}.field-item-actions{display:flex;gap:var(--spacing-2)}@media (max-width: 640px){.hide-mobile{display:none!important}.app-container{padding:var(--spacing-3)}.card{padding:var(--spacing-4)}.auth-card{padding:var(--spacing-5)}}@media (min-width: 641px){.hide-desktop{display:none!important}}@media print{.navbar,.sidebar,.btn,.no-print{display:none!important}.main-content{padding:0}.card{box-shadow:none;border:1px solid #ddd;break-inside:avoid}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--primary-blue);outline-offset:2px}.fade-enter{opacity:0}.fade-enter-active{opacity:1;transition:opacity var(--transition-base)}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity var(--transition-base)}.slide-enter{transform:translate(100%)}.slide-enter-active{transform:translate(0);transition:transform var(--transition-base)}.excel-preview{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}.excel-preview table{width:auto;min-width:100%;border-collapse:collapse;border-spacing:0;font-size:14px;margin:0;white-space:nowrap}.excel-preview table td,.excel-preview table th{border:1px solid #d1d5db;padding:8px 12px;text-align:left;vertical-align:top;white-space:nowrap;min-width:fit-content}.excel-preview table th{background-color:#f3f4f6;font-weight:600;color:#374151}.excel-preview table tr:nth-child(2n){background-color:#f9fafb}.excel-preview table td[colspan],.excel-preview table th[colspan]{text-align:center}.fab{position:fixed;bottom:var(--spacing-8);right:var(--spacing-8);width:56px;height:56px;border-radius:50%;background:var(--primary-blue);color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);border:none;cursor:pointer;z-index:100;transition:all var(--transition-base);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.fab:hover{transform:scale(1.1) rotate(90deg);background:var(--primary-blue-dark);box-shadow:var(--shadow-xl)}.fab svg{width:24px;height:24px}@media (max-width: 640px){.fab{bottom:var(--spacing-4);right:var(--spacing-4);width:48px;height:48px}}
