:root{--bg-chat: #e5ddd5;--bg-bubble-own: #dcf8c6;--bg-bubble-other: #ffffff;--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-elevated: #ffffff;--bg-hover: #f1f5f9;--bg-active: #e2e8f0;--bg-input: #ffffff;--bg-overlay: rgba(15, 23, 42, .6);--bg-header: linear-gradient(135deg, #0284c7 0%, #06b6d4 100%);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-muted: #94a3b8;--text-inverse: #ffffff;--border-color: #e2e8f0;--border-light: #f1f5f9;--border-strong: #cbd5e1;--border-focus: #0284c7;--accent-primary: #0284c7;--accent-primary-hover: #0369a1;--accent-secondary: #06b6d4;--accent-secondary-hover: #0891b2;--accent-success: #059669;--accent-danger: #dc2626;--accent-warning: #d97706;--success: #059669;--success-bg: #d1fae5;--success-text: #065f46;--warning: #d97706;--warning-bg: #fef3c7;--warning-text: #92400e;--danger: #dc2626;--danger-bg: #fee2e2;--danger-text: #991b1b;--info: #6366f1;--info-bg: #e0e7ff;--info-text: #4338ca;--gradient-primary: linear-gradient(135deg, #0284c7 0%, #06b6d4 100%);--gradient-success: linear-gradient(135deg, #059669 0%, #10b981 100%);--gradient-danger: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--input-bg: #ffffff;--input-bg-hover: #f8fafc;--input-bg-focus: #ffffff;--input-border: #cbd5e1;--input-border-hover: #94a3b8;--input-border-focus: #0284c7;--input-text: #0f172a;--input-placeholder: #94a3b8;--table-header-bg: #f8fafc;--table-row-hover: #f1f5f9;--table-border: #e2e8f0;--card-bg: #ffffff;--card-border: #e2e8f0;--card-hover-bg: #f8fafc;--sidebar-bg: #ffffff;--header-bg: #ffffff;--modal-overlay: rgba(15, 23, 42, .6);--modal-bg: #ffffff;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 15px;--font-size-lg: 17px;--font-size-xl: 20px}[data-theme=dark]{--bg-chat: #0b141a;--bg-bubble-own: #005c4b;--bg-bubble-other: #1f2c34;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-elevated: #1e293b;--bg-hover: #334155;--bg-active: #475569;--bg-input: #1e293b;--bg-overlay: rgba(0, 0, 0, .75);--bg-header: linear-gradient(135deg, #1e293b 0%, #0f172a 100%);--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #8696a0;--text-muted: #64748b;--text-inverse: #0f172a;--border-color: #334155;--border-light: #1e293b;--border-strong: #475569;--border-focus: #38bdf8;--accent-primary: #38bdf8;--accent-primary-hover: #0ea5e9;--accent-secondary: #22d3ee;--accent-secondary-hover: #06b6d4;--accent-success: #10b981;--accent-danger: #ef4444;--accent-warning: #f59e0b;--success: #10b981;--success-bg: rgba(16, 185, 129, .15);--success-text: #6ee7b7;--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--warning-text: #fcd34d;--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .15);--danger-text: #fca5a5;--info: #818cf8;--info-bg: rgba(129, 140, 248, .15);--info-text: #a5b4fc;--gradient-primary: linear-gradient(135deg, #38bdf8 0%, #22d3ee 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #f87171 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--input-bg: rgba(30, 41, 59, .95);--input-bg-hover: rgba(51, 65, 85, .95);--input-bg-focus: rgba(51, 65, 85, .95);--input-border: rgba(255, 255, 255, .15);--input-border-hover: rgba(255, 255, 255, .25);--input-border-focus: #38bdf8;--input-text: #f1f5f9;--input-placeholder: #64748b;--table-header-bg: rgba(255, 255, 255, .02);--table-row-hover: rgba(255, 255, 255, .03);--table-border: rgba(255, 255, 255, .05);--card-bg: rgba(30, 41, 59, .6);--card-border: rgba(255, 255, 255, .08);--card-hover-bg: rgba(51, 65, 85, .6);--sidebar-bg: #1e293b;--header-bg: #1e293b;--modal-overlay: rgba(0, 0, 0, .75);--modal-bg: #1e293b}[data-text-size=small]{--font-size-xs: 10px;--font-size-sm: 12px;--font-size-base: 13px;--font-size-lg: 15px;--font-size-xl: 17px}[data-text-size=normal]{--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 15px;--font-size-lg: 17px;--font-size-xl: 20px}[data-text-size=large]{--font-size-xs: 13px;--font-size-sm: 15px;--font-size-base: 17px;--font-size-lg: 20px;--font-size-xl: 24px}html{font-size:var(--font-size-base)}body{background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-base);transition:background-color .3s ease,color .3s ease;line-height:1.5}p,span,div,button,input,textarea,select{font-size:inherit}.message-content,.message-text{font-size:var(--font-size-base)!important}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:440px;overflow:hidden;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 32px;text-align:center}.login-header h1{font-size:36px;margin-bottom:8px;font-weight:700;letter-spacing:-.5px}.login-header p{font-size:16px;opacity:.95;font-weight:300}.login-form{padding:40px 32px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:16px;transition:all .2s;font-family:inherit}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-group input::placeholder{color:#9ca3af}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:20px;border-left:4px solid #dc2626}.btn-login{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #667eea4d}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{background:#f9fafb;padding:24px 32px;border-top:1px solid #e5e7eb}.demo-credentials{font-size:13px;color:#6b7280;line-height:1.8;text-align:center}.demo-credentials strong{color:#374151;display:block;margin-bottom:12px;font-size:14px}.superuser-line{color:#ef4444;font-weight:600}@media(max-width:480px){.login-card{border-radius:0;max-width:100%;height:100vh}.login-header{padding:32px 24px}.login-header h1{font-size:28px}.login-form{padding:32px 24px}.login-footer{padding:20px 24px}}.audio-player{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;min-width:200px;max-width:320px;width:100%}.audio-player.own{background:#d9fdd3}.audio-player.other{background:#fff}[data-theme=dark] .audio-player.own{background:#005c4b}[data-theme=dark] .audio-player.other{background:#202c33}.player-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:#54656f;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;flex-shrink:0}.player-btn:hover{background:#0000000d}[data-theme=dark] .player-btn{color:#d1d7db}[data-theme=dark] .player-btn:hover{background:#ffffff1a}.player-waveform{flex:1;display:flex;align-items:center;gap:2px;height:28px;cursor:pointer;min-width:60px}.player-bar{width:3px;min-height:4px;background:#b4b4b4;border-radius:2px;transition:background .1s}[data-theme=dark] .player-bar{background:#fff6}.player-bar.active{background:#25d366}.audio-player.own .player-bar{background:#99aab5}.audio-player.own .player-bar.active{background:#54656f}[data-theme=dark] .audio-player.own .player-bar{background:#fff6}[data-theme=dark] .audio-player.own .player-bar.active{background:#ffffffe6}.player-time{font-size:11px;color:#54656f;min-width:28px;text-align:right;flex-shrink:0}.player-speed{font-size:11px;font-weight:600;color:#54656f;background:#0000000d;border:none;border-radius:4px;padding:2px 6px;cursor:pointer;transition:background .15s;flex-shrink:0}.player-speed:hover{background:#0000001a}[data-theme=dark] .player-time{color:#ffffffb3}[data-theme=dark] .player-speed{color:#fff;background:#ffffff26}[data-theme=dark] .player-speed:hover{background:#ffffff40}@media(max-width:480px){.audio-player{min-width:unset;max-width:100%;gap:6px;padding:6px 10px}.player-btn{width:32px;height:32px}.player-btn svg{width:22px;height:22px}.player-waveform{gap:1px;height:24px}.player-bar{width:2px}.player-time{font-size:10px;min-width:24px}.player-speed{font-size:10px;padding:2px 5px}}.message-bubble{max-width:75%;padding:6px 10px 8px;font-size:14.2px;line-height:1.35;margin:2px 0;word-wrap:break-word;box-shadow:0 1px .5px #00000021;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.message-bubble.sent{background:#d9fdd3;align-self:flex-end;border-radius:12px 0 12px 12px;color:#111b21}[data-theme=dark] .message-bubble.sent{background:#005c4b;color:#e9edef}.message-bubble.received{background:#fff;align-self:flex-start;border-radius:0 12px 12px;color:#111b21}[data-theme=dark] .message-bubble.received{background:#202c33;color:#e9edef}.sender-name{font-weight:500;font-size:12px;color:#e542a3;margin-bottom:2px;line-height:14px}.message-content{position:relative}.message-time{float:right;margin-left:8px;margin-top:6px;font-size:10px;color:#00000073;line-height:1;vertical-align:bottom}[data-theme=dark] .message-time{color:#fff9}[data-theme=dark] .sender-name{color:#fca5a5}.message-content:after{content:"";clear:both;display:table}.message-content>div{max-width:100%}.edited-label{font-size:10px;color:#00000073;font-style:italic;margin-left:4px}.edit-container{display:flex;flex-direction:column;gap:8px;width:100%}.edit-textarea{width:100%;min-height:60px;padding:8px;border:1px solid #128c7e;border-radius:8px;font-family:inherit;font-size:14px;resize:vertical}.edit-textarea:focus{outline:none;border-color:#0f7a6d}.edit-buttons{display:flex;gap:8px;justify-content:flex-end}.btn-save{background:#128c7e;color:#fff;border:none;padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.btn-save:hover{background:#0f7a6d}.btn-cancel-edit{background:#e5e7eb;color:#374151;border:none;padding:6px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.btn-cancel-edit:hover{background:#d1d5db}.context-menu{position:absolute;top:-40px;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;overflow:visible}.menu-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:99;cursor:default}[data-theme=dark] .context-menu{background:#233138;box-shadow:0 4px 12px #00000080;border:1px solid #3b4a54}.context-menu.open-up{top:auto;bottom:100%;margin-bottom:4px;transform-origin:bottom right}.menu-list{list-style:none;padding:4px 0;margin:0}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 16px;border:none;background:transparent;text-align:left;cursor:pointer;font-size:14.5px;color:#3b4a54;transition:background .1s}[data-theme=dark] .menu-item{color:#d1d7db}.menu-item:hover{background:#f0f2f5}[data-theme=dark] .menu-item:hover{background:#182229}.menu-item.primary-action{font-weight:500}.menu-item.disabled{opacity:.5;cursor:default}.menu-item.disabled:hover{background:transparent}@media(max-width:768px){.message-bubble{font-size:13.5px;max-width:82%}}.audio-recorder{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-secondary, #202c33);border-radius:24px;min-width:280px}.recorder-btn{width:40px;height:40px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,opacity .15s}.recorder-btn:hover:not(:disabled){transform:scale(1.05)}.recorder-btn:disabled{opacity:.5;cursor:not-allowed}.recorder-cancel{background:transparent;color:#ef4444}.recorder-cancel:hover:not(:disabled){background:#ef44441a}.recorder-send{background:#25d366}.recorder-send:hover:not(:disabled){background:#1da851}.recorder-timer{display:flex;align-items:center;gap:8px;color:#aebac1;font-size:14px;font-weight:500;min-width:50px}.recorder-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.recorder-waveform{flex:1;display:flex;align-items:center;justify-content:center;gap:2px;height:32px;overflow:hidden}.waveform-bar{width:3px;min-height:4px;background:#25d366;border-radius:2px;transition:height .05s ease-out}.lock-indicator{font-size:16px;padding:4px}.recorder-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(hover:none)and (pointer:coarse){.recorder-btn:active{transform:scale(.95)}}@media(max-width:400px){.audio-recorder{min-width:unset;width:100%;gap:6px;padding:6px 8px}.recorder-btn{width:34px;height:34px}.recorder-waveform{flex:1;max-width:none}.recorder-timer{min-width:45px;font-size:12px}}@media(max-width:480px){.audio-recorder{min-width:unset;width:100%;gap:8px;padding:6px 10px}.recorder-waveform{flex:1;max-width:none}}.camera-capture{position:fixed!important;inset:0!important;width:100vw!important;height:100vh!important;background:#000!important;z-index:99999!important;overflow:hidden!important;margin:0!important;padding:0!important}.camera-close{position:fixed!important;top:20px;left:20px;width:44px;height:44px;border-radius:50%;background:#00000080;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:100000;transition:background .2s}.camera-close:hover{background:#000000b3}.camera-video{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;object-fit:cover!important;background:#000;z-index:99998}.camera-video.mirrored{transform:scaleX(-1)}.camera-preview-image,.camera-preview-video{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;object-fit:contain!important;background:#000;z-index:99998}.recording-indicator{position:fixed!important;top:30px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:8px 16px;background:#0009;border-radius:20px;color:#fff;font-size:16px;font-weight:600;z-index:100000}.recording-dot{width:12px;height:12px;background:#ff3b30;border-radius:50%;animation:pulse-recording 1s infinite}@keyframes pulse-recording{0%,to{opacity:1}50%{opacity:.3}}.camera-controls{position:fixed!important;bottom:40px;left:0;right:0;display:flex;justify-content:space-around;align-items:center;padding:0 40px;z-index:100000;background:transparent!important}.camera-btn{width:50px;height:50px;border-radius:50%;background:#0006;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.camera-btn:hover:not(.disabled){background:#0009}.camera-btn.active{background:#fc0}.camera-btn.active svg{fill:#000}.camera-btn.disabled{opacity:.3;cursor:not-allowed}.camera-btn-placeholder{width:50px;height:50px}.camera-btn-capture{width:80px;height:80px;border-radius:50%;background:transparent;border:4px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.camera-btn-capture:hover{transform:scale(1.05)}.capture-inner{width:64px;height:64px;border-radius:50%;background:#fff;transition:all .2s}.camera-btn-capture.video .capture-inner.video{background:#ff3b30}.camera-btn-capture.recording .capture-inner.recording{width:30px;height:30px;border-radius:6px;background:#ff3b30}.camera-mode-toggle{position:fixed!important;bottom:140px;left:50%;transform:translate(-50%);display:flex;gap:20px;z-index:100000;background:transparent!important}.mode-btn{padding:8px 20px;border:none;background:transparent;color:#fff9;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:1px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.mode-btn.active{color:#fc0}.mode-btn:hover:not(.active){color:#ffffffe6}.preview-controls{position:fixed!important;bottom:50px;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:80px;z-index:100000;background:transparent!important}.preview-btn{width:60px;height:60px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.preview-btn:hover:not(:disabled){transform:scale(1.1)}.preview-btn:disabled{opacity:.5;cursor:not-allowed}.preview-btn.discard{background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.preview-btn.send{background:#25d366}.upload-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@supports (padding-top: env(safe-area-inset-top)){.camera-close{top:calc(20px + env(safe-area-inset-top))}.camera-controls{bottom:calc(40px + env(safe-area-inset-bottom))}.camera-mode-toggle{bottom:calc(140px + env(safe-area-inset-bottom))}.preview-controls{bottom:calc(50px + env(safe-area-inset-bottom))}.recording-indicator{top:calc(30px + env(safe-area-inset-top))}}.message-input-wrapper{display:flex;flex-direction:column;background:#f0f2f5;border-top:none}[data-theme=dark] .message-input-wrapper,.dark .message-input-wrapper{background:#1f2c34;border-top-color:#2a3942}.edit-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#1f2c34;border-bottom:1px solid #2a3942;animation:editBarSlide .2s ease-out}@keyframes editBarSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.edit-bar-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.edit-bar-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.edit-bar-text{display:flex;flex-direction:column;min-width:0;flex:1}.edit-label{font-size:11px;color:#00a884;font-weight:500}.edit-preview{font-size:13px;color:#8696a0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edit-bar-close{width:32px;height:32px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s;flex-shrink:0}.edit-bar-close:hover{background:#ffffff1a}.message-input-container{display:flex;align-items:flex-end;gap:6px;padding:6px 8px;background:#f0f2f5;min-height:auto;box-sizing:border-box;position:sticky;bottom:0;border-top:none;padding-bottom:calc(6px + env(safe-area-inset-bottom))}[data-theme=dark] .message-input-container,.dark .message-input-container{background:#1f2c34;border-top:none}.upload-progress{position:absolute;top:-45px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:10px 20px;border-radius:20px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.progress-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.btn-action{background:transparent;color:#54656f;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;transition:all .15s;flex-shrink:0;display:flex;align-items:center;justify-content:center}[data-theme=dark] .btn-action,.dark .btn-action{color:#8696a0}.btn-action:hover:not(:disabled){background:#0000000d}[data-theme=dark] .btn-action:hover:not(:disabled),.dark .btn-action:hover:not(:disabled){background:#ffffff14}.btn-action:disabled{opacity:.4;cursor:default}.btn-formulario{background:transparent;color:#54656f;width:40px!important;height:40px!important;border-radius:50%!important;flex-shrink:0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:none;font-size:1.2rem}[data-theme=dark] .btn-formulario,.dark .btn-formulario{color:#8696a0}.btn-formulario:hover:not(:disabled){background:#0000000d}[data-theme=dark] .btn-formulario:hover,.dark .btn-formulario:hover{background:#ffffff14!important}.btn-plus{background:transparent;color:#54656f;width:40px!important;height:40px!important;border-radius:50%!important;flex-shrink:0;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:none}[data-theme=dark] .btn-plus,.dark .btn-plus{color:#8696a0}.btn-plus:hover:not(:disabled){background:#0000000d}[data-theme=dark] .btn-plus:hover,.dark .btn-plus:hover{background:#ffffff14!important}.btn-attach{background:transparent;color:#54656f;width:40px!important;height:40px!important;border-radius:50%!important;display:flex;align-items:center;justify-content:center;border:none;flex-shrink:0}[data-theme=dark] .btn-attach,.dark .btn-attach{color:#8696a0}.btn-attach:hover:not(:disabled){background:#0000000d}[data-theme=dark] .btn-attach:hover,.dark .btn-attach:hover{background:#ffffff14!important}.btn-microphone{background:transparent;color:#54656f;border:none;width:40px!important;height:40px!important;border-radius:50%!important;flex-shrink:0;box-shadow:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.microphone-wrapper{display:flex;align-items:center}.microphone-wrapper .btn-microphone{width:40px!important;height:40px!important;border-radius:50%!important;flex-shrink:0;box-shadow:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}[data-theme=dark] .microphone-wrapper .btn-microphone,.dark .microphone-wrapper .btn-microphone{color:#8696a0}.microphone-wrapper .btn-microphone:hover:not(:disabled){background:#0000000d}[data-theme=dark] .microphone-wrapper .btn-microphone:hover,.dark .microphone-wrapper .btn-microphone:hover{background:#ffffff14!important}.btn-send{background:#00a884;color:#fff;border:none;width:40px!important;height:40px!important;border-radius:50%!important;flex-shrink:0;box-shadow:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}[data-theme=dark] .btn-send,.dark .btn-send{background:#00a884;color:#fff}.btn-send:hover:not(:disabled){background:#06cf9c;transform:scale(1.05)}[data-theme=dark] .btn-send:hover:not(:disabled),.dark .btn-send:hover:not(:disabled){background:#06cf9c}.btn-send:disabled{background:#e2e8f0;color:#94a3b8;cursor:default;transform:none}[data-theme=dark] .btn-send:disabled,.dark .btn-send:disabled{background:#3b4a54;color:#667781}.btn-send.editing{background:#00a884}.input-area{flex:1;display:flex;align-items:center;position:relative;min-width:0}.message-textarea{flex:1;min-height:40px;max-height:100px;padding:10px 14px;background:#fff;border:none;border-radius:21px;font-size:15px;resize:none;font-family:inherit;color:#111b21;box-sizing:border-box;transition:none;line-height:1.35}[data-theme=dark] .message-textarea,.dark .message-textarea{background:#2a3942;color:#e9edef}.message-textarea:focus{outline:none;background:#fff}[data-theme=dark] .message-textarea:focus,.dark .message-textarea:focus{background:#2a3942}.message-textarea::placeholder{color:#667781}[data-theme=dark] .message-textarea::placeholder,.dark .message-textarea::placeholder{color:#8696a0}.message-textarea.editing{border:2px solid #00a884;background:#f0fdf4}.image-preview,.video-preview,.audio-preview{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#f1f5f9;border-radius:14px;border:1px solid #e2e8f0;margin-right:6px;font-size:13px}[data-theme=dark] .image-preview,[data-theme=dark] .video-preview,[data-theme=dark] .audio-preview,.dark .image-preview,.dark .video-preview,.dark .audio-preview{background:#2a3942;border-color:#3b4a54;color:#d1d7db}.btn-cancel{background:#64748b;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-cancel:hover{background:#ef4444}.options-container{position:relative;flex-shrink:0}.options-overlay{position:fixed;inset:0;background:transparent;z-index:999}.options-menu{position:absolute;bottom:50px;left:0;background:#fff;border-radius:12px;box-shadow:0 8px 20px #00000026;padding:6px;min-width:180px;z-index:1001;animation:slideUp .2s cubic-bezier(.16,1,.3,1);border:none}[data-theme=dark] .options-menu,.dark .options-menu{background:#233138;box-shadow:0 8px 20px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.option-item{display:flex;align-items:center;gap:10px;padding:10px 14px;color:#111b21;background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;width:100%;text-align:left;transition:all .1s}[data-theme=dark] .option-item,.dark .option-item{color:#e9edef}.option-item:hover{background:#f0f2f5}[data-theme=dark] .option-item:hover,.dark .option-item:hover{background:#182229}.camera-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:2000;padding:0}.camera-content{background:#000;border-radius:0;overflow:hidden;width:100%;height:100%;position:relative;display:flex;flex-direction:column;align-items:center}.camera-title{color:#fff;margin:12px 0;font-size:1rem}.video-wrapper{width:100%;flex:1;background:#000;display:flex;justify-content:center;align-items:center}.video-wrapper video{width:100%;height:100%;object-fit:cover}.camera-controls{padding:16px;width:100%;display:flex;justify-content:space-around;align-items:center;background:#000c}.btn-capture{width:64px;height:64px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.btn-capture-inner{width:52px;height:52px;border-radius:50%;background:#fff;border:2px solid #000}.btn-capture:active .btn-capture-inner{transform:scale(.9);background:#ddd}.btn-close-camera{color:#fff;background:transparent;border:1px solid rgba(255,255,255,.4);padding:8px 14px;border-radius:18px;cursor:pointer;font-size:13px}.audio-recorder-inline{flex:1;display:flex;min-width:0}.audio-recorder-inline .audio-recorder{flex:1;min-width:0;width:100%}@media(max-width:480px){.message-input-container{padding:5px 6px;padding-bottom:calc(5px + env(safe-area-inset-bottom));gap:5px}.btn-plus,.btn-formulario,.btn-send,.btn-microphone,.btn-attach{width:34px!important;height:34px!important}.message-textarea{min-height:36px;padding:8px 12px;font-size:14px}.audio-recorder-inline .audio-recorder{gap:6px;padding:4px 6px}.audio-recorder-inline .recorder-btn{width:34px;height:34px}}@media(max-width:360px){.message-input-container{padding:4px 5px;padding-bottom:calc(4px + env(safe-area-inset-bottom));gap:4px}.btn-plus,.btn-formulario,.btn-send,.btn-microphone,.btn-attach{width:32px!important;height:32px!important}.message-textarea{min-height:32px;padding:6px 10px;font-size:13px}}:root{--form-primary: #0284c7;--form-bg: #f1f5f9;--form-card: #ffffff;--form-border: #cbd5e1;--form-text: #0f172a}.form-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.form-modal{background:var(--form-bg);width:100%;max-width:650px;height:90vh;max-height:850px;display:flex;flex-direction:column;border-radius:16px;overflow:hidden;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.form-overlay{padding:0}.form-modal{max-width:100%;height:100dvh;border-radius:0;max-height:none}.form-body.vertical-scroll{padding:16px;gap:12px}.form-section-card{padding:16px;border-radius:8px}.input-large,select,textarea{font-size:14px;padding:10px}}.form-header{background:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--form-border);flex-shrink:0}.header-content{display:flex;align-items:center;gap:12px}.header-icon{background:#e0f2fe;color:#0284c7;padding:8px;border-radius:8px}.header-icon svg{width:24px;height:24px}.form-header h1{font-size:18px;font-weight:700;margin:0;color:var(--form-text)}.form-header p{font-size:13px;color:#64748b;margin:0}.close-btn{background:#f1f5f9;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;transition:background .2s}.close-btn:hover{background:#e2e8f0;color:#0f172a}.form-body.vertical-scroll{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.form-section-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 2px #0000000d;border:1px solid #e2e8f0}.form-section-card.highlight{border:2px solid #eab308;background:#fefce8}.section-header-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;border-bottom:1px solid #f1f5f9;padding-bottom:10px}.section-icon{font-size:20px}.section-header-row h3{font-size:16px;font-weight:700;margin:0;color:var(--form-text);text-transform:uppercase;letter-spacing:.5px}.input-grid{display:grid;gap:16px;margin-bottom:16px}.input-grid.cols-2{grid-template-columns:1fr 1fr}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:13px;font-weight:600;color:#475569;margin-bottom:6px}.input-large,select,textarea{width:100%;padding:12px;border:1px solid var(--form-border);border-radius:8px;font-size:16px;background:#fff;box-sizing:border-box;color:#0f172a;transition:border-color .2s}.input-large:focus,select:focus,textarea:focus{outline:none;border-color:var(--form-primary);box-shadow:0 0 0 3px #0284c71a}.input-area-compact{width:100%;padding:12px;border:1px solid var(--form-border);border-radius:8px;font-size:16px;resize:vertical;min-height:80px;box-sizing:border-box;font-family:inherit}.toggle-group{display:flex;gap:6px;background:#f1f5f9;padding:4px;border-radius:10px}.toggle-btn{flex:1;padding:10px;border:none;background:transparent;border-radius:8px;font-weight:600;color:#64748b;font-size:14px;cursor:pointer;transition:all .2s}.toggle-btn.active{background:#fff;color:var(--form-primary);box-shadow:0 1px 3px #0000001a}.esi-selector-compact{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;flex-wrap:nowrap}@media(max-width:480px){.esi-selector-compact{flex-wrap:wrap;justify-content:center}.esi-btn-compact{min-width:45px;flex:0 0 calc(20% - 8px)}.esi-btn-compact .esi-num{font-size:18px}.esi-btn-compact .esi-txt{font-size:8px;display:none}}.esi-btn-compact{flex:1;min-width:65px;display:flex;flex-direction:column;align-items:center;padding:12px 6px;border:2px solid #e2e8f0;border-radius:10px;background:#fff;cursor:pointer;transition:transform .1s}.esi-btn-compact:active{transform:scale(.95)}.esi-btn-compact.selected{background:var(--esi-c);border-color:var(--esi-c)}.esi-btn-compact .esi-num{font-size:24px;font-weight:800;color:var(--esi-c);line-height:1;margin-bottom:4px}.esi-btn-compact.selected .esi-num,.esi-btn-compact.selected .esi-txt{color:#fff}.esi-btn-compact .esi-txt{font-size:10px;font-weight:700;text-transform:uppercase;color:#64748b;text-align:center}.vitals-grid-compact{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.vital-field label{display:block;font-size:11px;text-align:center;font-weight:700;color:#64748b;margin-bottom:4px;text-transform:uppercase}.vital-field input{width:100%;padding:10px;text-align:center;font-weight:600;font-size:16px;border:1px solid var(--form-border);border-radius:8px;color:#0f172a}.checkbox-card{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer}.checkbox-card.compact{padding:8px 12px;font-size:14px;font-weight:500}.checkbox-card.warning{background:#fffbeb;border-color:#fbbf24;color:#92400e}.form-actions-inline{display:flex;gap:12px;margin-top:24px;padding-bottom:24px}.btn-primary,.btn-secondary{flex:1;padding:16px;border-radius:12px;font-weight:700;font-size:16px;cursor:pointer;border:none;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .2s}.btn-primary{background:#dc2626;color:#fff;box-shadow:0 4px 6px -1px #dc26264d}.btn-secondary{background:#fff;color:#64748b;border:1px solid #e2e8f0}.btn-primary:active,.btn-secondary:active{opacity:.8;transform:translateY(1px)}@media(max-width:480px){.vitals-grid-compact{grid-template-columns:repeat(3,1fr)}}.deriv-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;cursor:pointer;max-width:300px;margin:4px 0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;transition:box-shadow .15s}.deriv-card:hover{box-shadow:0 3px 10px #00000026}[data-theme=dark] .deriv-card{background:#1e293b;box-shadow:0 1px 3px #0000004d}.deriv-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#f8fafc;border-bottom:1px solid #e2e8f0}[data-theme=dark] .deriv-header{background:#0f172a;border-color:#334155}.estado-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.estado-badge.pendiente{background:#fef3c7;color:#92400e}.estado-badge.aceptada{background:#d1fae5;color:#065f46}.estado-badge.rechazada{background:#fee2e2;color:#991b1b}.deriv-timer{font-size:12px;font-weight:700;font-family:SF Mono,monospace;padding:2px 8px;border-radius:4px}.deriv-timer.normal{background:#d1fae5;color:#065f46}.deriv-timer.advertencia{background:#fef3c7;color:#92400e}.deriv-timer.critico{background:#fee2e2;color:#991b1b;animation:blink 1s infinite}.deriv-timer.vencido{background:#fecaca;color:#7f1d1d}@keyframes blink{50%{opacity:.5}}.deriv-time{font-size:11px;color:#64748b}.deriv-esi{display:flex;align-items:center;gap:8px;padding:8px 12px;border-left:4px solid;background:#f8fafc}[data-theme=dark] .deriv-esi{background:#1e293b}.esi-num{font-size:13px;font-weight:700}.esi-label{font-size:11px;color:#64748b;text-transform:uppercase}.deriv-patient{display:flex;align-items:center;gap:6px;padding:8px 12px;font-size:12px;color:#475569;border-bottom:1px solid #f1f5f9}[data-theme=dark] .deriv-patient{color:#94a3b8;border-color:#334155}.dot{color:#cbd5e1}.deriv-motivo-card{margin:8px 12px;padding:10px 12px;background:#f1f5f9;border-radius:8px}[data-theme=dark] .deriv-motivo-card{background:#0f172a}.motivo-label{font-size:9px;font-weight:600;color:#64748b;text-transform:uppercase;display:block;margin-bottom:4px}.motivo-text{margin:0;font-size:12px;color:#1e293b;line-height:1.4}[data-theme=dark] .motivo-text{color:#e2e8f0}.deriv-vitals{display:flex;flex-wrap:wrap;gap:12px;padding:8px 12px;font-size:11px;color:#475569}[data-theme=dark] .deriv-vitals{color:#94a3b8}.deriv-vitals strong{color:#64748b;font-weight:500;margin-right:2px}.deriv-func{display:flex;gap:12px;padding:6px 12px;font-size:11px;color:#6366f1}.deriv-actions{display:flex;gap:8px;padding:8px 12px;border-top:1px solid #f1f5f9}[data-theme=dark] .deriv-actions{border-color:#334155}.btn-auth,.btn-deny{flex:1;padding:6px 12px;border:none;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}.btn-auth{background:#10b981;color:#fff}.btn-auth:hover{background:#059669}.btn-deny{background:#fff;color:#ef4444;border:1px solid #fecaca}.btn-deny:hover{background:#fef2f2}[data-theme=dark] .btn-deny{background:transparent;border-color:#7f1d1d}.deriv-footer{padding:6px 12px;text-align:center;font-size:11px;color:#3b82f6;background:#f8fafc;border-top:1px solid #f1f5f9}[data-theme=dark] .deriv-footer{background:#0f172a;border-color:#334155}.modal-bg{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s ease-in-out}.modal-card{background:#fff;border-radius:12px;width:95%;max-width:800px;height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 25px 50px -12px #0006;font-family:Inter,system-ui,-apple-system,sans-serif}[data-theme=dark] .modal-card{background:#1e293b;border:1px solid #334155}.modal-head-solid{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#0f172a;color:#fff;flex-shrink:0}[data-theme=dark] .modal-head-solid{background:#020617;border-bottom:1px solid #334155}.modal-head-solid h3{margin:0;font-size:1.1rem;font-weight:600;color:#f8fafc;letter-spacing:.02em}.modal-x-solid{background:#ffffff1a;border:none;width:28px;height:28px;border-radius:6px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .2s}.modal-x-solid:hover{background:#fff3}.modal-dashboard-body{display:flex;flex:1;overflow:hidden}.modal-sidebar{width:300px;background:#f1f5f9;padding:24px;border-right:1px solid #e2e8f0;overflow-y:auto;display:flex;flex-direction:column;gap:24px}[data-theme=dark] .modal-sidebar{background:#1e293b;border-right-color:#334155}.sidebar-section{display:flex;flex-direction:column;gap:12px}.sidebar-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:700}[data-theme=dark] .sidebar-label{color:#94a3b8}.patient-info-block{background:#fff;padding:16px;border-radius:8px;box-shadow:0 1px 2px #0000000d;display:flex;flex-direction:column;gap:12px}[data-theme=dark] .patient-info-block{background:#0f172a;border:1px solid #334155}.info-item{display:flex;flex-direction:column}.info-item .label{font-size:.7rem;color:#64748b;margin-bottom:2px}.info-item .value{font-size:.95rem;color:#0f172a;font-weight:500}[data-theme=dark] .info-item .value{color:#e2e8f0}.info-item .value.warning{color:#d97706;font-weight:700}.sidebar-status{margin-top:auto;padding-top:24px;display:flex;flex-direction:column;gap:12px}.timer-box{padding:12px;border-radius:8px;text-align:center}.timer-box.normal{background:#d1fae5;color:#064e3b}.timer-box.advertencia{background:#fef3c7;color:#92400e}.timer-box.critico,.timer-box.vencido{background:#fee2e2;color:#991b1b}.timer-box span{display:block;font-size:.7rem;text-transform:uppercase;opacity:.8}.timer-box strong{display:block;font-size:1.2rem;font-family:monospace}.modal-main{flex:1;padding:32px;overflow-y:auto;background:#fff}[data-theme=dark] .modal-main{background:#0f172a}.esi-banner{padding:16px 24px;border-radius:8px;color:#fff;display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;box-shadow:0 4px 6px -1px #0000001a}.esi-number{font-size:1.5rem;font-weight:800}.esi-text{font-size:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.main-section{margin-bottom:32px}.main-section h4{font-size:.85rem;text-transform:uppercase;color:#64748b;margin-bottom:12px;border-bottom:2px solid #f1f5f9;padding-bottom:8px;display:inline-block}[data-theme=dark] .main-section h4{border-bottom-color:#334155;color:#cbd5e1}.text-content{font-size:1rem;line-height:1.6;color:#334155;margin:0}[data-theme=dark] .text-content{color:#cbd5e1}.prestacion-box{background:#f8fafc;padding:12px 16px;border-left:4px solid #3b82f6;border-radius:4px;font-weight:500;color:#1e293b}[data-theme=dark] .prestacion-box{background:#1e293b;color:#fff}.vitals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.vital-tile{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;aspect-ratio:1;transition:transform .2s}[data-theme=dark] .vital-tile{background:#1e293b;border-color:#334155}.vital-tile:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.vital-tile.highlight{background:#eff6ff;border-color:#bfdbfe}[data-theme=dark] .vital-tile.highlight{background:#172554;border-color:#1e40af}.vt-label{font-size:.7rem;color:#64748b;text-transform:uppercase;margin-bottom:4px}.vt-value{font-size:1.4rem;font-weight:700;color:#0f172a}[data-theme=dark] .vt-value{color:#f8fafc}.vt-unit{font-size:.7rem;color:#94a3b8}.vital-tile.highlight .vt-value{color:#2563eb}[data-theme=dark] .vital-tile.highlight .vt-value{color:#60a5fa}.antecedentes-grid{display:flex;flex-wrap:wrap;gap:8px}.tag{background:#f1f5f9;padding:6px 12px;border-radius:20px;font-size:.85rem;color:#475569;border:1px solid #e2e8f0}.tag.full{width:100%;border-radius:8px}[data-theme=dark] .tag{background:#334155;border-color:#475569;color:#e2e8f0}.main-actions{display:flex;gap:16px;margin-top:48px;padding-top:24px;border-top:1px solid #e2e8f0}@media(max-width:480px){.deriv-card{max-width:100%}.modal-dashboard-body{flex-direction:column;overflow-y:auto}.modal-card{height:90vh;max-width:100%;margin-top:auto;border-radius:12px 12px 0 0}.modal-sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0;padding:16px;gap:16px;height:auto;overflow-y:visible;flex-shrink:0}.modal-main{padding:16px;overflow-y:visible}.vitals-grid{grid-template-columns:repeat(3,1fr)}.main-actions{flex-direction:column;gap:12px;margin-top:24px}}.derivacion-card-premium,.consulta-paciente-card{display:none}.derivaciones-overlay{position:fixed;inset:0;background:var(--bg-overlay, rgba(0, 0, 0, .5));display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.derivaciones-panel{background:var(--bg-primary, white);border-radius:16px;width:95vw;max-width:1000px;height:85vh;max-height:700px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;overflow:hidden}.derivaciones-header{padding:16px 24px;background:var(--bg-header, linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%));color:#fff;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.header-back{width:40px;height:40px;border:none;background:#ffffff26;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}.header-back:hover{background:#ffffff40}.derivaciones-header h2{margin:0;font-size:18px;font-weight:600}.filtros-section{padding:16px 24px;background:var(--bg-secondary, #f8fafc);border-bottom:1px solid var(--border-color, #e2e8f0);flex-shrink:0}.filtros-row{display:flex;gap:16px;flex-wrap:wrap}.filtro-grupo{display:flex;flex-direction:column;gap:4px}.filtro-grupo label{font-size:12px;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase}.filtro-grupo select{padding:8px 12px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;background:var(--bg-primary, white);color:var(--text-primary, #1e293b);font-size:14px;cursor:pointer;min-width:120px}.filtro-grupo select:focus{outline:none;border-color:var(--accent-primary, #0ea5e9)}.filtro-actual{margin-top:12px;font-size:13px;color:var(--text-secondary, #64748b)}@media(max-width:480px){.filtros-section{padding:12px 16px}.filtros-row{flex-direction:column;gap:12px}.filtro-grupo select{width:100%}}.resumen-section{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px 24px;background:var(--bg-primary, white);border-bottom:1px solid var(--border-color, #e2e8f0);flex-shrink:0}.resumen-card{padding:12px 16px;border-radius:10px;text-align:center;border-left:4px solid}.resumen-card.total{background:#64748b1a;border-left-color:#64748b}.resumen-card.pendientes{background:#f59e0b1a;border-left-color:#f59e0b}.resumen-card.aceptadas{background:#10b9811a;border-left-color:#10b981}.resumen-card.rechazadas{background:#ef44441a;border-left-color:#ef4444}.resumen-numero{display:block;font-size:24px;font-weight:700;color:var(--text-primary, #1e293b)}.resumen-label{font-size:12px;color:var(--text-secondary, #64748b);text-transform:uppercase;font-weight:500}.tabla-section{flex:1;overflow-y:auto;padding:0}.loading-state,.empty-state{padding:60px 20px;text-align:center;color:var(--text-secondary, #64748b);font-size:15px}.derivaciones-tabla{width:100%;border-collapse:collapse}.derivaciones-tabla thead{position:sticky;top:0;background:var(--bg-secondary, #f8fafc);z-index:10}.derivaciones-tabla th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;border-bottom:2px solid var(--border-color, #e2e8f0)}.derivaciones-tabla td{padding:14px 16px;border-bottom:1px solid var(--border-light, #f1f5f9);font-size:14px;color:var(--text-primary, #1e293b)}.derivaciones-tabla tbody tr:hover{background:var(--bg-tertiary, #f8fafc)}.badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.badge.pendiente{background:#f59e0b26;color:#d97706}.badge.aceptada{background:#10b98126;color:#059669}.badge.rechazada{background:#ef444426;color:#dc2626}.esi-badge{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:700}.esi-badge.esi-1{background:#fee2e2;color:#dc2626}.esi-badge.esi-2{background:#ffedd5;color:#ea580c}.esi-badge.esi-3{background:#fef9c3;color:#ca8a04}.esi-badge.esi-4{background:#dcfce7;color:#16a34a}.esi-badge.esi-5{background:#dbeafe;color:#2563eb}.cell-origen{display:flex;align-items:center;gap:8px}.origen-icon{font-size:16px}.cell-paciente{color:var(--text-secondary, #64748b)}.cell-fecha{font-family:-apple-system,BlinkMacSystemFont,SF Mono,monospace;font-size:13px;color:var(--text-secondary, #64748b)}.cell-accion{font-size:13px}.accion-aceptada{color:#10b981;font-weight:500}.accion-rechazada{color:#ef4444;font-weight:500}.accion-pendiente{color:var(--text-tertiary, #94a3b8)}.tabla-section::-webkit-scrollbar{width:6px}.tabla-section::-webkit-scrollbar-thumb{background:var(--text-tertiary, #94a3b8);border-radius:3px}@media(max-width:768px){.derivaciones-panel{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0}.resumen-section{grid-template-columns:repeat(2,1fr)}.derivaciones-tabla{font-size:12px}.derivaciones-tabla th,.derivaciones-tabla td{padding:10px 8px}}.sidebar-overlay{position:fixed;inset:0;background:var(--bg-overlay, rgba(0, 0, 0, .5));z-index:10000;animation:fadeIn .2s ease-out;display:flex;align-items:center;justify-content:center}[data-theme=dark]{--bg-primary: #111b21;--bg-secondary: #202c33;--bg-tertiary: #2a3942;--bg-hover: #182229;--bg-header: #202c33;--text-primary: #e9edef;--text-secondary: #8696a0;--text-tertiary: #667781;--text-inverse: #e9edef;--border-color: #2a3942;--bg-overlay: rgba(0, 0, 0, .85);--accent-primary: #53bdeb;--accent-secondary: #00a884}.chat-sidebar{position:relative;width:600px;max-width:90vw;height:80vh;background:var(--bg-primary, #ffffff);display:flex;flex-direction:column;animation:scaleIn .25s ease-out;overflow:hidden;border-radius:12px;box-shadow:0 25px 50px -12px #00000040}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.sidebar-header{background:var(--bg-header, linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%));padding:16px 20px;display:flex;align-items:center;gap:16px;min-height:64px;color:var(--text-inverse, white)}.sidebar-header h2{color:var(--text-inverse, white);font-size:18px;font-weight:600;margin:0}.sidebar-back{width:40px;height:40px;border:none;background:#ffffff26;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;color:var(--text-inverse, white)}.sidebar-back:hover{background:#ffffff40}.sidebar-header-info{display:flex;align-items:center;gap:12px;flex:1}.sidebar-avatar{width:44px;height:44px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;color:var(--text-inverse, white)}.sidebar-header-text{flex:1}.sidebar-header-text h2{font-size:16px;margin:0}.sidebar-header-text span{font-size:12px;color:#fffc}.sidebar-menu{flex:1;overflow-y:auto;padding:8px 0;background:var(--bg-primary, #ffffff)}.menu-item{width:100%;padding:14px 20px;border:none;background:transparent;display:flex;align-items:center;gap:16px;cursor:pointer;transition:background .15s;text-align:left;color:var(--text-primary, #1e293b)}.menu-item:hover{background:var(--bg-tertiary, #f1f5f9)}.menu-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.menu-icon.info{background:#0ea5e926;color:#0ea5e9}.menu-icon.derivaciones{background:#10b98126;color:#10b981}.menu-icon.buscar{background:#8b5cf626;color:#8b5cf6}.menu-icon.archivos{background:#f59e0b26;color:#f59e0b}.menu-icon.starred{background:#fbbf2426;color:#fbbf24}.menu-icon.notif{background:#ec489926;color:#ec4899}.menu-icon.stats{background:#3b82f626;color:#3b82f6}.menu-icon.export{background:#22c55e26;color:#22c55e}.menu-icon.config{background:#94a3b826;color:#64748b}.menu-text{flex:1;display:flex;flex-direction:column}.menu-label{font-size:15px;font-weight:500;color:var(--text-primary, #1e293b)}.menu-desc{font-size:12px;color:var(--text-secondary, #64748b);margin-top:2px}.menu-arrow{color:var(--text-tertiary, #94a3b8)}.menu-divider{height:1px;background:var(--border-color, #e2e8f0);margin:8px 20px}.toggle-switch{width:48px;height:26px;background:var(--text-tertiary, #94a3b8);border-radius:13px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle-switch.active{background:var(--accent-secondary, #00a884)}.toggle-thumb{width:22px;height:22px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-thumb{transform:translate(22px)}.info-panel{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto}.info-card{background:var(--bg-secondary, #f8fafc);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px}.info-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center}.info-icon.hospital{background:#0ea5e926;color:#0ea5e9}.info-icon.sala{background:#10b98126;color:#10b981}.info-icon.tiempo{background:#f59e0b26;color:#f59e0b}.info-icon.contacto{background:#8b5cf626;color:#8b5cf6}.info-content{flex:1;display:flex;flex-direction:column}.info-label{font-size:12px;color:var(--text-secondary, #64748b)}.info-value{font-size:15px;color:var(--text-primary, #1e293b);font-weight:500;margin-top:2px}.search-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.search-input-container{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-secondary, #f8fafc);border-bottom:1px solid var(--border-color, #e2e8f0);color:var(--text-secondary, #64748b)}.search-input{flex:1;border:none;background:transparent;font-size:15px;color:var(--text-primary, #1e293b);outline:none}.search-input::placeholder{color:var(--text-tertiary, #94a3b8)}.search-clear{background:none;border:none;color:var(--text-secondary, #64748b);cursor:pointer;font-size:16px}.search-results{flex:1;overflow-y:auto;padding:8px}.search-hint,.search-empty{text-align:center;color:var(--text-secondary, #64748b);padding:40px 20px;font-size:14px}.search-result-item{padding:12px;border-radius:8px;background:var(--bg-secondary, #f8fafc);margin-bottom:8px}.result-sender{font-size:12px;font-weight:600;color:var(--accent-primary, #0ea5e9)}.result-text{font-size:14px;color:var(--text-primary, #1e293b);margin:4px 0}.result-time{font-size:11px;color:var(--text-tertiary, #94a3b8)}.files-panel{flex:1;overflow-y:auto;padding:16px}.files-section{margin-bottom:24px}.files-section h3{font-size:14px;font-weight:600;color:var(--text-secondary, #64748b);margin-bottom:12px}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:4px}.file-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;cursor:pointer}.files-list{display:flex;flex-direction:column;gap:8px}.file-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary, #f8fafc);border-radius:8px;color:var(--text-primary, #1e293b);font-size:14px}.file-item svg{color:var(--accent-primary, #0ea5e9)}.link-item{word-break:break-all;text-decoration:none;color:var(--accent-primary, #0ea5e9)!important;align-items:flex-start}.link-item svg{flex-shrink:0;margin-top:2px}.link-item:hover{text-decoration:underline}.files-empty{text-align:center;color:var(--text-secondary, #64748b);padding:40px}.files-tabs-container{display:flex;border-bottom:1px solid var(--border-color, #e2e8f0);background:var(--bg-primary, #fff);padding:0 8px}.files-tab{flex:1;padding:14px;background:none;border:none;font-size:14px;font-weight:500;color:var(--text-secondary, #64748b);cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;text-align:center}.files-tab.active{color:var(--accent-primary, #0ea5e9);border-bottom-color:var(--accent-primary, #0ea5e9)}.files-tab:hover:not(.active){background:var(--bg-hover, #f1f5f9)}.file-icon-placeholder{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary, #f1f5f9);border-radius:8px;margin-right:2px;flex-shrink:0}.file-icon-placeholder.doc{background:#e0f2fe;color:#0ea5e9}.file-icon-placeholder.link{background:#f0fdf4;color:#22c55e}.video-thumb{position:relative;background:#000;display:flex;align-items:center;justify-content:center}.video-thumb video{width:100%;height:100%;object-fit:cover;opacity:.7}.video-thumb svg{position:absolute;z-index:2;width:32px;height:32px}.stats-panel{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;align-content:start}.stat-card{background:var(--bg-secondary, #f8fafc);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:20px 16px;text-align:center}.stat-value{font-size:28px;font-weight:700;display:block}.stat-label{font-size:12px;color:var(--text-secondary, #64748b);margin-top:4px;display:block}.stat-card.total .stat-value{color:var(--accent-primary, #0ea5e9)}.stat-card.text .stat-value{color:#64748b}.stat-card.images .stat-value{color:#8b5cf6}.stat-card.videos .stat-value{color:#ef4444}.stat-card.audios .stat-value{color:#f59e0b}.stat-card.derivaciones .stat-value{color:#10b981}.config-panel{flex:1;overflow-y:auto;padding:16px}.config-section{margin-bottom:24px}.config-section h3{font-size:13px;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.config-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-secondary, #f8fafc);border-radius:12px;margin-bottom:8px}.config-label{font-size:15px;color:var(--text-primary, #1e293b)}.config-select{background:var(--bg-tertiary, #f1f5f9);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:8px 12px;color:var(--text-primary, #1e293b);font-size:14px;cursor:pointer}.theme-toggle{display:flex;gap:8px}.theme-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border-color, #e2e8f0);background:var(--bg-tertiary, #f1f5f9);border-radius:8px;cursor:pointer;font-size:13px;color:var(--text-secondary, #64748b);transition:all .2s}.theme-btn.active{background:var(--accent-primary, #0ea5e9);border-color:var(--accent-primary, #0ea5e9);color:#fff}.theme-btn:hover:not(.active){background:var(--bg-secondary, #f8fafc)}.bg-selector{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.custom-bg-wrapper{display:flex}.bg-option{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #0000001a}.bg-option:hover{transform:scale(1.1)}.bg-option.active{border-color:var(--accent-primary, #0ea5e9);box-shadow:0 0 0 2px var(--accent-primary, #0ea5e9)}.sidebar-menu::-webkit-scrollbar,.info-panel::-webkit-scrollbar,.search-results::-webkit-scrollbar,.files-panel::-webkit-scrollbar,.stats-panel::-webkit-scrollbar,.config-panel::-webkit-scrollbar{width:4px}.sidebar-menu::-webkit-scrollbar-thumb,.info-panel::-webkit-scrollbar-thumb,.search-results::-webkit-scrollbar-thumb,.files-panel::-webkit-scrollbar-thumb,.stats-panel::-webkit-scrollbar-thumb,.config-panel::-webkit-scrollbar-thumb{background:var(--text-tertiary, #94a3b8);border-radius:2px}@media(max-width:480px){.sidebar-overlay{align-items:stretch;justify-content:stretch}.chat-sidebar{width:100%;max-width:100%;max-height:100%;height:100%;border-radius:0;animation:slideUp .25s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.sidebar-header{padding:12px 16px;min-height:56px}.info-panel,.search-panel,.files-panel,.stats-panel,.config-panel{padding:12px}.stats-panel{grid-template-columns:1fr}.menu-item{padding:12px 16px}}.chat-container{display:flex;flex-direction:column;height:100dvh;height:100vh;min-height:-webkit-fill-available;width:100%;background-color:#efeae2;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15 15h10v10H15V15zm40 0h10v10H55V15zm-20 20h10v10H35V35zm40 0h10v10H75V35zM15 55h10v10H15V55zm40 0h10v10H55V55zm-20 20h10v10H35V75zm40 0h10v10H75V75z' fill='%23d1d7db' fill-opacity='0.15'/%3E%3C/svg%3E");position:relative;overflow:hidden;padding-top:env(safe-area-inset-top)}[data-theme=dark] .chat-container{background-color:#0b141a;background-image:none}.chat-header-modern{background:#f0f2f5;color:#1e293b;padding:0 12px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 2px #0000000f;flex-shrink:0;height:34px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;z-index:1000}@media(max-width:480px){.chat-header-modern{height:40px;padding:0 8px}.header-actions{gap:4px}.header-title{font-size:12px;max-width:140px}}[data-theme=dark] .chat-header-modern{background:#202c33;color:#f8fafc;border-bottom:1px solid #334155}.header-left{display:flex;align-items:center;gap:16px;cursor:pointer;transition:opacity .2s}.header-left:hover{opacity:.8}.header-avatar{display:none}.header-info{display:flex;flex-direction:column;justify-content:center;align-items:center;position:absolute;left:50%;transform:translate(-50%);cursor:pointer}.header-title{margin:0;font-family:Inter,-apple-system,sans-serif;font-weight:600;font-size:14px;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.header-subtitle{font-size:.85rem;color:#64748b;margin-top:2px}[data-theme=dark] .header-subtitle{color:#94a3b8}.header-actions{display:flex;align-items:center;justify-content:center;gap:8px;margin:0;padding:0}.btn-icon-back,.btn-icon-menu{background:transparent;border:none;width:34px;height:100%;border-radius:6px;display:none;align-items:center;justify-content:center;color:#64748b;cursor:pointer;transition:all .15s ease;padding:0;margin:0;line-height:0}.btn-icon-back svg,.btn-icon-menu svg{width:20px;height:20px}.btn-icon-back:hover,.btn-icon-menu:hover{background:#f1f5f9;color:#0ea5e9}[data-theme=dark] .btn-icon-back:hover,[data-theme=dark] .btn-icon-menu:hover{background:#334155;color:#38bdf8}.messages-container{flex:1;padding:0}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.messages-container::-webkit-scrollbar-track{background:#efeae2}[data-theme=dark] .messages-container::-webkit-scrollbar-track{background:transparent}[data-theme=dark] .messages-container::-webkit-scrollbar-thumb{background:#ffffff26}.messages-container .consulta-paciente-card{align-self:flex-start;max-width:360px!important;width:100%;margin-bottom:8px}@media(max-width:480px){.messages-container .consulta-paciente-card{max-width:260px!important;margin-bottom:4px}}.typing-indicator{padding:4px 12px;margin:4px 10px;font-size:12px;color:#555;font-style:italic;background:#fff9;border-radius:12px;display:inline-block}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s}.modal-confirmacion .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-confirmacion .modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937}.modal-confirmacion .modal-body{padding:1.5rem}.modal-confirmacion .modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb}[data-theme=dark] .modal-content{background:#202c33}[data-theme=dark] .modal-confirmacion .modal-header{border-bottom-color:#334155}[data-theme=dark] .modal-confirmacion .modal-header h3{color:#f8fafc}[data-theme=dark] .modal-confirmacion .modal-footer{border-top-color:#334155}@media(max-width:360px){.chat-header-modern{padding:0 12px;height:56px}.header-actions{gap:4px}.btn-icon-back,.btn-icon-menu{width:32px;height:32px}.header-title{font-size:1rem}}@media(max-width:480px){.chat-header-modern{padding:0 16px;height:60px;gap:8px}.btn-icon-menu{display:flex}}.selector-container{padding:40px;background:var(--bg-primary);min-height:100vh;color:var(--text-primary)}.selector-header{text-align:center;margin-bottom:40px}.selector-header h1{font-size:24px;margin-bottom:8px;color:var(--text-primary)}.selector-header p{color:var(--text-secondary)}.header-row{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.btn-logout{position:absolute;top:24px;right:24px;padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ef4444;border-color:#ef4444;color:#fff}.selector-container{position:relative}.hospitals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;max-width:1200px;margin:0 auto}.hospital-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px;cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;align-items:center;text-align:center}.hospital-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a;border-color:var(--accent-primary)}.hospital-icon{font-size:40px;margin-bottom:16px}.hospital-card h3{font-size:18px;margin:0 0 8px;color:var(--text-primary)}.hospital-region{font-size:14px;color:var(--text-tertiary);background:var(--bg-tertiary);padding:4px 12px;border-radius:12px}.selector-loading,.selector-error{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:var(--text-secondary)}.superuser-badge{display:inline-block;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-left:12px}.admin-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-left:12px}.header-actions{position:absolute;top:24px;right:24px;display:flex;gap:12px;align-items:center}.header-actions .btn-logout{position:static}.btn-admin{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.btn-admin:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.selector-tabs{display:flex;justify-content:center;gap:12px;margin-bottom:32px}.tab-btn{padding:12px 24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;cursor:pointer;transition:all .2s}.tab-btn:hover{background:var(--bg-tertiary)}.tab-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.auditoria-placeholder{text-align:center;padding:60px 40px;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;max-width:600px;margin:0 auto}.placeholder-icon{font-size:60px;margin-bottom:16px}.auditoria-placeholder h2{font-size:24px;margin-bottom:8px;color:var(--text-primary)}.auditoria-placeholder p{color:var(--text-secondary);margin-bottom:24px}.placeholder-features{list-style:none;padding:0;text-align:left;display:inline-block}.placeholder-features li{padding:8px 0;font-size:15px;color:var(--text-secondary)}@media(max-width:768px){.selector-container{padding:20px}.header-actions{position:static;margin-top:16px;justify-content:center;flex-wrap:wrap}.btn-logout{position:static}.selector-header h1{font-size:20px;flex-direction:column;gap:8px}.header-row{flex-direction:column;gap:8px}.superuser-badge,.admin-badge{margin-left:0}}@media(max-width:480px){.hospitals-grid{grid-template-columns:1fr}.hospital-card{padding:16px}.selector-header{margin-bottom:24px}}.user-management{padding:1.5rem;max-width:1400px;margin:0 auto}.user-management-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.um-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.um-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.btn-crear{display:flex;align-items:center;gap:.5rem;background:var(--success);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-crear:hover{background:var(--success-dark);transform:translateY(-1px);box-shadow:var(--shadow-success)}.um-filtros{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;margin-bottom:1.5rem}.filtro-busqueda{position:relative;display:flex;align-items:center}.filtro-busqueda svg{position:absolute;left:1rem;color:var(--text-muted)}.filtro-busqueda input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid var(--border-strong);border-radius:8px;font-size:.95rem;background:var(--input-bg);color:var(--text-primary);transition:all .2s ease}.filtro-busqueda input:hover{background:var(--bg-hover);border-color:var(--border-color)}.um-filtros select{padding:.75rem 1rem;border:1px solid var(--border-strong);border-radius:8px;font-size:.95rem;background:var(--input-bg);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.um-filtros select:hover{background:var(--bg-hover);border-color:var(--border-color)}.um-filtros select:focus,.filtro-busqueda input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover);box-shadow:var(--focus-ring)}.um-filtros select option{background:var(--input-bg);color:var(--text-primary);padding:.5rem}.um-tabla-container{background:var(--card-bg);border-radius:12px;border:1px solid var(--card-border);overflow:hidden;box-shadow:var(--shadow-sm)}.um-tabla{width:100%;border-collapse:collapse}.um-tabla thead{background:var(--bg-hover);border-bottom:2px solid var(--card-border)}.um-tabla th{padding:1rem;text-align:left;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.um-tabla tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .15s}.um-tabla tbody tr:hover{background:var(--bg-hover)}.um-tabla tbody tr.inactivo{opacity:.6}.um-tabla td{padding:1rem;font-size:.95rem;color:var(--text-primary)}.um-tabla td code{background:var(--bg-hover);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-family:monospace}.tipo-badge,.rol-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.tipo-badge.hospital{background:var(--info-bg);color:var(--info-text)}.tipo-badge.cesfam{background:var(--success-bg);color:var(--success-text)}.rol-badge.rol-superuser{background:var(--warning-bg);color:var(--warning-text)}.rol-badge.rol-admin,.rol-badge.rol-medico{background:var(--info-bg);color:var(--info-text)}.rol-badge.rol-tens{background:var(--success-bg);color:var(--success-text)}.rol-badge.rol-administrativo{background:var(--info-bg);color:var(--info-text)}.btn-estado{padding:.35rem .75rem;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-estado.activo{background:var(--success-bg);color:var(--success-text)}.btn-estado.activo:hover:not(:disabled){background:var(--success-hover)}.btn-estado.inactivo{background:var(--danger-bg);color:var(--danger-text)}.btn-estado.inactivo:hover:not(:disabled){background:var(--danger-hover)}.btn-estado:disabled{opacity:.5;cursor:not-allowed}.acciones{display:flex;gap:.5rem}.btn-accion.editar{background:var(--info-bg);color:var(--info-text)}.btn-accion.editar:hover{background:var(--info-hover)}.btn-accion.password{background:var(--warning-bg);color:var(--warning-text)}.btn-accion.password:hover{background:var(--warning-hover)}.btn-accion.eliminar{background:var(--danger-bg);color:var(--danger-text)}.btn-accion.eliminar:hover:not(:disabled){background:var(--danger-hover)}.btn-accion:disabled{opacity:.3;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-contenido{background:var(--card-bg);border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s}.modal-contenido.modal-pequeno{max-width:450px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--card-border)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.25rem;border-radius:4px;transition:all .2s}.modal-header button:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-contenido form{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem;color:var(--text-primary)}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-strong);border-radius:8px;font-size:.95rem;background:var(--input-bg);color:var(--text-primary);transition:all .2s}.form-group input:hover,.form-group select:hover{background:var(--bg-hover);border-color:var(--border-color)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover);box-shadow:var(--focus-ring)}.form-group input:disabled{background:var(--input-disabled);color:var(--text-muted);cursor:not-allowed;border-color:var(--border-subtle)}.form-group select option{background:var(--input-bg);color:var(--text-primary);padding:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.password-input{position:relative}.password-input input{padding-right:3rem}.btn-toggle-password{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s}.btn-toggle-password:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.btn-cancelar,.btn-guardar,.btn-eliminar{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancelar{background:var(--bg-hover);color:var(--text-primary)}.btn-cancelar:hover{background:var(--border-color)}.btn-guardar{background:var(--info);color:#fff}.btn-guardar:hover{background:var(--info-dark);box-shadow:var(--shadow-info)}.btn-eliminar{background:var(--danger);color:#fff}.btn-eliminar:hover{background:var(--danger-dark);box-shadow:var(--shadow-danger)}.notificacion{position:fixed;top:2rem;right:2rem;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-radius:8px;font-weight:500;box-shadow:0 10px 15px -3px #0000001a;z-index:1001;animation:slideInRight .3s;min-width:300px}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notificacion.success{background:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.notificacion.error{background:var(--danger-bg);color:var(--danger-text);border:1px solid var(--danger-border)}.notificacion button{background:none;border:none;cursor:pointer;padding:.25rem;color:inherit;opacity:.7;transition:opacity .2s}.notificacion button:hover{opacity:1}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--info);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1024px){.um-filtros{grid-template-columns:1fr}.um-tabla-container{overflow-x:auto}.um-tabla{min-width:800px}}@media(max-width:768px){.um-header{flex-direction:column;align-items:flex-start;gap:1rem}.modal-contenido{width:95%;margin:1rem}.form-row{grid-template-columns:1fr}}.derivacion-management{padding:1.5rem;max-width:1600px;margin:0 auto}.derivacion-management-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.dm-header{margin-bottom:2rem}.dm-title{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.dm-title h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.dm-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:var(--card-bg);padding:1.25rem;border-radius:12px;border:2px solid var(--card-border);text-align:center;transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card.total{border-color:var(--info)}.stat-card.pendientes{border-color:var(--warning)}.stat-card.aceptadas{border-color:var(--success)}.stat-card.rechazadas{border-color:var(--danger)}.stat-card.tiempo{border-color:var(--accent-secondary)}.stat-value{font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-card.total .stat-value{color:var(--info)}.stat-card.pendientes .stat-value{color:var(--warning)}.stat-card.aceptadas .stat-value{color:var(--success)}.stat-card.rechazadas .stat-value{color:var(--danger)}.stat-card.tiempo .stat-value{color:var(--accent-secondary)}.stat-label{font-size:.85rem;color:var(--text-muted);font-weight:500}.dm-filtros{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filtro-group{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.dm-filtros select,.dm-filtros input[type=date]{padding:.65rem 1rem;border:1px solid var(--border-strong);border-radius:8px;font-size:.9rem;background:var(--input-bg);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.dm-filtros select:hover,.dm-filtros input[type=date]:hover{background:var(--bg-hover);border-color:var(--border-color)}.dm-filtros select:focus,.dm-filtros input[type=date]:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover);box-shadow:var(--focus-ring)}.dm-filtros select option{background:var(--input-bg);color:var(--text-primary);padding:.5rem}.btn-export-derivaciones{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;background:var(--gradient-success);border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:600;white-space:nowrap;margin-left:auto}.btn-export-derivaciones:hover{transform:translateY(-2px);box-shadow:var(--shadow-success)}.btn-export-derivaciones:active{transform:translateY(0)}.dm-tabla-container{background:var(--card-bg);border-radius:12px;border:1px solid var(--card-border);overflow:hidden;box-shadow:var(--shadow-sm)}.dm-tabla{width:100%;border-collapse:collapse}.dm-tabla thead{background:var(--bg-hover);border-bottom:2px solid var(--card-border)}.dm-tabla th{padding:1rem;text-align:left;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.dm-tabla tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .15s}.dm-tabla tbody tr:hover{background:var(--bg-hover)}.dm-tabla td{padding:1rem;font-size:.95rem;color:var(--text-primary)}.origen-info{display:flex;flex-direction:column;gap:.25rem}.origen-nombre{font-weight:500}.origen-tipo{font-size:.8rem;color:var(--text-muted)}.paciente-info{display:flex;flex-direction:column;gap:.25rem}.paciente-prevision{font-size:.8rem;color:var(--text-muted)}.estado-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.estado-badge.estado-pendiente{background:var(--warning-bg);color:var(--warning-text)}.estado-badge.estado-aceptada{background:var(--success-bg);color:var(--success-text)}.estado-badge.estado-rechazada{background:var(--danger-bg);color:var(--danger-text)}.esi-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:700;text-transform:uppercase}.esi-badge.esi-1{background:#991b1b;color:#fff}.esi-badge.esi-2{background:#dc2626;color:#fff}.esi-badge.esi-3{background:#f59e0b;color:#fff}.esi-badge.esi-4{background:#22c55e;color:#fff}.esi-badge.esi-5{background:#3b82f6;color:#fff}.sla-timer{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:6px;font-size:.85rem;font-weight:600;transition:all .3s ease;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.sla-timer.sla-normal{background:var(--info-bg);color:var(--info-text);animation:none}.sla-timer.sla-warning{background:var(--warning-bg);color:var(--warning-text);animation:pulse 2s ease-in-out infinite}.sla-timer.sla-critical{background:var(--warning-bg);color:var(--warning-text);animation:pulse 1.5s ease-in-out infinite}.sla-timer.sla-exceeded{background:var(--danger-bg);color:var(--danger-text);animation:pulse 1s ease-in-out infinite;box-shadow:0 0 0 2px var(--danger-border)}.sla-timer svg{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dm-acciones{display:flex;gap:.5rem}.btn-accion{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.btn-accion.ver{background:var(--info-bg);color:var(--info-text)}.btn-accion.ver:hover{background:var(--info-hover)}.btn-accion.aceptar{background:var(--success-bg);color:var(--success-text)}.btn-accion.aceptar:hover{background:var(--success-hover)}.btn-accion.rechazar{background:var(--danger-bg);color:var(--danger-text)}.btn-accion.rechazar:hover{background:var(--danger-hover)}.btn-accion.reasignar{background:var(--warning-bg);color:var(--warning-text)}.btn-accion.reasignar:hover{background:var(--warning-hover)}.modal-body{padding:1.5rem;max-height:70vh;overflow-y:auto}.modal-grande{max-width:800px}.detalle-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--card-border)}.detalle-section:last-child{border-bottom:none}.detalle-section h4{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;color:var(--text-primary);font-size:1.1rem}.detalle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detalle-item{display:flex;flex-direction:column;gap:.25rem}.detalle-item.full-width{grid-column:1 / -1}.detalle-item label{font-weight:600;font-size:.85rem;color:var(--text-muted)}.detalle-item span{color:var(--text-primary)}.motivo-texto{background:var(--bg-hover);padding:1rem;border-radius:8px;border:1px solid var(--card-border);color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.textarea-motivo{width:100%;padding:.75rem;border:1px solid var(--border-strong);border-radius:8px;font-family:inherit;font-size:.95rem;resize:vertical;background:var(--input-bg);color:var(--text-primary);transition:all .2s ease}.textarea-motivo:hover{background:var(--bg-hover);border-color:var(--border-color)}.textarea-motivo:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover);box-shadow:var(--focus-ring)}.btn-aceptar{background:var(--success);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-aceptar:hover{background:var(--success-dark);box-shadow:var(--shadow-success)}.btn-rechazar{background:var(--danger);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-rechazar:hover{background:var(--danger-dark);box-shadow:var(--shadow-danger)}.btn-reasignar{background:var(--warning);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-reasignar:hover{background:var(--warning-dark);box-shadow:var(--shadow-warning)}@media(max-width:1200px){.dm-stats-cards{grid-template-columns:repeat(3,1fr)}.dm-tabla-container{overflow-x:auto}.dm-tabla{min-width:900px}}@media(max-width:768px){.dm-stats-cards{grid-template-columns:repeat(2,1fr)}.dm-filtros{flex-direction:column;align-items:stretch}.dm-filtros select,.dm-filtros input[type=date]{width:100%}.detalle-grid{grid-template-columns:1fr}}.kpi-stats{padding:1.5rem;max-width:1600px;margin:0 auto}.kpi-stats-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.kpi-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.kpi-stats-title{display:flex;align-items:center;gap:1rem}.kpi-stats-title h2{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin:0}.kpi-stats-title p{font-size:.875rem;color:var(--text-muted);margin:.25rem 0 0}.kpi-stats-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.date-filters{display:flex;align-items:center;gap:.75rem}.date-filters .filter-group{display:flex;align-items:center;gap:.5rem;color:var(--text-muted)}.date-filters input[type=date]{padding:.65rem 1rem;border:1px solid var(--border-strong);border-radius:8px;font-size:.875rem;background:var(--input-bg);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.date-filters input[type=date]:hover{background:var(--bg-hover);border-color:var(--border-color)}.date-filters input[type=date]:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--focus-ring)}.btn-refresh,.btn-export{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-refresh{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-primary)}.btn-refresh:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-export{background:var(--gradient-success);color:#fff}.btn-export:hover{transform:translateY(-1px);box-shadow:var(--shadow-success)}.kpi-main-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem;margin-bottom:2rem}.kpi-main-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow-sm);transition:all .2s}.kpi-main-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-main-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.kpi-main-icon.success{background:var(--success-bg);color:var(--success)}.kpi-main-icon.warning{background:var(--warning-bg);color:var(--warning)}.kpi-main-icon.info{background:var(--info-bg);color:var(--info)}.kpi-main-icon.danger{background:var(--danger-bg);color:var(--danger)}.kpi-main-content{display:flex;flex-direction:column;gap:.25rem;flex:1}.kpi-main-label{font-size:.875rem;font-weight:500;color:var(--text-muted)}.kpi-main-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.kpi-main-sublabel{font-size:.75rem;color:var(--text-muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.kpi-chart-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm)}.kpi-chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.kpi-chart-header h3{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.kpi-chart-header p{font-size:.75rem;color:var(--text-muted);margin:.25rem 0 0}.kpi-chart{min-height:250px;position:relative}.chart-empty{display:flex;align-items:center;justify-content:center;height:250px;color:var(--text-muted);font-size:.875rem}.line-chart{position:relative;height:250px}.line-chart-grid{position:absolute;inset:0 0 50px;display:flex;flex-direction:column;justify-content:space-between}.grid-line{width:100%;height:1px;background:var(--border-subtle)}.line-chart-bars{position:absolute;bottom:0;left:0;right:0;height:200px;display:flex;align-items:flex-end;justify-content:space-around;gap:.5rem}.line-chart-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative}.line-chart-bar{width:100%;background:var(--gradient-primary);border-radius:4px 4px 0 0;transition:all .3s ease;min-height:2px}.line-chart-bar.derivaciones{background:var(--gradient-success)}.line-chart-bar:hover{opacity:.8}.line-chart-label{position:absolute;bottom:-25px;font-size:.75rem;color:var(--text-muted);white-space:nowrap}.line-chart-value{position:absolute;top:-20px;font-size:.75rem;font-weight:600;color:var(--text-primary)}.distribution-bars{display:flex;flex-direction:column;gap:1rem}.distribution-item{display:grid;grid-template-columns:150px 1fr 60px;align-items:center;gap:1rem}.distribution-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary)}.type-icon{width:8px;height:8px;border-radius:50%}.type-icon.texto{background:#22c55e}.type-icon.imagen{background:#3b82f6}.type-icon.video{background:#8b5cf6}.type-icon.audio{background:#f59e0b}.type-icon.derivacion{background:#ef4444}.type-icon.archivo{background:#6366f1}.distribution-value{margin-left:auto;font-weight:600;color:var(--text-muted)}.distribution-bar-bg{height:8px;background:var(--bg-hover);border-radius:4px;overflow:hidden}.distribution-bar{height:100%;border-radius:4px;transition:width .3s ease}.distribution-bar.texto{background:#22c55e}.distribution-bar.imagen{background:#3b82f6}.distribution-bar.video{background:#8b5cf6}.distribution-bar.audio{background:#f59e0b}.distribution-bar.derivacion{background:#ef4444}.distribution-bar.archivo{background:#6366f1}.distribution-percent{font-size:.875rem;font-weight:600;color:var(--text-primary);text-align:right}.hourly-chart{display:flex;align-items:flex-end;justify-content:space-between;height:200px;gap:.25rem}.hourly-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.hourly-bars{width:100%;height:180px;display:flex;align-items:flex-end;justify-content:center;gap:1px}.hourly-bar{flex:1;border-radius:2px 2px 0 0;transition:all .3s ease;min-height:2px}.hourly-bar.mensajes{background:var(--accent-primary)}.hourly-bar.derivaciones{background:var(--success)}.hourly-bar:hover{opacity:.7}.hourly-label{margin-top:.25rem;font-size:.7rem;color:var(--text-muted)}.kpi-table-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}.kpi-table-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--card-border)}.kpi-table-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.kpi-table-header p{font-size:.875rem;color:var(--text-muted);margin:.25rem 0 0}.kpi-table-container{overflow-x:auto}.kpi-table{width:100%;border-collapse:collapse}.kpi-table thead{background:var(--bg-hover)}.kpi-table th{padding:1rem 1.5rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.kpi-table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .15s}.kpi-table tbody tr:hover{background:var(--bg-hover)}.kpi-table tbody tr:last-child{border-bottom:none}.kpi-table td{padding:1rem 1.5rem;font-size:.875rem;color:var(--text-primary)}.esi-badge-small{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;color:#fff;text-transform:uppercase}.tiempo-retraso{display:inline-flex;align-items:center;gap:.35rem;color:var(--danger);font-weight:600}.estado-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase}.estado-badge.pendiente{background:var(--warning-bg);color:var(--warning-text)}.prioridad-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.prioridad-badge.critica{background:var(--danger-bg);color:var(--danger-text);animation:pulse-badge 2s ease-in-out infinite}.prioridad-badge.alta{background:var(--warning-bg);color:var(--warning-text)}.prioridad-badge.media{background:var(--info-bg);color:var(--info-text)}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:1200px){.kpi-grid{grid-template-columns:1fr}.kpi-main-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.kpi-stats-header{flex-direction:column;align-items:flex-start}.kpi-stats-actions{width:100%;flex-direction:column;align-items:stretch}.date-filters{width:100%;flex-direction:column}.date-filters input[type=date]{width:100%}.btn-refresh,.btn-export{width:100%;justify-content:center}.kpi-main-cards{grid-template-columns:1fr}.distribution-item{grid-template-columns:1fr;gap:.5rem}.distribution-percent{text-align:left}.kpi-table-container{overflow-x:scroll}.kpi-table{min-width:800px}}.theme-toggle{display:flex;align-items:center;gap:.5rem;padding:.65rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;white-space:nowrap}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-md)}.theme-toggle:active{transform:translateY(0)}.theme-icon{color:var(--accent-primary);transition:transform .3s ease}.theme-toggle:hover .theme-icon{transform:rotate(15deg) scale(1.1)}.theme-label{color:var(--text-secondary);font-weight:500}@media(max-width:640px){.theme-label{display:none}.theme-toggle{padding:.65rem;min-width:40px;justify-content:center}}.theme-transition *{transition:background-color .3s ease,border-color .3s ease,color .3s ease!important}.theme-switching *{transition:none!important}.admin-dashboard{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--card-bg);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-header-left{display:flex;align-items:center;gap:1.5rem}.admin-header-divider{width:1px;height:32px;background:var(--border-color)}.admin-header h1{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.admin-header-actions{display:flex;gap:1rem;align-items:center}.btn-back{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--bg-hover);border-color:var(--border-strong);transform:translateY(-1px)}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--info-bg);border:1px solid var(--info);border-radius:20px;font-size:.875rem;color:var(--info-text)}.admin-content{flex:1;overflow-y:auto;padding:1.5rem 2rem}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--card-bg);padding:.5rem;border-radius:12px;border:1px solid var(--border-color);width:fit-content}.admin-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s;font-weight:500}.admin-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-tab.active{background:var(--gradient-primary);color:var(--text-inverse)}.alertas-banner{background:var(--danger-bg);border:1px solid var(--danger);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem}.alertas-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:var(--danger-text);font-weight:600}.alertas-list{display:flex;flex-direction:column;gap:.5rem}.alerta-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--card-hover-bg);border-radius:6px;font-size:.875rem;border-left:3px solid}.alerta-item.prioridad-critica{border-left-color:var(--danger);color:var(--danger-text)}.alerta-item.prioridad-alta{border-left-color:var(--warning);color:var(--warning-text)}.alerta-item.prioridad-media{border-left-color:var(--info);color:var(--info-text)}.alertas-more{text-align:center;padding:.5rem;color:var(--text-muted);font-size:.75rem}.kpi-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2rem}.kpi-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:1.5rem;transition:all .3s ease}.kpi-card-clickable{cursor:pointer;position:relative}.kpi-card-clickable:after{content:"👆 Click para detalles";position:absolute;bottom:-25px;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--accent-primary);opacity:0;transition:opacity .3s ease;white-space:nowrap}.kpi-card-clickable:hover:after{opacity:1}.kpi-card:hover{background:var(--card-hover-bg);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.kpi-card-clickable:hover{background:var(--info-bg);border-color:var(--info);transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl)}.kpi-card-clickable:active{transform:translateY(-2px) scale(1.01)}.kpi-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.kpi-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,#667eea33,#764ba233)}.kpi-card-icon.mensajes{background:linear-gradient(135deg,#22c55e33,#16a34a33)}.kpi-card-icon.derivaciones{background:linear-gradient(135deg,#ef444433,#dc262633)}.kpi-card-icon.pendientes{background:linear-gradient(135deg,#fbbf2433,#f59e0b33)}.kpi-card-icon.usuarios{background:linear-gradient(135deg,#3b82f633,#2563eb33)}.kpi-card-icon.aceptacion{background:linear-gradient(135deg,#10b98133,#05966933)}.kpi-card-icon.rechazo{background:linear-gradient(135deg,#ef444433,#dc262633)}.kpi-card-icon.tiempo{background:linear-gradient(135deg,#8b5cf633,#7c3aed33)}.kpi-card-icon.sla{background:linear-gradient(135deg,#fbbf2433,#f59e0b33)}.kpi-card-label{font-size:.875rem;color:var(--text-muted);font-weight:500}.kpi-card-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.kpi-card-change{font-size:.75rem;color:var(--success-text);margin-top:.5rem}.kpi-card-change.negative{color:var(--danger-text)}.charts-section{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:1.5rem}.chart-card h3{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.bar-chart{display:flex;align-items:flex-end;gap:.5rem;height:180px;padding-top:1rem}.bar-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.bar{width:100%;min-height:4px;background:var(--gradient-primary);border-radius:4px 4px 0 0;transition:height .5s ease}.bar-label{font-size:.7rem;color:var(--text-muted);text-align:center}.bar-value{font-size:.7rem;color:var(--text-primary);font-weight:600}.pie-chart{display:flex;flex-direction:column;gap:.75rem}.pie-item{display:flex;align-items:center;gap:.75rem}.pie-color{width:12px;height:12px;border-radius:3px}.pie-color.texto{background:#22c55e}.pie-color.imagen{background:#3b82f6}.pie-color.video{background:#8b5cf6}.pie-color.audio{background:#f59e0b}.pie-color.derivacion{background:#ef4444}.pie-color.archivo{background:#6366f1}.pie-info{flex:1;display:flex;justify-content:space-between}.pie-label{font-size:.875rem;color:var(--text-primary)}.pie-value{font-size:.875rem;color:var(--text-muted)}.top-salas{display:flex;flex-direction:column;gap:.75rem}.sala-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--bg-hover);border-radius:8px}.sala-rank{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:6px;font-size:.75rem;font-weight:700}.sala-info{flex:1}.sala-name{font-weight:500;color:var(--text-primary)}.sala-code{font-size:.75rem;color:var(--text-muted)}.sala-count{font-weight:600;color:var(--accent-primary)}.audit-section{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;overflow:hidden}.audit-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--card-border)}.audit-header h3{font-size:1rem;font-weight:600}.audit-actions{display:flex;gap:1rem;align-items:center}.audit-filters{display:flex;gap:.75rem}.btn-export{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--gradient-success);border:none;border-radius:8px;color:#fff;cursor:pointer;transition:all .2s;font-size:.875rem;font-weight:500;white-space:nowrap}.btn-export:hover{transform:translateY(-2px);box-shadow:var(--shadow-success)}.audit-filter{padding:.5rem 1rem;background:var(--input-bg);border:1px solid var(--border-strong);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s ease}.audit-filter:hover{background:var(--bg-hover);border-color:var(--border-color)}.audit-filter:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-hover);box-shadow:var(--focus-ring)}.audit-filter option{background:var(--input-bg);color:var(--text-primary);padding:.5rem}.audit-table{width:100%}.audit-table th,.audit-table td{padding:1rem 1.5rem;text-align:left}.audit-table th{background:var(--bg-hover);color:var(--text-muted);font-weight:500;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.audit-table tr{border-bottom:1px solid var(--border-subtle)}.audit-table tr:last-child{border-bottom:none}.audit-table tr:hover td{background:var(--bg-hover)}.audit-table td{font-size:.875rem}.accion-badge{display:inline-flex;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.accion-badge.LOGIN{background:#22c55e33;color:#22c55e}.accion-badge.LOGIN_FALLIDO{background:#ef444433;color:#ef4444}.accion-badge.MENSAJE{background:#3b82f633;color:#3b82f6}.accion-badge.DERIVACION_CREADA{background:#fbbf2433;color:#f59e0b}.accion-badge.DERIVACION_ACEPTADA{background:#22c55e33;color:#22c55e}.accion-badge.DERIVACION_RECHAZADA{background:#ef444433;color:#ef4444}.accion-badge.ARCHIVO_SUBIDO{background:#8b5cf633;color:#8b5cf6}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.charts-section{grid-template-columns:1fr}.kpi-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.admin-header{flex-direction:column;gap:1rem}.kpi-cards{grid-template-columns:1fr}.admin-tabs{flex-wrap:wrap}.audit-filters{flex-direction:column}}
