/* belleza-mpa — multipágina editorial (molde signature de salonapp adaptado a
 * webonly: render SSR de listas). Tokens --color-* / --font-* inyectados por SSR
 * desde el manifest. Hereda resets de /css/base.css. Reveal: app-core añade .visible. */

:root { --ease: cubic-bezier(.16,1,.3,1); --radius: 16px; --shadow: 0 30px 60px -34px rgba(20,16,12,.45); --maxw: 1280px; }

body { background: var(--color-bg); color: var(--color-fg); font-family: var(--font-body); line-height: 1.6; }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(1.5rem, 3vw, 3rem); }
h1,h2,h3 { font-family: var(--font-heading); font-weight: 600; line-height: 1.06; letter-spacing: -0.01em; }
h2 { font-size: clamp(2rem, 4.2vw, 3.1rem); }
a { color: inherit; text-decoration: none; }
.eyebrow { display: inline-block; font-family: var(--font-body); font-size: .76rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--color-accent); margin-bottom: 1rem; }
.eyebrow.light { color: rgba(255,255,255,.82); }
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 1rem; top: 1rem; background: #fff; padding: .6rem 1rem; z-index: 200; border-radius: 6px; }

/* ── Botones ── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; font-family: var(--font-body); font-weight: 600; font-size: .92rem; letter-spacing: .02em; padding: .85rem 1.6rem; border-radius: 4px; border: 1.5px solid transparent; cursor: pointer; transition: transform .18s var(--ease), background .18s, color .18s; background: var(--color-accent); color: #fff; }
.btn:hover { transform: translateY(-2px); background: var(--color-accent-soft); color: #fff; text-decoration: none; }
.btn-glass { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.4); color: #fff; backdrop-filter: blur(6px); }
.btn-glass:hover { background: rgba(255,255,255,.22); }
.btn-light { background: var(--color-bg); color: var(--color-fg); }
.btn-light:hover { background: #fff; color: var(--color-fg); }
.link-arrow { display: inline-flex; align-items: center; gap: .35rem; font-weight: 600; color: var(--color-accent); margin-top: 1.2rem; }
.link-arrow:hover { color: var(--color-accent-soft); text-decoration: none; }

/* ── Nav ── */
.nav { position: sticky; top: 0; z-index: 100; background: color-mix(in srgb, var(--color-bg) 85%, transparent); backdrop-filter: blur(10px); border-bottom: 1px solid transparent; transition: border-color .25s, background .25s; }
.nav.is-scrolled { border-bottom-color: var(--color-border); background: color-mix(in srgb, var(--color-bg) 94%, transparent); }
.nav-inner { display: flex; align-items: center; gap: 1.5rem; height: 74px; }
.nav-logo { font-family: var(--font-heading); font-size: 1.5rem; font-weight: 600; color: var(--color-fg); }
.nav-logo:hover { color: var(--color-accent); text-decoration: none; }
.nav-menu { display: flex; gap: .35rem; margin-left: auto; }
.nav-menu a { padding: .5rem .8rem; border-radius: 6px; font-size: .9rem; font-weight: 600; color: var(--color-fg-muted); transition: color .15s, background .15s; }
.nav-menu a:hover { color: var(--color-fg); background: var(--color-surface); text-decoration: none; }
.nav-menu a[aria-current="page"] { color: var(--color-accent); }
.nav-right { display: flex; align-items: center; gap: 1rem; }
.nav-social { display: flex; gap: 8px; }
.nav-social a { color: var(--color-fg-muted); display: inline-flex; } .nav-social a:hover { color: var(--color-accent); } .nav-social svg { width: 18px; height: 18px; }
.nav-book-btn { font-weight: 600; font-size: .85rem; background: var(--color-fg); color: var(--color-bg); border: none; border-radius: 4px; padding: .65rem 1.2rem; cursor: pointer; transition: background .18s; }
.nav-book-btn:hover { background: var(--color-accent); color: #fff; text-decoration: none; }
.nav-hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 10px; margin-left: auto; }
.nav-hamburger span { width: 24px; height: 2px; background: var(--color-fg); display: block; }
.mobile-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45); z-index: 90; }
.mobile-menu { position: fixed; top: 0; right: 0; bottom: 0; width: min(82vw, 320px); background: var(--color-bg); z-index: 95; padding: 84px 1.5rem 1.5rem; display: flex; flex-direction: column; gap: 1rem; box-shadow: -8px 0 40px rgba(0,0,0,.18); }
.mobile-menu a { font-family: var(--font-heading); font-size: 1.5rem; color: var(--color-fg); }
.mobile-menu a[aria-current="page"] { color: var(--color-accent); }
.mobile-book-btn { margin-top: auto; background: var(--color-accent); color: #fff; border: none; border-radius: 4px; padding: .9rem; font-weight: 600; text-align: center; }

/* ── Hero ── */
.hero { position: relative; display: flex; align-items: flex-end; overflow: hidden; color: #fff; background: var(--color-fg); }
.hero-full { min-height: calc(100svh - 74px); }
.hero-page { min-height: 52vh; }
.hero-bg { position: absolute; inset: -6% 0; background-size: cover; background-position: center; transform: scale(1.05); animation: heroIn 1.4s var(--ease) forwards; }
@keyframes heroIn { from { opacity: 0; transform: scale(1.1); } to { opacity: 1; transform: scale(1.05); } }
.hero-veil { position: absolute; inset: 0; background: linear-gradient(to top, rgba(20,16,12,.88), rgba(20,16,12,.28) 55%, transparent 86%), linear-gradient(to right, rgba(20,16,12,.6), transparent 62%); }
.hero-inner { position: relative; z-index: 2; width: 100%; padding-top: 6rem; padding-bottom: clamp(3rem, 9vh, 6.5rem); }
.hero-copy { max-width: 62rem; }
.hero-copy h1 { font-size: clamp(3rem, 8.5vw, 6.4rem); margin-bottom: 1.3rem; text-wrap: balance; color: #fff; }
.hero-copy p { font-size: clamp(1.1rem, 1.9vw, 1.4rem); color: rgba(255,255,255,.9); max-width: 42rem; }
.hero-page .hero-copy h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.4rem; }
.hero-actions .btn { padding: 1.05rem 2.4rem; font-size: 1.05rem; border-radius: 5px; }

/* ── Secciones ── */
.section { padding: clamp(3.5rem, 8vw, 6.5rem) 0; }
.section.alt { background: var(--color-surface); }
.sec-head { max-width: 60ch; margin: 0 0 clamp(2rem, 4vw, 3rem); }
.sec-head p { color: var(--color-fg-muted); font-size: 1.05rem; margin-top: .7rem; }
.band { max-width: 760px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; }
.band p { color: var(--color-fg-muted); font-size: 1.08rem; margin-top: .7rem; }

/* ── Split (sobre) ── */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.split-media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius); box-shadow: var(--shadow); }
.split-copy h2 { margin-bottom: 1rem; }
.split-copy p { color: var(--color-fg-muted); font-size: 1.08rem; }
.split-copy p::first-letter { font-family: var(--font-heading); font-size: 3rem; float: left; line-height: .82; padding: 6px 12px 0 0; color: var(--color-accent); }

/* ── Servicios (zigzag SSR de webonly) ── */
.zigzag { display: flex; flex-direction: column; gap: clamp(3rem, 7vw, 6rem); }
.zigzag-item { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: center; }
.zigzag-item:nth-child(even) { grid-template-columns: 1.2fr .8fr; }
.zigzag-item:nth-child(even) .zigzag-photo { order: 2; }
.zigzag-item:nth-child(even) .zigzag-text { text-align: right; justify-self: end; }
.zigzag-photo { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.zigzag-photo img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.zigzag-photo--empty { aspect-ratio: 4/3; background: var(--color-surface); }
.zigzag-text { max-width: 60ch; }
.zigzag-title { font-size: clamp(1.9rem, 3.4vw, 2.8rem); margin-bottom: .7rem; }
.zigzag-desc { color: var(--color-fg-muted); font-size: 1.12rem; }
@media (max-width: 760px) { .zigzag-item, .zigzag-item:nth-child(even) { grid-template-columns: 1fr; gap: 1.4rem; } .zigzag-item:nth-child(even) .zigzag-photo { order: -1; } .zigzag-item:nth-child(even) .zigzag-text { text-align: left; justify-self: start; } }

/* ── Proceso (steps SSR) ── */
.process-steps { list-style: none; display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.2rem, 2.5vw, 2rem); padding: 0; margin: 0; }
.process-steps li { border-top: 2px solid var(--color-accent); padding-top: 1.2rem; }
.process-num { display: block; font-family: var(--font-heading); font-size: 1.8rem; font-weight: 600; color: var(--color-accent); margin-bottom: .6rem; font-variant-numeric: tabular-nums; }
.process-steps h3 { font-size: 1.25rem; margin-bottom: .35rem; }
.process-steps p { color: var(--color-fg-muted); }
@media (max-width: 900px) { .process-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .process-steps { grid-template-columns: 1fr; } }

/* ── Equipo (item-card SSR). Flex centrado: con 1-2 personas quedan CENTRADAS
   (antes el grid auto-fill 1fr las alineaba a la izquierda con huecos). ── */
.staff-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 2rem; }
.staff-grid .item-card { text-align: center; background: none; border: none; padding: 0; box-shadow: none; flex: 0 1 240px; max-width: 280px; }
.staff-grid .item-card-photo { aspect-ratio: 3/4; border-radius: var(--radius); overflow: hidden; margin-bottom: 1rem; background: var(--color-surface); }
.staff-grid .item-card-photo img { width: 100%; height: 100%; object-fit: cover; }
.staff-grid .item-card-title { font-size: 1.2rem; margin-bottom: .35rem; }
.staff-grid .item-card-desc { color: var(--color-fg-muted); }

/* ── Productos (item-card SSR compacto, foto cuadrada). Cross-sell dentro de
   Servicios. Reutiliza la tarjeta base del SPA. ── */
.products-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 16px; }
.products-grid .item-card { flex: 1 1 240px; max-width: 300px; }
.item-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: transform .25s, box-shadow .25s, border-color .25s; }
.item-card:hover { transform: translateY(-3px); box-shadow: 0 18px 40px -22px rgba(17,24,39,.25); border-color: var(--color-accent-soft); }
.item-card-photo { aspect-ratio: 1 / 1; overflow: hidden; background: var(--color-surface); flex-shrink: 0; }
.item-card-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.item-card-photo--empty { background: repeating-linear-gradient(45deg, var(--color-surface), var(--color-surface) 10px, var(--color-border) 10px, var(--color-border) 20px); }
.item-card-body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 3px; flex: 1; }
.item-card-title { font-family: var(--font-heading); font-size: 1rem; line-height: 1.25; margin: 0; }
.item-card-desc { margin: 0; color: var(--color-fg-muted); font-size: .82rem; line-height: 1.45; }
.item-card-precio { margin: 3px 0 0; font-family: var(--font-heading); font-weight: 700; font-size: 1.05rem; color: var(--color-accent); }
/* el equipo reusa .item-card pero sin caja: re-neutralizo lo de arriba */
.staff-grid .item-card { border-radius: 0; }
.staff-grid .item-card:hover { transform: none; box-shadow: none; border: none; }
.staff-grid .item-card-body { padding: 0; gap: .25rem; }

/* ── Galería (gallery SSR) ── */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.gallery-grid figure { margin: 0; overflow: hidden; border-radius: var(--radius); }
.gallery-grid img { width: 100%; aspect-ratio: 1; object-fit: cover; display: block; transition: transform .55s var(--ease); }
.gallery-grid figure:hover img { transform: scale(1.06); }
@media (max-width: 760px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Reviews (SSR) ── */
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.4rem; }
.review-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.8rem; }
.review-stars { color: var(--color-accent); letter-spacing: 2px; margin-bottom: .8rem; }
.review-card blockquote { font-size: 1.05rem; line-height: 1.6; margin: 0 0 1rem; font-style: italic; }
.review-card footer { font-weight: 600; letter-spacing: .05em; font-size: .82rem; color: var(--color-fg-muted); }

/* ── CTA cierre ── */
.cta { background: var(--color-accent); color: #fff; padding: clamp(3.5rem, 8vw, 6rem) 0; text-align: center; }
.cta-inner { max-width: 680px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.4rem; }
.cta-inner h2 { color: #fff; font-size: clamp(2rem, 4.5vw, 3rem); }
.cta-aside { display: flex; flex-direction: column; align-items: center; gap: 1.6rem; }
.cta-aside p { opacity: .9; font-size: 1.12rem; max-width: 46ch; }

/* ── Contacto: dos tarjetas IGUALES (info+mapa | formulario). El mapa va en
   flex:1 para que la tarjeta de info iguale el alto de la del formulario. ── */
.contact-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(1.5rem, 4vw, 2.75rem); align-items: stretch; }
.contact-card { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius); padding: clamp(1.4rem, 3vw, 2.2rem); box-shadow: 0 18px 48px -28px rgba(0,0,0,.35); display: flex; flex-direction: column; gap: 1.1rem; min-width: 0; }
.contact-card.contact-card-form { background: var(--color-surface); }
.contact-card-title { font-family: var(--font-heading); font-size: clamp(1.4rem, 2.4vw, 1.85rem); margin: 0; }
.contact-details { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1rem; }
.contact-details li { display: flex; flex-direction: column; gap: 3px; }
.contact-key { font-family: var(--font-heading); text-transform: uppercase; letter-spacing: .05em; color: var(--color-accent); font-size: .85rem; }
.contact-details a { color: var(--color-fg); font-weight: 600; }
.contact-map { flex: 1; min-height: 240px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: 12px; overflow: hidden; }
.contact-card-form .contact-map { background: var(--color-bg); }
.contact-map iframe { width: 100%; height: 100%; border: 0; display: block; }
/* Form a flex:1 + textarea flex:1 → el textarea crece y empuja el botón al
   fondo, igualando el alto de la tarjeta de info (con el mapa). */
.lead-form { display: flex; flex-direction: column; gap: .8rem; flex: 1; }
.lead-form input, .lead-form textarea { width: 100%; box-sizing: border-box; padding: .8rem 1rem; border: 1px solid var(--color-border); border-radius: 8px; font-family: inherit; font-size: .95rem; background: var(--color-bg); color: var(--color-fg); }
.lead-form textarea { flex: 1; min-height: 120px; resize: vertical; }
.lead-form input:focus, .lead-form textarea:focus { outline: none; border-color: var(--color-accent); }
/* checkbox + texto como una unidad: el texto fluye en su <span>, el checkbox no se encoge. */
.lead-consent { display: flex; align-items: flex-start; gap: .55rem; font-size: .82rem; color: var(--color-fg-muted); line-height: 1.45; }
/* el checkbox NO debe heredar el width:100% de .lead-form input (lo estiraba a
   todo el ancho y empujaba el texto). width:auto lo deja a su tamaño nativo. */
.lead-consent input[type="checkbox"] { flex-shrink: 0; width: auto; margin-top: 2px; }
.lead-consent a { color: var(--color-accent); }
.lead-form .btn { margin-top: auto; width: 100%; }
.lead-status { font-size: .88rem; color: var(--color-fg-muted); min-height: 1.2em; }

/* ── Footer (fiel a salonapp -signature) ── */
.footer { background: var(--color-fg); color: var(--color-bg); padding: clamp(2.75rem, 5vw, 4.25rem) 0 1.75rem; }
/* Neutralizo el grid 1fr/auto/1fr que base.css aplica a .footer-inner (rompía
   este layout metiendo .footer-grid en 1/3 y la copy en el centro). Aquí mando
   yo: .footer-grid (3 columnas) y .footer-base (copy) apilados a ancho completo. */
.footer-inner { display: block; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: clamp(1.75rem, 4vw, 3rem); padding-bottom: 2.25rem; border-bottom: 1px solid color-mix(in srgb, var(--color-bg) 16%, transparent); }
.footer-brand { max-width: 340px; }
.footer-logo { font-family: var(--font-heading); font-size: 1.6rem; font-weight: 600; color: var(--color-bg); }
.footer-logo:hover { color: var(--color-accent-soft); text-decoration: none; }
.footer-tag { color: color-mix(in srgb, var(--color-bg) 72%, transparent); letter-spacing: .04em; line-height: 1.55; margin: .5rem 0 1rem; max-width: 300px; }
.footer-social { display: flex; gap: 12px; } .footer-social a { color: color-mix(in srgb, var(--color-bg) 80%, transparent); } .footer-social a:hover { color: var(--color-accent-soft); } .footer-social svg { width: 18px; height: 18px; }
.footer-nav { display: flex; flex-direction: column; gap: .55rem; align-items: flex-start; }
.footer-nav-title { font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: color-mix(in srgb, var(--color-bg) 55%, transparent); margin-bottom: .3rem; }
.footer-nav a { color: color-mix(in srgb, var(--color-bg) 85%, transparent); font-size: .95rem; }
.footer-nav a:hover { color: var(--color-bg); text-decoration: none; }
.footer-nav a[aria-current="page"] { color: var(--color-accent-soft); }
.footer-base { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 1rem; padding-top: 1.5rem; text-align: center; }
/* el separador es el border-bottom de .footer-grid; anulo el border-top que
   base.css pone en .footer-copy para no duplicar la línea. */
.footer-copy { opacity: .55; font-size: .85rem; margin: 0; padding-top: 0; border-top: none; }

/* ── Reveal ── */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } .hero-bg { animation: none; } }

@media (max-width: 900px) {
  .nav-menu, .nav-right { display: none; }
  .nav-hamburger { display: flex; }
  .split, .contact-grid { grid-template-columns: 1fr; gap: 2rem; }
  .contact-map { min-height: 280px; aspect-ratio: 4/3; flex: none; }
  .split-media { order: -1; }
  .footer-grid { grid-template-columns: 1fr; }
}


/* portfolio */
.portfolio-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; }
.portfolio-item { margin: 0; display: flex; flex-direction: column; }
.portfolio-photo { position: relative; overflow: hidden; border-radius: 14px; aspect-ratio: 4/5; }
.portfolio-photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.portfolio-item:hover .portfolio-photo img { transform: scale(1.05); }
.portfolio-cap { position: absolute; inset: auto 0 0 0; padding: 1.4rem 1rem .9rem; color: #fff; font-family: var(--font-heading); font-size: 1.1rem; background: linear-gradient(to top, rgba(0,0,0,.72), transparent); }
.portfolio-meta { display: flex; flex-direction: column; gap: .35rem; padding: .9rem .2rem 0; }
.portfolio-desc { margin: 0; color: var(--color-fg-muted); font-size: .9rem; line-height: 1.5; }
.portfolio-precio { color: var(--color-accent); font-weight: 600; font-size: .9rem; }
@media (max-width: 900px) { .portfolio-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .portfolio-grid { grid-template-columns: 1fr; } }
