@import url('https://fonts.googleapis.com/css2?family=Arimo:ital,wght@0,400;0,600;0,700;1,400&display=swap');
/* Design section styles matching requested palette */
:root{
  --blue:#1e3a8a; /* titles */
  --green: rgb(98,242,202); /* subtitles */
}
*{box-sizing:border-box}
body{margin:0;font-family: 'Arimo', Arial, sans-serif;background:#fff;color:#222}
a{color:var(--blue);text-decoration:none}
.container{max-width:1400px;margin:0 auto;padding:24px}
.header, .footer{padding:16px 0}
.header .site-title{font-size:1.4rem;font-weight:700;color:var(--blue)}
.nav{display:flex;gap:16px;flex-wrap:wrap}
.nav a{padding:6px 8px;border-radius:6px}
.nav a:hover{background:#f2f2f2}

/* Header gradient nav variant */
.header{color:#222}
.header[style*="linear-gradient"] .nav a{color:#111}
.header[style*="linear-gradient"] .nav a:hover{background:rgba(0,0,0,.06)}
.header[style*="linear-gradient"] .site-title{color:#111}

h1{color:var(--blue);margin:0 0 12px}
h2{color:var(--green);margin:24px 0 8px}
.subtitle{color:var(--green)}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card{border:4px solid var(--card-accent, #e5e7eb);border-radius:12px;padding:16px;background:#fff}
.card h3{color:var(--blue);margin-top:0}
.card .meta{color:#666;font-size:0.9rem}
.btn{display:inline-block;background:var(--blue);color:#fff;border:none;border-radius:10px;padding:10px 14px;font-weight:600}
.btn.secondary{background:var(--green);color:#003b2f}
.section{padding:24px 0}
.muted{color:#666}
.hero{padding:48px 24px;background:#fff}
.hero p{margin:0}

/* Detail page gradient gray background */
.detail-bg{background:linear-gradient(180deg, #f3f4f6 0%, #e5e7eb 100%)}
.detail .dates{list-style:none;padding:0;margin:0}
.detail .dates li{display:flex;align-items:center;justify-content:space-between;border:1px solid #ddd;background:#fff;border-radius:10px;padding:12px 14px;margin-bottom:12px}

/* Detail page extended description block: jean-like blue with white text, no borders */
.detail-desc{background: linear-gradient(135deg, #1f3552 0%, #2a4365 60%, #1e3a8a 100%); color:#fff; padding:24px 20px; border:none; border-radius:12px; box-shadow: 0 6px 16px rgba(0,0,0,.12)}
.detail-desc h2, .detail-desc h3, .detail-desc p, .detail-desc ul, .detail-desc li{color:#fff}
.detail-desc a{color:#a7f3d0}
.detail-desc ul{padding-left:18px}

/* Biography sepia image */
.bio-photo{filter:sepia(100%);border-radius:12px;max-width:100%;height:auto}

/* Agenda filters */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0 20px}
.filter-btn{border:1px solid #e5e7eb;background:#f9fafb;color:#222;padding:8px 12px;border-radius:999px;cursor:pointer;font-weight:600}
/* Generic active style (kept for non-activity filters like "Todas") */
.filter-btn.active{background:#1e3a8a;color:#fff;border-color:#1e3a8a}
/* Per-activity filter tag colors (default state) */
.filter-btn[data-filter="ncf"]{background:#cfefff;color:#0b3a5c;border-color:#cfefff}
.filter-btn[data-filter="taller-presencial-verde"]{background:#d7fbe8;color:#064e3b;border-color:#d7fbe8}
.filter-btn[data-filter="taller-presencial-rosa"]{background:#fde2f3;color:#7a2849;border-color:#fde2f3}
.filter-btn[data-filter="progest"]{background:#fff3cd;color:#7a5b00;border-color:#fff3cd}
.filter-btn[data-filter="eev"]{background:#ede2ff;color:#433878;border-color:#ede2ff}
/* Keep same colors when active so selection doesn’t turn blue */
.filter-btn.active[data-filter="ncf"],
.filter-btn.active[data-filter="taller-presencial-verde"],
.filter-btn.active[data-filter="taller-presencial-rosa"],
.filter-btn.active[data-filter="progest"],
.filter-btn.active[data-filter="eev"]{color:inherit;background:inherit;border-color:inherit; box-shadow: 0 0 0 2px rgba(0,0,0,.03) inset}
/* Slight hover emphasis */
.filter-btn[data-filter]:hover{filter:brightness(0.97)}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:0.8rem;font-weight:600}
.badge.ncf{background:#cfefff;color:#0b3a5c}       /* celeste claro */
.badge.taller-presencial-verde{background:#d7fbe8;color:#064e3b} /* verde claro */
.badge.taller-presencial-rosa{background:#fde2f3;color:#7a2849}  /* rosa claro */
.badge.progest{background:#fff3cd;color:#7a5b00}                 /* crema */
.badge.eev{background:#ede2ff;color:#433878}                     /* lila claro */
/* Make card border follow badge color (without :has() for broader support) */
.card[data-type="ncf"], .card.ncf{--card-accent:#cfefff}
.card[data-type="taller-presencial-verde"], .card.taller-presencial-verde{--card-accent:#d7fbe8}
.card[data-type="taller-presencial-rosa"], .card.taller-presencial-rosa{--card-accent:#fde2f3}
.card[data-type="progest"], .card.progest{--card-accent:#fff3cd}
.card[data-type="eev"], .card.eev{--card-accent:#ede2ff}

/* Hide helper */
.hidden{display:none !important}

/* Responsive */
.carousel{position:relative;overflow:hidden;border-radius:12px}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel img, .carousel video{width:100%;display:block;flex:0 0 100%;height:auto}
.carousel .controls{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 8px;pointer-events:none}
.carousel button{pointer-events:auto;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:999px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.carousel .dots{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:6px;justify-content:center}
.carousel .dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.6);border:0}
.carousel .dot.active{background:#fff}

.detail-hero{position:relative; background: linear-gradient(180deg,#e9ecef 0%, #dfe3e8 100%); padding:0}
.detail-hero .carousel{border-radius:0;max-height:60vh}
/* Make media a bit dimmer so text stands out */
.detail-hero .carousel img, .detail-hero .carousel video{height:60vh;object-fit:cover;filter:brightness(.78)}
/* Slightly stronger overlay for better contrast */
.detail-hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.42) 60%, rgba(0,0,0,.65) 100%);display:flex;align-items:center;justify-content:center;text-align:center;padding:24px}
.detail-hero .title-wrap{color:#fff;max-width:900px}
/* Add soft text shadow to enhance legibility over imagery */
.detail-hero .title-wrap h1{margin:0;font-size: clamp(2rem, 5vw, 4rem);line-height:1.05;letter-spacing:.2px;text-shadow:0 2px 8px rgba(0,0,0,.5), 0 1px 2px rgba(0,0,0,.35); color: white;}
.detail-hero .title-wrap .subtitle{color:rgb(98,242,202);font-weight:600;font-size: clamp(1rem, 2.2vw, 1.4rem);text-shadow:0 1px 3px rgba(0,0,0,.45)}

/* Home activity visual cards */
.activity-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.activity-card{position:relative;border-radius:16px;overflow:hidden;min-height:480px;display:flex;align-items:flex-end;color:#fff}
/* Ensure background fully covers the card and is slightly dimmer */
.activity-card .bg{position:absolute;inset:0;background-size:cover;background-repeat:no-repeat;background-position:center;filter:brightness(.65);background-color:#000}
.activity-card .color{position:absolute;inset:0}
/* Increase vertical padding to give text more air above and below */
.activity-card .content{position:relative;padding:24px 18px;z-index:2}
.activity-card h3{margin:0 0 6px 0;font-size: clamp(1.4rem, 3.4vw, 2.4rem);color:#fff}
.activity-card .tag{display:inline-block;margin-top:2px;background:rgba(0,0,0,.4);border-radius:999px;padding:6px 12px;font-size:.9rem}
.activity-card:hover{transform:translateY(-2px)}
.activity-card{transition:transform .2s ease}

/* Responsive */
@media (max-width: 700px){
  .grid-2{grid-template-columns:1fr}
  .activity-cards{grid-template-columns:1fr}
  .detail-hero .carousel img, .detail-hero .carousel video{height:50vh}
}

/* Home hero banner tweaks */
.home-hero-banner .home-hero-name{letter-spacing:.2px}

/* Non-flex, non-grid helpers for Home */
.hero-line{display:table;width:100%;min-height:calc(100vh - 80px)}
.hero-line-inner{display:table-cell;vertical-align:middle;text-align:center}
.hero-inline{display:inline-block;white-space:nowrap}
.hero-inline .home-hero-name{display:inline-block;vertical-align:middle;margin:0 24px}
.hero-inline img{display:inline-block;vertical-align:middle}
/*.hero-logo{width:33%;object-fit:contain}*/
.hero-photo{border-radius:12px;object-fit:contain;}

/* Activities 2x2 without grid/flex */
.activity-rows{text-align:center}
.activity-tile{display:inline-block;width:48%;margin:1%;position:relative;border-radius:16px;overflow:hidden;min-height:180px;color:#fff;vertical-align:top}
.activity-tile .tile-bg,.activity-tile .tile-color{position:absolute;left:0;top:0;right:0;bottom:0;background-size:cover;background-position:center;filter:brightness(.75)}
.activity-tile .tile-content{position:absolute;left:0;right:0;bottom:0;padding:18px 16px}
.activity-tile h3{margin:0;font-size: clamp(1.3rem, 3.2vw, 2.2rem);color:#fff}
.activity-tile .tag{display:inline-block;margin-top:6px;background:rgba(0,0,0,.4);border-radius:999px;padding:4px 10px;font-size:.85rem}

/* Two columns without grid/flex */
.two-col{font-size:0;text-align:center}
.two-col .col{display:inline-block;width:49%;vertical-align:middle;font-size:16px;text-align:left}
.two-col .col-image img{width:100%;height:100%;object-fit:cover;border-radius:12px}
@media (max-width: 700px){
  .activity-tile{width:100%;margin:0 0 12px 0}
  .two-col .col{width:100%;display:block}
}


/* Masonry gallery */
.masonry{column-count:3;column-gap:16px}
.masonry-item{break-inside:avoid;margin:0 0 16px}
.masonry-item img{width:100%;height:auto;border-radius:12px;display:block}
@media (max-width: 1000px){.masonry{column-count:2}}
@media (max-width: 600px){.masonry{column-count:1}}

/* Videos grid */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.video-grid video{width:100%;height:auto;border-radius:12px;background:#000}
