body{font-family:sans-serif;line-height:1.6;background-color:#f4f4f9;color:#333;margin:0;padding:20px}.app-container{max-width:900px;margin:auto;background:#fff;padding:30px;box-shadow:0 4px 8px #0000001a;border-radius:8px}h1,h2{color:#4a4a4a;margin-top:0}h3{color:#4a4a4a}.step-container{padding:20px}.submit-button{display:inline-block;padding:15px 30px;font-size:18px;color:#fff;background-color:#007bff;border:none;border-radius:4px;cursor:pointer;margin-top:20px;text-align:center}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}.help-text{margin-top:10px;color:#888;font-style:italic}.back-button{padding:10px 20px;font-size:16px;color:#007bff;background-color:transparent;border:1px solid #007bff;border-radius:4px;cursor:pointer}.back-button:hover{background-color:#e6f2ff}@media (max-width: 1024px){.app-container{max-width:95%;margin:10px auto;padding:20px}.tabs-container{flex-direction:column}.tab-buttons{flex-wrap:wrap;gap:8px}.tab-button{min-width:auto;flex:1 1 calc(33.333% - 8px)}.sub-tab-buttons{flex-wrap:wrap;gap:6px}.sub-tab-button{flex:1 1 calc(50% - 6px);min-width:120px}}@media (max-width: 768px){body{padding:10px;font-size:14px}.app-container{padding:15px;border-radius:4px;box-shadow:0 2px 4px #0000001a}h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}.step-container{padding:15px}.progress-indicator{flex-direction:column;gap:15px;padding:15px}.progress-step{margin:0}.step-line{width:3px;height:40px;transform:rotate(90deg)}.step-label{position:static;transform:none;margin-top:8px;text-align:center}.tab-buttons{flex-direction:column;gap:8px}.tab-button{flex:none;min-width:100%;padding:12px;font-size:14px}.sub-tab-buttons{flex-direction:column;gap:6px}.sub-tab-button{flex:none;min-width:100%;padding:10px 12px}.input-group{margin-bottom:20px}.input-group label{font-size:14px;margin-bottom:6px}.input-group input,.input-group select,.input-group textarea{font-size:16px;padding:12px}.submit-button,.back-button{width:100%;margin:10px 0;padding:15px;font-size:16px}.tree-view{font-size:14px}.nested-list{padding-left:15px}.checkbox-label{padding:12px 10px}.input-group-row{flex-direction:column;gap:0}.input-group.half-width{margin-bottom:1rem}.validation-section{padding:15px;margin:15px 0}.pending-forms ul{margin-left:15px}.validation-summary{padding:6px 10px}}@media (max-width: 480px){.app-container{margin:5px;padding:10px}.step-circle{width:32px;height:32px;font-size:14px}.tab-button-content{flex-direction:column;gap:4px}.tab-id{font-size:12px}.tab-status{font-size:10px}}*{transition:all .2s ease}.step-container{animation:slideIn .4s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tab-content{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tab-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.sub-tab-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #007bff4d}.all-complete-message{animation:pulse 2s ease-in-out}.tab-button.active{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #007bff66}70%{box-shadow:0 0 0 10px #007bff00}to{box-shadow:0 0 #007bff00}}.loading{position:relative;pointer-events:none}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;transform:translate(-50%,-50%)}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.popup{animation:popIn .3s ease-out}@keyframes popIn{0%{transform:translate(-50%) scale(.8);opacity:0}to{transform:translate(-50%) scale(1);opacity:1}}input:focus,select:focus,textarea:focus{transform:scale(1.02);box-shadow:0 0 0 3px #007bff40}.checkbox-label:hover{transform:translate(4px)}.completion-indicator{animation:bounceIn .5s ease}@keyframes bounceIn{0%,20%,40%,60%,80%{transform:translateY(0)}50%{transform:translateY(-10px)}}.validation-error{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.spinner-circle{position:relative;border-radius:50%;border:3px solid #f3f3f3;border-top:3px solid #2563eb;animation:spin 1s linear infinite}.spinner-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60%;height:60%;border-radius:50%;border:2px solid transparent;border-top:2px solid #60a5fa;animation:spin .8s linear infinite reverse}.spinner-small .spinner-circle{width:20px;height:20px;border-width:2px}.spinner-small .spinner-inner{border-width:1px}.spinner-medium .spinner-circle{width:40px;height:40px;border-width:3px}.spinner-medium .spinner-inner{border-width:2px}.spinner-large .spinner-circle{width:60px;height:60px;border-width:4px}.spinner-large .spinner-inner{border-width:3px}.spinner-message{font-size:14px;color:#6b7280;text-align:center;font-weight:500}.spinner-small .spinner-message{font-size:12px}.spinner-large .spinner-message{font-size:16px}.spinner-overlay{position:fixed;inset:0;background-color:#fffc;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:9999}.spinner-overlay .loading-spinner{background:#fff;padding:24px 32px;border-radius:12px;box-shadow:0 10px 25px #0000001a;border:1px solid #e5e7eb}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner:hover .spinner-message{color:#374151}@media (max-width: 768px){.spinner-overlay .loading-spinner{padding:20px 24px;margin:0 16px}.spinner-message{font-size:13px}}@media (prefers-reduced-motion: reduce){.spinner-circle,.spinner-inner{animation:none}.spinner-circle{border-top-color:#9ca3af}.spinner-inner{border-top-color:#d1d5db}}@media (prefers-color-scheme: dark){.spinner-circle{border-color:#374151;border-top-color:#60a5fa}.spinner-inner{border-top-color:#93c5fd}.spinner-message{color:#9ca3af}.spinner-overlay{background-color:#111827cc}.spinner-overlay .loading-spinner{background:#1f2937;border-color:#374151}}.error-fallback{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;align-items:center;justify-content:center;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.error-container{background:#fff;border-radius:16px;padding:40px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;text-align:center;border:1px solid #e2e8f0}.error-icon{margin:0 auto 24px;display:flex;justify-content:center}.error-icon svg{animation:pulse 2s infinite}.error-title{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:16px;line-height:1.2}.error-description{font-size:16px;color:#6b7280;margin-bottom:32px;line-height:1.6}.error-actions{display:flex;gap:16px;justify-content:center;margin-bottom:32px;flex-wrap:wrap}.btn-primary{background:#2563eb;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-secondary{background:#f8fafc;color:#374151;border:2px solid #e5e7eb;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.btn-secondary:hover{background:#f1f5f9;border-color:#d1d5db;transform:translateY(-1px)}.error-details-section{border-top:1px solid #e5e7eb;padding-top:24px;margin-top:24px}.btn-details{background:none;border:none;color:#2563eb;font-size:14px;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:6px;transition:all .2s ease;margin-bottom:16px}.btn-details:hover{background:#eff6ff;color:#1d4ed8}.error-details{text-align:left;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-top:16px}.error-details h3{font-size:18px;font-weight:600;color:#374151;margin-bottom:16px;text-align:center}.error-info{margin-bottom:16px}.error-info h4{font-size:14px;font-weight:600;color:#4b5563;margin-bottom:8px}.error-info pre{background:#1f2937;color:#f9fafb;padding:12px;border-radius:6px;font-size:12px;line-height:1.4;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-stack{max-height:200px;overflow-y:auto}.btn-report{background:#059669;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;margin:16px auto 0}.btn-report:hover{background:#047857;transform:translateY(-1px)}.error-help{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.error-help p{font-size:14px;color:#6b7280;line-height:1.6;margin:0}.error-help strong{color:#374151}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.error-container{padding:24px;margin:16px}.error-title{font-size:24px}.error-actions{flex-direction:column;align-items:center}.btn-primary,.btn-secondary{width:100%;max-width:280px;justify-content:center}.error-info pre{font-size:11px}}@media (max-width: 480px){.error-fallback{padding:16px}.error-container{padding:20px}.error-title{font-size:20px}.error-description{font-size:14px}}@media (prefers-color-scheme: dark){.error-fallback{background:linear-gradient(135deg,#0f172a,#1e293b)}.error-container{background:#1e293b;border-color:#334155}.error-title{color:#f1f5f9}.error-description{color:#cbd5e1}.btn-secondary{background:#334155;color:#f1f5f9;border-color:#475569}.btn-secondary:hover{background:#475569}.error-details{background:#0f172a;border-color:#334155}.error-details h3{color:#f1f5f9}.error-info h4,.error-help p{color:#cbd5e1}.error-help strong{color:#f1f5f9}}.tree-view{list-style-type:none;padding:0;transition:all .3s ease-in-out}.tree-item{margin-bottom:10px}.nested-list{list-style-type:none;padding-left:20px;margin-top:5px;overflow:hidden;transition:all .3s ease-in-out}.item-header{display:flex;align-items:center}.expand-indicator{margin-right:8px;font-size:12px;color:#666;width:12px;text-align:center;-webkit-user-select:none;user-select:none}.item-header input[type=checkbox]{margin-right:10px}.tabs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.tabs-container{border:1px solid #ddd;border-radius:6px;overflow:hidden}.tab-buttons{display:flex;background-color:#f2f2f2;border-bottom:1px solid #ddd;overflow-x:auto;white-space:nowrap}.tab-button{flex:1;padding:12px 20px;border:none;background-color:transparent;cursor:pointer;font-weight:700;color:#555;border-right:1px solid #ddd}.tab-button.active{background-color:#fff;border-top:2px solid #007bff;border-bottom:1px solid #fff;color:#007bff}.tab-content{padding:20px}.sub-tab-buttons{display:flex;gap:8px;margin-bottom:20px;padding:10px;background-color:#f8f9fa;border-radius:6px;flex-wrap:wrap}.sub-tab-button{padding:8px 16px;border:1px solid #dee2e6;background-color:#fff;border-radius:4px;cursor:pointer;font-size:.85em;transition:all .2s ease;white-space:nowrap;position:relative;display:flex;align-items:center;gap:6px}.sub-tab-button.completed{border-color:#28a745;background-color:#f8fff9}.sub-tab-button.completed .completion-indicator{color:#28a745;font-weight:700;font-size:.9em}.sub-tab-button:hover{background-color:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.sub-tab-button.completed:hover{background-color:#e8f5e8;border-color:#28a745}.sub-tab-button.active{background-color:#007bff;color:#fff;border-color:#007bff;box-shadow:0 2px 4px #007bff4d}.sub-tab-button.active .completion-indicator{color:#fff}.sub-tab-button.active:hover{background-color:#0056b3;border-color:#0056b3;transform:translateY(-1px)}.sub-tab-content{background-color:#fff;border:1px solid #e9ecef;border-radius:6px;padding:20px}.sub-tabs-container{margin-top:15px}.readonly-input{background-color:#f8f9fa;color:#6c757d;font-weight:500}.no-publicos-message{text-align:center;padding:40px 20px;background-color:#f8f9fa;border-radius:6px;color:#6c757d}.no-publicos-message p{margin:10px 0}.publico-header{color:#007bff;font-size:1.1em;font-weight:600;margin-bottom:15px;padding-bottom:8px;border-bottom:2px solid #e7f3ff}.publico-navigation{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:20px;padding:15px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.nav-button{padding:8px 20px;border:1px solid #007bff;background-color:#007bff;color:#fff;border-radius:4px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s ease;display:flex;align-items:center;gap:6px}.nav-button:hover:not(:disabled){background-color:#0056b3;border-color:#0056b3;transform:translateY(-1px);box-shadow:0 2px 4px #007bff4d}.nav-button:disabled{background-color:#e9ecef;border-color:#dee2e6;color:#6c757d;cursor:not-allowed;opacity:.6}.nav-indicator{font-size:.9em;font-weight:600;color:#495057;min-width:80px;text-align:center}.form-group{display:flex;flex-direction:column;gap:15px}.input-group{display:flex;flex-direction:column;gap:5px}.input-group label{font-weight:700;color:#444}.input-group select,.input-group textarea,.input-group input[type=date],.input-group input[type=text],.input-group input[type=email]{width:100%;padding:8px;box-sizing:border-box;border:1px solid #ccc;border-radius:4px;font-size:14px}.input-group textarea{min-height:80px;resize:vertical}.final-submit{width:100%}.tipologia-info{margin-top:8px;padding:8px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;border-left:4px solid #007bff}.tipologia-info small{color:#6c757d;line-height:1.4}.tipologia-info strong{color:#495057}.input-group-row{display:flex;gap:1rem;margin-bottom:1rem}.input-group.half-width{flex:1;margin-bottom:0}.progress-indicator{display:flex;justify-content:center;align-items:center;margin-bottom:30px;padding:20px 0;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:1px solid #dee2e6}.progress-step{display:flex;align-items:center;position:relative;margin:0 10px}.step-circle{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;transition:all .3s ease;border:3px solid #dee2e6;background:#fff;color:#6c757d}.step-circle.active{background:#007bff;color:#fff;border-color:#007bff;box-shadow:0 0 0 4px #007bff40;transform:scale(1.1)}.step-circle.completed{background:#28a745;color:#fff;border-color:#28a745}.step-circle.completed:before{content:"✓";font-size:18px}.step-line{width:80px;height:3px;background:#dee2e6;transition:background-color .3s ease}.step-line.completed{background:#28a745}.step-label{position:absolute;top:50px;left:50%;transform:translate(-50%);font-size:12px;font-weight:600;color:#6c757d;white-space:nowrap}.step-label.active{color:#007bff}.step-label.completed{color:#28a745}.required{color:#dc3545;font-weight:700}.optional{color:#6c757d;font-size:.85em;font-style:italic}.field-default{border:2px solid #ced4da;background-color:#fff}.field-required{border:2px solid #dc3545!important}.field-valid{border:2px solid #28a745!important;background-color:#f8fff8}.field-invalid{border:2px solid #dc3545!important;background-color:#fff5f5}.field-optional{border:2px solid #6c757d;background-color:#f8f9fa}.field-error{display:block;color:#dc3545;font-size:.875rem;margin-top:.25rem;font-style:italic}.sub-tab-button.empty{border-color:#dee2e6;background-color:#fff;color:#6c757d}.sub-tab-button.in-progress{border-color:#ffc107;background-color:#fff8e1;color:#856404}.sub-tab-button.completed{border-color:#28a745;background-color:#d4edda;color:#155724}.check-icon{color:#28a745;font-weight:700;margin-left:5px}.warning-icon{color:#ffc107;font-weight:700;margin-left:5px}.empty-icon{color:#6c757d;font-weight:700;margin-left:5px}.validation-summary{padding:8px 12px;border-radius:4px;font-size:.9em;display:flex;flex-direction:column;gap:10px;margin:10px 0}.validation-summary.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.pending-count{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7;padding:4px 8px;border-radius:4px;font-size:.85em}.completed-icon{color:#28a745;font-weight:700;margin-right:5px}.validation-section{margin:20px 0;padding:20px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.validation-header{margin-bottom:12px;color:#495057}.progress-info{margin-bottom:8px;font-weight:500;color:#495057}.validation-bar{width:100%;height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden;margin-bottom:12px}.validation-progress{height:100%;background:linear-gradient(90deg,#28a745,#20c997);transition:width .3s ease}.pending-forms ul{margin:8px 0 0 20px;padding:0}.pending-forms li{margin:4px 0;font-size:.9em}.objetivo-id{font-weight:700;color:#007bff}.publico-name{font-weight:500;color:#495057;margin:0 5px}.pending-fields{color:#dc3545;font-size:.85em}.more-items{color:#6c757d;font-style:italic}.validation-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;padding:15px;border-radius:6px;text-align:center;font-size:1.1em}.success-icon{margin-right:8px;font-size:1.2em}.progress-summary{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.progress-text{font-weight:600;color:#4a4a4a;white-space:nowrap}.progress-bar{flex:1;min-width:200px;height:8px;background-color:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.next-pending-button{padding:6px 12px;font-size:12px;background-color:#ff9800;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;white-space:nowrap}.next-pending-button:hover{background-color:#f57c00}.tab-button.completed{border-left:4px solid #4CAF50}.tab-button .status-indicator{font-size:12px;font-weight:700;padding:2px 6px;border-radius:12px;min-width:20px;text-align:center}.tab-button .status-indicator.complete{background-color:#4caf50;color:#fff}.tab-button .status-indicator.pending{background-color:#ff9800;color:#fff}.sub-tab-button.completed{border-bottom:3px solid #4CAF50}.sub-tab-button .status-badge{margin-left:8px;font-size:12px;font-weight:700;padding:2px 6px;border-radius:50%;min-width:18px;min-height:18px;display:inline-flex;align-items:center;justify-content:center}.sub-tab-button .status-badge.complete{background-color:#4caf50;color:#fff}.sub-tab-button .status-badge.pending{background-color:#ff9800;color:#fff}.validation-info{margin:20px 0}.pending-forms-warning{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:15px;margin-bottom:15px}.pending-forms-warning h4{margin:0 0 10px;color:#856404}.pending-forms-warning ul{margin:0;padding-left:20px}.pending-forms-warning li{margin-bottom:5px;color:#856404}.all-complete-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:6px;padding:15px;color:#155724;font-weight:600;text-align:center;animation:pulse 2s ease-in-out}optgroup{font-weight:700;color:#495057;background-color:#f8f9fa}.sub-option{font-weight:400;color:#6c757d;padding-left:15px;font-size:.9em}select option.sub-option{padding-left:20px}.publicos-alvo-selection{max-width:100%}.selection-instruction{margin-bottom:20px;color:#6c757d;font-size:.95em}.publicos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-bottom:25px;padding:15px;background-color:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.publico-checkbox{display:flex;align-items:center;padding:10px 12px;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.publico-checkbox:hover{background-color:#f0f8ff;border-color:#007bff;transform:translateY(-1px);box-shadow:0 2px 4px #007bff1a}.publico-checkbox input[type=checkbox]{margin-right:10px;width:16px;height:16px;accent-color:#007bff}.checkbox-label{font-size:.9em;color:#495057;line-height:1.3}.publico-checkbox input:checked+.checkbox-label{font-weight:600;color:#007bff}.selection-summary{padding:15px;background-color:#e7f3ff;border:1px solid #b3d9ff;border-radius:6px;margin-bottom:20px}.selection-summary strong{color:#0056b3}.selected-count{color:#007bff;font-weight:500}.tab-button-content{display:flex;flex-direction:column;align-items:center;text-align:center}.tab-id{font-weight:600;margin-bottom:2px}.tab-status{font-size:.75em;color:#6c757d;font-weight:400}.tab-button.active .tab-status{color:#007bff}.step-navigation{margin-top:30px;padding-top:20px;border-top:1px solid #e9ecef}
