/* Estilos Compartidos */
.hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); 
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.hero-overlay h1 {
    font-size: 2.5rem;
    font-weight: bold;
    color: #fff;
    padding: 0 20px;
    z-index: 1;
}

.hero-overlay p {
    font-size: 1.2rem;
    color: #fff;
    padding: 0 20px;
    margin-top: 10px;
    z-index: 1;
}

.intro-section {
    margin-bottom: 40px;
    text-align: center;
}

.intro-section p {
    font-size: 1.1rem;
    line-height: 1.8;
    color: #333;
    text-align: justify;
    padding: 0 15px;
}

.modelo-educativo-section,
.vida-estudiantil-section,
.programas-academicos-section,
.compromiso-section {
    margin-bottom: 40px;
    text-align: center;
}

.modelo-educativo-section h2,
.vida-estudiantil-section h2,
.programas-academicos-section h2,
.compromiso-section h2 {
    font-size: 2rem;
    color: var(--color-primary);
    margin-bottom: 15px;
}

.modelo-educativo-section p,
.vida-estudiantil-section p,
.programas-academicos-section p,
.compromiso-section p {
    font-size: 1.1rem;
    line-height: 1.8;
    color: #333;
    text-align: justify;
    padding: 0 15px;
    margin-bottom: 20px;
}

.cta-section {
    text-align: center;
    padding: 2rem 0;
}

.cta-section h2 {
    font-size: 2rem;
    color: var(--color-primary);
    margin-bottom: 15px;
}

.cta-section p {
    font-size: 1.1rem;
    line-height: 1.8;
    color: #333;
    text-align: justify;
    padding: 0 15px;
    margin-bottom: 20px;
}

.btn-cta {
    display: inline-block;
    padding: 12px 30px;
    background-color: #D32F2F;
    color: #fff;
    text-decoration: none;
    border-radius: 25px;
    font-size: 1.2rem;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.3s ease;
}

.btn-cta:hover {
    background-color: #b71c1c; 
    transform: translateY(-3px); 
}

/* Estilos de Cards */
.modelo-grid,
.vida-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); 
    gap: 20px;
    padding: 0 15px;
}

.modelo-item,
.vida-item {
    background: #fff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: var(--shadow);
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.modelo-item img,
.vida-item img {
    width: 100%;
    height: 200px; 
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 15px;
}

.modelo-item h3,
.vida-item h3 {
    font-size: 1.5rem;
    color: var(--color-primary);
    margin-bottom: 10px;
}

.modelo-item p,
.vida-item p {
    font-size: 1rem;
    line-height: 1.6;
    color: #666;
    text-align: justify;
    flex-grow: 1;
}

/* ===== Bachillerato — Diseño editorial moderno (Opción B) ===== */
:root{
  --ib2-primary: var(--color-primary, #1a4b8c);
  --ib2-accent: #D32F2F;
  --ib2-border: #e6e8eb;
  --ib2-muted: #5b6675;
  --ib2-shadow: 0 10px 30px rgba(0,0,0,.08);
  --ib2-r: 18px;
}

.ib-bach2--modern{ background:#fff; color:#121417; }

/* HERO */
.ib2-hero{ position:relative; height:440px; overflow:hidden; }
.ib2-hero__bg img{ width:100%; height:100%; object-fit:cover; display:block; filter:brightness(.72) saturate(1.02); object-position: center 100% !important; }
.ib2-hero__content{
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center;
  padding-left:min(8vw, 120px); padding-right:20px; color:#fff;
}
.ib2-eyebrow{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.35); font-weight:800; letter-spacing:.35px;
}
.ib2-hero h1{ font-size:2.6rem; margin:12px 0 6px; line-height:1.15; }
.ib2-hero p{ font-size:1.12rem; max-width:720px; opacity:.95; }

.ib2-hero .ib2-hero__bg img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: brightness(.72) saturate(1.02);

    /* → valor que alinea el horizonte y sube ligeramente el encuadre */
    object-position: center 82% !important;

    /* → movimiento adicional para centrar el grupo */
    transform: translateY(-40%);
}

/* LAYOUT */
.ib2-wrap{ max-width:1200px; margin:0 auto; display:grid; grid-template-columns:260px 1fr; gap:28px; padding:42px 20px; }
.ib2-aside{ position:sticky; top:72px; align-self:start; }
.ib2-toc{ display:flex; flex-direction:column; gap:6px; }
.ib2-link{
  text-decoration:none; color:#1b1f24; background:#f7f9fb; border:1px solid #eef0f3; padding:10px 12px; border-radius:12px; font-weight:700;
}
.ib2-link:hover{ background:#edf3ff; border-color:#d7e3ff; }
.ib2-main{ min-width:0; }
.ib2-section{ margin-bottom:46px; }

/* ENCABEZADOS / PROSA */
.ib2-header{ margin-bottom:14px; }
.ib2-h2{ font-size:2rem; color:var(--ib2-primary); margin:4px 0 6px; line-height:1.2; }
.ib2-h3{ font-size:1.2rem; margin:0 0 6px; }
.ib2-lead{ color:var(--ib2-muted); max-width:78ch; }
.ib2-prose p{ font-size:1.05rem; line-height:1.75; color:#2a2f36; text-align:justify; }

/* BLOQUES EDITORIALES (media rows) */
.ib2-media-row{
  display:grid; grid-template-columns: minmax(240px, 360px) 1fr; gap:20px;
  padding:18px 0; border-top:1px solid var(--ib2-border);
}
.ib2-media-row:first-of-type{ border-top:0; padding-top:0; }
.ib2-media{ overflow:hidden; border-radius:16px; box-shadow:var(--ib2-shadow); }
.ib2-media img{ width:100%; height:100%; object-fit:cover; display:block; max-height:220px; }
.ib2-media__body p{ margin:0; color:#2a2f36; line-height:1.7; }

/* MATRIZ DE PROGRAMAS (dt/dd) */
.ib2-matrix{ margin:12px 0 0; border-top:1px dashed var(--ib2-border); }
.ib2-matrix__row{
  display:grid; grid-template-columns: 180px 1fr; gap:16px;
  padding:14px 0; border-bottom:1px dashed var(--ib2-border);
}
.ib2-matrix__row dt{ font-weight:900; color:#1c2530; }
.ib2-matrix__row dd{ margin:0; color:#394150; }
.ib2-badges{ list-style:none; padding:0; margin:14px 0 0; display:flex; gap:10px; flex-wrap:wrap; }
.ib2-badges li{
  border:1px solid var(--ib2-border); padding:8px 12px; border-radius:999px; background:#fff; font-weight:700;
}

/* TIRAS DE VIDA ESTUDIANTIL */
.ib2-media-strip{
  display:grid; grid-template-columns: 200px 1fr; gap:14px; align-items:center;
  padding:12px 0; border-bottom:1px solid var(--ib2-border);
}
.ib2-media-strip:last-of-type{ border-bottom:0; }
.ib2-media-strip figure{ margin:0; border-radius:14px; overflow:hidden; box-shadow:var(--ib2-shadow); }
.ib2-media-strip img{ width:100%; height:140px; object-fit:cover; display:block; }

/* CTA */
.ib2-cta__card{
  text-align:center; padding:28px; border-radius:18px;
  background:linear-gradient(135deg, rgba(26,75,140,.08), rgba(211,47,47,.08));
  border:1px solid var(--ib2-border); box-shadow:var(--ib2-shadow);
}
.ib2-btn{
  display:inline-block; margin-top:10px; padding:12px 20px; background:var(--ib2-accent); color:#fff; text-decoration:none;
  border-radius:999px; font-weight:800; transition:transform .2s ease, opacity .2s ease;
}
.ib2-btn:hover{ transform:translateY(-2px); opacity:.95; }

/* RESPONSIVE */
@media (max-width: 980px){
  .ib2-wrap{ grid-template-columns:1fr; }
  .ib2-aside{ position:static; order:-1; }
}
@media (max-width: 760px){
  .ib2-hero{ height:380px; }
  .ib2-hero h1{ font-size:2.1rem; }
  .ib2-media-row{ grid-template-columns:1fr; }
  .ib2-media-strip{ grid-template-columns:1fr; }
  .ib2-matrix__row{ grid-template-columns: 1fr; }
}


/* ===== Secundaria — Diseño editorial moderno ===== */
:root{
  --ibsec-primary: var(--color-primary, #1a4b8c);
  --ibsec-accent: #D32F2F;
  --ibsec-border: #e6e8eb;
  --ibsec-muted: #5b6675;
  --ibsec-shadow: 0 10px 30px rgba(0,0,0,.08);
  --ibsec-r: 18px;
}

.ib-sec--modern{ background:#fff; color:#121417; }

/* HERO */
.ibsec-hero{ position:relative; height:440px; overflow:hidden; }
.ibsec-hero__bg img{ width:100%; height:100%; object-fit:cover; display:block; filter:brightness(.72) saturate(1.02); }
.ibsec-hero__content{
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:center;
  padding-left:min(8vw, 120px); padding-right:20px; color:#fff;
}
.ibsec-eyebrow{
  display:inline-block; padding:6px 10px; border-radius:999px;
  background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.35); font-weight:800; letter-spacing:.35px;
}
.ibsec-hero h1{ font-size:2.6rem; margin:12px 0 6px; line-height:1.15; }
.ibsec-hero p{ font-size:1.12rem; max-width:720px; opacity:.95; }

/* Ajuste del HERO de Secundaria */
.ibsec-hero .ibsec-hero__bg img{
    object-fit: cover;
    object-position: center 80% !important;  /* mover foco hacia abajo */
    transform: translateY(-14%);             /* subir un poco la imagen */
    filter: brightness(.72) saturate(1.02);
}

/* LAYOUT */
.ibsec-wrap{ max-width:1200px; margin:0 auto; display:grid; grid-template-columns:260px 1fr; gap:28px; padding:42px 20px; }
.ibsec-aside{ position:sticky; top:72px; align-self:start; }
.ibsec-toc{ display:flex; flex-direction:column; gap:6px; }
.ibsec-link{
  text-decoration:none; color:#1b1f24; background:#f7f9fb; border:1px solid #eef0f3; padding:10px 12px; border-radius:12px; font-weight:700;
}
.ibsec-link:hover{ background:#edf3ff; border-color:#d7e3ff; }
.ibsec-main{ min-width:0; }
.ibsec-section{ margin-bottom:46px; }

/* ENCABEZADOS / PROSA */
.ibsec-header{ margin-bottom:14px; }
.ibsec-h2{ font-size:2rem; color:var(--ibsec-primary); margin:4px 0 6px; line-height:1.2; }
.ibsec-h3{ font-size:1.2rem; margin:0 0 6px; }
.ibsec-lead{ color:var(--ibsec-muted); max-width:78ch; }
.ibsec-prose p{ font-size:1.05rem; line-height:1.75; color:#2a2f36; text-align:justify; }

/* BLOQUES EDITORIALES (media rows) */
.ibsec-media-row{
  display:grid; grid-template-columns: minmax(240px, 360px) 1fr; gap:20px;
  padding:18px 0; border-top:1px solid var(--ibsec-border);
}
.ibsec-media-row:first-of-type{ border-top:0; padding-top:0; }
.ibsec-media{ overflow:hidden; border-radius:16px; box-shadow:var(--ibsec-shadow); }
.ibsec-media img{ width:100%; height:100%; object-fit:cover; display:block; max-height:220px; }
.ibsec-media__body p{ margin:0; color:#2a2f36; line-height:1.7; }

/* MATRIZ DE PROGRAMAS */
.ibsec-matrix{ margin:12px 0 0; border-top:1px dashed var(--ibsec-border); }
.ibsec-matrix__row{
  display:grid; grid-template-columns: 180px 1fr; gap:16px;
  padding:14px 0; border-bottom:1px dashed var(--ibsec-border);
}
.ibsec-matrix__row dt{ font-weight:900; color:#1c2530; }
.ibsec-matrix__row dd{ margin:0; color:#394150; }
.ibsec-badges{ list-style:none; padding:0; margin:14px 0 0; display:flex; gap:10px; flex-wrap:wrap; }
.ibsec-badges li{
  border:1px solid var(--ibsec-border); padding:8px 12px; border-radius:999px; background:#fff; font-weight:700;
}

/* VIDA ESTUDIANTIL */
.ibsec-media-strip{
  display:grid; grid-template-columns: 200px 1fr; gap:14px; align-items:center;
  padding:12px 0; border-bottom:1px solid var(--ibsec-border);
}
.ibsec-media-strip:last-of-type{ border-bottom:0; }
.ibsec-media-strip figure{ margin:0; border-radius:14px; overflow:hidden; box-shadow:var(--ibsec-shadow); }
.ibsec-media-strip img{ width:100%; height:140px; object-fit:cover; display:block; }

/* GALERÍA + LIGHTBOX CSS-only */
.ibsec-gallery{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:12px;
}
.ibsec-thumb{ display:block; border-radius:12px; overflow:hidden; border:1px solid var(--ibsec-border); }
.ibsec-thumb img{ width:100%; height:150px; object-fit:cover; display:block; transition:transform .2s ease; }
.ibsec-thumb:hover img{ transform:scale(1.04); }

/* Lightbox mediante :target */
.ibsec-lightbox{
  position:fixed; inset:0; background:rgba(0,0,0,.85); display:none; align-items:center; justify-content:center; z-index:1000;
  padding:20px;
}
.ibsec-lightbox img{ max-width:92vw; max-height:86vh; border-radius:12px; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.ibsec-lightbox__close{
  position:fixed; top:16px; right:24px; font-size:2rem; color:#fff; text-decoration:none; line-height:1;
}
.ibsec-lightbox:target{ display:flex; }

/* CTA */
.ibsec-cta__card{
  text-align:center; padding:28px; border-radius:18px;
  background:linear-gradient(135deg, rgba(26,75,140,.08), rgba(211,47,47,.08));
  border:1px solid var(--ibsec-border); box-shadow:var(--ibsec-shadow);
}
.ibsec-btn{
  display:inline-block; margin-top:10px; padding:12px 20px; background:var(--ibsec-accent); color:#fff; text-decoration:none;
  border-radius:999px; font-weight:800; transition:transform .2s ease, opacity .2s ease;
}
.ibsec-btn:hover{ transform:translateY(-2px); opacity:.95; }

/* RESPONSIVE */
@media (max-width: 980px){
  .ibsec-wrap{ grid-template-columns:1fr; }
  .ibsec-aside{ position:static; order:-1; }
}
@media (max-width: 760px){
  .ibsec-hero{ height:380px; }
  .ibsec-hero h1{ font-size:2.1rem; }
  .ibsec-media-row{ grid-template-columns:1fr; }
  .ibsec-media-strip{ grid-template-columns:1fr; }
  .ibsec-matrix__row{ grid-template-columns: 1fr; }
  .ibsec-thumb img{ height:130px; }
}


/* ====== Tokens IDIOMAS ====== */
:root{
  --color-primary:#0e5ba9;
  --color-secondary:#e74c3c;
  --color-text:#2b2b2b;
  --color-muted:#6b7280;
  --color-bg:#f7f7fb;
  --color-white:#fff;
  --shadow:0 10px 30px rgba(0,0,0,.08);
  --radius:16px;
  --transition:.25s ease;
}

.idiomas{ background:var(--color-bg); color:var(--color-text); }

/* ====== HERO ====== */
.idiomas-hero{
  position:relative; height: 480px; display:grid; place-items:center; overflow:hidden;
  background: radial-gradient(70% 90% at 70% 20%, rgba(14,91,169,.25), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.55)),
              url("../images/len-hero.jpg") 50% 25% / cover no-repeat;
  color:#fff;
  background-attachment: fixed;
}
.idiomas-hero .overlay{ text-align:center; padding: 0 24px; }
.idiomas-hero h1{ font-size: clamp(2rem, 5vw, 3rem); margin:0 0 10px; }
.idiomas-hero p{ font-size: clamp(1rem, 2.2vw, 1.15rem); opacity:.95; }
.btn-hero{
  margin-top:18px; display:inline-block; padding:12px 22px; border-radius:999px;
  background:var(--color-primary); color:#fff; text-decoration:none; font-weight:700;
  box-shadow:0 8px 24px rgba(14,91,169,.35); transition: transform var(--transition), box-shadow var(--transition);
}
.btn-hero:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(14,91,169,.45); }
.globe-animation{
  position:absolute; inset:auto -15% -25% auto; width:min(900px, 90vw); height: 900px;
  background: radial-gradient(closest-side, rgba(255,255,255,.08), transparent 60%);
  filter: blur(30px); opacity:.5; pointer-events:none;
}

/* ====== INTRO + METODO ====== */
.idiomas-metodo{ max-width:1200px; margin: 60px auto; padding: 0 20px; }
.idiomas-metodo .intro-wrap{ background:#fff; border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow); margin-bottom: 26px; }
.idiomas-metodo p{ color:var(--color-text); line-height:1.7; }
.idiomas-metodo h2{ text-align:center; font-size: clamp(1.6rem, 3vw, 2rem); margin: 20px 0 24px; }

.metodo-grid{ display:grid; gap:18px; grid-template-columns: repeat(3, 1fr); }
.metodo-item{
  background: var(--color-white); border-radius: var(--radius); padding: 24px;
  box-shadow: var(--shadow); transition: transform var(--transition), box-shadow var(--transition);
}
.metodo-item:hover{ transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0,0,0,.12); }
.metodo-item img{ width:54px; height:54px; margin-bottom:12px; }
.metodo-item h3{ margin:6px 0 6px; font-size:1.05rem; }
.metodo-item p{ color: var(--color-muted); line-height:1.6; }

/* ====== PROPUESTA (tu bloque len7.webp) ====== */
.idiomas-propuesta{ max-width:1200px; margin: 60px auto; padding: 0 20px; }
.idiomas-propuesta h2{ text-align:center; margin-bottom: 20px; }
.propuesta-grid{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:20px; background:#fff; padding:20px;
  border-radius: var(--radius); box-shadow: var(--shadow);
}
.propuesta-grid img{ width:100%; height:320px; object-fit:cover; border-radius: 12px; }
.propuesta-text{ display:flex; flex-direction:column; justify-content:center; }
.propuesta-text h3{ margin-bottom:8px; color:var(--color-primary); }
.propuesta-text p{ color:var(--color-muted); line-height:1.7; }

/* ====== RUTAS (MCER) por idioma ====== */
.idiomas-ruta{ max-width:1100px; margin: 60px auto; padding: 0 20px; }
.idiomas-ruta h2{ text-align:center; margin-bottom: 10px; }
.ruta-card{
  background:#fff; border:1px solid #e5e7eb; border-radius: 16px; padding: 18px; box-shadow: var(--shadow);
  margin-top: 18px;
}
.ruta-card h3{ margin-bottom: 10px; color:#0b2140; }
.ruta-note{ margin-top:10px; color:var(--color-muted); }

.ruta-timeline{
  position:relative; background: #fff; border-radius: 12px;
  padding: 18px; display:flex; justify-content:space-between; gap:10px; border:1px dashed #e5e7eb;
}
.ruta-timeline::before{
  content:""; position:absolute; left:30px; right:30px; top:50%; height:2px; background: linear-gradient(90deg, #e5e7eb, #c7d2fe);
}
.nivel{ position:relative; z-index:1; text-align:center; flex:1; transition: transform var(--transition); }
.nivel span{
  display:inline-grid; place-items:center; width:56px; height:56px; border-radius:999px;
  background:#edf2ff; color:#1e40af; font-weight:700; border:2px solid #c7d2fe;
  box-shadow: 0 6px 16px rgba(29,78,216,.15);
}
.nivel p{ margin-top:6px; color: var(--color-muted); font-size:.95rem; }
.nivel:hover{ transform: translateY(-3px); }

/* ====== GALERÍA (tus imágenes) ====== */
.idiomas-galeria{ max-width:1200px; margin: 60px auto; padding: 0 20px; }
.idiomas-galeria h2{ text-align:center; margin-bottom:22px; }
.galeria-grid{ display:grid; gap:12px; grid-template-columns: repeat(3, 1fr); }
.galeria-grid .galeria-item{
  width:100%; height:220px; object-fit: cover; border-radius: 12px;
  transition: transform var(--transition), filter var(--transition);
}
.galeria-grid .galeria-item:hover{ transform: scale(1.03); filter: saturate(1.08); }

/* ====== CTA ====== */
.idiomas-cta{
  max-width: 1000px; margin: 70px auto; padding: 32px 22px; text-align:center;
  background: linear-gradient(135deg, rgba(14,91,169,.08), rgba(14,91,169,.03));
  border: 1px solid rgba(14,91,169,.15); border-radius: 20px;
}
.idiomas-cta h2{ font-size: clamp(1.4rem, 3vw, 1.9rem); margin: 0 0 10px; }
.idiomas-cta .btn-cta{
  display:inline-block; margin-top:8px; padding: 12px 24px; border-radius: 12px;
  background: var(--color-primary); color:#fff; text-decoration:none; font-weight:700;
  box-shadow: 0 10px 26px rgba(14,91,169,.28); transition: transform var(--transition), box-shadow var(--transition);
}
.idiomas-cta .btn-cta:hover{ transform: translateY(-3px); box-shadow: 0 14px 34px rgba(14,91,169,.35); }

/* ====== Lightbox genérico (si no lo tienes ya) ====== */
.lightbox{ display:none; position:fixed; inset:0; background:rgba(0,0,0,.8); z-index:1000; justify-content:center; align-items:center; }
.lightbox.active{ display:flex; }
.lightbox-content{ max-width:90%; max-height:80%; border-radius:8px; }
.lightbox .close, .prev-lightbox, .next-lightbox{
  position:absolute; color:#fff; font-size:2rem; cursor:pointer; padding:10px;
}
.lightbox .close{ top:20px; right:20px; }
.prev-lightbox{ left:20px; top:50%; transform: translateY(-50%); }
.next-lightbox{ right:20px; top:50%; transform: translateY(-50%); }

/* ====== Responsive ====== */
@media (max-width: 992px){
  .idiomas-hero{
    background-attachment: scroll; /* desactiva fixed en tablet/móvil */
    background-position: 50% 20%;  /* re-encuadre */
  }

  .metodo-grid{ grid-template-columns: 1fr 1fr; }
  .galeria-grid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px){
  .idiomas-hero{
    height: 380px;
    background-position: 50% 15%;  /* re-encuadre más alto */
  }

  .propuesta-grid{ grid-template-columns: 1fr; }
  .propuesta-grid img{ height: 240px; }
  .ruta-timeline{ flex-direction: column; align-items:center; gap:12px; }
  .ruta-timeline::before{ display:none; }
}
@media (max-width: 520px){
  .metodo-grid, .galeria-grid{ grid-template-columns: 1fr; }
}


:root{
  --color-primary: var(--ibx-primary, #B7003C);
  --text: #2e3340;
  --muted: #707789;
  --surface: #ffffff;
  --bg-soft: #f6f7f9;
  --radius: 16px;
  --shadow-1: 0 10px 24px rgba(0,0,0,.08);
  --shadow-2: 0 24px 48px rgba(0,0,0,.12);
}

/* helpers */
.dep-container{ width:min(1180px,92%); margin-inline:auto; }
.section-title{ font-size: clamp(1.4rem, 1.1rem + 1.2vw, 2rem); margin: .5rem 0 1rem; color: var(--color-primary); }

/* HERO */
.dep-hero{
  position: relative;
  min-height: 58vh;
  display: grid;
  align-content: end;
  color:#fff;
  background:
    radial-gradient(60% 60% at 50% 35%, rgba(183,0,60,.28) 0%, rgba(183,0,60,0) 60%),
    linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.55) 100%),
    var(--hero) center 40% / cover no-repeat;
}
.dep-hero__inner{
  padding: clamp(24px, 3vw, 40px) 0 0;
  width:min(1180px,92%); margin-inline:auto;
}
.dep-hero__title{
  font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem);
  line-height: 1.1; margin: .25rem 0 .5rem;
}
.dep-hero__subtitle{
  font-size: clamp(1rem, .9rem + .6vw, 1.25rem);
  color: #f2f2f2; max-width: 58ch;
}
.dep-hero__cta{ display:flex; gap:.75rem; margin-top:1.1rem; flex-wrap:wrap; }

.dep-breadcrumb{
  display:flex; gap:.5rem; align-items:center;
  font-size:.95rem; margin-bottom:.75rem; color:#f3f4f6;
}
.dep-breadcrumb a{ color:#fff; text-decoration:none; opacity:.9 }
.dep-breadcrumb a:hover{ opacity:1; text-decoration:underline; }
.dep-breadcrumb .current{ opacity:.8 }

/* Stats band */
.dep-stats{
  list-style:none; margin: clamp(14px, 2vw, 22px) auto 0; padding: 10px 0 22px;
  display:flex; gap: clamp(10px, 3vw, 22px); justify-content:center; flex-wrap:wrap;
}
.dep-stats li{
  display:flex; flex-direction:column; align-items:center; gap:.2rem;
  padding:.6rem .9rem; background: rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  border-radius: 999px; backdrop-filter: blur(6px);
}
.dep-stats strong{ font-size: clamp(1.1rem, .9rem + 1vw, 1.6rem); }
.dep-stats span{ font-size:.85rem; opacity:.9 }

/* INTRO */
.dep-intro{ padding: clamp(28px, 4vw, 48px) 0 10px; color: var(--text); }
.dep-intro p{ font-size: clamp(1rem, .95rem + .2vw, 1.05rem); line-height:1.7; color: var(--text); text-align: center; }

/* GRID FEATURE */
.dep-feature{ padding: 6px 0 34px; }
.dep-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(14px, 2vw, 22px);
}
.dep-card{
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  overflow: clip; display:flex; flex-direction:column;
  transition: transform .18s ease, box-shadow .18s ease;
}
.dep-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-2); }

.dep-media{ aspect-ratio: 16/10; background:#e9ecf1; overflow:hidden; }
.dep-media img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition: transform .5s ease;
}
.dep-card:hover .dep-media img{ transform: scale(1.03); }

.dep-card__body{ padding: 16px 16px 18px; }
.dep-card__body h3{ margin: 6px 0 8px; font-size: clamp(1.05rem, 1rem + .3vw, 1.25rem); color: var(--text); }
.dep-card__body p{ color:#616879; line-height:1.6; }
.dep-chips{ display:flex; gap:.4rem; flex-wrap:wrap; margin-top:.8rem; }
.dep-chips span{
  font-size:.85rem; padding:.35rem .6rem; border-radius:999px;
  background: var(--bg-soft); border:1px solid #e7e9ee; color:#4a5160;
}

/* GALERÍA */
.dep-gallery{ padding: 6px 0 clamp(30px, 4vw, 52px); }
.dep-masonry{
  columns: 1; column-gap: clamp(10px, 2vw, 18px);
}
@media (min-width: 640px){ .dep-masonry{ columns: 2; } }
@media (min-width: 1024px){ .dep-masonry{ columns: 3; } }

.dep-masonry__item{
  break-inside: avoid; margin: 0 0 clamp(10px, 2vw, 18px);
  border-radius: 12px; overflow:hidden; box-shadow: var(--shadow-1);
  background:#fff;
}
.dep-masonry__item img{ width:100%; height:auto; display:block; }

/* CTA FINAL */
.dep-cta{
  background: linear-gradient(90deg, rgba(183,0,60,.08), rgba(255,106,149,.10));
  padding: clamp(26px, 4vw, 46px) 0;
}
.dep-cta__inner{
  display:flex; align-items:center; justify-content:space-between; gap: 1rem; flex-wrap:wrap;
}
.dep-cta h2{ margin:0 0 6px; color: var(--text); }
.dep-cta p{ margin:0; color: #576072; }
.dep-cta__actions{ display:flex; gap:.6rem; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.4rem;
  padding: .7rem 1.1rem; border-radius: 999px; text-decoration:none; font-weight:800;
  transition: transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}
.btn--primary{ color:#fff; background: linear-gradient(90deg, #B7003C, #ff6a95); box-shadow: var(--shadow-1); }
.btn--primary:hover{ transform: translateY(-1px); }
.btn--ghost{ color: var(--color-primary); background: #fff; border:1px solid #f0cdda; }
.btn--ghost:hover{ opacity:.95; }

/* Motion safe */
@media (prefers-reduced-motion: reduce){
  .dep-card, .dep-media img, .btn { transition: none !important; }
}

/* ===============================
   BASE SIMPLE PARA LA DEMO
   =============================== */

*,
*::before,
*::after{
  box-sizing:border-box;
}

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:#1d1d1f;
  background:#f5f5f7;
}

img{
  max-width:100%;
  display:block;
}

/* Header y footer básicos */
.site-header{
  background:#fff;
  box-shadow:0 2px 12px rgba(15,23,42,.08);
  position:sticky;
  top:0;
  z-index:100;
}
.site-header__inner{
  max-width:1200px;
  margin:0 auto;
  padding:10px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.site-header .brand{
  font-weight:800;
  text-decoration:none;
  color:#1d1d1f;
}
.nav a{
  margin-left:12px;
  text-decoration:none;
  color:#555;
  font-size:.95rem;
}
.nav a:hover{
  color:#c62828;
}

.site-footer{
  padding:16px;
  text-align:center;
  font-size:.85rem;
  color:#777;
}

/* ===============================
   ARTE Y CULTURA – ESTILOS 2025
   =============================== */

/* Paleta específica Arte y Cultura */
:root{
  --arte-1:#E74C3C;
  --arte-2:#8E44AD;
  --arte-3:#1ABC9C;
  --ink:#1d1d1f;
  --muted:#666;
  --card:#ffffffcc;
  --shadow:0 10px 30px rgba(0,0,0,.12);
  --radius:18px;
}

/* ===============================
   HERO – ARTE Y CULTURA
   =============================== */

.artes-v2.hero {
  min-height:420px;
  display:flex;
  justify-content:center;
  align-items:center;
  text-align:center;
  color:#fff;
  position:relative;
  background:
    linear-gradient(rgba(0,0,0,0.45), rgba(0,0,0,0.55)),
    url('../images/art-hero.webp') center 40% / cover no-repeat;
  background-attachment: fixed;
}

/* Fallback en móvil (muchos navegadores no soportan fixed) */
@media (max-width: 768px){
  .artes-v2.hero{
    background-attachment: scroll;
  }
}

/* Encapsulado dentro de Arte y Cultura */
.artes-v2 .hero-inner{
  position:relative;
  z-index:2;
  padding:0 16px;
  max-width:720px;
  margin-inline:auto;
}

.artes-v2 .hero-eyebrow{
  font-size:.8rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  opacity:.9;
  margin-bottom:.35rem;
}

.artes-v2 .hero-inner h1{
  font-size:clamp(2.2rem, 4vw, 3rem);
  font-weight:700;
  margin-bottom:.4rem;
}

.artes-v2 .hero-sub{
  opacity:.95;
  margin-bottom:1.2rem;
  font-size:1.05rem;
  line-height:1.45;
}

.artes-v2 .hero-actions{
  display:flex;
  gap:.75rem;
  justify-content:center;
  flex-wrap:wrap;
}

.btn-arte,
.btn-ghost{
  padding:.85rem 1.2rem;
  border-radius:999px;
  font-weight:600;
  text-decoration:none;
  box-shadow:0 8px 20px rgba(0,0,0,0.15);
  border:none;
  cursor:pointer;
  font-size:.95rem;
}

.btn-arte{
  background:#fff;
  color:#111;
}
.btn-arte:hover{
  transform:translateY(-2px);
}

.btn-ghost{
  background:transparent;
  border:1.5px solid #ffffff55;
  color:#fff;
}
.btn-ghost:hover{
  background:#ffffff22;
}

/* Pincel inferior opcional */
.artes-v2 .hero-brush{
  position:absolute;
  inset:auto 0 0 0;
  height:120px;
  z-index:1;
}
.artes-v2 .brush-svg{
  width:100%;
  height:100%;
}
.artes-v2 .brush-svg path{
  fill:#fff;
  opacity:.9;
}

/* ===============================
   CONTENEDOR GENERAL CONTENIDO
   =============================== */

.artes-v2.content{
  padding-top:32px;
  padding-bottom:40px;
}

/* ===============================
   TARJETAS – HIGHLIGHTS
   =============================== */

.artes-v2.highlights{
  max-width:1200px;
  margin:0 auto 32px;
  padding:0 16px;
  display:grid;
  gap:18px;
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
}

.card-arte{
  background:var(--card);
  backdrop-filter: blur(10px);
  border:1px solid #fff6;
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
  transition:transform .35s ease, box-shadow .35s ease;
  display:grid;
  gap:10px;
}

.card-arte h3{
  font-size:1.1rem;
  margin-bottom:.15rem;
  color:var(--ink);
}

.card-arte p{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.6;
}

.card-arte img{
  width:100%;
  height:220px;
  object-fit:cover;
  border-radius:14px;
  transform:perspective(900px) rotateX(0deg);
  transition:transform .35s ease;
}

.card-arte:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 40px rgba(0,0,0,.16);
}
.card-arte:hover img{
  transform:perspective(900px) rotateX(2deg);
}

/* ===============================
   BLOQUES DE TEXTO
   =============================== */

.artes-v2.text-block{
  max-width:1100px;
  margin:10px auto 40px;
  padding:0 16px;
}

.artes-v2.text-block h2{
  font-size:clamp(1.6rem,2.4vw,2.1rem);
  margin-bottom:1rem;
  color:var(--ink);
  text-align:left;
}

.text-grid{
  display:grid;
  gap:24px;
  grid-template-columns:minmax(0,1fr);
}

.text-grid article h3{
  font-size:1.2rem;
  margin-bottom:.4rem;
  color:var(--ink);
}

.text-grid p{
  color:var(--muted);
  line-height:1.6;
  margin-bottom:.6rem;
}

.text-grid ul{
  padding-left:1.1rem;
  color:var(--muted);
  line-height:1.6;
}

/* ===============================
   CHIPS – PROGRAMAS
   =============================== */

.artes-v2.chips{
  max-width:1100px;
  margin:30px auto 4px;
  padding:0 16px;
  text-align:center;
}

.artes-v2.chips h2{
  font-size:clamp(1.5rem,2.5vw,2rem);
  margin-bottom:12px;
  color:var(--ink);
}

.chip-list{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  list-style:none;
  padding-left:0;
  margin:0;
}

.chip{
  background:#f6f2ff;
  color:#5a31a5;
  border:1px solid #e7ddff;
  padding:.55rem .9rem;
  border-radius:999px;
  font-weight:600;
  font-size:.9rem;
}
.chip:hover{
  background:#efe7ff;
}

/* ===============================
   GALERÍA ARTÍSTICA + LIGHTBOX
   =============================== */

.artes-v2.gallery-section{
  max-width:1200px;
  margin:32px auto 40px;
  padding:0 16px 8px;
  position:relative;
}

.artes-v2.gallery-section::before{
  content:"";
  position:absolute;
  inset:auto 8px 0 8px;
  height:65%;
  border-radius:32px;
  background:
    radial-gradient(circle at 0% 0%, rgba(142,68,173,.18), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(46,204,113,.16), transparent 55%);
  z-index:-1;
  opacity:.9;
}

.gallery-head{
  display:flex;
  flex-direction:column;
  gap:.25rem;
  margin-bottom:14px;
}

.gallery-head h2{
  font-size:clamp(1.5rem,2.4vw,2rem);
  color:var(--ink);
}

.gallery-head p{
  color:var(--muted);
  font-size:.95rem;
  max-width:520px;
}

/* Carril horizontal */
.gallery-rail{
  display:flex;
  gap:16px;
  overflow-x:auto;
  padding:12px 4px 8px;
  scroll-snap-type:x mandatory;
}

.gallery-rail::-webkit-scrollbar{
  height:6px;
}
.gallery-rail::-webkit-scrollbar-thumb{
  border-radius:999px;
  background:#d0c4ff;
}

/* Ítems */
.g-item{
  position:relative;
  border:none;
  background:transparent;
  padding:0;
  cursor:pointer;
  min-width:260px;
  max-width:360px;
  scroll-snap-align:center;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(15,23,42,.35);
  transform:translateY(0) scale(1);
  transition:
    transform .4s ease,
    box-shadow .4s ease;
}

.g-item img{
  display:block;
  width:100%;
  height:220px;
  object-fit:cover;
}

/* Degradado artístico */
.g-item::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.55));
  opacity:.85;
  pointer-events:none;
}

/* Etiqueta */
.g-tag{
  position:absolute;
  left:14px;
  bottom:12px;
  padding:.4rem .75rem;
  border-radius:999px;
  font-size:.8rem;
  font-weight:600;
  color:#fff;
  background:linear-gradient(135deg, var(--arte-2), var(--arte-3));
  box-shadow:0 8px 18px rgba(0,0,0,.3);
}

/* Hover */
.g-item:hover{
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 22px 55px rgba(15,23,42,.5);
}

/* ===============================
   LIGHTBOX
   =============================== */

.gallery-lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:1200;
}

.gallery-lightbox.is-open{
  display:flex;
}

.gl-backdrop{
  position:absolute;
  inset:0;
  background:rgba(5,5,15,.82);
  backdrop-filter:blur(6px);
}

.gl-inner{
  position:relative;
  max-width:min(1000px, 100% - 32px);
  max-height:min(90vh, 700px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:1;
}

/* Figura central */
.gl-figure{
  margin:0;
  background:radial-gradient(circle at top, #1f2937, #020617);
  border-radius:20px;
  padding:16px 18px 14px;
  box-shadow:0 24px 80px rgba(0,0,0,.85);
  display:flex;
  flex-direction:column;
  align-items:center;
  max-height:90vh;
}

.gl-figure img{
  display:block;
  max-width:100%;
  max-height:72vh;
  border-radius:14px;
}

.gl-figure figcaption{
  margin-top:10px;
  font-size:.9rem;
  color:#e5e7eb;
  text-align:center;
  max-width:580px;
}

/* Botón cerrar */
.gl-close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border-radius:999px;
  border:none;
  background:rgba(15,23,42,.9);
  color:#fff;
  font-size:1.4rem;
  line-height:1;
  cursor:pointer;
  display:grid;
  place-items:center;
}

/* Flechas navegación */
.gl-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px;
  height:40px;
  border-radius:999px;
  border:none;
  background:rgba(15,23,42,.9);
  color:#fff;
  font-size:1.6rem;
  display:grid;
  place-items:center;
  cursor:pointer;
}

.gl-prev{ left:10px; }
.gl-next{ right:10px; }

/* ===============================
   CTA FINAL
   =============================== */

.artes-v2.cta{
  padding:28px 16px 48px;
  text-align:center;
}

.artes-v2.cta h2{
  font-size:clamp(1.6rem,2.5vw,2.2rem);
  margin-bottom:.3rem;
  color:var(--ink);
}

.artes-v2.cta p{
  color:var(--muted);
  margin-bottom:12px;
}

/* ===============================
   RESPONSIVE / ACCESIBILIDAD
   =============================== */

@media (min-width: 768px){
  .text-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .artes-v2.text-block h2{
    text-align:center;
  }
}

@media (max-width: 640px){
  .g-item img{
    height:190px;
  }

  .gl-figure{
    padding:12px 12px 10px;
  }

  .gl-figure img{
    max-height:60vh;
  }

  .gl-nav{
    width:34px;
    height:34px;
  }
}

/* Menos animación */
@media (prefers-reduced-motion: reduce){
  .card-arte,
  .card-arte img,
  .btn-arte,
  .btn-ghost,
  .g-item{
    transition:none;
  }
}
