:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-success: #10b981;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-light: #fee2e2;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-bg-primary: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-text-primary: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-on-primary: #ffffff;--color-border-light: #e5e7eb;--color-border-medium: #d1d5db;--color-border-dark: #9ca3af;--font-family-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--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;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--focus-ring-width: 2px;--focus-ring-offset: 2px;--focus-ring-color: var(--color-primary-500);--focus-ring: 0 0 0 var(--focus-ring-offset) white, 0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-sans);font-size:var(--text-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-secondary)}.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}.focus-visible:focus-visible{outline:none;box-shadow:var(--focus-ring)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.container{width:100%;max-width:1280px;margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}@media(min-width:640px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}@media(min-width:1024px){.container{padding-left:var(--space-8);padding-right:var(--space-8)}}:root{font-family:var(--font-family-sans, system-ui, Avenir, Helvetica, Arial, sans-serif);line-height:1.5;font-weight:400;color-scheme:light;color:var(--color-text-primary, #111827);background-color:var(--color-bg-secondary, #f9fafb);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-primary-600, #2563eb);text-decoration:inherit}a:hover{color:var(--color-primary-700, #1d4ed8)}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:var(--color-bg-secondary, #f9fafb)}#root{min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:2.5rem;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;font-weight:700;color:#2d3748;margin:0 0 .5rem}.login-header p{font-size:.95rem;color:#718096;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.error-message{background:#fed7d7;color:#c53030;padding:.75rem 1rem;border-radius:6px;font-size:.9rem;border:1px solid #fc8181}.form-group input{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center}.login-hint{font-size:.85rem;color:#a0aec0;margin:0;padding:.75rem;background:#f7fafc;border-radius:6px}.dashboard{display:flex;min-height:100vh;width:100%;overflow:hidden;background-color:var(--color-bg-secondary, #f9fafb);box-sizing:border-box}.sidebar{width:260px;background:#2d3748;color:#fff;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:1.5rem 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center}.sidebar-header h2{font-size:1.5rem;font-weight:700;margin:0;text-align:center;width:100%}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;color:#cbd5e0;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.nav-item:hover{background:#ffffff0d;color:#fff}.nav-item.active{background:#667eea26;color:#fff;border-left-color:#667eea}.nav-icon{font-size:1.25rem}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--color-bg-secondary, #f7fafc)}.header{background:#fff;border-bottom:1px solid #e2e8f0;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.header-left{display:flex;align-items:center;gap:1rem}.page-title{font-size:1.5rem;font-weight:600;color:#2d3748;margin:0}.header-right,.user-menu{display:flex;align-items:center;gap:1rem}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-email{font-size:.9rem;font-weight:500;color:#2d3748}.user-role{font-size:.75rem;color:#718096;text-transform:capitalize}.logout-button{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s}.logout-button:hover{background:#5568d3}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-6, 1.5rem);min-height:0;width:100%;box-sizing:border-box}@media(max-width:1024px){.sidebar{width:200px}.page-content{padding:var(--space-4, 1rem)}}@media(max-width:640px){.dashboard{flex-direction:column}.sidebar{width:100%;height:auto;max-height:60px;flex-shrink:0}.sidebar-header{padding:1rem}.sidebar-header h2{font-size:1.25rem}.sidebar-nav{display:none}.main-content{flex:1;min-height:calc(100vh - 60px)}.header{padding:.75rem 1rem}.page-title{font-size:1.25rem}.page-content{padding:var(--space-3, .75rem)}}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;border-left:4px solid;min-width:300px;max-width:500px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-message{flex:1;font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--line-height-normal);color:var(--color-text-primary)}.toast-close{flex-shrink:0;background:none;border:none;padding:var(--space-1);cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.toast-close:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.toast-success{border-left-color:var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-left-color:var(--color-error)}.toast-error .toast-icon{color:var(--color-error)}.toast-warning{border-left-color:var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{border-left-color:var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}@media(prefers-reduced-motion:reduce){.toast{animation:none}}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.toast-container>*{pointer-events:auto}@media(max-width:640px){.toast-container{top:var(--space-2);right:var(--space-2);left:var(--space-2)}.toast{min-width:unset;max-width:unset}}.dashboard-home{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;font-weight:600;color:#1a1a1a;margin-bottom:.5rem}.dashboard-header p{font-size:1rem;color:#666}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr)!important;gap:1.5rem;margin-bottom:2rem;max-width:100%}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1.5rem;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.stat-icon{font-size:3rem;width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#0000000d}.stat-consorcios .stat-icon{background:#3b82f61a}.stat-unidades .stat-icon{background:#10b9811a}.stat-vecinos .stat-icon{background:#f973161a}.stat-reclamos .stat-icon{background:#a855f71a}.stat-content{flex:1}.stat-label{font-size:.875rem;color:#666;margin-bottom:.5rem;font-weight:500}.stat-value{font-size:2rem;font-weight:700;color:#1a1a1a}.widgets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem;margin-bottom:2rem}.widget{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.widget-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.widget-header h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.widget-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;background:#f3f4f6;color:#6b7280}.widget-badge.status-active{background:#10b9811a;color:#059669}.widget-content{padding:1.5rem}.widget-content.placeholder{text-align:center;padding:2rem 1.5rem}.placeholder-icon{font-size:3rem;margin-bottom:1rem}.widget-content.placeholder p{color:#666;margin-bottom:1.5rem}.feature-list{list-style:none;padding:0;margin:0;text-align:left}.feature-list li{color:#666;font-size:.875rem;position:relative;padding:.5rem 0 .5rem 1.5rem}.feature-list li:before{content:"•";position:absolute;left:.5rem;color:#3b82f6;font-weight:700}.activity-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.activity-section h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin-bottom:1.5rem}.activity-log{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;gap:1rem;padding:1rem;border-radius:8px;background:#f9fafb;transition:background .2s}.activity-item:hover{background:#f3f4f6}.activity-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-content{flex:1}.activity-title{font-weight:600;color:#1a1a1a;margin-bottom:.25rem}.activity-meta{font-size:.875rem;color:#666}.attention-reclamos-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-top:2rem}.attention-reclamos-section .section-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center}.attention-reclamos-section .section-header h2{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0;display:flex;align-items:center;gap:.5rem}.tooltip-container{position:relative;display:inline-block;margin-left:.5rem}.tooltip-icon{font-size:1rem;cursor:help;color:#666;display:inline-block}.tooltip-text{visibility:hidden;width:280px;background-color:#1f2937;color:#fff;text-align:left;border-radius:8px;padding:.75rem;position:absolute;z-index:1000;top:150%;left:0;opacity:0;transition:opacity .3s;font-size:.875rem;font-weight:400;line-height:1.5;box-shadow:0 4px 12px #0003}.tooltip-text:before{content:"";position:absolute;bottom:100%;left:1rem;border-width:6px;border-style:solid;border-color:transparent transparent #1f2937 transparent}.tooltip-container:hover .tooltip-text{visibility:visible;opacity:1}.reclamos-table-container{overflow-x:auto;padding:1.5rem}.reclamos-table thead{background:#f9fafb}.reclamos-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:#374151;border-bottom:2px solid #e5e7eb}.reclamos-table td{padding:.75rem 1rem;font-size:.875rem;color:#1f2937;border-bottom:1px solid #e5e7eb}.ticket-cell{font-family:Courier New,monospace;font-weight:600;color:#3b82f6}.titulo-cell{font-weight:500;max-width:300px;min-width:200px}.days-cell{font-weight:600;color:#059669}.priority-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.priority-badge.priority-urgente{background:#ef44441a;color:#dc2626}.priority-badge.priority-alta{background:#f973161a;color:#ea580c}.priority-badge.priority-media{background:#fbbf241a;color:#d97706}.priority-badge.priority-baja{background:#3b82f61a;color:#2563eb}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge.status-nuevo{background:#3b82f61a;color:#2563eb}.status-badge.status-en_proceso{background:#fbbf241a;color:#d97706}.status-badge.status-asignado{background:#a855f71a;color:#9333ea}.status-badge.status-resuelto{background:#10b9811a;color:#059669}.status-badge.status-cerrado{background:#6b72801a;color:#6b7280}.loading{text-align:center;padding:4rem 2rem;color:#666;font-size:1.125rem}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}@media(max-width:768px){.dashboard-home{padding:1rem}.dashboard-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-icon{font-size:2rem;width:48px;height:48px}.stat-value{font-size:1.5rem}.widgets-grid{grid-template-columns:1fr;gap:1rem}.widget-header,.widget-content{padding:1rem}.widget-content.placeholder{padding:1.5rem 1rem}.activity-section{padding:1rem}}@media(max-width:480px){.dashboard-header h1{font-size:1.25rem}.dashboard-header p{font-size:.875rem}.stat-label{font-size:.75rem}.stat-value{font-size:1.25rem}.widget-header h2{font-size:1rem}.placeholder-icon{font-size:2rem}.activity-icon{font-size:1.25rem;width:32px;height:32px}.activity-title{font-size:.875rem}.activity-meta{font-size:.75rem}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:1000px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h2{font-size:1.5rem;font-weight:600;color:#2d3748;margin:0}.modal-close{background:none;border:none;font-size:2rem;color:#a0aec0;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:#f7fafc;color:#2d3748}.modal-form{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:#2d3748}.form-group input,.form-group select,.form-group textarea{padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:invalid{border-color:#fc8181}.error-message{background:#fed7d7;color:#c53030;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;border:1px solid #fc8181;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid #e2e8f0}.modal-large{max-width:900px}.modal-body{padding:1.5rem}.confirmation-summary,.envio-summary{margin-bottom:1.5rem}.confirmation-summary h3,.envio-summary h3{font-size:1.2rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.summary-item{padding:.75rem;background:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.summary-label{display:block;font-size:.85rem;color:#718096;margin-bottom:.25rem}.summary-value{display:block;font-size:1.1rem;font-weight:600;color:#2d3748}.summary-value.highlight{color:#667eea}.confirmation-details h4,.message-configuration h4{font-size:1rem;font-weight:600;color:#2d3748;margin-bottom:.75rem}.confirmation-list{list-style:none;padding:0;margin:0}.confirmation-list li{padding:.5rem 0;border-bottom:1px solid #e2e8f0}.confirmation-list li:last-child{border-bottom:none}.warning-box{background:#fef5e7;border:1px solid #f39c12;border-radius:8px;padding:1rem;margin-top:1rem;font-size:.9rem;color:#7d6608}.info-box{background:#e8f4fd;border:1px solid #3498db;border-radius:8px;padding:1rem;margin-bottom:1rem;font-size:.9rem;color:#1b4965}.info-box ul{margin:.5rem 0 0;padding-left:1.5rem}.info-box li{margin-bottom:.25rem}.checkbox-group{margin-bottom:1rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.message-preview{margin-top:1.5rem}.preview-box{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.preview-box pre{margin:0;white-space:pre-wrap;word-wrap:break-word;font-size:.9rem;line-height:1.6;color:#2d3748}.form-hint{display:block;font-size:.85rem;color:#718096;margin-top:.25rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #ffffff;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;margin-right:.5rem}.success-message{background:#d4edda;color:#155724;padding:1rem;border-radius:8px;border:1px solid #c3e6cb;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center}.success-message .close-btn{background:none;border:none;font-size:1.5rem;color:#155724;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.success-message .close-btn:hover{background:#0000000d}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge-borrador{background:#e2e8f0;color:#4a5568}.badge-generada{background:#bee3f8;color:#2c5282}.badge-aprobada{background:#c6f6d5;color:#22543d}.badge-cerrada{background:#fed7d7;color:#742a2a}@media(max-width:768px){.form-row{grid-template-columns:1fr}.modal-content{max-width:100%;margin:1rem}.summary-grid{grid-template-columns:1fr}}.file-dropzone{border:2px dashed #cbd5e0;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#f7fafc;min-height:180px;display:flex;align-items:center;justify-content:center}.file-dropzone:hover{border-color:#667eea;background:#edf2f7}.file-dropzone.has-file{border-style:solid;border-color:#48bb78;background:#f0fff4;cursor:default;padding:1.5rem}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.dropzone-icon{font-size:3rem;opacity:.5}.dropzone-text{margin:0;color:#718096;font-size:.95rem}.dropzone-content button{margin-top:.5rem}.file-preview{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem;background:#fff;border-radius:8px}.file-icon{font-size:2.5rem;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{margin:0;font-weight:600;color:#2d3748;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{margin:.25rem 0 0;font-size:.85rem;color:#718096}.btn-remove-file{background:#fc8181;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;font-size:1.25rem;font-weight:700}.btn-remove-file:hover{background:#f56565;transform:scale(1.1)}.form-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.form-section:last-of-type{border-bottom:none}.form-section h3{font-size:1.1rem;font-weight:600;color:#2d3748;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-family-sans);font-weight:var(--font-medium);line-height:1;white-space:nowrap;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;position:relative}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-full-width{width:100%}.btn-small{height:32px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-medium{height:40px;padding:0 var(--space-4);font-size:var(--text-sm)}.btn-large{height:48px;padding:0 var(--space-5);font-size:var(--text-base)}.btn-primary{background-color:var(--color-primary-600);color:var(--color-text-on-primary);border-color:var(--color-primary-600);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-700);border-color:var(--color-primary-700);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-800);border-color:var(--color-primary-800)}.btn-secondary{background-color:var(--color-bg-primary);color:var(--color-primary-600);border-color:var(--color-primary-600);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background-color:var(--color-primary-50);border-color:var(--color-primary-700);color:var(--color-primary-700);box-shadow:var(--shadow-sm)}.btn-secondary:active:not(:disabled){background-color:var(--color-primary-100)}.btn-danger{background-color:var(--color-error);color:var(--color-text-on-primary);border-color:var(--color-error);box-shadow:var(--shadow-sm)}.btn-danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626;box-shadow:var(--shadow-md)}.btn-danger:active:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.btn-ghost{background-color:transparent;color:var(--color-text-primary);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-text-primary)}.btn-ghost:active:not(:disabled){background-color:var(--color-gray-200)}.btn-outline{background-color:var(--color-bg-primary);color:var(--color-text-primary);border-color:var(--color-border-medium);box-shadow:var(--shadow-xs)}.btn-outline:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400);box-shadow:var(--shadow-sm)}.btn-outline:active:not(:disabled){background-color:var(--color-gray-100)}.btn-icon{display:inline-flex;align-items:center;justify-center;flex-shrink:0}.btn-icon svg{width:16px;height:16px}.btn-large .btn-icon svg{width:20px;height:20px}.btn-spinner{animation:spin 1s linear infinite}.btn-text{display:inline-flex;align-items:center}@media(prefers-contrast:high){.btn{border-width:2px}}@media(prefers-reduced-motion:reduce){.btn{transition:none}.btn:active:not(:disabled){transform:none}.btn-spinner{animation:none}}@media(max-width:640px){.btn-large{height:44px}}.consorcios-page{display:flex;flex-direction:column;gap:1.5rem}.header-actions{display:flex;gap:1rem;align-items:center}.search-form{display:flex;gap:.5rem}.search-input{padding:.625rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;width:300px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#667eea}.error-banner{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;border:1px solid #fc8181}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:12px;text-align:center}.empty-state h3{font-size:1.25rem;color:#2d3748;margin:0 0 .5rem}.empty-state p{color:#718096;margin:0 0 1.5rem}.table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:#f7fafc}.data-table th{text-align:left;padding:1rem;font-weight:600;font-size:.85rem;color:#4a5568;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e2e8f0}.data-table td{padding:1rem;border-bottom:1px solid #e2e8f0;font-size:.95rem;color:#2d3748}.data-table tbody tr:hover{background:#f7fafc}.data-table tbody tr:last-child td{border-bottom:none}.font-semibold{font-weight:600}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.status-badge.active{background:#c6f6d5;color:#22543d}.status-badge.inactive{background:#fed7d7;color:#742a2a}.action-buttons{display:flex;gap:.5rem}.btn-icon{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:background .2s;height:32px;width:32px;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:#f7fafc}.btn-edit:hover{background:#ebf8ff}.btn-delete:hover{background:#fff5f5}.pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.pagination-info{font-size:.9rem;color:#718096}.reclamos-page{padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.page-header h1{margin:0;font-size:2rem;color:#1f2937}.header-actions{display:flex;gap:1rem}.filters-panel{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.filter-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.filter-input,.filter-select{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;flex:1;min-width:200px}.filter-input:focus,.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280;white-space:nowrap}.filter-checkbox input[type=checkbox]{width:1rem;height:1rem;cursor:pointer}.reclamos-table-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.reclamos-table{width:100%;border-collapse:collapse}.reclamos-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.reclamos-table th{padding:.75rem 1rem;text-align:left;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.reclamos-table td{padding:1rem;border-bottom:1px solid #e5e7eb;font-size:.875rem;color:#374151}.reclamos-table tbody tr:hover{background:#f9fafb}.reclamos-table tbody tr.sla-vencido{background:#fef3c7}.reclamos-table tbody tr.sla-vencido:hover{background:#fde68a}.ticket-number{font-family:monospace;font-weight:600;color:#3b82f6}.titulo{font-weight:500;max-width:300px;min-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.titulo-header{width:35%}.consorcio-cell{white-space:nowrap}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.badge-tipo{background:#e0e7ff;color:#4f46e5}.badge-baja{background:#dbeafe;color:#1e40af}.badge-media{background:#fef3c7;color:#92400e}.badge-alta{background:#fed7aa;color:#c2410c}.badge-urgente{background:#fee2e2;color:#991b1b}.badge-nuevo{background:#dbeafe;color:#1e40af}.badge-en-proceso{background:#fef3c7;color:#92400e}.badge-asignado{background:#e0e7ff;color:#4f46e5}.badge-resuelto{background:#d1fae5;color:#065f46}.badge-cerrado{background:#e5e7eb;color:#374151}.no-data{text-align:center;padding:3rem!important;color:#9ca3af;font-style:italic}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1rem}.pagination-info{font-size:.875rem;color:#6b7280}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:#fff;border-radius:12px}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{margin-top:1rem;color:#718096;font-size:.95rem}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem}.action-button{background:none;border:none;padding:.375rem;cursor:pointer;border-radius:.375rem;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.action-button svg{width:20px;height:20px}.action-button.view{color:#3b82f6;background-color:#eff6ff}.action-button.view:hover{background-color:#dbeafe;transform:scale(1.05)}.reclamo-detail-page{padding:2rem;max-width:1200px;margin:0 auto}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.page-header h1{font-size:2rem;color:#1f2937;margin:0}.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:2rem}.detail-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.detail-card h2{font-size:1.25rem;color:#1f2937;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.detail-row{display:flex;padding:.75rem 0;border-bottom:1px solid #f3f4f6}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:600;color:#6b7280;width:150px;flex-shrink:0}.detail-row .value{color:#374151;flex:1}.sla-warning{color:#dc2626;font-weight:600}.action-buttons{display:flex;flex-direction:column;gap:.75rem}.btn-block{width:100%;justify-content:center}.notas-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.notas-section h3{font-size:1rem;color:#6b7280;margin:0 0 .5rem}.notas-section p{color:#374151;line-height:1.6;margin:0}.historial-section{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.historial-section h2{font-size:1.25rem;color:#1f2937;margin:0 0 1.5rem}.historial-list{display:flex;flex-direction:column;gap:1rem}.historial-item{padding:1rem;background:#f9fafb;border-radius:6px;border-left:3px solid #3b82f6}.historial-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.historial-date{font-size:.875rem;color:#6b7280}.historial-change{display:flex;align-items:center;gap:.5rem}.historial-change .arrow{color:#9ca3af}.historial-comment{font-size:.875rem;color:#374151;margin:0;padding-top:.5rem;border-top:1px solid #e5e7eb}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1f2937}.form-control{width:100%;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.no-data{text-align:center;padding:2rem;color:#9ca3af;font-style:italic}@media(max-width:768px){.detail-grid{grid-template-columns:1fr}.detail-row{flex-direction:column;gap:.25rem}.detail-row .label{width:auto}.historial-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.reclamo-form-page{padding:2rem;max-width:800px;margin:0 auto}.reclamo-form{display:flex;flex-direction:column;gap:2rem}.form-card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.form-card h2{font-size:1.25rem;color:#1f2937;margin:0 0 1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#374151;font-size:.875rem}.form-group label.required:after{content:" *";color:#dc2626}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-control{width:100%;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}textarea.form-control{resize:vertical;min-height:100px}.form-actions{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}@media(max-width:768px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions button{width:100%}}.comunicaciones-page{height:calc(100vh - 80px);display:flex;flex-direction:column;background-color:#f0f2f5}.comunicaciones-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background-color:#fff;border-bottom:1px solid #e0e0e0}.comunicaciones-header h2{margin:0;font-size:1.5rem;color:#333}.comunicaciones-header-actions{display:flex;gap:.75rem}.comunicaciones-filters{padding:1rem 1.5rem;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.filters-form{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:200px;flex:1}.filter-group label{font-size:.875rem;font-weight:500;color:#333}.filter-group select,.filter-group input{padding:.5rem;border:1px solid #d1d7db;border-radius:4px;font-size:.875rem;background-color:#fff}.filter-actions{display:flex;gap:.5rem}.comunicaciones-layout{flex:1;display:grid;grid-template-columns:380px 1fr;overflow:hidden;background-color:#fff}.comunicaciones-main-full{grid-column:1 / -1}.comunicaciones-sidebar{border-right:1px solid #e0e0e0;display:flex;flex-direction:column;background-color:#fff}.sidebar-header{padding:1rem;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.sidebar-header h3{margin:0;font-size:1.25rem;color:#333}.conversations-count{font-size:.875rem;color:#666}.conversations-list{flex:1;overflow-y:auto}.conversations-loading,.conversations-empty{padding:2rem 1rem;text-align:center;color:#666}.conversation-empty,.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;background-color:#f8f9fa}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-message{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 .5rem}.empty-subtitle{font-size:.9375rem;color:#666;margin:0;max-width:400px}.conversation-item{display:flex;gap:1rem;padding:1rem;cursor:pointer;border-bottom:1px solid #f0f2f5;transition:background-color .2s}.conversation-item:hover{background-color:#f5f6f6}.conversation-item.active{background-color:#e8f5e9}.conversation-item.unread{background-color:#fff9c4}.conversation-avatar{position:relative;flex-shrink:0}.avatar-icon{display:flex;align-items:center;justify-content:center;width:50px;height:50px;border-radius:50%;background-color:#e0e0e0;font-size:1.5rem}.unread-badge{position:absolute;top:-5px;right:-5px;background-color:#25d366;color:#fff;font-size:.75rem;font-weight:700;border-radius:50%;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;padding:0 5px}.conversation-content{flex:1;min-width:0}.conversation-detail .conversation-header{background-color:#f0f2f5;padding:1rem 1.5rem;border-bottom:1px solid #d1d7db;display:flex;align-items:center;gap:1rem}.conversation-back-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;color:#333;transition:background-color .2s;border-radius:50%;width:36px;height:36px;display:none;align-items:center;justify-content:center}.conversation-back-btn:hover{background-color:#0000000d}.conversation-header-info{flex:1;min-width:0}.conversation-header-info h3{margin:0 0 .25rem;font-size:1.125rem;color:#333}.conversation-header-subtitle{margin:0;font-size:.875rem;color:#667781}.conversation-header-badge{display:flex;align-items:center}.read-only-badge{font-size:.75rem;padding:.25rem .75rem;background-color:#fff3cd;color:#856404;border-radius:12px;font-weight:500}.conversation-item .conversation-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.conversation-name{margin:0;font-size:1rem;font-weight:600;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-time{font-size:.75rem;color:#667781;white-space:nowrap}.conversation-footer{display:flex;flex-direction:column;gap:.25rem}.conversation-preview{margin:0;font-size:.875rem;color:#667781;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-unit{font-size:.75rem;color:#999}.conversation-status{margin-top:.25rem}.status-badge{font-size:1rem}.comunicaciones-main{display:flex;flex-direction:column;height:100%;min-height:0;background-color:#e5ddd5;background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAwIiBoZWlnaHQ9IjQwMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZGVmcz48cGF0dGVybiBpZD0iYSIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgd2lkdGg9IjQwIiBoZWlnaHQ9IjQwIiBwYXR0ZXJuVHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCwwKSBzY2FsZSgxLDEpIj48cmVjdCB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSJyZ2JhKDAsMCwwLC4wMikiLz48L3BhdHRlcm4+PC9kZWZzPjxyZWN0IHdpZHRoPSI0MDAiIGhlaWdodD0iNDAwIiBmaWxsPSJ1cmwoI2EpIi8+PC9zdmc+)}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-header{background-color:#f0f2f5;padding:1rem 1.5rem;border-bottom:1px solid #d1d7db}.chat-header-info h3{margin:0 0 .25rem;font-size:1.125rem;color:#333}.chat-header-subtitle{margin:0;font-size:.875rem;color:#667781}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.conversation-detail{display:flex;flex-direction:column;height:100%;min-height:0;flex:1}.conversation-messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:1rem;display:flex;flex-direction:column;gap:.5rem;background-color:#e5ddd5;background-image:url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAwIiBoZWlnaHQ9IjQwMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZGVmcz48cGF0dGVybiBpZD0iYSIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgd2lkdGg9IjQwIiBoZWlnaHQ9IjQwIiBwYXR0ZXJuVHJhbnNmb3JtPSJ0cmFuc2xhdGUoMCwwKSBzY2FsZSgxLDEpIj48cmVjdCB3aWR0aD0iMSIgaGVpZ2h0PSIxIiBmaWxsPSJyZ2JhKDAsMCwwLC4wMikiLz48L3BhdHRlcm4+PC9kZWZzPjxyZWN0IHdpZHRoPSI0MDAiIGhlaWdodD0iNDAwIiBmaWxsPSJ1cmwoI2EpIi8+PC9zdmc+)}.conversation-loading,.conversation-no-messages{flex:1;display:flex;align-items:center;justify-content:center;color:#667781;font-style:italic}.conversation-info{background-color:#f0f2f5;padding:.75rem 1rem;border-top:1px solid #d1d7db}.conversation-info-text{margin:0;font-size:.813rem;color:#667781;text-align:center}.chat-no-messages{text-align:center;padding:2rem;color:#667781}.message{display:flex;max-width:65%}.message-received{align-self:flex-start}.message-sent{align-self:flex-end}.message-bubble{background-color:#fff;border-radius:8px;padding:8px 12px;box-shadow:0 1px .5px #00000021;position:relative}.message-sent .message-bubble{background-color:#dcf8c6}.message-text{margin:0 0 4px;word-wrap:break-word;white-space:pre-wrap;color:#111b21;font-size:.875rem;line-height:1.4}.message-footer{display:flex;justify-content:flex-end;align-items:center;gap:4px;margin-top:4px}.message-time{font-size:.688rem;color:#667781}.message-status{font-size:.875rem;color:#667781}.chat-input{background-color:#f0f2f5;padding:.5rem 1rem;display:flex;gap:.5rem;align-items:flex-end;border-top:1px solid #d1d7db}.chat-input-field{flex:1;padding:.75rem;border:1px solid #d1d7db;border-radius:8px;font-size:.9375rem;resize:none;font-family:inherit;background-color:#fff}.chat-input-field:focus{outline:none;border-color:#25d366}.chat-send-button{background-color:#25d366;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:.9375rem;cursor:pointer;white-space:nowrap;transition:background-color .2s}.chat-send-button:hover:not(:disabled){background-color:#1faa55}.chat-send-button:disabled{background-color:#ccc;cursor:not-allowed}.modal-large{max-width:700px;width:90%}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e8e8e8}.form-section:last-child{border-bottom:none;padding-bottom:0}.form-section h3{margin:0 0 1.25rem;font-size:1.125rem;font-weight:600;color:#2d3748;display:flex;align-items:center;gap:.5rem}.variable-input{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.variable-input label{font-size:.875rem;color:#666;font-weight:500}.variable-input input{padding:.5rem;border:1px solid #d1d7db;border-radius:4px;font-size:.875rem}.message-preview{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.message-preview h4{margin:0 0 .5rem;font-size:.875rem;color:#666}.preview-box{background-color:#dcf8c6;padding:1rem;border-radius:8px;white-space:pre-wrap;word-wrap:break-word;font-size:.875rem;line-height:1.4;color:#111b21}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-group label{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;cursor:pointer}.radio-group input[type=radio]{cursor:pointer}.vecino-search{margin-top:1rem;margin-bottom:1rem}.vecino-search input{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .2s ease;background-color:#f7fafc}.vecino-search input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea1a}.vecino-search input::placeholder{color:#a0aec0}.vecino-selection-actions{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background-color:#f7fafc;border-radius:8px;border:1px solid #e2e8f0}.btn-sm{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;font-weight:500}.selected-count{margin-left:auto;font-size:.875rem;color:#4a5568;font-weight:600;padding:.375rem .75rem;background-color:#e2e8f0;border-radius:12px}.vecino-list{max-height:350px;overflow-y:auto;border:2px solid #e2e8f0;border-radius:8px;background-color:#fff}.vecino-list::-webkit-scrollbar{width:8px}.vecino-list::-webkit-scrollbar-track{background:#f7fafc;border-radius:8px}.vecino-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:8px}.vecino-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.no-vecinos{padding:2.5rem;text-align:center;color:#a0aec0;font-size:.95rem}.vecino-item{display:grid!important;grid-template-columns:auto 1fr;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid #e8e8e8;cursor:pointer;transition:all .2s ease}.vecino-item:last-child{border-bottom:none}.vecino-item:hover{background-color:#f8f9fa;transform:translate(2px)}.vecino-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;flex-shrink:0;accent-color:#667eea}.vecino-info{display:flex;flex-direction:column;gap:.25rem;width:100%}.vecino-name{font-weight:600;color:#2d3748;font-size:.95rem;line-height:1.4;display:block}.vecino-contact{display:flex;gap:.75rem;flex-wrap:wrap}.vecino-phone{font-size:.875rem;color:#718096}.vecino-email{font-size:.875rem;color:#a0aec0;font-weight:400}@media(max-width:768px){.comunicaciones-layout{grid-template-columns:1fr;position:relative}.comunicaciones-sidebar{position:absolute;inset:0;z-index:10;transform:translate(0);transition:transform .3s ease}.comunicaciones-sidebar.sidebar-hidden{transform:translate(-100%)}.comunicaciones-main{position:absolute;inset:0}.conversation-back-btn{display:flex}.message{max-width:85%}}.public-tracking-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem 1rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.tracking-container{max-width:800px;margin:0 auto}.tracking-header{text-align:center;margin-bottom:2rem;color:#fff}.tracking-header h1{margin:0 0 .5rem;font-size:2.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2)}.tracking-subtitle{margin:0;font-size:1.125rem;opacity:.95}.tracking-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.tracking-loading p{margin:0;color:#666;font-size:1.125rem}.tracking-error{background-color:#fff;border-radius:12px;padding:3rem 2rem;box-shadow:0 10px 40px #00000026;text-align:center}.error-icon{font-size:4rem;margin-bottom:1rem}.tracking-error h2{margin:0 0 1rem;color:#d32f2f;font-size:1.75rem}.tracking-error p{margin:0 0 1.5rem;color:#666;font-size:1.125rem}.error-help{background-color:#f5f5f5;border-radius:8px;padding:1.5rem;text-align:left;max-width:500px;margin:0 auto}.error-help p{margin:.5rem 0;font-size:.9375rem;color:#333}.error-help strong{color:#667eea}.reclamo-info-card{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #00000026;margin-bottom:2rem}.info-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.5rem;border-bottom:2px solid #f0f0f0;margin-bottom:1.5rem}.ticket-number{display:flex;flex-direction:column}.ticket-label{font-size:.875rem;color:#666;margin-bottom:.25rem}.ticket-value{font-size:1.5rem;font-weight:700;color:#333;font-family:Courier New,monospace}.estado-badge{padding:.5rem 1.25rem;border-radius:20px;font-weight:600;font-size:.9375rem;text-transform:capitalize}.estado-badge.estado-blue{background-color:#e3f2fd;color:#1976d2}.estado-badge.estado-orange{background-color:#fff3e0;color:#f57c00}.estado-badge.estado-purple{background-color:#f3e5f5;color:#7b1fa2}.estado-badge.estado-green{background-color:#e8f5e9;color:#388e3c}.estado-badge.estado-gray{background-color:#f5f5f5;color:#616161}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-size:.875rem;color:#666;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:1rem;color:#333;font-weight:500}.prioridad-badge{padding:.25rem .75rem;border-radius:12px;font-weight:600;font-size:.875rem;display:inline-block;width:fit-content}.prioridad-badge.prioridad-baja{background-color:#e8f5e9;color:#2e7d32}.prioridad-badge.prioridad-media{background-color:#fff3e0;color:#f57c00}.prioridad-badge.prioridad-alta{background-color:#ffebee;color:#c62828}.prioridad-badge.prioridad-urgente{background-color:#f3e5f5;color:#6a1b9a}.info-description,.info-observations{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #f0f0f0}.info-description p,.info-observations p{margin:.5rem 0 0;color:#333;line-height:1.6;white-space:pre-wrap}.historial-section{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #00000026;margin-bottom:2rem}.historial-section h2{margin:0 0 2rem;font-size:1.5rem;color:#333;font-weight:700}.timeline{position:relative}.timeline-item{display:flex;gap:1.5rem;position:relative}.timeline-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.timeline-dot{width:16px;height:16px;border-radius:50%;border:3px solid white;box-shadow:0 0 0 3px currentColor;flex-shrink:0}.timeline-dot.estado-blue{color:#1976d2}.timeline-dot.estado-orange{color:#f57c00}.timeline-dot.estado-purple{color:#7b1fa2}.timeline-dot.estado-green{color:#388e3c}.timeline-dot.estado-gray{color:#616161}.timeline-line{width:2px;flex:1;background-color:#e0e0e0;margin:4px 0;min-height:40px}.timeline-content{flex:1;padding-bottom:2rem}.timeline-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.timeline-estado{font-weight:600;font-size:1rem}.timeline-estado.estado-blue{color:#1976d2}.timeline-estado.estado-orange{color:#f57c00}.timeline-estado.estado-purple{color:#7b1fa2}.timeline-estado.estado-green{color:#388e3c}.timeline-estado.estado-gray{color:#616161}.timeline-date{font-size:.875rem;color:#666}.timeline-observation{margin:.5rem 0;color:#555;line-height:1.6}.timeline-user{font-size:.875rem;color:#999;font-style:italic}.tracking-help{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #00000026;margin-bottom:2rem;text-align:center}.tracking-help h3{margin:0 0 1rem;color:#667eea;font-size:1.25rem}.tracking-help p{margin:0;color:#666;line-height:1.6}.tracking-footer{text-align:center;padding:2rem 1rem;color:#fff}.tracking-footer p{margin:.5rem 0;opacity:.9}.footer-disclaimer{font-size:.875rem;opacity:.8}@media(max-width:768px){.public-tracking-page{padding:1rem .5rem}.tracking-header h1{font-size:2rem}.reclamo-info-card,.historial-section,.tracking-help{padding:1.5rem;border-radius:8px}.info-header{flex-direction:column;align-items:flex-start;gap:1rem}.info-grid{grid-template-columns:1fr;gap:1rem}.timeline-item{gap:1rem}.timeline-header{flex-direction:column;align-items:flex-start;gap:.25rem}}.loading-overlay{position:fixed;inset:0;background-color:#0000004d;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.loading-spinner-fullscreen{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 25px #0000001a}.loading-spinner{position:relative;display:inline-block}.loading-spinner-small{width:30px;height:30px}.loading-spinner-medium{width:50px;height:50px}.loading-spinner-large{width:70px;height:70px}.spinner-ring{position:absolute;border:3px solid transparent;border-top-color:#3b82f6;border-radius:50%;animation:spin 1.5s cubic-bezier(.68,-.55,.27,1.55) infinite}.loading-spinner-small .spinner-ring{width:30px;height:30px}.loading-spinner-medium .spinner-ring{width:50px;height:50px}.loading-spinner-large .spinner-ring{width:70px;height:70px}.spinner-ring:nth-child(1){animation-delay:0s;border-top-color:#3b82f6}.spinner-ring:nth-child(2){animation-delay:.2s;border-top-color:#60a5fa;opacity:.7}.spinner-ring:nth-child(3){animation-delay:.4s;border-top-color:#93c5fd;opacity:.4}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner-message{margin-top:1rem;font-size:.875rem;color:#6b7280;font-weight:500;text-align:center}.loading-spinner-fullscreen .loading-spinner-message{color:#374151}.error-message{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;border-left:4px solid;box-shadow:0 2px 4px #0000001a;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message-error{background-color:#fee2e2;border-left-color:#dc2626}.error-message-warning{background-color:#fef3c7;border-left-color:#f59e0b}.error-message-info{background-color:#dbeafe;border-left-color:#3b82f6}.error-message-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.error-message-icon{font-size:1.5rem;flex-shrink:0}.error-message-text{flex:1}.error-message-title{font-weight:600;font-size:.875rem;margin-bottom:.25rem}.error-message-error .error-message-title{color:#991b1b}.error-message-warning .error-message-title{color:#92400e}.error-message-info .error-message-title{color:#1e40af}.error-message-description{font-size:.875rem;line-height:1.5}.error-message-error .error-message-description{color:#7f1d1d}.error-message-warning .error-message-description{color:#78350f}.error-message-info .error-message-description{color:#1e3a8a}.error-message-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.error-message-action-btn{padding:.375rem .75rem;font-size:.875rem;font-weight:500;border-radius:.375rem;border:1px solid;cursor:pointer;transition:all .2s}.error-message-error .error-message-action-btn{background-color:#dc2626;color:#fff;border-color:#dc2626}.error-message-error .error-message-action-btn:hover{background-color:#b91c1c}.error-message-warning .error-message-action-btn{background-color:#f59e0b;color:#fff;border-color:#f59e0b}.error-message-warning .error-message-action-btn:hover{background-color:#d97706}.error-message-info .error-message-action-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.error-message-info .error-message-action-btn:hover{background-color:#2563eb}.error-message-close-btn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:transparent;border:none;cursor:pointer;border-radius:.25rem;transition:background-color .2s;color:#6b7280}.error-message-close-btn:hover{background-color:#0000001a}.pagination-container{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1rem;background-color:#f9fafb;border-radius:.5rem;margin-top:1.5rem;gap:1rem;flex-wrap:wrap}.pagination-info{font-size:.875rem;color:#6b7280;font-weight:500}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-pages{display:flex;align-items:center;gap:.25rem;margin:0 .5rem}.pagination-btn{min-width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;padding:.5rem;border:1px solid #d1d5db;background-color:#fff;color:#374151;font-size:.875rem;font-weight:500;border-radius:.375rem;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f9fafb}.pagination-btn-edge{font-weight:700;font-size:1rem}.pagination-btn-number{min-width:2.5rem}.pagination-btn-active{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.pagination-btn-active:hover{background-color:#2563eb;border-color:#2563eb}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;min-width:2.5rem;height:2.5rem;color:#9ca3af;font-weight:600}.pagination-page-info{font-size:.875rem;color:#6b7280;font-weight:600}@media(max-width:768px){.pagination-container{flex-direction:column;align-items:stretch}.pagination-info,.pagination-page-info{text-align:center}.pagination-controls{justify-content:center}.pagination-btn{min-width:2rem;height:2rem;font-size:.75rem}.pagination-btn-edge{font-size:.875rem}.pagination-ellipsis{min-width:2rem;height:2rem}}@media(max-width:480px){.pagination-pages{margin:0 .25rem}.pagination-btn{min-width:1.75rem;height:1.75rem;padding:.25rem}}.archivos-page{display:flex;flex-direction:column;gap:1.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.filters-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.filter-field{display:flex;flex-direction:column;gap:.5rem}.filter-field label{font-size:.875rem;font-weight:600;color:#374151}.filter-input{padding:.625rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:border-color .2s;font-family:inherit}.filter-input:focus{outline:none;border-color:#667eea}.filters-actions{display:flex;gap:.5rem;justify-content:flex-end}.table-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.archivos-table{width:100%;border-collapse:collapse}.archivos-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.archivos-table th{padding:1rem;text-align:left;font-size:.875rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.025em}.archivos-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .15s}.archivos-table tbody tr:hover{background:#f8fafc}.archivos-table td{padding:1rem;font-size:.95rem;color:#1f2937}.archivo-row{cursor:pointer}.archivo-name{display:flex;align-items:center;gap:.5rem}.archivo-icon{font-size:1.25rem}.action-buttons{display:flex;gap:.5rem;align-items:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;background:#fff;border-radius:12px;text-align:center}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-text{font-size:1.125rem;font-weight:600;color:#475569;margin-bottom:.5rem}.empty-state-subtext{font-size:.95rem;color:#94a3b8}.modal-large{max-width:900px;width:90%}.modal-subtitle{font-size:.875rem;color:#6b7280;margin-top:.25rem}.archivo-preview-container{min-height:400px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.filters-grid{grid-template-columns:1fr}.filters-actions{flex-direction:column}.filters-actions button{width:100%}.table-container{overflow-x:auto}.archivos-table{min-width:800px}.action-buttons{flex-direction:column;gap:.25rem}.action-buttons button{width:100%}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
