:root{
  --green:#075f35;
  --green-2:#0d7a45;
  --green-3:#0b4b2c;
  --mint:#dff4e9;
  --mint-2:#edf9f3;
  --cream:#fff0cf;
  --peach:#ffe0cf;
  --lilac:#eee4ff;
  --sky:#e8f6ff;
  --ink:#11131a;
  --soft-ink:#414650;
  --muted:#727986;
  --line:#e6ebef;
  --paper:#ffffff;
  --bg:#f4fafb;
  --radius:26px;
  --radius-sm:18px;
  --shadow:0 20px 50px rgba(13,45,56,.12);
  --shadow-soft:0 10px 28px rgba(13,45,56,.10);
  --head:'Nunito Sans',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --script:'Caveat',cursive;
  --max:1220px;
  --pad:clamp(18px,5vw,72px);
}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--body);color:var(--ink);background:linear-gradient(135deg,#f1fbff 0%,#fff 44%,#eefaf3 100%);font-size:16px;line-height:1.55;overflow-x:hidden}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}h1,h2,h3{font-family:var(--head);line-height:1.05;letter-spacing:-.035em}.section-shell{width:min(var(--max),100%);margin:auto;padding:0 var(--pad)}
/* ── Header barra separada ── */
.site-header{position:sticky;top:0;z-index:50;padding:12px var(--pad);background:rgba(255,255,255,.92);backdrop-filter:blur(22px);border-bottom:1px solid rgba(216,226,229,.8)}
.header-shell{width:min(var(--max),100%);height:58px;margin:auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand-group{display:flex;align-items:center;gap:14px}.brand-divider{width:1px;height:36px;background:rgba(0,0,0,.15)}.brand img{height:46px;mix-blend-mode:multiply}.brand-import img{height:38px}
.main-nav{display:flex;gap:28px;align-items:center}
.main-nav a{font-size:.91rem;font-weight:700;color:#191d24}
.main-nav a:hover{color:var(--green)}
.header-actions{display:flex;align-items:center;gap:10px}
.nav-cta{background:var(--green);color:#fff;border-radius:999px;padding:13px 24px;font-family:var(--head);font-weight:900;font-size:.87rem;box-shadow:0 12px 26px rgba(7,95,53,.22)}
.nav-whatsapp{width:43px;height:43px;border-radius:999px;background:#16bf58;color:#fff;display:grid;place-items:center;font-size:1.25rem}
.menu-button{display:none;background:#fff;border:1px solid var(--line);border-radius:12px;width:44px;height:44px;place-items:center}
.menu-button span{display:block;width:19px;height:2px;background:var(--ink);margin:3px;border-radius:999px}

/* ── Hero card ── */
.hero{padding:28px var(--pad) 30px}
.hero-shell{
  width:min(var(--max),100%);
  margin:auto;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(220,230,232,.9);
  border-radius:30px;
  box-shadow:var(--shadow);
  display:grid;
  grid-template-columns:1fr minmax(420px,560px);
  min-height:610px;
  position:relative;
  overflow:hidden;
}.hero-copy{position:relative;z-index:2}.pill{display:inline-flex;align-items:center;background:#a8ddbd;color:#07562f;border-radius:999px;padding:7px 17px;font-family:var(--head);font-size:.82rem;font-weight:900}.hero h1{font-size:clamp(2rem,3.2vw,3.4rem);font-weight:900;margin:22px 0 6px;color:#101219}.hero h1 strong{font-weight:900}.script-line{font-family:var(--script);font-size:clamp(2.1rem,3.8vw,3.6rem);line-height:1;color:var(--green);margin-bottom:22px}.hero-categories{font-weight:700;color:#1b2229;margin-bottom:28px}.proof-row{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;max-width:660px;margin-bottom:30px}.proof-row div{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:800;color:#2a333b}.proof-row i{width:28px;height:28px;border:1px solid #93d5af;border-radius:50%;display:grid;place-items:center;color:var(--green)}.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:999px;font-family:var(--head);font-weight:900;transition:.22s ease}.btn-primary{background:var(--green);color:#fff;padding:16px 28px;box-shadow:0 12px 24px rgba(7,95,53,.24)}.btn-primary:hover{transform:translateY(-2px);background:var(--green-3)}.btn-secondary{background:#fff;color:#20252b;border:1px solid var(--line);padding:16px 28px;box-shadow:0 10px 22px rgba(0,0,0,.06)}.btn.small{padding:13px 19px;font-size:.9rem}.hero-stage{position:relative;min-height:610px;z-index:1}.pet-orb{position:absolute;right:-40px;top:54px;width:510px;height:420px;background:radial-gradient(circle at 45% 35%,#f2f7cd 0%,#dceab8 54%,rgba(220,234,184,0) 72%);border-radius:46% 54% 58% 42%;}.pet-placeholder{position:absolute;border-radius:50%;display:grid;place-items:center;background:linear-gradient(145deg,#fff,#f2f8ee);box-shadow:var(--shadow-soft);color:#d18b2f}.pet-placeholder i{font-size:4.5rem}.pet-placeholder.dog{right:122px;top:85px;width:190px;height:190px}.pet-placeholder.cat{right:310px;top:170px;width:145px;height:145px;color:#7c6a5a}.product{position:absolute;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(0,0,0,.18))}.product-main{right:190px;bottom:76px;max-height:240px;z-index:4}.product-left{right:340px;bottom:65px;max-height:210px;z-index:5}.product-right{right:58px;bottom:82px;max-height:218px;z-index:3}.stage-card{position:absolute;right:46px;bottom:265px;background:#fff;border-radius:16px;padding:16px 20px;font-family:var(--head);font-weight:900;font-size:.86rem;box-shadow:var(--shadow-soft);z-index:6}.stage-card strong{color:var(--green)}
.categories{padding:42px 0 20px}.section-title{display:flex;justify-content:space-between;align-items:end;gap:20px;margin-bottom:24px}.section-title h2,.center-title h2{font-size:clamp(2rem,3vw,2.8rem);font-weight:900}.section-title p{color:var(--muted);font-weight:600;margin-top:8px}.section-title a{font-size:.86rem;font-weight:900;color:var(--green)}.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.category-card{min-height:190px;border-radius:24px;padding:24px 18px 18px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,.8);transition:.22s ease}.category-card:hover{transform:translateY(-6px)}.category-card h3{font-size:1rem;font-weight:900}.category-card span{display:inline-block;margin-top:14px;font-size:.78rem;font-weight:900;color:#20252b}.category-card img{position:absolute;right:-4px;bottom:0;max-height:120px;max-width:70%;object-fit:contain}.card-icon{position:absolute;right:20px;bottom:22px;font-size:4.4rem;color:rgba(7,95,53,.36)}.bg-cream{background:var(--cream)}.bg-mint{background:#c9f0dc}.bg-lilac{background:var(--lilac)}.bg-peach{background:var(--peach)}.bg-green{background:#d9efc0}.brands{padding:42px 0}.center-title{text-align:center;margin-bottom:24px}.brand-strip{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-soft);padding:26px;display:flex;align-items:center;justify-content:center;gap:34px;flex-wrap:wrap}.brand-strip img{max-height:34px;max-width:118px;object-fit:contain;filter:grayscale(.1)}
.trust-block{padding:22px 0}.trust-grid{display:grid;grid-template-columns:1fr 1.1fr .9fr;gap:18px}.trust-card,.warehouse-card,.map-card{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-soft);overflow:hidden}.checklist{padding:30px}.checklist h2{font-size:1.7rem;margin-bottom:18px}.checklist ul{list-style:none;margin-bottom:22px}.checklist li{display:flex;gap:10px;align-items:flex-start;padding:7px 0;font-weight:700;font-size:.92rem;color:#293039}.checklist i{color:var(--green)}.warehouse-card{position:relative;min-height:245px}.warehouse-card video{width:100%;height:100%;min-height:245px;object-fit:cover}.warehouse-card span{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.92);border-radius:999px;padding:8px 14px;font-weight:900;font-size:.82rem}.map-card{background:#dff4e9;padding:34px;display:flex;flex-direction:column;justify-content:center}.map-card i{font-size:3rem;color:var(--green);margin-bottom:16px}.map-card h3{font-size:1.85rem}.map-card p{font-weight:700;color:#33423b;margin-top:10px}.own-brand{padding:34px 0}.own-brand-grid{background:linear-gradient(135deg,#edf9ee,#d6f0df);border:1px solid #c7e7d2;border-radius:30px;display:grid;grid-template-columns:1fr 440px;gap:36px;align-items:center;padding:46px var(--pad);box-shadow:var(--shadow-soft)}.own-brand h2{font-size:clamp(2.2rem,4vw,4rem);font-weight:900;margin:18px 0}.own-brand p{max-width:610px;color:#365043;font-weight:600;font-size:1.08rem}.benefit-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,210px));gap:12px;margin:26px 0}.benefit-mini-grid span{background:#fff;border-radius:16px;padding:12px 14px;font-weight:900;font-size:.88rem;box-shadow:0 6px 16px rgba(7,95,53,.07)}.benefit-mini-grid i{color:var(--green);margin-right:8px}.own-products{display:flex;flex-direction:column;align-items:center;gap:14px}.own-products img{max-height:540px;width:100%;object-fit:contain;filter:drop-shadow(0 22px 30px rgba(7,95,53,.18))}.floating-note{background:#fff;border-radius:999px;padding:12px 22px;font-family:var(--head);font-weight:900;box-shadow:var(--shadow-soft);align-self:flex-start}.why-work{padding:38px 0}.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.why-item{background:#fff;border:1px solid var(--line);border-radius:22px;padding:24px;display:flex;align-items:center;gap:15px;box-shadow:0 8px 20px rgba(10,49,58,.06)}.why-item i{width:46px;height:46px;border-radius:14px;background:#edf9f3;color:var(--green);display:grid;place-items:center;font-size:1.3rem}.why-item h3{font-size:1.04rem;font-weight:900}.testimonial-band{padding:12px 0 48px}.testimonial-inner{background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-soft);padding:28px var(--pad);display:flex;align-items:center;justify-content:space-between;gap:22px}.testimonial-inner h2{font-size:1.55rem;max-width:680px}.stars{color:#f59e0b;font-size:1.4rem;letter-spacing:2px;margin-top:8px}.avatar-row{display:flex}.avatar-row span{width:54px;height:54px;border-radius:50%;background:#edf9f3;border:3px solid #fff;margin-left:-10px;display:grid;place-items:center;color:var(--green);box-shadow:0 8px 18px rgba(0,0,0,.08)}.contact{padding:68px 0;background:linear-gradient(135deg,#07351f,#075f35);color:#fff}.contact-grid{display:grid;grid-template-columns:.8fr 1.3fr .85fr;grid-template-rows:auto 1fr;grid-template-areas:"copy form map" "actions form map";gap:28px;align-items:stretch}.contact-copy{grid-area:copy}.contact-actions{grid-area:actions}.contact-map-col{grid-area:map;align-self:center}.lead-form{grid-area:form}.contact h2{font-size:clamp(1.6rem,2.6vw,2.4rem);font-weight:900;margin:18px 0}.contact p{color:rgba(255,255,255,.72);font-size:1.05rem;max-width:520px}.contact .pill{background:rgba(255,255,255,.14);color:#c8f2d9}.contact-actions{display:flex;flex-direction:column;gap:12px;margin-top:28px}.contact-actions a,.contact-actions span{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-weight:700}.lead-form{background:#fff;color:var(--ink);border-radius:26px;padding:28px 32px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.lead-form label{font-size:.85rem;font-weight:900;color:#27313b}.lead-form input,.lead-form textarea{margin-top:7px;width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;font:inherit;background:#f8fbfa}.lead-form button{border:0;background:var(--green);color:#fff;border-radius:16px;padding:16px;font-family:var(--head);font-weight:900;font-size:1rem;cursor:pointer}.hp{display:none!important}.site-footer{background:#fff;border-top:1px solid var(--line);padding:26px 0}.footer-inner{display:flex;align-items:center;gap:18px;color:var(--muted);font-weight:700}.footer-inner img{height:38px}.mobile-sticky-cta{display:none}
@media(max-width:1050px){.hero-shell{grid-template-columns:1fr}.hero-copy{padding:54px 34px 20px}.hero-stage{min-height:420px}.product-main{right:38%;bottom:40px}.product-left{right:56%;bottom:42px}.product-right{right:12%;bottom:56px}.pet-placeholder.dog{right:22%;top:28px}.pet-placeholder.cat{right:50%;top:80px}.category-grid{grid-template-columns:repeat(2,1fr)}.trust-grid,.own-brand-grid{grid-template-columns:1fr}.contact-grid{display:flex!important;flex-direction:column!important;gap:20px}.own-brand-grid{padding:38px var(--pad)}.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){body{padding-bottom:64px}.site-header{padding:8px 14px}.header-shell{height:52px}.brand img{height:36px;mix-blend-mode:multiply}.brand-import img{height:30px}.nav-cta{display:none}.menu-button{display:grid}.main-nav{position:fixed;left:14px;right:14px;top:68px;display:none;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow)}.main-nav.is-open{display:flex}.main-nav a{color:#191d24!important;text-shadow:none!important}.hero{padding:18px 14px 20px}.hero-shell{border-radius:24px;min-height:unset}.hero-copy{padding:34px 22px 8px}.hero h1{font-size:2.35rem}.script-line{font-size:2rem}.hero-categories{font-size:.9rem}.proof-row{grid-template-columns:repeat(2,1fr);gap:10px}.proof-row div{font-size:.68rem}.hero-buttons{display:grid}.btn{width:100%}.hero-stage{min-height:330px}.pet-orb{right:-120px;top:15px;width:430px;height:300px}.pet-placeholder.dog{width:118px;height:118px;right:18px;top:28px}.pet-placeholder.cat{width:92px;height:92px;right:124px;top:70px}.pet-placeholder i{font-size:2.8rem}.product-main{max-height:150px;right:32%;bottom:36px}.product-left{max-height:130px;right:54%;bottom:38px}.product-right{max-height:128px;right:6%;bottom:44px}.stage-card{display:none}.section-title{align-items:flex-start;flex-direction:column}.category-grid{grid-template-columns:1fr 1fr;gap:10px}.category-card{height:auto!important;min-height:0!important;border-radius:18px;padding:14px 14px 0;display:flex!important;flex-direction:column!important;overflow:hidden}.category-card h3{font-size:.92rem;line-height:1.2}.category-card span{margin-top:6px;margin-bottom:10px;font-size:.75rem}.category-card img{position:static!important;display:block!important;width:100%!important;max-width:100%!important;height:115px!important;max-height:115px!important;object-fit:contain!important;object-position:center bottom!important;transform:none!important;left:auto!important;right:auto!important;margin-top:auto;align-self:center}.category-card.bg-cream img,.category-card.bg-mint img,.category-card.bg-lilac img,.category-card.bg-peach img,.category-card.bg-green img{max-height:115px!important;max-width:100%!important;left:auto!important;right:auto!important;transform:none!important}.contact-copy{order:1!important}.lead-form{order:2!important}.contact-actions{order:3!important}.contact-map{order:4!important}.brand-strip{gap:22px;padding:20px}.brand-strip img{max-height:28px;max-width:96px}.trust-grid{gap:12px}.own-brand h2,.contact h2{font-size:2.1rem}.benefit-mini-grid{grid-template-columns:1fr}.why-grid{grid-template-columns:1fr 1fr;gap:10px}.why-item{padding:16px;flex-direction:column;align-items:flex-start}.why-item h3{font-size:.9rem}.testimonial-inner{flex-direction:column;align-items:flex-start}.lead-form{grid-template-columns:1fr;padding:20px}.mobile-sticky-cta{position:fixed;display:flex;align-items:center;justify-content:center;right:18px;bottom:22px;width:58px;height:58px;background:var(--green);color:#fff;border-radius:50%;font-size:1.6rem;z-index:60;box-shadow:0 8px 24px rgba(7,95,53,.45)}}
@media(max-width:420px){.category-grid{grid-template-columns:1fr}.proof-row{grid-template-columns:1fr}.hero-stage{min-height:300px}.product-left{right:48%}.product-main{right:25%}.product-right{right:-2%}.why-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════════════════════════
   HERO — columnas + imagen que rellena la columna derecha completa
   ═══════════════════════════════════════════════════════════════ */

/* ─── Layout del card ─── */
.hero-shell{
  display: flex !important;
  flex-direction: row;
  align-items: stretch;
  min-height: 560px;
  overflow: visible;               /* la imagen desborda por la derecha */
  position: relative;
  /* clip solo el interior del card (izq/arriba/abajo), derecha libre */
  clip-path: inset(0 -60px 0 0 round 30px);
}

/* Columna izquierda: copy */
.hero-copy{
  flex: 1 1 52%;
  padding: 60px 40px 60px 52px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 2;
}

/* Columna derecha: contexto de posicionamiento */
.hero-stage{
  flex: 0 0 50%;
  position: relative;
  overflow: visible;               /* la imagen sale por la derecha */
  min-height: 0;
}

/* Blob circular de fondo */
.hero-visual-blob{
  position: absolute;
  width: 80%;
  height: 84%;
  left: 8%;
  top: 50%;
  transform: translateY(-50%);
  background: radial-gradient(circle at 50% 45%, #ceeedd 0%, #b8e5cc 55%, transparent 75%);
  border-radius: 50%;
  z-index: 0;
}

/* Imagen PNG (fondo transparente): centrada verticalmente, desborda derecha */
.hero-main-image{
  position: absolute;
  top: 50%;
  left: -2%;
  transform: translateY(-50%);
  width: 115%;                     /* 15% extra desborda por la derecha */
  height: auto;
  object-fit: contain;
  z-index: 1;
  display: block;
  filter: drop-shadow(0 24px 32px rgba(10,40,20,.10));
}

/* ── Tablet (≤ 1050px) ── */
@media(max-width:1050px){
  .hero-shell{
    flex-direction: column !important;
    min-height: unset;
    overflow: hidden !important;
  }
  .hero-copy{
    padding: 48px 34px 24px;
    flex: unset;
  }
  .hero-stage{
    flex: unset;
    height: 420px;
    overflow: hidden;
  }
  .hero-main-image{
    width: 100%;
    left: 0;
    object-position: center bottom;
  }
}

/* ── Móvil (≤ 760px) ── */
@media(max-width:760px){
  .hero-stage{
    order: -1;
    height: 260px;
  }
  .hero-copy{
    padding: 24px 22px 32px;
  }
}

/* ── Teléfono pequeño (≤ 420px) ── */
@media(max-width:420px){
  .hero-stage{ height: 220px; }
}

/* ── Sección contacto: H2 compacto ── */
.contact h2{font-size:clamp(1.6rem,2.6vw,2.4rem)!important;}

/* ── Botones sociales ── */
.contact-social-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:18px 0 12px}
.social-btn-wa,.social-btn-ig,.social-btn-em{display:flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;padding:10px 14px;text-decoration:none;transition:.2s ease;font-family:var(--head)}
.social-btn-wa{background:#22c55e;color:#fff}
.social-btn-wa:hover{background:#16a34a;transform:translateY(-2px)}
.social-btn-ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff}
.social-btn-ig:hover{opacity:.9;transform:translateY(-2px)}
.social-btn-em{background:rgba(255,255,255,.18);color:#fff;border:1.5px solid rgba(255,255,255,.35);grid-column:1/-1;justify-self:center;width:62%}
.social-btn-em:hover{background:rgba(255,255,255,.28);transform:translateY(-2px)}
.social-btn-wa i,.social-btn-ig i,.social-btn-em i{font-size:1.15rem;flex-shrink:0}
.social-btn-wa span,.social-btn-ig span,.social-btn-em span{display:flex;flex-direction:column;line-height:1.2;text-align:left}
.social-btn-wa strong,.social-btn-ig strong,.social-btn-em strong{font-size:.78rem;white-space:nowrap}
.social-btn-wa small,.social-btn-ig small,.social-btn-em small{font-size:.68rem;opacity:.85;white-space:nowrap}

/* ── Fila inferior: datos + mapa al mismo nivel ── */
.contact-bottom-row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch;
}
.contact-details{
  display:flex;flex-direction:column;justify-content:center;gap:10px;
}
.contact-details a{
  display:inline-flex;align-items:center;gap:9px;
  color:rgba(255,255,255,.8);font-weight:600;font-size:.85rem;
}
.contact-details a:hover{color:#fff;}
.contact-details i{width:16px;text-align:center;color:rgba(255,255,255,.55);}
.contact-map{
  border-radius:16px;overflow:hidden;
  border:1px solid rgba(255,255,255,.15);
  box-shadow:0 8px 28px rgba(0,0,0,.28);
  min-height:0;
  align-self:stretch;
}
.contact-map iframe{
  width:100%;height:260px;display:block;
}

/* ── Ajuste imágenes por categoría ── */

/* Arenas para gatos */
.category-card.bg-cream img{
  max-height: 148px;
  max-width: 90%;
  right: -6px;
  bottom: 0;
}

/* PoopBags y Toallitas */
.category-card.bg-mint img{
  max-height: 145px;
  max-width: 82%;
  right: -4px;
  bottom: 0;
}

/* Training Pads y Pañales */
.category-card.bg-lilac img{
  max-height: 155px;
  max-width: 90%;
  left: 50%;
  right: auto;
  transform: translateX(-46%);
  bottom: 0;
}

/* Baño y Aseo en Casa */
.category-card.bg-peach img{
  max-height: 165px;
  max-width: 95%;
  left: 50%;
  right: auto;
  transform: translateX(-48%);
  bottom: 0;
}

/* Grooming Profesional */
.category-card.bg-green img{
  max-height: 155px;
  max-width: 95%;
  left: 50%;
  right: auto;
  transform: translateX(-48%);
  bottom: 0;
}

/* ── Selector código de país ── */
.phone-label{}
.phone-row{display:flex;gap:8px;margin-top:7px}
.phone-code{flex:0 0 auto;border:1px solid var(--line);border-radius:14px;padding:13px 10px;font:inherit;background:#f8fbfa;cursor:pointer;font-size:.88rem}
.phone-number{flex:1 1 auto;border:1px solid var(--line);border-radius:14px;padding:13px 14px;font:inherit;background:#f8fbfa;min-width:0}
.phone-code:focus,.phone-number:focus{outline:2px solid var(--green);outline-offset:1px}

/* ── Mensajes de feedback del formulario ── */
.form-msg{display:none;grid-column:1/-1;border-radius:12px;padding:12px 16px;font-weight:700;font-size:.88rem}
.form-msg--ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.form-msg--error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}

/* ── Input error highlight ── */
input:invalid:not(:placeholder-shown),
textarea:invalid:not(:placeholder-shown){border-color:#f87171}

/* ── Columna mapa + info ── */
.contact-map-col{display:flex;flex-direction:column;gap:12px}
.map-info-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:12px 16px;display:flex;flex-direction:column;gap:6px}
.map-info-line{display:flex;align-items:flex-start;gap:9px;font-size:.78rem;font-weight:600;color:rgba(255,255,255,.8);line-height:1.4;white-space:nowrap}
.map-info-line i{color:rgba(255,255,255,.5);margin-top:2px;flex-shrink:0;width:13px;text-align:center}
.map-info-line span{white-space:normal;line-height:1.35}
.map-info-line small{font-size:.75rem;opacity:.85;display:block}

/* ── Footer alias ── */
.footer-alias{font-size:.75rem;color:var(--muted);margin-top:6px}

/* ── FAQ ── */
.faq-section{padding:72px 0;background:var(--bg)}
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:box-shadow .2s}
.faq-item:hover{box-shadow:var(--shadow-soft)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;font-size:1rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;font-weight:400;color:var(--green);flex-shrink:0;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open]{border-color:var(--green)}
.faq-item p{padding:0 24px 20px;color:var(--soft-ink);font-size:.93rem;line-height:1.65;margin:0}

/* ── Custom flag dropdown ── */
.flag-select{position:relative;flex-shrink:0}
.flag-select-btn{display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:14px;padding:13px 12px;background:#f8fbfa;cursor:pointer;font-size:.88rem;white-space:nowrap;color:var(--ink);transition:.15s ease;height:100%}
.flag-select-btn:hover{border-color:#a7c4b5}
.flag-img{width:22px;height:16px;object-fit:cover;border-radius:2px;flex-shrink:0}
.flag-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:200;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 16px 40px rgba(0,0,0,.13);width:270px;overflow:hidden}
.flag-search-wrap{padding:10px 10px 8px;border-bottom:1px solid var(--line)}
.flag-search-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:8px 12px;font:inherit;font-size:.85rem;outline:none}
.flag-search-input:focus{border-color:var(--green)}
.flag-list{max-height:230px;overflow-y:auto;margin:0;padding:5px 0;list-style:none}
.flag-list li{display:flex;align-items:center;gap:10px;padding:7px 14px;cursor:pointer;font-size:.84rem;transition:.1s}
.flag-list li:hover{background:#f0fdf4}
.flag-list li.selected{background:#e8f9ef}
.flag-list li .fl-name{flex:1;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.flag-list li .fl-code{color:var(--green);font-weight:700;font-size:.78rem;flex-shrink:0}
