:root{--green-900: #0d2b1e;--green-800: #14402d;--green-700: #1a5c3e;--green-600: #217a52;--green-400: #34b87a;--green-200: #a3e4c2;--green-50: #edfaf4;--amber-500: #d97706;--amber-400: #f59e0b;--amber-100: #fef3c7;--gray-900: #111827;--gray-700: #374151;--gray-500: #6b7280;--gray-200: #e5e7eb;--gray-50: #f9fafb;--white: #ffffff;--font-display: "DM Serif Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background:var(--gray-50);color:var(--gray-900);min-height:100vh}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;max-width:860px;width:100%;margin:0 auto;padding:2rem 1.25rem 3rem}.site-header{background:var(--green-900);border-bottom:3px solid var(--green-600)}.header-inner{max-width:860px;margin:0 auto;padding:1.1rem 1.25rem;display:flex;align-items:center;justify-content:space-between}.header-brand{display:flex;flex-direction:column;gap:1px}.brand-region{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green-400)}.brand-title{font-family:var(--font-display);font-size:1.35rem;color:var(--white);line-height:1.2}.brand-sub{font-size:.75rem;font-weight:500;color:var(--green-200);letter-spacing:.05em}.header-badge{background:var(--green-700);border:1px solid var(--green-600);border-radius:var(--radius-sm);padding:.25rem .75rem;font-size:.8rem;font-weight:600;color:var(--green-200);letter-spacing:.08em}.tabs-redes{display:flex;gap:4px;overflow-x:auto;padding-bottom:0;margin-bottom:1rem;scrollbar-width:none;border-bottom:2px solid var(--gray-200)}.tabs-redes::-webkit-scrollbar{display:none}.tab-red{padding:.55rem 1.1rem;font-size:.88rem;font-weight:500;color:var(--gray-500);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:color .15s,border-color .15s;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab-red:hover{color:var(--green-700)}.tab-red.active{color:var(--green-800);font-weight:600;border-bottom-color:var(--green-600)}.tabs-categorias{display:flex;gap:6px;margin-bottom:1.5rem;flex-wrap:wrap}.tab-cat{padding:.4rem 1rem;font-size:.82rem;font-weight:500;color:var(--gray-500);background:var(--white);border:1px solid var(--gray-200);border-radius:999px;transition:all .15s}.tab-cat:hover{color:var(--green-700);border-color:var(--green-400)}.tab-cat.active{background:var(--green-800);color:var(--white);border-color:var(--green-800);font-weight:600}.reportes-lista{display:flex;flex-direction:column;gap:8px}.reportes-empty{padding:2.5rem;text-align:center;color:var(--gray-500);font-size:.9rem;background:var(--white);border:1px dashed var(--gray-200);border-radius:var(--radius-md)}.reporte-card{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.1rem;background:var(--white);border:1px solid var(--gray-200);border-left:3px solid var(--green-600);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow .15s,border-color .15s,transform .12s;gap:1rem}.reporte-card:hover{box-shadow:var(--shadow-md);border-color:var(--gray-200);border-left-color:var(--green-400);transform:translateY(-1px)}.reporte-card.inactivo{opacity:.55;pointer-events:none;border-left-color:var(--gray-200)}.reporte-left{display:flex;align-items:center;gap:.9rem;min-width:0}.reporte-badge{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--green-50);border:1px solid var(--green-200);border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;color:var(--green-800);letter-spacing:.02em}.reporte-info{display:flex;flex-direction:column;gap:2px;min-width:0}.reporte-nombre{font-size:.9rem;font-weight:500;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reporte-periodo{font-size:.75rem;color:var(--gray-500)}.reporte-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.reporte-estado{font-size:.72rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;letter-spacing:.04em}.reporte-estado.activo{background:var(--green-50);color:var(--green-700);border:1px solid var(--green-200)}.reporte-estado.pendiente{background:var(--amber-100);color:var(--amber-500);border:1px solid #fde68a}.reporte-icon{width:18px;height:18px;color:var(--gray-500);flex-shrink:0}.reporte-card:hover .reporte-icon{color:var(--green-700)}.site-footer{background:var(--green-900);border-top:1px solid var(--green-800);padding:.9rem 1.25rem}.footer-inner{max-width:860px;margin:0 auto;display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--green-200);opacity:.7}.footer-sep{opacity:.4}@media (max-width: 600px){.reporte-nombre{font-size:.82rem}.reporte-badge{width:30px;height:30px;font-size:.68rem}.tab-red{padding:.45rem .8rem;font-size:.82rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#0a140f8c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{position:relative;background:var(--white);border:1px solid var(--gray-200);border-radius:20px;padding:2rem;width:100%;max-width:440px;box-shadow:0 24px 60px #0000002e,0 4px 16px #00000014;animation:card-in .25s cubic-bezier(.34,1.56,.64,1)}@keyframes card-in{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--gray-500);transition:background .15s,color .15s}.modal-close:hover{background:var(--gray-50);color:var(--gray-900)}.modal-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.modal-icon-wrap{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--green-50);border:1px solid var(--green-200);border-radius:14px;color:var(--green-700)}.modal-title-block{display:flex;flex-direction:column;gap:3px;padding-top:2px}.modal-badge{font-size:.7rem;font-weight:700;letter-spacing:.08em;color:var(--green-700);background:var(--green-50);border:1px solid var(--green-200);border-radius:4px;padding:1px 7px;align-self:flex-start}.modal-title{font-size:1rem;font-weight:600;color:var(--gray-900);line-height:1.35}.modal-periodo{font-size:.75rem;color:var(--gray-500)}.modal-divider{height:1px;background:var(--gray-200);margin-bottom:1.25rem}.modal-question{font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500);margin-bottom:.75rem}.modal-options{display:flex;flex-direction:column;gap:10px}.modal-option{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;border-radius:14px;border:1.5px solid transparent;text-align:left;width:100%;transition:all .18s;cursor:pointer}.modal-option-icon{flex-shrink:0;width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:10px}.modal-option-text{flex:1;display:flex;flex-direction:column;gap:2px}.modal-option-label{font-size:.92rem;font-weight:600}.modal-option-desc{font-size:.78rem}.modal-option-arrow{flex-shrink:0;opacity:.5;transition:opacity .15s,transform .15s}.modal-option:hover .modal-option-arrow{opacity:1;transform:translate(3px)}.modal-option--primary{background:var(--green-50);border-color:var(--green-200);color:var(--green-900)}.modal-option--primary .modal-option-icon{background:var(--green-700);color:var(--white)}.modal-option--primary .modal-option-desc{color:var(--green-700)}.modal-option--primary:hover{background:var(--green-700);border-color:var(--green-700);color:var(--white)}.modal-option--primary:hover .modal-option-icon{background:#fff3}.modal-option--primary:hover .modal-option-desc{color:var(--green-200)}.modal-option--secondary{background:var(--amber-100);border-color:#fde68a;color:var(--gray-900)}.modal-option--secondary .modal-option-icon{background:var(--amber-500);color:var(--white)}.modal-option--secondary .modal-option-desc{color:var(--amber-500)}.modal-option--secondary:hover{background:var(--amber-500);border-color:var(--amber-500);color:var(--white)}.modal-option--secondary:hover .modal-option-icon{background:#fff3}.modal-option--secondary:hover .modal-option-desc{color:#fef3c7}.reporte-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.reporte-btn{display:inline-flex;align-items:center;gap:5px;padding:.38rem .75rem;border-radius:8px;font-size:.78rem;font-weight:600;letter-spacing:.02em;border:1.5px solid transparent;transition:all .15s;white-space:nowrap;text-decoration:none}.reporte-btn--acceso{background:var(--amber-100);border-color:#fde68a;color:var(--amber-500)}.reporte-btn--acceso:hover{background:var(--amber-500);border-color:var(--amber-500);color:var(--white)}.reporte-btn--ver{background:var(--green-50);border-color:var(--green-200);color:var(--green-700)}.reporte-btn--ver:hover{background:var(--green-700);border-color:var(--green-700);color:var(--white)}.reporte-btn--ver.disabled{opacity:.4;pointer-events:none}@media (max-width: 480px){.reporte-btn span{display:none}.reporte-btn{padding:.4rem .5rem}}.form-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0a140f8c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:overlay-in .2s ease}.form-modal-card{position:relative;background:var(--white);border:1px solid var(--gray-200);border-radius:20px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #0000002e;animation:card-in .25s cubic-bezier(.34,1.56,.64,1);overflow:hidden}.form-modal-card--result{max-width:400px}.form-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.5rem 1.5rem 1.25rem;border-bottom:1px solid var(--gray-200);flex-shrink:0}.form-modal-title{font-family:var(--font-display);font-size:1.2rem;color:var(--gray-900);line-height:1.2}.form-modal-subtitle{font-size:.8rem;color:var(--gray-500);margin-top:3px}.form-modal-x{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--gray-500);transition:background .15s,color .15s}.form-modal-x:hover{background:var(--gray-50);color:var(--gray-900)}.form-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem;scrollbar-width:thin;scrollbar-color:var(--gray-200) transparent}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-field{display:flex;flex-direction:column;gap:5px}.form-field--indent{padding-left:1rem;border-left:2px solid var(--green-200)}.form-label{font-size:.8rem;font-weight:600;color:var(--gray-700)}.form-label span{color:var(--green-600)}.form-input,.form-select{padding:.55rem .85rem;font-size:.88rem;font-family:var(--font-body);color:var(--gray-900);background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);transition:border-color .15s,box-shadow .15s;outline:none;width:100%}.form-input::placeholder{color:var(--gray-500)}.form-input:focus,.form-select:focus{border-color:var(--green-600);box-shadow:0 0 0 3px #217a521f}.form-input.err,.form-select.err{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-error{font-size:.74rem;color:#ef4444;font-weight:500}.form-hint{font-size:.74rem;color:var(--gray-500)}.form-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:1rem 1.5rem;border-top:1px solid var(--gray-200);flex-shrink:0}.form-btn-cancel{padding:.55rem 1.1rem;font-size:.85rem;font-weight:500;color:var(--gray-500);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);background:var(--white);transition:all .15s}.form-btn-cancel:hover{background:var(--gray-50);color:var(--gray-700)}.form-btn-submit{display:inline-flex;align-items:center;gap:6px;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600;color:var(--white);background:var(--green-700);border:1.5px solid var(--green-700);border-radius:var(--radius-sm);transition:all .15s}.form-btn-submit:hover:not(:disabled){background:var(--green-800);border-color:var(--green-800)}.form-btn-submit:disabled{opacity:.6;cursor:not-allowed}.form-result{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:2.5rem 2rem}.form-result h2{font-size:1.1rem;font-weight:700}.form-result p{font-size:.85rem;color:var(--gray-500);line-height:1.5}.form-result--success{color:var(--green-700)}.form-result--success h2{color:var(--green-800)}.form-result--error{color:#ef4444}.form-result--error h2{color:#b91c1c}.form-btn-close-result{margin-top:.5rem;padding:.55rem 1.5rem;font-size:.85rem;font-weight:600;color:var(--white);background:var(--green-700);border-radius:var(--radius-sm);transition:background .15s}.form-btn-close-result:hover{background:var(--green-800)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}@media (max-width: 480px){.form-row-2{grid-template-columns:1fr}.form-modal-card{border-radius:16px}}
