/* ===========================================================
   Fiestas de Matrimonio — réplica del diseño en producción
   (WordPress / theme Ekko). Paleta dorado #C2A070 + Prata/Jost.
   =========================================================== */
:root{
  --gold:#C2A070; --gold-d:#a8854f; --gold-soft:#e7d8bf;
  --ink:#1c1c1c; --txt:#6f6f6f; --muted:#9a948c;
  --bg:#ffffff; --bg-soft:#faf8f5; --line:#ece6dd; --dark:#1a1a1a;
  --maxw:1200px;
  --fdisplay:'Prata',Georgia,serif;
  --fbody:'Jost',system-ui,-apple-system,'Segoe UI',sans-serif;
  --shadow:0 14px 40px -22px rgba(40,28,12,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--fbody);font-weight:300;color:var(--txt);background:var(--bg);
  font-size:16px;line-height:1.8;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--fdisplay);font-weight:400;color:var(--ink);line-height:1.22;margin:0 0 .5em}
h2{font-size:clamp(1.9rem,3.6vw,2.7rem)}
h3{font-size:1.4rem}
p{margin:0 0 1.1em}
.center{text-align:center}
.sec{padding:clamp(3.2rem,6.5vw,5.5rem) 0}
.sec-soft{background:var(--bg-soft)}
.sec-head{max-width:660px;margin:0 auto 3rem;text-align:center}
.sec-head p{color:var(--txt)}
.gold{color:var(--gold-d)}

/* ── Botones estilo Ekko ── */
.btn{display:inline-block;font-family:var(--fbody);font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;font-size:.74rem;padding:1.05em 2.2em;border:1px solid var(--gold);
  color:var(--gold-d);background:transparent;cursor:pointer;transition:.3s;border-radius:2px}
.btn:hover{background:var(--gold);color:#fff}
.btn-solid{background:var(--gold);color:#fff}
.btn-solid:hover{background:var(--gold-d);border-color:var(--gold-d)}
.btn-light{border-color:#fff;color:#fff}
.btn-light:hover{background:#fff;color:var(--ink)}

/* ── Top bar contacto ── */
.topbar{background:transparent;color:#fff;font-size:.82rem;font-weight:300;position:absolute;top:0;left:0;right:0;z-index:40}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:.6rem;padding-bottom:.6rem}
.topbar a{color:rgba(255,255,255,.85)}
.topbar a:hover{color:var(--gold-soft)}
.topbar .tb-left{display:flex;gap:1.6rem;flex-wrap:wrap}
.topbar .tb-left span{display:inline-flex;align-items:center;gap:.45em}
.topbar .tb-social{display:flex;gap:.9rem}
.topbar svg{width:15px;height:15px;fill:currentColor;vertical-align:middle}

/* ── Header / nav (transparente sobre hero -> blanco al scroll) ── */
.site-head{position:absolute;top:38px;left:0;right:0;z-index:45;transition:.35s}
.site-head.fixed{position:fixed;top:0;background:#fff;box-shadow:0 4px 24px -14px rgba(0,0,0,.3)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.85rem 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{height:46px;width:auto;display:block}
.brand .rings{width:46px;height:30px;flex:0 0 auto}
.brand .rings circle{fill:none;stroke:var(--gold);stroke-width:2.4}
.brand-txt b{font-family:var(--fdisplay);font-weight:400;font-size:1.02rem;letter-spacing:.06em;line-height:1.05;display:block;color:#fff;transition:.35s}
.brand-txt span{font-family:var(--fbody);font-size:.62rem;letter-spacing:.34em;color:var(--gold-soft);text-transform:uppercase}
.site-head.fixed .brand-txt b{color:var(--ink)}
.nav-links{display:flex;align-items:center;gap:1.9rem;list-style:none;margin:0;padding:0}
.nav-links a{font-family:var(--fbody);font-weight:400;font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;color:#fff;transition:.25s}
.site-head.fixed .nav-links a{color:var(--ink)}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.site-head.fixed .nav-links a:hover,.site-head.fixed .nav-links a.active{color:var(--gold-d)}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;color:#fff;cursor:pointer;line-height:1}
.site-head.fixed .nav-toggle{color:var(--ink)}
.nav-backdrop{display:none}

/* ── Hero con rotador ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
/* Fondo de video YouTube (cover, sin bandas negras) + póster de respaldo */
.hero-yt{position:absolute;inset:0;z-index:0;overflow:hidden;background-size:cover;background-position:center}
.hero-yt iframe{position:absolute;top:50%;left:50%;width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;
  transform:translate(-50%,-50%);border:0;pointer-events:none}
/* Video nativo del hero: oculto en desktop (allí manda el iframe de YouTube) */
.hero-vid{display:none;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0;pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.5);z-index:1}
.hero .wrap{position:relative;z-index:2}
.hero-wave{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:8vw;min-height:48px;max-height:90px;z-index:3;display:block;fill:var(--bg)}
.rotator{position:relative;height:1.3em;margin:0 auto .4em;display:flex;align-items:center;justify-content:center}
.rotator span{position:absolute;font-family:var(--fdisplay);font-size:clamp(2.4rem,6vw,4.5rem);color:#fff;opacity:0;
  transition:opacity .8s;line-height:1.2;white-space:nowrap}
.rotator span.on{opacity:1}
.hero .lead{font-size:clamp(1rem,1.6vw,1.18rem);max-width:42ch;margin:0 auto 2.2rem;color:rgba(255,255,255,.92);font-weight:300}
.hero-title{font-family:var(--fdisplay);font-weight:400;color:#fff;margin:0 auto .8rem;font-size:clamp(2.4rem,6vw,4.5rem);line-height:1.06;overflow-wrap:break-word}

/* ── Social fijo lateral ── */
.side-social{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column}
.side-social a{width:46px;height:46px;display:flex;align-items:center;justify-content:center;transition:.25s}
.side-social a svg{width:20px;height:20px;fill:#fff}
.ss-fb{background:#1877f2}.ss-ig{background:radial-gradient(circle at 30% 110%,#fdc468,#df4996 45%,#7a3bb8)}.ss-tt{background:#111}
.side-social a:hover{filter:brightness(1.12)}

/* ── 3 cards superpuestas ── */
.feature-cards{margin-top:-90px;position:relative;z-index:10}
.fc-grid{display:flex;gap:26px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.fc-grid::-webkit-scrollbar{display:none}
.fcard{flex:0 0 calc((100% - 52px)/3);scroll-snap-align:center;background:#fff;box-shadow:var(--shadow);border-radius:3px;overflow:hidden;text-align:center;display:flex;flex-direction:column}
.fcard img{width:100%;height:190px;object-fit:cover}
.fcard .fc-body{padding:2rem 1.6rem 2.2rem;display:flex;flex-direction:column;flex:1}
.fcard h3{margin-bottom:.6rem}
.fcard p{color:var(--txt);font-size:.96rem;flex:1}
.fcard .btn{align-self:center;margin-top:1.1rem}
/* Flechas del carrusel de tarjetas (solo se muestran en móvil) */
.fc-nav{display:none;justify-content:center;gap:1rem;margin-top:1.6rem}
.fc-nav button{width:46px;height:46px;border-radius:50%;border:1px solid var(--gold);background:#fff;color:var(--gold);cursor:pointer;font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:.2s}
.fc-nav button:active,.fc-nav button:hover{background:var(--gold);color:#fff}

/* ── Coordinación: tabs izq + imagen der ── */
.coord{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.coord-tabs{display:flex;flex-direction:column;gap:1rem}
.coord-tab{border:1px solid var(--line);border-radius:40px;padding:1rem 1.6rem;transition:.3s;cursor:default;background:#fff}
.coord-tab.active{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:var(--shadow)}
.coord-tab b{font-family:var(--fdisplay);font-weight:400;font-size:1.15rem;display:block;color:var(--ink)}
.coord-tab.active b{color:#fff}
.coord-tab p{margin:.4rem 0 0;font-size:.92rem}
.coord-tab.active p{color:rgba(255,255,255,.9)}
.coord-img{border-radius:3px;overflow:hidden}
.coord-img img{width:100%;height:100%;max-height:460px;object-fit:cover}

/* ── Servicios icon grid ── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc{background:#fff;text-align:center;padding:3rem 2rem}
.svc .ico{width:64px;height:64px;margin:0 auto 1.3rem;color:var(--gold)}
.svc .ico svg{width:100%;height:100%;fill:none;stroke:var(--gold);stroke-width:1.4}
.svc h3{margin-bottom:.5rem}
.svc p{color:var(--txt);font-size:.95rem;margin:0}

/* ── Banda oscura "a tu lado" ── */
.band{position:relative;color:#fff;text-align:center;overflow:hidden}
.band-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.band::after{content:"";position:absolute;inset:0;background:rgba(15,12,8,.7);z-index:1}
.band .wrap{position:relative;z-index:2;padding:clamp(4rem,8vw,7rem) 24px}
.band h2{color:#fff}
.band p{max-width:54ch;margin:0 auto 2rem;color:rgba(255,255,255,.88)}

/* ── Texto SEO ── */
.seo-text{max-width:920px;margin:0 auto;text-align:center}
.seo-text h2{margin-bottom:1.4rem}
.seo-text p{text-align:justify;color:var(--txt);font-size:1rem}

/* ── Galería ── */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.55rem}
.gallery a{display:block;overflow:hidden;border-radius:2px;aspect-ratio:1/1}
.gallery img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery a:hover img{transform:scale(1.07)}

/* ── FAQ ── */
.faq{max-width:820px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:1.15rem 0}
.faq summary{font-family:var(--fdisplay);font-size:1.12rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold-d);font-size:1.4rem}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:.9rem 0 0;color:var(--txt)}

/* ── Página interna ── */
.page-hero{position:relative;color:#fff;text-align:center;padding:0;min-height:46vh;display:flex;align-items:center;justify-content:center}
.page-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.page-hero::after{content:"";position:absolute;inset:0;background:rgba(15,12,8,.6);z-index:1}
.page-hero .wrap{position:relative;z-index:2;padding-top:140px;padding-bottom:60px}
.page-hero h1{color:#fff;max-width:20ch;margin:0 auto .4rem}
.page-hero .crumbs{color:rgba(255,255,255,.8)}
.page-hero .crumbs a{color:var(--gold-soft)}
.prose{max-width:820px;margin:0 auto}
.prose h2{margin-top:2.2rem}
.prose h3{margin-top:1.6rem;color:var(--gold-d)}
.prose p{color:var(--txt)}
.prose ul{padding-left:1.2rem}.prose li{margin-bottom:.5rem;color:var(--txt)}
.related{background:var(--bg-soft)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.rel{display:block;padding:1.2rem 1.4rem;background:#fff;border:1px solid var(--line);border-radius:3px;transition:.25s}
.rel:hover{border-color:var(--gold);box-shadow:var(--shadow)}
.rel b{font-family:var(--fdisplay);font-weight:400;font-size:1.05rem;display:block;color:var(--ink)}
.rel span{font-size:.82rem;color:var(--gold-d);letter-spacing:.12em;text-transform:uppercase}

/* ── Footer ── */
.site-foot{background:#fff;border-top:1px solid var(--line);padding:3rem 0 1.4rem;text-align:center}
.foot-logo{height:54px;margin:0 auto 1rem;width:auto}
.site-foot .rights{font-size:.85rem;color:var(--muted);margin-bottom:1.5rem;letter-spacing:.04em}
.baen-net{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem 1.1rem;font-size:.82rem;border-top:1px solid var(--line);padding-top:1.4rem;max-width:980px;margin:0 auto}
.baen-net a{color:var(--txt)}
.baen-net a:hover{color:var(--gold-d)}
.foot-socials{display:flex;justify-content:center;gap:.9rem;margin:1.2rem 0}
.foot-socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.foot-socials a svg{width:17px;height:17px;fill:var(--txt)}
.foot-socials a:hover{background:var(--gold);border-color:var(--gold)}
.foot-socials a:hover svg{fill:#fff}

/* ── Flotantes ── */
.wa-pill{position:fixed;left:18px;bottom:18px;z-index:60;background:#25D366;color:#fff;border-radius:40px;
  padding:.7em 1.3em .7em .9em;display:inline-flex;align-items:center;gap:.5em;font-size:.92rem;
  box-shadow:0 10px 28px -10px rgba(0,0,0,.4);transition:.25s}
.wa-pill:hover{transform:translateY(-2px)}
.wa-pill svg{width:24px;height:24px;fill:#fff}
.call-float{position:fixed;right:18px;bottom:18px;z-index:60;width:56px;height:56px;background:var(--gold);
  border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px -10px rgba(0,0,0,.4);transition:.25s}
.call-float:hover{background:var(--gold-d)}
.call-float svg{width:26px;height:26px;fill:#fff}

/* ===========================================================
   REDISEÑO — vocabulario de componentes utilitarios
   (eyebrow / grid / card / split / stats / bandas)
   =========================================================== */
section{padding:clamp(3.2rem,6.5vw,5.5rem) 0}
.eyebrow{display:inline-block;font-family:var(--fbody);font-weight:500;font-size:.72rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold-d);margin-bottom:.9rem}
.lead{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--txt);font-weight:300;line-height:1.75}

/* Botón dorado sólido (alias semántico de btn-solid) */
.btn-gold{background:var(--gold);border-color:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-d);border-color:var(--gold-d);color:#fff}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:.4rem}

/* El hero del rediseño: titular grande sobre imagen */
.hero h1{font-size:clamp(2.4rem,6vw,4.3rem);color:#fff;max-width:16ch;margin:0 auto .6rem}
.hero .eyebrow{color:var(--gold-soft)}

/* Secciones con fondo alterno / oscuro */
.alt{background:var(--bg-soft)}
.ink-bg{background:var(--dark)}
.ink-bg h2{color:#fff}
.ink-bg .lead{color:rgba(255,255,255,.78)}

/* Split a dos columnas (texto + imagen) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split img{border-radius:4px;width:100%;height:100%;max-height:560px;object-fit:cover;box-shadow:var(--shadow)}

/* Cifras destacadas */
.stats{display:flex;gap:2.6rem;margin-top:2.2rem;flex-wrap:wrap}
.stat b{font-family:var(--fdisplay);font-weight:400;font-size:2.3rem;color:var(--gold-d);display:block;line-height:1}
.stat span{font-size:.84rem;color:var(--muted);letter-spacing:.04em}

/* Grids reutilizables */
.grid{display:grid;gap:1.6rem}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* Tarjetas (servicios / blog) */
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:4px;overflow:hidden;transition:.3s;box-shadow:0 2px 12px -9px rgba(40,28,12,.3)}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--gold-soft)}
.card img{width:100%;height:210px;object-fit:cover}
.card-body{padding:1.7rem 1.6rem 1.9rem;display:flex;flex-direction:column;flex:1}
.card-body h3{margin-bottom:.55rem}
.card-body p{color:var(--txt);font-size:.95rem;flex:1;margin-bottom:1rem}
.more{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-d);font-weight:500}

/* Tarjetas tipo "feature" sin imagen (proceso / tipos de boda) */
.icon-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;padding:2rem 1.7rem}
.icon-card h3{margin-bottom:.5rem;font-size:1.25rem}
.icon-card p{color:var(--txt);font-size:.94rem;margin:0}

/* Banda CTA oscura */
.cta-band{background:var(--dark);color:#fff;text-align:center;border-radius:6px}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.82);max-width:56ch;margin-left:auto;margin-right:auto}

/* ── Formulario de contacto ── */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form{display:grid;gap:1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form label{display:block;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.35rem}
.form input,.form textarea{width:100%;font-family:var(--fbody);font-size:1rem;color:var(--ink);
  padding:.85rem 1rem;border:1px solid var(--line);border-radius:3px;background:#fff;transition:.2s}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,160,112,.15)}
.form textarea{min-height:130px;resize:vertical}
.form .hp{position:absolute;left:-9999px}
.contact-info{background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;padding:2rem 1.8rem}
.contact-info h3{margin-bottom:1.2rem}
.contact-info .ci{display:flex;gap:.8rem;align-items:flex-start;margin-bottom:1.1rem;font-size:.96rem;color:var(--txt)}
.contact-info .ci svg{width:20px;height:20px;fill:var(--gold-d);flex:0 0 auto;margin-top:.15rem}
.contact-info .ci a{color:var(--txt)}.contact-info .ci a:hover{color:var(--gold-d)}
.alert{padding:1rem 1.2rem;border-radius:3px;margin-bottom:1rem;font-size:.95rem}
.alert-ok{background:#e8f6ec;border:1px solid #9ed5af;color:#1d6b34}
.alert-err{background:#fbecec;border:1px solid #e0a3a3;color:#9a2a2a}

/* ── Responsive ── */
@media(max-width:900px){
  /* En móvil el iframe de YouTube no hace autoplay → usamos el <video> nativo */
  .hero-embed{display:none}
  .hero-vid{display:block}
  .contact-grid{grid-template-columns:1fr}
  .grid.g-3,.grid.g-4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .split img{max-height:340px}
  .svc-grid,.related-grid{grid-template-columns:1fr}
  /* Tarjetas como carrusel deslizable (swipe) en móvil */
  .fcard{flex:0 0 86%}
  .fc-nav{display:flex}
  .coord{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .feature-cards{margin-top:-60px}
  /* En móvil el topbar se ocultaba a sí mismo encima del logo: lo quitamos y subimos el header */
  .topbar{display:none}
  .site-head{top:0}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,320px);background:#fff;flex-direction:column;
    align-items:flex-start;padding:5.5rem 2rem;gap:1.4rem;transform:translateX(100%);transition:transform .3s;box-shadow:var(--shadow);z-index:55}
  body.nav-open .nav-links{transform:translateX(0)}
  .nav-links a{color:var(--ink)!important}
  body.nav-open .site-head{z-index:56}  /* sube todo el header sobre el backdrop para que la ✕ sea tocable */
  .nav-toggle{display:block;position:relative;z-index:60}
  .nav-toggle .nt-close{display:none}
  body.nav-open .nav-toggle{color:var(--ink)}
  body.nav-open .nav-toggle .nt-open{display:none}
  body.nav-open .nav-toggle .nt-close{display:inline}
  .nav-backdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;visibility:hidden;transition:.3s;z-index:54}
  body.nav-open .nav-backdrop{opacity:1;visibility:visible}
  body.nav-open{overflow:hidden}
  /* Redes centradas verticalmente a la derecha (igual que producción) */
  .side-social a{width:40px;height:40px}
}
@media(max-width:560px){
  .grid.g-3,.grid.g-4{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .stats{gap:1.6rem}
  .gallery{grid-template-columns:1fr 1fr}
  .topbar .tb-left span:nth-child(1){display:none}
  .wa-pill span{display:none}
  /* ── Logo legible y compacto en móvil + dejar aire para el ☰ ── */
  .nav{padding:.7rem 16px;gap:.8rem}
  .brand-logo{height:38px}
  .nav-toggle{font-size:1.9rem}
  /* WhatsApp como botón circular en móvil (sin el texto) */
  .wa-pill{width:56px;height:56px;padding:0;border-radius:50%;justify-content:center;gap:0}
  .wa-pill svg{margin:0}
  /* Título del hero sin desbordar el viewport */
  .hero-title{font-size:clamp(2rem,9vw,2.7rem)}
  .hero .lead{font-size:1rem}
}
@media(max-width:380px){
  .brand-logo{height:34px}
}

/* ===========================================================
   Páginas internas — alineadas al look de producción
   (reutilizan .coord/.fcard/.svc-grid/.band/.seo-text/.rel)
   =========================================================== */
.rel p{margin:.5rem 0 0;color:var(--txt);font-size:.95rem}
.rel{cursor:default}
a.rel-link{cursor:pointer;text-decoration:none}
a.rel-link b{transition:color .2s}
a.rel-link:hover b{color:var(--gold-d)}
.coord.no-tabs{align-items:center}
.coord .lead{color:var(--txt)}
.svc .svc-sub{display:block;margin-top:.2rem}
.band .btn{margin-top:1.4rem}
.page-hero .crumbs span{color:rgba(255,255,255,.92)}
/* Formulario de contacto sobre look producción */
.contact-grid{align-items:start}

/* ── Menú "Servicios" desplegable ───────────────────────────── */
.has-sub{position:relative}
.has-sub>a .caret{font-size:.7em;margin-left:.18em;opacity:.85}
.sub{position:absolute;top:100%;left:0;min-width:248px;background:#fff;list-style:none;margin:0;padding:.5rem 0;
  border-radius:7px;box-shadow:0 14px 38px rgba(40,28,12,.16);opacity:0;visibility:hidden;transform:translateY(9px);
  transition:.22s;z-index:60}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateY(0)}
.sub li{display:block}
.sub a{display:block;padding:.56rem 1.15rem;font-size:.73rem;letter-spacing:.07em;color:var(--ink)!important;
  text-transform:none;white-space:nowrap}
.sub a:hover{background:#faf6ef;color:var(--gold-d)!important}

/* ── Footer con columnas de enlaces ─────────────────────────── */
.foot-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;max-width:1000px;margin:0 auto 2.6rem;
  text-align:left;padding-bottom:2.2rem;border-bottom:1px solid var(--line)}
.fcol h4{font-family:var(--fdisplay);font-weight:400;font-size:1.06rem;color:var(--ink);margin:0 0 .85rem;letter-spacing:.03em}
.fcol a{display:block;font-size:.85rem;color:var(--muted);padding:.3rem 0;transition:.2s}
.fcol a:hover{color:var(--gold-d);padding-left:4px}
@media(max-width:760px){.foot-cols{grid-template-columns:repeat(2,1fr);gap:1.6rem 1.2rem}}
@media(max-width:430px){.foot-cols{grid-template-columns:1fr;gap:1.3rem;text-align:center}.fcol a:hover{padding-left:0}}

/* ── Submenú en panel móvil: inline, siempre visible ────────── */
@media(max-width:900px){
  .nav-links{overflow-y:auto}
  .sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;min-width:0;
    padding:.1rem 0 .5rem;background:transparent;border-radius:0}
  .sub a{padding:.5rem 0 .5rem 1.1rem;font-size:.78rem;color:var(--muted)!important;letter-spacing:.04em}
  .has-sub>a .caret{display:none}
}
