/* ═══════════════════════════════════════════════════════════
   FLOWLY PRINT — styles.css  v4
   #000000 · #E63329 · #14B8A6 · Poppins
═══════════════════════════════════════════════════════════ */

:root {
  --red:    #E63329;
  --teal:   #14B8A6;
  --ink:    #000000;
  --paper:  #F5F2EE;
  --white:  #ffffff;
  --mid:    #888888;
  --font:   'Poppins', sans-serif;
  --r:      18px; /* radio de tarjetas */
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--font); background:var(--paper); color:var(--ink); overflow-x:hidden; }

/* ═══════════════════════════════════════════════════════════
   CURSOR
   Blanco con borde — visible sobre fondos oscuros Y claros
   mix-blend-mode:difference invierte el color automáticamente
═══════════════════════════════════════════════════════════ */
/*
* { cursor:none !important; }

#cur {
    z-index: 999999 !important;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    pointer-events: none;
    transform: translate(-50%,-50%);
    transition: width .15s, height .15s, opacity .15s;
    mix-blend-mode: difference; /* se invierte: blanco sobre negro → negro; blanco sobre blanco → negro 
}
#cur.big {
  width: 38px;
  height: 38px;
  opacity: .7;
}
*/
/* ═══════════════════════════════════════════════════════════
   HEADER — blanco, logo PNG encaja sin recuadro
═══════════════════════════════════════════════════════════ */
header {
  position: fixed;
  top:0; left:0; width:100%;
  height: 66px;
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  background:rgba(255,255,255,.97);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.logo { display:flex; align-items:center; text-decoration:none; }
.logo img { height:40px; object-fit:contain; display:block; }
.logo-fallback {
  font-family:var(--font); font-weight:900; font-size:1.3rem;
  color:var(--ink); display:none;
}
.logo-fallback em { color:var(--red); font-style:normal; }

nav ul { list-style:none; display:flex; gap:2rem; align-items:center; }
nav a {
  text-decoration:none; color:var(--ink);
  font-size:.84rem; font-weight:500; opacity:.65; transition:opacity .2s, color .2s;
}
nav a:hover { opacity:1; color:var(--red); }

.lang-grp { display:flex; gap:.3rem; }
.lang-btn {
  font-family:var(--font); font-size:.75rem; font-weight:700;
  padding:4px 12px; border-radius:999px;
  border:1.5px solid rgba(0,0,0,.18);
  background:transparent; color:var(--ink);
  transition:all .18s;
}
.lang-btn.active,
.lang-btn:hover { background:var(--ink); color:#fff; border-color:var(--ink); }

.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:4px; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--ink); border-radius:2px; transition:all .3s; }

.nav-drawer {
  display:none; position:fixed; top:66px; left:0; width:100%;
  background:#fff; padding:1.5rem 2rem;
  border-bottom:1px solid rgba(0,0,0,.08);
  flex-direction:column; gap:1rem; z-index:899;
}
.nav-drawer.open { display:flex; }
.nav-drawer a { text-decoration:none; color:var(--ink); font-size:1rem; font-weight:500; }

/* ═══════════════════════════════════════════════════════════
   HERO — GALERÍA DE COLUMNAS CON VIDEO + FLIP 3D EN HOVER
   El flip ocurre sobre la columna misma:
   · Cara frontal = video en blanco/negro + icono + nombre
   · Cara trasera = color sólido + CTA → abre el chat
═══════════════════════════════════════════════════════════ */
.hero {
  position:relative; height:100vh; min-height:640px;
  overflow:hidden; padding-top:66px;
}

.gallery {
  position:absolute;
  top: 66px; left: 0; right: 0; bottom: 0;
  display:flex;
  align-items: flex-end;        /* columnas ancladas al fondo — referencia Alan Menken */
  justify-content: center;
  gap: 10px;
  padding: 0 5rem 4rem;         /* respiro lateral y base */
}

/* Columna: altura variable definida por JS — referencia exacta Alan Menken */
.col {
  flex: 1 1 0;
  min-width: 0;
  /* height se asigna inline por JS: cada columna tiene su propia altura */
  position:relative;
  overflow:hidden;
  border-radius: 12px;
  transition: flex .65s cubic-bezier(.4,0,.2,1),
              height .65s cubic-bezier(.4,0,.2,1);
  perspective: 1000px;
  box-shadow: 0 12px 40px rgba(0,0,0,.22);
  align-self: flex-end;          /* cada una desde su propio fondo */
}

/* Inner del flip — contiene las dos caras */
.col-inner {
  position:absolute; inset:0;
  transform-style: preserve-3d;
  transition: transform .7s cubic-bezier(.4,0,.2,1);
}

.col:hover { flex:3.8; }
.col:hover .col-inner { transform: rotateY(180deg); }

/* Cara delantera — video + overlay + info */
.col-front {
  position:absolute; inset:0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  overflow:hidden;
}

.col-front video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  /* Video limpio, sin filtros — se ve a color completo siempre */
  filter: none;
  transition: filter .5s ease, opacity .5s ease;
  pointer-events:none;
}

/* Sin capa oscura encima del video */
.col-front-dim { display: none; }

/* Al hover: las otras columnas se atenúan ligeramente */
.gallery:has(.col:hover) .col:not(:hover) .col-front video {
  filter: brightness(.55) saturate(.4);
}

/* Etiqueta — nombre vertical en la parte baja, sin gradiente */
.col-label {
  position:absolute; bottom:0; left:0; right:0;
  z-index:3;
  display:flex; align-items:flex-start; justify-content:flex-end;
  padding:.8rem .7rem;
  /* Solo un degradado muy sutil en la base para legibilidad del texto */
  background: linear-gradient(transparent 0%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
  min-height: 60px;
}
/* Nombre vertical negro sobre fondo oscuro sutil */
.col-label h3 {
  font-size:.72rem; font-weight:700; color:#fff; line-height:1.2;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  letter-spacing:.08em; text-transform:uppercase;
  opacity: 1;
}
.col-label p  { display:none; }
/* En hover el label desaparece — la cara trasera toma protagonismo */
.col:hover .col-label { opacity: 0; }

/* Barra de color en el pie */
.col-bar {
  position:absolute; bottom:0; left:0; right:0; height:3px; z-index:4;
}

/* Cara trasera — se ve al hover */
.col-back {
  position:absolute; inset:0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  transform: rotateY(180deg); /* empieza oculta */
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:2rem 1.4rem;
  gap:.8rem;
  overflow:hidden;
}

/* Fondo de la cara trasera: video a color + capa de color semitransparente */
.col-back video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0;
  filter: saturate(1.2) brightness(.7);
  pointer-events:none;
}
.col-back-overlay {
  position:absolute; inset:0; z-index:1;
}
.col:nth-child(odd)  .col-back-overlay { background: rgba(230,51,41,.72); }
.col:nth-child(even) .col-back-overlay { background: rgba(20,184,166,.72); }

/* Contenido cara trasera — por encima del video */
.col-back .b-icon  { display:none; }
.col-back .b-name  {
  font-size:clamp(2rem, 4.5vw, 3.8rem);
  font-weight:900; color:#fff; line-height:1.05;
  position:relative; z-index:2;
  text-align:center;
  letter-spacing:-.02em;
  /* Texto vertical como en la referencia */
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
}
.col-back .b-desc  { font-size:.73rem; color:rgba(255,255,255,.85); line-height:1.5; position:relative; z-index:2; }
.col-back .b-cta   {
  position:relative; z-index:2;
  display:inline-block; margin-top:.3rem;
  padding:9px 24px; border-radius:999px;
  font-size:.78rem; font-weight:700;
  color:var(--ink); background:rgba(255,255,255,.92);
  transition:background .18s, transform .15s;
}
.col-back .b-cta:hover { background:#fff; transform:scale(1.04); }

/* Texto central del hero (se desvanece al hover la galería) */
.hero-center {
  position:absolute; inset:0; top:66px; z-index:10;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; pointer-events:none;
  transition:opacity .35s;
}
.gallery:hover ~ .hero-center { opacity:0; }

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(0,0,0,.78); color:#fff;
  font-size:.74rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  padding:6px 16px; border-radius:999px; margin-bottom:1.2rem;
}
.hero-badge .dot { width:7px; height:7px; border-radius:50%; background:var(--teal); animation:blink 1.8s infinite; }

.hero-h1 { font-size:clamp(2.2rem,4.5vw,3.8rem); font-weight:900; line-height:1.1; color:#fff; text-shadow:0 2px 24px rgba(0,0,0,.5); }
.hero-h1 em { color:var(--red); font-style:normal; }
.hero-sub { font-size:.95rem; color:rgba(255,255,255,.8); max-width:520px; margin:.9rem auto 0; line-height:1.65; text-shadow:0 1px 8px rgba(0,0,0,.4); }

.hero-ctas {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  z-index:20; display:flex; gap:.9rem; align-items:center; pointer-events:auto;
}
.btn-primary {
  background:var(--red); color:#fff; border:none;
  border-radius:999px; font-family:var(--font); font-weight:700; font-size:.9rem; padding:14px 32px;
  box-shadow:0 6px 24px rgba(230,51,41,.45); transition:transform .2s, box-shadow .2s;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(230,51,41,.5); }
.btn-outline {
  background:rgba(255,255,255,.12); backdrop-filter:blur(12px); color:#fff;
  border:1.5px solid rgba(255,255,255,.45); border-radius:999px;
  font-family:var(--font); font-weight:600; font-size:.88rem; padding:13px 28px;
  transition:background .2s;
}
.btn-outline:hover { background:rgba(255,255,255,.2); }

.fbadge {
  position:absolute; z-index:20;
  background:rgba(0,0,0,.82); backdrop-filter:blur(10px); color:#fff;
  border-radius:999px; padding:7px 16px 7px 10px;
  font-size:.76rem; font-weight:600; display:flex; align-items:center; gap:7px;
  animation:floaty 3.5s ease-in-out infinite;
}
.fb1 { top:28%; left:2.5rem; }
.fb2 { top:44%; left:2rem; animation-delay:1.2s; }
.fbdot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

.hero-widget { position:absolute; bottom:5.5rem; right:3rem; z-index:20; width:275px; }
.hero-card {
  background:rgba(255,255,255,.13); backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.25); border-radius:18px; padding:1.2rem;
}
.hc-label { font-size:.74rem; font-weight:700; color:#fff; letter-spacing:.05em; text-transform:uppercase; margin-bottom:.8rem; opacity:.85; }
.hc-chips { display:flex; flex-wrap:wrap; gap:.35rem; margin-bottom:.8rem; }
.hc-chip {
  background:rgba(255,255,255,.16); color:#fff;
  border:1px solid rgba(255,255,255,.22); border-radius:999px;
  font-size:.72rem; font-weight:500; padding:4px 10px; transition:background .2s;
}
.hc-chip:hover { background:var(--red); border-color:var(--red); }
.hc-row { display:flex; gap:.45rem; }
.hc-input {
  flex:1; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.22);
  border-radius:11px; color:#fff; font-family:var(--font); font-size:.8rem;
  padding:9px 13px; outline:none; transition:border .2s;
}
.hc-input::placeholder { color:rgba(255,255,255,.5); }
.hc-input:focus { border-color:rgba(255,255,255,.55); }
.hc-send { width:37px; height:37px; background:var(--red); color:#fff; border:none; border-radius:10px; font-size:1.1rem; transition:transform .15s; }
.hc-send:hover { transform:scale(1.08); }

/* ═══════════════════════════════════════════════════════════
   PRODUCTS — tarjetas divididas: imagen arriba, texto abajo
═══════════════════════════════════════════════════════════ */
.products { padding:5rem 0; background:#f5f5f5; }
.sec-inner { max-width:1200px; margin:0 auto; padding:0 32px; }

.sec-tag { font-size:.68rem; font-weight:800; letter-spacing:.22em; color:var(--teal); text-transform:uppercase; margin-bottom:.6rem; }
.sec-title { font-size:clamp(1.6rem,3vw,2.4rem); font-weight:800; color:var(--ink); line-height:1.15; margin-bottom:2.2rem; }
.sec-title em { color:var(--red); font-style:normal; }

.products-grid {
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:1.2rem;
}

/* Tarjeta — contenedor flip split */
.prod-card {
  background:#fff;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.07);
  display:flex;
  flex-direction:column;
  cursor:pointer;
  transition: transform .3s cubic-bezier(.4,0,.2,1),
              box-shadow .3s;
  /* sin min-height — la imagen da la altura */
}
.prod-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,.13);
}

/* ── PARTE SUPERIOR: Imagen ── */
.prod-card-img {
  width:100%;
  height: 190px;           /* más altura = más detalle visible */
  background-size: cover;  /* fallback si no viene inline */
  background-position: center;
  background-repeat: no-repeat;
  position:relative;
  overflow:hidden;
  flex-shrink:0;
  transition: transform .5s cubic-bezier(.4,0,.2,1),
              background-position .5s ease;
}
.prod-card:hover .prod-card-img {
  transform: scale(1.04);  /* zoom muy suave para no perder detalle */
}
.prod-card.featured .prod-card-img {
  height: 220px;           /* la tarjeta featured tiene aún más espacio */
}
/* Overlay sutil para mejorar transición al texto */
.prod-card-img-overlay {
  position:absolute; inset:0;
  background: linear-gradient(to bottom,
    transparent 50%,
    rgba(0,0,0,.22) 100%);
}

/* ── PARTE INFERIOR: Texto ── */
.prod-card-body {
  padding:1rem 1.1rem 1.1rem;
  display:flex;
  flex-direction:column;
  flex:1;
}

/* Número decorativo muy sutil */
.prod-num {
  position:absolute; top:8px; right:10px; z-index:2;
  font-size:1.6rem; font-weight:900; line-height:1;
  color:rgba(255,255,255,.55);
  text-shadow: 0 1px 4px rgba(0,0,0,.3);
}

.prod-icon { display:none; } /* la imagen reemplaza el icono */
.prod-name { font-size:.9rem; font-weight:700; color:var(--ink); line-height:1.25; margin-bottom:.25rem; }
.prod-desc { font-size:.72rem; color:var(--mid); line-height:1.4; flex:1; }
.prod-cta {
  display:inline-block; margin-top:.7rem;
  padding:6px 14px; border-radius:999px;
  font-size:.7rem; font-weight:700; color:#fff;
  opacity:0; transform:translateY(4px); transition:all .25s;
  align-self:flex-start;
}
.prod-card:nth-child(odd)  .prod-cta { background:var(--red); }
.prod-card:nth-child(even) .prod-cta { background:var(--teal); }
.prod-card:hover .prod-cta { opacity:1; transform:translateY(0); }

/* Línea de color en el borde inferior al hover */
.prod-card::after {
  content:''; position:absolute;
  bottom:0; left:0; right:0; height:3px;
  transform:scaleX(0); transform-origin:left; transition:transform .35s;
}
.prod-card:nth-child(odd)::after  { background:var(--red); }
.prod-card:nth-child(even)::after { background:var(--teal); }
.prod-card:hover::after { transform:scaleX(1); }

.prod-card.featured .prod-card-img { height:200px; }

/* ═══════════════════════════════════════════════════════════
   HOW IT WORKS
═══════════════════════════════════════════════════════════ */
.how { padding:5.5rem 0; background:var(--paper); }
.how .sec-title { color:var(--ink); }

.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.step {
  background:#fff; border-radius:18px; padding:2rem;
  border:1px solid rgba(0,0,0,.07); position:relative; overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
.step:hover { transform:translateY(-4px); box-shadow:0 10px 32px rgba(0,0,0,.08); }
.step::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.step:nth-child(1)::before,.step:nth-child(3)::before { background:var(--red); }
.step:nth-child(2)::before,.step:nth-child(4)::before { background:var(--teal); }
.step-num { font-size:2.8rem; font-weight:900; color:rgba(0,0,0,.06); line-height:1; margin-bottom:.5rem; }
.step h4 { font-size:1rem; font-weight:700; margin-bottom:.45rem; }
.step p  { font-size:.82rem; color:var(--mid); line-height:1.6; }

/* ═══════════════════════════════════════════════════════════
   NEWSLETTER
═══════════════════════════════════════════════════════════ */
.newsletter { padding:5rem 2rem; background:var(--ink); text-align:center; }
.nl-inner { max-width:580px; margin:0 auto; }
.newsletter h3 { font-size:clamp(1.5rem,3vw,2.3rem); font-weight:800; color:#fff; margin-bottom:.7rem; }
.nl-sub { font-size:.9rem; color:rgba(255,255,255,.6); margin-bottom:1.8rem; line-height:1.7; }
.nl-form { display:flex; gap:.6rem; max-width:560px; margin:0 auto 1rem; }
.nl-form input {
  flex:1; border:1.5px solid rgba(255,255,255,.15); border-radius:12px;
  background:rgba(255,255,255,.09); color:#fff; font-family:var(--font);
  font-size:.88rem; padding:13px 17px; outline:none; transition:border .2s;
}
.nl-form input::placeholder { color:rgba(255,255,255,.4); }
.nl-form input:focus { border-color:var(--teal); }
.nl-form button {
  background:var(--red); color:#fff; border:none; border-radius:12px;
  font-family:var(--font); font-weight:700; font-size:.88rem; padding:13px 24px;
  transition:transform .15s, box-shadow .15s;
  white-space:nowrap; flex-shrink:0;
}
.nl-form button:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(230,51,41,.4); }
.nl-check { display:flex; align-items:flex-start; gap:.5rem; max-width:420px; margin:0 auto; font-size:.76rem; color:rgba(255,255,255,.45); }

footer { background:#050505; padding:2rem; text-align:center; font-size:.78rem; color:rgba(255,255,255,.3); }

/* ═══════════════════════════════════════════════════════════
   CHAT TOGGLE
═══════════════════════════════════════════════════════════ */
#chatToggle {
  position:fixed; bottom:2rem; right:2rem;
  width:56px; height:56px; border-radius:50%;
  background:var(--red); color:#fff; border:none;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 24px rgba(230,51,41,.5); z-index:800;
  transition:transform .2s, box-shadow .2s;
}
#chatToggle:hover { transform:scale(1.08); box-shadow:0 10px 32px rgba(230,51,41,.55); }
#chatToggle.hidden { display:none; }
#chatToggle::after {
  content:''; position:absolute; inset:-4px; border-radius:50%;
  border:2px solid rgba(230,51,41,.35); animation:ring 2.5s infinite;
}

/* ═══════════════════════════════════════════════════════════
   CHAT WIDGET
   + botón minimizar (−) además del cerrar (×)
═══════════════════════════════════════════════════════════ */
#chatWidget {
  position:fixed; bottom:2rem; right:2rem;
  width:375px; max-height:590px; background:#fff; border-radius:22px;
  box-shadow:0 20px 60px rgba(0,0,0,.18);
  display:flex; flex-direction:column; z-index:800; overflow:hidden;
  border:1px solid rgba(0,0,0,.07);
  font-family: 'DM Sans', var(--font); /* fuente original del chat */
}
#chatWidget.hidden { display:none; }

.cw-head {
  background:var(--ink); padding:.9rem 1.1rem;
  display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.cw-info { display:flex; align-items:center; gap:.7rem; }
.cw-avatar { width:34px; height:34px; background:var(--red); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.95rem; }
.cw-name { font-weight:700; font-size:.88rem; color:#fff; }
.cw-status { display:flex; align-items:center; gap:5px; font-size:.7rem; color:rgba(255,255,255,.55); }
.cw-dot { width:6px; height:6px; border-radius:50%; background:var(--teal); animation:blink 1.8s infinite; }

/* Botón cerrar del chat */
.cw-close {
  background:rgba(255,255,255,.1); border:none; color:#fff;
  border-radius:50%; width:26px; height:26px;
  font-size:1.1rem; display:flex; align-items:center; justify-content:center;
  transition:background .2s;
}
.cw-close:hover { background:rgba(255,255,255,.22); }

.cw-body {
  flex:1; overflow-y:auto; padding:1rem 1.1rem;
  display:flex; flex-direction:column; gap:.65rem;
  scroll-behavior:smooth;
}
.cw-body::-webkit-scrollbar { width:4px; }
.cw-body::-webkit-scrollbar-thumb { background:#e0e0e0; border-radius:2px; }

/* Bubbles — estilo original suave */
.bubble { max-width:82%; padding:.75rem 1rem; border-radius:18px; font-size:.83rem; line-height:1.55; animation:pop .22s ease; font-family:'DM Sans', var(--font); }
.bubble.bot { background:#f4f4f6; color:#111; border-bottom-left-radius:4px; align-self:flex-start; }
.bubble.user { background:var(--red); color:#fff; border-bottom-right-radius:4px; align-self:flex-end; }
.bubble.bot strong { font-weight:700; }

.typing-dots { display:flex; gap:4px; align-items:center; padding:.55rem .95rem; background:#f4f4f6; border-radius:18px; border-bottom-left-radius:4px; align-self:flex-start; width:54px; }
.typing-dots span { width:7px; height:7px; border-radius:50%; background:#bbb; animation:bounce .9s infinite; }
.typing-dots span:nth-child(2){animation-delay:.15s} .typing-dots span:nth-child(3){animation-delay:.3s}
.typing-dots.hidden { display:none; }

/* Quick chips — como en la imagen de referencia */
.quick-chips {
  display:flex; flex-wrap:wrap; gap:8px;
  padding:10px 14px 12px; flex-shrink:0;
  border-top:1px solid #ebebeb;
}
.quick-chips.hidden { display:none; }
.qchip {
  font-size:.82rem; font-weight:700;
  padding:8px 18px; border-radius:999px;
  background:#f0f0f0; border:1.5px solid rgba(0,0,0,.13);
  color:#111; transition:all .16s;
  white-space:nowrap;
}
.qchip:hover { background:#111; color:#fff; border-color:#111; }

.cw-foot { padding:.7rem 1.1rem .9rem; border-top:1px solid rgba(0,0,0,.06); display:flex; gap:.45rem; flex-shrink:0; }
#chatInput { flex:1; border:1.5px solid rgba(0,0,0,.1); border-radius:11px; font-family:var(--font); font-size:.83rem; padding:9px 13px; outline:none; transition:border .2s; color:var(--ink); }
#chatInput:focus { border-color:var(--red); }
#chatSend { background:var(--red); color:#fff; border:none; border-radius:11px; font-family:var(--font); font-weight:700; font-size:.83rem; padding:9px 17px; transition:transform .15s; }
#chatSend:hover { transform:scale(1.04); }

/* ── INLINE CHIPS (opciones dentro del chat) ── */
.inline-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-self: flex-start;
    padding: 4px 0 6px 2px;
    max-width: 92%;
}
.ichip {
    background: var(--paper);
    color: var(--ink);
    border: 1.5px solid rgba(0,0,0,.18);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: .78rem;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s, opacity .15s;
    white-space: nowrap;
}
.ichip:hover:not(:disabled) {
    background: var(--ink);
    color: var(--white);
    border-color: var(--ink);
}
.ichip:disabled {
    cursor: default;
}

/* bubble-chip usa el mismo estilo que ichip */
.bubble-chips { display:flex; flex-wrap:wrap; gap:7px; align-self:flex-start; padding:4px 0 6px 2px; max-width:92%; }
.bubble-chip {
    background: var(--paper);
    color: var(--ink);
    border: 1.5px solid rgba(0,0,0,.18);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: .78rem;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s, opacity .15s;
    white-space: nowrap;
}
.bubble-chip:hover { background: var(--ink); color: var(--white); border-color: var(--ink); }

/* Upload slot — original exacto */
.upload-slot {
  align-self:flex-start; background:#fff;
  border:1.5px solid rgba(0,0,0,.12); border-radius:14px;
  padding:14px 16px; max-width:92%;
  display:flex; flex-direction:column; gap:7px;
}
.upload-label { font-size:.82rem; font-weight:700; color:var(--ink); }
.upload-formats { font-size:.72rem; color:var(--mid); line-height:1.4; }
.upload-btn {
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--ink); color:#fff; border-radius:999px;
  padding:8px 18px; font-size:.78rem; font-weight:700;
  font-family:var(--font); transition:opacity .18s; width:fit-content;
}
.upload-btn:hover { opacity:.82; }
.upload-status { font-size:.76rem; font-weight:600; min-height:16px; }
.upload-warning {
  font-size:.74rem; color:#92620a; background:#fffbeb;
  border:1px solid rgba(245,166,35,.4); border-radius:8px;
  padding:7px 10px; line-height:1.5; margin-bottom:4px;
}

/* Diagrama de zonas de archivo — idéntico al original */
.disclaimer-diagram { margin:10px 0 6px; display:flex; flex-direction:column; gap:10px; }
.dz-bleed {
  position:relative; background:rgba(230,51,41,.12);
  border:2px dashed rgba(230,51,41,.6); border-radius:8px;
  padding:20px; display:flex; align-items:center; justify-content:center; min-height:130px;
}
.dz-label-outer {
  position:absolute; top:4px; left:8px;
  font-size:.65rem; font-weight:700; color:rgba(230,51,41,.9);
  letter-spacing:.02em; text-transform:uppercase;
}
.dz-trim {
  position:relative; background:rgba(107,107,107,.08);
  border:1.5px solid rgba(107,107,107,.5); border-radius:5px;
  padding:16px; display:flex; align-items:center; justify-content:center;
  width:100%; min-height:86px;
}
.dz-label-trim {
  position:absolute; bottom:3px; right:7px;
  font-size:.62rem; color:var(--mid); font-weight:600;
  text-transform:uppercase; letter-spacing:.02em;
}
.dz-safe {
  background:rgba(34,197,94,.12); border:1.5px solid rgba(34,197,94,.5);
  border-radius:4px; padding:10px 14px;
  display:flex; align-items:center; justify-content:center;
  width:80%; min-height:44px; text-align:center;
}
.dz-label-safe { font-size:.7rem; font-weight:700; color:#15803d; line-height:1.4; }
.dz-label-safe small { font-weight:400; font-size:.65rem; color:#166534; }
.dz-legend { display:flex; flex-direction:column; gap:4px; font-size:.71rem; color:var(--mid); line-height:1.5; }
.dz-legend div { display:flex; align-items:center; gap:6px; }
.dz-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.dz-dot.bleed { background:rgba(230,51,41,.7); }
.dz-dot.trim  { background:rgba(107,107,107,.6); }
.dz-dot.safe  { background:rgba(34,197,94,.7); }

/* Resume banner — original exacto */
.resume-banner {
  display:flex; align-items:center; gap:10px;
  background:#fff8f0; border:1.5px solid rgba(245,166,35,.35);
  border-radius:12px; padding:10px 13px; margin:4px 0 2px;
  align-self:stretch; flex-shrink:0; animation:fadeSlideIn .25s ease;
}
@keyframes fadeSlideIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.resume-icon { font-size:1rem; flex-shrink:0; }
.resume-text { flex:1; font-size:.75rem; font-weight:600; color:var(--ink); line-height:1.35; }
.resume-text span { display:block; font-weight:400; color:var(--mid); font-size:.71rem; margin-top:1px; }
.resume-actions { display:flex; gap:6px; flex-shrink:0; }
.resume-btn {
  font-size:.7rem; font-weight:700; padding:5px 11px;
  border-radius:999px; border:1.5px solid; font-family:var(--font);
  white-space:nowrap; transition:all .16s;
}
.resume-btn.primary { background:var(--ink); color:#fff; border-color:var(--ink); }
.resume-btn.primary:hover { opacity:.8; }
.resume-btn.secondary { background:transparent; color:var(--mid); border-color:rgba(0,0,0,.18); }
.resume-btn.secondary:hover { border-color:var(--ink); color:var(--ink); }

/* ═══════════════════════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════════════════════ */
@keyframes blink  { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.5)} }
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
@keyframes ring   { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.55);opacity:0} }
@keyframes bounce { 0%,80%,100%{transform:translateY(0)} 40%{transform:translateY(-6px)} }
@keyframes pop    { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(28px); transition:all .65s ease; }
.reveal.on { opacity:1; transform:translateY(0); }

/* ═══════════════════════════════════════════════════════════
   GRAIN SUTIL
═══════════════════════════════════════════════════════════ */
body::after {
  content:''; position:fixed; inset:0; z-index:9998; pointer-events:none; opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media (max-width:900px) {
  nav ul { display:none; }
  .nav-toggle { display:flex; }
  .hero-widget,.fbadge { display:none; }
  .hero-ctas { flex-direction:column; bottom:1.5rem; }
  #chatWidget { width:calc(100vw - 2rem); right:1rem; bottom:1rem; }

  .steps { grid-template-columns:1fr 1fr; }
}
@media (max-width:600px) {
  .products-grid { grid-template-columns: repeat(2, 1fr); }
  .hero-h1 { font-size:1.6rem; line-height:1.15; }
  .hero-sub { font-size:.85rem; padding:0 1rem; }
  .hero-center { padding:0 1.2rem; box-sizing:border-box; width:100%; }
  .steps { grid-template-columns:1fr; }

  /* ── Galería móvil: grid 2x2 en lugar de columnas verticales ── */
  /* ── Galería móvil: grid 2x2 con video de fondo único ── */
  .gallery {
    position: relative;
    top: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    padding: 8px;
    align-items: stretch;
    height: auto !important;
    overflow: hidden;
  }
  /* Video de fondo único — cubre todo el gallery */
  .gallery-bg-video {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    z-index: 0;
    pointer-events: none;
  }
  .col {
    height: 160px !important;
    border-radius: 10px;
    flex: none;
    width: 100%;
    position: relative;
    z-index: 1;
    background: transparent;
    overflow: hidden;
  }
  /* Última columna ocupa todo el ancho */
  .col:last-child { grid-column: span 2; }
  .col:hover { flex: none; }

  /* En móvil las tarjetas son ventanas semitransparentes sobre el video */
  .col-front video { display: none; }
  .col-front {
    background: rgba(0,0,0,0.18);
    backdrop-filter: blur(1px);
  }
  .col-label {
    background: linear-gradient(transparent 0%, rgba(0,0,0,0.65) 100%);
  }
  .col-label h3 {
    writing-mode: horizontal-tb;
    transform: none;
    font-size: 0.75rem;
    text-align: center;
  }
  .col-back video { display: none; }
  .col-back .b-name {
    writing-mode: horizontal-tb;
    transform: none;
    font-size: 1.4rem;
  }
  .col-back .b-cta {
    font-size: 0.72rem;
    padding: 7px 16px;
  }
  .hero-center {
    position: relative;
    top: 0;
    padding: 2rem 1.2rem 1rem;
  }
  .gallery:hover ~ .hero-center { opacity: 1; }
}

/* ── ART DISCLAIMER ── */
.art-disclaimer {
  align-self:flex-start; background:#fff8f0;
  border:1.5px solid rgba(245,166,35,.4); border-radius:14px;
  padding:14px 16px; max-width:96%; margin:4px 0;
  font-size:.78rem; line-height:1.6; color:var(--ink);
  font-family:'DM Sans', var(--font);
}
.art-disclaimer-body { margin-bottom:12px; }
.art-disclaimer-body em { color:var(--mid); font-size:.74rem; font-style:italic; }
.art-disclaimer-footer { display:flex; justify-content:flex-start; }
.art-disclaimer-btn {
  background:var(--ink); color:#fff; border:none; border-radius:999px;
  padding:8px 18px; font-size:.78rem; font-weight:700;
  font-family:'DM Sans', var(--font); cursor:pointer; transition:opacity .18s;
}
.art-disclaimer-btn:hover { opacity:.82; }
.art-disclaimer.collapsed { padding:8px 14px; background:#f0fdf4; border-color:rgba(34,197,94,.4); }
.art-disclaimer-summary {
  display:flex; align-items:center; gap:8px;
  font-size:.76rem; font-weight:600; color:#15803d;
  font-family:'DM Sans', var(--font);
}
.art-disclaimer-check { font-size:.9rem; }
.art-disclaimer-summary span:nth-child(2) { flex:1; }
.art-disclaimer-expand {
  background:none; border:1px solid rgba(34,197,94,.4); border-radius:4px;
  color:#15803d; font-size:.65rem; padding:2px 6px; cursor:pointer;
  line-height:1; transition:background .15s;
}
.art-disclaimer-expand:hover { background:rgba(34,197,94,.1); }

/* ════════════════════════════════════════════════════════
   ART VIEWER MODAL — Visor de arte para impresión
════════════════════════════════════════════════════════ */

/* ── Botón del chat que lanza el modal ─────────────────*/
.av-chat-btn-wrap {
    align-self: flex-start;
    width: 96%;
    max-width: 96%;
    margin: 4px 0 8px;
}
.av-chat-card {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #fff;
    border: 1.5px solid rgba(0,0,0,.1);
    border-radius: 14px;
    padding: 12px 14px;
    box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.av-chat-card-icon {
    font-size: 1.6rem;
    flex-shrink: 0;
}
.av-chat-card-info {
    flex: 1;
    min-width: 0;
}
.av-chat-card-title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 2px;
}
.av-chat-card-sub {
    font-size: .74rem;
    color: var(--mid);
}
.av-chat-card-formats {
    font-size: .68rem;
    color: #aaa;
    margin-top: 2px;
    letter-spacing: .02em;
}
.av-chat-card-btn {
    background: var(--ink);
    color: #fff;
    border: none;
    border-radius: 999px;
    padding: 8px 16px;
    font-size: .78rem;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: opacity .18s;
}
.av-chat-card-btn:hover { opacity: .82; }
.av-chat-card-note {
    font-size: .72rem;
    color: var(--mid);
    margin-top: 6px;
    padding-left: 4px;
}
.av-chat-done {
    background: rgba(34,197,94,.1);
    border: 1px solid rgba(34,197,94,.3);
    border-radius: 10px;
    padding: 10px 14px;
    font-size: .8rem;
    font-weight: 600;
    color: #15803d;
}

/* ── Modal overlay ─────────────────────────────────────*/
.av-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(10,10,10,.72);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .25s ease;
}
.av-modal--open { opacity: 1; }

.av-modal-inner {
    background: #fff;
    border-radius: 20px;
    width: min(94vw, 560px);
    max-height: 92vh;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 24px 80px rgba(0,0,0,.3);
    position: relative;
}

/* ── Header ────────────────────────────────────────────*/
.av-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 18px 12px;
    border-bottom: 1px solid rgba(0,0,0,.08);
    flex-shrink: 0;
}
.av-header-left {
    display: flex;
    align-items: center;
    gap: 10px;
}
.av-header-icon { font-size: 1.4rem; }
.av-header-title {
    font-size: .95rem;
    font-weight: 800;
    color: var(--ink);
}
.av-header-sub {
    font-size: .72rem;
    color: var(--mid);
    margin-top: 1px;
}
.av-close {
    background: rgba(0,0,0,.06);
    border: none;
    border-radius: 50%;
    width: 32px; height: 32px;
    font-size: 1.1rem;
    cursor: pointer;
    color: var(--ink);
    display: flex; align-items: center; justify-content: center;
    transition: background .15s;
    flex-shrink: 0;
}
.av-close:hover { background: rgba(0,0,0,.12); }

/* ── Tabs ──────────────────────────────────────────────*/
.av-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid rgba(0,0,0,.08);
    flex-shrink: 0;
}
.av-tab {
    flex: 1;
    padding: 10px;
    border: none;
    background: transparent;
    font-size: .8rem;
    font-weight: 600;
    font-family: 'DM Sans', sans-serif;
    color: var(--mid);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: color .15s, border-color .15s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.av-tab.active {
    color: var(--ink);
    border-bottom-color: var(--ink);
}
.av-tab-status { font-size: .75rem; }

/* ── Canvas area ───────────────────────────────────────*/
.av-canvas-area {
    position: relative;
    background: #f5f5f5;
    min-height: 240px;
    max-height: 420px;
    flex-shrink: 0;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.av-canvas-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 16px;
    box-sizing: border-box;
}
.av-canvas-wrap canvas {
    display: block;
    border-radius: 4px;
    box-shadow: 0 2px 16px rgba(0,0,0,.18);
    max-width: 100%;
    max-height: 400px;
}

/* ── Drop zone ─────────────────────────────────────────*/
.av-dropzone {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: #fafafa;
    border: 2px dashed rgba(0,0,0,.15);
    border-radius: 0;
    transition: background .18s, border-color .18s;
    padding: 20px;
    text-align: center;
}
.av-dropzone--over {
    background: rgba(230,51,41,.05);
    border-color: var(--accent);
}
.av-dropzone-icon { font-size: 2rem; margin-bottom: 4px; }
.av-dropzone-text {
    font-size: .9rem;
    font-weight: 700;
    color: var(--ink);
}
.av-dropzone-sub {
    font-size: .75rem;
    color: var(--mid);
}
.av-dropzone-btn {
    background: var(--ink);
    color: #fff;
    border: none;
    border-radius: 999px;
    padding: 8px 20px;
    font-size: .8rem;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    margin-top: 8px;
    transition: opacity .18s;
    display: inline-block;
}
.av-dropzone-btn:hover { opacity: .82; }
.av-dropzone-formats {
    font-size: .68rem;
    color: #aaa;
    margin-top: 4px;
}
.av-dropzone-error {
    font-size: .76rem;
    color: var(--accent);
    font-weight: 600;
    margin-top: 4px;
}

/* ── Controles de zoom ─────────────────────────────────*/
.av-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    border-bottom: 1px solid rgba(0,0,0,.06);
    gap: 12px;
    flex-shrink: 0;
}
.av-ctrl-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}
.av-ctrl-label {
    font-size: .74rem;
    color: var(--mid);
    white-space: nowrap;
}
.av-zoom-slider {
    flex: 1;
    accent-color: var(--ink);
    height: 4px;
    cursor: pointer;
}
#avZoomVal {
    font-size: .74rem;
    color: var(--ink);
    font-weight: 600;
    min-width: 38px;
    text-align: right;
}
.av-ctrl-btn {
    background: transparent;
    border: 1.5px solid rgba(0,0,0,.15);
    border-radius: 999px;
    padding: 5px 12px;
    font-size: .74rem;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    white-space: nowrap;
    transition: border-color .15s;
}
.av-ctrl-btn:hover { border-color: var(--ink); }

/* ── Info panel ────────────────────────────────────────*/
.av-info {
    padding: 10px 16px;
    border-bottom: 1px solid rgba(0,0,0,.06);
    flex-shrink: 0;
}
.av-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px 12px;
}
.av-info-item {
    font-size: .74rem;
    color: var(--mid);
    line-height: 1.4;
}
.av-ok  { color: #16a34a; font-weight: 700; }
.av-warn{ color: #d97706; font-weight: 700; }
.av-err { color: var(--accent); font-weight: 700; }
.av-warn-dot {
    display: inline-block;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #d97706;
    margin-right: 4px;
    vertical-align: middle;
}

/* ── Leyenda ───────────────────────────────────────────*/
.av-legend {
    display: flex;
    gap: 14px;
    padding: 8px 16px;
    border-bottom: 1px solid rgba(0,0,0,.06);
    flex-shrink: 0;
}
.av-leg-item {
    font-size: .68rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.av-leg-item::before {
    content: '';
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 2px;
    flex-shrink: 0;
}
.av-leg-bleed { color: rgba(230,51,41,.9); }
.av-leg-bleed::before { background: rgba(230,51,41,.2); border: 1px dashed rgba(230,51,41,.6); }
.av-leg-trim  { color: #1a1a1a; }
.av-leg-trim::before  { background: transparent; border: 1.5px dashed #1a1a1a; }
.av-leg-safe  { color: #16a34a; }
.av-leg-safe::before  { background: transparent; border: 1px dashed rgba(34,197,94,.8); }

/* ── Checklist vectoriales ─────────────────────────────*/
.av-vector-check {
    padding: 12px 16px;
    border-bottom: 1px solid rgba(0,0,0,.06);
    flex-shrink: 0;
}
.av-vector-check-title {
    font-size: .78rem;
    font-weight: 700;
    color: var(--ink);
    margin-bottom: 8px;
}
.av-check-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .76rem;
    color: var(--mid);
    padding: 3px 0;
    cursor: pointer;
}
.av-check-item input { cursor: pointer; accent-color: var(--ink); }

/* ── Footer ────────────────────────────────────────────*/
.av-footer {
    padding: 12px 16px 14px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.av-footer-note {
    font-size: .7rem;
    color: var(--mid);
    font-style: italic;
}
.av-footer-btns {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}
.av-btn-cancel {
    background: transparent;
    border: 1.5px solid rgba(0,0,0,.15);
    border-radius: 999px;
    padding: 9px 20px;
    font-size: .8rem;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    color: var(--mid);
    transition: border-color .15s, color .15s;
}
.av-btn-cancel:hover { border-color: var(--ink); color: var(--ink); }
.av-btn-confirm {
    background: var(--ink);
    color: #fff;
    border: none;
    border-radius: 999px;
    padding: 9px 22px;
    font-size: .82rem;
    font-weight: 700;
    font-family: 'DM Sans', sans-serif;
    cursor: pointer;
    transition: opacity .18s, background .18s;
}
.av-btn-confirm:disabled {
    background: #ccc;
    cursor: not-allowed;
    opacity: 1;
}
.av-btn-confirm:not(:disabled):hover { opacity: .82; }

/* ── Upload progress overlay ───────────────────────────*/
.av-uploading {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.92);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    border-radius: 20px;
    font-size: .9rem;
    font-weight: 600;
    color: var(--ink);
    z-index: 10;
}
.av-uploading-spinner {
    width: 36px; height: 36px;
    border: 3px solid rgba(0,0,0,.1);
    border-top-color: var(--ink);
    border-radius: 50%;
    animation: av-spin .8s linear infinite;
}
@keyframes av-spin { to { transform: rotate(360deg); } }

/* ── Mobile adjustments ────────────────────────────────*/
@media (max-width: 600px) {
    .av-modal-inner {
        width: 100%;
        max-height: 100dvh;
        border-radius: 20px 20px 0 0;
        align-self: flex-end;
    }
    .av-modal {
        align-items: flex-end;
    }
    .av-canvas-area {
        min-height: 200px;
        max-height: 260px;
    }
    .av-info-grid {
        grid-template-columns: 1fr;
    }
    .av-footer-btns {
        flex-direction: column;
    }
    .av-btn-cancel, .av-btn-confirm {
        width: 100%;
        text-align: center;
    }
    .av-chat-card {
        flex-wrap: wrap;
    }
    .av-chat-card-btn {
        width: 100%;
        text-align: center;
    }
}
