@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600&display=swap";body{background-image:url(/assets/FondoLogin-CnHKXLG1.webp);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed}.registro-fondo{background-size:cover;background-position:center;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px;background-image:url(/assets/FondoLogin-CnHKXLG1.webp)}.registro-contenedor{background:#ffffff1a;padding:40px;border-radius:15px;max-width:400px;width:100%;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;text-align:center;transition:all .3s ease}.registro-logo{width:120px;margin-bottom:10px;transition:width .3s ease}.registro-titulo{color:#fff;font-size:24px;margin-bottom:20px;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.3)}.registro-formulario .campo{margin-bottom:15px;position:relative;display:flex;justify-content:center;align-items:center;width:100%}.registro-formulario input{width:100%;padding:12px 15px 12px 45px;border:2px solid rgba(255,255,255,.2);border-radius:8px;outline:none;font-size:14px;background:#ffffffe6;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.registro-formulario input:focus{border:2px solid #24211e;background:#fffffff2;transform:translateY(-1px);box-shadow:0 4px 12px #24211e33}.registro-formulario input::placeholder{color:#666;opacity:.8}.registro-formulario .icono{position:absolute;left:15px;color:#24211e;pointer-events:none;display:flex;align-items:center;height:100%;z-index:1}.recordarme{display:flex;justify-content:center;align-items:center;color:#fff;font-size:14px;margin-bottom:15px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.boton-ingresar{background-color:#24211e;color:#fff;width:100%;padding:15px;border:none;border-radius:8px;font-size:16px;font-weight:500;margin-bottom:15px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.boton-ingresar:hover{background-color:#3a3734;transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.boton-ingresar:active{transform:translateY(0)}.boton-google{background-color:#fffffff2;color:#333;border:1px solid rgba(255,255,255,.3);width:100%;padding:12px;border-radius:8px;display:flex;justify-content:center;align-items:center;gap:10px;cursor:pointer;font-weight:500;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.boton-google:hover{background-color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.enlace-olvido{font-size:14px;color:#fff;text-decoration:none;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:all .3s ease}.enlace-olvido:hover{text-decoration:underline;color:#f0f0f0}.enlace-registro{font-size:14px;color:#fff;text-decoration:none;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:all .3s ease}.enlace-registro:hover{text-decoration:underline;color:#f0f0f0}.mensaje-login{padding:12px;border-radius:8px;margin-top:15px;text-align:center;font-weight:500;animation:fadeIn .4s ease-in-out}.mensaje-error{background-color:#ffe6e6f2;color:#c00;border:1px solid #cc0000}.mensaje-alerta{background-color:#fff8e1f2;color:#8a6d3b;border:1px solid #f0ad4e}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media screen and (max-width: 380px){.registro-contenedor{padding:25px 20px;border-radius:10px;margin:10px}.registro-logo{width:90px}.registro-titulo{font-size:20px;margin-bottom:25px}.registro-formulario .campo .icono{display:none!important}.registro-formulario input{font-size:13px;padding:12px 15px;width:100%}.boton-ingresar{font-size:14px;padding:14px}.boton-google{font-size:13px;padding:10px}.enlace-olvido{font-size:13px}}@media screen and (min-width: 381px) and (max-width: 480px){.registro-contenedor{padding:30px;max-width:350px}.registro-logo{width:100px}.registro-formulario input{width:100%;padding:12px 15px 12px 45px}}@media screen and (min-width: 481px) and (max-width: 768px){.registro-contenedor{max-width:420px;padding:40px}.registro-logo{width:110px}.registro-titulo{font-size:26px}.registro-formulario input{width:100%;padding:14px 15px 14px 45px;font-size:15px}.boton-ingresar{padding:16px;font-size:16px}}@media screen and (min-width: 769px) and (max-width: 999px){.registro-contenedor{max-width:450px;padding:45px}.registro-logo{width:130px}.registro-titulo{font-size:28px;margin-bottom:25px}.registro-formulario input{width:100%;padding:15px 15px 15px 50px;font-size:15px}.registro-formulario .icono{left:18px}.boton-ingresar{padding:18px;font-size:17px}}@media screen and (min-width: 1000px) and (max-width: 1199px){.registro-fondo{padding:40px}.registro-contenedor{max-width:480px;padding:50px;border-radius:20px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 12px 40px #00000026}.registro-logo{width:140px;margin-bottom:15px}.registro-titulo{font-size:30px;margin-bottom:30px;font-weight:500}.registro-formulario .campo{margin-bottom:20px}.registro-formulario input{width:100%;padding:16px 20px 16px 55px;font-size:16px;border-radius:10px;border:2px solid rgba(255,255,255,.3)}.registro-formulario input:focus{border:2px solid #24211e;box-shadow:0 0 0 3px #24211e1a}.registro-formulario .icono{left:20px;font-size:18px}.recordarme{font-size:15px;margin-bottom:20px}.boton-ingresar{padding:18px;font-size:17px;border-radius:10px;margin-bottom:20px}.boton-google{padding:14px;font-size:15px;border-radius:10px}.enlace-olvido{font-size:15px}}@media screen and (min-width: 1200px) and (max-width: 1439px){.registro-fondo{padding:50px}.registro-contenedor{max-width:520px;padding:60px;border-radius:25px;-webkit-backdrop-filter:blur(25px);backdrop-filter:blur(25px);box-shadow:0 16px 50px #0003}.registro-logo{width:150px;margin-bottom:20px}.registro-titulo{font-size:32px;margin-bottom:35px;font-weight:500}.registro-formulario .campo{margin-bottom:25px}.registro-formulario input{width:100%;padding:18px 25px 18px 60px;font-size:17px;border-radius:12px;border:2px solid rgba(255,255,255,.3)}.registro-formulario .icono{left:22px;font-size:20px}.recordarme{font-size:16px;margin-bottom:25px}.boton-ingresar{padding:20px;font-size:18px;border-radius:12px;margin-bottom:25px}.boton-google{padding:16px;font-size:16px;border-radius:12px}.enlace-olvido{font-size:16px}.mensaje-login{padding:15px;border-radius:10px;margin-top:20px}}@media screen and (min-width: 1440px) and (max-width: 1919px){.registro-fondo{padding:60px}.registro-contenedor{max-width:580px;padding:70px;border-radius:30px;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);box-shadow:0 20px 60px #00000040}.registro-logo{width:160px;margin-bottom:25px}.registro-titulo{font-size:36px;margin-bottom:40px;font-weight:500}.registro-formulario .campo{margin-bottom:30px}.registro-formulario input{width:100%;padding:20px 30px 20px 65px;font-size:18px;border-radius:15px;border:2px solid rgba(255,255,255,.3)}.registro-formulario .icono{left:25px;font-size:22px}.recordarme{font-size:17px;margin-bottom:30px}.boton-ingresar{padding:22px;font-size:19px;border-radius:15px;margin-bottom:30px}.boton-google{padding:18px;font-size:17px;border-radius:15px}.enlace-olvido{font-size:17px}}@media screen and (min-width: 1920px){.registro-fondo{padding:80px}.registro-contenedor{max-width:650px;padding:80px;border-radius:35px;-webkit-backdrop-filter:blur(35px);backdrop-filter:blur(35px);box-shadow:0 25px 80px #0000004d}.registro-logo{width:180px;margin-bottom:30px}.registro-titulo{font-size:40px;margin-bottom:45px;font-weight:500}.registro-formulario .campo{margin-bottom:35px}.registro-formulario input{width:100%;padding:24px 35px 24px 75px;font-size:20px;border-radius:18px;border:3px solid rgba(255,255,255,.3)}.registro-formulario input:focus{border:3px solid #24211e;box-shadow:0 0 0 4px #24211e1a}.registro-formulario .icono{left:28px;font-size:24px}.recordarme{font-size:18px;margin-bottom:35px}.boton-ingresar{padding:25px;font-size:20px;border-radius:18px;margin-bottom:35px}.boton-google{padding:20px;font-size:18px;border-radius:18px}.enlace-olvido{font-size:18px}.mensaje-login{padding:18px;border-radius:12px;margin-top:25px;font-size:16px}}@media screen and (min-width: 1000px){.registro-contenedor:hover{transform:translateY(-5px);box-shadow:0 20px 60px #00000040}.registro-formulario input:hover{border-color:#24211e66}}@media screen and (min-width: 1000px){.registro-logo:hover{transform:scale(1.05)}}@media screen and (min-width: 2560px){.registro-contenedor{max-width:750px;padding:100px}.registro-titulo{font-size:48px}.registro-formulario input{font-size:22px;padding:28px 40px 28px 85px}.registro-formulario .icono{font-size:28px;left:35px}}@media screen and (min-width: 1000px){.registro-contenedor{will-change:transform}.boton-ingresar,.boton-google{will-change:transform,box-shadow}.registro-formulario input{will-change:border-color,transform,box-shadow}}@media screen and (min-width: 1000px) and (-webkit-min-device-pixel-ratio: 2){.registro-contenedor{backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.registro-contenedor:hover{transform:none}}.registro-fondo{background-size:cover;background-position:center;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px;background-image:url(/assets/FondoLogin-CnHKXLG1.webp)}.registro-contenedor{background:#ffffff1a;padding:40px;border-radius:10px;max-width:600px;width:100%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center}.registro-logo{width:120px;margin-bottom:10px}.registro-titulo{color:#fff;font-size:24px;margin-bottom:20px}.registro-formulario .campo{margin-bottom:15px;position:relative;display:flex;justify-content:center;align-items:center}.registro-formulario input{width:100%;padding:10px 15px 10px 45px;border:2px solid transparent;border-radius:6px;outline:none;font-size:14px;transition:border .2s ease}.registro-formulario input:focus{border:2px solid #24211e}.registro-formulario .icono{position:absolute;left:15px;color:#24211e;pointer-events:none;display:flex;align-items:center;height:100%}.boton-ingresar{background-color:#24211e;color:#fff;width:40%;padding:18px;border:none;border-radius:6px;font-size:16px;margin-bottom:15px;cursor:pointer;transition:all .3s ease}.boton-ingresar:hover{background-color:#3a3734;box-shadow:0 4px 12px #0003}.enlace-olvido{font-size:14px;color:#fff;text-decoration:none}.enlace-olvido:hover{text-decoration:underline}.enlace-login{font-size:14px;color:#fff;text-decoration:none;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:all .3s ease}.enlace-login:hover{text-decoration:underline;color:#f0f0f0}.mensaje-form{padding:10px;border-radius:6px;margin-top:15px;text-align:center;font-weight:700;animation:fadeIn .3s ease-in-out}.mensaje-exito{background-color:#e6ffed;color:#2d7a46;border:1px solid #2d7a46}.mensaje-error{background-color:#ffe6e6;color:#c00;border:1px solid #cc0000}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@media screen and (max-width: 380px){.registro-contenedor{padding:25px}.registro-logo{width:90px}.registro-titulo{font-size:20px}.registro-formulario .campo .icono{display:none!important}.registro-formulario input{font-size:13px;padding:10px 15px}.boton-ingresar{font-size:13px;padding:12px}.enlace-olvido{font-size:13px}}@media screen and (min-width: 381px) and (max-width: 768px){.registro-contenedor{max-width:90%;padding:35px}.registro-logo{width:100px}.registro-titulo{font-size:22px}}.layout-usuario{display:block;min-height:100vh;background-color:#f7f7f7;transition:all .3s ease}.header-movil{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:#23201d;z-index:1200;align-items:center;padding:0 1rem;box-shadow:0 2px 8px #00000026}@media (max-width: 768px){.en-lector-pdf .header-movil{display:flex}}.btn-menu-hamburguesa{background:none;border:none;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-menu-hamburguesa:hover{background:#ffffff1a}.btn-menu-hamburguesa svg{width:24px;height:24px}.titulo-app-movil{flex:1;text-align:center;color:#fff;font-size:1.1rem;font-weight:600}.perfil-movil{width:35px;height:35px;border-radius:50%;overflow:hidden;background:#edb1a6;display:flex;align-items:center;justify-content:center;cursor:pointer}.perfil-movil img{width:100%;height:100%;object-fit:cover}.perfil-movil svg{width:18px;height:18px;fill:#fff}.sidebar-usuario{background-color:#23201d;color:#fff;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:20px 10px;width:220px;min-height:100vh;position:fixed;left:0;top:0;bottom:0;overflow-y:auto;transition:all .3s ease;z-index:1000;gap:50px;scrollbar-width:none;-ms-overflow-style:none}.sidebar-usuario::-webkit-scrollbar{display:none}.sidebar-usuario.colapsado{width:70px}.sidebar-movil-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:950;opacity:0;visibility:hidden;transition:all .3s ease}.sidebar-movil-overlay.abierto{opacity:1;visibility:visible}.sidebar-movil{position:fixed;top:0;left:0;bottom:0;width:280px;background:#23201d;color:#fff;padding:20px;transform:translate(-100%);transition:transform .3s ease;z-index:975;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.sidebar-movil::-webkit-scrollbar{display:none}.sidebar-movil.abierto{transform:translate(0)}.sidebar-movil .perfil-movil-drawer{display:flex;align-items:center;gap:15px;padding:20px 0;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:30px}.sidebar-movil .perfil-movil-drawer .imagen-perfil{width:60px;height:60px;background-color:#edb1a6;border-radius:50%;overflow:hidden;display:flex;justify-content:center;align-items:center}.sidebar-movil .perfil-movil-drawer .imagen-perfil img{width:100%;height:100%;object-fit:cover}.sidebar-movil .perfil-movil-drawer .imagen-perfil svg{width:24px;height:24px;fill:#fff}.sidebar-movil .info-usuario{color:#fff}.sidebar-movil .info-usuario h4{margin:0 0 5px;font-size:1.1rem}.sidebar-movil .info-usuario p{margin:0;font-size:.9rem;opacity:.7}.imagen-perfil{width:80px;height:80px;background-color:#edb1a6;border-radius:50%;overflow:hidden;display:flex;justify-content:center;align-items:center;transition:all .3s ease;cursor:pointer;flex-shrink:0}.imagen-perfil img{width:100%;height:100%;object-fit:cover}.imagen-perfil svg{width:30px;height:30px;fill:#fff;transition:all .3s ease}.sidebar-usuario.colapsado .imagen-perfil{width:40px;height:40px}.sidebar-usuario.colapsado .imagen-perfil svg{width:20px;height:20px}.avatar-imagen{width:100%;height:100%;object-fit:cover}.sidebar-menu{flex-grow:1;display:flex;flex-direction:column;align-items:center;gap:18px;width:100%;margin-top:auto;margin-bottom:auto}.sidebar-menu button{background:none;color:#fff;border:none;font-size:.95rem;cursor:pointer;display:flex;align-items:center;gap:12px;padding:12px 14px;width:100%;text-align:left;border-radius:8px;transition:all .2s ease;min-height:44px}.sidebar-menu button:hover{background-color:#e731801a;transform:translate(2px)}.sidebar-menu button.activo,.sidebar-menu button:active{background-color:#e73180;color:#fff}.sidebar-menu button span{display:inline;transition:opacity .2s ease;font-weight:500}.sidebar-menu button svg{width:20px;height:20px;flex-shrink:0}.sidebar-usuario.colapsado .sidebar-menu button{justify-content:center;padding:12px 8px}.sidebar-usuario.colapsado .sidebar-menu button span{display:none}.sidebar-movil .sidebar-menu{align-items:stretch;gap:8px}.sidebar-movil .sidebar-menu button{justify-content:flex-start;padding:15px 20px;border-radius:12px;font-size:1rem}.sidebar-movil .sidebar-menu button:hover{transform:none}.toggle-btn{background-color:#e73180;color:#fff;border:none;padding:8px 12px;cursor:pointer;border-radius:6px;font-size:.9rem;transition:all .2s ease;margin:10px 0}.toggle-btn:hover{background-color:#d91570;transform:scale(1.05)}.logo-footer{margin-top:auto;padding-bottom:20px}.logo-imagen{width:100px;object-fit:contain;filter:brightness(0) invert(1);transition:width .3s ease}.sidebar-usuario.colapsado .logo-imagen{width:50px}.logo-placeholder{color:#aaa;font-size:.8rem;text-align:center}.contenido-usuario{padding:30px 30px 90px;margin-left:220px;transition:margin-left .3s ease;min-height:calc(100vh - 60px)}.sidebar-usuario.colapsado~.contenido-usuario{margin-left:70px}.bottom-nav-usuario{display:none;position:fixed;left:0;right:0;bottom:0;height:65px;background:#23201d;box-shadow:0 -4px 20px #00000026;z-index:1000;border-top:1px solid #333;overflow:hidden;padding:0}.bottom-nav-container{display:flex;align-items:center;justify-content:center;height:100%;width:100%;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;padding:0 8px;gap:4px;min-width:100%;scrollbar-width:none;-ms-overflow-style:none}.bottom-nav-container::-webkit-scrollbar{display:none}@media (max-width: 480px){.bottom-nav-container{justify-content:flex-start}}.bottom-nav-usuario button{background:none;border:none;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:9px;gap:3px;width:55px;min-width:55px;height:55px;border-radius:12px;transition:all .2s ease;position:relative;overflow:hidden;flex-shrink:0;cursor:pointer}.bottom-nav-usuario button.perfil{flex-direction:column;gap:2px}.bottom-nav-usuario button.perfil .perfil-imagen{width:24px;height:24px;border-radius:50%;overflow:hidden;background:#edb1a6;display:flex;align-items:center;justify-content:center;margin-bottom:1px}.bottom-nav-usuario button.perfil .perfil-imagen img{width:100%;height:100%;object-fit:cover}.bottom-nav-usuario button.perfil .perfil-imagen svg{width:12px;height:12px;fill:#fff}.bottom-nav-usuario button:before{content:"";position:absolute;inset:0;background:#e73180;opacity:0;transition:opacity .2s ease;border-radius:12px}.bottom-nav-usuario button.activo:before{opacity:1}.bottom-nav-usuario button svg{width:20px;height:20px;position:relative;z-index:1;transition:transform .2s ease;flex-shrink:0}.bottom-nav-usuario button span{position:relative;z-index:1;font-weight:500;opacity:.8;font-size:8px;text-align:center;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50px}.bottom-nav-usuario button.activo span{opacity:1;font-weight:600}@media (hover: hover) and (pointer: fine){.bottom-nav-usuario button:hover:before{opacity:.3}.bottom-nav-usuario button:hover svg{transform:scale(1.1)}}@media (max-width: 1200px) and (min-width: 1001px){.sidebar-usuario{width:180px;gap:50px;padding:15px 8px}.contenido-usuario{margin-left:180px;padding:25px}.sidebar-usuario.colapsado~.contenido-usuario{margin-left:70px}.imagen-perfil{width:65px;height:65px}.sidebar-menu button{font-size:.9rem;padding:10px 12px;gap:10px}.logo-imagen{width:85px}}@media (max-width: 1000px) and (min-width: 769px){.sidebar-usuario{width:70px;gap:30px;padding:15px 5px}.contenido-usuario{margin-left:70px;padding:20px}.sidebar-usuario.colapsado~.contenido-usuario{margin-left:70px}.imagen-perfil{width:50px;height:50px}.imagen-perfil svg{width:20px;height:20px}.sidebar-menu button{justify-content:center;padding:10px 6px;gap:0}.sidebar-menu button span{display:none}.sidebar-menu button svg{width:22px;height:22px}.toggle-btn{padding:6px 8px;font-size:.8rem}.logo-imagen{width:45px}.logo-footer{padding-bottom:10px}}@media (max-width: 768px){.sidebar-usuario{display:none!important}.layout-usuario:not(.en-lector-pdf) .sidebar-movil-overlay{display:block}.en-lector-pdf .sidebar-movil-overlay{display:none!important}.contenido-usuario{margin-left:0!important;padding:20px 20px 80px}.en-lector-pdf .contenido-usuario{padding-top:80px;padding-bottom:20px}.layout-usuario:not(.en-lector-pdf) .bottom-nav-usuario{display:flex;flex-direction:column}.en-lector-pdf .bottom-nav-usuario{display:none!important}.bottom-nav-container{justify-content:center;padding:0 12px;gap:8px}.bottom-nav-usuario button{width:58px;min-width:58px}}@media (max-width: 480px){.contenido-usuario{padding:12px 12px 75px}.en-lector-pdf .contenido-usuario{padding-top:75px;padding-bottom:12px}.bottom-nav-usuario{height:60px}.bottom-nav-container{padding:0 5px;gap:3px;justify-content:flex-start}.bottom-nav-usuario button{width:50px;min-width:50px;height:50px;font-size:8px;gap:2px}.bottom-nav-usuario button svg{width:18px;height:18px}.bottom-nav-usuario button span{font-size:7px;max-width:45px}.bottom-nav-usuario button.perfil .perfil-imagen{width:22px;height:22px}.bottom-nav-usuario button.perfil .perfil-imagen svg{width:11px;height:11px}.sidebar-movil{width:260px}}h1{margin-bottom:10px;color:#333;font-size:clamp(1.5rem,4vw,2.5rem)}.separador{border:1px solid #e73180;margin-bottom:clamp(20px,5vw,30px)}.seccion-titulo{color:#e73180;margin-bottom:12px;font-weight:600;font-size:clamp(1rem,2.5vw,1.1rem)}.fila{display:flex;flex-direction:column;gap:clamp(15px,4vw,40px);margin-bottom:clamp(20px,5vw,40px)}.fila-1 .col{width:100%;min-width:unset}.fila-2{display:grid;grid-template-columns:1fr;gap:clamp(15px,4vw,30px)}.grupo-inputs{display:flex;flex-direction:column;gap:clamp(8px,2vw,12px)}input{width:100%;max-width:400px;padding:clamp(8px,2vw,10px);border-radius:8px;border:1px solid #ccc;font-size:clamp(.85rem,2vw,.9rem);background:#fff;box-sizing:border-box}.btn-perfil{background-color:#e73180;color:#fff;padding:clamp(8px,2vw,10px);width:100%;max-width:200px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease;font-size:clamp(.85rem,2vw,.9rem)}.btn-perfil:hover{background-color:#c91f6d;transform:translateY(-1px)}.input-imagen{width:100%;max-width:400px;background:#fafafa;border:2px dashed #ccc;padding:clamp(15px,4vw,20px);text-align:center;border-radius:8px;font-size:clamp(.8rem,2vw,.85rem);color:#666;cursor:pointer;transition:all .2s ease}.input-imagen:hover{border-color:#e73180;background:#f9f9f9}.adquirido{overflow-x:auto;-webkit-overflow-scrolling:touch}.adquirido table{width:100%;min-width:500px;border-collapse:collapse;background:#fff;font-size:clamp(.8rem,2vw,.9rem)}.adquirido th,.adquirido td{padding:clamp(6px,2vw,10px);border:1px solid #ddd;text-align:left}.adquirido th{background-color:#f8f9fa;font-weight:600}.estadisticas .card{background:#fff;border-left:5px solid #e73180;padding:clamp(12px,3vw,15px);margin-bottom:clamp(10px,3vw,15px);border-radius:6px;font-size:clamp(.85rem,2vw,.9rem);box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.contenedor-imagen-perfil{display:flex;justify-content:center;align-items:center;margin-bottom:10px}.foto-perfil{width:clamp(80px,15vw,120px);height:clamp(80px,15vw,120px);object-fit:cover;border-radius:50%;border:2px solid #ccc;transition:border-color .2s ease}.foto-perfil:hover{border-color:#e73180}.foto-placeholder{width:clamp(80px,15vw,120px);height:clamp(80px,15vw,120px);background-color:#eee;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:clamp(1.5rem,4vw,2rem);color:#888;border:2px solid #ddd}.mensaje{width:100%;max-width:400px;padding:clamp(6px,1.5vw,8px);margin-top:8px;border-radius:5px;text-align:center;font-weight:500;border:1px solid transparent;transition:opacity .3s ease-in-out;font-size:clamp(.8rem,2vw,.9rem)}.mensaje.exito{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.mensaje.error{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}@media (min-width: 600px){.grupo-inputs{flex-direction:row;flex-wrap:wrap;align-items:flex-end}.grupo-inputs>*{flex:1;min-width:200px}input,.btn-perfil{width:auto}}@media (min-width: 768px){.fila{flex-direction:row;flex-wrap:wrap}.fila-1 .col{flex:1;min-width:280px}.fila-2{grid-template-columns:2fr 1fr}.input-imagen,input,.btn-perfil{width:70%}}@media (min-width: 1000px){.fila{gap:50px;margin-bottom:50px}.fila-2{gap:40px}.input-imagen,input,.btn-perfil{width:60%}.grupo-inputs{flex-direction:row;align-items:center}.adquirido table{min-width:unset}.estadisticas .card{padding:20px;margin-bottom:20px}}@media (min-width: 1200px){.fila{gap:60px}.input-imagen,input,.btn-perfil{width:50%}.estadisticas{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.estadisticas .card{margin-bottom:0}}@media (min-width: 1400px){.container-principal{max-width:1200px;margin:0 auto;padding:0 20px}}*{margin:0;padding:0;box-sizing:border-box}body,input,button,label,h1,h2,h3,h4,h5{font-family:Poppins,sans-serif}.verificacion-fondo{background-size:cover;background-position:center;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px;background-image:url(/assets/FondoLogin-CnHKXLG1.webp)}.verificacion-contenedor{background:#ffffff1a;padding:40px;border-radius:10px;max-width:500px;width:100%;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center}.verificacion-logo{width:120px;margin-bottom:10px}.verificacion-icono{font-size:50px;margin-bottom:10px}.verificacion-titulo{color:#fff;font-size:24px;margin-bottom:15px}.verificacion-mensaje{color:#fff;font-size:16px;margin-bottom:25px}.verificacion-boton{background-color:#24211e;color:#fff;padding:15px 30px;border-radius:6px;font-size:16px;text-decoration:none;transition:all .3s ease;display:inline-block}.verificacion-boton:hover{background-color:#3a3734;box-shadow:0 4px 12px #0003}@media screen and (max-width: 380px){.verificacion-contenedor{padding:25px}.verificacion-logo{width:90px}.verificacion-titulo{font-size:20px}.verificacion-boton{font-size:14px;padding:12px 20px}}@media screen and (min-width: 381px) and (max-width: 768px){.verificacion-contenedor{max-width:90%;padding:35px}.verificacion-logo{width:100px}.verificacion-titulo{font-size:22px}}.libro-card{background:#e5e5e5;border-radius:10px;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:transform .15s ease;outline:none;width:100%;max-width:100%;min-width:0}.libro-card:focus{box-shadow:0 0 0 3px #e731804d}.libro-card:hover{transform:translateY(-2px)}.libro-card__portada{width:100%;aspect-ratio:3 / 4;display:grid;place-items:start;overflow:hidden;position:relative}.libro-card__portada img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.libro-card:hover .libro-card__portada img{transform:scale(1.05)}.libro-card__placeholder{width:100%;height:100%;background:#cfcfcf}.libro-card__info{padding:clamp(8px,2vw,12px) clamp(10px,2.5vw,14px) clamp(10px,2.5vw,14px);display:grid;gap:clamp(4px,1vw,8px);flex:1;min-width:0}.libro-card__titulo{font-size:clamp(.85rem,2vw,.95rem);line-height:1.25;color:#333;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.libro-card__autor{font-size:clamp(.75rem,1.8vw,.8rem);color:#666;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.libro-card__precio{margin-top:clamp(4px,1vw,8px);background:#2dbb45;color:#fff;text-align:center;padding:clamp(6px,1.5vw,8px) clamp(8px,2vw,10px);border-radius:8px;font-weight:600;font-size:clamp(.8rem,1.8vw,.9rem);transition:filter .15s ease;border:none;cursor:inherit}.libro-card:hover .libro-card__precio{filter:brightness(.95)}@media (max-width: 320px){.libro-card__info{padding:8px 10px 10px;gap:6px}.libro-card__titulo{font-size:.8rem;-webkit-line-clamp:3}.libro-card__autor{font-size:.72rem}.libro-card__precio{font-size:.8rem;padding:6px 8px}}.catalogo-header{display:flex;justify-content:space-between;align-items:center;gap:clamp(12px,3vw,20px);flex-wrap:wrap;margin-bottom:clamp(16px,4vw,24px)}.catalogo-busqueda{display:flex;gap:clamp(6px,1.5vw,10px);flex:1;min-width:0;max-width:400px}.catalogo-busqueda input{padding:clamp(8px,2vw,12px) clamp(10px,2.5vw,14px);border:1px solid #ccc;border-radius:8px;flex:1;min-width:200px;font-size:clamp(.85rem,2vw,1rem);transition:border-color .15s ease}.catalogo-busqueda input:focus{outline:none;border-color:#e73180;box-shadow:0 0 0 2px #e731801a}.catalogo-busqueda input::placeholder{color:#999}.catalogo-busqueda button{background:#e73180;color:#fff;border:none;border-radius:8px;padding:clamp(8px,2vw,12px) clamp(12px,3vw,18px);cursor:pointer;font-size:clamp(.85rem,2vw,1rem);font-weight:500;transition:background-color .15s ease;white-space:nowrap;min-width:fit-content}.catalogo-busqueda button:hover{background:#c91f6d}.catalogo-busqueda button:focus{outline:2px solid #e73180;outline-offset:2px}.catalogo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:18px;padding:0;width:100%;justify-items:start}@media (max-width: 1200px){.catalogo-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:clamp(14px,2.5vw,20px)}}@media (max-width: 900px){.catalogo-header{flex-direction:column;align-items:stretch;gap:16px}.catalogo-busqueda{max-width:100%}.catalogo-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px}}@media (max-width: 600px){.catalogo-header{gap:12px}.catalogo-busqueda input{min-width:150px}.catalogo-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}}@media (max-width: 480px){.catalogo-busqueda{flex-direction:column;gap:8px}.catalogo-busqueda input{min-width:0}.catalogo-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}}@media (max-width: 360px){.catalogo-grid{grid-template-columns:1fr;gap:16px}}.catalogo-grid--loading{opacity:.6;pointer-events:none}.catalogo-grid--empty{display:flex;justify-content:center;align-items:center;min-height:200px;color:#666;font-size:1.1rem;text-align:center}.catalogo-filtros{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.catalogo-filtro{padding:6px 12px;background:transparent;border:1px solid #ccc;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .15s ease}.catalogo-filtro:hover{background:#f5f5f5;border-color:#999}.catalogo-filtro.active{background:#e73180;color:#fff;border-color:#e73180}.catalogo-filtro:focus{outline:2px solid #e73180;outline-offset:2px}.catalogo-contador{color:#666;font-size:.9rem;margin-bottom:12px;text-align:right}.catalogo-paginacion{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:32px;flex-wrap:wrap}.catalogo-paginacion button{padding:8px 12px;background:transparent;border:1px solid #ccc;border-radius:6px;cursor:pointer;transition:all .15s ease}.catalogo-paginacion button:hover{background:#f5f5f5;border-color:#999}.catalogo-paginacion button.active{background:#e73180;color:#fff;border-color:#e73180}.catalogo-paginacion button:disabled{opacity:.5;cursor:not-allowed}@media (prefers-reduced-motion: reduce){.catalogo-busqueda input,.catalogo-busqueda button,.catalogo-filtro,.catalogo-paginacion button{transition:none}}@media (prefers-color-scheme: dark){.catalogo-contador{color:#ccc}.catalogo-busqueda input{background:#2a2a2a;color:#fff;border-color:#555}.catalogo-busqueda input::placeholder{color:#aaa}}.btn-volver{background:transparent;border:none;color:#e73180;cursor:pointer;margin-bottom:clamp(12px,3vw,18px);font-weight:600;font-size:clamp(.9rem,2vw,1rem);padding:4px 0;transition:color .15s ease}.btn-volver:hover{color:#c91f6d;text-decoration:underline}.btn-volver:focus{outline:2px solid #e73180;outline-offset:2px;border-radius:4px}.detalle{display:grid;grid-template-columns:minmax(280px,320px) 1fr;gap:clamp(20px,4vw,32px);align-items:start;background:#e0e0e0;padding:clamp(14px,3vw,20px);border-radius:10px;width:100%;max-width:100%;overflow:hidden}.detalle__portada{width:100%;aspect-ratio:3 / 4;overflow:hidden;border-radius:8px;background:#d1d1d1;box-shadow:0 4px 12px #0000001a}.detalle__portada img{width:100%;height:100%;object-fit:cover}.detalle__info{display:grid;gap:clamp(8px,2vw,12px);min-width:0}.detalle__titulo{font-size:clamp(1.1rem,3vw,1.4rem);letter-spacing:.5px;line-height:1.2;color:#333;margin:0;word-break:break-word}.detalle__sub{color:#666;font-size:clamp(.9rem,2vw,1rem);margin:0}.detalle__datos{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 22px;padding:0;margin:8px 0 0;align-items:start}.detalle__datos li{font-size:.98rem;color:#444;margin:0 0 2px;min-width:0;max-width:100%;white-space:normal;word-break:break-word;font-weight:400;padding-bottom:10px}.detalle__progreso{display:flex;align-items:center;gap:clamp(8px,2vw,12px);margin:clamp(10px,2vw,16px) 0}.barra{height:clamp(18px,4vw,22px);width:100%;background:#fff;border-radius:30px;overflow:hidden;border:1px solid #ccc;position:relative;margin-right:14px}.barra__llena{height:100%;background:#000;width:0%;transition:width .3s ease}.btn-descargar{background:transparent;border:none;cursor:pointer;font-size:clamp(1rem,2.5vw,1.2rem);color:#333;padding:4px;border-radius:4px;transition:background-color .15s ease}.btn-descargar:hover{background:#0000000d}.btn-descargar:focus{outline:2px solid #e73180;outline-offset:2px}.detalle__sinopsis{margin-top:clamp(8px,2vw,12px);color:#333;line-height:1.5;font-size:clamp(.9rem,2vw,1rem)}.detalle__acciones{display:flex;gap:clamp(8px,2vw,14px);flex-wrap:wrap;margin-top:clamp(12px,3vw,16px)}.btn-accion{background:transparent;border:1px solid #333;padding:clamp(8px,2vw,10px) clamp(12px,3vw,16px);border-radius:8px;cursor:pointer;font-size:clamp(.85rem,2vw,.9rem);transition:background-color .15s ease;white-space:nowrap}.btn-accion:hover{background:#f2f2f2}.btn-accion:focus{outline:2px solid #e73180;outline-offset:2px}.btn-comprar{background:#2dbb45;color:#fff;border:none;padding:clamp(8px,2vw,10px) clamp(14px,3vw,18px);border-radius:8px;cursor:pointer;font-weight:600;font-size:clamp(.85rem,2vw,.9rem);transition:filter .15s ease;white-space:nowrap}.btn-comprar:hover{filter:brightness(.95)}.btn-comprar:focus{outline:2px solid #2dbb45;outline-offset:2px}@media (max-width: 1000px){.detalle{grid-template-columns:minmax(250px,280px) 1fr;gap:24px}}@media (max-width: 800px){.detalle{grid-template-columns:1fr;gap:20px}.detalle__portada{max-width:280px;justify-self:center}.detalle__datos{grid-template-columns:1fr;gap:6px}.barra{max-width:200px}}@media (max-width: 600px){.detalle{padding:16px 12px}.detalle__acciones{flex-direction:column;align-items:stretch}.btn-accion,.btn-comprar{text-align:center;width:100%}}@media (max-width: 400px){.detalle__portada{max-width:220px}.detalle__progreso{flex-direction:column;align-items:stretch;gap:8px}.barra{max-width:100%}}@media (prefers-reduced-motion: reduce){.barra__llena,.btn-volver,.btn-accion,.btn-comprar,.btn-descargar{transition:none}}*,*:before,*:after{box-sizing:border-box}img{max-width:100%;display:block}.biblio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(12px,2vw,20px);padding-inline:clamp(8px,3vw,24px);justify-items:center;align-content:start;width:100%;max-width:100%}.biblio-card{background:#e5e5e5;border-radius:10px;overflow:hidden;display:grid;grid-template-rows:auto 1fr;transition:transform .15s ease;width:100%;max-width:220px;min-width:180px;container-type:inline-size}.biblio-card:hover{transform:translateY(-2px)}.biblio-card__portada{width:100%;aspect-ratio:3 / 4;overflow:hidden;display:grid;place-items:center;background:#d1d1d1;position:relative}.biblio-card__portada img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.biblio-card:hover .biblio-card__portada img{transform:scale(1.04)}.biblio-card__placeholder{width:100%;height:100%;background:#cfcfcf}.biblio-card__info{padding:clamp(8px,2vw,12px) clamp(10px,2.5vw,14px) clamp(12px,3vw,16px);display:grid;gap:clamp(6px,1.5vw,10px);min-width:0}.biblio-card__titulo{font-size:clamp(.85rem,2vw,.95rem);color:#333;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.biblio-card__autor{font-size:clamp(.75rem,1.8vw,.8rem);color:#666;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.biblio-card__progreso{display:flex;align-items:center;gap:clamp(5px,1.5vw,8px);min-width:0}.barra{height:clamp(8px,2vw,10px);flex:1;background:#fff;border:1px solid #ccc;border-radius:30px;overflow:hidden;min-width:40px}.barra__llena{height:100%;background:#000;width:0%;transition:width .25s ease}.porcentaje{font-size:clamp(.7rem,1.8vw,.8rem);color:#333;white-space:nowrap;min-width:fit-content}.biblio-card__cta{margin-top:clamp(2px,1vw,6px);background:transparent;border:1px solid #333;color:#333;padding:clamp(6px,1.5vw,8px) clamp(8px,2vw,12px);border-radius:8px;cursor:pointer;width:100%;font-size:clamp(.75rem,1.8vw,.85rem);transition:background-color .15s ease;text-align:center}.biblio-card__cta:hover{background:#f2f2f2}.biblio-card__cta:focus{outline:2px solid #e73180;outline-offset:2px}@container (max-width: 200px){.biblio-card__titulo{font-size:.8rem;-webkit-line-clamp:3}.biblio-card__info{padding:8px 10px 12px;gap:6px}}@media (max-width: 480px){.biblio-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;padding-inline:12px}.biblio-card{min-width:160px}}@media (max-width: 360px){.biblio-grid{grid-template-columns:1fr;padding-inline:8px}.biblio-card{max-width:100%;width:100%}}.biblio-header{display:flex;justify-content:space-between;align-items:center;gap:clamp(12px,3vw,20px);flex-wrap:wrap;margin-bottom:clamp(16px,4vw,24px)}.biblio-busqueda{display:flex;gap:clamp(6px,1.5vw,10px);flex:1;min-width:0;max-width:400px}.biblio-busqueda input{padding:clamp(8px,2vw,12px) clamp(10px,2.5vw,14px);border:1px solid #ccc;border-radius:8px;flex:1;min-width:200px;font-size:clamp(.85rem,2vw,1rem);transition:border-color .15s ease}.biblio-busqueda input:focus{outline:none;border-color:#e73180;box-shadow:0 0 0 2px #e731801a}.biblio-busqueda button{background:#e73180;color:#fff;border:none;border-radius:8px;padding:clamp(8px,2vw,12px) clamp(12px,3vw,18px);cursor:pointer;font-size:clamp(.85rem,2vw,1rem);font-weight:500;transition:background-color .15s ease;white-space:nowrap;min-width:fit-content}.biblio-busqueda button:hover{background:#c91f6d}.biblio-busqueda button:focus{outline:2px solid #e73180;outline-offset:2px}.biblio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:clamp(18px,3.5vw,28px);padding:clamp(12px,2vw,16px);width:100%;max-width:100%;justify-content:start;justify-items:start}@media (max-width: 1200px){.biblio-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:clamp(14px,2.5vw,20px)}}@media (max-width: 900px){.biblio-header{flex-direction:column;align-items:stretch;gap:16px}.biblio-busqueda{max-width:100%}.biblio-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px}}@media (max-width: 600px){.biblio-header{gap:12px}.biblio-busqueda input{min-width:150px}.biblio-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}}@media (max-width: 480px){.biblio-busqueda{flex-direction:column;gap:8px}.biblio-busqueda input{min-width:0}.biblio-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px}}@media (max-width: 360px){.biblio-grid{grid-template-columns:1fr;gap:16px}}.biblio-grid--loading{opacity:.6;pointer-events:none}.biblio-grid--empty{display:flex;justify-content:center;align-items:center;min-height:200px;color:#666;font-size:1.1rem}@media (prefers-reduced-motion: reduce){.biblio-busqueda input,.biblio-busqueda button{transition:none}}.mv-backdrop{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:1000;padding:16px}.mv-dialog{position:relative;width:min(100%,960px);background:#111;color:#fff;border-radius:12px;box-shadow:0 10px 30px #0006;padding:16px 16px 12px}.mv-close{position:absolute;right:10px;top:8px;background:transparent;border:0;color:#fff;font-size:22px;cursor:pointer;line-height:1;opacity:.85}.mv-close:hover{opacity:1}.mv-aspect{position:relative;width:100%;padding-bottom:56.25%;background:#000;border-radius:8px;overflow:hidden}.mv-aspect iframe{position:absolute;inset:0;width:100%;height:100%}.mv-title{margin:10px 2px 0;font-size:15px;font-weight:500;color:#ddd;text-align:left}@media (max-width: 420px){.mv-dialog{padding:12px}.mv-title{font-size:14px}}@media (max-width: 768px){.mv-backdrop{padding:12px}.mv-dialog{width:min(100%,600px)}}@media (max-width: 600px){.mv-backdrop{padding:8px}.mv-dialog{padding:14px 14px 10px}.mv-close{right:8px;top:6px;font-size:20px}}@media (max-width: 480px){.mv-backdrop{padding:6px}.mv-dialog{border-radius:10px}.mv-aspect{border-radius:6px}.mv-title{margin:8px 2px 0}}@media (max-width: 360px){.mv-dialog{padding:10px;border-radius:8px}.mv-title{font-size:13px;margin:6px 1px 0}.mv-close{right:6px;top:4px;font-size:18px}.mv-aspect{border-radius:4px}}@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px){.mv-backdrop{padding:4px}.mv-dialog{width:min(100%,800px);padding:8px 8px 6px}.mv-title{font-size:13px;margin:4px 2px 0}.mv-close{right:6px;top:2px;font-size:18px}}@media (max-width: 480px) and (min-height: 800px){.mv-dialog{width:min(100%,400px)}}@media (max-width: 768px){.mv-close{padding:4px;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}}.mv-close:focus-visible{outline:2px solid #fff;outline-offset:2px;opacity:1}@media (hover: none){.mv-backdrop{background:#000000b3}}@media (min-width: 1200px){.mv-dialog{width:min(100%,1100px)}}@media (prefers-reduced-motion: reduce){.mv-dialog{transition:none}}@media (prefers-contrast: high){.mv-dialog{border:2px solid #fff}.mv-close{background:#ffffff1a;border-radius:4px}}.tuts-header{margin-bottom:8px}.tuts-sub{color:#666;font-size:.95rem}.tuts-grid{display:grid;gap:20px;grid-template-columns:repeat(3,minmax(220px,1fr))}@media (max-width: 1100px){.tuts-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width: 600px){.tuts-grid{grid-template-columns:1fr}}@media (min-width: 1400px){.tuts-grid{grid-template-columns:repeat(4,minmax(220px,1fr))}}@media (max-width: 900px) and (min-width: 601px){.tuts-grid{grid-template-columns:repeat(2,minmax(200px,1fr));gap:18px}}@media (max-width: 480px){.tuts-grid{gap:16px}}@media (max-width: 360px){.tuts-grid{gap:14px}}@media (max-width: 900px) and (orientation: landscape){.tuts-grid{grid-template-columns:repeat(2,minmax(180px,1fr));gap:16px}}@media (max-width: 1100px) and (min-width: 768px) and (orientation: portrait){.tuts-grid{grid-template-columns:repeat(2,minmax(240px,1fr))}}@media (max-width: 400px){.tuts-grid{grid-template-columns:minmax(0,1fr)}}.tut-card{background:#eee;border-radius:10px;cursor:pointer;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease;outline:none}.tut-card:hover{transform:translateY(-2px);box-shadow:0 10px 18px #00000014}.tut-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:#d6d6d6;overflow:hidden}.tut-thumb img{width:100%;height:100%;object-fit:cover;display:block;filter:contrast(1.02) saturate(1.02);transition:transform .25s ease}.tut-card:hover .tut-thumb img{transform:scale(1.04)}.tut-play{position:absolute;inset:0;display:grid;place-items:center;font-size:46px;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.45);background:linear-gradient(to bottom,#0000,#00000040);pointer-events:none}.tut-title{padding:12px 14px 14px;font-size:.95rem;color:#222}@media (max-width: 600px){.tut-play{font-size:40px}}@media (max-width: 400px){.tut-play{font-size:36px}}@media (max-width: 600px){.tut-title{padding:10px 12px 12px;font-size:.9rem}}@media (max-width: 400px){.tut-title{padding:8px 10px 10px;font-size:.85rem}}@media (hover: none){.tut-card:hover{transform:none;box-shadow:none}.tut-card:active{transform:translateY(-1px);box-shadow:0 5px 12px #0000001f}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.tut-thumb img{image-rendering:-webkit-optimize-contrast}}@media (prefers-reduced-motion: reduce){.tut-card,.tut-thumb img{transition:none}}:root{--color-primary: #a53359;--color-lectura: #4caf50;--color-notas: #8bc34a;--color-tiempo: #e91e63;--color-intermitencia: #9c27b0;--color-bg-page: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);--color-text-primary: #2d3748;--color-text-secondary: #4a5568;--color-text-muted: #718096;--spacing-xs: 8px;--spacing-sm: 12px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 40px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-pill: 25px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 8px 25px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .15);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem}.estadisticas-page{padding:var(--spacing-lg);max-width:1200px;margin:0 auto;background:transparent;min-height:100vh}.stats-header{text-align:center;margin-bottom:var(--spacing-xl);animation:fadeInDown .8s cubic-bezier(.4,0,.2,1)}.stats-header h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0;background:linear-gradient(135deg,var(--color-primary),#f06292);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1)}.stats-sub{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0;font-weight:400}.separador{border:none;height:3px;background:linear-gradient(90deg,transparent,var(--color-primary),#f06292,transparent);margin:var(--spacing-xl) 0;border-radius:2px;animation:expandWidth 1s ease-out .5s both}.libros-strip{display:flex;justify-content:flex-start;align-items:center;gap:var(--spacing-sm);overflow-x:auto;padding:var(--spacing-md) 0;margin-bottom:var(--spacing-xl);scrollbar-width:thin;scrollbar-color:var(--color-text-muted) #f9fafb;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;width:100%}.libro-pill{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #d1d5db;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-slow);flex-shrink:0;min-width:250px;position:relative;overflow:hidden;scroll-snap-align:start;animation:slideInUp .6s cubic-bezier(.4,0,.2,1);box-shadow:none}.libro-pill:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .6s ease}.libro-pill:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 25px #e91e6338;background:#fffffff7;border-color:var(--color-primary)}.libro-pill:hover:before{left:100%}.libro-pill.activo{background:linear-gradient(135deg,#e91e6317,#fffffffa);border-color:var(--color-primary)}.pill-thumb{width:32px;height:44px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-md)}.pill-thumb img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-normal)}.libro-pill:hover .pill-thumb img{transform:scale(1.1)}.pill-title{font-size:var(--font-size-sm);font-weight:600;color:#6b7280;line-height:1.3;text-align:left;transition:color var(--transition-normal)}.libro-pill:hover .pill-title{color:var(--color-primary)}.libro-pill.activo .pill-title{color:#ad1457;font-weight:700}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.stats-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:var(--spacing-xl) var(--spacing-lg);box-shadow:0 4px 20px #00000014;border:1px solid rgba(255,255,255,.2);transition:all var(--transition-slow);position:relative;overflow:hidden;min-height:280px;aspect-ratio:16/9;max-width:520px;width:100%;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;animation:fadeInUp .8s cubic-bezier(.4,0,.2,1)}.stats-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--card-color);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.stats-card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .8s ease}.stats-card:hover:after{left:100%}.stats-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #00000026}.stats-card--progreso{--card-color: var(--color-primary);background:linear-gradient(135deg,#e91e6308,#fff)}.stats-card--progreso:hover{box-shadow:0 20px 40px #e91e6340;background:linear-gradient(135deg,#e91e630f,#fffffffa)}.stats-card--lectura{--card-color: var(--color-lectura);background:linear-gradient(135deg,#4caf5008,#fff)}.stats-card--lectura:hover{box-shadow:0 20px 40px #4caf5040;background:linear-gradient(135deg,#4caf500f,#fffffffa)}.stats-card--notas{--card-color: var(--color-notas);background:linear-gradient(135deg,#8bc34a08,#fff)}.stats-card--notas:hover{box-shadow:0 20px 40px #8bc34a40;background:linear-gradient(135deg,#8bc34a0f,#fffffffa)}.stats-card--tiempo{--card-color: var(--color-tiempo);background:linear-gradient(135deg,#e91e6308,#fff)}.stats-card--tiempo:hover{box-shadow:0 20px 40px #e91e6340;background:linear-gradient(135deg,#e91e630f,#fffffffa)}.stats-card--intermitencia{--card-color: var(--color-intermitencia);background:linear-gradient(135deg,#9c27b008,#fff)}.stats-card--intermitencia:hover{box-shadow:0 20px 40px #9c27b040;background:linear-gradient(135deg,#9c27b00f,#fffffffa)}.card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-shrink:0;animation:slideInLeft .6s ease-out}.card-header svg{width:22px;height:22px;color:var(--card-color);flex-shrink:0;transition:transform var(--transition-normal)}.stats-card:hover .card-header svg{transform:scale(1.1) rotate(5deg)}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.2}.card-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;margin:var(--spacing-md) 0}.card-footer{flex-shrink:0;margin-top:auto}.stat-display{display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-sm);animation:numberPulse 2s ease-in-out infinite}.stat-number{font-size:3.5rem;font-weight:300;line-height:1;color:var(--card-color);margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1);transition:all var(--transition-normal)}.stats-card:hover .stat-number{transform:scale(1.07);text-shadow:0 4px 8px rgba(0,0,0,.2)}.btn-seguir{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),#ad1457);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-slow);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 8px 25px #e91e6366;position:relative;overflow:hidden;animation:slideInUp .6s ease-out}.btn-seguir:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s ease}.btn-seguir:hover:before{left:100%}.btn-seguir:hover{transform:translateY(-4px);box-shadow:0 12px 35px #e91e6399;background:linear-gradient(135deg,#c2185b,#ad1457)}.btn-seguir:active{transform:translateY(-2px)}.card-help{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;text-align:center;line-height:1.4;font-weight:400;font-style:italic;animation:fadeIn 1s ease-out .5s both}.loading-state,.estado-vacio{text-align:center;padding:var(--spacing-xxl);color:var(--color-text-secondary);font-size:var(--font-size-lg);background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:2px dashed rgba(233,30,99,.3);margin:var(--spacing-xl) 0;font-weight:500;animation:pulse 2s ease-in-out infinite}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes expandWidth{0%{width:0}to{width:100%}}@keyframes numberPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.stats-card:nth-child(1){animation-delay:.1s}.stats-card:nth-child(2){animation-delay:.2s}.stats-card:nth-child(3){animation-delay:.3s}.stats-card:nth-child(4){animation-delay:.4s}.stats-card:nth-child(5){animation-delay:.5s}@media (max-width: 600px){.libros-strip{justify-content:center!important}}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.stats-card{max-width:95vw;min-height:260px;aspect-ratio:auto}}@media (max-width: 768px){.estadisticas-page{padding:var(--spacing-md)}.stats-header h1{font-size:var(--font-size-3xl)}.stats-sub{font-size:var(--font-size-base)}.stats-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.stats-card{padding:var(--spacing-lg) var(--spacing-md);min-height:240px;max-width:98vw;aspect-ratio:auto}.stat-number{font-size:2.8rem;font-weight:300}.libro-pill{min-width:200px;padding:var(--spacing-xs) var(--spacing-md)}.pill-title{font-size:var(--font-size-xs)}}@media (max-width: 480px){.estadisticas-page{padding:var(--spacing-sm)}.stats-header h1{font-size:var(--font-size-2xl)}.stats-sub{font-size:var(--font-size-sm)}.stats-card{padding:var(--spacing-md) var(--spacing-sm);min-height:200px;max-width:99vw}.stat-number{font-size:2.2rem;font-weight:300}.btn-seguir{padding:var(--spacing-sm) var(--spacing-md);font-size:12px}.libro-pill{min-width:150px;padding:var(--spacing-xs)}.pill-title{font-size:11px;line-height:1.2}.card-help{font-size:12px}}@media (min-width: 1400px){.estadisticas-page{max-width:1600px;padding:var(--spacing-xxl)}}@media (min-width: 1800px){.estadisticas-page{max-width:95%}}.soporte-container{max-width:800px;margin:0 auto;padding:20px}.soporte-header{display:flex;align-items:center;gap:20px;margin-bottom:40px;padding:25px;background:linear-gradient(135deg,#e73180,#f39c12);border-radius:12px;color:#fff}.header-icon{background:#fff3;padding:15px;border-radius:50%;display:flex;align-items:center;justify-content:center}.header-icon svg{width:32px;height:32px;fill:#fff}.header-content h1{margin:0 0 8px;font-size:2rem;font-weight:600}.header-content p{margin:0;opacity:.9;font-size:1.1rem}.ticket-form-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px #0000001a}.user-info{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:25px;border-left:4px solid #e73180}.info-row{display:flex;gap:30px;margin-bottom:10px}.info-row:last-child{margin-bottom:0}.info-item{display:flex;align-items:center;gap:8px}.info-item label{font-weight:600;color:#666;font-size:.9rem}.info-item span{color:#333;font-weight:500}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:1rem}.required{color:#e73180}.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fff;resize:vertical;font-family:inherit}.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#e73180;box-shadow:0 0 0 3px #e731801a}.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px;appearance:none}.char-counter{text-align:right;font-size:.85rem;color:#666;margin-top:5px}.file-input-container{position:relative}.file-input{position:absolute;opacity:0;width:0;height:0}.file-input-label{display:flex;align-items:center;gap:10px;padding:12px 16px;border:2px dashed #e1e5e9;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#fafafa;color:#666;font-weight:500}.file-input-label:hover{border-color:#e73180;background:#fff;color:#333}.file-input-label svg{width:20px;height:20px;fill:currentColor}.file-help{display:block;margin-top:5px;color:#666;font-size:.85rem}.mensaje{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:500}.mensaje.exito{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.mensaje.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.btn-enviar{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 20px;background:#e73180;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-enviar:hover:not(:disabled){background:#d91570;transform:translateY(-2px);box-shadow:0 6px 20px #e731804d}.btn-enviar:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-enviar svg{width:18px;height:18px;fill:currentColor}.loading-spin{animation:spin 1s linear infinite}@media (max-width: 768px){.soporte-container{padding:15px}.soporte-header{flex-direction:column;text-align:center;gap:15px}.header-content h1{font-size:1.5rem}.ticket-form-container{padding:20px}.info-row{flex-direction:column;gap:10px}}@media (max-width: 480px){.header-content h1{font-size:1.3rem}.header-content p{font-size:1rem}.ticket-form-container{padding:15px}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999!important;padding:1rem;animation:overlayFadeIn .3s ease-out}@keyframes overlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.modal-edicion{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d,0 8px 24px #0003;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1);border:1px solid rgba(222,0,126,.1);z-index:10000!important;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.8) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;background:linear-gradient(135deg,#de007e,#b8005a);color:#fff;position:relative}.modal-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent)}.modal-titulo{display:flex;align-items:center;gap:.75rem;font-size:1.125rem;font-weight:600;margin:0}.modal-titulo svg{opacity:.9}.modal-cerrar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease}.modal-cerrar:hover{background:#fff3;border-color:#fff6;transform:scale(1.05)}.modal-cerrar:active{transform:scale(.95)}.modal-contenido{padding:2rem;display:flex;flex-direction:column;gap:1.5rem;flex:1;overflow-y:auto}.textarea-container{display:flex;flex-direction:column;gap:.5rem}.textarea-container label{font-size:.875rem;font-weight:600;color:#333;margin-bottom:.25rem}.textarea-modal{width:100%;min-height:100px;padding:1rem;border:2px solid #e0e0e0;border-radius:12px;font-size:.95rem;line-height:1.5;resize:vertical;transition:all .2s ease;background:#fafafa;font-family:inherit}.textarea-modal.caveat-text{font-family:Caveat,cursive;font-optical-sizing:auto;font-weight:500;font-style:normal;font-size:18px;line-height:1.4;letter-spacing:.5px}.textarea-modal:focus{outline:none;border-color:#de007e;background:#fff;box-shadow:0 0 0 3px #de007e1a}.textarea-modal::placeholder{color:#999;font-style:italic}.controles-formato{display:grid;grid-template-columns:1fr;gap:1.5rem}.control-item{display:flex;flex-direction:column;gap:.5rem}.control-item label{font-size:.875rem;font-weight:600;color:#333}.input-with-unit{display:flex;align-items:center;gap:.75rem}.range-input{flex:1;height:6px;background:#e0e0e0;border-radius:3px;outline:none;cursor:pointer;transition:background .2s ease}.range-input::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:linear-gradient(135deg,#de007e,#b8005a);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #de007e4d,0 1px 3px #0003;transition:all .2s ease}.range-input::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #de007e66,0 2px 6px #0000004d}.range-input::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,#de007e,#b8005a);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 8px #de007e4d,0 1px 3px #0003}.unit-display{font-size:.875rem;font-weight:600;color:#de007e;min-width:40px;text-align:center;background:#de007e1a;padding:.25rem .5rem;border-radius:6px}.vista-previa{display:flex;flex-direction:column;gap:.5rem}.vista-previa label{font-size:.875rem;font-weight:600;color:#333}.preview-text{padding:1rem;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;min-height:60px;display:flex;align-items:center;justify-content:center;text-align:center;transition:all .2s ease;line-height:1.4;color:#000}.preview-text.caveat-text{font-family:Caveat,cursive;font-optical-sizing:auto;font-style:normal;letter-spacing:.5px;line-height:1.3}.preview-text:empty:before{content:"Vista previa del texto...";color:#999;font-style:italic;font-family:inherit;font-weight:400}.mensaje-error-modal{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.875rem;animation:errorShake .5s ease}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.mensaje-error-modal svg{flex-shrink:0}.modal-footer{padding:1.5rem 2rem;background:#fafafa;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;gap:1rem}.atajos-hint{font-size:.75rem;color:#666;font-style:italic}.botones-modal{display:flex;gap:.75rem}.btn-modal{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px;position:relative;overflow:hidden}.btn-modal:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.btn-modal:active:before{width:200%;height:200%}.btn-cancelar-modal{background:#6c757d;color:#fff;border:2px solid transparent}.btn-cancelar-modal:hover{background:#5a6268;transform:translateY(-1px);box-shadow:0 4px 12px #6c757d4d}.btn-guardar-modal{background:linear-gradient(135deg,#de007e,#b8005a);color:#fff;border:2px solid transparent;box-shadow:0 2px 8px #de007e33}.btn-guardar-modal:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #de007e4d,0 2px 8px #0000001a}.btn-guardar-modal:disabled{background:#ccc;color:#999;cursor:not-allowed;transform:none;box-shadow:none}.spinner-btn{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.modal-edicion{max-width:90vw;margin:1rem}.modal-header{padding:1rem 1.5rem}.modal-contenido{padding:1.5rem;gap:1.25rem}.controles-formato{grid-template-columns:1fr;gap:1rem}.modal-footer{padding:1rem 1.5rem;flex-direction:column;align-items:stretch;gap:.75rem}.atajos-hint{text-align:center}.botones-modal{justify-content:center}}@media (max-width: 480px){.modal-overlay{padding:.5rem}.modal-edicion{max-width:100%;max-height:95vh}.modal-header{padding:.75rem 1rem}.modal-titulo{font-size:1rem}.modal-contenido{padding:1rem;gap:1rem}.textarea-modal{min-height:80px;padding:.75rem}.textarea-modal.caveat-text{font-size:16px}.modal-footer{padding:.75rem 1rem}.btn-modal{padding:.625rem 1rem;font-size:.8rem;min-width:80px}.botones-modal{gap:.5rem}.atajos-hint{display:none}}@media (prefers-color-scheme: dark){.modal-edicion{background:#2d2d2d;border-color:#de007e33}.modal-contenido,.textarea-container label,.control-item label,.vista-previa label{color:#e0e0e0}.textarea-modal{background:#3a3a3a;border-color:#555;color:#e0e0e0}.textarea-modal:focus{background:#444;border-color:#de007e}.preview-text{background:#3a3a3a;border-color:#555;color:#000!important}.modal-footer{background:#3a3a3a;border-top-color:#555}.atajos-hint{color:#bbb}.unit-display{background:#de007e33;color:#f0b7d1}}.panel-herramientas-flotante{position:fixed;top:50%;right:20px;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:800;-webkit-user-select:none;user-select:none;transition:all .3s ease}.panel-herramientas-flotante.colapsado .herramienta-label,.panel-herramientas-flotante.colapsado .herramienta-shortcut{display:none!important}.panel-herramientas-flotante.colapsado .herramienta-btn-flotante{min-width:48px!important;width:48px!important;justify-content:center!important;padding:12px!important;gap:0!important}.panel-herramientas-flotante.colapsado .herramientas-container{min-width:48px;padding:8px}.panel-herramientas-flotante.colapsado .boton-colapsar{min-width:48px;width:48px;padding:12px}.herramienta-activa-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;box-shadow:0 2px 8px #00000026;border:1px solid rgba(222,0,126,.1);font-size:.875rem;font-weight:500;color:#333;min-width:140px;justify-content:center;transition:all .2s ease}.indicator-dot{width:8px;height:8px;background:#de007e;border-radius:50%;box-shadow:0 0 8px #de007e66;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.indicator-text{color:#333;font-weight:600}.herramientas-container{display:flex;flex-direction:column;gap:8px;padding:12px;background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:16px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.herramientas-container:hover{transform:translate(-2px);box-shadow:0 12px 40px #00000026,0 4px 12px #0000001a}.boton-colapsar{display:flex;align-items:center;justify-content:center;padding:8px;background:#f8f9fa;border:1px solid rgba(222,0,126,.1);border-radius:8px;cursor:pointer;transition:all .2s ease;color:#666;min-height:36px}.boton-colapsar:hover{background:#f0b7d1;border-color:#de007e;color:#b8005a;transform:translateY(-1px);box-shadow:0 2px 8px #de007e26}.boton-colapsar:active{transform:translateY(0);transition:transform .1s ease}.icono-colapsar{transition:transform .2s ease}.icono-colapsar.expandir{transform:rotate(0)}.icono-colapsar.colapsar{transform:rotate(180deg)}.separador-herramientas{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(222,0,126,.2) 50%,transparent 100%);margin:4px 0}.herramienta-btn-flotante{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .2s ease;color:#333;font-size:.875rem;font-weight:500;min-width:160px;position:relative;overflow:hidden}.herramienta-btn-flotante:hover{background:#f0b7d1;border-color:#de007e;transform:translateY(-1px);box-shadow:0 4px 12px #de007e33,0 2px 4px #0000001a}.herramienta-btn-flotante:hover svg{transform:scale(1.1);color:#b8005a}.herramienta-btn-flotante:hover .herramienta-label{color:#b8005a;font-weight:600}.herramienta-btn-flotante.activo{background:linear-gradient(135deg,#de007e,#b8005a);border-color:#b8005a;color:#fff;box-shadow:0 6px 20px #de007e4d,0 2px 8px #0000001a;transform:translateY(-2px)}.herramienta-btn-flotante.activo:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 0%,transparent 50%,rgba(255,255,255,.1) 100%);pointer-events:none}.herramienta-btn-flotante.activo .herramienta-label,.herramienta-btn-flotante.activo .herramienta-shortcut{color:#fff;font-weight:600}.herramienta-btn-flotante.activo svg{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.herramienta-btn-flotante:active{transform:translateY(0);transition:transform .1s ease}.herramienta-label{flex:1;text-align:left;transition:all .2s ease}.herramienta-shortcut{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#0000000d;border-radius:6px;font-size:.75rem;font-weight:600;color:#666;transition:all .2s ease}.herramienta-btn-flotante:hover .herramienta-shortcut{background:#de007e1a;color:#b8005a}.herramienta-btn-flotante.activo .herramienta-shortcut{background:#fff3;color:#fff}.atajos-info-flotante{position:absolute;right:100%;top:50%;transform:translateY(-50%);margin-right:12px;padding:12px 16px;background:#000000e6;color:#fff;border-radius:8px;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.panel-herramientas-flotante:hover .atajos-info-flotante{opacity:1;visibility:visible;transform:translateY(-50%) translate(-4px)}.atajos-titulo{font-weight:600;margin-bottom:4px;color:#f0b7d1}.atajo-item{font-family:Courier New,monospace;opacity:.9;line-height:1.4}@media (max-width: 768px){.panel-herramientas-flotante{position:fixed;top:50%;right:15px;transform:translateY(-50%);flex-direction:column;gap:8px;z-index:800}.herramienta-activa-indicator,.boton-colapsar,.separador-herramientas{display:none}.panel-herramientas-flotante.colapsado .herramienta-label{display:block!important}.panel-herramientas-flotante.colapsado .herramienta-shortcut{display:flex!important}.panel-herramientas-flotante.colapsado .herramienta-btn-flotante{min-width:140px!important;width:auto!important;justify-content:flex-start!important;padding:12px 14px!important;gap:12px!important}.panel-herramientas-flotante.colapsado .herramientas-container{padding:10px}.herramientas-container{padding:10px;border-radius:20px;gap:6px}.herramienta-btn-flotante{min-width:140px;padding:12px 14px;border-radius:16px;font-size:.8rem}.herramienta-shortcut{width:20px;height:20px;font-size:.7rem}.atajos-info-flotante{display:none}}@media (max-width: 480px){.panel-herramientas-flotante{position:fixed;top:50%;right:10px;transform:translateY(-50%);z-index:800}.herramienta-activa-indicator,.boton-colapsar,.separador-herramientas{display:none}.panel-herramientas-flotante .herramienta-label,.panel-herramientas-flotante .herramienta-shortcut,.panel-herramientas-flotante.colapsado .herramienta-label,.panel-herramientas-flotante.colapsado .herramienta-shortcut{display:none!important}.panel-herramientas-flotante .herramienta-btn-flotante,.panel-herramientas-flotante.colapsado .herramienta-btn-flotante{min-width:48px!important;width:48px!important;height:48px!important;padding:0!important;justify-content:center!important;border-radius:14px;gap:0!important}.herramientas-container{padding:8px;gap:6px;border-radius:16px}.atajos-info-flotante{display:none}.herramienta-btn-flotante svg{width:22px;height:22px}}@media (max-width: 360px){.panel-herramientas-flotante{right:8px}.herramienta-btn-flotante{width:44px;height:44px;min-width:44px;border-radius:12px}.herramienta-btn-flotante svg{width:20px;height:20px}}@keyframes panelFadeIn{0%{opacity:0;transform:translateY(-50%) translate(20px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.panel-herramientas-flotante{animation:panelFadeIn .5s ease-out}.herramienta-btn-flotante:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease;pointer-events:none}.herramienta-btn-flotante:active:after{width:120%;height:120%}@media (prefers-color-scheme: dark){.herramienta-activa-indicator{background:#1e1e1ef2;border-color:#de007e33;color:#e0e0e0}.herramientas-container{background:#1e1e1ef2;border-color:#ffffff1a}.herramienta-btn-flotante{background:#282828cc;color:#e0e0e0}.herramienta-btn-flotante:hover{background:#de007e33}.indicator-text{color:#e0e0e0}.herramienta-shortcut{background:#ffffff1a;color:#e0e0e0}.boton-colapsar{background:#282828cc;border-color:#de007e33;color:#e0e0e0}.boton-colapsar:hover{background:#de007e33;border-color:#de007e;color:#f0b7d1}.separador-herramientas{background:linear-gradient(90deg,transparent 0%,rgba(222,0,126,.3) 50%,transparent 100%)}}.barra-inferior{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:1rem;padding:8px 1.5rem;background:#000000d9;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 20px #0000004d,0 -1px 4px #0003;z-index:900;transition:all .3s ease;flex-wrap:wrap;min-height:50px}.barra-inferior:hover{background:#000000e6;box-shadow:0 -6px 25px #0006,0 -2px 8px #0000004d}.grupo-controles{display:flex;align-items:center;gap:.5rem;padding:0 .75rem;position:relative}.grupo-controles:after{content:"";position:absolute;right:-.5rem;top:25%;bottom:25%;width:1px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.2),transparent)}.grupo-controles:last-child:after{display:none}.barra-inferior button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s ease;color:#fff;position:relative;overflow:hidden}.barra-inferior button:hover{background:#fff3;border-color:#fff6;transform:translateY(-1px);box-shadow:0 4px 12px #ffffff1a}.barra-inferior button:active{transform:translateY(0);background:#ffffff4d}.barra-inferior button:disabled{opacity:.4;cursor:not-allowed;transform:none!important;background:#ffffff0d!important}.barra-inferior button.activo{background:linear-gradient(135deg,#de007e,#b8005a);border-color:#de007e;box-shadow:0 0 20px #de007e4d,0 2px 8px #0003}.barra-inferior button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.barra-inferior button:active:before{width:100%;height:100%}.navegacion{gap:.5rem}.navegacion button{width:44px;height:44px}.navegacion button:first-child,.navegacion button:last-child{width:36px;height:36px;opacity:.8}.navegacion button:first-child:hover,.navegacion button:last-child:hover{opacity:1}.pagina-info{display:flex;align-items:center;gap:.25rem;padding:0 .75rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease;min-width:auto}.pagina-info:hover{background:#ffffff26;border-color:#ffffff4d}.input-pagina{width:32px;background:transparent;border:none;color:#fff;text-align:center;font-size:.85rem;font-weight:600;outline:none;padding:.25rem;border-radius:4px;transition:background .2s ease}.input-pagina:focus{background:#ffffff1a}.input-pagina::-webkit-outer-spin-button,.input-pagina::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.input-pagina[type=number]{-moz-appearance:textfield}.separador-pagina{color:#fff9;font-weight:500;font-size:.85rem}.total-paginas{color:#fffc;font-weight:500;font-size:.85rem}.zoom{gap:.5rem}.zoom-info{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.5rem 1rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative}.zoom-info:hover{background:#ffffff26;border-color:#ffffff4d}.porcentaje-zoom{color:#fff;font-weight:600;font-size:.875rem;min-width:40px;text-align:center;display:inline-block}.select-zoom{background:#000000e6;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.25rem .5rem;font-size:.875rem;outline:none;cursor:pointer}.select-zoom option{background:#000000f2;color:#fff}.vista button{width:36px;height:36px;border-radius:6px}.adicionales button{width:36px;height:36px;opacity:.8;border-radius:6px}.adicionales button:hover{opacity:1}.adicionales button:disabled{opacity:.3}.separador-vertical{width:1px;height:20px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.3),transparent);margin:0 .25rem}@media (max-width: 768px){.barra-inferior{padding:8px .75rem;gap:.5rem}.grupo-controles{gap:.25rem;padding:0 .25rem}.barra-inferior button{width:34px;height:34px}.navegacion button{width:38px;height:38px}.navegacion button:first-child,.navegacion button:last-child{width:30px;height:30px}.separador-vertical{height:18px;margin:0 .15rem}.info-adicional{display:none}}@media (max-width: 480px){.barra-inferior{padding:6px .5rem;gap:.25rem;flex-wrap:nowrap;justify-content:space-between;min-height:45px}.grupo-controles{gap:.15rem;padding:0 .15rem}.grupo-controles:after{display:none}.barra-inferior button{width:30px;height:30px;border-radius:5px}.navegacion{gap:.15rem}.navegacion button{width:34px;height:34px}.navegacion button:first-child,.navegacion button:last-child{width:26px;height:26px}.pagina-info{padding:0 .4rem}.input-pagina{width:28px;font-size:.75rem;padding:.15rem}.zoom{gap:.15rem}.zoom-info{padding:.2rem .4rem}.porcentaje-zoom{font-size:.75rem;min-width:28px}.separador-vertical{display:none}.vista,.adicionales{gap:.15rem}@media (max-width: 360px){.barra-inferior{padding:5px .4rem;gap:.2rem;min-height:40px}.grupo-controles{gap:.1rem;padding:0 .1rem}.barra-inferior button{width:28px;height:28px}.navegacion button{width:32px;height:32px}.navegacion button:first-child,.navegacion button:last-child{width:24px;height:24px}.input-pagina{width:24px;font-size:.7rem}.porcentaje-zoom{font-size:.7rem;min-width:24px}.adicionales button:nth-child(n+3){display:none}.vista button:nth-child(3){display:none}}}@keyframes barraSlideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.barra-inferior{animation:barraSlideUp .4s ease-out}.barra-inferior.cargando:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#de007e,transparent);animation:loadingBar 2s ease-in-out infinite}@keyframes loadingBar{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (prefers-color-scheme: dark){.barra-inferior{background:#000000f2;border-top-color:#ffffff26}.barra-inferior:hover{background:#000000fa}.barra-inferior button{background:#ffffff14;border-color:#ffffff26}.barra-inferior button:hover{background:#ffffff26;border-color:#ffffff4d}}:root{--color-primary: #de007e;--color-primary-light: #f0b7d1;--color-primary-dark: #b8005a;--color-secondary: #23201d;--color-background: #f7f7f7;--color-white: #ffffff;--color-text: #333333;--color-text-light: #666666;--color-border: #e0e0e0;--color-error: #dc3545;--color-success: #28a745;--color-warning: #ffc107;--shadow-light: 0 1px 3px rgba(0, 0, 0, .1);--shadow-medium: 0 2px 8px rgba(0, 0, 0, .15);--shadow-strong: 0 4px 20px rgba(0, 0, 0, .25);--border-radius: 8px;--border-radius-small: 4px;--transition-fast: .2s ease;--transition-medium: .3s ease;--font-caveat: "Caveat", cursive}.caveat-text{font-family:var(--font-caveat);font-optical-sizing:auto;font-weight:500;font-style:normal}.caveat-light{font-weight:400}.caveat-medium{font-weight:500}.caveat-semi-bold{font-weight:600}.caveat-bold{font-weight:700}.lector-pdf{display:flex;flex-direction:column;height:100vh;background-color:var(--color-background);position:relative;overflow:hidden}.visor-container{flex:1;position:relative;display:flex;justify-content:center;align-items:flex-start;padding:1rem;padding-bottom:80px;overflow:auto;background-color:#f0f0f0;background-image:radial-gradient(circle,#ccc 1px,transparent 1px);background-size:20px 20px}.visor-pdf-wrapper{position:relative;display:inline-block}.visor-pdf{position:relative;z-index:1;display:inline-block}.capa-anotaciones{position:absolute;top:0;left:0;z-index:100;cursor:default;pointer-events:auto;transform-origin:top left}.capa-anotaciones.texto{cursor:crosshair}.cursor-texto-indicador{position:absolute;top:10px;left:10px;background-color:var(--color-primary);color:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.875rem;font-weight:500;box-shadow:var(--shadow-medium);z-index:1001;pointer-events:none;animation:fadeInOut 2s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.7}50%{opacity:1}}.overlay-arrastrando{position:absolute;top:0;left:0;width:100%;height:100%;z-index:999;pointer-events:none}.indicador-posicion{position:absolute;width:4px;height:4px;background-color:var(--color-primary);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px var(--color-primary)}.anotacion-wrapper{transition:var(--transition-fast);pointer-events:auto}.anotacion-wrapper.seleccionada{z-index:1000!important}.anotacion-texto{width:100%;height:100%;position:relative;transition:var(--transition-fast);pointer-events:auto;font-family:var(--font-caveat)}.anotacion-texto.seleccionada{z-index:1001}.anotacion-texto.editando{z-index:1002}.contenido-texto-caveat{font-family:var(--font-caveat);font-optical-sizing:auto;font-weight:500;font-style:normal;line-height:1.3;letter-spacing:.5px}.editor-inline{position:relative;width:100%;height:100%}.controles-inline{position:absolute;top:-35px;right:0;display:flex;gap:4px;background:#fffffff2;border-radius:6px;padding:4px;box-shadow:0 2px 8px #00000026;border:1px solid rgba(222,0,126,.2);z-index:1005;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.btn-guardar-inline,.btn-cancelar-inline{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:700}.btn-guardar-inline{background:#28a745;color:#fff}.btn-guardar-inline:hover:not(:disabled){background:#218838;transform:scale(1.05)}.btn-guardar-inline:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.btn-cancelar-inline{background:#dc3545;color:#fff}.btn-cancelar-inline:hover{background:#c82333;transform:scale(1.05)}.controles-seleccion{position:absolute;top:-35px;right:0;display:flex;gap:4px;background-color:#fffffff2;border:1px solid #de007e;border-radius:6px;padding:4px;box-shadow:0 2px 8px #de007e26;z-index:1004;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.btn-editar,.btn-eliminar{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;cursor:pointer;transition:all .2s ease}.btn-editar{background-color:#de007e;color:#fff}.btn-editar:hover{background-color:#b8005a;transform:scale(1.05)}.btn-eliminar{background-color:#dc3545;color:#fff}.btn-eliminar:hover{background-color:#c82333;transform:scale(1.05)}.indicador-doble-click{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);font-size:10px;color:#666;background-color:#000c;color:#fff;padding:2px 6px;border-radius:3px;white-space:nowrap;z-index:1005;opacity:0;transition:opacity .3s ease}.anotacion-texto.seleccionada .indicador-doble-click{opacity:1}.anotacion-texto:hover:not(.editando){transform:scale(1.02);box-shadow:0 2px 12px #de007e33!important}.anotacion-texto.editando{background-color:#de007e1a!important;border-color:#de007e!important;box-shadow:0 0 0 2px #de007e33!important}.anotacion-texto.seleccionada:not(.editando){border-color:#de007e!important;box-shadow:0 2px 12px #de007e4d!important}.lector-cargando,.lector-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;text-align:center;padding:2rem}.lector-cargando .spinner,.spinner-pdf,.spinner-pagina{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.spinner-mini{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lector-error h3{color:var(--color-error);margin-bottom:.5rem}.lector-error button{margin-top:1rem;padding:.5rem 1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius-small);cursor:pointer;transition:var(--transition-fast)}.lector-error button:hover{background-color:var(--color-primary-dark)}.contenedor-paginas{display:flex;align-items:flex-start;gap:1rem;position:relative}.vista-una{display:flex;justify-content:center}.vista-doble{display:flex;gap:1rem;align-items:flex-start}.vista-continua{display:flex;flex-direction:column;gap:1rem;align-items:center}.pagina-izquierda,.pagina-derecha,.pagina-continua{box-shadow:var(--shadow-medium);border-radius:var(--border-radius-small);overflow:hidden;background-color:var(--color-white);position:relative}.cargando-pagina{display:flex;align-items:center;justify-content:center;min-height:200px;background-color:var(--color-white);color:var(--color-text-light)}.overlay-carga{position:absolute;inset:0;background-color:#fffc;display:flex;align-items:center;justify-content:center;z-index:1000}.cargando-documento{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem}.error-pdf{display:flex;align-items:center;justify-content:center;min-height:400px;background-color:var(--color-white);border-radius:var(--border-radius);border:2px dashed var(--color-error)}.error-contenido{text-align:center;padding:2rem}@media (max-width: 768px){.visor-container{padding:.75rem;padding-bottom:100px}.en-lector-pdf .visor-container{padding-top:80px;padding-bottom:100px}}@media (max-width: 480px){.visor-container{padding:.5rem;padding-bottom:120px}.en-lector-pdf .visor-container{padding-top:70px;padding-bottom:120px}}@media (hover: hover) and (pointer: fine){.anotacion-texto:hover{box-shadow:0 2px 8px #de007e33}}@media (prefers-color-scheme: dark){:root{--color-background: #1a1a1a;--color-white: #2d2d2d;--color-text: #e0e0e0;--color-text-light: #b0b0b0;--color-border: #404040}.visor-container{background-color:#202020;background-image:radial-gradient(circle,#404040 1px,transparent 1px)}}.contenido-texto-caveat,.anotacion-texto .contenido-texto{font-family:Caveat,cursive!important;font-optical-sizing:auto;font-style:normal;letter-spacing:.5px}.anotacion-texto.guardada{background-color:transparent!important;border:1px solid transparent!important;box-shadow:none!important}.anotacion-texto.guardada:hover{background-color:#de007e0d!important;border:1px solid rgba(222,0,126,.2)!important;box-shadow:0 1px 6px #de007e1a!important}.anotacion-texto.guardada.seleccionada{background-color:#de007e14!important;border:1px solid rgba(222,0,126,.3)!important;box-shadow:0 2px 8px #de007e26!important}.textarea-modal{font-family:Caveat,cursive!important;font-optical-sizing:auto;font-weight:500;font-style:normal;font-size:18px!important;letter-spacing:.5px;line-height:1.4!important}.preview-text{font-family:Caveat,cursive!important;font-optical-sizing:auto;font-style:normal;letter-spacing:.5px;line-height:1.3!important}@media (max-width: 480px){.visor-pdf-wrapper{max-width:none!important;min-width:fit-content}.react-pdf__Document,.react-pdf__Page,.react-pdf__Page__canvas{max-width:none!important}.visor-container{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.visor-container:has(.react-pdf__Page__canvas[width]){justify-content:flex-start}}.capa-anotaciones.arrastrando{touch-action:none!important;user-select:none!important;-webkit-user-select:none!important;-webkit-touch-callout:none!important}@media (max-width: 768px){.visor-container:has(.capa-anotaciones.arrastrando){overflow:hidden!important;touch-action:none!important}.visor-pdf-wrapper:has(.capa-anotaciones.arrastrando){touch-action:none!important}}.overlay-arrastrando{position:absolute;top:0;left:0;width:100%;height:100%;z-index:999;pointer-events:none;background:#de007e05}.indicador-posicion{position:absolute;width:6px;height:6px;background-color:var(--color-primary);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px var(--color-primary),0 0 20px #de007e4d;animation:pulseIndicador 1s ease-in-out infinite}@keyframes pulseIndicador{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.2)}}.anotacion-wrapper.siendo-arrastrada{opacity:.8;transform:scale(1.02);box-shadow:0 8px 25px #de007e4d!important;z-index:1001!important}@media (max-width: 768px){.capa-anotaciones.arrastrando *{user-select:none!important;-webkit-user-select:none!important;-webkit-touch-callout:none!important}.capa-anotaciones.arrastrando{touch-action:none!important}}.debug-arrastre{position:fixed;top:60px;left:10px;background:#000c;color:#fff;padding:8px;font-size:11px;border-radius:4px;font-family:monospace;z-index:10001}@media (max-width: 768px){.anotacion-wrapper{cursor:pointer}.anotacion-wrapper.puede-arrastrar{cursor:grab}.anotacion-wrapper.arrastrando{cursor:grabbing}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-edicion{background:#fff;border-radius:12px;padding:0;width:90%;max-width:500px;max-height:90vh;overflow:hidden;box-shadow:0 20px 40px #0000004d;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#de007e,#b8005a);color:#fff}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600}.modal-header button{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s ease}.modal-header button:hover{background:#fff3}.modal-contenido{padding:24px;max-height:60vh;overflow-y:auto}.grupo-control{margin-bottom:20px}.grupo-control:last-child{margin-bottom:0}.grupo-control label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:.9rem}.textarea-modal{width:100%;min-height:100px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-family:Caveat,cursive!important;font-optical-sizing:auto;font-weight:500;font-style:normal;font-size:18px!important;letter-spacing:.5px;line-height:1.4!important;resize:vertical;transition:border-color .2s ease;outline:none}.textarea-modal:focus{border-color:#de007e;box-shadow:0 0 0 3px #de007e1a}.selector-color{display:flex;align-items:center;gap:12px;padding:8px;border:1px solid #e0e0e0;border-radius:8px;background:#f8f9fa}.selector-color input[type=color]{width:50px;height:40px;border:none;border-radius:6px;cursor:pointer;outline:none}.valor-color{font-family:Courier New,monospace;font-size:.9rem;color:#666;background:#fff;padding:4px 8px;border-radius:4px;border:1px solid #ddd}.grupo-control input[type=range]{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none}.grupo-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#de007e;cursor:pointer;box-shadow:0 2px 4px #0003}.grupo-control input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#de007e;cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.preview-text{font-family:Caveat,cursive!important;font-optical-sizing:auto;font-style:normal;letter-spacing:.5px;line-height:1.3!important;border:1px solid #ddd;padding:12px;border-radius:8px;background-color:#f9f9f9;min-height:50px;word-wrap:break-word;color:inherit!important}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0;background:#f8f9fa}.btn-cancelar,.btn-guardar{padding:10px 20px;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.9rem}.btn-cancelar{background:#6c757d;color:#fff}.btn-cancelar:hover{background:#5a6268;transform:translateY(-1px)}.btn-guardar{background:#de007e;color:#fff}.btn-guardar:hover:not(:disabled){background:#b8005a;transform:translateY(-1px);box-shadow:0 4px 12px #de007e4d}.btn-guardar:disabled{background:#ccc;cursor:not-allowed;transform:none}@media (max-width: 480px){.modal-edicion{width:95%;margin:10px}.modal-header{padding:16px 20px}.modal-contenido{padding:20px}.modal-footer{padding:16px 20px;flex-direction:column}.btn-cancelar,.btn-guardar{width:100%;padding:12px}.textarea-modal{font-size:16px!important}}.anotacion-texto .contenido-texto-caveat,.anotacion-texto .contenido-texto,.editor-inline textarea{color:inherit!important}.anotacion-texto[data-color]{color:var(--texto-color, #000000)}.anotacion-texto *,.anotacion-texto.guardada .contenido-texto-caveat{color:inherit!important}.progress-bar-container{display:flex;flex-direction:column;gap:16px;width:100%;height:100%;min-height:120px;justify-content:center}.progress-label{font-size:16px;font-weight:700;color:#374151;margin-bottom:8px;display:flex;align-items:center;gap:8px}.progress-label svg{width:20px;height:20px;flex-shrink:0}.progress-bar{width:100%;height:24px;background-color:#f3f4f6;border-radius:12px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.progress-fill{height:100%;border-radius:12px;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative;background:linear-gradient(90deg,var(--fill-color, #3db54a) 0%,var(--fill-color-light, #8cc63f) 100%);box-shadow:0 2px 8px rgba(var(--shadow-color, 61, 181, 74),.4)}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2.5s infinite}.progress-fill:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 50%,rgba(0,0,0,.1) 100%);border-radius:12px}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-percent{font-size:18px;font-weight:800;color:#1f2937;text-align:center;min-width:45px;margin-top:8px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.progress-bar-container[data-type=lectura] .progress-fill{--fill-color: #3db54a;--fill-color-light: #8cc63f;--shadow-color: 61, 181, 74}.progress-bar-container[data-type=lectura] .progress-label{color:#3db54a}.progress-bar-container[data-type=notas] .progress-fill{--fill-color: #8cc63f;--fill-color-light: #3db54a;--shadow-color: 140, 198, 63}.progress-bar-container[data-type=notas] .progress-label{color:#8cc63f}.progress-bar-container[data-type=tiempo] .progress-fill{--fill-color: #e73180;--fill-color-light: #f472b6;--shadow-color: 231, 49, 128}.progress-bar-container[data-type=tiempo] .progress-label{color:#e73180}.progress-bar-container[data-progress=low] .progress-fill{--fill-color: #ef4444;--fill-color-light: #f87171;--shadow-color: 239, 68, 68;animation:pulse-red 2s infinite}.progress-bar-container[data-progress=medium] .progress-fill{--fill-color: #f59e0b;--fill-color-light: #fbbf24;--shadow-color: 245, 158, 11;animation:pulse-yellow 2s infinite}.progress-bar-container[data-progress=high] .progress-fill{--fill-color: #10b981;--fill-color-light: #34d399;--shadow-color: 16, 185, 129;animation:pulse-green 2s infinite}@keyframes pulse-red{0%,to{box-shadow:0 2px 8px #ef444466}50%{box-shadow:0 4px 16px #ef444499}}@keyframes pulse-yellow{0%,to{box-shadow:0 2px 8px #f59e0b66}50%{box-shadow:0 4px 16px #f59e0b99}}@keyframes pulse-green{0%,to{box-shadow:0 2px 8px #10b98166}50%{box-shadow:0 4px 16px #10b98199}}.progress-bar-container.vertical{flex-direction:row;align-items:center;height:80px;min-height:auto}.progress-bar-container.vertical .progress-bar{width:12px;height:100%;margin:0 16px}.progress-bar-container.vertical .progress-fill{width:100%;height:var(--fill-height, 0%);position:absolute;bottom:0;background:linear-gradient(0deg,var(--fill-color, #3db54a) 0%,var(--fill-color-light, #8cc63f) 100%)}.progress-bar-container.vertical .progress-percent{text-align:left;margin-top:0;margin-left:8px}@media (max-width: 768px){.progress-label{font-size:16px}.progress-label svg{width:24px;height:24px}.progress-bar{height:32px}.progress-percent{font-size:3rem}.progress-bar-container.vertical{height:70px}.progress-bar-container.vertical .progress-bar{width:10px}}@media (max-width: 480px){.progress-bar-container{gap:16px;min-height:140px}.progress-label{font-size:15px}.progress-label svg{width:22px;height:22px}.progress-bar{height:28px}.progress-percent{font-size:2.5rem;margin-top:12px}.progress-bar-container.vertical{height:60px}.progress-bar-container.vertical .progress-bar{width:8px;margin:0 12px}}.dashboard-admin{padding:20px 0;display:grid;gap:24px}.dashboard-header{display:grid;gap:8px}.dashboard-header h1{font-size:2rem;color:#222;margin:0}.dashboard-subtitle{color:#666;font-size:1rem;margin:0}.dashboard-loading{display:grid;place-items:center;gap:16px;min-height:400px;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #e73180;border-radius:50%;animation:spin 1s linear infinite}.dashboard-grid{display:grid;grid-template-columns:1fr 400px;grid-template-rows:auto auto;gap:20px}.metrics-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;grid-column:1 / -1}.metric-card{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease}.metric-card:hover{box-shadow:0 8px 25px #00000014;transform:translateY(-2px)}.metric-icon{width:56px;height:56px;border-radius:12px;display:grid;place-items:center;color:#fff;font-size:24px;font-weight:600}.metric-icon svg{width:24px;height:24px}.users-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.books-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.sales-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.revenue-icon{background:linear-gradient(135deg,#43e97b,#38f9d7)}.metric-content{display:grid;gap:4px}.metric-label{font-size:.9rem;color:#666;font-weight:500}.metric-value{font-size:1.8rem;font-weight:700;color:#222}.chart-section{grid-row:2}.chart-card{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:20px;display:grid;gap:16px;height:fit-content}.chart-title{font-size:1.2rem;color:#333;margin:0;text-align:center}.chart-container{display:grid;place-items:center;padding:10px 0}.chart-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:12px;display:grid;gap:4px;text-align:center}.stat-label{font-size:.85rem;color:#666}.stat-value{font-size:1.1rem;font-weight:600;color:#222}.progress-section{grid-column:1;grid-row:2}.progress-card{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:20px;display:grid;gap:16px}.progress-title{font-size:1.2rem;color:#333;margin:0}.progress-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px}.progress-stat{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:10px;display:grid;gap:2px}.progress-stat span{font-size:.85rem;color:#666}.progress-stat strong{font-size:1rem;color:#222;font-weight:600}.quick-actions{grid-column:2;grid-row:2}.actions-card{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:20px;display:grid;gap:16px}.actions-title{font-size:1.2rem;color:#333;margin:0}.action-btn{display:flex;align-items:center;gap:10px;padding:12px 16px;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-decoration:none}.action-btn svg{width:16px;height:16px}.action-btn.primary{background:#e73180;color:#fff}.action-btn.primary:hover{background:#d91570;transform:translateY(-1px)}.action-btn.secondary{background:#f8f9fa;color:#495057;border:1px solid #dee2e6}.action-btn.secondary:hover{background:#e9ecef;transform:translateY(-1px)}.action-btn.tertiary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.tertiary:hover{filter:brightness(1.1);transform:translateY(-1px)}.progress-bar-container{display:flex;flex-direction:column;gap:6px;margin:12px 0;width:100%}.progress-label{font-size:.9rem;font-weight:600;color:#333}.progress-bar{width:100%;height:18px;background:#e9ecef;border-radius:10px;overflow:hidden}.progress-fill{height:100%;border-radius:10px;transition:width .4s ease}.progress-percent{font-size:.85rem;color:#666;font-weight:500}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr;gap:16px}.metrics-cards{grid-template-columns:repeat(2,1fr)}.chart-section,.progress-section,.quick-actions{grid-column:1;grid-row:auto}}@media (max-width: 768px){.dashboard-admin{padding:15px 0;gap:18px}.dashboard-header h1{font-size:1.6rem}.metrics-cards{grid-template-columns:1fr;gap:12px}.metric-card{padding:16px;gap:12px}.metric-icon{width:48px;height:48px}.metric-icon svg{width:20px;height:20px}.metric-value{font-size:1.5rem}.chart-card,.progress-card,.actions-card{padding:16px}.progress-stats,.chart-stats{grid-template-columns:1fr;gap:8px}}@media (max-width: 480px){.dashboard-admin{padding:10px 0}.dashboard-header h1{font-size:1.4rem}.dashboard-subtitle{font-size:.9rem}.metric-card{padding:12px;gap:10px}.metric-icon{width:40px;height:40px}.metric-value{font-size:1.3rem}.action-btn{padding:10px 12px;font-size:.9rem}}.usuarios-admin{padding:20px 0;display:flex;flex-direction:column;gap:0}.tabs-navigation{display:flex;gap:2px;background:#f8f9fa;border-radius:8px;padding:4px;overflow-x:auto;border:1px solid #e9ecef;margin-bottom:0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 16px;border:none;background:transparent;border-radius:6px;font-size:.9rem;font-weight:500;color:#6c757d;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:fit-content;min-height:44px;touch-action:manipulation}.tab-button svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.tab-content{display:flex;flex-direction:column;min-height:500px;height:auto;background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:0;box-sizing:border-box;margin-top:0}.tab-content.datos-tab{padding:0!important;gap:0!important;display:flex!important;flex-direction:column!important}.tab-content.datos-tab>*{margin:0!important;padding:0!important}.tab-content.datos-tab>*:not(.filtros-container):not(.table-container){display:none!important}.tab-content.datos-tab .filtros-container{order:1!important;margin:20px 20px 0!important;padding:0 0 16px!important;border-bottom:1px solid #e9ecef!important;flex-shrink:0!important}.tab-content.datos-tab .table-container{order:2!important;margin:0 20px 20px!important;padding:0!important;flex:1!important;min-height:0!important}.tab-content.datos-tab:before,.tab-content.datos-tab:after,.tab-content.datos-tab .filtros-container:before,.tab-content.datos-tab .filtros-container:after,.tab-content.datos-tab .table-container:before,.tab-content.datos-tab .table-container:after{display:none!important;content:none!important}.tab-content.datos-tab .filtros-container+.table-container{margin-top:0!important}.tab-content.actividad-tab,.tab-content.historial-tab{padding:20px;gap:16px}.tab-content.actividad-tab>*,.tab-content.historial-tab>*{margin:initial;padding:initial;display:initial}.filtros-container{display:flex;flex-direction:column;gap:12px;margin:20px 20px 0;padding:0 0 16px;border-bottom:1px solid #e9ecef}.filtros-top{display:flex;margin:0;padding:0}.filtros-top .filtro-input{flex:1;max-width:100%}.filtros-bottom{display:flex;gap:12px;flex-wrap:wrap;margin:0;padding:0;position:relative;overflow:visible}.filtros-bottom .filtro-select{min-width:160px;flex:1}.filtros-bottom .filtro-date{min-width:140px;flex:1}.filtros-row{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch;margin:0;padding:0}.filtro-input,.filtro-select,.filtro-date{padding:12px 16px;border:1px solid #ced4da;border-radius:8px;font-size:16px;transition:border-color .2s ease;background:#fff;width:100%;box-sizing:border-box;touch-action:manipulation;-webkit-appearance:none;appearance:none}.filtro-input:focus,.filtro-select:focus,.filtro-date:focus{outline:none;border-color:#e73180;box-shadow:0 0 0 3px #e731801a}.filtro-input{background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%236c757d" viewBox="0 0 16 16"><path d="M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0"/></svg>') no-repeat right 16px center;background-size:16px;padding-right:48px}.filtro-select{background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="%236c757d" viewBox="0 0 16 16"><path d="M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z"/></svg>') no-repeat right 16px center;background-size:12px;padding-right:48px}.table-container{flex:1;overflow:auto;border:1px solid #e9ecef;border-radius:8px;margin:0 20px 20px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.usuarios-table{width:100%;min-width:600px;border-collapse:collapse;background:#fff}.usuarios-table thead th{position:sticky;top:0;z-index:10;background:#f8f9fa;color:#495057;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;padding:16px 12px;text-align:left;border-bottom:2px solid #e9ecef;white-space:nowrap}.usuarios-table td{padding:16px 12px;border-bottom:1px solid #f1f3f4;font-size:.9rem;vertical-align:middle}.usuario-row{cursor:pointer;transition:background-color .2s ease;touch-action:manipulation}.usuario-row:hover,.usuario-row:active{background:#f8f9fa}.status-badge{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:inline-block;white-space:nowrap}.status-badge.pending{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.status-badge.downloaded{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}.actividad-usuario,.historial-usuario{display:grid;gap:20px;padding:0}.actividad-header,.historial-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:2px solid #e9ecef;gap:16px}.usuario-info-header h3{margin:0;color:#333;font-size:1.2rem;word-break:break-word}.usuario-info-header p{margin:4px 0 0;color:#666;font-size:.9rem;word-break:break-word}.btn-back{padding:12px 20px;background:#6c757d;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease;min-height:44px;touch-action:manipulation;white-space:nowrap;flex-shrink:0}.btn-back:hover,.btn-back:active{background:#5a6268}.actividad-empty,.historial-empty{display:grid;place-items:center;padding:60px 20px;text-align:center;color:#6c757d;font-size:1rem}.loading-container{display:grid;place-items:center;gap:16px;padding:40px;text-align:center;color:#6c757d}.no-libros,.no-compras{background:#f8f9fa;border:1px dashed #ced4da;border-radius:8px;padding:40px;text-align:center;color:#6c757d}.actividad-libros-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:24px}.actividad-libro-card{background:#fafafa;border-radius:16px;padding:20px;box-shadow:0 2px 10px #0000000d;transition:transform .2s ease,box-shadow .2s ease}.actividad-libro-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #0000001a}.libro-titulo{margin:0 0 16px;font-size:1.1rem;font-weight:600;color:#333;line-height:1.4;word-break:break-word}.barra-progreso{background:#e0e0e0;height:10px;border-radius:5px;overflow:hidden;margin:12px 0}.barra-progreso .relleno{background:linear-gradient(90deg,#0047ba,#0056d6);height:100%;transition:width .5s ease}.porcentaje{text-align:center;font-weight:600;color:#333;margin:12px 0;font-size:1rem}.actividad-kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:16px}.kpi{background:#f4f4f4;padding:16px 12px;border-radius:8px;text-align:center;transition:background .2s ease}.kpi:hover{background:#eee}.kpi span{display:block;font-size:.8rem;color:#555;margin-bottom:4px}.kpi strong{font-size:1.1rem;color:#222;font-weight:700}.historial-table{width:100%;min-width:500px;border-collapse:collapse;background:#fff}.historial-table th{background:#f8f9fa;color:#495057;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;padding:16px 12px;text-align:left;border-bottom:2px solid #e9ecef;white-space:nowrap}.historial-table td{padding:16px 12px;border-bottom:1px solid #f1f3f4;font-size:.9rem;vertical-align:middle}.table-loading,.table-empty{display:grid;place-items:center;gap:12px;padding:40px;text-align:center;color:#6c757d}@media (max-width: 1200px){.filtros-bottom{flex-direction:column;align-items:stretch}.filtros-bottom .filtro-select,.filtros-bottom .filtro-date{min-width:auto;width:100%}.filtros-bottom p{align-self:flex-start;margin-top:8px}.actividad-libros-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}}@media (max-width: 768px){.usuarios-admin{padding:12px 0}.page-header h1{font-size:1.5rem;line-height:1.3}.page-subtitle{font-size:.9rem}.tabs-navigation{padding:3px;gap:2px;margin:0 8px}.tab-button{padding:12px 16px;font-size:.85rem;gap:6px;min-height:48px}.tab-button svg{width:14px;height:14px}.tab-content{margin:0 8px;border-radius:8px}.tab-content.actividad-tab,.tab-content.historial-tab{padding:16px}.filtros-container{margin:16px 16px 0!important;padding:0 0 12px!important;gap:8px}.filtros-bottom{flex-direction:column;align-items:stretch;gap:8px}.filtros-bottom .filtro-select,.filtros-bottom .filtro-date{width:100%}.table-container{margin:0 16px 16px!important}.usuarios-table{min-width:500px}.usuarios-table th,.usuarios-table td{padding:12px 8px;font-size:.85rem}.actividad-header,.historial-header{flex-direction:column;align-items:flex-start;gap:12px}.btn-back{width:100%;justify-content:center;display:flex;align-items:center}.actividad-libros-grid{grid-template-columns:1fr;gap:12px}.actividad-libro-card{padding:16px}.actividad-kpis{grid-template-columns:1fr;gap:8px}.historial-table{min-width:400px}.historial-table th,.historial-table td{padding:12px 8px;font-size:.85rem}}@media (max-width: 480px){.usuarios-admin{padding:8px 0}.page-header h1{font-size:1.3rem}.tabs-navigation,.tab-content{margin:0 4px}.tab-content.actividad-tab,.tab-content.historial-tab{padding:12px}.filtros-container{margin:12px 12px 0!important;padding:0 0 8px!important}.table-container{margin:0 12px 12px!important}.filtro-input,.filtro-select,.filtro-date{padding:14px 16px;font-size:16px}.filtro-input,.filtro-select{padding-right:50px}.usuarios-table{min-width:350px}.usuarios-table th,.usuarios-table td{padding:10px 6px;font-size:.8rem}.usuarios-table th:nth-child(2),.usuarios-table td:nth-child(2),.usuarios-table th:nth-child(6),.usuarios-table td:nth-child(6){display:none}.actividad-libro-card{padding:12px}.libro-titulo{font-size:1rem}.kpi{padding:12px 8px}.kpi span{font-size:.75rem}.kpi strong{font-size:1rem}.historial-table{min-width:300px}.historial-table th:nth-child(4),.historial-table td:nth-child(4),.historial-table th:nth-child(5),.historial-table td:nth-child(5){display:none}}.table-container::-webkit-scrollbar{height:6px;width:6px}.table-container::-webkit-scrollbar-track{background:#f8f9fa;border-radius:3px}.table-container::-webkit-scrollbar-thumb{background:#ced4da;border-radius:3px}.table-container::-webkit-scrollbar-thumb:hover{background:#adb5bd}.tabs-navigation::-webkit-scrollbar{height:4px}.tabs-navigation::-webkit-scrollbar-track{background:transparent}.tabs-navigation::-webkit-scrollbar-thumb{background:#ced4da;border-radius:2px}.btn-back:focus-visible{outline:3px solid #6c757d;outline-offset:2px}.usuario-row:focus-visible{outline:3px solid #e73180;outline-offset:-2px}.tab-button:focus-visible{outline:3px solid #e73180;outline-offset:2px}@media (prefers-reduced-motion: reduce){.barra-progreso .relleno,.loading-spinner,.actividad-libro-card,.tab-button,.usuario-row,.btn-back{animation:none;transition:none}}@media (prefers-contrast: high){.tab-button.active{border:2px solid #fff}.status-badge,.table-container{border-width:2px}}.libros-admin{padding:20px 0;display:grid;gap:20px}.tabs-navigation{display:flex;gap:2px;background:#f8f9fa;border-radius:8px;padding:4px;overflow-x:auto;border:1px solid #e9ecef}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 16px;border:none;background:transparent;border-radius:6px;font-size:.9rem;font-weight:500;color:#6c757d;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:fit-content}.tab-button svg{width:16px;height:16px;fill:currentColor}.tab-button:hover{background:#e9ecef;color:#495057}.tab-button.active{background:#e73180;color:#fff}.tab-button.active:hover{background:#d91570}.tab-content{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:20px;min-height:400px}.lista-header,.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e9ecef}.lista-header h3,.form-header h3{font-size:1.3rem;color:#333;margin:0}.form-header{flex-direction:column;align-items:flex-start;gap:8px}.form-header p{color:#666;margin:0;font-size:.9rem}.btn-primary{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#e73180;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:#d91570;transform:translateY(-1px)}.btn-primary svg{width:16px;height:16px}.table-container{overflow-x:auto;border-radius:8px;border:1px solid #e9ecef}.libros-table{width:100%;border-collapse:collapse;background:#fff;min-width:800px}.libros-table th{background:#f8f9fa;color:#495057;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;text-align:left;border-bottom:2px solid #e9ecef}.libros-table td{padding:12px 16px;border-bottom:1px solid #f1f3f4;font-size:.9rem;vertical-align:top}.libro-row{cursor:pointer;transition:background-color .2s ease}.libro-row:hover{background:#f8f9fa}.portada-mini{width:40px;height:56px;border-radius:4px;overflow:hidden;background:#f1f3f4;display:grid;place-items:center}.portada-mini img{width:100%;height:100%;object-fit:cover}.portada-placeholder{width:100%;height:100%;display:grid;place-items:center;color:#6c757d}.portada-placeholder svg{width:20px;height:20px}.titulo-cell{max-width:200px}.titulo-cell div{display:grid;gap:4px}.titulo-cell strong{color:#333;font-size:.9rem;line-height:1.2}.titulo-cell small{color:#666;font-size:.8rem;line-height:1.2}.status-badge{padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-badge.inactive{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.acciones-cell{display:flex;gap:4px;justify-content:flex-start}.action-btn{width:30px;height:30px;border:none;border-radius:6px;display:grid;place-items:center;cursor:pointer;transition:all .2s ease}.action-btn svg{width:14px;height:14px}.action-btn.view{background:#e3f2fd;color:#1976d2}.action-btn.view:hover{background:#bbdefb}.action-btn.edit{background:#fff3e0;color:#f57c00}.action-btn.edit:hover{background:#ffe0b2}.action-btn.delete{background:#ffebee;color:#d32f2f}.action-btn.delete:hover{background:#ffcdd2}.libro-form{display:grid;gap:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.form-section{display:grid;gap:16px}.form-section h3{font-size:1.1rem;color:#333;margin:0;padding-bottom:8px;border-bottom:2px solid #e73180}.files-section{grid-column:1 / -1;background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.file-upload-container{display:grid;gap:8px}.file-upload-label{font-size:.9rem;font-weight:500;color:#495057}.file-upload-label.required:after{content:" *";color:#dc3545}.file-upload-area{position:relative;border:2px dashed #ced4da;border-radius:8px;transition:all .2s ease;background:#fff}.file-upload-area:hover{border-color:#e73180;background:#fefefe}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.file-upload-content{padding:20px;text-align:center;pointer-events:none}.file-placeholder{display:grid;gap:8px;place-items:center;color:#6c757d}.file-placeholder svg{width:32px;height:32px}.file-placeholder span{font-weight:500;font-size:.9rem}.file-placeholder small{font-size:.8rem;opacity:.8}.file-selected{display:flex;align-items:center;gap:12px;justify-content:center;color:#28a745}.file-selected svg{width:24px;height:24px}.file-selected span{font-weight:500;font-size:.9rem}.form-group{display:grid;gap:6px}.form-label{font-size:.9rem;font-weight:500;color:#495057}.form-label.required:after{content:" *";color:#dc3545}.form-input,.form-textarea,.form-select{padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease;background:#fff}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#e73180;box-shadow:0 0 0 3px #e731801a}.form-textarea{resize:vertical;font-family:inherit}.form-select{cursor:pointer;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="%23495057" viewBox="0 0 16 16"><path d="M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z"/></svg>');background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;appearance:none}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:20px;border-top:1px solid #e9ecef}.btn-secondary{padding:10px 16px;background:#f8f9fa;color:#495057;border:1px solid #ced4da;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:#e9ecef;border-color:#adb5bd}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.table-loading,.table-empty,.form-loading{display:grid;place-items:center;gap:12px;padding:40px;text-align:center;color:#6c757d}.loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #e73180;border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 1200px){.form-grid{grid-template-columns:1fr}.files-section{grid-column:1}}@media (max-width: 768px){.libros-admin{padding:15px 0}.page-header h1{font-size:1.5rem}.tabs-navigation{padding:2px;gap:1px}.tab-button{padding:10px 12px;font-size:.85rem;gap:6px}.tab-content{padding:16px}.lista-header,.form-header{flex-direction:column;align-items:flex-start;gap:12px}.form-section{gap:12px}.file-upload-content{padding:16px}.file-placeholder svg{width:28px;height:28px}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}.libros-table{font-size:.8rem}.libros-table th,.libros-table td{padding:8px 10px}.libros-table th:nth-child(1),.libros-table td:nth-child(1),.libros-table th:nth-child(7),.libros-table td:nth-child(7),.libros-table th:nth-child(9),.libros-table td:nth-child(9){display:none}.titulo-cell{max-width:150px}}@media (max-width: 480px){.libros-admin{padding:10px 0}.tab-content{padding:12px}.files-section{padding:16px}.file-upload-content{padding:12px}.form-grid{gap:16px}.form-section{gap:10px}.libros-table th:nth-child(4),.libros-table td:nth-child(4),.libros-table th:nth-child(5),.libros-table td:nth-child(5),.libros-table th:nth-child(6),.libros-table td:nth-child(6){display:none}.acciones-cell{gap:2px}.action-btn{width:26px;height:26px}.action-btn svg{width:12px;height:12px}}.table-container::-webkit-scrollbar{height:8px}.table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.table-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.mensaje-flotante{margin:16px auto;width:fit-content;max-width:90%;padding:12px 20px;border-radius:8px;font-weight:500;text-align:center;animation:fadeOut 4s forwards;box-shadow:0 2px 10px #0000001a}.mensaje-flotante.success{background-color:#d1f7dc;color:#1e4620;border:1px solid #a3e4af}.mensaje-flotante.error{background-color:#f8d7da;color:#842029;border:1px solid #f5c2c7}@keyframes fadeOut{0%{opacity:1}80%{opacity:1}to{opacity:0;display:none}}.ecommerce-admin{padding:20px 0;display:grid;gap:20px}.page-header{display:grid;gap:8px;margin-bottom:8px}.page-header h1{font-size:1.8rem;color:#222;margin:0}.page-subtitle{color:#666;font-size:.95rem;margin:0}.main-content{background:#fff;border:1px solid #e7e7e7;border-radius:12px;padding:24px;display:grid;gap:24px}.ecommerce-header{display:grid;gap:8px;margin-bottom:8px}.ecommerce-header h3{font-size:1.4rem;color:#333;margin:0}.ecommerce-header p{color:#666;margin:0;font-size:.95rem}.metricas-ventas{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:20px}.metrica-card{background:#fff;border:1px solid #e7e7e7;border-radius:16px;padding:24px;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 4px 8px #0000000a;min-height:120px}.metrica-card:hover{box-shadow:0 8px 25px #0000001f;transform:translateY(-2px);border-color:#e73180}.metrica-icon{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;color:#fff;font-size:24px;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #00000026}.metrica-icon svg{width:28px;height:28px}.ventas-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.ingresos-icon{background:linear-gradient(135deg,#43e97b,#38f9d7)}.transacciones-icon{background:linear-gradient(135deg,#fa709a,#fee140)}.comision-icon{background:linear-gradient(135deg,#a8edea,#fed6e3);color:#495057}.metrica-content{display:grid;gap:4px;flex-grow:1}.metrica-label{font-size:.9rem;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.metrica-value{font-size:2rem;font-weight:800;color:#222;line-height:1}.metricas-loading{display:grid;place-items:center;gap:12px;padding:40px;text-align:center;color:#6c757d}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #e73180;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.desarrollo-section{margin-top:20px}.desarrollo-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;display:flex;align-items:center;gap:16px;color:#fff;box-shadow:0 8px 25px #667eea40}.desarrollo-icon{width:60px;height:60px;background:#fff3;border-radius:12px;display:grid;place-items:center;flex-shrink:0}.desarrollo-icon svg{width:24px;height:24px;color:#fff}.desarrollo-content{display:grid;gap:8px}.desarrollo-content h4{font-size:1.2rem;margin:0;font-weight:600}.desarrollo-content p{margin:0;opacity:.9;line-height:1.5;font-size:.95rem}.metrica-card{animation:fadeInUp .6s ease-out}.metrica-card:nth-child(1){animation-delay:.1s}.metrica-card:nth-child(2){animation-delay:.2s}.metrica-card:nth-child(3){animation-delay:.3s}.metrica-card:nth-child(4){animation-delay:.4s}.desarrollo-card{animation:fadeInUp .6s ease-out .5s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1200px){.metricas-ventas{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.ecommerce-admin{padding:15px 0}.page-header h1{font-size:1.5rem}.main-content{padding:20px}.metricas-ventas{grid-template-columns:1fr;gap:16px}.metrica-card{padding:20px;gap:14px;min-height:100px}.metrica-icon{width:56px;height:56px}.metrica-icon svg{width:24px;height:24px}.metrica-value{font-size:1.6rem}.desarrollo-card{padding:20px;gap:14px}.desarrollo-icon{width:50px;height:50px}.desarrollo-content h4{font-size:1.1rem}.desarrollo-content p{font-size:.9rem}}@media (max-width: 480px){.ecommerce-admin{padding:10px 0}.main-content{padding:16px}.metricas-ventas{gap:12px}.metrica-card{padding:16px;gap:12px;min-height:90px}.metrica-icon{width:48px;height:48px;border-radius:12px}.metrica-icon svg{width:20px;height:20px}.metrica-value{font-size:1.4rem}.metrica-label{font-size:.8rem}.desarrollo-card{padding:16px;flex-direction:column;text-align:center}.desarrollo-icon{width:48px;height:48px}.desarrollo-content h4{font-size:1rem}.desarrollo-content p{font-size:.85rem}}.metrica-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#e73180,#667eea);border-radius:16px 16px 0 0;opacity:0;transition:opacity .3s ease}.metrica-card{position:relative}.metrica-card:hover:before{opacity:1}.metricas-loading .loading-spinner{animation-duration:.8s}.ventas-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.ingresos-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.transacciones-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.comision-icon{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff}.perfil-admin-container{max-width:1200px;margin:0 auto;padding:0 20px}.perfil-admin-container h1{margin-bottom:10px;color:#2c3e50;font-size:clamp(1.5rem,4vw,2.5rem);font-weight:700}.separador-admin{border:1px solid #e73180;margin-bottom:clamp(20px,5vw,30px)}.seccion-titulo-admin{color:#e73180;margin-bottom:12px;font-weight:600;font-size:clamp(1rem,2.5vw,1.2rem)}.fila-admin{display:flex;flex-direction:column;gap:clamp(20px,5vw,40px);margin-bottom:clamp(20px,5vw,40px)}.col-admin{width:100%;min-width:unset;background:#fff;padding:clamp(20px,4vw,30px);border-radius:12px;box-shadow:0 4px 6px #0000001a;border:1px solid #e1e8ed}.grupo-inputs-admin{display:flex;flex-direction:column;gap:clamp(12px,3vw,16px)}.input-admin{width:100%;max-width:450px;padding:clamp(12px,3vw,14px);border-radius:8px;border:2px solid #e1e8ed;font-size:clamp(.9rem,2vw,1rem);background:#f8f9fa;box-sizing:border-box;transition:all .3s ease;font-family:inherit}.input-admin:focus{border-color:#e73180;background:#fff;outline:none;box-shadow:0 0 0 3px #3498db1a}.btn-admin{background:linear-gradient(135deg,#e73180,#e73180);color:#fff;padding:clamp(12px,3vw,14px) clamp(24px,5vw,32px);width:100%;max-width:220px;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;font-size:clamp(.9rem,2vw,1rem);text-transform:uppercase;letter-spacing:.5px}.btn-admin:hover{background:linear-gradient(135deg,#2980b9,#1f618d);transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.btn-admin:active{transform:translateY(0)}.input-imagen-admin{width:100%;max-width:450px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px dashed #3498db;padding:clamp(20px,5vw,25px);text-align:center;border-radius:12px;font-size:clamp(.9rem,2vw,1rem);color:#2c3e50;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.input-imagen-admin:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,#3498db0d,#2980b90d);opacity:0;transition:opacity .3s ease;pointer-events:none}.input-imagen-admin:hover:before{opacity:1}.input-imagen-admin:hover{border-color:#2980b9;background:linear-gradient(135deg,#e9ecef,#dee2e6);transform:translateY(-1px)}.contenedor-imagen-perfil-admin{display:flex;justify-content:center;align-items:center;margin:clamp(15px,4vw,20px) 0}.foto-perfil-admin{width:clamp(100px,18vw,140px);height:clamp(100px,18vw,140px);object-fit:cover;border-radius:50%;border:3px solid #e73180;transition:all .3s ease;box-shadow:0 4px 12px #e7318033}.foto-perfil-admin:hover{border-color:#c91f6d;transform:scale(1.05);box-shadow:0 6px 20px #e731804d}.foto-placeholder-admin{width:clamp(100px,18vw,140px);height:clamp(100px,18vw,140px);background:linear-gradient(135deg,#ecf0f1,#bdc3c7);display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:clamp(1.8rem,5vw,2.5rem);color:#7f8c8d;border:3px solid #bdc3c7;transition:all .3s ease}.mensaje-admin{width:100%;max-width:450px;padding:clamp(10px,2.5vw,12px);margin-top:12px;border-radius:8px;text-align:center;font-weight:600;border:1px solid transparent;transition:all .3s ease-in-out;font-size:clamp(.85rem,2vw,.95rem);position:relative;overflow:hidden}.mensaje-admin:before{content:"";position:absolute;inset:0 0 0 -100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.mensaje-admin.exito{background:linear-gradient(135deg,#d5f4e6,#c3e9d0);color:#1e7e34;border-color:#28a745}.mensaje-admin.exito:before{background:linear-gradient(90deg,transparent,rgba(40,167,69,.2),transparent)}.mensaje-admin.error{background:linear-gradient(135deg,#f8d7da,#f1b0b7);color:#721c24;border-color:#dc3545}.mensaje-admin.error:before{background:linear-gradient(90deg,transparent,rgba(220,53,69,.2),transparent)}.mensaje-admin:hover:before{left:100%}@media (min-width: 600px){.grupo-inputs-admin{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,20px);align-items:end}.input-imagen-admin{grid-column:1 / -1}.btn-admin{grid-column:1 / -1;justify-self:start}}@media (min-width: 768px){.fila-admin{flex-direction:row;align-items:flex-start}.col-admin{flex:1;min-width:300px}.grupo-inputs-admin{grid-template-columns:1fr}.input-admin,.btn-admin{max-width:350px}}@media (min-width: 1000px){.fila-admin{gap:60px;margin-bottom:60px}.col-admin{padding:40px}.grupo-inputs-admin{gap:20px}.input-admin,.btn-admin{max-width:400px}}@media (min-width: 1200px){.perfil-admin-container{padding:0 40px}.fila-admin{gap:80px}.input-admin,.btn-admin{max-width:420px}.grupo-inputs-admin{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:end}.input-imagen-admin{grid-column:1 / -1}.btn-admin{grid-column:1 / -1;justify-self:start;max-width:250px}}@media (min-width: 1400px){.perfil-admin-container{max-width:1400px;padding:0 60px}.col-admin{padding:50px}}
