/*
TPL_COUPLESTHERAPY
Base CSS
Compatible Joomla 4 / 5
*/

/* =========================
RESET
========================= */

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

html{
scroll-behavior:smooth;
height:100%;
}

body{
line-height:1.5;
-webkit-font-smoothing:antialiased;
-moz-osx-font-smoothing:grayscale;

/* ===== STICKY FOOTER LAYOUT ===== */

display:flex;
flex-direction:column;
min-height:100vh;
}

/* =========================
VARIABLES
========================= */

:root{

--bg:#ffffff;
--blue-dark:#4c82a8;
--blue-mid:#9bb0c7;
--blue-light:#dbecf8;

--accent:#ff7f41;

--card:#e6eef6;

--text-dark:#03151a;
--text-clear:#ffffff;

--muted:#7a8b94;

--nav-height:80px;

--radius:18px;

--soft-shadow:0 6px 18px rgba(18,40,60,0.12);

}

/* =========================
BASE
========================= */

body{
font-family:'Nunito Sans',sans-serif;
color:#03151a;
line-height:1.6;
}

h1, h2, h3, h4, h5, h6{
font-family:'Nata Sans',sans-serif;
}

body{
background:var(--bg);
color:var(--text-dark);
}


h1{
font-size:2.5rem;
margin-bottom:20px;
}

h2{
font-size:2rem;
margin-bottom:30px;
}

h3{
font-size:1.5rem;
margin-bottom:20px;
}

p{
margin-bottom:20px;
line-height:1.6;
}

img{
max-width:100%;
height:auto;
display:block;
}

/* =========================
LAYOUT
========================= */

main{

margin-top:var(--nav-height);
width:100%;

/* permite empujar el footer al fondo */
flex:1;

/* espacio mínimo entre contenido y footer */
padding-bottom:20px;

}

.container{
width:100%;
max-width:1180px;
margin:0 auto;
padding:0 24px;
}

.section{
padding:60px 0;
}

/* =========================
NAVBAR
========================= */

.navbar{
position:fixed;
top:0;
left:0;
width:100%;
height:var(--nav-height);
background:var(--blue-dark);
z-index:999;
display:flex;
align-items:center;
border-bottom:1px solid rgba(255,255,255,0.1);
}

.nav-container{
max-width:1180px;
margin:0 auto;
display:flex;
align-items:center;
justify-content:space-between;
padding:0 24px;
width:100%;
}

.logo-img{
height:40px;
}

@media(max-width:768px){

.nav-container{
width:100%;
max-width:100%;
}

.hamburger{
margin-left:auto;
}

}

/* =========================
NAVBAR MENU
========================= */

.navbar .nav-menu{
display:flex;
align-items:center;
justify-content:center;
gap:10px;
list-style:none;
margin:0;
padding:0;
}

.navbar .nav-menu a{
color:var(--text-clear);
text-decoration:none;
padding:10px 15px;
border-radius:30px;
border:2px solid transparent;
transition:all .3s ease;
font-weight:500;
}

.navbar .nav-menu a:hover{
border-color:var(--accent);
color:var(--accent);
}

.navbar .nav-menu .active{
border-color:var(--accent);
color:var(--accent);
font-weight:600;
}

.nav-item{
margin:0;
}

.nav-link{
display:inline-block;
}

/* =========================
HAMBURGER
========================= */

.hamburger{
display:none;
flex-direction:column;
width:30px;
height:22px;
cursor:pointer;
background:transparent;
border:none;
}

.hamburger span{
display:block;
height:3px;
width:100%;
background:var(--text-clear);
border-radius:3px;
transition:.3s;
}

.hamburger.active span:nth-child(1){
transform:translateY(9px) rotate(45deg);
}

.hamburger.active span:nth-child(2){
opacity:0;
}

.hamburger.active span:nth-child(3){
transform:translateY(-9px) rotate(-45deg);
}

/* =========================
BUTTONS
========================= */

.btn{
display:inline-block;
background:var(--accent);
color:white;
padding:10px 20px;
border-radius:30px;
text-decoration:none;
font-weight:600;
transition:.3s;
}

.btn:hover{
background:#e66a30;
}

/* =========================
CARDS
========================= */

.card{
background:var(--card);
border-radius:var(--radius);
padding:30px;
box-shadow:var(--soft-shadow);
transition:transform .3s;
}

.card:hover{
transform:translateY(-5px);
}

/* =========================
GRIDS
========================= */

.grid-2{
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
}

.grid-3{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
}

/* =========================
FOOTER
========================= */

.site-footer{
background:var(--blue-dark);
color:white;
display:flex;
align-items:center;
justify-content:space-between;
padding:22px 48px;
flex-wrap:wrap;
gap:20px;

/* fuerza que siempre quede al final */
margin-top:auto;
}

.footer-left{
display:flex;
align-items:center;
gap:14px;
}

.footer-left img{
height:48px;
}

/* footer-main */

.footer-links{
display:flex;
gap:18px;
}

/* footer-legal */

.footer-right{
display:flex;
align-items:center;
justify-content:flex-end;
gap:14px;
}

/* footer menus */

.site-footer .nav-menu{
display:flex;
flex-direction:row;
gap:18px;
list-style:none;
margin:0;
padding:0;
}

.site-footer .nav-menu li{
display:inline-block;
}

.site-footer .nav-menu a{
color:white;
text-decoration:none;
font-size:14px;
opacity:0.95;
transition:all 0.3s ease;
}

.site-footer .nav-menu a:hover{
opacity:1;
text-decoration:underline;
}

/* =========================
RESPONSIVE BASE
========================= */

@media(max-width:980px){

.grid-2{
grid-template-columns:1fr;
}

.grid-3{
grid-template-columns:1fr 1fr;
}

}

@media(max-width:768px){

.hamburger{
display:flex;
}

.navbar .nav-menu{
position:absolute;
top:80px;
left:0;
width:100%;
background:var(--blue-dark);
flex-direction:column;
align-items:center;
display:none;
}

.navbar .nav-menu.active{
display:flex;
}

.grid-3{
grid-template-columns:1fr;
}

/*.site-footer{
flex-direction:column;
align-items:center;
text-align:center;
}*/

.site-footer{
flex-direction:column;
align-items:center;
text-align:center;
padding:30px 20px;
}

.footer-links{
flex-wrap:wrap;
justify-content:center;
}

.footer-right{
justify-content:center;
}

.site-footer .nav-menu{
flex-wrap:wrap;
justify-content:center;
gap:12px;
}

main{
margin-top:var(--nav-height);
width:100%;
max-width:100%;
}

}

@media(max-width:480px){

.container{
padding:0 16px;
}

}




/*clases para calendario de actividades*/

.invitation-grid{
display:block;
grid-template-columns:repeat(auto-fit,minmax(420px,520px));
justify-content:center;
gap:40px;
margin-top:40px;
}

/* =====================================================
CALENDARIOS HOME
===================================================== */

.calendar-section{
padding:70px 48px;
background:#f6f8ff;
}

.calendar-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(420px,520px));
justify-content:center;
gap:40px;
margin-top:40px;
}

/* tarjeta */

.calendar-card{
background:#fff;
border-radius:20px;
padding:35px;
box-shadow:var(--soft-shadow);
display:flex;
flex-direction:column;
gap:25px;
}

.calendar-card.highlight{
border-top:6px solid var(--accent);
}

/* header */

.calendar-header h3{
font-size:1.6rem;
color:var(--blue-dark);
margin-bottom:5px;
}

.calendar-subtitle{
font-size:0.9rem;
color:var(--muted);
}

/* eventos */

.calendar-events{
display:flex;
flex-direction:column;
gap:18px;
}

/* evento */

.calendar-event{
display:flex;
gap:18px;
align-items:flex-start;
padding-bottom:12px;
border-bottom:1px solid rgba(0,0,0,.06);
}

/* fecha */

.calendar-date{
min-width:90px;
font-weight:700;
color:var(--accent);
font-size:0.95rem;
}

/* info */

.calendar-info h4{
font-size:1rem;
margin-bottom:4px;
color:var(--text-dark);
}

.calendar-info p{
font-size:0.9rem;
margin-bottom:3px;
color:#555;
}

.calendar-info span{
font-size:0.85rem;
color:var(--blue-dark);
font-weight:600;
}

/* botón */

.calendar-btn{
display:inline-block;
align-self:flex-start;
background:var(--accent);
color:#fff;
padding:10px 22px;
border-radius:30px;
text-decoration:none;
font-weight:600;
margin-top:10px;
}

.calendar-btn:hover{
background:#e66a30;
}

/* responsive */

@media(max-width:980px){

.calendar-grid{
grid-template-columns:1fr;
}

.calendar-section{
padding:50px 24px;
}

}

/* =====================================================
CALENDARIO HOME – FONDO OSCURO
===================================================== */

.calendar-dark{
background:var(--blue-dark);
padding:70px 48px;
color:var(--text-clear);
}

.calendar-dark-title{
color:white;
margin-bottom:40px;
}

/* GRID */

/*.calendar-dark-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:40px;
}*/

.calendar-dark-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(420px,520px));
justify-content:center;
gap:40px;
margin-top:40px;
}

/* CARD */

.calendar-dark-card{
background:white;
border-radius:20px;
padding:35px;
box-shadow:var(--soft-shadow);
display:flex;
flex-direction:column;
gap:25px;
}

.calendar-dark-highlight{
border-top:6px solid var(--accent);
}

/* HEADER */

.calendar-dark-header h3{
color:var(--blue-dark);
font-size:1.6rem;
margin-bottom:4px;
}

.calendar-dark-header p{
color:var(--muted);
font-size:.9rem;
}

/* EVENTS */

.calendar-dark-events{
display:flex;
flex-direction:column;
gap:18px;
}

.calendar-dark-event{
display:flex;
gap:18px;
padding-bottom:12px;
border-bottom:1px solid rgba(0,0,0,.06);
}

/* DATE */

.calendar-dark-date{
min-width:95px;
font-weight:700;
color:var(--accent);
font-size:.95rem;
}

/* INFO */

.calendar-dark-event h4{
font-size:1rem;
margin-bottom:4px;
color:var(--text-dark);
}

.calendar-dark-event p{
font-size:.9rem;
color:#555;
margin-bottom:3px;
}

.calendar-dark-event span{
font-size:.85rem;
color:var(--blue-dark);
font-weight:600;
}

/* BUTTON */

.calendar-dark-btn{
display:inline-block;
align-self:flex-start;
background:var(--accent);
color:white;
padding:10px 22px;
border-radius:30px;
text-decoration:none;
font-weight:600;
margin-top:10px;
}

.calendar-dark-btn:hover{
background:#e66a30;
}

/* RESPONSIVE */

@media(max-width:980px){

.calendar-dark-grid{
grid-template-columns:1fr;
}

.calendar-dark{
padding:50px 24px;
}

}