@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary-green: #10b981;--primary-blue: #3b82f6;--primary-teal: #14b8a6;--gradient-start: #0ea5e9;--gradient-mid: #14b8a6;--gradient-end: #10b981;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--traffic-red: #ef4444;--traffic-yellow: #fbbf24;--traffic-green: #10b981;--sentiment-positive: #10b981;--sentiment-neutral: #6b7280;--sentiment-negative: #ef4444;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out}:root,[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: rgba(30, 41, 59, .6);--bg-gradient: linear-gradient(135deg, #0f172a 0%, #1a2332 100%);--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: rgba(148, 163, 184, .1);--border-hover: rgba(148, 163, 184, .2);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(16, 185, 129, .3)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #e2e8f0;--bg-card: rgba(255, 255, 255, .8);--bg-gradient: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--border-color: rgba(148, 163, 184, .2);--border-hover: rgba(148, 163, 184, .3);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .2);--shadow-glow: 0 0 20px rgba(16, 185, 129, .2)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-gradient);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-base),color var(--transition-base)}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--gradient-start),var(--gradient-end));border-radius:4px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--primary-blue),var(--primary-green))}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:2.5rem;font-weight:700}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{color:var(--text-secondary)}.gradient-text{background:linear-gradient(90deg,var(--gradient-start),var(--gradient-mid),var(--gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass-card{background:var(--bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}[data-theme=light] .glass-card{background:#ffffffe6;border:1px solid rgba(148,163,184,.15);box-shadow:0 2px 8px #0000000a}.glass-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}[data-theme=light] .glass-card:hover{box-shadow:0 8px 20px #00000014;border-color:#0ea5e940}.btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;font-size:.875rem;cursor:pointer;border:none;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--spacing-xs)}.btn-primary{background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));color:#fff}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge-success{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.2)}.badge-warning{background:#f59e0b1a;color:var(--warning);border:1px solid rgba(245,158,11,.2)}.badge-danger{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.badge-info{background:#3b82f61a;color:var(--info);border:1px solid rgba(59,130,246,.2)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .5s ease-out}.animate-slide-in{animation:slideIn .5s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--primary-green);border-radius:50%;animation:spin .8s linear infinite}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-semibold{font-weight:600}.font-bold{font-weight:700}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.app-container{display:flex;min-height:100vh;background:var(--bg-gradient)}.main-content{flex:1;margin-left:280px;padding:var(--spacing-2xl);transition:margin-left var(--transition-base)}.main-content.collapsed{margin-left:80px}.page-wrapper{max-width:1400px;margin:0 auto}@media(max-width:1024px){.main-content{margin-left:80px;padding:var(--spacing-lg)}}.mobile-menu-toggle{display:none}@media(max-width:768px){.main-content{margin-left:0;padding:var(--spacing-md);padding-top:5rem}.mobile-menu-toggle{display:flex;position:fixed;top:1rem;left:1rem;z-index:900;background:var(--bg-card);border:1px solid var(--border-color);padding:.75rem;min-width:44px;min-height:44px;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-primary);box-shadow:var(--shadow-md);cursor:pointer}[data-theme=light] .mobile-menu-toggle{background:#fff}}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:1000;transition:all var(--transition-base)}[data-theme=light] .sidebar{background:linear-gradient(180deg,#fffffffa,#c7d2ff,#79b68bfa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:5px 0 15px #0d121480;border-right:1px solid rgba(24,47,58,.12)}.sidebar-header{padding:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.logo-container{display:flex;align-items:center;gap:var(--spacing-md)}.logo-image-wrapper{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:var(--shadow-md);background:#fff}[data-theme=light] .logo-image-wrapper{box-shadow:0 2px 8px #0000001a}.logo-image{width:100%;height:100%;object-fit:contain}.logo-info{flex:1}.logo-title{font-size:1.25rem;font-weight:700;margin:0;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-subtitle{font-size:.75rem;color:var(--text-muted);margin:0;text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{flex:1;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto}.nav-item{position:relative;display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:transparent;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:left;color:var(--text-secondary)}.nav-item:hover{background:#3b82f60d;border-color:var(--border-hover);transform:translate(4px)}[data-theme=light] .nav-item:hover{background:#0ea5e914;border-color:#0ea5e933}.nav-item.active{background:linear-gradient(90deg,#0ea5e91a,#10b9811a);border-color:#0ea5e94d;color:var(--text-primary)}[data-theme=light] .nav-item.active{background:linear-gradient(90deg,#0ea5e926,#10b98126);border-color:#0ea5e959}.nav-item.active .nav-item-icon{color:var(--gradient-start)}.nav-item-icon{display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.nav-item-content{flex:1;display:flex;flex-direction:column;gap:2px}.nav-item-label{font-weight:600;font-size:.9rem}.nav-item-description{font-size:.7rem;color:var(--text-muted)}.nav-item-indicator{position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:linear-gradient(180deg,var(--gradient-start),var(--gradient-end));border-radius:2px 0 0 2px}.sidebar-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--spacing-md)}.sidebar-actions{display:flex;justify-content:space-between;width:100%}.user-profile{display:flex;align-items:center;gap:.75rem;width:100%;padding:.5rem;border-radius:var(--radius-md);background:#ffffff0d;transition:all .2s ease;margin-top:.5rem}[data-theme=light] .user-profile{background:#00000008}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.avatar-img{width:100%;height:100%;object-fit:cover}.user-info{display:flex;flex-direction:column;overflow:hidden;flex:1}.user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .user-info{display:none}.sidebar.collapsed .user-profile{padding:0;background:transparent;justify-content:center;margin-top:0}.logout-button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.logout-button:hover{color:var(--danger);background:#ef44441a}.sidebar.collapsed .logout-button{display:none}.theme-toggle-button,.collapse-button{width:32px;height:32px;border-radius:var(--radius-md);background:#1e293b66;border:1px solid var(--border-color);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base)}[data-theme=light] .theme-toggle-button,[data-theme=light] .collapse-button{background:#fff9}.theme-toggle-button:hover,.collapse-button:hover{background:#0ea5e91a;color:var(--text-primary);border-color:var(--border-hover)}[data-theme=light] .theme-toggle-button:hover,[data-theme=light] .collapse-button:hover{background:#0ea5e926}.sidebar.collapsed{width:80px}.sidebar.collapsed .logo-info,.sidebar.collapsed .nav-item-content{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--spacing-md) 0}.sidebar.collapsed .sidebar-header{padding:var(--spacing-lg) var(--spacing-md);display:flex;justify-content:center}.sidebar.collapsed .sidebar-footer{padding:var(--spacing-lg) var(--spacing-md);justify-content:center}@media(max-width:768px){.collapse-button.desktop-only{display:none}.sidebar{transform:translate(-100%);width:280px}.sidebar.mobile-open{transform:translate(0);box-shadow:10px 0 30px #00000080}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.mobile-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-muted);cursor:pointer}}.mobile-close-button,.sidebar-overlay{display:none}@media(max-width:768px){.sidebar-overlay{display:block}.sidebar-header{display:flex;justify-content:space-between;align-items:center}}.metric-card{position:relative;overflow:hidden}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));opacity:0;transition:opacity var(--transition-base)}.metric-card:hover:before{opacity:1}.metric-card-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.metric-card-icon-wrapper{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0ea5e91a,#10b9811a);border:1px solid rgba(14,165,233,.2)}.metric-card-icon{color:var(--gradient-start)}.metric-card-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0}.metric-card-value{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm);line-height:1}.metric-card-trend{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:600}.trend-up{color:var(--success)}.trend-down{color:var(--danger)}.trend-indicator{font-size:1.25rem}.trend-value{opacity:.9}.metric-card-success .metric-card-icon-wrapper{background:linear-gradient(135deg,#10b9811a,#10b9810d);border-color:#10b98133}.metric-card-success .metric-card-icon{color:var(--success)}.metric-card-warning .metric-card-icon-wrapper{background:linear-gradient(135deg,#f59e0b1a,#f59e0b0d);border-color:#f59e0b33}.metric-card-warning .metric-card-icon{color:var(--warning)}.metric-card-info .metric-card-icon-wrapper{background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border-color:#3b82f633}.metric-card-info .metric-card-icon{color:var(--info)}.metrics-page{animation:fadeIn .5s ease-out}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:var(--spacing-lg)}.chart-container{min-height:400px}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.chart-subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--spacing-lg)}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg);gap:var(--spacing-md)}.traffic-filters{display:flex;gap:var(--spacing-xs)}.filter-btn{padding:var(--spacing-xs) var(--spacing-md);background:#fff6;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.filter-btn:hover{border-color:var(--border-hover);background:#0ea5e91a}.filter-btn.active{background:linear-gradient(90deg,#0ea5e933,#10b98133);border-color:#0ea5e966;color:var(--text-primary)}.filter-btn.green.active{background:#10b98133;border-color:#10b98166}.filter-btn.yellow.active{background:#fbbf2433;border-color:#fbbf2466}.filter-btn.red.active{background:#ef444433;border-color:#ef444466}@media(max-width:1200px){.charts-section{grid-template-columns:1fr}}@media(max-width:768px){.metrics-grid{grid-template-columns:1fr}.page-title{font-size:1.75rem}.chart-header{flex-direction:column;align-items:stretch}.traffic-filters{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:.5rem}.filter-btn{flex:1;text-align:center;min-width:60px}.chart-container{min-height:300px}}@media(max-width:480px){.page-title{font-size:1.5rem}.charts-section{display:flex;flex-direction:column}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);min-height:400px}.error-container svg{color:var(--danger)}.error-container h2{color:var(--text-primary);margin:0}.error-container p{color:var(--text-secondary);text-align:center;max-width:500px}.error-hint{font-size:.875rem;color:var(--text-muted);font-style:italic}.empty-container{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);min-height:400px}.empty-container p{color:var(--text-muted);font-size:1.125rem}.conversations-page{animation:fadeIn .5s ease-out}.source-filter-container{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.source-filter-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:#1e293b66;border:2px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all var(--transition-base)}[data-theme=light] .source-filter-btn{background:#fff9}.source-filter-btn:hover{border-color:var(--border-hover);background:#0ea5e91a;transform:translateY(-2px)}.source-filter-btn.active{background:linear-gradient(135deg,#0ea5e933,#10b98133);border-color:var(--info);color:var(--text-primary);box-shadow:0 4px 12px #0ea5e94d}.filter-count{margin-left:auto;padding:.125rem .5rem;background:#0ea5e94d;border-radius:var(--radius-sm);font-size:.75rem}.clear-search{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-base)}.clear-search:hover{background:#ef44441a;color:var(--danger)}.conversations-container{min-height:400px}.conversations-header{margin-bottom:var(--spacing-lg)}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;color:var(--text-primary)}.conversations-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.conversation-card{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.conversation-card:hover{border-color:var(--border-hover);background:#0ea5e90d;transform:translate(4px)}.conversation-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.conversation-content{flex:1;min-width:0}.conversation-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.conversation-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.conversation-count{font-size:.75rem;padding:.25rem .75rem;background:#0ea5e933;color:var(--info);border-radius:var(--radius-sm);font-weight:600}.conversation-phone{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:.875rem;margin-bottom:var(--spacing-sm)}.last-message{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:#1e293b66;border-radius:var(--radius-md);margin-top:var(--spacing-sm)}[data-theme=light] .last-message{background:#f1f5f999}.sender-badge{display:inline-block;padding:.125rem .5rem;background:#0ea5e933;color:var(--info);border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.message-preview{margin:0;color:var(--text-secondary);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.message-time{font-size:.75rem;color:var(--text-muted)}.gmail-info{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm);font-size:.875rem;align-items:center}.thread-count{color:var(--success);font-weight:600;font-size:.75rem}.fase-badge{padding:.125rem .5rem;background:#0ea5e933;color:var(--info);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:capitalize}.semaforo-badge{padding:.125rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.semaforo-badge.rojo{background:#ef444433;color:var(--danger)}.semaforo-badge.amarillo{background:#fbbf2433;color:#f59e0b}.semaforo-badge.verde{background:#10b98133;color:var(--success)}.last-update{color:var(--text-muted);font-size:.75rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--spacing-lg);animation:fadeIn .2s ease-out}[data-theme=light] .modal-overlay{background:#0006}.modal-content.whatsapp-style{width:100%;max-width:600px;max-height:85vh;display:flex;flex-direction:column;background:#0b141a;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease-out;overflow:hidden}[data-theme=light] .modal-content.whatsapp-style{background:#f0f2f5}.whatsapp-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#202c33;border-bottom:1px solid rgba(255,255,255,.1)}[data-theme=light] .whatsapp-header{background:#f0f2f5;border-bottom:1px solid rgba(0,0,0,.1)}.whatsapp-header-info{display:flex;align-items:center;gap:var(--spacing-md)}.whatsapp-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#00a884,#25d366);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.whatsapp-contact h2{margin:0;font-size:1rem;font-weight:600;color:#e9edef}[data-theme=light] .whatsapp-contact h2{color:#111b21}.whatsapp-contact p{margin:0;font-size:.8125rem;color:#8696a0}[data-theme=light] .whatsapp-contact p{color:#667781}.whatsapp-close{background:none;border:none;color:#8696a0;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.whatsapp-close:hover{background:#ffffff1a;color:#e9edef}[data-theme=light] .whatsapp-close{color:#54656f}[data-theme=light] .whatsapp-close:hover{background:#0000000d;color:#111b21}.whatsapp-body{flex:1;overflow-y:auto;padding:var(--spacing-lg);background:#0b141a;background-image:linear-gradient(#0b141ad9,#0b141ad9),url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAwIiBoZWlnaHQ9IjEwMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZGVmcz48cGF0dGVybiBpZD0iYSIgcGF0dGVyblVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgd2lkdGg9IjEwMCIgaGVpZ2h0PSIxMDAiPjxwYXRoIGQ9Ik0wIDBoMTAwdjEwMEgweiIgZmlsbD0ibm9uZSIvPjxwYXRoIGQ9Ik0wIDBoMTAwdjEwMEgweiIgZmlsbD0ibm9uZSIvPjwvcGF0dGVybj48L2RlZnM+PHJlY3Qgd2lkdGg9IjEwMCUiIGhlaWdodD0iMTAwJSIgZmlsbD0idXJsKCNhKSIgb3BhY2l0eT0iLjA1Ii8+PC9zdmc+)}[data-theme=light] .whatsapp-body{background:#efeae2}.loading-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-2xl)}.whatsapp-messages{display:flex;flex-direction:column;gap:var(--spacing-sm)}.whatsapp-message{display:flex;flex-direction:column;max-width:75%;animation:messageSlide .2s ease-out}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.whatsapp-message.clinica{align-self:flex-start}.whatsapp-message.paciente{align-self:flex-end}.whatsapp-bubble{position:relative;padding:6px 7px 8px 9px;border-radius:7.5px;box-shadow:0 1px .5px #00000021}.whatsapp-message.clinica .whatsapp-bubble{background:#202c33;border-radius:0 7.5px 7.5px}[data-theme=light] .whatsapp-message.clinica .whatsapp-bubble{background:#fff}.whatsapp-message.paciente .whatsapp-bubble{background:#005c4b;border-radius:7.5px 0 7.5px 7.5px}[data-theme=light] .whatsapp-message.paciente .whatsapp-bubble{background:#d9fdd3}.whatsapp-text{margin:0;padding:0;font-size:.875rem;line-height:1.5;color:#e9edef;word-wrap:break-word;white-space:pre-wrap}[data-theme=light] .whatsapp-text{color:#111b21}.whatsapp-time{display:block;margin-top:4px;font-size:.6875rem;color:#8696a0;text-align:right}[data-theme=light] .whatsapp-time{color:#667781}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--info);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.source-filter-container{flex-direction:row;overflow-x:auto}.modal-overlay{padding:0;align-items:flex-end;background:#0b141a}[data-theme=light] .modal-overlay{background:#f0f2f5}.modal-content.whatsapp-style{max-width:100%;height:100%;max-height:100%;border-radius:0;display:flex;flex-direction:column}.whatsapp-header{padding:var(--spacing-sm)}.message{max-width:85%}.whatsapp-messages{padding-bottom:2rem}}.sentiment-page{animation:fadeIn .5s ease-out}.page-header{margin-bottom:var(--spacing-2xl)}.page-title{font-size:2.5rem;margin-bottom:var(--spacing-sm)}.page-subtitle{color:var(--text-muted);font-size:1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:var(--spacing-lg)}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.25rem;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.sentiment-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}.sentiment-chart-container,.word-cloud-container{min-height:450px}.word-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:center;justify-content:center;padding:var(--spacing-xl);min-height:300px}.word-cloud-item{font-weight:700;cursor:pointer;transition:all var(--transition-base);padding:var(--spacing-xs);border-radius:var(--radius-sm);-webkit-user-select:none;user-select:none}.word-cloud-item:hover{transform:scale(1.3);opacity:1!important;text-shadow:0 0 15px currentColor}.conversations-sentiment-section{min-height:400px}.sentiment-conversations-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.sentiment-conversation-item{padding:var(--spacing-md);background:#1e293b66;border:1px solid var(--border-color);border-left:4px solid;border-radius:var(--radius-md);transition:all var(--transition-base)}[data-theme=light] .sentiment-conversation-item{background:#fffc;border:1px solid rgba(148,163,184,.2)}.sentiment-conversation-item.positive{border-left-color:var(--sentiment-positive)}.sentiment-conversation-item.neutral{border-left-color:var(--sentiment-neutral)}.sentiment-conversation-item.negative{border-left-color:var(--sentiment-negative)}.sentiment-conversation-item:hover{border-color:var(--border-hover);transform:translate(4px);background:#fff9}.sentiment-conversation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);gap:var(--spacing-md)}.sentiment-indicator{display:flex;align-items:center;gap:var(--spacing-sm)}.sentiment-emoji{font-size:1.5rem}.sentiment-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.conversation-info{display:flex;align-items:center;gap:var(--spacing-md)}.conversation-patient{font-weight:600;color:var(--text-primary)}.conversation-time{font-size:.75rem;color:var(--text-muted)}.conversation-message{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.sender-label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.conversation-message p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.sentiment-score{font-size:.75rem;color:var(--text-muted);text-align:right}.sentiment-score strong{color:var(--text-primary);font-weight:700}@media(max-width:1024px){.sentiment-overview{grid-template-columns:1fr}}@media(max-width:768px){.page-title{font-size:2rem}.sentiment-conversation-header{flex-direction:column;align-items:flex-start}.conversation-info{width:100%;justify-content:space-between}.word-cloud{padding:var(--spacing-md)}}.patients-page{animation:fadeIn .5s ease-out}.header-stats{display:flex;gap:var(--spacing-md)}.stat-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(90deg,#0ea5e91a,#10b9811a);border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-md);color:var(--text-primary);font-weight:600}.search-container{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-xl)}.search-icon{color:var(--text-muted)}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:1rem;font-family:inherit}.search-input::placeholder{color:var(--text-muted)}.patients-table-container{overflow:hidden}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.table-count{font-size:.875rem;color:var(--text-muted);font-weight:600}.patients-table-wrapper{overflow-x:auto}.patients-table{width:100%;border-collapse:collapse}.patients-table thead{background:#1e293b66;border-bottom:2px solid var(--border-color)}[data-theme=light] .patients-table thead{background:#f1f5f999}.patients-table th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.patients-table tbody tr{border-bottom:1px solid var(--border-color);transition:all var(--transition-base)}.patient-row:hover{background:#0ea5e90d;transform:scale(1.01)}.patients-table td{padding:var(--spacing-md) var(--spacing-lg);color:var(--text-secondary)}.patient-name-cell{display:flex;align-items:center;gap:var(--spacing-md)}.patient-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gradient-start),var(--gradient-end));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem}.patient-name{font-weight:600;color:var(--text-primary)}.phone-cell{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary)}.date-text{font-size:.875rem;color:var(--text-muted)}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.patients-table thead{display:none}.patients-table,.patients-table tbody,.patients-table tr,.patients-table td{display:block;width:100%}.patients-table tr{margin-bottom:var(--spacing-lg);background:#ffffff0d;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:0 4px 6px -1px #0000001a}[data-theme=light] .patients-table tr{background:#fff}.patients-table td{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0;text-align:right;border-bottom:1px solid rgba(255,255,255,.05)}[data-theme=light] .patients-table td{border-bottom:1px solid rgba(0,0,0,.05)}.patients-table td:last-child{border-bottom:none}.patients-table td:before{content:attr(data-label);font-weight:600;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;text-align:left;margin-right:1rem}.patient-name-cell{flex-direction:row-reverse;justify-content:flex-end}.patients-table td[data-label=Paciente]{justify-content:center;border-bottom:2px solid var(--border-color);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md)}.patients-table td[data-label=Paciente]:before{display:none}.patients-table td[data-label=Paciente] .patient-name-cell{width:100%;justify-content:flex-start}.contact-cell,.date-cell,.surgery-cell{align-items:flex-end}}.contact-cell{display:flex;flex-direction:column;gap:var(--spacing-xs)}.email-cell{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:.875rem}.rut-text{font-family:monospace;color:var(--text-secondary)}.fase-badge{padding:.25rem .75rem;background:#0ea5e91a;color:var(--info);border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.semaforo-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:capitalize}.semaforo-badge.verde{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.2)}.semaforo-badge.amarillo{background:#fbbf241a;color:var(--warning);border:1px solid rgba(251,191,36,.2)}.semaforo-badge.rojo{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.date-cell{display:flex;align-items:center;gap:var(--spacing-xs)}.surgery-cell{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--success);font-weight:600}.no-surgery{color:var(--text-muted)}.patient-doctor{font-size:.75rem;color:var(--text-muted);margin-top:2px}.traffic-light-page{animation:fadeIn .5s ease-out}.traffic-light-section{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2xl);padding:var(--spacing-2xl);margin-bottom:var(--spacing-xl);background:linear-gradient(145deg,#1e293b99,#0f172a99)}[data-theme=light] .traffic-light-section{background:#ffffff80}.traffic-light-container{position:relative;filter:drop-shadow(0 20px 30px rgba(0,0,0,.5))}.traffic-mount{position:absolute;top:-20px;left:50%;transform:translate(-50%);width:20px;height:40px;background:#334155;border-radius:4px;z-index:0}.traffic-light-box{position:relative;display:flex;flex-direction:column;gap:15px;padding:15px;background:#1e293b;border-radius:20px;border:4px solid #0f172a;box-shadow:inset 0 0 20px #00000080,0 10px 20px #0000004d;z-index:1}.traffic-light{position:relative;width:60px;height:60px;border-radius:50%;border:none;background:#334155;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 5px 10px #00000080;overflow:hidden}.traffic-light:before{content:"";position:absolute;top:5%;left:20%;width:30%;height:30%;background:#ffffff1a;border-radius:50%;filter:blur(2px)}.traffic-light.red{background:#451a1a}.traffic-light.yellow{background:#45381a}.traffic-light.green{background:#1a452e}.traffic-light.red.active{background:#ef4444;box-shadow:0 0 20px #ef4444,0 0 40px #ef4444,inset 0 0 20px #ffffff80;transform:scale(1.05)}.traffic-light.yellow.active{background:#f59e0b;box-shadow:0 0 20px #f59e0b,0 0 40px #f59e0b,inset 0 0 20px #ffffff80;transform:scale(1.05)}.traffic-light.green.active{background:#10b981;box-shadow:0 0 20px #10b981,0 0 40px #10b981,inset 0 0 20px #ffffff80;transform:scale(1.05)}.traffic-light:not(.active):hover{filter:brightness(1.2);transform:scale(1.02)}.traffic-details{flex:1;display:flex;flex-direction:column;gap:var(--spacing-lg)}.traffic-header-info h2{margin:0 0 var(--spacing-xs) 0;font-size:1.5rem;color:var(--text-primary)}.traffic-header-info p{margin:0;color:var(--text-muted)}.traffic-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.traffic-stat-card{background:#1e293b66;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}[data-theme=light] .traffic-stat-card{background:#ffffffe6;border:1px solid rgba(148,163,184,.2)}.traffic-stat-card:hover{transform:translateY(-4px);background:#1e293b99}.traffic-stat-card.red:hover{border-color:#ef444480}.traffic-stat-card.yellow:hover{border-color:#fbbf2480}.traffic-stat-card.green:hover{border-color:#10b98180}.traffic-stat-card.active{background:#1e293bcc;border-width:2px}.traffic-stat-card.red.active{border-color:#ef4444;box-shadow:0 4px 12px #ef444433}.traffic-stat-card.yellow.active{border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b33}.traffic-stat-card.green.active{border-color:#10b981;box-shadow:0 4px 12px #10b98133}.stat-icon-wrapper{font-size:1.5rem;background:#ffffff0d;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}.stat-content{display:flex;flex-direction:column}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:600}.stat-number{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-desc{font-size:.75rem;color:var(--text-muted)}.active-filter-banner{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);padding:var(--spacing-md);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;color:var(--info)}.clear-filter-link{background:none;border:none;color:var(--text-primary);text-decoration:underline;cursor:pointer;font-size:.875rem}.clear-filter-link:hover{color:var(--info)}@media(max-width:1024px){.traffic-light-section{flex-direction:column;text-align:center}.traffic-details{width:100%}.traffic-header-info{display:none}}.classifications-list{display:flex;flex-direction:column;gap:var(--spacing-lg)}.classification-card{position:relative;overflow:hidden}.classification-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;transition:all var(--transition-base)}.classification-card.green:before{background:var(--traffic-green)}.classification-card.yellow:before{background:var(--traffic-yellow)}.classification-card.red:before{background:var(--traffic-red)}.classification-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);gap:var(--spacing-md)}.classification-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.classification-badge-container{display:flex;align-items:center;gap:var(--spacing-sm)}.classification-icon{font-size:1.5rem}.classification-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.badge-green{background:#10b9811a;color:var(--traffic-green);border:1px solid rgba(16,185,129,.2)}.badge-yellow{background:#fbbf241a;color:var(--traffic-yellow);border:1px solid rgba(251,191,36,.2)}.badge-red{background:#ef44441a;color:var(--traffic-red);border:1px solid rgba(239,68,68,.2)}.patient-info{display:flex;flex-direction:column;gap:.25rem}.patient-info .patient-name{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.patient-info .patient-phone{font-size:.875rem;color:var(--text-muted);margin:0}.classification-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-sm)}.classification-time{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.expand-button{background:#0ea5e91a;border:1px solid rgba(14,165,233,.2);border-radius:var(--radius-md);padding:var(--spacing-xs);cursor:pointer;color:var(--gradient-start);display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.expand-button:hover{background:#0ea5e933;transform:scale(1.1)}.classification-reason{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md);background:#1e293b66;border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}[data-theme=light] .classification-reason{background:#f1f5f999}.classification-reason svg{color:var(--gradient-start);flex-shrink:0;margin-top:2px}.classification-reason p{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.conversation-log{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.log-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-md)}.log-messages{display:flex;flex-direction:column;gap:var(--spacing-md)}.log-message{padding:var(--spacing-md);border-radius:var(--radius-md);border-left:3px solid}.log-message.agent{background:#10b9810d;border-left-color:var(--success)}.log-message.patient{background:#3b82f60d;border-left-color:var(--info)}.log-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.log-sender{font-size:.75rem;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.log-time{font-size:.7rem;color:var(--text-muted)}.log-message-text{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.empty-icon{color:var(--text-muted);opacity:.5}.empty-state p{color:var(--text-muted);font-size:1rem}@media(max-width:768px){.traffic-light-section{padding:var(--spacing-lg)}.filter-tabs{flex-wrap:nowrap;overflow-x:auto}.classification-header{flex-direction:column}.classification-meta{flex-direction:row;align-items:center;width:100%;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm)}.classification-time{white-space:normal}}.progress-container{margin-top:var(--spacing-md)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary);font-weight:600}.progress-bar{width:100%;height:8px;background:#94a3b81a;border-radius:999px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--gradient-start),var(--gradient-end));transition:width var(--transition-base)}.progress-phases{display:flex;justify-content:space-between;margin-top:var(--spacing-sm)}.phase-indicator{font-size:.875rem;color:var(--text-muted)}.phase-indicator.completed{color:var(--success)}.expanded-content{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.phase-details h4{margin:0 0 var(--spacing-md) 0;color:var(--text-primary);font-size:1rem}.phase-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.phase-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.phase-item strong{color:var(--text-secondary);font-size:.875rem}.status-ok{color:var(--success);font-weight:600}.status-error{color:var(--danger);font-weight:600}.status-pending{color:var(--text-muted)}.priority-badge{padding:.25rem .5rem;background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);font-size:.75rem;font-weight:700}.more-messages{text-align:center;color:var(--text-muted);font-size:.875rem;margin-top:var(--spacing-sm)}.surgery-date{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--success);font-weight:600}.login-wrapper{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;position:relative;overflow:hidden;background:linear-gradient(135deg,#f0f4f8,#dbeafe)}[data-theme=dark] .login-wrapper{background:linear-gradient(135deg,#0f172a,#1e293b)}.login-decorative-circle{position:absolute;border-radius:50%;filter:blur(100px);z-index:0;opacity:.5;animation:float 20s infinite alternate}.circle-1{width:600px;height:600px;background:radial-gradient(circle,#0ea5e966,#0ea5e900 70%);top:-200px;left:-200px}.circle-2{width:500px;height:500px;background:radial-gradient(circle,#10b98166,#10b98100 70%);bottom:-150px;right:-150px;animation-delay:-10s}.login-card{width:400px;max-width:90%;padding:3rem 2.5rem;border-radius:24px;background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 20px 40px #0000000d,0 1px 1px #ffffff80 inset;border:1px solid rgba(255,255,255,.4);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:10;transform:translateY(0);transition:transform .3s ease,box-shadow .3s ease}[data-theme=dark] .login-card{background:#1e293b99;border:1px solid rgba(255,255,255,.05);box-shadow:0 25px 50px -12px #00000080}.login-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px #00000014,0 1px 1px #fff9 inset}.login-header{margin-bottom:2.5rem;width:100%;display:flex;flex-direction:column;align-items:center}.logo-container-login{width:100px;height:100px;background:#fff;border-radius:24px;padding:12px;box-shadow:0 10px 25px #00000014;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;animation:scaleIn .8s cubic-bezier(.2,.8,.2,1)}.login-logo-img{width:100%;height:100%;object-fit:contain}.login-title{font-size:2rem;font-weight:800;color:#1e293b;margin:0 0 .5rem;letter-spacing:-.02em;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:slideUp .8s cubic-bezier(.2,.8,.2,1) .1s backwards}[data-theme=dark] .login-title{background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.login-subtitle{font-size:.95rem;color:#64748b;margin:0;font-weight:500;animation:slideUp .8s cubic-bezier(.2,.8,.2,1) .2s backwards}[data-theme=dark] .login-subtitle{color:#94a3b8}.login-content{width:100%;animation:slideUp .8s cubic-bezier(.2,.8,.2,1) .3s backwards}.login-instruction{font-size:.9rem;color:#64748b;margin-bottom:2rem;line-height:1.6}.auth-btn{width:100%;padding:1rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:12px;border:none;outline:none;position:relative;overflow:hidden}.auth-btn.google{background:#fff;color:#374151;border:1px solid #e5e7eb;box-shadow:0 4px 6px -1px #0000000d}.auth-btn.google:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 10px 15px -3px #00000014;border-color:#d1d5db}.auth-btn.google:active{transform:translateY(0)}.google-icon{width:20px;height:20px}.unauthorized-message{padding:1rem;border-radius:12px;background:#ef44440d;border:1px solid rgba(239,68,68,.2)}.error-icon{color:#ef4444;margin-bottom:1rem;animation:pulse 2s infinite}.auth-btn.logout{background:#fff;color:#ef4444;border:1px solid #fca5a5;margin-top:1rem}.auth-btn.logout:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626}.login-footer{margin-top:3rem;font-size:.75rem;color:#94a3b8;animation:fadeIn 1s ease .6s backwards}@keyframes float{0%{transform:translate(0)}to{transform:translate(30px,30px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.spinner{width:40px;height:40px;border:3px solid rgba(14,165,233,.2);border-radius:50%;border-top-color:#0ea5e9;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.login-card{width:90%;max-width:100%;padding:2rem 1.5rem;margin:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-title{font-size:1.75rem}.circle-1{width:300px;height:300px;top:-50px;left:-50px;opacity:.4}.circle-2{width:250px;height:250px;bottom:-50px;right:-50px;opacity:.4}.login-header{margin-bottom:2rem}}
