/* ============================================================================
   Cal Roig · Yogic Experience — Sistema de estilos (web nueva)
   Reconstruido a partir del diseño de "Calroig ejemplo nueva".
   Fase 1: tokens + tipografías + cabecera/nav + footer + hero.
   ========================================================================== */

/* ---- Tipografías (Google Fonts) ----------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Marcellus&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Montserrat:wght@300;400;500;600&family=Petit+Formal+Script&display=swap');

/* ---- Tokens de diseño ---------------------------------------------------- */
:root {
    /* Colores de marca */
    --c-fondo:        #F4EEE3;  /* crema cálido, fondo principal */
    --c-fondo-claro:  #FBF8F2;  /* crema muy claro */
    --c-fondo-suave:  #EFE7D9;  /* secciones alternas */
    --c-texto:        #2B2722;  /* marrón casi negro */
    --c-texto-suave:  #6B5E52;  /* texto secundario */
    --c-tenue:        #9C8E7E;  /* texto tenue / metadatos */
    --c-terracota:    #A95425;  /* acento / marca */
    --c-terracota-osc:#8A4220;  /* hover del acento */
    --c-arena:        #E0A87E;  /* detalle cálido */
    --c-borde:        #D8CCBE;  /* líneas y bordes */
    --c-borde-claro:  #C9BCAD;

    /* Tipografías */
    --f-titulo:  'Marcellus', serif;
    --f-serif:   'Cormorant Garamond', serif;
    --f-texto:   'Montserrat', sans-serif;
    --f-script:  'Petit Formal Script', cursive;

    /* Medidas */
    --ancho-max: 1340px;
    --radio:     14px;
}

/* ---- Reset y base -------------------------------------------------------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--c-fondo);
    color: var(--c-texto);
    font-family: var(--f-texto);
    font-weight: 400;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }
::selection { background: var(--c-terracota); color: var(--c-fondo-claro); }

h1, h2, h3 { font-family: var(--f-titulo); font-weight: 400; line-height: 1.15; margin: 0; }

.contenedor { max-width: var(--ancho-max); margin: 0 auto; padding: 0 34px; }

/* ---- Animaciones de la web nueva ---------------------------------------- */
@keyframes calReveal { from { opacity: 0; transform: translateY(34px); } to { opacity: 1; transform: translateY(0); } }
@keyframes calHeroIn { from { opacity: 0; transform: translateY(22px); } to { opacity: 1; transform: translateY(0); } }
[data-reveal] {
    animation: calReveal linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 28%;
}

/* ============================================================================
   CABECERA / NAV
   ========================================================================== */
.site-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    color: var(--c-fondo-claro);
    transition: background .4s ease, color .4s ease, box-shadow .4s ease;
}
/* Estado sólido: al hacer scroll o en páginas internas (sin hero). */
.site-header.is-solid,
.site-header.no-hero {
    background: var(--c-fondo-claro);
    color: var(--c-texto);
    box-shadow: 0 1px 0 var(--c-borde);
}

/* Topbar superior */
.topbar {
    display: flex; justify-content: flex-end; align-items: center; gap: 22px;
    max-width: var(--ancho-max); margin: 0 auto; padding: 9px 34px 0;
    font-size: 11px; letter-spacing: .26em; text-transform: uppercase; opacity: .92;
}
.topbar a { letter-spacing: .18em; }
.topbar .sep { opacity: .4; }
.is-solid .topbar, .no-hero .topbar { opacity: .8; }

/* Barra principal */
.navbar {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
    max-width: var(--ancho-max); margin: 0 auto; padding: 16px 34px;
}

/* Logotipo */
.wordmark { display: flex; flex-direction: column; line-height: 1; flex: none; }
.wordmark .marca { font-family: var(--f-script); font-size: 34px; letter-spacing: .5px; }
.wordmark .sub {
    font-size: 9.5px; letter-spacing: .52em; text-transform: uppercase;
    margin-top: 5px; opacity: .78; padding-left: 3px;
}

/* Menú */
.nav { display: flex; align-items: center; gap: 1px;
    font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.nav .item { position: relative; }
.nav .item > a {
    display: flex; align-items: center; gap: 6px; padding: 13px 12px; white-space: nowrap;
    transition: opacity .2s;
}
.nav .item > a:hover { opacity: .65; }
.nav .item .caret { width: 9px; height: 9px; opacity: .7; }

/* Dropdowns */
.dropdown {
    position: absolute; top: 100%; left: 0; min-width: 230px;
    background: var(--c-fondo-claro); color: var(--c-texto);
    border: 1px solid var(--c-borde); border-radius: var(--radio);
    box-shadow: 0 18px 40px rgba(43, 39, 34, .14);
    padding: 10px; opacity: 0; visibility: hidden; transform: translateY(8px);
    transition: opacity .22s ease, transform .22s ease, visibility .22s;
}
.nav .item:hover .dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.dropdown a {
    display: block; padding: 9px 12px; border-radius: 9px;
    font-size: 11px; letter-spacing: .08em; text-transform: none;
    font-family: var(--f-texto);
}
.dropdown a:hover { background: var(--c-fondo-suave); color: var(--c-terracota); }

/* Botón Reservar */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    font-family: var(--f-texto); font-size: 12px; letter-spacing: .14em; text-transform: uppercase;
    padding: 12px 24px; border-radius: 999px; border: 1px solid transparent;
    cursor: pointer; transition: background .25s, color .25s, border-color .25s, transform .15s;
}
.btn-primario { background: var(--c-terracota); color: var(--c-fondo-claro); }
.btn-primario:hover { background: var(--c-terracota-osc); }
.btn-contorno { background: transparent; color: currentColor; border-color: currentColor; }
.btn-contorno:hover { background: currentColor; }
.is-solid .btn-contorno:hover, .no-hero .btn-contorno:hover { color: var(--c-fondo-claro); }
.btn:active { transform: translateY(1px); }

.nav-cierre { display: flex; align-items: center; gap: 14px; flex: none; }
.lang { font-size: 11px; letter-spacing: .14em; opacity: .8; }

/* Botón hamburguesa (móvil) */
.nav-toggle {
    display: none; background: none; border: 0; cursor: pointer; color: inherit;
    width: 40px; height: 40px; align-items: center; justify-content: center;
}
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after {
    content: ''; display: block; width: 24px; height: 1.5px; background: currentColor;
    position: relative; transition: transform .3s, opacity .3s;
}
.nav-toggle span::before { position: absolute; top: -7px; }
.nav-toggle span::after  { position: absolute; top: 7px; }

/* ============================================================================
   HERO (portada)
   ========================================================================== */
.hero {
    position: relative; min-height: 100vh; display: flex; align-items: center;
    background: var(--c-terracota); color: var(--c-fondo-claro); overflow: hidden;
}
/* Foto de fondo con suave zoom (Ken Burns) */
.hero__media {
    position: absolute; inset: 0; z-index: 0;
    background-size: cover; background-position: center;
    animation: calKen 14s ease-out both;
}
.hero::after { /* oscurecido + viñeta para que el texto se lea */
    content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
    background:
        linear-gradient(180deg, rgba(20,12,8,.30) 0%, rgba(20,12,8,.15) 40%, rgba(20,12,8,.55) 100%),
        radial-gradient(120% 120% at 50% 20%, transparent 40%, rgba(20,12,8,.45) 100%);
}
.hero .contenedor { position: relative; z-index: 2; padding-top: 120px; padding-bottom: 80px; }
.hero .eyebrow {
    font-size: 12px; letter-spacing: .42em; text-transform: uppercase; opacity: .8;
    animation: calHeroIn .9s both;
}
.hero h1 {
    font-family: var(--f-serif); font-weight: 500; font-style: italic;
    font-size: clamp(40px, 7vw, 92px); margin: 18px 0 22px; max-width: 16ch;
    animation: calHeroIn 1s .05s both;
}
.hero .lead {
    font-family: var(--f-serif); font-size: clamp(18px, 2.2vw, 24px);
    max-width: 46ch; opacity: .92; animation: calHeroIn 1.1s .1s both;
}
.hero .acciones { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 38px;
    animation: calHeroIn 1.2s .15s both; }

/* ============================================================================
   SECCIONES genéricas
   ========================================================================== */
.seccion { padding: 90px 0; }
.seccion--suave { background: var(--c-fondo-suave); }
.seccion .kicker {
    font-size: 12px; letter-spacing: .32em; text-transform: uppercase;
    color: var(--c-terracota); margin-bottom: 12px;
}
.seccion h2 { font-size: clamp(28px, 4vw, 46px); margin-bottom: 18px; }
.seccion .intro { font-family: var(--f-serif); font-size: 20px; color: var(--c-texto-suave); max-width: 60ch; }

/* Sección con foto de fondo (texto claro sobre imagen) */
.seccion--foto {
    position: relative; color: var(--c-fondo-claro); overflow: hidden;
    background-size: cover; background-position: center; padding: 130px 0;
}
.seccion--foto::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(20,12,8,.35), rgba(20,12,8,.6));
}
.seccion--foto .contenedor { position: relative; z-index: 1; }
.seccion--foto .kicker { color: var(--c-arena); }
.seccion--foto .intro { color: rgba(251,248,242,.92); }

/* ============================================================================
   PIE DE PÁGINA
   ========================================================================== */
.site-footer { background: var(--c-texto); color: var(--c-fondo-claro); padding: 70px 0 34px; }
.footer-top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.footer-marca .marca { font-family: var(--f-script); font-size: 30px; }
.footer-marca .sub { font-size: 9.5px; letter-spacing: .5em; text-transform: uppercase; opacity: .7; margin-top: 4px; }
.footer-marca p { color: var(--c-borde-claro); margin-top: 16px; max-width: 30ch; font-size: 14px; }
.footer-col h4 {
    font-family: var(--f-texto); font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
    opacity: .6; margin: 0 0 16px;
}
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { font-size: 14px; color: var(--c-borde-claro); transition: color .2s; }
.footer-col a:hover { color: var(--c-arena); }
.footer-bottom {
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
    margin-top: 50px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.12);
    font-size: 12px; opacity: .7;
}
.footer-bottom .legales { display: flex; gap: 20px; }

/* ============================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 980px) {
    .topbar { display: none; }
    .nav-toggle { display: flex; }

    /* El menú pasa a panel lateral deslizante */
    .nav, .nav-cierre .lang { display: none; }
    .nav {
        position: fixed; top: 0; right: 0; bottom: 0; width: min(86vw, 360px);
        flex-direction: column; align-items: stretch; gap: 0;
        background: var(--c-fondo-claro); color: var(--c-texto);
        padding: 90px 24px 40px; box-shadow: -20px 0 60px rgba(0,0,0,.2);
        transform: translateX(100%); transition: transform .35s ease; overflow-y: auto;
        text-transform: none; letter-spacing: normal; font-size: 15px;
    }
    body.menu-abierto .nav { display: flex; transform: translateX(0); }
    body.menu-abierto { overflow: hidden; }
    .nav .item > a { padding: 14px 6px; border-bottom: 1px solid var(--c-borde); }
    .nav .item .caret { margin-left: auto; }
    /* En móvil los dropdowns se muestran en flujo (acordeón simple por hover/tap) */
    .dropdown {
        position: static; opacity: 1; visibility: visible; transform: none;
        box-shadow: none; border: 0; padding: 0 0 8px 12px; min-width: 0;
        display: none;
    }
    .nav .item.abierto .dropdown { display: block; }

    .footer-top { grid-template-columns: 1fr 1fr; gap: 30px; }
}
@media (max-width: 560px) {
    .contenedor, .navbar { padding-left: 20px; padding-right: 20px; }
    .footer-top { grid-template-columns: 1fr; }
    .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ============================================================================
   FASE 2 — Páginas internas (cabecera de página, prosa, tarjetas, reseñas…)
   ========================================================================== */

/* ---- Cabecera de página interna ----------------------------------------- */
.page-hero {
    position: relative; color: var(--c-fondo-claro); overflow: hidden;
    background: var(--c-terracota);
    padding: 180px 0 70px; /* deja hueco bajo la navbar fija */
}
.page-hero--foto { background-size: cover; background-position: center; }
.page-hero::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(20,12,8,.35), rgba(20,12,8,.6));
}
.page-hero .contenedor { position: relative; z-index: 1; }
.page-hero .migas { font-size: 12px; letter-spacing: .22em; text-transform: uppercase; opacity: .8; margin-bottom: 14px; }
.page-hero h1 { font-family: var(--f-serif); font-style: italic; font-weight: 500; font-size: clamp(34px, 5.5vw, 64px); }
.page-hero .subtitulo { font-family: var(--f-serif); font-size: clamp(17px, 2.2vw, 22px); opacity: .92; margin-top: 14px; max-width: 50ch; }

/* ---- Prosa (artículos / textos largos) ---------------------------------- */
.prosa { max-width: 760px; margin: 0 auto; }
.prosa > .lead {
    font-family: var(--f-serif); font-size: clamp(20px, 2.6vw, 26px);
    line-height: 1.5; color: var(--c-texto); margin-bottom: 30px;
}
.prosa p { margin: 0 0 20px; color: var(--c-texto); }
.prosa h2 {
    font-size: clamp(24px, 3.4vw, 34px); margin: 46px 0 14px;
    padding-top: 10px;
}
.prosa h3 { font-size: 22px; margin: 32px 0 10px; color: var(--c-terracota); }
.prosa ul { margin: 0 0 24px; padding-left: 0; list-style: none; }
.prosa ul li {
    position: relative; padding-left: 26px; margin-bottom: 10px; color: var(--c-texto-suave);
}
.prosa ul li::before {
    content: ''; position: absolute; left: 4px; top: 12px;
    width: 7px; height: 7px; border-radius: 50%; background: var(--c-arena);
}
.prosa blockquote {
    margin: 30px 0; padding: 4px 0 4px 26px; border-left: 3px solid var(--c-arena);
    font-family: var(--f-serif); font-style: italic; font-size: 21px; color: var(--c-texto-suave);
}
.prosa blockquote cite { display: block; font-style: normal; font-size: 14px; margin-top: 8px; color: var(--c-tenue); }
.prosa .firma { font-family: var(--f-serif); font-size: 18px; color: var(--c-texto-suave); margin-top: 30px; }

/* ---- Rejilla de tarjetas (prácticas, disciplinas, terapias) ------------- */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; margin-top: 40px; }
.card {
    background: var(--c-fondo-claro); border: 1px solid var(--c-borde); border-radius: var(--radio);
    padding: 28px 26px; display: flex; flex-direction: column; gap: 10px;
    transition: transform .25s, box-shadow .25s, border-color .25s;
}
.card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(43,39,34,.12); border-color: var(--c-arena); }
.card h3 { font-family: var(--f-titulo); font-size: 22px; margin: 0; }
.card p { color: var(--c-texto-suave); margin: 0; font-size: 15px; flex: 1; }
.card .mas {
    font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--c-terracota);
    display: inline-flex; align-items: center; gap: 6px; margin-top: 6px;
}
.card .mas::after { content: '→'; transition: transform .2s; }
.card:hover .mas::after { transform: translateX(4px); }

/* ---- Reseñas (Google) --------------------------------------------------- */
.reviews-head { text-align: center; margin-bottom: 10px; }
.reviews-head .estrellas { color: #E8A33D; letter-spacing: 3px; font-size: 18px; }
.reviews-head .nota { font-family: var(--f-titulo); font-size: 20px; margin-top: 6px; }
.reviews-head .fuente { font-size: 13px; color: var(--c-tenue); }
.reviews { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; margin-top: 36px; }
.review {
    background: var(--c-fondo-claro); border: 1px solid var(--c-borde); border-radius: var(--radio);
    padding: 26px;
}
.review .estrellas { color: #E8A33D; letter-spacing: 2px; font-size: 14px; }
.review p { font-family: var(--f-serif); font-size: 17px; color: var(--c-texto); margin: 12px 0 14px; line-height: 1.5; }
.review .autor { font-size: 13px; letter-spacing: .08em; color: var(--c-tenue); text-transform: uppercase; }

/* ---- Banda de llamada a la acción ---------------------------------------- */
.cta-band { background: var(--c-terracota); color: var(--c-fondo-claro); text-align: center; padding: 70px 0; }
.cta-band h2 { font-family: var(--f-serif); font-style: italic; font-weight: 500; font-size: clamp(26px, 4vw, 40px); }
.cta-band p { max-width: 46ch; margin: 14px auto 28px; opacity: .92; }

/* ---- Agenda (eventos/retiros en la home) -------------------------------- */
.agenda-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-top: 40px; }
.agenda-col h3 { font-size: 22px; margin-bottom: 18px; }
.agenda-item { display: flex; gap: 18px; padding: 18px 0; border-top: 1px solid var(--c-borde); }
.agenda-item .fecha {
    flex: none; width: 64px; text-align: center; font-family: var(--f-titulo);
    line-height: 1.1; color: var(--c-terracota);
}
.agenda-item .fecha .dia { font-size: 26px; display: block; }
.agenda-item .fecha .mes { font-size: 12px; letter-spacing: .14em; text-transform: uppercase; }
.agenda-item .info h4 { font-family: var(--f-titulo); font-weight: 400; font-size: 18px; margin: 0 0 4px; }
.agenda-item .info span { font-size: 14px; color: var(--c-texto-suave); }
.agenda-nota { font-size: 13px; color: var(--c-tenue); margin-top: 18px; font-style: italic; }

/* ---- Formulario de contacto --------------------------------------------- */
.contacto-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 50px; align-items: start; }
.contacto-datos .dato { margin-bottom: 22px; }
.contacto-datos .dato .etq { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: var(--c-tenue); }
.contacto-datos .dato a, .contacto-datos .dato p { font-family: var(--f-serif); font-size: 20px; color: var(--c-texto); margin: 4px 0 0; }
.form-campo { margin-bottom: 18px; }
.form-campo label { display: block; font-size: 13px; letter-spacing: .06em; color: var(--c-texto-suave); margin-bottom: 7px; }
.form-campo input, .form-campo textarea {
    width: 100%; background: var(--c-fondo-claro); border: 1px solid var(--c-borde); border-radius: 10px;
    padding: 13px 15px; font-family: var(--f-texto); font-size: 15px; color: var(--c-texto);
    transition: border-color .2s, box-shadow .2s;
}
.form-campo input:focus, .form-campo textarea:focus {
    outline: none; border-color: var(--c-terracota); box-shadow: 0 0 0 3px rgba(169,84,37,.12);
}
.form-campo textarea { resize: vertical; min-height: 130px; }
.aviso {
    border-radius: 12px; padding: 14px 18px; font-size: 14px; margin-bottom: 22px;
}
.aviso--info { background: #EFE7D9; color: var(--c-texto-suave); border: 1px solid var(--c-borde); }
.aviso--ok { background: #E7F0E3; color: #3c6b30; border: 1px solid #c4ddb8; }

/* ---- Mapa embebido ------------------------------------------------------- */
.mapa { border: 0; width: 100%; height: 380px; border-radius: var(--radio); filter: grayscale(.2); }

@media (max-width: 860px) {
    .contacto-grid, .agenda-cols { grid-template-columns: 1fr; gap: 34px; }
    .page-hero { padding-top: 140px; }
}

/* ============================================================================
   FASE 4 — Calendario público (agenda) + ficha de actividad
   ========================================================================== */

/* ---- Barra de controles -------------------------------------------------- */
.agenda-controles {
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
    gap: 16px; margin-bottom: 28px;
}
.vista-toggle, .tipo-filtro { display: inline-flex; background: var(--c-fondo-claro);
    border: 1px solid var(--c-borde); border-radius: 999px; padding: 4px; gap: 2px; }
.vista-toggle a, .tipo-filtro a {
    font-size: 13px; letter-spacing: .04em; padding: 8px 16px; border-radius: 999px;
    color: var(--c-texto-suave); transition: background .2s, color .2s; white-space: nowrap;
}
.vista-toggle a.activo, .tipo-filtro a.activo { background: var(--c-terracota); color: var(--c-fondo-claro); }
.vista-toggle a:hover:not(.activo), .tipo-filtro a:hover:not(.activo) { color: var(--c-terracota); }

.cal-nav { display: inline-flex; align-items: center; gap: 16px; }
.cal-nav a { width: 38px; height: 38px; display: inline-flex; align-items: center; justify-content: center;
    border: 1px solid var(--c-borde); border-radius: 50%; color: var(--c-texto); transition: all .2s; }
.cal-nav a:hover { background: var(--c-terracota); color: var(--c-fondo-claro); border-color: var(--c-terracota); }
.cal-nav .periodo { font-family: var(--f-titulo); font-size: 22px; min-width: 200px; text-align: center; text-transform: capitalize; }

/* ---- Vista MES (rejilla) ------------------------------------------------- */
.cal-mes { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.cal-dow { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--c-tenue);
    text-align: center; padding: 6px 0; }
.cal-dia {
    background: var(--c-fondo-claro); border: 1px solid var(--c-borde); border-radius: 10px;
    min-height: 104px; padding: 8px; display: flex; flex-direction: column; gap: 5px;
}
.cal-dia.otro { background: transparent; border-color: transparent; }
.cal-dia.otro .cal-num { color: var(--c-borde-claro); }
.cal-dia.hoy { border-color: var(--c-terracota); box-shadow: inset 0 0 0 1px var(--c-terracota); }
.cal-num { font-family: var(--f-titulo); font-size: 15px; color: var(--c-texto-suave); }
.cal-dia.hoy .cal-num { color: var(--c-terracota); font-weight: bold; }
.cal-evento {
    display: block; font-size: 11.5px; line-height: 1.25; padding: 5px 7px; border-radius: 6px;
    background: var(--c-fondo-suave); color: var(--c-texto); border-left: 3px solid var(--c-arena);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transition: background .15s;
}
.cal-evento:hover { background: #E8DAC6; }
.cal-evento.t-evento { border-left-color: #38606f; }
.cal-evento.t-retiro { border-left-color: #6f3868; }
.cal-evento.t-clase  { border-left-color: var(--c-arena); }
.cal-evento .h { color: var(--c-tenue); }

/* ---- Vista SEMANA (lista de días) ---------------------------------------- */
.cal-semana { display: flex; flex-direction: column; gap: 2px; }
.semana-dia { display: grid; grid-template-columns: 120px 1fr; gap: 20px; padding: 18px 0;
    border-top: 1px solid var(--c-borde); }
.semana-dia.hoy .sd-fecha { color: var(--c-terracota); }
.sd-fecha { font-family: var(--f-titulo); }
.sd-fecha .sd-num { font-size: 30px; line-height: 1; }
.sd-fecha .sd-dow { font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-tenue); }
.sd-eventos { display: flex; flex-direction: column; gap: 10px; }
.sd-vacio { color: var(--c-tenue); font-style: italic; font-size: 14px; padding-top: 6px; }
.sd-evento {
    display: flex; align-items: center; gap: 14px; background: var(--c-fondo-claro);
    border: 1px solid var(--c-borde); border-radius: 12px; padding: 12px 16px; transition: border-color .2s, transform .15s;
}
.sd-evento:hover { border-color: var(--c-arena); transform: translateX(3px); }
.sd-evento .sd-hora { font-family: var(--f-titulo); color: var(--c-terracota); font-size: 14px; min-width: 92px; }
.sd-evento .sd-tit { font-weight: 500; }
.sd-evento .sd-precio { margin-left: auto; font-size: 13px; }

/* ---- Ficha de actividad (detalle) --------------------------------------- */
.ficha { display: grid; grid-template-columns: 1.4fr 1fr; gap: 44px; align-items: start; }
.ficha-cuerpo .descripcion { font-size: 17px; color: var(--c-texto); line-height: 1.7; }
.ficha-cuerpo .descripcion p { margin: 0 0 16px; }
.ficha-lateral {
    background: var(--c-fondo-claro); border: 1px solid var(--c-borde); border-radius: var(--radio);
    padding: 28px; position: sticky; top: 100px;
}
.ficha-dato { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--c-borde-claro); font-size: 15px; }
.ficha-dato:last-of-type { border-bottom: 0; }
.ficha-dato .etq { color: var(--c-tenue); min-width: 96px; }
.ficha-dato .val { color: var(--c-texto); font-weight: 500; }
.ficha-precio { font-family: var(--f-titulo); font-size: 32px; color: var(--c-terracota); margin: 6px 0 4px; }
.ficha-lateral .btn { width: 100%; margin-top: 16px; }
.ficha-imagen { width: 100%; border-radius: var(--radio); margin-bottom: 24px; }

@media (max-width: 860px) {
    .ficha { grid-template-columns: 1fr; gap: 28px; }
    .ficha-lateral { position: static; }
    .cal-mes { gap: 4px; }
    .cal-dia { min-height: 78px; padding: 5px; }
    .cal-evento { font-size: 10px; padding: 3px 5px; }
    .cal-nav .periodo { min-width: 130px; font-size: 18px; }
    .semana-dia { grid-template-columns: 80px 1fr; gap: 12px; }
}
@media (max-width: 560px) {
    /* En móvil, el mes oculta texto de eventos y deja solo un punto por día con actividad */
    .cal-dow { font-size: 9px; letter-spacing: .05em; }
    .cal-evento { text-indent: -9999px; height: 6px; padding: 0; border-radius: 3px; border-left-width: 0; background: var(--c-terracota); }
    .cal-evento.t-evento { background: #38606f; } .cal-evento.t-retiro { background: #6f3868; }
}
