/* =========================================================
   Ratatouille Cheesecake · EVENTS — estilos.css
   Identidad real: Negro #1D1D1B · Vainilla #EFDD9E · Gris #808181
   Sub-marca Events: dorado elegante (mercado bodas)
   Tipografía: Lufga (corporativa) -> Poppins (sustituto web) + Playfair (display)
   ========================================================= */

:root{
  --negro:#1D1D1B;
  --negro-2:#262522;
  --crema:#F6F2E9;
  --crema-2:#EFE8D9;
  --oro:#9C7A1C;          /* vainilla oscuro = texto acento legible sobre crema */
  --oro-claro:#EFDD9E;    /* VAINILLA de marca para rellenos/acentos */
  --oro-osc:#7E6315;
  --vainilla:#EFDD9E;     /* símbolo de marca (el mordisco) */
  --gris:#7C7B78;
  --texto:#2A2926;
  --linea:rgba(29,29,27,.12);
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Lufga","Poppins", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --maxw:1180px;
  --r:16px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--texto);background:var(--crema);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:22px}

/* ---------- tipografía ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.08;color:var(--negro);letter-spacing:.01em}
h1{font-size:clamp(2.5rem,7vw,4.6rem)}
h2{font-size:clamp(2rem,5.2vw,3.2rem);margin-bottom:.4em}
h3{font-size:clamp(1.25rem,2.6vw,1.6rem)}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--oro);display:inline-block;margin-bottom:1rem}
.gold{color:var(--oro)}
.deco{display:flex;align-items:center;gap:.7rem;color:var(--oro);margin:.4rem 0 1.4rem;font-size:1.2rem}
.deco::before,.deco::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--oro))}
.deco::after{background:linear-gradient(90deg,var(--oro),transparent)}
.deco.center{max-width:340px;margin-inline:auto}

/* ---------- botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-weight:600;
  font-size:.95rem;padding:.95em 1.7em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .25s, background .25s, color .25s, border-color .25s}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:1.15em;height:1.15em;fill:currentColor}
.btn-primary{background:var(--negro);color:var(--crema)}
.btn-primary:hover{background:var(--oro);color:var(--negro)}
.btn-gold{background:#C9A53F;color:var(--negro)}
.btn-gold:hover{background:#B8942F}
.btn-ghost{background:transparent;border-color:var(--negro);color:var(--negro)}
.btn-ghost:hover{background:var(--negro);color:var(--crema)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1ebe5a}
.btn-light{background:var(--crema);color:var(--negro)}
.btn-light:hover{background:var(--oro);color:var(--negro)}

/* ---------- nav ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;background:rgba(246,242,233,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:border-color .3s,padding .3s}
.nav.scrolled{border-color:var(--linea)}
.nav .brand{display:flex;align-items:center;gap:.55rem}
.nav .brand img{height:30px;width:auto}
.nav .brand .ev{font-family:var(--sans);font-weight:700;font-size:.56rem;letter-spacing:.2em;
  background:var(--negro);color:var(--crema);padding:.3em .5em;border-radius:5px}
.nav .links{display:none;gap:1.25rem;align-items:center;font-weight:500;font-size:.9rem;white-space:nowrap}
.nav .links a{position:relative;padding:.2em 0}
.nav .links a.active{color:var(--oro)}
.nav .links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;
  background:var(--oro);transition:width .25s}
.nav .links a:not(.btn):hover::after{width:100%}
.nav .links .btn{padding:.7em 1.25em;font-size:.88rem}
@media(min-width:1060px){.nav .links{display:flex}.burger{display:none}}
.burger{display:flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--negro);transition:.3s}
.mobile-menu{position:fixed;inset:0;z-index:55;background:var(--negro);color:var(--crema);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.6rem;
  font-family:var(--serif);font-size:1.7rem;transform:translateY(-100%);transition:transform .4s ease;}
.mobile-menu.open{transform:none}
.mobile-menu a{color:var(--crema)}
.mobile-menu a.btn{font-family:var(--sans);font-size:1rem}
.mobile-menu .close{position:absolute;top:22px;right:26px;font-size:2.4rem;font-family:var(--sans);background:none;border:0;color:var(--crema);cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:grid;align-items:center;padding:130px 0 70px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:radial-gradient(120% 80% at 85% 8%, rgba(216,188,126,.22), transparent 55%),var(--crema)}
.hero-grid{display:grid;gap:46px}
@media(min-width:960px){.hero-grid{grid-template-columns:1.02fr .98fr;align-items:center}}
.hero h1{margin:.15em 0 .25em}
.hero h1 em{font-style:italic;color:var(--oro)}
.hero .lead{font-size:clamp(1.05rem,2.1vw,1.22rem);color:var(--gris);max-width:40ch;margin-bottom:2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem}
.hero-media{position:relative}
.hero-media img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:center;
  border-radius:22px;box-shadow:0 34px 80px -34px rgba(29,29,27,.55)}
/* En escritorio la imagen iguala la altura del bloque de texto:
   borde superior a la altura del titular y borde inferior al botón. */
@media(min-width:960px){
  .hero-grid{align-items:stretch}
  .hero-media{display:flex}
  .hero-media img{aspect-ratio:auto;height:100%;min-height:480px}
}
.hero-media .float{position:absolute;left:-12px;bottom:26px;background:#fff;border-radius:14px;
  padding:.85em 1.2em;box-shadow:0 18px 40px -16px rgba(29,29,27,.5);display:flex;gap:.7em;align-items:center}
.hero-media .float .n{font-family:var(--serif);font-size:1.6rem;color:var(--oro);line-height:1}
.hero-media .float small{font-size:.78rem;color:var(--gris);max-width:13ch}

/* page hero (interiores) */
.phero{position:relative;padding:150px 0 70px;text-align:center;color:var(--crema);overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;z-index:-2;background:var(--negro)}
.phero.img::before{background:linear-gradient(rgba(20,20,18,.72),rgba(20,20,18,.82))}
.phero.img{background-size:cover;background-position:center}
.phero h1,.phero h2{color:var(--crema)}
.phero .lead{color:rgba(246,242,233,.82);max-width:54ch;margin:.6rem auto 0;font-size:1.1rem}
.phero .eyebrow{color:var(--oro-claro)}
.breadcrumb{font-size:.82rem;color:rgba(246,242,233,.6);margin-bottom:1rem;font-family:var(--sans)}
.breadcrumb a:hover{color:var(--oro-claro)}

/* ---------- marquee ---------- */
.marquee{background:var(--negro);color:var(--crema);overflow:hidden;padding:15px 0}
.marquee .track{display:flex;gap:2.4rem;white-space:nowrap;width:max-content;
  animation:slide 28s linear infinite;font-family:var(--serif);font-size:1.1rem;font-style:italic}
.marquee .track i{color:var(--vainilla);font-style:normal}
@keyframes slide{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee .track{animation:none}}

/* ---------- secciones ---------- */
section{padding:84px 0}
.section-head{max-width:62ch;margin-bottom:46px}
.section-head.center{margin-inline:auto;text-align:center}
.section-head p{color:var(--gris);font-size:1.08rem;margin-top:.3rem}
.alt{background:var(--crema-2)}
.dark{background:var(--negro);color:var(--crema)}
.dark h2,.dark h3{color:var(--crema)}
.dark .section-head p{color:rgba(246,242,233,.72)}
.dark .eyebrow{color:var(--oro-claro)}

/* ---------- split (texto + foto) ---------- */
.split{display:grid;gap:44px;align-items:center}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr}.split.rev .txt{order:2}}
.split img{border-radius:18px;box-shadow:0 26px 60px -32px rgba(29,29,27,.5)}
.split ul{list-style:none;display:grid;gap:.7rem;margin-top:1.3rem}
.split li{display:flex;gap:.7em;align-items:flex-start;color:var(--texto)}
.split li::before{content:"";width:18px;height:18px;border-radius:50%;flex:none;margin-top:.3em;
  background:var(--vainilla);
  -webkit-mask:radial-gradient(circle at 72% 28%, transparent 30%, #000 31%);
          mask:radial-gradient(circle at 72% 28%, transparent 30%, #000 31%)}

/* ---------- cards ---------- */
.cards{display:grid;gap:22px}
.cards.c2{grid-template-columns:1fr}
.cards.c3{grid-template-columns:1fr}
@media(min-width:680px){.cards.c2{grid-template-columns:repeat(2,1fr)}.cards.c3{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.cards.c3{grid-template-columns:repeat(3,1fr)}}
.card{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:30px 26px;
  transition:transform .3s, box-shadow .3s}
.alt .card{background:var(--crema)}
.dark .card{background:var(--negro-2);border-color:rgba(246,242,233,.1)}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 54px -30px rgba(29,29,27,.4)}
.card .ico{width:52px;height:52px;display:grid;place-items:center;border-radius:50%;
  border:1.5px solid var(--oro);color:var(--oro);font-size:1.4rem;margin-bottom:1rem}
.card h3{margin-bottom:.35rem}
.card p{color:var(--gris);font-size:.97rem}
.dark .card p{color:rgba(246,242,233,.7)}

/* ---------- pasos / timeline ---------- */
.steps{display:grid;gap:24px;counter-reset:step}
@media(min-width:760px){.steps.cols4{grid-template-columns:repeat(4,1fr)}}
.step{position:relative;padding-top:56px}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:0;left:0;
  font-family:var(--serif);font-size:2.6rem;color:var(--oro);font-weight:600}
.step h3{font-size:1.18rem;margin-bottom:.3rem}
.step p{color:var(--gris);font-size:.95rem}
.dark .step p{color:rgba(246,242,233,.7)}

.timeline{display:grid;gap:0;max-width:780px;margin-inline:auto}
.tl{position:relative;padding:0 0 38px 64px;border-left:2px solid var(--linea);margin-left:22px}
.tl:last-child{border-color:transparent;padding-bottom:0}
.tl .num{position:absolute;left:-23px;top:-4px;width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--oro-claro),var(--oro));color:var(--negro);
  display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:1.2rem}
.tl h3{margin-bottom:.25rem}
.tl p{color:var(--gris)}

/* ---------- precio destacado ---------- */
.price-box{background:var(--negro);color:var(--crema);border-radius:22px;padding:46px 36px;text-align:center;
  position:relative;overflow:hidden}
.price-box::before{content:"";position:absolute;inset:0;z-index:0;
  background:radial-gradient(80% 120% at 50% 0%, rgba(216,188,126,.18), transparent 60%)}
.price-box>*{position:relative;z-index:1}
.price-box .amt{font-family:var(--serif);font-size:clamp(3rem,9vw,4.6rem);color:var(--oro-claro);line-height:1}
.price-box .amt small{font-size:1.1rem;color:rgba(246,242,233,.7);font-family:var(--sans)}
.price-box .incluye{display:grid;gap:.7rem;max-width:560px;margin:1.8rem auto 0;text-align:left}
.price-box .incluye li{display:flex;gap:.7em;align-items:flex-start;list-style:none;color:rgba(246,242,233,.92)}
.price-box .incluye li::before{content:"";width:18px;height:18px;border-radius:50%;flex:none;margin-top:.3em;background:var(--vainilla);
  -webkit-mask:radial-gradient(circle at 72% 28%, transparent 30%, #000 31%);mask:radial-gradient(circle at 72% 28%, transparent 30%, #000 31%)}
.price-box .nota{margin-top:1.6rem;font-size:.86rem;color:rgba(246,242,233,.6)}

/* ---------- galería ---------- */
.gallery{display:grid;gap:14px;grid-template-columns:repeat(4,1fr)}
.gallery img{border-radius:14px;width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.gallery .wide{grid-column:span 2}
/* Móvil: carrusel deslizable con fotos grandes (swipe) */
@media(max-width:759px){
  .gallery{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;
    gap:12px;padding:2px 18px 14px;margin-inline:-18px;-webkit-overflow-scrolling:touch}
  .gallery img{flex:0 0 82%;scroll-snap-align:center;aspect-ratio:4/5}
  .gallery::-webkit-scrollbar{display:none}
}
.swipe-hint{display:none}
@media(max-width:759px){
  .swipe-hint{display:block;text-align:center;color:var(--oro);font-weight:600;
    font-size:.8rem;letter-spacing:.06em;margin:-18px 0 16px}
}

/* ---------- cita ---------- */
.quote{background:var(--negro);color:var(--crema);text-align:center}
.quote blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,4vw,2.5rem);
  line-height:1.25;max-width:22ch;margin-inline:auto}
.quote .who{margin-top:1.4rem;color:var(--oro-claro);font-weight:600;letter-spacing:.04em;font-family:var(--sans)}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:14px;max-width:860px;margin-inline:auto}
details{border:1px solid var(--linea);border-radius:14px;background:#fff;padding:0 24px;overflow:hidden}
.alt details{background:var(--crema)}
summary{cursor:pointer;list-style:none;font-family:var(--serif);font-weight:600;font-size:1.12rem;color:var(--negro);
  padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:1rem}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";font-size:1.7rem;color:var(--oro);transition:transform .25s;font-family:var(--sans)}
details[open] summary::after{transform:rotate(45deg)}
details .ans{padding:0 0 22px;color:var(--gris)}

/* ---------- CTA / formulario ---------- */
.cta{position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(110% 90% at 12% 0%, rgba(216,188,126,.2), transparent 55%),var(--crema-2)}
.cta-grid{display:grid;gap:42px}
@media(min-width:900px){.cta-grid{grid-template-columns:1fr 1fr;align-items:start}}
.cta .lead{color:var(--gris);font-size:1.1rem;margin-bottom:1.4rem;max-width:40ch}
.contact-list{display:grid;gap:1rem;margin-top:1.4rem}
.contact-list a{display:flex;gap:.8em;align-items:center;font-weight:500}
.contact-list .ico{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;
  border:1.5px solid var(--oro);color:var(--oro);flex:none}
.contact-list a:hover .ico{background:var(--oro);color:#fff}
form{display:grid;gap:14px;background:#fff;padding:30px;border-radius:var(--r);border:1px solid var(--linea);
  box-shadow:0 24px 60px -40px rgba(29,29,27,.4)}
form .row{display:grid;gap:14px}
@media(min-width:520px){form .row{grid-template-columns:1fr 1fr}}
label{font-weight:600;font-size:.82rem;display:block;margin-bottom:.32rem;color:var(--negro)}
input,select,textarea{width:100%;font-family:var(--sans);font-size:.97rem;padding:.82em .9em;
  border:1px solid var(--linea);border-radius:11px;background:var(--crema);color:var(--texto)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--oro);border-color:transparent}
textarea{resize:vertical;min-height:92px}
form .btn{justify-content:center;margin-top:.3rem}
.formnote{font-size:.78rem;color:var(--gris);text-align:center}

/* ---------- footer ---------- */
footer{background:var(--negro);color:var(--crema);padding:64px 0 32px}
.foot-grid{display:grid;gap:32px}
@media(min-width:760px){.foot-grid{grid-template-columns:2fr 1fr 1fr}}
footer .brand img{height:46px;margin-bottom:1rem}
footer p{color:rgba(246,242,233,.66);font-size:.93rem;max-width:36ch}
footer h4{font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--oro-claro);margin-bottom:1rem}
footer ul{list-style:none;display:grid;gap:.55rem;font-size:.94rem}
footer ul a{color:rgba(246,242,233,.85)}
footer ul a:hover{color:var(--oro-claro)}
.foot-legal{border-top:1px solid rgba(246,242,233,.14);margin-top:42px;padding-top:22px;
  display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.82rem;color:rgba(246,242,233,.62)}
.foot-legal a{color:rgba(246,242,233,.82)}
.foot-legal a:hover{color:var(--oro-claro)}
.foot-bottom{margin-top:14px;padding-top:14px;border-top:1px solid rgba(246,242,233,.08);
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;font-size:.82rem;color:rgba(246,242,233,.5)}

/* ---------- páginas legales ---------- */
.legal{padding:128px 0 70px}
.legal .wrap{max-width:860px}
.legal h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:.3em}
.legal .updated{color:var(--gris);font-size:.9rem;margin-bottom:2.4rem}
.legal h2{font-size:clamp(1.3rem,3vw,1.7rem);margin:2.2rem 0 .6rem}
.legal h3{font-size:1.1rem;margin:1.4rem 0 .4rem}
.legal p,.legal li{color:var(--texto);font-size:1rem;margin-bottom:.7rem}
.legal ul{padding-left:1.2rem;margin-bottom:1rem}
.legal li{margin-bottom:.4rem}
.legal a{color:var(--oro);text-decoration:underline}
.legal .box{background:var(--crema-2);border:1px solid var(--linea);border-radius:14px;padding:22px 24px;margin:1.2rem 0}
.legal table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.92rem}
.legal th,.legal td{text-align:left;padding:.6em .7em;border-bottom:1px solid var(--linea);vertical-align:top}
.legal th{font-family:var(--sans);font-weight:600;color:var(--negro)}

/* ---------- banner cookies ---------- */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:80;max-width:760px;margin-inline:auto;
  background:var(--negro);color:var(--crema);border-radius:16px;padding:18px 22px;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.55);display:flex;flex-wrap:wrap;gap:14px 22px;align-items:center;
  justify-content:space-between;opacity:0;transform:translateY(20px);transition:opacity .35s, transform .35s}
.cookie-banner.show{opacity:1;transform:none}
.cookie-banner .cb-txt{font-size:.9rem;color:rgba(246,242,233,.88);flex:1 1 320px;line-height:1.5}
.cookie-banner .cb-txt a{color:var(--oro-claro);text-decoration:underline}
.cookie-banner .cb-btns{display:flex;gap:.6rem;flex:0 0 auto}
.cookie-banner .btn{padding:.6em 1.2em;font-size:.88rem}
.cookie-banner .btn-ghost{border-color:rgba(246,242,233,.5);color:var(--crema)}
.cookie-banner .btn-ghost:hover{background:var(--crema);color:var(--negro)}
@media(max-width:560px){.cookie-banner .cb-btns{width:100%}.cookie-banner .cb-btns .btn{flex:1}}

/* consentimiento en formulario */
.consent{display:flex;gap:.6em;align-items:flex-start;font-size:.84rem;color:var(--gris)}
.consent input{width:auto;margin-top:.2em;flex:none}
.consent a{color:var(--oro);text-decoration:underline}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s, transform .7s}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- pulido móvil ---------- */
h1,h2,h3,h4,p,a,li,blockquote,summary,span{overflow-wrap:break-word}
/* Móvil/tablet: el hero muestra la tarta (producto = apetece). */
@media(max-width:959px){
  .hero{min-height:auto}
  .hero-media{margin-top:8px}
  .hero-media img{aspect-ratio:4/3}
}
@media(max-width:600px){
  .wrap{padding-inline:18px}
  .hero{padding:104px 0 56px}
  .hero h1{font-size:2.15rem;line-height:1.12}
  .hero .lead{font-size:1rem;max-width:none}
  .hero-cta .btn{flex:1 1 auto;justify-content:center}
  .phero{padding:124px 0 56px}
  section{padding:60px 0}
  .price-box{padding:36px 22px}
  .price-box .incluye{margin-left:0}
  .timeline{margin-left:0}
  .tl{padding-left:54px;margin-left:18px}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:380px){
  .hero h1{font-size:1.95rem}
  .nav .brand img{height:26px}
}

/* ---------- rating hero ---------- */
.hero-rating{margin-top:1.3rem;font-size:.92rem;color:var(--gris);letter-spacing:.04em}
.hero-rating .stars{color:var(--oro);letter-spacing:.05em}
.hero-rating strong{color:var(--negro)}

/* ---------- precio sabor ---------- */
.precio{margin-top:.5rem;font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--oro)}

/* ---------- badge nuevo local ---------- */
.ribbon-new{display:inline-block;background:var(--vainilla);color:var(--negro);font-weight:700;
  font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.32em .7em;border-radius:999px;margin-bottom:.7rem}

/* ---------- botón flotante Pedir en Glovo ---------- */
.order-float{position:fixed;right:18px;bottom:18px;z-index:70;background:var(--negro);color:var(--crema);
  font-weight:700;font-size:.92rem;padding:.85em 1.4em;border-radius:999px;
  box-shadow:0 14px 32px -10px rgba(0,0,0,.5);transition:transform .25s, background .25s}
.order-float:hover{transform:translateY(-2px);background:var(--oro);color:var(--negro)}

/* ---------- whatsapp flotante ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:70;width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 30px -8px rgba(0,0,0,.45);
  transition:transform .25s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px}
