@import"https://fonts.googleapis.com/css2?family=SUSE+Mono:ital,wght@0,100..800;1,100..800&display=swap";*{margin:0;padding:0;box-sizing:border-box;font-family:SUSE Mono,monospace}#root{width:100%;padding:0}.landing-container{display:flex;flex-direction:column;min-height:100vh;font-family:Arial,sans-serif;color:#333}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;background:#fff;box-shadow:0 2px 8px #0000001a;position:relative}.logo-about{max-width:250px;height:auto;margin:0 auto 40px;display:block;box-shadow:0 4px 15px #0000001a;border-radius:10px;transition:transform .3s ease}.logo-about:hover{transform:scale(1.05)}.logo{font-size:1.5rem;font-weight:700;color:#6b21a8}.nav-buttons{display:flex;justify-content:end;gap:15px}.nav-button{padding:10px 20px;border:2px solid #6b21a8;background:transparent;color:#6b21a8;font-weight:500;border-radius:6px;cursor:pointer;transition:all .3s ease;font-size:1rem}.nav-button:hover{background:#6b21a8;color:#fff;transform:translateY(-2px)}.nav-button.primary{background:#6b21a8;color:#fff}.nav-button.primary:hover{background:#4c1d95}.hero-section{flex:1;display:flex;justify-content:center;align-items:center;text-align:center;background:linear-gradient(135deg,#ede9fe,#f3e8ff);padding:80px 20px}.hero-content{max-width:700px;animation:fadeIn .8s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-size:2.5rem;font-weight:700;color:#4c1d95;margin-bottom:20px;line-height:1.2}.hero-subtitle{font-size:1.2rem;color:#555;margin-bottom:30px;line-height:1.6;min-height:60px}.hero-button{padding:12px 30px;background:#6b21a8;color:#fff;font-size:1rem;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease}.hero-button:hover{background:#4c1d95;transform:translateY(-2px);box-shadow:0 4px 12px #6b21a84d}.about-section{padding:60px 20px;background:#fff;text-align:center}.section-title{font-size:2rem;font-weight:700;color:#6b21a8;margin-bottom:20px}.section-text{max-width:800px;margin:0 auto;font-size:1rem;color:#555;line-height:1.6}.benefits-section{padding:60px 20px;background:#f9f9f9;text-align:center}.benefits-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:25px;max-width:1000px;margin:0 auto}.benefit-card{background:#fff;padding:25px;border-radius:10px;box-shadow:0 2px 10px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.benefit-card:hover{transform:translateY(-5px);box-shadow:0 4px 20px #00000026}.benefit-title{font-size:1.2rem;font-weight:700;color:#4c1d95;margin-bottom:10px}.benefit-text{font-size:1rem;color:#555;line-height:1.4}.landing-footer{background:#6b21a8;color:#fff;text-align:center;padding:15px;font-size:.9rem}@media (max-width: 1024px){.landing-header{padding:15px 30px}.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1.1rem}.benefits-container{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.section-title{font-size:1.8rem}}@media (max-width: 768px){.landing-header{padding:15px 20px;flex-wrap:wrap;gap:15px}.logo{font-size:1.3rem;flex:1 1 100%;text-align:center}.nav-buttons{width:100%;justify-content:center;gap:10px}.nav-button{flex:1;padding:10px 15px;font-size:.9rem}.hero-section{padding:60px 20px}.hero-title{font-size:1.8rem;margin-bottom:15px}.hero-subtitle{font-size:1rem;margin-bottom:25px;min-height:50px}.hero-button{padding:12px 25px;font-size:.95rem}.about-section,.benefits-section{padding:40px 20px}.section-title{font-size:1.6rem;margin-bottom:15px}.section-text{font-size:.95rem}.logo-about{max-width:200px;margin-bottom:30px}.benefits-container{grid-template-columns:1fr;gap:20px;max-width:400px}.benefit-card{padding:20px}.benefit-title{font-size:1.1rem}.benefit-text{font-size:.95rem}}@media (max-width: 480px){.landing-header{padding:12px 15px}.logo{font-size:1.2rem}.nav-buttons{flex-direction:column;gap:10px}.nav-button{width:100%;padding:12px}.hero-section{padding:40px 15px}.hero-title{font-size:1.5rem;line-height:1.3}.hero-subtitle{font-size:.9rem;min-height:45px}.hero-button{padding:12px 20px;font-size:.9rem;width:100%;max-width:250px}.about-section,.benefits-section{padding:30px 15px}.section-title{font-size:1.4rem}.section-text{font-size:.9rem;line-height:1.5}.logo-about{max-width:180px;margin-bottom:25px}.benefit-card{padding:18px}.benefit-title{font-size:1rem}.benefit-text{font-size:.9rem}.landing-footer{padding:12px;font-size:.85rem}}@media (max-width: 768px) and (orientation: landscape){.hero-section{padding:40px 20px}.hero-title{font-size:1.6rem}.hero-subtitle{font-size:.95rem;min-height:auto}.about-section,.benefits-section{padding:30px 20px}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.btn{display:flex;align-items:center;gap:8px;padding:4px 8px;margin-bottom:2rem;border-radius:.3rem;border:none;cursor:pointer;background-color:#5f41e4;transition:.3s ease;color:#fff}.btn:hover{background-color:#462cbb}.loader{width:48px;height:48px;border-radius:50%;display:inline-block;border-top:4px solid #FFF;border-right:4px solid transparent;box-sizing:border-box;animation:rotation 1s linear infinite}.loader:after{content:"";box-sizing:border-box;position:absolute;left:0;top:0;width:48px;height:48px;border-radius:50%;border-left:4px solid #FF3D00;border-bottom:4px solid transparent;animation:rotation .5s linear infinite reverse}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-background{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(#00000080,#00000080),url(/assets/background-clUr8fC5.jpg) no-repeat center center/cover}.auth-container{max-width:410px;margin:0 auto;background:#fff;border-radius:.5rem;padding:2rem 1.5rem;box-shadow:0 10px 20px #0000001a}.auth-container .form-title{text-align:center;font-size:1.37rem;font-weight:600;margin-bottom:1.87rem}.auth-container .social-login{display:flex;gap:1.31rem}.social-login .social-button{flex-grow:1;display:flex;width:100px;align-items:center;justify-content:center;gap:.83rem;font-weight:500;padding:.7rem 0;cursor:pointer;border-radius:.3rem;background:#f9f9ff;border:1px solid #d5cbff;font-size:1rem;transition:.3s ease}.social-login .social-button:hover{background:#f1eff9;border-color:#5f41e4}.social-login .social-button .social-icon{width:23px}.auth-container .separator{display:flex;align-items:center;margin:1.5rem 0}.auth-container .separator span{background:#fff;z-index:1;font-size:1.06rem;font-weight:500;margin-inline:.9rem}.auth-container .separator:before,.auth-container .separator:after{content:"";flex-grow:1;height:1px;background:#bfb3f2}.auth-form .input-wrapper{position:relative;height:54px;width:100%;margin-bottom:1.5rem}.auth-form .input-wrapper .input-field{height:100%;width:100%;outline:none;font-size:1.06rem;border-radius:.31rem;border:1px solid #bfb3f2;padding:0 1.25rem 0 3.12rem}.auth-form .input-wrapper svg{position:absolute;top:50%;left:1.25rem;transform:translateY(-50%)}.auth-form .input-field:focus{border-color:#5f41e4}.auth-form .input-field:focus+svg{color:#5f41e4}.auth-form .input-field:focus~.input-icon{color:#5f41e4}.auth-form .forgot-password-link{font-size:.87rem;font-weight:500;color:#8c8c8c;float:right;margin-bottom:2rem;text-decoration:none}.auth-form .forgot-password-link:hover{color:#5f41e4}.auth-button{width:100%;background:#4caf50;border:none;border-radius:.3rem;height:54px;color:#fff;font-size:1.06rem;font-weight:600;cursor:pointer;transition:.3s ease}.auth-button:hover{background:#348236}.auth-text{font-size:.87rem;font-weight:500;color:#8c8c8c;text-align:center;margin-top:1.5rem}.auth-text a{color:#5f41e4;text-decoration:none;font-weight:600}.auth-text a:hover{text-decoration:underline}.error-message{color:red;text-align:center;margin-bottom:1rem}.success-message{color:green;text-align:center;margin-bottom:1rem}.loader-container{display:flex;justify-content:center;margin-bottom:1rem}.input-wrapper{position:relative}.input-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);z-index:2}.show-password-btn{position:absolute;right:2.5rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#bfb3f2;z-index:2;padding:.5rem;border-radius:.25rem;transition:color .3s ease,background-color .3s ease;display:flex;align-items:center;justify-content:center}.show-password-btn:hover{color:#5f41e4;background-color:#f9f9ff}.input-field:focus~.show-password-btn{color:#5f41e4}.input-field{padding-left:3.5rem!important;padding-right:3rem!important}.button-container{display:flex;justify-content:center}.button-container>button{display:flex;justify-content:center;margin:0}.comentarios-section{padding:.75rem 1.25rem 1rem;border-top:1px solid #f0f0f0;background:#fafafa}.comentario-form{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.comentario-avatar-small{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.comentario-input{flex:1;padding:.625rem 1rem;border:1px solid #e5e5e5;border-radius:20px;font-size:.875rem;outline:none;transition:border-color .2s}.comentario-input:focus{border-color:#7a3e9d}.comentario-input::placeholder{color:#999}.comentario-btn-enviar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:#7a3e9d;color:#fff;cursor:pointer;transition:background .2s,transform .2s;flex-shrink:0}.comentario-btn-enviar:hover:not(:disabled){background:#5b2d79;transform:scale(1.05)}.comentario-btn-enviar:disabled{background:#ccc;cursor:not-allowed}.comentarios-lista{display:flex;flex-direction:column;gap:.75rem}.comentario-item{display:flex;gap:.625rem;align-items:flex-start;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.comentario-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.comentario-contenido{flex:1;background:#fff;padding:.5rem .75rem;border-radius:12px;border:1px solid #eee}.comentario-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.comentario-autor{font-size:.8125rem;font-weight:600;color:#333}.comentario-fecha{font-size:.75rem;color:#999}.comentario-texto{font-size:.875rem;color:#444;margin:0;line-height:1.4;word-wrap:break-word}.comentario-btn-eliminar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:#999;cursor:pointer;transition:all .2s;flex-shrink:0;opacity:0}.comentario-item:hover .comentario-btn-eliminar{opacity:1}.comentario-btn-eliminar:hover{background:#fee2e2;color:#dc2626}.comentarios-btn-mas{width:100%;padding:.5rem;border:none;background:transparent;color:#7a3e9d;font-size:.8125rem;font-weight:600;cursor:pointer;transition:color .2s}.comentarios-btn-mas:hover:not(:disabled){color:#5b2d79;text-decoration:underline}.comentarios-btn-mas:disabled{color:#999}.comentarios-vacio{text-align:center;color:#999;font-size:.875rem;padding:.5rem 0;margin:0}@media (max-width: 640px){.comentarios-section{padding:.625rem 1rem .875rem}.comentario-avatar-small,.comentario-avatar{width:28px;height:28px}.comentario-input{font-size:.8125rem;padding:.5rem .875rem}.comentario-btn-enviar{width:32px;height:32px}.comentario-contenido{padding:.375rem .625rem}.comentario-autor{font-size:.75rem}.comentario-texto{font-size:.8125rem}.comentario-btn-eliminar{opacity:1}}.publicacion-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:1.25rem;transition:box-shadow .3s ease,transform .2s ease;animation:fadeIn .4s ease}.publicacion-card:hover{box-shadow:0 4px 16px #0000001a}.publicacion-card.deleting{opacity:.5;pointer-events:none;text-align:center;padding:2rem}.publicacion-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem 1.25rem;border-bottom:1px solid #f0f0f0}.autor-info{display:flex;gap:.875rem;align-items:center}.autor-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5}.autor-detalles{display:flex;flex-direction:column;gap:.125rem}.autor-nombre{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0}.autor-meta{font-size:.8125rem;color:#666;margin:0}.publicacion-fecha{font-size:.75rem;color:#999}.publicacion-menu{position:relative}.menu-toggle{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:50%;color:#666;transition:background .2s ease}.menu-toggle:hover{background:#f5f5f5}.menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e5e5e5;border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:150px;z-index:10;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.75rem 1rem;border:none;background:none;cursor:pointer;font-size:.9375rem;color:#333;text-align:left;transition:background .2s ease}.menu-item:hover{background:#f9f9f9}.menu-item.delete{color:#dc2626}.menu-item.delete:hover{background:#fef2f2}.publicacion-contenido{padding:1rem 1.25rem}.publicacion-descripcion{font-size:.9375rem;line-height:1.6;color:#333;margin:0 0 1rem;white-space:pre-wrap;word-wrap:break-word}.publicacion-imagen-container{margin-top:1rem;border-radius:8px;overflow:hidden;background:#f5f5f5}.publicacion-imagen{width:100%;height:auto;display:block;max-height:500px;object-fit:contain}.publicacion-footer{padding:.75rem 1.25rem;border-top:1px solid #f0f0f0}.btn-like{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:.5rem .75rem;border-radius:6px;font-size:.9375rem;color:#666;transition:all .2s ease}.btn-like:hover{background:#f9f9f9}.btn-like.liked{color:#dc2626}.btn-like.liked .icon-heart{color:#dc2626;animation:heartBeat .3s ease}.btn-like.processing{opacity:.6;pointer-events:none}.btn-like:disabled{cursor:not-allowed}@keyframes heartBeat{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(1)}75%{transform:scale(1.1)}to{transform:scale(1)}}.likes-count{font-weight:500}@media (max-width: 640px){.publicacion-card{border-radius:0;margin-bottom:.625rem}.publicacion-header{padding:.875rem 1rem}.autor-avatar{width:40px;height:40px}.autor-nombre{font-size:.9375rem}.autor-meta{font-size:.75rem}.publicacion-contenido{padding:.875rem 1rem}.publicacion-descripcion{font-size:.875rem}.publicacion-imagen{max-height:400px}.publicacion-footer{padding:.625rem 1rem}}.likes-popup{position:absolute;bottom:calc(100% + .5rem);left:0;background:#fff;border:1px solid #e5e5e5;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.75rem;min-width:220px;max-width:300px;z-index:20;animation:fadeIn .2s ease}.likes-popup-title{font-size:.875rem;font-weight:600;color:#333;margin:0 0 .5rem}.likes-popup-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.likes-popup-user{display:flex;align-items:center;gap:.5rem}.likes-popup-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid #e5e5e5}.likes-popup-name{font-size:.8125rem;color:#333;margin:0;font-weight:500}.likes-popup-more{font-size:.8125rem;color:#999;margin:.25rem 0 0;font-style:italic}.publicacion-footer{display:flex;align-items:center;gap:.5rem}.btn-comentarios{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;padding:.5rem .75rem;border-radius:6px;font-size:.9375rem;color:#666;transition:all .2s ease}.btn-comentarios:hover{background:#f9f9f9;color:#7a3e9d}.btn-comentarios.active{color:#7a3e9d;background:#f5ebff}.btn-comentarios span{font-weight:500}.autor-info{display:flex;gap:.875rem;align-items:center;cursor:pointer;padding:.25rem;margin:-.25rem;border-radius:8px;transition:background .2s ease}.autor-info:hover{background:#f5f5f5}.autor-info:hover .autor-nombre{color:#7a3e9d}:root{--morado: #7a3e9d;--morado-dark: #5b2d79;--morado-soft: #f5ebff;--blanco: #ffffff;--fondo: #f5f2f8;--texto: #333;--gris-claro: #e5e5e5;--max-width: 1400px}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--fondo);margin:0;padding:0;color:var(--texto)}.home-wrapper{display:grid;grid-template-columns:280px 1fr 320px;gap:1.5rem;max-width:var(--max-width);margin:0 auto;padding:1.5rem;min-height:100vh}.sidebar-card{background:var(--blanco);border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #0000000f;margin-bottom:1rem;position:sticky;top:1.5rem}.home-sidebar-left{display:block}.perfil-preview{text-align:center;padding-bottom:1rem;border-bottom:1px solid var(--gris-claro)}.perfil-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--morado);margin-bottom:.75rem}.perfil-nombre{font-size:1.125rem;font-weight:600;color:var(--texto);margin:0 0 .25rem}.perfil-correo{font-size:.8125rem;color:#666;margin:0}.perfil-actions{display:flex;flex-direction:column;gap:.625rem;margin-top:1rem}.btn-action{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease;border:none}.btn-outline{background:transparent;color:var(--morado);border:2px solid var(--morado)}.btn-outline:hover{background:var(--morado);color:#fff}.btn-logout{background:#fee2e2;color:#dc2626;border:2px solid transparent}.btn-logout:hover{background:#fecaca;border-color:#dc2626}.home-feed{max-width:680px;margin:0 auto;width:100%}.feed-header{display:flex;justify-content:space-between;align-items:center;margin:1.5rem 0}.feed-title{font-size:1.5rem;font-weight:700;color:var(--texto);margin:0}.btn-crear-mobile{display:none;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--morado);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 12px #7a3e9d4d;transition:transform .2s ease}.btn-crear-mobile:hover{transform:scale(1.05)}.btn-crear-mobile:active{transform:scale(.95)}.crear-publicacion-box{display:flex;align-items:center;gap:1rem;background:var(--blanco);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 8px #0000000f;margin-bottom:1.25rem}.crear-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--gris-claro)}.crear-input{flex:1;background:#f5f5f5;border:none;border-radius:24px;padding:.875rem 1.25rem;font-size:.9375rem;color:#666;cursor:pointer;text-align:left;transition:background .2s ease}.crear-input:hover{background:#e8e8e8}.publicaciones-lista{display:flex;flex-direction:column}.empty-state{background:var(--blanco);border-radius:12px;padding:3rem 2rem;text-align:center;box-shadow:0 2px 8px #0000000f}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{font-size:1.5rem;font-weight:600;color:var(--texto);margin:0 0 .5rem}.empty-state p{color:#666;margin:0 0 1.5rem}.btn-crear-first{background:var(--morado);color:#fff;border:none;padding:.875rem 2rem;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s ease}.btn-crear-first:hover{background:var(--morado-dark)}.error-box{background:#fee2e2;border:1px solid #fecaca;border-radius:12px;padding:1.5rem;text-align:center;margin-bottom:1.25rem}.error-box p{color:#dc2626;margin:0 0 1rem}.error-box button{background:#dc2626;color:#fff;border:none;padding:.625rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer}.loading-box{background:var(--blanco);border-radius:12px;padding:2rem;text-align:center;margin-bottom:1.25rem;box-shadow:0 2px 8px #0000000f}.spinner{width:40px;height:40px;border:4px solid var(--gris-claro);border-top-color:var(--morado);border-radius:50%;margin:0 auto 1rem;animation:spin .8s linear infinite}.loading-box p{color:#666;margin:0}.end-message{text-align:center;padding:2rem 1rem;color:#999;font-size:.9375rem}.scroll-trigger{height:20px}.home-sidebar-right{display:block}.sidebar-title{font-size:1.125rem;font-weight:600;color:var(--texto);margin:0 0 1rem}.sugerencias-lista{list-style:none;padding:0;margin:0}.sugerencias-lista li{margin-bottom:.75rem}.sugerencias-lista a{color:var(--morado);text-decoration:none;font-size:.9375rem;transition:color .2s ease}.sugerencias-lista a:hover{color:var(--morado-dark);text-decoration:underline}.estadisticas{display:flex;flex-direction:column;gap:1rem}.stat-item{display:flex;justify-content:space-between;align-items:center}.stat-label{color:#666;font-size:.9375rem}.stat-value{font-weight:700;font-size:1.25rem;color:var(--morado)}@media (max-width: 1200px){.home-wrapper{grid-template-columns:260px 1fr}.home-sidebar-right{display:none}}@media (max-width: 900px){.home-wrapper{grid-template-columns:1fr;padding:0;gap:0}.home-sidebar-left,.home-sidebar-right{display:none}.home-feed{max-width:100%}.feed-header{padding:1rem;margin-bottom:0;background:var(--blanco);box-shadow:0 2px 4px #0000000f;position:sticky;top:0;z-index:10}.feed-title{font-size:1.25rem}.btn-crear-mobile{display:flex}.crear-publicacion-box{display:none}.publicaciones-lista{padding:.625rem}.empty-state,.loading-box{border-radius:0;margin:.625rem}}@media (max-width: 640px){.feed-header{padding:.875rem}.feed-title{font-size:1.125rem}.btn-crear-mobile{width:44px;height:44px}.publicaciones-lista{padding:0}}.global-navbar{background:#fff;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #00000014}.navbar-container{max-width:1400px;margin:0 auto;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.navbar-logo{font-size:1.5rem;font-weight:700;color:#7a3e9d;display:flex;align-items:center;gap:.5rem}.navbar-logo-text{display:none}@media (min-width: 640px){.navbar-logo-text{display:inline}}.navbar-desktop-menu{display:none;gap:1rem;align-items:center}@media (min-width: 768px){.navbar-desktop-menu{display:flex}}.navbar-user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-radius:8px;background:#f9f9f9}.navbar-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid #7a3e9d}.navbar-user-name{font-size:.875rem;font-weight:600;color:#333;margin:0}.navbar-user-email{font-size:.75rem;color:#666;margin:0}.navbar-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:2px solid}.navbar-btn-danger:hover{background:#fecaca;border-color:#dc2626}.navbar-mobile-toggle{display:flex;padding:.5rem;background:transparent;border:none;cursor:pointer}.navbar-mobile-menu{background:#fff;border-top:1px solid #e5e5e5;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.navbar-mobile-user{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;background:#f9f9f9}.navbar-mobile-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #7a3e9d}.navbar-mobile-user-name{font-size:1rem;font-weight:600;color:#333;margin:0}.navbar-mobile-user-email{font-size:.875rem;color:#666;margin:0}.navbar-mobile-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;font-size:1rem;border:2px solid}.navbar-mobile-btn-outline{background:transparent;color:#7a3e9d;border-color:#7a3e9d}.navbar-mobile-btn-danger{background:#fee2e2;color:#dc2626;border-color:transparent}.home-wrapper{display:block;max-width:680px;margin:0 auto;padding:1.5rem}.navbar-badge{position:absolute;top:-4px;right:-4px;background:#dc2626;color:#fff;font-size:.75rem;font-weight:700;padding:.125rem .375rem;border-radius:10px;min-width:18px;text-align:center;line-height:1}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;padding:1rem;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container.modal-fb{background:#fff;width:100%;max-width:600px;border-radius:12px;box-shadow:0 8px 20px #00000040;padding:18px 22px;display:flex;flex-direction:column;animation:slideUp .25s ease-in-out;max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-container textarea{width:100%;border:none;resize:none;background:transparent;font-size:18px;font-weight:400;color:#050505;outline:none;min-height:120px;margin-top:10px;font-family:inherit}.modal-container textarea::placeholder{color:#65676b}.upload-section{display:flex;justify-content:space-between;align-items:center;border:1px solid #ddd;border-radius:8px;padding:10px 14px;margin-top:12px;background:#f8f9fa}.upload-label{color:#462cbb;font-weight:600;cursor:pointer;font-size:15px}.file-name{font-size:13px;color:#65676b;flex:1;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-left:10px}.modal-buttons{border-top:1px solid #dadde1;padding-top:14px;margin-top:16px;display:flex;justify-content:center}.btn-publicar{width:100%;background:#462cbb;color:#fff;font-weight:600;border:none;border-radius:8px;padding:12px;font-size:16px;cursor:pointer;transition:background .2s ease-in-out}.btn-publicar:hover{background:#572364}.btn-publicar:disabled{background:#9ca3af;cursor:not-allowed}.error-message{color:#dc2626;font-size:14px;margin-top:8px;padding:10px;background:#fee2e2;border-radius:6px;border:1px solid #fecaca}@media (max-width: 640px){.modal-overlay{align-items:flex-end;padding:0}.modal-container.modal-fb{border-radius:12px 12px 0 0;max-height:85vh;width:100%;animation:slideUpMobile .25s ease-in-out}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-container textarea{font-size:16px;min-height:100px}.upload-section{flex-direction:column;align-items:flex-start;gap:8px}.file-name{text-align:left;margin-left:0}}.perfil-page{min-height:100vh;background:#f5f2f8}.perfil-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.perfil-navbar{background:#fff;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:100}.perfil-navbar .navbar-container{max-width:900px;margin:0 auto;padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.navbar-back{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:#7a3e9d;font-weight:600;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s}.navbar-back:hover{background:#f5ebff}.navbar-desktop-actions{display:none;gap:.75rem}@media (min-width: 768px){.navbar-desktop-actions{display:flex}}.navbar-btn-outline,.navbar-btn-danger{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:2px solid}.navbar-btn-outline{background:transparent;color:#7a3e9d;border-color:#7a3e9d}.navbar-btn-outline:hover{background:#7a3e9d;color:#fff}.navbar-btn-danger{background:#fee2e2;color:#dc2626;border-color:transparent}.navbar-btn-danger:hover{background:#fecaca}.navbar-mobile-toggle{display:flex;padding:.5rem;background:none;border:none;cursor:pointer;color:#333}@media (min-width: 768px){.navbar-mobile-toggle{display:none}}.navbar-mobile-menu{background:#fff;border-top:1px solid #e5e5e5;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.navbar-mobile-menu button{width:100%;padding:.75rem;border:none;background:#f5f5f5;border-radius:8px;font-weight:600;cursor:pointer}.perfil-mensaje{max-width:600px;margin:1rem auto;padding:.75rem 1rem;border-radius:8px;text-align:center;font-weight:600;animation:slideDown .3s ease}.perfil-mensaje.success{background:#d1fae5;color:#065f46}.perfil-mensaje.error{background:#fee2e2;color:#991b1b}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.perfil-header-card{max-width:900px;margin:0 auto;background:#fff;border-radius:0 0 16px 16px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.perfil-cover{height:120px;background:linear-gradient(135deg,#7a3e9d,#5b2d79)}@media (min-width: 768px){.perfil-cover{height:160px}}.perfil-avatar-section{display:flex;flex-direction:column;align-items:center;padding:0 1.5rem 1rem;margin-top:-60px;position:relative}@media (min-width: 640px){.perfil-avatar-section{flex-direction:row;align-items:flex-end;gap:1.5rem;margin-top:-50px}}.perfil-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:0 4px 12px #00000026}.avatar-edit-btn{position:absolute;bottom:5px;right:5px;width:36px;height:36px;background:#7a3e9d;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;box-shadow:0 2px 8px #0003}.avatar-edit-btn:hover{background:#5b2d79}.avatar-loading{position:absolute;inset:0;background:#fffc;border-radius:50%;display:flex;align-items:center;justify-content:center}.mini-spinner{width:24px;height:24px;border:3px solid #e5e5e5;border-top-color:#7a3e9d;border-radius:50%;animation:spin .8s linear infinite}.perfil-info-principal{text-align:center;flex:1;padding-top:.5rem}@media (min-width: 640px){.perfil-info-principal{text-align:left;padding-top:0}}.perfil-info-principal h1{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0}.perfil-programa{color:#7a3e9d;font-weight:600;margin:.25rem 0}.perfil-año{color:#666;font-size:.875rem;margin:0}.btn-editar-perfil{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#7a3e9d;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:1rem}@media (min-width: 640px){.btn-editar-perfil{margin-top:0;margin-left:auto}}.btn-editar-perfil:hover{background:#5b2d79}.perfil-detalles{padding:1rem 1.5rem 1.5rem;border-top:1px solid #f0f0f0}.perfil-descripcion{color:#444;line-height:1.6;margin:0 0 1rem}.perfil-redes{display:flex;gap:1rem;justify-content:center}@media (min-width: 640px){.perfil-redes{justify-content:flex-start}}.perfil-redes a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#f5f5f5;border-radius:50%;color:#666;transition:all .2s}.perfil-redes a:hover{background:#7a3e9d;color:#fff}.perfil-form-editar{padding:1rem 1.5rem 1.5rem;border-top:1px solid #f0f0f0;display:flex;flex-direction:column;gap:.75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.perfil-form-editar input,.perfil-form-editar textarea{width:100%;padding:.75rem 1rem;border:1px solid #e5e5e5;border-radius:8px;font-size:.9375rem;transition:border-color .2s}.perfil-form-editar input:focus,.perfil-form-editar textarea:focus{outline:none;border-color:#7a3e9d}.perfil-form-editar textarea{resize:vertical;min-height:80px}.form-section-title{font-weight:600;color:#666;margin:.5rem 0 0;font-size:.875rem}.form-buttons{display:flex;gap:.75rem;margin-top:.5rem}.btn-guardar,.btn-cancelar{flex:1;padding:.75rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-guardar{background:#7a3e9d;color:#fff;border:none}.btn-guardar:hover{background:#5b2d79}.btn-cancelar{background:#f5f5f5;color:#666;border:1px solid #e5e5e5}.btn-cancelar:hover{background:#e5e5e5}.perfil-tabs{max-width:900px;margin:1rem auto 0;display:flex;background:#fff;border-radius:12px;padding:.5rem;box-shadow:0 2px 8px #0000000f}.perfil-tabs .tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:none;border:none;border-radius:8px;font-weight:600;color:#666;cursor:pointer;transition:all .2s}.perfil-tabs .tab:hover{background:#f5f5f5}.perfil-tabs .tab.active{background:#7a3e9d;color:#fff}.perfil-content{max-width:680px;margin:1rem auto;padding:0 1rem}.publicaciones-grid{display:flex;flex-direction:column}.empty-state{background:#fff;border-radius:12px;padding:3rem 2rem;text-align:center;color:#999}.empty-state svg{margin-bottom:1rem}.btn-cargar-mas{width:100%;padding:.875rem;background:#fff;border:2px solid #7a3e9d;border-radius:8px;color:#7a3e9d;font-weight:600;cursor:pointer;transition:all .2s;margin-top:1rem}.btn-cargar-mas:hover{background:#7a3e9d;color:#fff}.loading-pubs{display:flex;justify-content:center;padding:2rem}.btn-enviar-mensaje{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#7a3e9d;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:1rem}@media (min-width: 640px){.btn-enviar-mensaje{margin-top:0;margin-left:auto}}.btn-enviar-mensaje:hover{background:#5b2d79}.mensaje-completar-perfil{max-width:fit-content;margin:1rem auto;padding:.75rem 1rem;border-radius:8px;text-align:center;font-weight:600;background:#fffbeb;color:#92400e;border:1px solid #fcd34d}.buscar-page{min-height:100vh;background:#f5f2f8}.buscar-header{background:#fff;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:100}.buscar-header .header-container{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem}.btn-back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;border-radius:50%;color:#7a3e9d;cursor:pointer;transition:background .2s}.buscar-header h1{font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0}.buscar-controls{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;gap:.75rem;background:#fff;border-bottom:1px solid #e5e5e5}.search-bar{flex:1;display:flex;align-items:center;gap:.75rem;background:#f5f5f5;border-radius:12px;padding:0 1rem;transition:all .2s}.search-bar:focus-within{background:#fff;box-shadow:0 0 0 2px #7a3e9d}.search-icon{color:#999;flex-shrink:0}.search-bar input{flex:1;border:none;background:transparent;padding:.875rem 0;font-size:1rem;outline:none}.search-bar input::placeholder{color:#999}.clear-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#e5e5e5;border:none;border-radius:50%;color:#666;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#d5d5d5;color:#333}.btn-filters{display:flex;align-items:center;gap:.5rem;padding:0 1.25rem;background:#f5f5f5;border:none;border-radius:12px;font-weight:600;color:#666;cursor:pointer;transition:all .2s;position:relative}.btn-filters:hover{background:#e5e5e5}.btn-filters.active{background:#7a3e9d;color:#fff}.filter-badge{position:absolute;top:8px;right:8px;width:8px;height:8px;background:#dc2626;border-radius:50%}.btn-filters.active .filter-badge{background:#fbbf24}.filters-panel{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e5e5e5;display:flex;flex-wrap:wrap;gap:1rem;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filter-group label{display:block;font-size:.8125rem;font-weight:600;color:#666;margin-bottom:.5rem}.filter-group select{width:100%;padding:.75rem 1rem;border:1px solid #e5e5e5;border-radius:8px;font-size:.9375rem;background:#fff;cursor:pointer;transition:border-color .2s}.buscar-results{max-width:1200px;margin:0 auto;padding:1.5rem}.results-count{font-size:.9375rem;color:#666;margin:0 0 1rem}.empty-results{background:#fff;border-radius:16px;padding:4rem 2rem;text-align:center;color:#999}.empty-results svg{margin-bottom:1rem;opacity:.5}.empty-results h3{font-size:1.25rem;color:#333;margin:0 0 .5rem}.empty-results p{margin:0}.egresados-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.egresado-card{background:#fff;border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000000f}.egresado-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.egresado-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;margin:0 auto 1rem;display:block;border:3px solid #f0f0f0}.egresado-info{text-align:center}.egresado-info h3{font-size:1.125rem;font-weight:600;color:#1a1a1a;margin:0 0 .25rem}.egresado-programa{color:#7a3e9d;font-weight:500;font-size:.875rem;margin:0 0 .25rem}.egresado-anio{color:#999;font-size:.8125rem;margin:0}.egresado-descripcion{color:#666;font-size:.8125rem;line-height:1.5;margin:1rem 0 0;text-align:center;border-top:1px solid #f0f0f0;padding-top:1rem}.btn-load-more{width:100%;margin-top:1.5rem;padding:1rem;background:#fff;border:2px solid #7a3e9d;border-radius:12px;color:#7a3e9d;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.btn-load-more:hover{background:#7a3e9d;color:#fff}.btn-load-more:disabled{opacity:.6;cursor:not-allowed}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}@media (max-width: 640px){.buscar-controls{flex-direction:column}.btn-filters{justify-content:center;padding:.875rem}.filters-panel{flex-direction:column}.filter-group{min-width:100%}.btn-clear-filters{width:100%}.egresados-grid{grid-template-columns:1fr}}.admin-publicaciones{min-height:100vh;background:#f5f2f8;padding-bottom:2rem}.publicaciones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.pub-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:transform .2s,box-shadow .2s}.pub-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.pub-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.25rem;border-bottom:1px solid #f0f0f0}.autor-info{display:flex;gap:.75rem;flex:1}.autor-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5;flex-shrink:0}.autor-nombre{font-weight:600;color:#1a1a1a;margin:0 0 .25rem;font-size:.9375rem}.autor-email{font-size:.8125rem;color:#666;margin:0 0 .25rem}.pub-fecha{font-size:.75rem;color:#999;margin:0}.btn-eliminar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:50%;color:#dc2626;cursor:pointer;transition:all .2s}.btn-eliminar:hover:not(:disabled){background:#fee2e2}.btn-eliminar:disabled{opacity:.5;cursor:not-allowed}.pub-contenido{padding:1.25rem}.pub-descripcion{font-size:.9375rem;line-height:1.6;color:#333;margin:0 0 1rem;white-space:pre-wrap;word-wrap:break-word;max-height:150px;overflow:hidden;text-overflow:ellipsis}.pub-imagen-container{margin-top:1rem;border-radius:12px;overflow:hidden;background:#f5f5f5}.pub-imagen{width:100%;height:200px;object-fit:cover;display:block}.pub-stats{display:flex;align-items:center;gap:1.5rem;padding:1rem 1.25rem;border-top:1px solid #f0f0f0;background:#f9f9f9}.stat-item{display:flex;align-items:center;gap:.5rem;color:#666;font-size:.875rem;font-weight:500}.stat-item svg{color:#7a3e9d}@media (max-width: 1024px){.publicaciones-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width: 768px){.publicaciones-grid{grid-template-columns:1fr}.pub-card{border-radius:12px}.pub-descripcion{font-size:.875rem}}.admin-dashboard{min-height:100vh;background:#f5f2f8;padding-bottom:2rem}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.admin-header{background:#fff;border-bottom:2px solid #e5e5e5;padding:1.5rem 2rem}.admin-header-content{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.btn-back{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:#7a3e9d;font-weight:600;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s;align-self:flex-start}.admin-title{display:flex;align-items:center;gap:.75rem}.admin-title h1{font-size:1.875rem;font-weight:700;color:#1a1a1a;margin:0}.metrics-grid{max-width:1400px;margin:2rem auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.metric-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;display:flex;gap:1.25rem;transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.metric-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-icon.usuarios{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.metric-icon.publicaciones{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.metric-icon.activos{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.metric-icon.likes{background:linear-gradient(135deg,#fa709a,#fee140);color:#fff}.metric-content{flex:1}.metric-label{font-size:.875rem;color:#666;margin:0 0 .5rem;font-weight:500}.metric-value{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 .25rem}.metric-sub{font-size:.8125rem;color:#999;margin:0}.quick-actions{max-width:1400px;margin:2rem auto;padding:0 2rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:#1a1a1a;margin:0 0 1.5rem}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.action-card{background:#fff;border:2px solid #e5e5e5;border-radius:16px;padding:2rem;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:.75rem}.action-card:hover{border-color:#7a3e9d;transform:translateY(-4px);box-shadow:0 8px 24px #7a3e9d26}.action-card svg{color:#7a3e9d;margin-bottom:.5rem}.action-card h3{font-size:1.25rem;font-weight:600;color:#1a1a1a;margin:0}.action-card p{font-size:.9375rem;color:#666;margin:0;line-height:1.5}.stats-section{max-width:1400px;margin:2rem auto;padding:0 2rem}.top-list{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:1rem}.top-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border-radius:12px;transition:background .2s}.top-item:hover{background:#f9f9f9}.top-rank{font-size:1.25rem;font-weight:700;color:#7a3e9d;min-width:40px}.top-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5}.top-info{flex:1}.top-name{font-weight:600;color:#1a1a1a;margin:0 0 .25rem}.top-count{font-size:.875rem;color:#666;margin:0}.distribution-list{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;gap:1.25rem}.distribution-item{display:grid;grid-template-columns:200px 1fr 60px;align-items:center;gap:1rem}.distribution-label{font-weight:600;color:#1a1a1a;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.distribution-bar{height:12px;background:#f0f0f0;border-radius:6px;overflow:hidden}.distribution-fill{height:100%;background:linear-gradient(90deg,#7a3e9d,#5b2d79);border-radius:6px;transition:width .3s ease}.distribution-count{font-weight:600;color:#7a3e9d;margin:0;text-align:right}@media (max-width: 768px){.admin-header{padding:1rem}.metrics-grid{padding:0 1rem;grid-template-columns:1fr}.quick-actions{padding:0 1rem}.actions-grid{grid-template-columns:1fr}.stats-section{padding:0 1rem}.distribution-item{grid-template-columns:1fr;gap:.5rem}.distribution-label{white-space:normal}}.admin-usuarios{min-height:100vh;background:#f5f2f8;padding-bottom:2rem}.header-subtitle{color:#666;margin:.5rem 0 0;font-size:1rem}.controles-section{max-width:1400px;margin:1.5rem auto;padding:0 2rem;display:flex;gap:1rem}.search-bar{flex:1;display:flex;align-items:center;gap:.75rem;background:#fff;border:2px solid #e5e5e5;border-radius:12px;padding:0 1rem;transition:border-color .2s}.search-bar:focus-within{border-color:#7a3e9d}.search-bar input{flex:1;border:none;padding:.875rem 0;font-size:1rem;outline:none}.clear-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#f0f0f0;border:none;border-radius:50%;color:#666;cursor:pointer;transition:all .2s}.clear-btn:hover{background:#e5e5e5}.btn-filters{display:flex;align-items:center;gap:.5rem;padding:0 1.5rem;background:#fff;border:2px solid #e5e5e5;border-radius:12px;font-weight:600;color:#666;cursor:pointer;transition:all .2s}.btn-filters:hover{border-color:#7a3e9d;color:#7a3e9d}.btn-filters.active{background:#7a3e9d;color:#fff;border-color:#7a3e9d}.filters-panel{max-width:1400px;margin:0 auto 1.5rem;padding:0 2rem;display:flex;flex-wrap:wrap;gap:1rem;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000f}.filter-group{flex:1;min-width:200px}.filter-group label{display:block;font-size:.875rem;font-weight:600;color:#666;margin-bottom:.5rem}.filter-group select{width:100%;padding:.75rem 1rem;border:2px solid #e5e5e5;border-radius:8px;font-size:.9375rem;cursor:pointer;transition:border-color .2s}.filter-group select:focus{outline:none;border-color:#7a3e9d}.btn-clear-filters{align-self:flex-end;padding:.75rem 1.5rem;background:transparent;border:2px solid #dc2626;border-radius:8px;color:#dc2626;font-weight:600;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background:#dc2626;color:#fff}.resultados-section{max-width:1400px;margin:0 auto;padding:0 2rem}.resultados-count{font-size:.9375rem;color:#666;margin:0 0 1rem}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f}.empty-state svg{opacity:.3}.usuarios-table{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.table-header{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:1rem;padding:1rem 1.5rem;background:#f9f9f9;border-bottom:2px solid #e5e5e5;font-weight:700;font-size:.875rem;color:#666;text-transform:uppercase}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #f0f0f0;transition:background .2s;align-items:center}.table-row:hover{background:#f9f9f9}.table-row:last-child{border-bottom:none}.usuario-info{display:flex;align-items:center;gap:.75rem}.usuario-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#7a3e9d,#5b2d79);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;flex-shrink:0}.usuario-nombre{font-weight:600;color:#1a1a1a;margin:0 0 .25rem}.usuario-correo{font-size:.875rem;color:#666;margin:0}.badge-rol,.badge-estado{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:20px;font-size:.8125rem;font-weight:600}.badge-rol.admin{background:#fef3c7;color:#92400e}.badge-rol.comun{background:#e0e7ff;color:#3730a3}.badge-estado.activo{background:#d1fae5;color:#065f46}.badge-estado.suspendido{background:#fee2e2;color:#991b1b}.col-acciones{display:flex;gap:.5rem;flex-wrap:wrap}.btn-accion{padding:.5rem .875rem;border:none;border-radius:8px;font-weight:600;font-size:.8125rem;cursor:pointer;transition:all .2s}.btn-accion:disabled{opacity:.5;cursor:not-allowed}.btn-accion.cambiar-rol{background:#e0e7ff;color:#3730a3}.btn-accion.cambiar-rol:hover:not(:disabled){background:#c7d2fe}.btn-accion.suspender{background:#fee2e2;color:#991b1b}.btn-accion.suspender:hover:not(:disabled){background:#fecaca}.btn-accion.reactivar{background:#d1fae5;color:#065f46}.btn-accion.reactivar:hover:not(:disabled){background:#a7f3d0}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding:1rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f}.pagination button{padding:.625rem 1.25rem;background:#7a3e9d;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:background .2s}.pagination button:hover:not(:disabled){background:#5b2d79}.pagination button:disabled{background:#e5e5e5;color:#999;cursor:not-allowed}.pagination span{font-weight:600;color:#666}@media (max-width: 1024px){.table-header,.table-row{grid-template-columns:1fr}.table-header{display:none}.table-row{padding:1.5rem;gap:1rem}.col-usuario,.col-rol,.col-estado,.col-acciones{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.col-acciones{flex-direction:row}}@media (max-width: 768px){.controles-section{flex-direction:column}.btn-filters{justify-content:center}.filters-panel{flex-direction:column}.btn-clear-filters{width:100%}}.conversaciones-sidebar{height:100%;background:#fff;border-right:1px solid #e5e5e5;display:flex;flex-direction:column}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #f0f0f0;background:#fafafa;flex-shrink:0}.sidebar-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:#1a1a1a;margin:0}.badge-no-leidos{background:#dc2626;color:#fff;font-size:.75rem;font-weight:700;padding:.25rem .5rem;border-radius:12px;min-width:20px;text-align:center;flex-shrink:0}.conversaciones-lista{flex:1;overflow-y:auto;overflow-x:hidden}.empty-conversaciones{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;text-align:center;color:#999;height:100%}.empty-conversaciones p{margin:.5rem 0 0;font-size:.9375rem}.conversacion-item{display:flex;gap:.875rem;padding:1rem 1.5rem;cursor:pointer;transition:background .2s;border-bottom:1px solid #f5f5f5;position:relative}.conversacion-item:hover{background:#f9f9f9}.conversacion-item.activa{background:#f5ebff;border-left:3px solid #7a3e9d}.conversacion-item:active{background:#f0e7ff}.conversacion-avatar-container{position:relative;flex-shrink:0}.conversacion-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5}.status-online{position:absolute;bottom:2px;right:2px;color:#10b981;background:#fff;border-radius:50%}.conversacion-info{flex:1;min-width:0}.conversacion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;gap:.5rem}.conversacion-nombre{font-weight:600;color:#1a1a1a;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversacion-fecha{font-size:.75rem;color:#999;flex-shrink:0}.conversacion-preview{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.conversacion-preview p{flex:1;margin:0;font-size:.875rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversacion-preview p.no-leido{color:#1a1a1a;font-weight:600}.badge-contador{background:#7a3e9d;color:#fff;font-size:.75rem;font-weight:700;padding:.125rem .5rem;border-radius:10px;min-width:20px;text-align:center;flex-shrink:0}.conversaciones-lista::-webkit-scrollbar{width:6px}.conversaciones-lista::-webkit-scrollbar-track{background:#f5f5f5}.conversaciones-lista::-webkit-scrollbar-thumb{background:#d5d5d5;border-radius:3px}.conversaciones-lista::-webkit-scrollbar-thumb:hover{background:#b5b5b5}@media (max-width: 1024px){.conversacion-item{padding:.875rem 1.25rem}.sidebar-header{padding:1rem 1.25rem}}@media (max-width: 768px){.sidebar-header{padding:1rem}.sidebar-header h2{font-size:1.125rem}.conversacion-item{padding:.875rem 1rem}.conversacion-avatar{width:42px;height:42px}.conversacion-nombre{font-size:.875rem}.conversacion-preview p{font-size:.8125rem}.empty-conversaciones{padding:2rem 1rem}}@media (max-width: 480px){.sidebar-header{padding:.875rem}.sidebar-header h2{font-size:1rem;gap:.5rem}.conversacion-item{padding:.75rem .875rem;gap:.75rem}.conversacion-avatar{width:38px;height:38px}.conversacion-nombre{font-size:.8125rem}.conversacion-preview p{font-size:.75rem}.conversacion-fecha{font-size:.6875rem}.badge-no-leidos,.badge-contador{font-size:.6875rem;padding:.125rem .375rem;min-width:18px}}.ventana-chat{height:100%;display:flex;flex-direction:column;background:#fff}.ventana-chat-vacia{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fafafa;color:#999;padding:2rem;text-align:center}.ventana-chat-vacia p{margin:1rem 0 0;font-size:1rem}.chat-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid #e5e5e5;background:#fafafa;flex-shrink:0}.btn-volver-mobile{display:none;background:none;border:none;color:#7a3e9d;cursor:pointer;padding:.5rem;border-radius:50%;transition:background .2s;flex-shrink:0}.btn-volver-mobile:hover{background:#f5ebff}.btn-volver-mobile:active{transform:scale(.95)}.chat-header-info{display:flex;align-items:center;gap:.875rem;flex:1;min-width:0}.avatar-container{position:relative;flex-shrink:0}.chat-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5}.status-indicator{position:absolute;bottom:2px;right:2px;color:#10b981;background:#fff;border-radius:50%}.chat-header-info h3{font-size:1rem;font-weight:600;color:#1a1a1a;margin:0 0 .125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-status{font-size:.8125rem;color:#666;margin:0}.chat-mensajes{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem;background:#f9f9f9;display:flex;flex-direction:column;gap:1rem;overflow-y:scroll;max-height:100vh}.chat-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem}.chat-loading p{color:#666;margin:0}.mensaje{display:flex;gap:.75rem;align-items:flex-end;animation:fadeIn .3s ease;max-width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mensaje.mio{flex-direction:row-reverse;align-self:flex-end;width:100%}.mensaje-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #e5e5e5;flex-shrink:0}.mensaje-contenido{max-width:70%;padding:.75rem 1rem;border-radius:12px;position:relative;word-wrap:break-word;overflow-wrap:break-word}.mensaje.otro .mensaje-contenido{background:#fff;border:1px solid #e5e5e5;border-bottom-left-radius:4px}.mensaje.mio .mensaje-contenido{background:#7a3e9d;color:#fff;border-bottom-right-radius:4px}.mensaje-contenido p{margin:0;font-size:.9375rem;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.mensaje-hora{display:block;font-size:.75rem;margin-top:.25rem;opacity:.7}.mensaje.otro .mensaje-hora{color:#999}.mensaje.mio .mensaje-hora{color:#ffffffe6}.chat-input-form{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e5e5e5;background:#fff;flex-shrink:0}.chat-input-form input{flex:1;padding:.875rem 1.25rem;border:1px solid #e5e5e5;border-radius:24px;font-size:.9375rem;outline:none;transition:border-color .2s;min-width:0}.chat-input-form input:focus{border-color:#7a3e9d}.chat-input-form input:disabled{background:#f5f5f5;cursor:not-allowed}.chat-input-form button{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#7a3e9d;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .2s;flex-shrink:0}.chat-input-form button:hover:not(:disabled){background:#5b2d79;transform:scale(1.05)}.chat-input-form button:active:not(:disabled){transform:scale(.95)}.chat-input-form button:disabled{background:#d5d5d5;cursor:not-allowed;transform:scale(1)}.chat-mensajes::-webkit-scrollbar{width:6px}.chat-mensajes::-webkit-scrollbar-track{background:#f5f5f5}.chat-mensajes::-webkit-scrollbar-thumb{background:#d5d5d5;border-radius:3px}.chat-mensajes::-webkit-scrollbar-thumb:hover{background:#b5b5b5}@media (max-width: 768px){.btn-volver-mobile{display:flex}.chat-header{padding:.875rem 1rem}.chat-avatar{width:42px;height:42px}.chat-header-info h3{font-size:.9375rem}.chat-status{font-size:.75rem}.chat-mensajes{padding:1rem}.mensaje-contenido{max-width:80%}.mensaje-avatar{width:28px;height:28px}.mensaje-contenido p{font-size:.875rem}.chat-input-form{padding:.875rem 1rem}.chat-input-form input{padding:.75rem 1rem;font-size:.875rem}.chat-input-form button{width:44px;height:44px}}@media (max-width: 480px){.chat-header{padding:.75rem .875rem;gap:.75rem}.chat-avatar{width:38px;height:38px}.mensaje-contenido{max-width:85%;padding:.625rem .875rem}.mensaje-contenido p{font-size:.8125rem}.mensaje-avatar{width:24px;height:24px}.chat-mensajes{padding:.875rem;gap:.875rem}.chat-input-form{padding:.75rem .875rem;gap:.625rem}.chat-input-form input{padding:.625rem .875rem;font-size:.8125rem}.chat-input-form button{width:40px;height:40px}}.mensajes-page{max-height:100vh;background:#f5f2f8;display:flex;flex-direction:column}.mensajes-header{background:#fff;border-bottom:1px solid #e5e5e5;padding:1rem 2rem;position:sticky;top:0;z-index:100}.btn-back{display:inline-flex;align-items:center;gap:.5rem;background:none;border:none;color:#7a3e9d;font-weight:600;cursor:pointer;padding:.5rem;border-radius:8px;transition:background .2s}.btn-back:hover{background:#f5ebff}.mensajes-layout{flex:1;display:grid;grid-template-columns:380px 1fr;max-width:1400px;width:100%;margin:0 auto;height:calc(100vh - 73px);overflow:hidden}.sidebar-container,.chat-container{height:100%;overflow:hidden}.spinner{width:40px;height:40px;border:4px solid #e5e5e5;border-top-color:#7a3e9d;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.mensajes-header{padding:1rem}.mensajes-layout{grid-template-columns:1fr;height:calc(100vh - 65px)}.sidebar-container.ocultar-mobile,.chat-container.ocultar-mobile{display:none}}@media (max-width: 640px){.btn-back span{display:none}}
