/*
Theme Name: Respira Theme
Author: Daniel
Version: 1.0
Description: Tema personalizado para Respira Arte Terapia
*/

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}


/* Oculta la barra de administración solo para vista previa local */
#wpadminbar {
  display: none;
}

html {
  margin-top: 0 !important;
}


html, body {
  overflow-x: hidden;
  max-width: 100vw;
}

body {
  background-color: rgb(194, 200, 196) !important;
}












/* ==== CTA superior del footer ==== */
.footer-cta{
  background: linear-gradient(135deg, #5e7c99 0%, #6e8eaa 100%);
  color:#fff;
}
.footer-cta__inner{
  max-width:1200px; margin:0 auto;
  padding:2.25rem 2rem;
  display:flex; gap:1.5rem; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.footer-cta__text h3{
  font-family:'Playfair Display',serif;
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  margin:0 0 .25rem;
}
.footer-cta__text p{
  font-family:'Karla',sans-serif;
  margin:0; opacity:.95;
}
.btn{
  display:inline-block; padding:.75rem 1.1rem; border-radius:6px; text-decoration:none; font-weight:700;
  font-family:'Karla',sans-serif; transition:transform .15s ease, opacity .15s ease;
}
.btn--light{ background:#fff; color:#2b3a45; }
.btn--light:hover{ transform:translateY(-1px); opacity:.95; }

/* ==== Footer principal ==== */
.site-footer{
  background:#faf9f6; color:#444;
  font-family:'Karla',sans-serif;
  border-top:1px solid rgba(0,0,0,.06);
}
.footer-container{
  max-width:1200px; margin:0 auto; padding:2.5rem 2rem 2rem;
  display:grid; gap:2rem;
  grid-template-columns: 1.35fr 1fr 1.2fr;
}
.footer-brand .footer-title{
  font-family:'Playfair Display',serif; font-size:1.4rem; margin:0 0 .35rem;
}
.footer-brand .footer-logo img{ max-height:44px; width:auto; }
.footer-tagline{ margin:.25rem 0 0; color:#666; }

.footer-nav .footer-menu{ list-style:none; margin:0; padding:0; }
.footer-nav .footer-menu li{ margin: .25rem 0; }
.footer-nav .footer-menu a{
  color:#222; text-decoration:none; transition:color .2s ease;
}
.footer-nav .footer-menu a:hover{ color:#5e7c99; }

.footer-contact h4{
  font-family:'Playfair Display',serif; margin:0 0 .5rem; font-size:1.15rem;
}
.footer-contact__list{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.55rem; }
.footer-contact__list li{ display:flex; align-items:center; gap:.6rem; }
.footer-contact__list a{ color:#222; text-decoration:none; }
.footer-contact__list a:hover{ color:#5e7c99; }

.footer-bottom{
  border-top:1px solid rgba(0,0,0,.06);
  text-align:center; padding:1rem 2rem 1.5rem; color:#666; font-size:.95rem;
}

/* ==== Responsive ==== */
@media (max-width: 900px){
  .footer-container{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 680px){
  .footer-cta__inner{ justify-content:center; text-align:center; }
  .footer-container{ grid-template-columns:1fr; text-align:center; }
  .footer-contact__list li{ justify-content:center; }
  .footer-brand .footer-logo,
  .footer-brand .footer-title{ justify-self:center; }
}











/* ===== Header Respira ===== */
:root{ --header-h: 74px; }

.site-header{
  position: fixed; top:0; left:0; right:0; z-index: 999;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(6px);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

.nav-container{
  max-width: 1200px; margin: 0 auto;
  padding: .65rem 1rem;
  display: flex; align-items: center; justify-content: space-between;
}

/* Logo */
.logo img{ max-height: 44px; height:auto; width:auto; display:block; }
.logo-text{ font-family:'Playfair Display',serif; font-size: 1.25rem; color:#222; text-decoration:none; }

/* Menú (desktop) */
.main-nav .menu{
  display:flex; gap: 1.75rem; list-style:none; margin:0; padding:0;
  font-family:'Karla',sans-serif;
}
.main-nav .menu a{
  color:#111; text-decoration:none; font-weight:700;
  padding:.35rem 0; display:inline-block;
}
.main-nav .menu a:hover{ color:#5e7c99; }

/* Botón hamburguesa (oculto en desktop) */
.nav-toggle{
  display:none; border:none; background:transparent; padding:.25rem .15rem; cursor:pointer;
}
.nav-toggle__bar{
  display:block; width:28px; height:2px; background:#1e1e1e; margin:6px 0; transition:.25s ease;
}

/* ===== Mobile / Tablet ===== */
@media (max-width: 900px){
  .nav-toggle{ display:block; }
  .main-nav{
    position: fixed; top:0; right:0; height:100dvh;
    width: 78vw; max-width: 360px;
    background:#faf9f6; box-shadow: -18px 0 32px rgba(0,0,0,.12);
    transform: translateX(100%); transition: transform .32s ease;
    padding: calc(var(--header-h) + 1rem) 1.25rem 2rem;
  }
  .main-nav .menu{ flex-direction:column; gap:1rem; }
  .site-header.is-open .main-nav{ transform: translateX(0); }

  /* Overlay */
  .nav-overlay{
    position: fixed; inset:0; background: rgba(0,0,0,.45);
    opacity:0; transition: opacity .28s ease; pointer-events:none;
  }
  .site-header.is-open .nav-overlay{ opacity:1; pointer-events:auto;         height: 100vh;}

  /* Animación del botón a “X” */
  .site-header.is-open .nav-toggle__bar:nth-child(1){ transform: translateY(8px) rotate(45deg); }
  .site-header.is-open .nav-toggle__bar:nth-child(2){ opacity:0; }
  .site-header.is-open .nav-toggle__bar:nth-child(3){ transform: translateY(-8px) rotate(-45deg); }
}

/* Utilidades */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Sugerencia: si el header es fixed, deja respiro al contenido */
.has-fixed-header .smooth-content,
.has-fixed-header main{ padding-top: 32px; }
    

@media (max-width:900px){
  .main-nav{ position:fixed !important; transform:translateX(100%) !important; }
  .site-header.is-open .main-nav{ transform:translateX(0) !important; }
  .nav-toggle{ display:block !important; z-index: 9999;}
  .sr-only{
    position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
    clip:rect(0 0 0 0);white-space:nowrap;border:0;
  }
}

/* --- Fix header/drawer móvil: línea gris y capas --- */
.site-header{ z-index: 1000; }       /* barra */
@media (max-width:900px){
  .main-nav{
    z-index: 1001;                   /* drawer por encima */
    box-shadow: none;                /* quita la franja/sombra gris del borde */
    border-left: 1px solid rgba(0,0,0,.06); /* borde fino y limpio (opcional) */
  }
  .nav-overlay{
    z-index: 900;                    /* overlay por debajo del drawer */
    background: rgba(0,0,0,.45);     /* puedes bajarlo si lo ves muy oscuro */
  }
}
/* Si la franja venía del color de fondo global, usa un fondo neutro */
body{ background:#f8f8f8; } /* (o elimina cualquier !important previo) */

@media (max-width:900px){
  .site-header{ box-shadow: none; }
}