.form-input.is-valid,.form-select.is-valid{border-color:#10b981;padding-right:2.5rem;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2310b981'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.primary-button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;background-color:#2563eb;color:#fff;font-weight:500;font-size:.875rem;border-radius:.375rem;border:none;cursor:pointer;text-decoration:none;transition:background-color .2s}.primary-button:hover{background-color:#1d4ed8;color:#fff}.primary-button:disabled{opacity:.5;cursor:not-allowed}.primary-button .mr-1{margin-right:.25rem}.primary-button .mr-2{margin-right:.5rem}.mt-6{margin-top:1.5rem}.mr-1{margin-right:.25rem}.batch-list-page{padding:2rem 0}.batch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.batch-header h1{font-size:1.75rem;font-weight:600;color:#1e3a8a;margin:0}.batch-actions{display:flex;gap:.75rem;margin-top:.5rem;flex-wrap:wrap}.batch-status{padding:.25rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:600;text-transform:capitalize;display:inline-flex;align-items:center;gap:.375rem;white-space:nowrap}.batch-status.completed{background-color:#22c55e1a;color:#15803d}.batch-status.processing{background-color:#3b82f61a;color:#1d4ed8}.batch-status.failed{background-color:#ef44441a;color:#b91c1c}.batch-status.pending{background-color:#f59e0b1a;color:#b45309}.status-icon{flex-shrink:0}.status-icon.completed{color:#15803d}.status-icon.processing{color:#1d4ed8}.status-icon.failed{color:#b91c1c}.status-icon.pending{color:#b45309}.action-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.batch-count-summary{display:flex;align-items:baseline;gap:.375rem}.batch-count-number{font-size:1.5rem;font-weight:700;color:#1f2937}.batch-count-label{font-size:.875rem;color:#6b7280}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background-color:#f9fafb;border-radius:.5rem;border:1px dashed #d1d5db;text-align:center;margin:2rem 0}.empty-state-icon{width:4rem;height:4rem;border-radius:50%;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#9ca3af}.empty-state-title{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:.75rem}.empty-state-description{font-size:.875rem;color:#6b7280;max-width:32rem;margin-bottom:2rem}.empty-state-actions{display:flex;gap:1rem}.batch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.batch-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;height:100%}.batch-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.batch-card-header{padding:1.25rem;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;align-items:center}.batch-card-title{font-size:1rem;font-weight:600;color:#111827;margin:0;text-overflow:ellipsis;max-width:60%}.batch-card-content{padding:1.25rem;flex-grow:1;display:flex;flex-direction:column;gap:1rem}.batch-info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{display:flex;align-items:center;font-size:.75rem;font-weight:500;color:#6b7280;gap:.375rem}.info-icon{flex-shrink:0}.info-value{font-size:.875rem;color:#1f2937;font-weight:500}.batch-card-footer{padding:1rem 1.25rem;border-top:1px solid #f3f4f6;background-color:#f9fafb;display:flex;justify-content:flex-end}.view-details-link{font-size:.875rem;font-weight:500;color:#2563eb;text-decoration:none;display:flex;align-items:center;gap:.375rem;transition:color .2s}.view-details-link:hover{color:#1d4ed8;text-decoration:underline}.batch-detail-page{padding:2rem 0}.batch-detail-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}@media (min-width: 768px){.batch-detail-header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.batch-info-header-content h1{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .75rem}.batch-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.batch-date{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#6b7280}.batch-actions{display:flex;gap:.75rem;margin-top:.5rem}@media (min-width: 768px){.batch-actions{margin-top:0}}.refresh-button{display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;color:#2563eb;background-color:#3b82f61a;border:1px solid rgba(37,99,235,.2);border-radius:.375rem;cursor:pointer;transition:all .2s ease}.refresh-button:hover{background-color:#3b82f633;color:#1e40af;transform:translateY(-1px)}.processing-timeout{margin-top:.5rem;color:#f59e0b;font-size:.75rem;font-style:italic}.certificates-card{background-color:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden;transition:box-shadow .3s ease}.certificates-card:hover{box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.certificates-list{max-height:500px;overflow-y:auto;padding:.5rem 1rem;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.certificates-list::-webkit-scrollbar{width:6px}.certificates-list::-webkit-scrollbar-track{background:transparent}.certificates-list::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.certificate-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.certificate-item:hover{background-color:#f9fafb}.certificate-item:last-child{border-bottom:none}.certificate-info{display:flex;align-items:center;gap:.75rem;overflow:hidden}.certificate-name{font-size:.875rem;font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.certificate-actions{display:flex;gap:.5rem;flex-shrink:0}.action-button{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:.375rem;font-size:.75rem;font-weight:500;gap:.375rem;cursor:pointer;transition:all .2s ease;border:none}.action-button.preview{background-color:#4f46e51a;color:#4338ca}.action-button.preview:hover{background-color:#4f46e533;transform:translateY(-1px)}.action-button.download{background-color:#10b9811a;color:#059669}.action-button.download:hover{background-color:#10b98133;transform:translateY(-1px)}.processing-alert{display:flex;align-items:center;background-color:#3b82f61a;border-left:4px solid rgb(37,99,235);border-radius:.375rem;padding:1rem 1.25rem;margin-bottom:1.5rem;box-shadow:0 1px 2px #0000000d;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #3b82f64d}70%{box-shadow:0 0 0 6px #3b82f600}to{box-shadow:0 0 #3b82f600}}.processing-spinner{width:1.25rem;height:1.25rem;border:2px solid rgba(59,130,246,.2);border-top-color:#2563eb;border-radius:50%;margin-right:1rem;animation:spin 1s linear infinite}.processing-alert p{margin:0;font-size:.875rem;color:#2563eb;font-weight:500}.back-navigation{margin-bottom:1.5rem}.back-link{display:inline-flex;align-items:center;font-size:.875rem;color:#6b7280;text-decoration:none;gap:.375rem;transition:color .2s}.back-link:hover{color:#4b5563}@media (max-width: 768px){.action-bar,.batch-detail-header{flex-direction:column;align-items:flex-start;gap:1rem}.action-bar .primary-button{width:100%;justify-content:center}.batch-grid{grid-template-columns:1fr}.batch-info-row{flex-direction:column;gap:.5rem}.batch-info-label,.batch-info-value{width:100%}.empty-state-actions{flex-direction:column;width:100%}.empty-state-actions .primary-button,.empty-state-actions .secondary-button{width:100%}.certificate-item{flex-direction:column;align-items:flex-start;gap:.75rem}.certificate-actions{width:100%}}.refresh-button{display:inline-flex;align-items:center;padding:.25rem .5rem;font-size:.75rem;font-weight:500;color:#4f46e5;background-color:#eff6ff;border:1px solid #c7d2fe;border-radius:.25rem;cursor:pointer;transition:all .2s ease;margin-left:.5rem}.refresh-button:hover{background-color:#4f46e5;color:#fff}.processing-timeout{margin-top:.5rem;color:#f59e0b;font-size:.875rem;font-style:italic}.content-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:1.5rem}@media (min-width: 768px){.content-grid{grid-template-columns:350px 1fr}}.batch-info-card{background-color:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden;transition:box-shadow .3s ease;height:-moz-fit-content;height:fit-content}.batch-info-card:hover{box-shadow:0 4px 6px #0000001a,0 2px 4px #0000000f}.batch-info-header{padding:1.25rem;border-bottom:1px solid #f3f4f6;background-color:#f9fafb}.batch-info-header h2{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 .25rem}.batch-info-description{font-size:.875rem;color:#6b7280;margin:0}.batch-info-body{padding:1rem 1.25rem}.batch-info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.batch-info-row:last-child{border-bottom:none}.batch-info-label{font-size:.875rem;font-weight:500;color:#6b7280;flex-basis:40%}.batch-info-value{font-size:.875rem;color:#1f2937;font-weight:500;text-align:right;flex-basis:60%}.error-alert{display:flex;align-items:flex-start;gap:1rem;background-color:#fef2f2;border-radius:.5rem;padding:1.25rem;border-left:4px solid #ef4444;margin-bottom:1.5rem;box-shadow:0 1px 2px #0000000d}.error-icon{flex-shrink:0;font-size:1.25rem;color:#ef4444}.error-message{margin-top:.25rem;font-size:.75rem;color:#b91c1c}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:300px;gap:1.5rem}.loading-spinner{width:2.5rem;height:2.5rem;border:3px solid rgba(59,130,246,.2);border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{color:#6b7280;font-size:.875rem;font-weight:500}.secondary-button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;background-color:#fff;color:#374151;font-weight:500;font-size:.875rem;border-radius:.375rem;border:1px solid #e5e7eb;cursor:pointer;text-decoration:none;transition:all .2s ease}.secondary-button:hover{background-color:#f9fafb;border-color:#d1d5db;color:#111827}.secondary-button .mr-1{margin-right:.25rem}.secondary-button .mr-2{margin-right:.5rem}@media (max-width: 640px){.batch-detail-header{padding-bottom:1rem}.batch-info-header-content h1{font-size:1.25rem}.batch-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.certificate-name{max-width:150px}.certificate-actions{flex-direction:column;gap:.375rem}.batch-actions{flex-direction:column;gap:.5rem;width:100%}.batch-actions .primary-button,.batch-actions .secondary-button{width:100%}}.back-link{transition:color .2s,transform .2s}.back-link:hover{transform:translate(-3px)}.view-details-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:#4b5563;text-decoration:none;transition:color .2s,transform .2s}.view-details-link:hover{color:#1f2937;transform:translate(-3px)}.icon{flex-shrink:0}.batch-card-actions{display:flex;align-items:center;gap:.75rem}.delete-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background-color:#fee2e2;color:#ef4444;font-weight:500;font-size:.875rem;border-radius:.375rem;border:1px solid #fecaca;cursor:pointer;transition:all .2s ease;gap:.375rem}.delete-button:hover{background-color:#fecaca;border-color:#fca5a5;color:#dc2626}.delete-button:disabled{opacity:.5;cursor:not-allowed}.delete-button .mr-1{margin-right:.25rem}.refresh-button-main{display:inline-flex;align-items:center;justify-content:center;background-color:#f3f4f6;color:#374151;border:1px solid #d1d5db;font-size:.875rem;font-weight:500;padding:.5rem 1rem;border-radius:.375rem;transition:all .2s;cursor:pointer}.refresh-button-main:hover{background-color:#e5e7eb;color:#111827}.refresh-button-secondary{display:inline-flex;align-items:center;justify-content:center;background-color:#e0f2fe;color:#0284c7;border:1px solid #bae6fd;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;border-radius:.375rem;margin-top:1rem;transition:all .2s;cursor:pointer}.refresh-button-secondary:hover{background-color:#bae6fd;color:#0369a1}.back-navigation{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.filter-container{display:flex;align-items:center;margin-right:20px}.filter-item{display:flex;align-items:center;background-color:#0000000a;padding:6px 12px;border-radius:4px}.filter-label{display:flex;align-items:center;margin-right:8px;font-size:14px;color:#555}.filter-icon{margin-right:5px}.filter-select{border:none;background-color:transparent;padding:4px 8px;font-size:14px;color:#333;border-radius:3px;cursor:pointer;min-width:150px}.filter-select:focus{outline:none;background-color:#00000014}*,*:before,*:after{box-sizing:border-box}html{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;font-size:1rem;color:#374151;background-color:#f9fafb}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:600;line-height:1.25;color:#111827}p{margin-top:0;margin-bottom:1rem}ul,ol{padding-left:2rem;margin-top:0;margin-bottom:1rem}img,svg{vertical-align:middle}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:100%;line-height:1.15}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button:focus,input:focus,select:focus,textarea:focus{outline:none}blockquote,dl,dd,figure{margin:0}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;overflow-x:hidden}.main-content{flex:1;padding:1.5rem;background-color:#f9fafb;width:100%}.container{width:100%;max-width:1280px;margin-left:auto;margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.px-4{padding-left:1rem;padding-right:1rem}.navbar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;position:sticky;top:0;z-index:100;width:100%}.navbar-container{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;max-width:1280px;margin:0 auto;width:100%}.navbar-left,.navbar-right{display:flex;align-items:center}.navbar-brand{font-size:1.25rem;font-weight:700;color:#111827;text-decoration:none;display:flex;align-items:center;gap:.5rem}.navbar-brand:hover{color:#4f46e5}.navbar-nav{display:flex;align-items:center;gap:1.5rem;margin-left:2rem}.nav-link{color:#4b5563;text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 0;border-bottom:2px solid transparent;transition:all .2s}.nav-link:hover,.nav-link.active{color:#4f46e5;border-bottom-color:#4f46e5}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-auth{display:flex;align-items:center;gap:.75rem}.navbar-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.375rem}.navbar-toggle:hover{background-color:#f3f4f6}.mobile-menu{display:none;background-color:#fff;border-bottom:1px solid #e5e7eb;padding:.5rem 0}.mobile-nav-link{display:block;padding:.75rem 1.5rem;color:#4b5563;text-decoration:none;font-weight:500;transition:background-color .2s}.mobile-nav-link:hover{background-color:#f3f4f6;color:#111827}.mobile-nav-link.active{background-color:#f9fafb;color:#4f46e5;border-left:3px solid #4f46e5}@media (max-width: 768px){.navbar-toggle{display:block}.navbar-nav,.navbar-right{display:none}.mobile-menu{display:block}}.header{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d}.header-logo{display:flex;align-items:center;gap:.75rem;font-weight:700;font-size:1.25rem;color:#111827}.header-logo-image{height:2rem;width:auto}.header-nav{display:flex;align-items:center;gap:1.5rem}.header-nav-link{color:#4b5563;text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 0;border-bottom:2px solid transparent;transition:all .2s}.header-nav-link:hover,.header-nav-link.active{color:#4f46e5;border-bottom-color:#4f46e5}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.375rem}.user-menu-button:hover{background-color:#f3f4f6}.user-avatar{width:2rem;height:2rem;border-radius:50%;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;color:#6b7280;font-weight:600}.user-menu-dropdown{position:absolute;right:0;top:100%;width:12rem;margin-top:.5rem;background-color:#fff;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb;z-index:10;overflow:hidden}.user-menu-item{display:block;padding:.75rem 1rem;color:#374151;font-size:.875rem;text-decoration:none;transition:background-color .2s}.user-menu-item:hover{background-color:#f3f4f6}.user-menu-item.danger{color:#ef4444}.user-menu-item.danger:hover{background-color:#fef2f2}.dashboard{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;display:flex;flex-direction:column}.dashboard-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.dashboard-card-title{font-size:1.125rem;font-weight:600;color:#111827}.dashboard-card-content{flex:1}.dashboard-card-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.template-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;transition:transform .2s,box-shadow .2s}.template-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.template-preview{height:160px;overflow:hidden;position:relative;background-color:#f3f4f6}.template-info{padding:1rem}.template-name{font-weight:600;font-size:1rem;color:#111827;margin-bottom:.25rem}.template-actions{padding:.75rem 1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;font-size:.875rem;transition:all .2s;cursor:pointer;border:1px solid transparent}.btn-icon{padding:.5rem}.btn-primary{background-color:#4f46e5;color:#fff}.btn-primary:hover{background-color:#4338ca}.btn-secondary{background-color:#fff;border-color:#d1d5db;color:#374151}.btn-secondary:hover{background-color:#f9fafb}.btn-success{background-color:#10b981;color:#fff}.btn-success:hover{background-color:#059669}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.form-container{width:100%;max-width:32rem;margin:0 auto}.form-header{margin-bottom:1.5rem}.form-title{font-size:1.5rem;font-weight:700;color:#111827;margin-bottom:.5rem}.form-section{margin-bottom:1.5rem}.form-section-title{font-size:1rem;font-weight:600;color:#111827;margin-bottom:.75rem}.form-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.csv-preview{margin-top:1rem;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.csv-preview-header{padding:.75rem 1rem;background-color:#f9fafb;font-weight:600;border-bottom:1px solid #e5e7eb}.csv-table{width:100%;border-collapse:collapse}.csv-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.csv-table td{padding:.75rem 1rem;font-size:.875rem;color:#374151;border-bottom:1px solid #e5e7eb}.editor-container{display:flex;height:calc(100vh - 4rem);background-color:#f9fafb}.editor-sidebar{width:280px;background-color:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column}.editor-sidebar-header{padding:1rem;border-bottom:1px solid #e5e7eb}.editor-sidebar-content{padding:1rem;flex:1;overflow-y:auto}.editor-sidebar-footer{padding:1rem;border-top:1px solid #e5e7eb}.editor-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.editor-toolbar{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem;background-color:#fff}.editor-canvas{flex:1;overflow:auto;position:relative}.canvas-container{position:absolute;top:2rem;left:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;background-color:#fff}.template-element{position:absolute;cursor:move;border:1px solid transparent;display:flex;align-items:center;justify-content:center;overflow:hidden}.template-element:hover{border-color:#4f46e5}.template-element.selected{border:2px solid #4f46e5;box-shadow:0 0 0 1px #4f46e5}.alert{padding:1rem;border-radius:.375rem;margin-bottom:1rem}.alert-success{background-color:#ecfdf5;border-left:4px solid #10b981;color:#065f46}.alert-info{background-color:#eff6ff;border-left:4px solid #3b82f6;color:#1e40af}.alert-warning{background-color:#fffbeb;border-left:4px solid #f59e0b;color:#92400e}.alert-danger{background-color:#fef2f2;border-left:4px solid #ef4444;color:#b91c1c}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.loading-spinner{width:40px;height:40px;border-radius:50%;border:3px solid #e5e7eb;border-top-color:#4f46e5;animation:spin 1s linear infinite}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.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}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-gray-500{color:#6b7280}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.text-red-600{color:#dc2626}.h-6{height:1.5rem}.h-8{height:2rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-auto{width:auto}.w-full{width:100%}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-red-50,.hover\:bg-red-50:hover{background-color:#fef2f2}.border-t{border-top-width:1px;border-top-style:solid}.border-gray-200{border-color:#e5e7eb}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.hidden{display:none}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.form-container{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem}.form-header{margin-bottom:1.5rem;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.form-title{font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:.5rem}.form-description{color:#6b7280;font-size:.875rem}.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:1.5rem}.col-span-12{grid-column:span 12 / span 12}.col-span-6{grid-column:span 6 / span 6}.col-span-4{grid-column:span 4 / span 4}.col-span-3{grid-column:span 3 / span 3}@media (max-width: 768px){.form-grid{gap:1rem}.col-span-6,.col-span-4,.col-span-3{grid-column:span 12 / span 12}}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-label.required:after{content:"*";color:#dc2626;margin-left:.25rem}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .75rem;font-size:.875rem;line-height:1.25rem;border:1px solid #d1d5db;border-radius:.375rem;color:#1f2937;background-color:#fff;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background-color:#f3f4f6;cursor:not-allowed;color:#9ca3af}.form-textarea{min-height:6rem;resize:vertical}.form-hint{margin-top:.5rem;font-size:.75rem;color:#6b7280}.form-error{margin-top:.5rem;font-size:.75rem;color:#dc2626}.input-with-icon{position:relative}.input-icon{position:absolute;top:50%;transform:translateY(-50%);color:#9ca3af;width:1.25rem;height:1.25rem}.input-icon-left{left:.75rem}.input-icon-right{right:.75rem}.input-with-icon-left .form-input{padding-left:2.5rem}.input-with-icon-right .form-input{padding-right:2.5rem}.checkbox-group,.radio-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-item,.radio-item{display:flex;align-items:center;gap:.5rem}.checkbox-input,.radio-input{width:1rem;height:1rem;border:1px solid #d1d5db;transition:all .2s}.checkbox-input{border-radius:.25rem}.radio-input{border-radius:50%}.checkbox-input:checked,.radio-input:checked{border-color:#6366f1;background-color:#6366f1}.checkbox-input:focus,.radio-input:focus{outline:none;box-shadow:0 0 0 3px #6366f11a}.checkbox-label,.radio-label{font-size:.875rem;color:#4b5563}.toggle-container{display:inline-flex;align-items:center;gap:.75rem}.toggle{position:relative;display:inline-block;width:3rem;height:1.5rem}.toggle-input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#e5e7eb;border-radius:9999px;transition:all .4s}.toggle-slider:before{position:absolute;content:"";height:1.25rem;width:1.25rem;left:.125rem;bottom:.125rem;background-color:#fff;border-radius:50%;transition:all .4s}.toggle-input:checked+.toggle-slider{background-color:#6366f1}.toggle-input:checked+.toggle-slider:before{transform:translate(1.5rem)}.toggle-input:focus+.toggle-slider{box-shadow:0 0 0 3px #6366f11a}.toggle-label{font-size:.875rem;color:#4b5563}.file-upload{position:relative}.file-upload-input{position:absolute;width:0;height:0;opacity:0}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;border:2px dashed #d1d5db;border-radius:.5rem;background-color:#f9fafb;cursor:pointer;transition:all .2s}.file-upload-label:hover{border-color:#6366f1;background-color:#f5f5ff}.file-upload-icon{color:#9ca3af;width:3rem;height:3rem;margin-bottom:1rem}.file-upload-text{color:#4b5563;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.file-upload-hint{color:#6b7280;font-size:.75rem;text-align:center}.file-preview{margin-top:1rem;padding:.75rem;border:1px solid #e5e7eb;border-radius:.375rem;background-color:#f9fafb;display:flex;align-items:center;gap:.75rem}.file-preview-icon{color:#6b7280;width:1.5rem;height:1.5rem}.file-preview-info{flex:1}.file-preview-name{font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.25rem}.file-preview-size{font-size:.75rem;color:#6b7280}.file-preview-remove{color:#dc2626;cursor:pointer;padding:.25rem}.form-actions{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:1rem}.form-buttons{display:flex;justify-content:flex-end;gap:1rem}.form-status{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;margin-bottom:1rem}.form-progress{height:.5rem;background-color:#e5e7eb;border-radius:9999px;margin-bottom:.75rem;overflow:hidden}.form-progress-fill{height:100%;background-color:#3b82f6;border-radius:9999px;transition:width .3s ease}.form-status-text{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#4b5563}.status-icon{vertical-align:-.125em;margin-right:.375rem}.status-icon.complete{color:#10b981}.status-icon.incomplete{color:#6b7280}.status-ready{color:#10b981;font-weight:600}.status-missing{color:#f59e0b;font-size:.813rem}.form-input.is-valid,.form-select.is-valid,.form-textarea.is-valid{border-color:#10b981}.form-input.is-invalid,.form-select.is-invalid,.form-textarea.is-invalid{border-color:#dc2626}.input-with-icon.is-valid .input-icon{color:#10b981}.input-with-icon.is-invalid .input-icon{color:#dc2626}.input-group{display:flex}.input-group-text{display:flex;align-items:center;padding:.625rem .75rem;font-size:.875rem;font-weight:500;color:#4b5563;text-align:center;background-color:#f3f4f6;border:1px solid #d1d5db}.input-group-prepend .input-group-text{border-right:0;border-top-left-radius:.375rem;border-bottom-left-radius:.375rem}.input-group-append .input-group-text{border-left:0;border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.input-group .form-input{flex:1}.input-group-prepend+.form-input{border-top-left-radius:0;border-bottom-left-radius:0}.form-input+.input-group-append{border-top-right-radius:0;border-bottom-right-radius:0}.form-section{margin-bottom:2rem}.form-section-title{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.date-picker{position:relative}.date-picker-input{width:100%;padding:.625rem 2.5rem .625rem .75rem;font-size:.875rem;line-height:1.25rem;border:1px solid #d1d5db;border-radius:.375rem;color:#1f2937;background-color:#fff;cursor:pointer}.date-picker-icon{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.date-picker-calendar{position:absolute;top:calc(100% + .5rem);left:0;z-index:10;width:20rem;background-color:#fff;border-radius:.375rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;border:1px solid #e5e7eb}.multi-select{position:relative}.multi-select-input{display:flex;flex-wrap:wrap;gap:.5rem;padding:.375rem .625rem;min-height:2.5rem;border:1px solid #d1d5db;border-radius:.375rem;background-color:#fff;cursor:text}.multi-select-input:focus-within{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.selected-item{display:flex;align-items:center;gap:.25rem;padding:.125rem .375rem;background-color:#f3f4f6;border-radius:.25rem;font-size:.75rem;color:#4b5563}.selected-item-remove{cursor:pointer;color:#9ca3af}.selected-item-remove:hover{color:#dc2626}.multi-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:.25rem;max-height:15rem;overflow-y:auto;background-color:#fff;border-radius:.375rem;border:1px solid #e5e7eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:10}.multi-select-option{padding:.625rem .75rem;font-size:.875rem;color:#1f2937;cursor:pointer}.multi-select-option:hover{background-color:#f3f4f6}.multi-select-option.selected{background-color:#f5f5ff;color:#6366f1}.slider-container{padding:.5rem 0}.slider{-webkit-appearance:none;width:100%;height:.5rem;border-radius:9999px;background:#e5e7eb;outline:none}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1.25rem;height:1.25rem;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid white;box-shadow:0 1px 2px #0000000d}.slider::-moz-range-thumb{width:1.25rem;height:1.25rem;border-radius:50%;background:#6366f1;cursor:pointer;border:2px solid white;box-shadow:0 1px 2px #0000000d}.slider-value{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#6b7280}.page-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.page-header{margin-bottom:2rem;text-align:center}.page-header h1{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.page-description{color:#6b7280;font-size:1rem}.error-alert{display:flex;align-items:center;background-color:#fee2e2;border-left:4px solid #ef4444;padding:1rem;margin-bottom:1.5rem;border-radius:.375rem}.error-icon{margin-right:.75rem;font-size:1.25rem}.error-alert p{color:#b91c1c;font-size:.875rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 0}.loading-spinner{width:3rem;height:3rem;border-radius:50%;border:3px solid #e5e7eb;border-top-color:#3b82f6;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-container p{color:#6b7280;font-size:.875rem}.steps-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem}.step{display:flex;flex-direction:column;align-items:center;position:relative}.step-number{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background-color:#f3f4f6;color:#6b7280;font-weight:600;margin-bottom:.5rem;border:2px solid #e5e7eb;transition:all .3s ease}.step.completed .step-number{background-color:#bfdbfe;color:#1d4ed8;border-color:#3b82f6}.step-label{font-size:.875rem;color:#6b7280;font-weight:500}.step.completed .step-label{color:#1f2937}.step-connector{flex-grow:1;height:2px;background-color:#e5e7eb;margin:0 .75rem 2rem;min-width:3rem;max-width:5rem}.form-section{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.form-section:last-child{border-bottom:none;margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1.25rem}.form-field{margin-bottom:1.5rem}.form-field:last-child{margin-bottom:0}.form-field label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.field-hint{margin-top:.5rem;font-size:.75rem;color:#6b7280}.form-input,.form-select{display:block;width:100%;padding:.75rem 1rem;font-size:.875rem;line-height:1.25;color:#1f2937;background-color:#fff;background-clip:padding-box;border:1px solid #d1d5db;border-radius:.375rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-input:focus,.form-select:focus{border-color:#3b82f6;outline:0;box-shadow:0 0 0 3px #3b82f640}.form-input.is-valid,.form-select.is-valid{border-color:#10b981;padding-right:2.5rem;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2310b981'%3e%3cpath fill-rule='evenodd' d='M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z' clip-rule='evenodd'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.25rem}.template-preview-container{margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.preview-title{padding:1rem 1.25rem;margin:0;font-size:1rem;font-weight:600;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;color:#111827}.template-preview{display:flex;flex-direction:row;gap:1.5rem;padding:1.25rem}.template-image-container{flex:0 0 auto;max-width:300px;height:200px;overflow:hidden;border-radius:.375rem;border:1px solid #e5e7eb;background-color:#f9fafb;display:flex;align-items:center;justify-content:center}.template-image{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}.template-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1rem}.template-info h4{margin:0;font-size:1.125rem;font-weight:600;color:#111827}.template-actions{margin-top:auto;display:flex;gap:.75rem}.template-elements-preview{display:flex;flex-direction:column;gap:1rem}.template-no-elements{display:flex;align-items:center;gap:.5rem;background-color:#fff7ed;border:1px solid #fedfbf;border-radius:.375rem;padding:.75rem 1rem;color:#9a3412;font-size:.875rem}.elements-counts{display:flex;flex-wrap:wrap;gap:1rem}.element-count{display:flex;align-items:center;gap:.5rem;background-color:#f3f4f6;padding:.5rem .75rem;border-radius:9999px;font-size:.875rem;color:#4b5563}.count-icon{color:#6b7280}.elements-list{margin-top:.5rem}.elements-list-title{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .5rem}.dynamic-fields-list{display:flex;flex-wrap:wrap;gap:.5rem}.dynamic-field-item{background-color:#eff6ff;border:1px solid #dbeafe;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;color:#1e40af;display:flex;flex-direction:column;gap:.25rem}.field-name{font-weight:600}.field-font{font-size:.75rem;color:#4b5563}.mixed-content-preview{display:flex;flex-direction:column;gap:.75rem}.mixed-content-item{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;padding:.75rem}.mixed-content-text{font-size:.875rem;color:#475569;margin-bottom:.5rem;font-style:italic}.mixed-placeholders{display:flex;flex-wrap:wrap;gap:.375rem}.mixed-placeholder{background-color:#fef9c3;border:1px solid #fde68a;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;color:#854d0e;font-weight:500}@media (max-width: 768px){.template-preview{flex-direction:column}.template-image-container{max-width:100%;margin-bottom:1rem}.elements-counts{justify-content:space-between}.element-count{flex:1;justify-content:center;min-width:120px}}.csv-upload-container{position:relative;border:2px dashed #d1d5db;border-radius:.5rem;padding:1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s ease;background-color:#f9fafb}.csv-upload-container:hover{border-color:#9ca3af;background-color:#f3f4f6}.csv-upload-container.has-file{border-style:solid;border-color:#d1d5db;background-color:#fff}.csv-upload-container.is-valid{border-color:#10b981;background-color:#ecfdf5}.csv-upload-container.is-invalid{border-color:#ef4444;background-color:#fef2f2}.upload-icon{font-size:2rem;color:#9ca3af}.csv-upload-container.has-file .upload-icon{color:#4b5563}.csv-upload-container.is-valid .upload-icon{color:#10b981}.upload-content{flex:1}.upload-title{font-weight:500;color:#111827;margin-bottom:.25rem;font-size:.938rem}.upload-subtitle{color:#6b7280;font-size:.813rem}.csv-upload-container input[type=file]{position:absolute;width:100%;height:100%;top:0;left:0;opacity:0;cursor:pointer}.clear-file-button{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background-color:#e5e7eb;border:none;border-radius:50%;color:#4b5563;font-size:1rem;cursor:pointer;transition:all .2s}.clear-file-button:hover{background-color:#d1d5db;color:#1f2937}.csv-preview{margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.table-container{overflow-x:auto;max-height:300px;overflow-y:auto}.csv-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.csv-table th{background-color:#f9fafb;font-weight:600;text-align:left;padding:.75rem 1rem;color:#374151;font-size:.875rem;border-bottom:1px solid #e5e7eb}.csv-table th:first-child{border-top-left-radius:.5rem}.csv-table th:last-child{border-top-right-radius:.5rem}.csv-table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;color:#4b5563;font-size:.875rem;word-break:break-word}.csv-table tr:last-child td{border-bottom:none}.csv-table tr:last-child td:first-child{border-bottom-left-radius:.5rem}.csv-table tr:last-child td:last-child{border-bottom-right-radius:.5rem}.csv-table tr:nth-child(2n){background-color:#f9fafb}.form-actions{display:flex;justify-content:flex-end;margin-top:2rem;gap:1rem}.no-templates-message{padding:1.5rem;text-align:center;color:#6b7280;font-size:.875rem;background-color:#f3f4f6;border-radius:.375rem;margin-top:.5rem}.primary-button{padding:.625rem 1.25rem;background-color:#6366f1;color:#fff;font-weight:500;border:none;border-radius:.375rem;font-size:.875rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 1px 2px #0000000d;min-width:180px}.primary-button:hover{background-color:#4f46e5}.primary-button:focus{outline:none;box-shadow:0 0 0 3px #6366f140}.primary-button:disabled{opacity:.5;cursor:not-allowed;background-color:#a5a6f6}.primary-button.ready{background-color:#10b981}.primary-button.ready:hover{background-color:#059669}.secondary-button{padding:.625rem 1.25rem;background-color:#fff;color:#4b5563;font-weight:500;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 1px 2px #0000000d}.secondary-button:hover{background-color:#f9fafb;border-color:#9ca3af}.secondary-button:focus{outline:none;box-shadow:0 0 0 3px #d1d5db80}.secondary-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.template-preview{flex-direction:column}.template-image{width:100%;margin-right:0;margin-bottom:1rem}.steps-indicator{flex-direction:column;gap:1rem}.step-connector{height:2rem;width:2px;margin:.5rem 0}.form-actions{flex-direction:column}.form-actions button{width:100%}}.field-error{margin-top:.5rem;font-size:.75rem;color:#dc2626}.form-input.is-invalid,.form-select.is-invalid,.csv-upload-container.is-invalid{border-color:#dc2626;background-color:#fff5f5}.form-input.is-invalid:focus,.form-select.is-invalid:focus{box-shadow:0 0 0 3px #dc262640}.field-validations{margin-top:1.5rem;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.25rem;background-color:#f9fafb}.validations-title{font-size:1rem;font-weight:600;color:#374151;margin-bottom:1rem;display:flex;align-items:center}.validations-list{display:flex;flex-direction:column;gap:.75rem}.validation-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-radius:.375rem;transition:background-color .2s}.validation-item:hover{background-color:#f3f4f6}.validation-item.valid{border-left:3px solid #10b981}.validation-item.invalid{border-left:3px solid #ef4444}.validation-icon{flex-shrink:0;margin-top:.125rem}.validation-icon.success{color:#10b981}.validation-icon.error{color:#ef4444}.validation-details{display:flex;flex-direction:column;gap:.25rem}.validation-field{font-weight:600;color:#111827}.validation-type{font-size:.875rem;color:#6b7280}.validation-status{color:#ef4444;font-weight:500}.primary-button .spinner{display:inline-block;width:1rem;height:1rem;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;animation:spin 1s linear infinite;margin-right:.5rem}.csv-upload-container.disabled{background-color:#f3f4f6;border-color:#e5e7eb;cursor:not-allowed;opacity:.75}.csv-upload-container.disabled:hover{background-color:#f3f4f6;border-color:#e5e7eb}.csv-upload-container.disabled .upload-icon{color:#9ca3af}.required-step{color:#f59e0b;font-size:.875rem;font-weight:400;margin-left:.5rem}.template-required-fields{margin-top:.5rem}.required-fields-title{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .5rem}.required-fields-list{display:flex;flex-wrap:wrap;gap:.5rem}.required-field-tag{background-color:#eff6ff;border:1px solid #dbeafe;border-radius:.375rem;padding:.5rem .75rem;font-size:.875rem;color:#1e40af;font-weight:500}.template-info-message{display:flex;align-items:center;gap:.5rem;background-color:#f3f4f6;border-radius:.375rem;padding:.75rem 1rem;color:#4b5563;font-size:.875rem;margin-top:.5rem}.template-section{margin-top:1.5rem}.template-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.template-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.template-info.scrollable{max-height:200px;overflow-y:auto;padding-right:.5rem}.template-info.scrollable::-webkit-scrollbar{width:6px}.template-info.scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.template-info.scrollable::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.template-info.scrollable::-webkit-scrollbar-thumb:hover{background:#9ca3af}.table-container{width:100%;overflow-x:auto;background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}table{width:100%;border-collapse:collapse;text-align:left;font-size:.875rem}thead{background-color:#f9fafb;border-bottom:1px solid #e5e7eb}th{padding:.75rem 1rem;font-weight:600;color:#374151;white-space:nowrap}th.sortable{cursor:pointer}th.sortable:hover{background-color:#f3f4f6}th.sorted-asc:after,th.sorted-desc:after{content:"";display:inline-block;width:.5rem;height:.5rem;margin-left:.5rem;border-right:2px solid #4b5563;border-bottom:2px solid #4b5563}th.sorted-asc:after{transform:rotate(-135deg)}th.sorted-desc:after{transform:rotate(45deg)}tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background-color:#f9fafb}td{padding:.75rem 1rem;color:#4b5563;vertical-align:middle}.status-indicator{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;font-size:.75rem;padding:.25rem .5rem;border-radius:9999px}.status-active{background-color:#d1fae5;color:#047857}.status-inactive{background-color:#e5e7eb;color:#4b5563}.status-pending{background-color:#fef3c7;color:#d97706}.status-error{background-color:#fee2e2;color:#dc2626}.table-actions{display:flex;gap:.5rem;justify-content:flex-end}.table-action-button{padding:.25rem;border-radius:.375rem;background-color:#fff;color:#6b7280;border:1px solid #e5e7eb;cursor:pointer;transition:all .2s}.table-action-button:hover{background-color:#f3f4f6;color:#111827}.table-action-button.edit:hover{color:#4f46e5;border-color:#4f46e5}.table-action-button.delete:hover{color:#dc2626;border-color:#dc2626}.table-action-button.view:hover{color:#0e7490;border-color:#0e7490}.table-checkbox{width:1rem;height:1rem;border-radius:.25rem;border:1px solid #d1d5db;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:all .2s}.table-checkbox:checked{background-color:#4f46e5;border-color:#4f46e5;background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}.table-checkbox:focus{outline:none;box-shadow:0 0 0 2px #4f46e54d}.table-empty{padding:3rem 1rem;text-align:center;color:#6b7280}.table-empty-icon{width:3rem;height:3rem;margin:0 auto 1rem;color:#9ca3af}.table-empty-text{margin:0 auto;max-width:20rem}.table-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.table-toolbar-title{font-size:1.25rem;font-weight:600;color:#111827}.table-toolbar-actions{display:flex;gap:.75rem}.table-pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid #e5e7eb;background-color:#f9fafb}.table-pagination-info{font-size:.875rem;color:#6b7280}.table-pagination-pages{display:flex;gap:.25rem}.table-pagination-button{padding:.25rem .5rem;border:1px solid #e5e7eb;border-radius:.25rem;background-color:#fff;font-size:.875rem;color:#4b5563;cursor:pointer;transition:all .2s}.table-pagination-button:hover{background-color:#f3f4f6}.table-pagination-button.active{background-color:#4f46e5;color:#fff;border-color:#4f46e5}.table-rows-per-page{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.table-rows-select{padding:.25rem .5rem;border:1px solid #e5e7eb;border-radius:.25rem;background-color:#fff;font-size:.875rem}.table-compact th,.table-compact td{padding:.5rem .75rem;font-size:.813rem}.table-striped tbody tr:nth-child(odd){background-color:#f9fafb}.table-striped tbody tr:hover{background-color:#f3f4f6}.table-bordered th,.table-bordered td{border:1px solid #e5e7eb}.table-fixed-header{height:100%;display:flex;flex-direction:column}.table-fixed-header thead{position:sticky;top:0;z-index:1;background-color:#f9fafb}.table-fixed-header tbody{flex:1;overflow-y:auto}.cell-with-image{display:flex;align-items:center;gap:.75rem}.cell-image{width:2.5rem;height:2.5rem;border-radius:.375rem;overflow:hidden;background-color:#f3f4f6}.cell-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cell-text{display:flex;flex-direction:column}.cell-main-text{font-weight:500;color:#111827}.cell-sub-text{font-size:.75rem;color:#6b7280}.cell-numeric{text-align:right;font-variant-numeric:tabular-nums}.cell-badge{font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:9999px;display:inline-block}.badge-blue{background-color:#eff6ff;color:#2563eb}.badge-green{background-color:#ecfdf5;color:#047857}.badge-red{background-color:#fef2f2;color:#dc2626}.badge-yellow{background-color:#fffbeb;color:#d97706}.badge-purple{background-color:#f5f3ff;color:#6d28d9}.badge-gray{background-color:#f3f4f6;color:#4b5563}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.dashboard-logo{display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1.25rem;color:#111827}.dashboard-logo img,.dashboard-logo svg{height:2rem;width:auto}.dashboard-user{display:flex;align-items:center;gap:.75rem}.user-avatar{width:2.5rem;height:2.5rem;border-radius:50%;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center;color:#6b7280;font-weight:500;font-size:1rem;overflow:hidden}.user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-name{font-weight:500;color:#111827}.dashboard-main{display:flex;flex:1;background-color:#f9fafb}.dashboard-sidebar{width:260px;background-color:#fff;border-right:1px solid #e5e7eb;padding:1.5rem 0;display:flex;flex-direction:column}.sidebar-menu{display:flex;flex-direction:column;gap:.25rem}.sidebar-group{margin-bottom:1.5rem}.sidebar-group-title{padding:0 1.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;color:#6b7280;margin-bottom:.75rem;letter-spacing:.05em}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#4b5563;font-weight:500;text-decoration:none;transition:all .2s}.sidebar-link:hover{background-color:#f3f4f6;color:#111827}.sidebar-link.active{background-color:#eff6ff;color:#4f46e5;border-right:2px solid #4f46e5}.sidebar-icon{width:1.25rem;height:1.25rem;color:#6b7280}.sidebar-link.active .sidebar-icon{color:#4f46e5}.sidebar-footer{margin-top:auto;padding:1.5rem;border-top:1px solid #e5e7eb}.dashboard-content{flex:1;padding:1.5rem;overflow-y:auto}.dashboard-title{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:1.5rem}.dashboard-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-title{font-size:1.25rem;font-weight:600;color:#111827}.section-actions{display:flex;gap:.75rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.dashboard-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden;transition:all .2s}.dashboard-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.card-header{padding:1.25rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background-color:#f9fafb}.card-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.card-header .text-primary{font-weight:500;color:#4f46e5;text-decoration:none;transition:color .2s ease}.card-header .text-primary:hover{color:#4338ca}.card-content{padding:1.25rem}.card-footer{padding:1rem;border-top:1px solid #e5e7eb;background-color:#f9fafb;display:flex;justify-content:space-between;align-items:center}.stat-card{background-color:#fff;border-radius:.5rem;padding:1.25rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.stat-title{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.5rem}.stat-value{font-size:1.875rem;font-weight:600;color:#111827;margin-bottom:.5rem}.stat-change{display:flex;align-items:center;gap:.25rem;font-size:.875rem}.stat-change.increase{color:#047857}.stat-change.decrease{color:#dc2626}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.template-card{background-color:#fff;border-radius:.5rem;overflow:hidden;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;transition:all .2s;display:flex;flex-direction:column}.template-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.template-preview{height:160px;background-color:#f3f4f6;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.template-preview img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.template-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#11182780;display:flex;align-items:center;justify-content:center;gap:1rem;opacity:0;transition:opacity .2s}.template-card:hover .template-overlay{opacity:1}.template-action{width:2.5rem;height:2.5rem;border-radius:9999px;background-color:#fff;display:flex;align-items:center;justify-content:center;color:#111827;cursor:pointer;transition:all .2s}.template-action:hover{background-color:#4f46e5;color:#fff}.template-info{padding:1rem;flex:1;display:flex;flex-direction:column}.template-name{font-weight:500;color:#111827;margin-bottom:.25rem}.template-meta{font-size:.875rem;color:#6b7280;margin-bottom:.75rem}.template-description{font-size:.875rem;color:#4b5563;margin-top:auto}.template-footer{padding:.75rem 1rem;border-top:1px solid #e5e7eb;background-color:#f9fafb;display:flex;justify-content:space-between;align-items:center}.template-status{font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:9999px;background-color:#e5e7eb;color:#4b5563}.template-status.published{background-color:#d1fae5;color:#047857}.template-status.draft{background-color:#fef3c7;color:#d97706}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;background-color:#f9fafb;border-radius:.5rem;border:2px dashed #e5e7eb}.empty-icon{font-size:2.5rem;margin-bottom:1rem;color:#9ca3af}.empty-title{font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:.5rem}.empty-description{color:#6b7280;margin-bottom:1.5rem;max-width:300px}.empty-state .btn{padding:.75rem 1.5rem;font-weight:500;border-radius:.5rem;transition:all .2s ease}.empty-state .btn:hover{transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.filter-bar{background-color:#fff;border-radius:.5rem;padding:1rem;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-label{font-size:.875rem;font-weight:500;color:#4b5563}.filter-separator{width:1px;height:2rem;background-color:#e5e7eb}.search-box{flex:1;position:relative}.search-input{width:100%;padding:.5rem 1rem .5rem 2.5rem;border:1px solid #e5e7eb;border-radius:.375rem;background-color:#f9fafb}.search-input:focus{outline:none;border-color:#4f46e5;background-color:#fff}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#9ca3af;width:1rem;height:1rem}.pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;margin-top:1.5rem}.pagination-info{font-size:.875rem;color:#6b7280}.pagination-actions{display:flex;gap:.25rem}.pagination-button{padding:.5rem;border:1px solid #e5e7eb;border-radius:.375rem;background-color:#fff;color:#4b5563;font-size:.875rem;cursor:pointer;transition:all .2s}.pagination-button:hover{background-color:#f3f4f6}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-button.active{background-color:#4f46e5;color:#fff;border-color:#4f46e5}.dashboard-page{padding:1.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.dashboard-title{font-size:1.875rem;font-weight:700;color:#111827;margin-bottom:.5rem}.dashboard-actions{display:flex;gap:.75rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background-color:#fff;border-radius:.5rem;padding:1.25rem;box-shadow:0 1px 3px #0000001a}.stat-title{font-size:.875rem;font-weight:600;color:#6b7280;margin-bottom:.5rem}.stat-value{font-size:1.875rem;font-weight:700;color:#111827;margin-bottom:.5rem}.stat-description{font-size:.875rem;color:#6b7280}.dashboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media (max-width: 1024px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;flex-direction:column}.card-header{padding:1.25rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.card-title{font-size:1.125rem;font-weight:600;color:#111827}.card-content{padding:1.25rem;flex:1;overflow-y:auto;max-height:350px}.template-list{display:flex;flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none}.template-list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f9fafb;border-radius:.5rem;transition:all .2s ease;border:1px solid #e5e7eb}.template-list-item:hover{background-color:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.template-info{display:flex;flex-direction:column;gap:.25rem}.template-name{font-weight:600;color:#111827;font-size:1rem;margin:0}.template-actions{display:flex;gap:.5rem}.template-actions .btn{padding:.5rem 1rem;font-size:.875rem;border-radius:.375rem;transition:all .2s ease}.template-actions .btn-secondary{background-color:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.template-actions .btn-secondary:hover{background-color:#e5e7eb;color:#374151}.template-actions .btn-primary{background-color:#4f46e5;color:#fff;border:1px solid #4f46e5}.template-actions .btn-primary:hover{background-color:#4338ca;border-color:#4338ca}.batch-list{display:flex;flex-direction:column;gap:1rem}.batch-list-item{padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.batch-list-item:hover{border-color:#4f46e5;background-color:#f9fafb}.batch-info{flex:1}.batch-name{font-weight:600;font-size:.938rem;color:#111827;margin-bottom:.25rem}.batch-details{font-size:.813rem;color:#6b7280;display:block;margin-bottom:.5rem}.batch-actions{display:flex;gap:.5rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.quick-action-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.25rem 1rem;text-align:center;transition:all .2s;text-decoration:none}.quick-action-card:hover{background-color:#eff6ff;border-color:#4f46e5;transform:translateY(-2px)}.quick-action-icon{font-size:2rem;margin-bottom:.75rem}.quick-action-title{font-size:.938rem;font-weight:600;color:#111827;margin-bottom:.5rem}.quick-action-desc{font-size:.813rem;color:#6b7280}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#e6eeff,#f0f0ff);padding:20px}.auth-card{width:100%;max-width:420px;background-color:#fff;border-radius:16px;box-shadow:0 10px 25px #0000001a;overflow:hidden;transition:box-shadow .3s ease}.auth-card:hover{box-shadow:0 15px 30px #4f46e526}.auth-content{padding:32px}.auth-logo{display:flex;justify-content:center;margin-bottom:24px}.auth-logo-circle{width:64px;height:64px;background-color:#4f46e5;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 6px #4f46e533}.auth-logo-icon{width:32px;height:32px;color:#fff}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-size:24px;font-weight:700;color:#111827;margin-bottom:8px}.auth-subtitle{font-size:14px;color:#6b7280}.auth-error{display:flex;align-items:flex-start;gap:12px;background-color:#fef2f2;border-radius:8px;padding:12px;margin-bottom:24px;color:#b91c1c;font-size:14px;animation:shake .5s ease-in-out}.auth-error-icon{width:20px;height:20px;flex-shrink:0;color:#ef4444}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:14px;font-weight:500;color:#374151}.form-input-wrapper{position:relative;display:flex;align-items:center}.form-input-icon{margin:0 12px;color:#9ca3af;transition:color .2s ease}.form-input-icon svg{width:20px;height:20px}.form-input{width:100%;height:44px;padding:0 12px 0 44px;background-color:#f9fafb;font-size:14px;color:#111827;transition:all .2s ease}.form-input:hover{border-color:#d1d5db}.form-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 1px #4f46e5;background-color:#fff}.form-input:focus+.form-input-icon{color:#4f46e5}.form-input::-moz-placeholder{color:#9ca3af}.form-input::placeholder{color:#9ca3af}.submit-button{height:44px;margin-top:8px;display:flex;justify-content:center;align-items:center;gap:8px;padding:0 24px;background-color:#4f46e5;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.submit-button:hover:not(:disabled){background-color:#4338ca;transform:translateY(-1px)}.submit-button:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #4f46e5}.submit-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:20px;height:20px;animation:spin 1s linear infinite}.spinner-circle{stroke:currentColor;opacity:.25}.spinner-circle:nth-child(1){opacity:.75}.auth-alt-action{margin-top:24px;text-align:center;font-size:14px;color:#6b7280}.auth-link{display:inline-flex;align-items:center;gap:4px;margin-left:8px;color:#4f46e5;font-weight:500;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:#4338ca;text-decoration:underline}.auth-link-icon{width:16px;height:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.templates-page{padding:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;color:#111827;margin-bottom:.5rem}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.template-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;display:flex;flex-direction:column;transition:all .2s ease}.template-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px #0000001a}.template-preview{height:180px;background-color:#f3f4f6;overflow:hidden;position:relative}.template-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.template-card:hover .template-image{transform:scale(1.05)}.template-content{padding:1.25rem;flex:1}.template-name{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:.5rem}.template-date{font-size:.875rem;color:#6b7280}.template-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.template-actions .btn{flex:1 1 auto;min-width:0;padding:8px;display:flex;justify-content:center;align-items:center}.btn-icon{padding:8px!important;min-width:36px;width:36px;display:inline-flex;justify-content:center;align-items:center;border-radius:4px}.template-actions .btn-icon{flex:0 0 auto}.form-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;margin-bottom:2rem}.template-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;font-size:.938rem;color:#374151}.form-input{width:100%;padding:.625rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.938rem;transition:border-color .2s ease}.form-input:focus{border-color:#4f46e5;outline:none}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.file-upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem 1.5rem;transition:all .2s ease}.file-upload-area:hover{border-color:#4f46e5;background-color:#f5f5f5}.file-upload-content{display:flex;flex-direction:column;align-items:center;text-align:center}.file-upload-icon{width:3rem;height:3rem;color:#9ca3af;margin-bottom:1rem}.file-upload-text{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.file-upload-label{color:#4f46e5;font-weight:500;cursor:pointer;position:relative}.file-upload-label:hover{text-decoration:underline}.file-upload-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.file-upload-help{color:#6b7280}.file-upload-formats{font-size:.813rem;color:#6b7280;margin-bottom:.75rem}.file-selected{font-size:.875rem;color:#047857;font-weight:500}.editor-container{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.editor-container{grid-template-columns:2fr 1fr}}.editor-preview{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.editor-header{padding:1.25rem;border-bottom:1px solid #e5e7eb}.editor-title{font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:.5rem}.editor-subtitle{font-size:.875rem;color:#6b7280}.editor-canvas{position:relative;background-size:contain;background-repeat:no-repeat;background-position:center;border:1px solid #e5e7eb;margin:1.25rem;border-radius:.25rem}.canvas-element{position:absolute;cursor:move;background-color:#fff3;border:1px dashed #d1d5db;display:flex;align-items:center;justify-content:center;transition:border .2s ease}.canvas-element.selected{border:2px solid #4f46e5;background-color:#4f46e50d}.editor-footer{padding:1.25rem;border-top:1px solid #e5e7eb;background-color:#f9fafb;display:flex;justify-content:space-between;align-items:center}.properties-panel{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.panel-header{padding:1.25rem;border-bottom:1px solid #e5e7eb}.panel-title{font-size:1.125rem;font-weight:600;color:#111827}.panel-content{padding:1.25rem}.panel-empty{padding:3rem 1.5rem;text-align:center;color:#6b7280}.editor-dropzone{padding:4rem 2rem;text-align:center;border:2px dashed #d1d5db;border-radius:.5rem;background-color:#f9fafb;transition:all .2s ease}.editor-dropzone:hover,.editor-dropzone.active{border-color:#4f46e5;background-color:#f5f8ff}.dropzone-icon{width:3rem;height:3rem;color:#9ca3af;margin:0 auto 1rem}.dropzone-text{color:#6b7280;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-container{background-color:#fff;padding:20px;border-radius:8px;width:90%;max-width:500px;box-shadow:0 5px 15px #0000004d}.modal-header{margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #e5e5e5}.modal-header h3{margin:0;font-size:1.5rem;color:#333}.modal-body{margin-bottom:20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:10px}.confirmation-message{font-size:16px;margin-bottom:16px}.warning-message{display:flex;align-items:flex-start;gap:10px;padding:10px;background-color:#fff8e1;border-radius:4px;color:#856404;font-size:14px}.warning-icon{color:#f57f17;flex-shrink:0;margin-top:2px}.error-message{padding:12px;background-color:#ffebee;border-radius:4px;color:#d32f2f;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}.btn-danger{background-color:#d32f2f;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:5px}.btn-danger:hover{background-color:#b71c1c}.btn-danger:disabled{background-color:#e57373;cursor:not-allowed}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite}.editor-container{display:flex;height:calc(100vh - 100px);overflow:hidden}.editor-workspace{flex:1;overflow:auto;padding:20px;background-color:#f0f2f5}.editor-toolbar{background-color:#fff;border-bottom:1px solid #e0e0e0;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;border-radius:4px;margin-bottom:15px;box-shadow:0 1px 3px #0000001a}.editor-title{flex:1;margin-right:20px}.editor-title input{font-size:1.2rem;padding:8px 12px;width:100%;max-width:300px}.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.upload-container{display:flex;justify-content:center;align-items:center;min-height:400px;background-color:#fff;border:2px dashed #ccc;border-radius:8px;margin:20px auto;width:100%;max-width:800px}.upload-prompt{text-align:center;padding:40px}.upload-prompt p{margin-bottom:20px;font-size:1.1rem;color:#555}.loading-indicator{display:flex;justify-content:center;align-items:center;min-height:300px;font-size:1.2rem;color:#555}.editor-canvas{position:relative;margin:0 auto;background-color:#fff;box-shadow:0 0 15px #0000001a;overflow:hidden;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.canvas-element{position:absolute;background-color:#f5f5f5b3;border:1px solid transparent;padding:5px;cursor:move;overflow:hidden;display:flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:1;transition:box-shadow .2s ease}.canvas-element:hover{box-shadow:0 0 5px #0003}.canvas-element.selected{border:1px solid #3498db;box-shadow:0 0 8px #3498db80;z-index:2}.element-content{width:100%;height:100%;overflow:hidden;pointer-events:none;padding:4px;word-break:break-word}.resize-handle{position:absolute;width:8px;height:8px;background-color:#3498db;border:1px solid #fff;z-index:3}.resize-handle-nw{top:-4px;left:-4px;cursor:nw-resize}.resize-handle-ne{top:-4px;right:-4px;cursor:ne-resize}.resize-handle-sw{bottom:-4px;left:-4px;cursor:sw-resize}.resize-handle-se{bottom:-4px;right:-4px;cursor:se-resize}.resize-handle-n{top:-4px;left:50%;transform:translate(-50%);cursor:n-resize}.resize-handle-e{right:-4px;top:50%;transform:translateY(-50%);cursor:e-resize}.resize-handle-s{bottom:-4px;left:50%;transform:translate(-50%);cursor:s-resize}.resize-handle-w{left:-4px;top:50%;transform:translateY(-50%);cursor:w-resize}.properties-panel{width:320px;background-color:#fff;border-left:1px solid #e0e0e0;overflow-y:auto;height:100%;box-shadow:-2px 0 5px #0000000d}.panel-header{padding:15px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10}.panel-title{margin:0;font-size:1.2rem;font-weight:500}.panel-content{padding:15px}.panel-empty{display:flex;height:100%;align-items:center;justify-content:center;padding:20px;color:#888;text-align:center}.element-type-badge{display:inline-block;padding:6px 12px;background-color:#eaf6ff;color:#2980b9;border-radius:4px;font-size:.8rem;margin-bottom:15px;font-weight:500}.form-row{display:flex;gap:10px;margin-bottom:15px}.form-group{margin-bottom:15px;width:100%}.form-group.half{width:calc(50% - 5px)}.form-label{display:block;margin-bottom:5px;font-weight:500;font-size:.9rem}.form-input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;transition:border-color .2s}.form-input:focus{border-color:#3498db;outline:none;box-shadow:0 0 0 2px #3498db33}.form-hint{margin-top:5px;font-size:.8rem;color:#888}.color-input{height:40px;padding:2px;cursor:pointer}.form-actions{margin-top:20px;display:flex;justify-content:flex-end}.btn{padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;font-size:.9rem;border:none;transition:all .2s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-danger{background-color:#e74c3c;color:#fff}.btn-danger:hover{background-color:#c0392b}.btn-group{display:flex;gap:10px}.element-type-select{min-width:160px}.element-type-select select{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background-color:#fff;cursor:pointer}.element-type-select select:focus{border-color:#3498db;outline:none}.text-element-type{position:absolute;top:-20px;left:0;font-size:.7rem;background-color:#3498dbcc;color:#fff;padding:2px 6px;border-radius:2px;pointer-events:none;white-space:nowrap}.fixed-element{background-color:#ffebebb3}.fixed-element .text-element-type{background-color:#e74c3ccc}.dynamic-element{background-color:#ebf5ffb3}.mixed-element{background-color:#ebfff0b3}.mixed-element .text-element-type{background-color:#2ecc71cc}@media (max-width: 768px){.editor-container{flex-direction:column;height:auto}.editor-toolbar{flex-direction:column;align-items:stretch}.editor-title{margin-right:0;margin-bottom:10px}.toolbar-actions{justify-content:flex-end}.properties-panel{width:100%;height:auto;max-height:300px;border-left:none;border-top:1px solid #e0e0e0}}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s linear infinite;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.auto-save-message{margin-top:10px;padding:8px 12px;border-radius:4px;font-size:14px;animation:fadeIn .3s}.auto-save-message.success{background-color:#e6f7e6;border:1px solid #c3e6cb;color:#155724}.auto-save-message.warning{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root{--color-primary: #4f46e5;--color-primary-dark: #4338ca;--color-primary-light: #818cf8;--color-secondary: #6b7280;--color-secondary-dark: #4b5563;--color-secondary-light: #9ca3af;--color-success: #10b981;--color-success-dark: #047857;--color-success-light: #d1fae5;--color-danger: #dc2626;--color-danger-dark: #b91c1c;--color-danger-light: #fee2e2;--color-warning: #f59e0b;--color-warning-dark: #d97706;--color-warning-light: #fef3c7;--color-info: #0ea5e9;--color-info-dark: #0284c7;--color-info-light: #e0f2fe;--color-black: #111827;--color-gray-900: #1f2937;--color-gray-800: #374151;--color-gray-700: #4b5563;--color-gray-600: #6b7280;--color-gray-500: #9ca3af;--color-gray-400: #d1d5db;--color-gray-300: #e5e7eb;--color-gray-200: #f3f4f6;--color-gray-100: #f9fafb;--color-white: #ffffff;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--spacing-0: 0;--spacing-px: 1px;--spacing-0-5: .125rem;--spacing-1: .25rem;--spacing-1-5: .375rem;--spacing-2: .5rem;--spacing-2-5: .625rem;--spacing-3: .75rem;--spacing-3-5: .875rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-none: 0;--radius-sm: .125rem;--radius-md: .25rem;--radius-lg: .375rem;--radius-xl: .5rem;--radius-2xl: .75rem;--radius-3xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-lg: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-xl: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-2xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .1s;--transition-normal: .2s;--transition-slow: .3s;--transition-ease: cubic-bezier(.4, 0, .2, 1);--z-0: 0;--z-10: 10;--z-20: 20;--z-30: 30;--z-40: 40;--z-50: 50;--z-auto: auto;--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}body{font-family:var(--font-family);color:var(--color-gray-800);line-height:1.5;background-color:var(--color-gray-100)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-normal) var(--transition-ease)}a:hover{color:var(--color-primary-dark)}a.btn:hover{color:var(--color-white)}button,input,select,textarea{font-family:var(--font-family)}@media print{body{background-color:var(--color-white)}.no-print{display:none!important}.print-only{display:block!important}a{text-decoration:none;color:var(--color-gray-800)}.print-container{padding:0;margin:0;box-shadow:none}}
