.repeatable-field{margin-bottom:1rem}.repeatable-field.disabled{opacity:.6;pointer-events:none}.repeatable-field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:1rem}.repeatable-field-header .field-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700, #374151);margin:0}.repeatable-field-actions{display:flex;gap:.5rem;align-items:center}.btn-add-item{padding:.5rem 1.125rem;background:linear-gradient(135deg,#4f46e5,#6366f1);color:#fff;border:none;border-radius:9999px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .25s ease;white-space:nowrap;box-shadow:0 3px 10px #4f46e559}.btn-add-item:hover{background:linear-gradient(135deg,#4338ca,#4f46e5);transform:translateY(-2px);box-shadow:0 6px 18px #4f46e573}.btn-add-item:active{transform:translateY(0)}.repeatable-field-empty{color:var(--color-gray-400, #94a3b8);font-size:.9rem;margin:0;padding:2.5rem;text-align:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius-xl, .75rem);border:2px dashed var(--color-gray-200, #e2e8f0)}.repeatable-items{display:flex;flex-direction:column;gap:.75rem}.repeatable-item{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:var(--radius-lg, .5rem);overflow:hidden;transition:all .25s ease;border:1px solid var(--color-gray-200, #e2e8f0);box-shadow:0 1px 3px #0000000d}.repeatable-item:hover{background:linear-gradient(180deg,#fff,#f5f3ff);border-color:var(--color-primary-light, #6366f1);box-shadow:0 4px 12px #4f46e51f}.repeatable-item.expanded{border-color:var(--color-primary, #4f46e5);box-shadow:0 0 0 4px #4f46e51f,0 4px 16px #4f46e526}.repeatable-item-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background-color:#fff;gap:.5rem}.btn-toggle-item{flex:1;text-align:left;padding:.25rem;background:none;border:none;cursor:pointer;font-size:.875rem;display:flex;align-items:center;gap:.5rem;color:var(--color-gray-700, #374151);transition:color .15s;border-radius:var(--radius-sm, .25rem)}.btn-toggle-item:hover{color:var(--color-gray-900, #111827)}.toggle-icon{display:inline-flex;width:1rem;justify-content:center;font-size:.625rem;color:var(--color-gray-400, #9ca3af)}.item-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-remove-item{padding:.3rem .625rem;background-color:transparent;color:var(--color-gray-400, #94a3b8);border:2px solid var(--color-gray-200, #e2e8f0);border-radius:var(--radius-md, .375rem);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.btn-remove-item:hover{background:linear-gradient(135deg,#dc2626,#ef4444);border-color:transparent;color:#fff;box-shadow:0 3px 10px #dc262659;transform:translateY(-1px)}.repeatable-item-content{padding:1rem;background-color:var(--color-gray-50, #f9fafb);border-top:1px solid var(--color-gray-200, #e5e7eb)}.repeatable-item-field{margin-bottom:1rem}.repeatable-item-field:last-child{margin-bottom:0}.repeatable-item-field .field{margin:0;display:flex;flex-direction:column;gap:.375rem}.repeatable-item-field .field-label{display:block;font-weight:500;font-size:.875rem;color:var(--color-gray-700, #374151)}.repeatable-item-field .field-input,.repeatable-item-field .field-textarea,.repeatable-item-field .field-select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-gray-300, #d1d5db);border-radius:var(--radius-md, .375rem);font-size:.875rem;font-family:inherit;transition:all .15s}.repeatable-item-field .field-input:focus,.repeatable-item-field .field-textarea:focus,.repeatable-item-field .field-select:focus{outline:none;border-color:var(--color-primary, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.repeatable-item-field .field-radio-group,.repeatable-items-simple{display:flex;flex-direction:column;gap:.5rem}.repeatable-item-simple{display:flex;align-items:flex-end;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-md, .375rem);transition:border-color .15s}.repeatable-item-simple:hover{border-color:var(--color-gray-300, #d1d5db)}.repeatable-item-simple-fields{display:flex;flex:1;gap:1rem;align-items:flex-end}.repeatable-item-simple-field{flex:1;min-width:0}.repeatable-item-simple-field .field{margin:0}.repeatable-item-simple-field .field-label{font-size:.75rem;color:var(--color-gray-500, #6b7280);margin-bottom:.25rem}.repeatable-item-simple-field .field-input{padding:.375rem .5rem;font-size:.875rem}.btn-remove-simple{flex-shrink:0;width:1.75rem;height:1.75rem;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-gray-400, #9ca3af);border:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-sm, .25rem);font-size:1rem;cursor:pointer;transition:all .15s}.btn-remove-simple:hover{background:var(--color-error, #dc2626);color:#fff}.repeatable-items-flat{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;background:transparent;border-radius:var(--radius-lg, .5rem);overflow:visible}.repeatable-item-row{display:flex;flex-direction:column;gap:.75rem;padding:1.125rem;background:linear-gradient(180deg,#fff,#fafbfc);border:2px solid var(--color-gray-200, #e2e8f0);border-radius:var(--radius-lg, .5rem);transition:all .25s ease;box-shadow:0 1px 3px #0000000a}.repeatable-item-row:hover{background:linear-gradient(180deg,#fff,#f5f3ff);border-color:var(--color-primary, #4f46e5);box-shadow:0 6px 20px #4f46e526,0 0 0 3px #4f46e514;transform:translateY(-2px)}.repeatable-item-row:last-child{border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.repeatable-item-label{min-width:auto;max-width:none;flex-shrink:0}.repeatable-item-label-text{font-size:.875rem;font-weight:600;color:var(--color-gray-900, #111827);word-break:break-word}.repeatable-item-fields{display:flex;flex:1;gap:.75rem;align-items:flex-start;flex-direction:column;width:100%}.repeatable-item-inline-field{display:flex;align-items:stretch;width:100%}.repeatable-item-inline-field .field{margin:0;width:100%}.repeatable-item-inline-field .field.field-compact,.repeatable-item-inline-field .field.field-inline{display:flex;flex-direction:column;align-items:stretch;gap:.375rem}.field-label-inline{font-size:.75rem;font-weight:500;color:var(--color-gray-500, #6b7280);white-space:nowrap}.repeatable-item-inline-field .pass-fail-options.pass-fail-options-compact{gap:.375rem}.repeatable-item-inline-field .pass-fail-options-compact .pass-fail-option{padding:.375rem .75rem;font-size:.75rem}.btn-remove-row{flex-shrink:0;width:2rem;height:2rem;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-gray-300, #d1d5db);border:none;border-radius:9999px;font-size:1.5rem;cursor:pointer;transition:all .2s;align-self:flex-start;margin-top:-.5rem}.btn-remove-row:hover{background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;box-shadow:0 4px 12px #dc262659;transform:translateY(-50%) scale(1.1)}.repeatable-item-field .radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.repeatable-item-field .radio-label input[type=radio]{cursor:pointer}.repeatable-item-field .checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.repeatable-item-field .checkbox-label input[type=checkbox]{cursor:pointer}.image-upload-wrapper{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.image-preview-container{position:relative;display:inline-block;border-radius:.375rem;overflow:hidden}.image-preview{max-width:200px;max-height:200px;display:block;border-radius:.375rem}.btn-upload-image,.btn-remove-image{padding:.5rem 1rem;background-color:var(--color-primary, #3b82f6);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-upload-image:hover:not(:disabled),.btn-remove-image:hover:not(:disabled){background-color:var(--color-primary-dark, #2563eb)}.btn-upload-image:active:not(:disabled),.btn-remove-image:active:not(:disabled){background-color:var(--color-primary-darker, #1d4ed8)}.btn-upload-image:disabled,.btn-remove-image:disabled{opacity:.5;cursor:not-allowed}.btn-remove-image{position:absolute;top:.5rem;right:.5rem;background-color:#ef4444e6;padding:.25rem .5rem;font-size:1rem}.btn-remove-image:hover:not(:disabled){background-color:#dc2626e6}.image-file-input{display:none}.repeatable-item-field .btn-upload-image,.repeatable-item-field .btn-remove-image{padding:.5rem 1rem;background-color:var(--color-primary, #3b82f6);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s}.repeatable-item-field .btn-upload-image:hover:not(:disabled),.repeatable-item-field .btn-remove-image:hover:not(:disabled){background-color:var(--color-primary-dark, #2563eb)}.repeatable-item-field .btn-upload-image:active:not(:disabled),.repeatable-item-field .btn-remove-image:active:not(:disabled){background-color:var(--color-primary-darker, #1d4ed8)}.repeatable-item-field .btn-upload-image:disabled,.repeatable-item-field .btn-remove-image:disabled{opacity:.5;cursor:not-allowed}.repeatable-item-field .image-upload-wrapper{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;width:100%}.repeatable-item-field .image-preview-container{position:relative;display:inline-block;border-radius:.375rem;overflow:hidden}.repeatable-item-field .image-preview{max-width:200px;max-height:200px;display:block;border-radius:.375rem}.repeatable-image-preview{width:150px;height:150px;border-radius:.375rem;overflow:hidden;border:2px solid var(--color-border, #e5e7eb);cursor:pointer;transition:all .2s ease;margin-bottom:.5rem}.repeatable-image-preview:hover{border-color:var(--color-primary, #3b82f6);box-shadow:0 4px 12px #00000026;transform:scale(1.02)}.repeatable-image-thumb{width:100%;height:100%;object-fit:cover}.image-viewer-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:.5rem;overflow:hidden}.repeatable-image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;margin-top:1rem;padding:.5rem}.image-gallery-item{display:flex;flex-direction:column;gap:.5rem}.image-gallery-item-fields{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem}.image-gallery-item-fields .image-gallery-text-field{flex:1;min-width:120px}.image-gallery-thumbnail{width:100%;aspect-ratio:1;border-radius:.5rem;overflow:hidden;border:2px solid var(--color-border, #e5e7eb);cursor:pointer;transition:all .2s ease;position:relative;background:var(--color-gray-100, #f3f4f6)}.image-gallery-thumbnail:hover{border-color:var(--color-primary, #3b82f6);box-shadow:0 4px 12px #00000026;transform:scale(1.02)}.image-gallery-thumbnail img{width:100%;height:100%;object-fit:cover}.image-gallery-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.image-gallery-thumbnail:hover .image-gallery-overlay{background:#0000004d}.image-gallery-label{color:#fff;font-size:.75rem;font-weight:500;opacity:0;transition:opacity .2s ease}.image-gallery-thumbnail:hover .image-gallery-label{opacity:1}.image-gallery-placeholder{width:100%;aspect-ratio:1;border-radius:.5rem;border:2px dashed var(--color-border, #e5e7eb);display:flex;align-items:center;justify-content:center;background:var(--color-gray-50, #f9fafb);color:var(--color-text-secondary, #6b7280);font-size:.875rem}.image-gallery-text-field{width:100%;padding:.5rem;border:1px solid var(--color-border, #e5e7eb);border-radius:.375rem;font-size:.875rem;transition:border-color .2s ease}.image-gallery-text-field:focus{outline:none;border-color:var(--color-primary, #3b82f6)}.image-gallery-text-field:disabled{background:var(--color-gray-50, #f9fafb);opacity:.6}.image-gallery-controls{display:flex;gap:.25rem;flex-wrap:wrap}.image-gallery-btn-upload,.image-gallery-btn-download,.image-gallery-btn-remove,.image-gallery-btn-delete{flex:1;padding:.5rem;border:1px solid var(--color-border, #e5e7eb);border-radius:.375rem;font-size:.75rem;cursor:pointer;transition:all .2s ease;background:#fff;color:var(--color-text, #1f2937);min-width:60px}.image-gallery-btn-upload:hover:not(:disabled),.image-gallery-btn-download:hover:not(:disabled),.image-gallery-btn-remove:hover:not(:disabled){background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6)}.image-gallery-btn-delete:hover:not(:disabled){background:var(--color-error, #ef4444);color:#fff;border-color:var(--color-error, #ef4444)}.image-gallery-btn-upload:disabled,.image-gallery-btn-download:disabled,.image-gallery-btn-remove:disabled,.image-gallery-btn-delete:disabled{opacity:.5;cursor:not-allowed}.btn-download-all{padding:.5rem 1rem;background-color:var(--color-success, #10b981);color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.btn-download-all:hover:not(:disabled){background-color:var(--color-success-dark, #059669)}.btn-download-all:active:not(:disabled){background-color:var(--color-success-darker, #047857)}.btn-download-all:disabled{opacity:.6;cursor:not-allowed}.btn-field-settings{padding:.4rem .6rem;background:var(--color-gray-100, #f3f4f6);border:1px solid var(--color-gray-300, #d1d5db);border-radius:.375rem;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-field-settings:hover{background:var(--color-gray-200, #e5e7eb);border-color:var(--color-gray-400, #9ca3af)}.btn-field-settings:active{transform:scale(.95)}.field-settings-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.field-settings-modal{background:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;max-width:500px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.field-settings-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.field-settings-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-gray-900, #111827)}.field-settings-close{background:none;border:none;font-size:1.25rem;color:var(--color-gray-400, #9ca3af);cursor:pointer;padding:.25rem;line-height:1;border-radius:.25rem;transition:all .15s}.field-settings-close:hover{color:var(--color-gray-600, #4b5563);background:var(--color-gray-100, #f3f4f6)}.field-settings-content{padding:1rem 1.25rem;overflow-y:auto;flex:1}.field-settings-description{margin:0 0 1rem;color:var(--color-gray-600, #4b5563);font-size:.875rem}.field-settings-actions{display:flex;gap:.5rem;margin-bottom:1rem}.btn-select-all,.btn-deselect-all{padding:.375rem .75rem;font-size:.75rem;border:1px solid var(--color-gray-300, #d1d5db);border-radius:.375rem;background:#fff;color:var(--color-gray-700, #374151);cursor:pointer;transition:all .15s}.btn-select-all:hover,.btn-deselect-all:hover{background:var(--color-gray-50, #f9fafb);border-color:var(--color-gray-400, #9ca3af)}.field-settings-list{display:flex;flex-direction:column;gap:.5rem}.field-settings-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;background:var(--color-gray-50, #f9fafb);border-radius:.5rem;cursor:pointer;transition:background .15s}.field-settings-item:hover{background:var(--color-gray-100, #f3f4f6)}.field-settings-item input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--color-primary, #2563eb);cursor:pointer}.field-settings-item-label{flex:1;font-size:.875rem;font-weight:500;color:var(--color-gray-800, #1f2937)}.field-settings-item-type{font-size:.75rem;color:var(--color-gray-400, #9ca3af);font-style:italic}.field-settings-footer{padding:1rem 1.25rem;border-top:1px solid var(--color-gray-200, #e5e7eb);display:flex;justify-content:flex-end}.field-settings-footer .btn{padding:.5rem 1.25rem}:root{--color-primary: #4f46e5;--color-primary-dark: #4338ca;--color-primary-light: #6366f1;--color-secondary: #7c3aed;--color-success: #059669;--color-success-light: #10b981;--color-warning: #d97706;--color-warning-light: #f59e0b;--color-error: #dc2626;--color-error-light: #ef4444;--color-info: #0891b2;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .08), 0 1px 2px -1px rgb(0 0 0 / .08);--shadow-md: 0 6px 12px -2px rgb(0 0 0 / .12), 0 3px 6px -3px rgb(0 0 0 / .1);--shadow-lg: 0 12px 24px -4px rgb(0 0 0 / .15), 0 4px 10px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 40px -8px rgb(0 0 0 / .2), 0 8px 16px -8px rgb(0 0 0 / .12);--shadow-colored: 0 4px 14px -2px rgba(79, 70, 229, .3);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--gradient-primary: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);--gradient-secondary: linear-gradient(135deg, #7c3aed 0%, #a78bfa 100%);--gradient-success: linear-gradient(135deg, #059669 0%, #10b981 100%);--gradient-warning: linear-gradient(135deg, #d97706 0%, #f59e0b 100%);--gradient-error: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);--gradient-surface: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--color-gray-900);background:linear-gradient(135deg,#f1f5f9,#e2e8f0);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{background:linear-gradient(180deg,#fff,#fafbfc);border-bottom:1px solid var(--color-gray-200);box-shadow:0 2px 8px #0000000f;padding:0 1.5rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:2rem}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.user-name{font-size:.875rem;font-weight:500;color:var(--color-gray-900)}.user-roles{font-size:.75rem;color:var(--color-gray-500);text-transform:capitalize}.btn-logout{padding:.375rem .875rem;font-size:.8125rem;background:var(--color-gray-100);color:var(--color-gray-700);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.btn-logout:hover{background:var(--color-gray-200)}.layout-header h1{font-size:1.25rem;font-weight:600;margin:0;color:var(--color-gray-900)}.muted{color:var(--color-gray-500);margin:0}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:var(--color-gray-500);margin:0 0 .25rem}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-size:.8125rem;font-weight:600;border:1px solid var(--color-gray-200);color:var(--color-gray-700);background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 1px 2px #0000000d}.pill.soft{background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#4338ca;border-color:#c7d2fe;box-shadow:0 1px 3px #6366f126}.callout{padding:.875rem 1rem;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200);background:linear-gradient(135deg,#f8fafc,#f1f5f9);font-size:.9rem;box-shadow:0 1px 3px #0000000d}.callout.success{border-color:#86efac;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#14532d;box-shadow:0 2px 6px #0596691f}.callout.error{border-color:#fca5a5;background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;box-shadow:0 2px 6px #dc26261f}.action-row{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.form-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.split-layout{display:grid;gap:1.5rem;grid-template-columns:2fr 1fr}@media (max-width: 960px){.split-layout{grid-template-columns:1fr}}.pill-toggle-group{display:flex;gap:.5rem;flex-wrap:wrap}.pill-toggle{border:2px solid var(--color-gray-200);background:#fff;color:var(--color-gray-600);padding:.45rem .9rem;border-radius:999px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000a}.pill-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);background:#f5f3ff;transform:translateY(-1px);box-shadow:0 3px 8px #4f46e526}.pill-toggle.active{background:linear-gradient(135deg,#4f46e5,#6366f1);border-color:transparent;color:#fff;box-shadow:0 4px 12px #4f46e559;transform:translateY(-1px)}.helper-card{border:1px solid var(--color-gray-200);border-radius:var(--radius-xl);padding:1.5rem;background:linear-gradient(145deg,#fff,#f8fafc,#f1f5f9);box-shadow:var(--shadow-md);border-left:4px solid var(--color-primary)}.helper-card h3{margin:0 0 .35rem}.helper-list{display:grid;gap:.75rem;margin-top:.75rem}.required{color:var(--color-error)}.layout-nav{display:flex;gap:1rem}.layout-nav a{color:var(--color-gray-600);text-decoration:none;font-weight:500;padding:.5rem .75rem;border-radius:var(--radius-md);transition:all .15s}.layout-nav a:hover{color:var(--color-primary);background:#f5f3ff}.layout-nav a.active{color:#fff;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);box-shadow:0 2px 8px #4f46e54d}.layout-main{flex:1;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.card{background:linear-gradient(180deg,#fff,#fafbfc);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid rgba(0,0,0,.06);transition:all .25s ease}.card:hover{box-shadow:var(--shadow-lg)}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-gray-100);background:linear-gradient(180deg,#f8fafc,#fff);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.card-body{padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .7rem;font-size:.75rem;font-weight:500;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all .15s;gap:.375rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;box-shadow:0 2px 8px #4f46e54d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);box-shadow:0 4px 14px #4f46e566;transform:translateY(-1px)}.btn-secondary{background:linear-gradient(180deg,#fff,#f8fafc);color:var(--color-gray-700);border:2px solid var(--color-gray-200);box-shadow:0 1px 3px #0000000d}.btn-secondary:hover:not(:disabled){background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-color:var(--color-gray-300);box-shadow:0 2px 6px #00000014}.btn-success{background:linear-gradient(135deg,var(--color-success) 0%,var(--color-success-light) 100%);color:#fff;box-shadow:0 2px 8px #0596694d}.btn-success:hover:not(:disabled){box-shadow:0 4px 14px #05966966;transform:translateY(-1px)}.btn-error{background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-light) 100%);color:#fff;box-shadow:0 2px 8px #dc26264d}.btn-error:hover:not(:disabled){box-shadow:0 4px 14px #dc262666;transform:translateY(-1px)}.field{margin-bottom:1rem;padding:1rem;background:linear-gradient(180deg,#fff,#f8fafc);border-radius:var(--radius-lg);border:1px solid var(--color-gray-100);transition:all .25s ease;box-shadow:0 1px 2px #00000008}.field:hover{background:#fff;border-color:var(--color-gray-200);box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.field:focus-within{border-color:var(--color-primary-light);box-shadow:0 0 0 3px #4f46e51f,0 4px 12px #00000014}.field-label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.field-label .required{color:var(--color-error);margin-left:.125rem}.field-description{font-size:.8125rem;color:var(--color-gray-500);margin:-.25rem 0 .5rem}.field-error{font-size:.8125rem;color:var(--color-error);margin-top:.375rem}.field-input{width:100%;max-width:400px;padding:.625rem .875rem;font-size:.875rem;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);background:#fff;transition:all .2s}.field-input:hover{border-color:var(--color-gray-300)}.field-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4f46e526}.field-input.has-error{border-color:var(--color-error);box-shadow:0 0 0 4px #dc26261a}.field-textarea{min-height:80px;resize:vertical;max-width:100%}.field-select{max-width:300px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M2.5 4.5l3.5 3.5 3.5-3.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.field-input-number{max-width:150px}.field-input-date{max-width:200px}.field-input-group{display:flex;align-items:center;gap:.5rem}.field-unit{color:var(--color-gray-500);font-size:.875rem}.field-helper-text{font-size:.8125rem;color:var(--color-gray-400);margin-top:.375rem}.field-warning{font-size:.8125rem;color:var(--color-warning);margin-top:.375rem}.checklist-items{display:flex;flex-direction:column;gap:.75rem}.checklist-item{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.5rem .75rem;border-radius:var(--radius-md);background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid var(--color-gray-100);transition:all .2s ease}.checklist-item:hover:not(.disabled){background:linear-gradient(180deg,#f5f3ff,#ede9fe);border-color:var(--color-primary-light);box-shadow:0 2px 8px #4f46e51a}.checklist-item.checked{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:var(--color-success)}.checklist-item.disabled{cursor:not-allowed;opacity:.5}.checklist-checkbox{width:20px;height:20px;cursor:inherit;accent-color:var(--color-primary)}.checklist-label{font-size:.9rem;color:var(--color-gray-700);font-weight:500}.pass-fail-options{display:inline-flex;gap:.5rem}.pass-fail-option{padding:.5rem 1.125rem;border:2px solid var(--color-gray-200);background:linear-gradient(180deg,#fff,#f8fafc);border-radius:999px;font-size:.8125rem;font-weight:600;color:var(--color-gray-500);cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000a}.pass-fail-option:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}.pass-fail-option.selected.green{background:linear-gradient(135deg,#059669,#10b981);border-color:transparent;color:#fff;box-shadow:0 4px 12px #05966966;transform:translateY(-2px)}.pass-fail-option.selected.red{background:linear-gradient(135deg,#dc2626,#ef4444);border-color:transparent;color:#fff;box-shadow:0 4px 12px #dc262666;transform:translateY(-2px)}.pass-fail-option.selected.gray{background:linear-gradient(135deg,#475569,#64748b);border-color:transparent;color:#fff;box-shadow:0 4px 12px #47556966;transform:translateY(-2px)}.pass-fail-option:disabled{opacity:.5;cursor:not-allowed}.eval-section{background:linear-gradient(180deg,#fff,#fafbfc);border-radius:var(--radius-xl);padding:1.5rem;margin-bottom:1.25rem;box-shadow:0 4px 12px #0000000f,0 1px 3px #0000000a;border:1px solid rgba(0,0,0,.04);position:relative}.eval-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.eval-section-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid var(--color-gray-100)}.eval-section-header h2{font-size:1.125rem;font-weight:700;margin:0;color:var(--color-gray-900);letter-spacing:-.01em}.eval-section-header p{font-size:.875rem;color:var(--color-gray-500);margin:.5rem 0 0}.eval-section-content{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.eval-section-content>*:last-child .field{margin-bottom:0}.eval-section-content .repeatable-field{grid-column:1 / -1}.eval-section-content .field:has(.field-textarea){grid-column:1 / -1}.eval-section-content>*{min-width:0}.eval-section.depth-1{background:linear-gradient(135deg,#f5f3ff,#ede9fe);margin-left:0;padding-left:1.5rem;border-left:4px solid var(--color-primary);box-shadow:0 2px 8px #4f46e51a}.eval-section.depth-1:before{display:none}.eval-section.depth-2{background:linear-gradient(135deg,#fef3c7,#fde68a 50%);padding:1rem;margin-left:0;border-left:4px solid var(--color-warning);box-shadow:0 2px 8px #d977061a}.eval-section.depth-2:before{display:none}@media (max-width: 900px){.eval-section-content{grid-template-columns:1fr}}@media (min-width: 901px) and (max-width: 1200px){.eval-section-content{grid-template-columns:repeat(2,1fr)}}.eval-section.depth-1{margin-left:1rem;padding-left:1rem;border-left:2px solid var(--color-gray-200)}.eval-section.depth-2{margin-left:1rem;padding-left:1rem;border-left:2px solid var(--color-gray-100)}.status-badge{display:inline-flex;align-items:center;padding:.3rem .75rem;font-size:.75rem;font-weight:600;border-radius:999px;text-transform:capitalize;letter-spacing:.02em;box-shadow:0 1px 3px #0000001a}.status-badge.draft{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fcd34d}.status-badge.submitted{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af;border:1px solid #93c5fd}.status-badge.locked{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;border:1px solid #86efac}.progress-bar{height:10px;background:linear-gradient(180deg,#e2e8f0,#cbd5e1);border-radius:5px;overflow:hidden;box-shadow:inset 0 1px 3px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 50%,var(--color-primary-light) 100%);background-size:200% 100%;animation:progressShimmer 2s linear infinite;transition:width .5s ease;border-radius:5px;box-shadow:0 0 10px #4f46e566}@keyframes progressShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.autosave-indicator{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-gray-500)}.autosave-indicator.saving{color:var(--color-warning)}.autosave-indicator.saved{color:var(--color-success)}.dropzone{border:2px dashed var(--color-gray-300);border-radius:var(--radius-xl);padding:2.5rem;text-align:center;color:var(--color-gray-500);cursor:pointer;transition:all .25s ease;background:linear-gradient(180deg,#fff,#f8fafc)}.dropzone:hover:not(.disabled){border-color:var(--color-primary);background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:0 0 0 4px #4f46e51a,0 8px 20px #4f46e526;transform:translateY(-2px)}.dropzone.dragging{border-color:var(--color-primary);background:linear-gradient(135deg,#e0e7ff,#c7d2fe);box-shadow:0 0 0 4px #4f46e533,0 12px 30px #4f46e540;transform:scale(1.02)}.dropzone.disabled{cursor:not-allowed;opacity:.5}.dropzone-text{margin:0;font-size:.875rem}.dropzone-hint{margin:.25rem 0 0;font-size:.75rem}.hidden-input{display:none}.upload-filename{font-size:.8125rem;flex:0 0 auto;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-error{color:var(--color-error);font-size:.8125rem}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.image-thumbnail{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;position:relative;border:2px solid var(--color-gray-200);transition:all .3s ease;box-shadow:0 2px 8px #00000014}.image-thumbnail:hover{border-color:var(--color-primary);box-shadow:0 8px 24px #4f46e540,0 0 0 4px #4f46e51a;transform:scale(1.05) translateY(-4px)}.image-thumbnail img{width:100%;height:100%;object-fit:cover}.image-viewer-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-viewer-content{position:relative;width:90%;height:90%;max-width:1200px;max-height:800px;display:flex;align-items:center;justify-content:center;animation:zoomIn .2s ease-in-out}@keyframes zoomIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.image-viewer-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:var(--radius-lg);overflow:hidden}.image-viewer-image{max-width:100%;max-height:100%;object-fit:contain}.image-viewer-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.image-viewer-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;z-index:10}.image-viewer-close:hover{transform:scale(1.1)}.image-viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:3rem;cursor:pointer;padding:1rem 1.5rem;border-radius:var(--radius-md);transition:all .2s ease;z-index:10}.image-viewer-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.image-viewer-prev{left:1rem}.image-viewer-next{right:1rem}.image-viewer-counter{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);color:#fff;font-size:.875rem;font-weight:500;white-space:nowrap}.upload-progress{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:var(--radius-lg);margin-top:.5rem;border:1px solid var(--color-gray-100)}.upload-progress-bar{flex:1;height:8px;background:linear-gradient(180deg,#e2e8f0,#cbd5e1);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.upload-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 100%);transition:width .2s ease;border-radius:4px;box-shadow:0 0 8px #4f46e566}.table{width:100%;border-collapse:collapse}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#7c3aed,#a855f7);padding:1rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 50%);animation:loginPulse 15s ease-in-out infinite}@keyframes loginPulse{0%,to{transform:translate(0)}50%{transform:translate(10%,10%)}}.login-card{background:linear-gradient(180deg,#fff,#f8fafc);border-radius:var(--radius-xl);box-shadow:0 25px 60px -12px #00000059;padding:2.5rem;width:100%;max-width:500px;position:relative;z-index:1;border:1px solid rgba(255,255,255,.2)}.login-card h1{margin:0 0 .5rem;font-size:1.75rem;font-weight:600;color:var(--color-gray-900)}.login-subtitle{margin:0 0 1.5rem;color:var(--color-gray-600);font-size:.9375rem}.login-card .form-group{margin-bottom:1.25rem}.login-card label{display:block;font-size:.875rem;font-weight:500;color:var(--color-gray-700);margin-bottom:.5rem}.login-card input{width:100%;padding:.75rem;font-size:.9375rem;border:1px solid var(--color-gray-300);border-radius:var(--radius-md)}.login-card input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4f46e526}.login-card textarea{width:100%;padding:.75rem;font-size:.8125rem;font-family:Monaco,Courier New,monospace;border:2px solid var(--color-gray-200);border-radius:var(--radius-md);resize:vertical;transition:all .2s ease}.login-card textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #4f46e526}.login-card .error-message{padding:.75rem;background:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;margin-bottom:1rem}.login-card button{width:100%;padding:.75rem;font-size:.9375rem;font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .15s}.login-card .btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:#fff;box-shadow:0 4px 14px #4f46e559}.login-card .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);box-shadow:0 6px 20px #4f46e573;transform:translateY(-2px)}.login-card .btn-secondary{background:linear-gradient(180deg,#fff,#f1f5f9);color:var(--color-gray-700);border:2px solid var(--color-gray-200)}.login-card .btn-secondary:hover:not(:disabled){background:linear-gradient(180deg,#f1f5f9,#e2e8f0);border-color:var(--color-gray-300)}.login-divider{position:relative;text-align:center;margin:1.5rem 0}.login-divider:before{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:var(--color-gray-200)}.login-divider span{position:relative;display:inline-block;padding:0 1rem;background:#fff;color:var(--color-gray-500);font-size:.875rem}.login-help{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-gray-200)}.login-help h3{margin:0 0 .75rem;font-size:.9375rem;font-weight:600;color:var(--color-gray-900)}.login-help ol{margin:0 0 1rem;padding-left:1.5rem;font-size:.875rem;color:var(--color-gray-700)}.login-help ol li{margin-bottom:.375rem}.login-help code{background:var(--color-gray-100);padding:.125rem .375rem;border-radius:var(--radius-sm);font-family:Monaco,Courier New,monospace;font-size:.8125rem}.login-help .note{padding:.75rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);font-size:.875rem;color:var(--color-gray-700);margin:0}.login-help .note strong{color:var(--color-primary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:4px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-gray-200)}.table th{font-weight:500;color:var(--color-gray-600);background:var(--color-gray-50)}.table tbody tr:hover{background:var(--color-gray-50)}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.small{width:14px;height:14px}@keyframes spin{to{transform:rotate(360deg)}}.eval-form-header{display:flex;justify-content:space-between;align-items:center}.eval-progress-section{display:flex;align-items:center;gap:1rem;flex:1}.eval-progress-bar-container{flex:1;max-width:300px}.eval-progress-label{display:flex;justify-content:space-between;margin-bottom:.25rem}.eval-progress-text{font-size:.8125rem;color:var(--color-gray-600)}.eval-progress-percent{font-size:.8125rem;font-weight:500}.eval-progress-stats{font-size:.8125rem;color:var(--color-gray-500)}.eval-required-warning{color:var(--color-warning);margin-left:.5rem}.eval-actions{display:flex;align-items:center;gap:.75rem}.section-toggles{margin-bottom:1.5rem;padding:1rem;background:var(--color-gray-50);border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.section-toggles-title{font-size:.875rem;font-weight:600;margin:0 0 .75rem;color:var(--color-gray-700)}.section-toggles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.section-toggle-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.375rem;border-radius:var(--radius-sm);transition:background .15s}.section-toggle-item:hover{background:#fff}.section-toggle-item input{cursor:pointer}.section-toggle-label{font-size:.8125rem;color:var(--color-gray-700)}.eval-empty-state{text-align:center;color:var(--color-gray-500);padding:2rem}.eval-empty-title{margin-bottom:.5rem}.eval-empty-subtitle{font-size:.875rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:600;margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out}.modal{background:#fff;border-radius:var(--radius-lg, .5rem);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:90%;animation:slideUp .2s ease-in-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-gray-900, #111827)}.modal-body{padding:1.5rem}.modal-footer{padding:1.5rem;border-top:1px solid var(--color-gray-200, #e5e7eb);display:flex;justify-content:flex-end;gap:.75rem}
