Preview de mixed.css
/* MIXED CSS PACK */
/* Template: hvpiscinas.com.ar/index.html */
/* Template mtime: 2025-11-05 17:13:53 */
/* external link (no embedded): https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap */
/* external link (no embedded): https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css */
/* external link (no embedded): https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css */
/* ===== INLINE <style> BLOCK #1 ===== */
:root {
--ink: #0f172a;
--muted: #64748b;
--line: #e5e7eb;
--bg: #ffffff;
--soft: #f8fafc;
--brand: #22C1F1;
--brand-dark: #0B84D9;
--brand-light: #ECF8FF;
--cta: #22C1F1;
--cta-dark: #0B84D9;
--cta-light: #E6F4FF;
--accent: #FFD54F;
--max: 1200px;
--radius: 16px;
--shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.12);
--transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
/* Prevent media overflow on small screens */
img, video, iframe { max-width: 100%; height: auto; }
* {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html {
scroll-behavior: smooth;
}
body {
font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
color: var(--ink);
background: var(--bg);
line-height: 1.6;
overflow-x: hidden;
}
a {
color: var(--brand);
text-decoration: none;
transition: var(--transition);
}
a:hover {
color: var(--brand-dark);
}
.container {
max-width: var(--max);
margin: 0 auto;
padding: 0 20px;
}
.btn {
display: inline-flex;
align-items: center;
gap: .5rem;
border: 1px solid transparent;
border-radius: 999px;
padding: .85rem 1.5rem;
font-weight: 600;
line-height: 1;
cursor: pointer;
transition: var(--transition);
position: relative;
overflow: hidden;
z-index: 1;
}
.btn::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 0%;
height: 100%;
background: rgba(255, 255, 255, 0.1);
transition: var(--transition);
z-index: -1;
}
.btn:hover::before {
width: 100%;
}
.btn-primary {
background: linear-gradient(135deg, var(--cta), #0ea171);
color: #fff;
box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(16, 185, 129, 0.4);
}
.btn-outline {
border-color: var(--brand);
color: var(--brand);
background: transparent;
}
.btn-outline:hover {
background: var(--brand-light);
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(14, 165, 233, 0.2);
}
.eyebrow {
font-size: .8rem;
letter-spacing: .12em;
text-transform: uppercase;
color: var(--muted);
font-weight: 700;
display: inline-block;
margin-bottom: 8px;
}
.section {
padding: 80px 0;
}
.section-soft {
background: linear-gradient(135deg, var(--soft) 0%, #f1f5f9 100%);
}
.section-title {
font-size: clamp(1.8rem, 4vw, 2.8rem);
line-height: 1.15;
margin: 8px 0 16px;
font-weight: 800;
background: linear-gradient(135deg, var(--ink) 0%, var(--brand-dark) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.lead {
font-size: clamp(1.1rem, 1.8vw, 1.25rem);
color: var(--ink);
opacity: 0.9;
}
.grid {
display: grid;
gap: 40px;
}
.grid-2 {
grid-template-columns: 1fr;
}
@media (min-width: 900px) {
.grid-2 {
grid-template-columns: 1.1fr .9fr;
}
}
/* Navbar */
.nav {
position: sticky;
top: 0;
z-index: 100;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
border-bottom: 1px solid rgba(229, 231, 235, 0.8);
transition: var(--transition);
}
.nav.scrolled {
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.nav-inner {
display: flex;
align-items: center;
justify-content: space-between;
height: 80px;
}
.logo {
font-weight: 800;
letter-spacing: .2px;
font-size: 1.4rem;
background: linear-gradient(135deg, var(--brand) 0%, var(--cta) 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.nav-links {
display: none;
gap: 28px;
align-items: center;
}
.nav-links a {
color: var(--ink);
font-weight: 500;
position: relative;
}
.nav-links a::after {
content: '';
position: absolute;
width: 0;
height: 2px;
bottom: -4px;
left: 0;
background: var(--brand);
transition: var(--transition);
}
.nav-links a:hover::after {
width: 100%;
}
.nav-cta {
display: none;
}
.nav-toggle {
display: inline-flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
border: 1px solid var(--line);
border-radius: 12px;
background: #fff;
cursor: pointer;
transition: var(--transition);
}
.nav-toggle:hover {
background: var(--soft);
}
@media (min-width: 900px) {
.nav-toggle {
display: none;
}
.nav-cta {
display: inline-flex;
}
}
#mobileMenu {
display: none;
border-top: 1px solid var(--line);
padding: 20px 0;
background: rgba(255, 255, 255, 0.98);
backdrop-filter: blur(10px);
}
#mobileMenu a {
display: block;
padding: 12px 0;
color: var(--ink);
font-weight: 500;
border-bottom: 1px solid rgba(229, 231, 235, 0.5);
}
#mobileMenu a:last-child {
border-bottom: none;
}
@media (min-width: 900px) {
#mobileMenu {
display: none !important;
}
}
/* Hero */
.hero {
padding: 100px 0 80px;
background:
radial-gradient(ellipse at 80% 20%, rgba(14, 165, 233, 0.08) 0%, transparent 60%),
radial-gradient(ellipse at 20% 80%, rgba(16, 185, 129, 0.08) 0%, transparent 60%),
linear-gradient(135deg, #f8fafc 0%, #ffffff 100%);
position: relative;
overflow: hidden;
}
.hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM12 86c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm28-65c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm23-11c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-6 60c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm29 22c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zM32 63c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm57-13c2.76 0 5-2.24 5-5s-2.24-5-5-5-5 2.24-5 5 2.24 5 5 5zm-9-21c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM60 91c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM35 41c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 60c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2z' fill='%230ea5e9' fill-opacity='0.03' fill-rule='evenodd'/%3E%3C/svg%3E");
opacity: 0.5;
}
.hero h1 {
font-size: clamp(2.2rem, 5.5vw, 3.5rem);
line-height: 1.05;
margin: 8px 0 16px;
font-weight: 900;
letter-spacing: -.5px;
}
.hero .bullets {
display: grid;
grid-template-columns: 1fr;
gap: 14px;
margin: 24px 0 28px;
}
.hero .bullets div {
display: flex;
gap: 12px;
align-items: flex-start;
}
.hero .bullets .dot {
font-size: 1.2rem;
flex-shrink: 0;
margin-top: 2px;
}
.hero-cta {
display: flex;
gap: 16px;
flex-wrap: wrap;
}
/* Quiénes somos */
.about .card {
background: #fff;
border-radius: var(--radius);
padding: 30px;
box-shadow: var(--shadow-lg);
position: relative;
overflow: hidden;
transition: var(--transition);
}
.about .card:hover {
transform: translateY(-5px);
box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
}
.about .card::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 4px;
background: linear-gradient(90deg, var(--brand), var(--cta));
}
.about .brand-logo {
width: min(320px, 72%);
height: auto;
display: block;
margin: 0 auto 20px auto;
filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.1));
}
@media (min-width: 900px) {
.about .brand-logo {
width: min(360px, 70%);
margin: 0 auto 24px auto;
}
}
.about.card {
text-align: center;
}
.about.card .section-title {
margin-top: 8px;
font-size: 1.5rem;
}
.about.card .muted {
margin-top: 16px;
}
/* Servicios */
.services .list {
display: grid;
grid-template-columns: 1fr;
gap: 24px;
}
.service-item {
background: #fff;
border-radius: var(--radius);
padding: 28px;
box-shadow: var(--shadow);
transition: var(--transition);
border: 1px solid transparent;
position: relative;
overflow: hidden;
}
.service-item::before {
content: '';
position: absolute;
top: 0;
left: 0;
width: 4px;
height: 100%;
background: linear-gradient(to bottom, var(--brand), var(--cta));
transform: scaleY(0);
transition: var(--transition);
}
.service-item:hover {
transform: translateY(-5px);
box-shadow: var(--shadow-lg);
border-color: rgba(14, 165, 233, 0.1);
}
.service-item:hover::before {
transform: scaleY(1);
}
.service-item h3 {
margin-bottom: 12px;
font-size: 1.3rem;
display: flex;
align-items: center;
gap: 10px;
}
.service-item h3::before {
content: '';
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--brand);
display: inline-block;
}
@media (min-width: 800px) {
.services .list {
grid-template-columns: repeat(3, 1fr);
}
}
/* Por qué elegirnos */
.why .cards {
display: grid;
grid-template-columns: 1fr;
gap: 24px;
}
.why .card {
background: #fff;
border-radius: var(--radius);
padding: 28px;
display: flex;
gap: 16px;
box-shadow: var(--shadow);
transition: var(--transition);
}
.why .card:hover {
transform: translateY(-5px);
box-shadow: var(--shadow-lg);
}
.why .icon {
font-size: 2rem;
flex-shrink: 0;
width: 60px;
height: 60px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
background: var(--brand-light);
color: var(--brand);
}
@media (min-width: 800px) {
.why .cards {
grid-template-columns: repeat(4, 1fr);
}
}
/* FAQs */
.faqs details {
background: #fff;
border-radius: var(--radius);
padding: 20px;
box-shadow: var(--shadow);
transition: var(--transition);
margin-bottom: 16px;
}
.faqs details[open] {
box-shadow: var(--shadow-lg);
}
.faqs details summary {
cursor: pointer;
font-weight: 700;
outline: none;
display: flex;
justify-content: space-between;
align-items: center;
list-style: none;
}
.faqs details summary::-webkit-details-marker {
display: none;
}
.faqs details summary::after {
content: '+';
font-size: 1.5rem;
font-weight: 300;
transition: var(--transition);
}
.faqs details[open] summary::after {
content: '-';
}
.faqs .answer {
color: var(--muted);
margin-top: 16px;
padding-top: 16px;
border-top: 1px solid var(--line);
}
/* Contacto */
.contact form {
display: grid;
grid-template-columns: 1fr;
gap: 20px;
max-width: 720px;
background: #fff;
padding: 40px;
border-radius: var(--radius);
box-shadow: var(--shadow);
}
.field {
display: flex;
flex-direction: column;
gap: 8px;
}
.field label {
font-weight: 500;
}
.field input, .field textarea {
width: 100%;
border: 1px solid var(--line);
border-radius: 12px;
padding: 14px 16px;
font: inherit;
transition: var(--transition);
}
.field input:focus, .field textarea:focus {
outline: none;
border-color: var(--brand);
box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}
.field textarea {
min-height: 140px;
resize: vertical;
}
.row-2 {
display: grid;
grid-template-columns: 1fr;
gap: 20px;
}
@media (min-width: 720px) {
.row-2 {
grid-template-columns: 1fr 1fr;
}
}
.muted {
color: var(--muted);
}
/* Footer */
footer {
padding: 40px 0;
border-top: 1px solid var(--line);
background: #fff;
}
.footer-inner {
display: flex;
flex-direction: column;
gap: 20px;
justify-content: space-between;
align-items: center;
text-align: center;
}
@media (min-width: 800px) {
.footer-inner {
flex-direction: row;
text-align: left;
}
}
/* Scroll to top */
.scroll-top {
position: fixed;
bottom: 25px;
left: 25px;
width: 44px;
height: 44px;
background: var(--brand);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: white;
box-shadow: 0 4px 12px rgba(14, 165, 233, 0.4);
z-index: 99;
cursor: pointer;
transition: var(--transition);
opacity: 0;
visibility: hidden;
}
.scroll-top.visible {
opacity: 1;
visibility: visible;
}
.scroll-top:hover {
background: var(--brand-dark);
transform: translateY(-3px);
}
/* Animations */
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(30px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.fade-in {
animation: fadeInUp 0.8s ease forwards;
}
.delay-1 {
animation-delay: 0.1s;
}
.delay-2 {
animation-delay: 0.2s;
}
.delay-3 {
animation-delay: 0.3s;
}
.delay-4 {
animation-delay: 0.4s;
}
@media (min-width: 900px) {
.nav-links { display: flex; }
}
/* --- Mobile spacing tweaks (navbar ↔ hero) --- */
@media (max-width: 899px){
.nav-inner{ height: 68px; } /* un pelín más compacta */
.hero{ padding-top: 48px; } /* antes: 100px; reduce vacío superior */
.hero h1{ margin-top: .25rem; } /* elimina salto extra del h1 */
.hero .eyebrow{ margin-bottom: .35rem; } /* acerca el eyebrow al título */
}
/* ===== INLINE <style> BLOCK #2 ===== */
/* ===== Overrides HV celeste-first ===== */
:root {
--detail-red: #E5483B;
--detail-yellow: #FFD54F;
}
/* Botones principales en celeste */
.btn-primary,
.btn.brand,
.btn.btn-brand {
background: var(--cta);
border-color: var(--cta-dark);
color: #fff;
}
.btn-primary:hover,
.btn.brand:hover,
.btn.btn-brand:hover {
background: var(--cta-dark);
border-color: var(--cta-dark);
}
/* Líneas divisorias más pro en celeste */
.rule, .divider, .hr, .nt-rule {
height: 2px !important;
background: linear-gradient(90deg, var(--brand), var(--brand-dark));
border: 0;
opacity: 1;
}
/* Eyebrow con mini detalle rojo */
.eyebrow {
letter-spacing: .18em;
color: var(--brand-dark);
position: relative;
padding-left: 14px;
}
.eyebrow::before {
content: "";
width: 6px; height: 6px;
border-radius: 999px;
background: var(--detail-red);
position: absolute; left: 0; top: .55em;
}
/* Links y focos en celeste */
a:focus, button:focus { outline: 2px solid var(--brand); outline-offset: 2px; }
a:hover { color: var(--brand-dark); }
/* Badges sutiles en amarillo */
.badge, .tag, .pill { background: var(--detail-yellow); color: #2a2a2a; }
/* Cards con halo suave celeste */
.card { border:1px solid rgba(13,163,255,.15); box-shadow: 0 6px 24px rgba(11,132,217,.08); }
/* Hero compactado en mobile */
@media (max-width: 576px){
.hero, .section-hero { padding-top: 48px; padding-bottom: 48px; }
}
header.hero .eyebrow::before {
content: none !important;
}
/* ===== INLINE <style> BLOCK #3 ===== */
.section-soft {
background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
padding: 80px 0;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}
.eyebrow {
display: inline-block;
color: #3b82f6;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.1em;
margin-bottom: 12px;
font-size: 0.875rem;
}
.section-title {
font-size: 2.5rem;
font-weight: 700;
color: #1e293b;
margin-bottom: 24px;
line-height: 1.2;
}
.content-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 60px;
align-items: center;
}
.text-content p {
color: #475569;
line-height: 1.6;
margin-bottom: 20px;
}
.lead {
font-size: 1.25rem;
}
.features-list {
margin: 24px 0 0;
list-style: none;
padding: 0;
}
.feature-item {
display: flex;
align-items: center;
gap: 12px;
padding: 12px 0;
border-bottom: 1px solid #e2e8f0;
color: #475569;
}
.feature-item:last-child {
border-bottom: none;
}
.feature-icon {
font-size: 1.25rem;
flex-shrink: 0;
width: 24px;
}
.image-gallery {
display: flex;
flex-direction: column;
gap: 16px;
}
.main-image {
height: 300px;
border-radius: 16px;
box-shadow: 0 20px 40px rgba(0,0,0,0.1);
overflow: hidden;
}
.main-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s ease;
}
.main-image:hover img {
transform: scale(1.05);
}
.thumbnails {
display: flex;
gap: 12px;
}
.thumb {
flex: 1;
height: 80px;
border-radius: 8px;
overflow: hidden;
cursor: pointer;
transition: transform 0.2s ease;
}
.thumb:hover {
transform: translateY(-4px);
}
.thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}
@media (max-width: 768px) {
.content-grid {
grid-template-columns: 1fr;
gap: 40px;
}
.section-title {
font-size: 2rem;
}
.main-image {
height: 250px;
}
}
/* ===== INLINE <style> BLOCK #4 ===== */
.gal-gallery .carousel{max-width:980px;margin-inline:auto;position:relative}
.gal-frame{
height: clamp(220px, 48vh, 440px);
background:#fff;border-radius:16px;overflow:hidden;
box-shadow:0 12px 28px rgba(0,0,0,.12);
display:flex;align-items:center;justify-content:center;padding:8px
}
.gal-img{
width:auto !important;max-width:100%;
height:auto !important;max-height:100%;
object-fit:contain !important;object-position:center;display:block;cursor:zoom-in
}
/* Controles circulares con más contraste */
.gal-gallery .carousel-control-prev,
.gal-gallery .carousel-control-next{
z-index:20;width:50px;height:50px;top:50%;transform:translateY(-50%);
opacity:1;background:rgba(0,0,0,.55);border-radius:50%;margin:0 12px
}
.gal-gallery .carousel-control-prev{left:0}
.gal-gallery .carousel-control-next{right:0}
.gal-gallery .gal-ctrl-icon{width:2.6rem;height:2.6rem;background-size:60% 60%}
/* Indicadores: se sitúan fuera; agregamos espacio inferior para que no se corten */
.gal-gallery .carousel-indicators{z-index:10;bottom:-50px}
.gal-gallery .carousel-indicators button{
width:10px;height:10px;border-radius:50%;
background:rgba(0,0,0,.5);border:none
}
.gal-gallery .carousel-indicators button.active{background:#000}
.gal-gallery{padding-bottom:56px} /* espacio para indicadores */
/* Modal */
#galLightbox .modal-content{background:#000}
#galLightboxImg{max-height:86vh;width:100%;height:auto;object-fit:contain;background:#000}
.gal-lightbox-nav{
position:absolute;top:50%;transform:translateY(-50%);
border:0;width:44px;height:44px;border-radius:999px;
background:rgba(255,255,255,.18);color:#fff;font-size:30px;line-height:44px;text-align:center;z-index:5;cursor:pointer
}
.gal-lightbox-nav:hover{background:rgba(255,255,255,.28)}
.gal-lightbox-nav.gal-prev{left:10px}
.gal-lightbox-nav.gal-next{right:10px}
/* Pequeños ajustes móviles */
@media (max-width: 575.98px){
.gal-frame{height: clamp(200px, 40vh, 360px)}
}
/* ===== INLINE <style> BLOCK #5 ===== */
/* --- Scope exclusivo footer --- */
#pro-footer{background:#0f172a;color:#e5e7eb;padding:48px 0 0;border-top:1px solid #0b1426}
#pro-footer .container{max-width:1200px;margin:0 auto;padding:0 20px}
#pro-footer .grid{display:grid;gap:28px}
#pro-footer .grid-3{grid-template-columns:1fr}
@media(min-width:900px){#pro-footer .grid-3{grid-template-columns:1.2fr .9fr .9fr}}
#pro-footer h4{margin:0 0 12px;font-size:1.05rem;color:#fff;font-weight:800;letter-spacing:.2px}
#pro-footer p,#pro-footer li,#pro-footer a{font-size:.95rem;line-height:1.55}
#pro-footer a{color:#9bd2ff;text-decoration:none}
#pro-footer a:hover{text-decoration:underline}
#pro-footer .brand{display:flex;align-items:flex-start;gap:14px}
#pro-footer .brand-logo{width:56px;height:56px;border-radius:12px;object-fit:contain;background:#0b1426;border:1px solid #15223a}
#pro-footer .muted{color:#94a3b8}
#pro-footer .list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
#pro-footer .chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #20314f;border-radius:999px;background:#0b1426;color:#cfe7ff}
#pro-footer .bar{margin-top:32px;border-top:1px solid #15223a}
#pro-footer .bar-in{display:flex;flex-direction:column;gap:10px;justify-content:space-between;align-items:flex-start;padding:16px 0;color:#9fb3d1}
@media(min-width:900px){#pro-footer .bar-in{flex-direction:row;align-items:center}}
/* ===== INLINE <style> BLOCK #6 ===== */
:root{
--wa:#25D366; --wa-dark:#128C7E; --wa-darker:#075E54;
--dark-bg:#0b0f18; --darker-bg:#0a1324;
--light-text:#ffffff; --muted-text:rgba(255,255,255,.7);
}
.wa-float{ position:fixed; right:18px; bottom:18px; z-index:9999; font-family:inherit; }
.wa-btn{
background:linear-gradient(135deg,var(--wa),var(--wa-dark));
color:#fff; border:0; width:60px; height:60px; border-radius:50%;
display:grid; place-items:center; box-shadow:0 10px 30px rgba(0,0,0,.25);
cursor:pointer; transition:transform .3s, box-shadow .3s, background .3s; position:relative; overflow:hidden;
}
.wa-btn::after{ content:""; position:absolute; inset:0;
background:radial-gradient(circle at 50% 50%, rgba(255,255,255,.18), rgba(255,255,255,0) 70%);
opacity:0; transition:opacity .3s;
}
.wa-btn:hover{ transform:translateY(-3px) scale(1.05); box-shadow:0 14px 36px rgba(0,0,0,.35); }
.wa-btn:hover::after{ opacity:1; }
.wa-card{
position:absolute; right:0; bottom:74px; width:min(360px,92vw);
background:var(--dark-bg); color:var(--light-text); border-radius:18px; overflow:hidden;
box-shadow:0 18px 60px rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.08);
transform:translateY(10px); opacity:0; transition:transform .3s, opacity .3s;
}
.wa-card[aria-modal="true"]{ transform:translateY(0); opacity:1; }
.wa-head{ display:flex; align-items:center; gap:12px; padding:14px;
background:linear-gradient(180deg,#0d162c,var(--darker-bg)); border-bottom:1px solid rgba(255,255,255,.06);
}
.wa-avatar{ width:40px; height:40px; border-radius:8px; background:#0e1a33;
display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); overflow:hidden; }
.wa-title{ font-weight:700; font-size:1.05rem; }
.wa-status{ font-size:.85rem; color:var(--muted-text); display:flex; align-items:center; gap:6px; }
.wa-status::before{ content:""; width:8px; height:8px; border-radius:50%; background:var(--wa); }
.wa-close{ margin-left:auto; background:transparent; color:#fff; border:0; font-size:24px; cursor:pointer; opacity:.7;
width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:.2s; }
.wa-close:hover{ opacity:1; background:rgba(255,255,255,.1); }
.wa-body{ padding:12px 14px; max-height:40vh; overflow:auto; background:var(--dark-bg);
display:flex; flex-direction:column; gap:8px; }
.wa-bubble{ max-width:88%; padding:10px 12px; border-radius:14px; line-height:1.35; box-shadow:0 4px 14px rgba(0,0,0,.25); animation:fadeIn .25s ease; }
@keyframes fadeIn{ from{opacity:0; transform:translateY(5px)} to{opacity:1; transform:none} }
.wa-bot{ background:#0c1428; border:1px solid rgba(255,255,255,.06); align-self:flex-start; border-bottom-left-radius:4px; }
.wa-user{ background:var(--wa-darker); align-self:flex-end; border-bottom-right-radius:4px; }
.wa-compose{ display:grid; grid-template-columns:1fr auto; gap:8px; padding:10px; background:var(--dark-bg); border-top:1px solid rgba(255,255,255,.08); }
.wa-compose textarea{
resize:none; border-radius:12px; padding:10px 12px; border:1px solid rgba(255,255,255,.12);
background:#0a1324; color:var(--light-text); outline:none; min-height:44px; font-family:inherit; transition:.2s;
}
.wa-compose textarea:focus{ border-color:var(--wa); box-shadow:0 0 0 2px rgba(37,211,102,.15); }
.wa-send{ background:var(--wa); color:#0b1220; border:0; border-radius:12px; padding:0 16px; font-weight:700; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:.2s; }
.wa-send:hover{ background:var(--wa-dark); transform:scale(1.05); }
/* Scrollbar */
.wa-body::-webkit-scrollbar{ width:6px; }
.wa-body::-webkit-scrollbar-track{ background:rgba(255,255,255,.05); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.2); border-radius:3px; }
.wa-body::-webkit-scrollbar-thumb:hover{ background:rgba(255,255,255,.3); }
/* Responsive */
@media (max-width:480px){
.wa-float{ right:12px; bottom:12px; }
.wa-card{ width:calc(100vw - 24px); right:0; }
}