/* ====== Base ====== */
:root{
  --bg:#f7f8fb;
  --surface:#ffffff;
  --text:#1d1f23;
  --muted:#eef1f6;
  --primary:#1e88e5;
  --primary-600:#1565c0;
  --shadow: 0 8px 24px rgba(17,24,39,.08);
}

*{box-sizing:border-box}
html{
  margin:0;
  padding:0;
  scroll-behavior:smooth;
}
body{
  margin:0;
  padding:0;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}

body.menu-open{overflow:hidden;}

.welcome-hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:clamp(56px, 8vw, 104px) clamp(20px, 6vw, 72px);
  color:#fff;
  overflow:hidden;
  background:linear-gradient(135deg,#0f172a 0%,#1a2744 60%,#0f1f3d 100%);
}

.welcome-hero__photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 18%;
  transform:none;
  filter:saturate(1.08);
  z-index:0;
}

@media (min-width:1024px){
  .welcome-hero__photo{
    object-position:center 48%;
  }
}

.welcome-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(9,16,32,.15) 0%, rgba(15,23,42,.72) 65%, rgba(15,23,42,.94) 100%);
  z-index:1;
}

.welcome-hero__content{
  position:relative;
  z-index:2;
  width:min(580px, 94%);
  margin-top:0;
  margin-right:auto;
  margin-bottom:clamp(80px, 14vh, 140px);
  margin-left:auto;
  text-align:center;
  padding:0;
  border-radius:0;
  background:none;
  -webkit-backdrop-filter:none;
  backdrop-filter:none;
  box-shadow:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:clamp(16px, 3vw, 28px);
}

.welcome-hero__eyebrow{
  display:inline-block;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  padding:6px 18px;
  border-radius:999px;
}

.welcome-hero__content h1{
  margin:0;
  font-size:clamp(1.75rem, 4.4vw, 3.2rem);
  letter-spacing:.02em;
  text-shadow:0 18px 32px rgba(15,23,42,.6);
  line-height:1.15;
}

.welcome-hero__highlight{
  display:inline-block;
  font-weight:800;
  font-style:italic;
}

.welcome-hero__content p{
  margin:0;
  font-size:clamp(1rem, 2.2vw, 1.2rem);
  opacity:.88;
  text-shadow:0 16px 30px rgba(15,23,42,.7);
  max-width:46ch;
}

.welcome-hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}

.welcome-hero__cta{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.85rem 1.6rem;
  border-radius:999px;
  background:var(--primary);
  color:#fff;
  border:none;
  font-weight:700;
  font-size:.92rem;
  letter-spacing:.02em;
  transition:.25s ease;
  box-shadow:0 18px 36px rgba(30,136,229,.35);
  align-self:center;
  text-decoration:none;
}

.welcome-hero__cta:hover,
.welcome-hero__cta:focus-visible{
  background:var(--primary-600);
  transform:translateY(-2px);
}

.welcome-hero__cta--outline{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.4);
  box-shadow:none;
}

.welcome-hero__cta--outline:hover{
  background:rgba(255,255,255,.2);
  box-shadow:none;
}

.welcome-hero__hint{
  position:absolute;
  inset:auto 0 clamp(32px, 9vh, 96px) 0;
  text-align:center;
  color:rgba(255,255,255,.78);
  font-size:.95rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.45rem;
  pointer-events:none;
  z-index:2;
}

.welcome-hero__hint span{
  position:relative;
  width:24px;
  height:38px;
  display:inline-flex;
  align-items:flex-start;
  justify-content:flex-start;
}

.welcome-hero__hint span::before,
.welcome-hero__hint span::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
}

.welcome-hero__hint span::before{
  top:0;
  width:2px;
  height:24px;
  background:rgba(255,255,255,.65);
  animation:scroll-hint-line 2s ease-in-out infinite;
}

.welcome-hero__hint span::after{
  bottom:0;
  width:12px;
  height:12px;
  border-left:2px solid rgba(255,255,255,.65);
  border-bottom:2px solid rgba(255,255,255,.65);
  transform:translate(-50%, -25%) rotate(-45deg);
  animation:scroll-hint-arrow 2s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce){
  .welcome-hero__hint span::before,
  .welcome-hero__hint span::after{animation:none;}
}

@keyframes scroll-hint-line{
  0%,100%{opacity:0; transform:translate(-50%, -6px);}
  40%{opacity:1; transform:translate(-50%, 0);}
  70%{opacity:0; transform:translate(-50%, 6px);}
}

@keyframes scroll-hint-arrow{
  0%,100%{opacity:0; transform:translate(-50%, -45%) rotate(-45deg);}
  40%{opacity:1; transform:translate(-50%, -25%) rotate(-45deg);}
  70%{opacity:0; transform:translate(-50%, -5%) rotate(-45deg);}
}

@media (max-width:720px){
  .welcome-hero{
    padding:clamp(40px, 16vh, 88px) 18px clamp(48px, 14vh, 96px);
    align-items:flex-start;
    justify-content:flex-start;
  }

  .welcome-hero__content{
    margin:clamp(18px, 12vh, 44px) auto auto;
    padding:0;
    text-align:center;
    gap:clamp(12px, 4vw, 22px);
  }

  .welcome-hero__content h1,
  .welcome-hero__content p{max-width:28ch; margin-inline:auto;}

  .welcome-hero__photo{object-position:center top;}

  .welcome-hero__cta{margin-inline:auto; align-self:center;}

  .welcome-hero__hint{font-size:.82rem; letter-spacing:.12em;}
}

:where(#bienvenida, #inicio, #quienes-somos, #lineas, #publicaciones, #convocatorias, #observatorio, #formacion, #agenda, #alianzas, #newsletter){
  scroll-margin-top:clamp(72px, 11vh, 112px);
}

img{max-width:100%; display:block; border-radius:14px;}

.container{width:min(1100px, 92%); margin-inline:auto;}

h1,h2,h3{line-height:1.2; margin:0 0 .5rem}
h2{font-size:clamp(1.4rem, 2.2vw, 2rem)}
h3{font-size:clamp(1.1rem, 2vw, 1.4rem)}

a{color:inherit; text-decoration:none}
.btn{
  background:var(--primary); color:#fff; border:none; border-radius:12px;
  padding:.7rem 1rem; font-weight:600; box-shadow:var(--shadow);
  display:inline-block; transition:.2s transform, .2s background;
  cursor:pointer; font-family:inherit; font-size:.9rem;
}
.btn:hover{background:var(--primary-600); transform:translateY(-1px)}
.btn.outline{background:transparent; color:var(--primary); border:1px solid var(--primary); box-shadow:none}
.btn.outline:hover{background:var(--primary); color:#fff}

.section{padding:72px 0}
.section.muted{background:var(--muted)}
.section--surface,
.section--muted,
.section--accent{
  position:relative;
  z-index:0;
}
.section--surface{background:var(--surface);}
.section--muted{background:var(--muted);}
.section--accent{
  background:linear-gradient(140deg, rgba(238,241,246,.92), rgba(247,248,251,.98));
}
.section--surface::after,
.section--muted::after,
.section--accent::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:inherit;
  box-shadow:inset 0 1px 0 rgba(15,23,42,.04), inset 0 -1px 0 rgba(15,23,42,.04);
}

.two-col{display:grid; grid-template-columns: 1.2fr 1fr; gap:28px; align-items:center}
@media (max-width:900px){ .two-col{grid-template-columns:1fr; } }

.project-text{display:flex; flex-direction:column; gap:1rem}
.project-logo{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.25rem 1.5rem;
  border-radius:18px;
  background:linear-gradient(160deg, rgba(15,23,42,.95), rgba(30,41,59,.88));
  box-shadow:var(--shadow);
  max-width:220px;
}
.project-logo img{width:100%; height:auto; display:block; filter:drop-shadow(0 6px 14px rgba(15,23,42,.32));}
.project-text p{margin:0; color:rgba(29,31,35,.9);}
.project-text .btn{margin-top:1.5rem; align-self:flex-start}

.section-intro{max-width:700px; margin:0 0 1.5rem; color:rgba(29,31,35,.85);}

.project-gallery{display:grid; gap:18px; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));}
.project-gallery figure{margin:0; border-radius:18px; overflow:hidden; background:var(--surface); box-shadow:var(--shadow);}
.project-gallery img{width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; border-radius:0;}

.a3-gallery{display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:32px; margin:2.5rem auto 0; max-width:min(860px, 94vw);}
.a3-gallery figure{margin:0; background:var(--surface); border-radius:24px; overflow:hidden; box-shadow:var(--shadow); display:flex; flex-direction:column; align-items:stretch;}
.a3-gallery img{width:100%; height:auto; aspect-ratio:2/3; object-fit:cover; display:block;}
.a3-gallery figcaption{margin:0; padding:1.25rem 1.5rem; background:linear-gradient(140deg, rgba(255,255,255,.96), rgba(247,248,251,.98)); font-weight:600; text-align:center; letter-spacing:.01em;}
.a3-gallery__cta{margin:3rem auto 0; text-align:center; display:flex; flex-direction:column; gap:1rem; align-items:center;}
.a3-gallery__cta p{margin:0; max-width:520px;}
.a3-gallery__cta a{display:inline-flex; align-items:center; justify-content:center; gap:.5rem; padding:.9rem 1.6rem; border-radius:999px; background:var(--primary); color:#fff; font-weight:600; text-decoration:none; box-shadow:var(--shadow); transition:.25s ease;}
.a3-gallery__cta a:hover,
.a3-gallery__cta a:focus-visible{background:var(--primary-600); transform:translateY(-2px);}

@media (max-width:1024px){
  .a3-gallery{grid-template-columns:repeat(2, minmax(0, 1fr));}
}

@media (max-width:600px){
  .a3-gallery{grid-template-columns:1fr; gap:24px;}
  .a3-gallery figcaption{padding:1rem 1.1rem; font-size:.95rem;}
}

.project-focus{display:grid; gap:.75rem; margin:1.5rem 0 0; padding:0; list-style:none;}
.project-focus li{padding:1rem 1.2rem; background:var(--surface); border-radius:16px; box-shadow:var(--shadow);}
.project-focus strong{display:block; margin-bottom:.35rem; font-size:1.05rem;}

@media (max-width:600px){
  .project-logo{margin-inline:auto;}
  .project-text .btn{width:100%; text-align:center;}
  .project-gallery{grid-template-columns:1fr 1fr;}
}

@media (max-width:480px){
  .project-gallery{grid-template-columns:1fr;}
}

/* ====== Header ====== */
.site-header{
  --header-height:clamp(64px, 6vw, 88px);
  position:sticky;
  top:0;
  z-index:1200;
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(18px);
  backdrop-filter:blur(18px);
  box-shadow:0 18px 36px rgba(15,23,42,.12);
  border-bottom:1px solid rgba(15,23,42,.05);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  min-height:var(--header-height);
  gap:18px;
}
.brand{display:flex; gap:.6rem; align-items:center; font-weight:800; letter-spacing:.3px}
.brand img{
  height:clamp(38px, 5vw, 52px);
  width:auto;
  display:block;
  filter:drop-shadow(0 6px 16px rgba(15,23,42,.18));
}
.brand span{font-size:1.15rem; letter-spacing:.2em;}
.main-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:22px;
  flex-wrap:wrap;
  margin-left:auto;
}
.main-nav a{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:10px 0;
  font-weight:600;
  font-size:.88rem;
  letter-spacing:.01em;
  color:inherit;
  opacity:.92;
  text-decoration:none;
  transition:color .25s ease;
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-6px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg, var(--primary), var(--primary-600));
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .25s ease;
  opacity:.88;
}
.main-nav a:hover,
.main-nav a:focus-visible{color:var(--primary-600); opacity:1;}
.main-nav a:hover::after,
.main-nav a:focus-visible::after{transform:scaleX(1);}
.main-nav a:focus-visible{outline:none;}
.main-nav a.nav-cta{
  background:var(--primary);
  color:#fff;
  padding:8px 18px;
  border-radius:999px;
  opacity:1;
  font-size:.82rem;
}
.main-nav a.nav-cta::after{display:none;}
.main-nav a.nav-cta:hover{background:var(--primary-600); transform:translateY(-1px);}
.socials{display:flex; align-items:center; gap:14px}
.socials a{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(145deg, rgba(238,241,246,.96), rgba(255,255,255,.96));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 12px 26px rgba(15,23,42,.14);
  transition:.25s transform ease, .25s box-shadow ease, .25s background-color ease;
  overflow:hidden;
  flex-shrink:0;
}
.socials a span{display:flex; align-items:center; justify-content:center; width:100%; height:100%; padding:10px;}
.socials a img{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:0;
  filter:drop-shadow(0 4px 9px rgba(15,23,42,.12));
  transition:filter .25s ease;
}
.socials a:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 34px rgba(15,23,42,.2);
}
.socials a:hover img{filter:drop-shadow(0 7px 16px rgba(15,23,42,.18));}
.socials a:focus-visible{outline:2px solid var(--primary); outline-offset:2px;}
.socials a:active{transform:translateY(0); box-shadow:0 6px 14px rgba(17,24,39,.12);}
.hamburger{
  display:none;
  align-items:center;
  justify-content:center;
  font-size:1.75rem;
  line-height:1;
  border:1px solid transparent;
  background:rgba(30,136,229,.08);
  color:var(--text);
  padding:8px 12px;
  border-radius:14px;
  transition:.25s background-color ease, .25s transform ease, .25s box-shadow ease;
  box-shadow:0 10px 20px rgba(30,136,229,.18);
  cursor:pointer;
}
.hamburger:hover{background:rgba(30,136,229,.16);}
.hamburger:focus-visible{outline:2px solid var(--primary); outline-offset:4px;}
.hamburger.is-active{transform:scale(.94); background:rgba(30,136,229,.24);}

.nav-backdrop{display:none;}

@media (max-width:980px){
  .main-nav{gap:18px;}
}

@media (max-width:860px){
  .site-header{--header-height:clamp(58px, 9vw, 72px);}
  .header-inner{gap:12px;}
  .hamburger{display:inline-flex; margin-left:auto;}
  .main-nav{
    position:fixed;
    top:var(--header-height);
    right:clamp(16px, 6vw, 28px);
    left:clamp(16px, 6vw, 28px);
    flex-direction:column;
    align-items:flex-start;
    justify-content:flex-start;
    gap:18px;
    padding:clamp(22px, 6vw, 32px);
    border-radius:24px;
    background:linear-gradient(155deg, rgba(255,255,255,.97), rgba(238,241,246,.94));
    border:1px solid rgba(15,23,42,.08);
    box-shadow:0 38px 68px rgba(15,23,42,.24);
    transform:translateY(-12px);
    opacity:0;
    pointer-events:none;
    visibility:hidden;
    max-height:calc(100vh - var(--header-height) - clamp(32px, 10vh, 80px));
    overflow-y:auto;
    z-index:1220;
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    transition:opacity .25s ease, transform .25s ease, visibility .25s;
  }
  .main-nav.is-open{
    opacity:1;
    transform:translateY(0);
    pointer-events:auto;
    visibility:visible;
  }
  .main-nav a{
    width:100%;
    font-size:1.05rem;
    padding:8px 0;
  }
  .main-nav a.nav-cta{
    padding:10px 18px;
    text-align:center;
    justify-content:center;
  }
  .main-nav a::after{bottom:-2px; height:2px;}
  .socials{
    width:100%;
    margin:12px 0 0;
    padding-top:14px;
    border-top:1px solid rgba(15,23,42,.08);
    gap:16px;
  }
  .socials a{width:46px; height:46px; border-radius:16px;}
  .nav-backdrop{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(9,12,24,.35);
    backdrop-filter:blur(2px);
    -webkit-backdrop-filter:blur(2px);
    z-index:1210;
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease;
  }
  .nav-backdrop.is-active{
    opacity:1;
    pointer-events:auto;
  }
}

/* ====== Intro block ====== */
.intro{padding:56px 0 40px}
.intro-grid{display:grid; grid-template-columns: 1fr 1.2fr; gap:28px; align-items:center}
.intro-photo{position:relative; overflow:hidden; border-radius:20px; aspect-ratio:16/9; box-shadow:var(--shadow)}
.intro-photo img{width:100%; height:100%; object-fit:cover; border-radius:0}
.intro-text p{opacity:.9; margin-bottom:1rem;}
.intro-text p:last-child{margin-bottom:0;}
@media (max-width:900px){ .intro-grid{grid-template-columns:1fr} }

/* ====== Pillars ====== */
.pillars{list-style:none; padding:0; margin:32px 0 0; display:grid; gap:20px; grid-template-columns:repeat(auto-fit, minmax(210px, 1fr))}
.pillars li{
  background:linear-gradient(145deg, rgba(30,136,229,.08), rgba(21,101,192,.16));
  padding:24px 22px; border-radius:20px; box-shadow:var(--shadow);
  border:1px solid rgba(30,136,229,.18); position:relative; overflow:hidden;
  display:flex; flex-direction:column;
}
.pillars li::after{
  content:""; position:absolute; inset:auto -30px -40px auto; width:120px; height:120px;
  background:radial-gradient(circle at center, rgba(255,255,255,.45), transparent 70%); transform:rotate(25deg); pointer-events:none;
}
.pillar-icon{display:inline-flex; width:46px; height:46px; align-items:center; justify-content:center; border-radius:14px;
  background:#fff; color:var(--primary); font-size:1.4rem; margin-bottom:18px; box-shadow:0 12px 28px rgba(30,136,229,.18);
  position:relative; z-index:1;}
.pillars h3{margin:0 0 .4rem; font-size:1.1rem; position:relative; z-index:1;}
.pillars p{margin:0; opacity:.88; position:relative; z-index:1; font-size:.95rem; line-height:1.5;}

/* ====== Section heading ====== */
.section-heading{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:36px;
  max-width:720px;
}
.section-heading h2,.section-heading h3{margin:0;}
.section-eyebrow{
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--primary);
  margin:0;
}
.section-heading p{margin:0; color:rgba(29,31,35,.75); font-size:.97rem;}

/* ====== Project cards ====== */
.projects-gallery{
  margin:32px 0 0;
  display:grid;
  gap:20px;
  grid-template-columns:repeat(3, minmax(0, 1fr));
}
.project-card{
  position:relative;
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  aspect-ratio:1/1;
  border-radius:20px;
  overflow:hidden;
  background:var(--surface);
  box-shadow:var(--shadow);
  transition:.25s transform, .25s box-shadow;
  isolation:isolate;
  cursor:pointer;
}
.project-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:0;
  transition:transform .35s ease;
}
.project-card span{
  position:relative;
  z-index:1;
  margin:0 0 20px 20px;
  padding:12px 16px;
  border-radius:14px;
  font-weight:700;
  color:#fff;
  background:rgba(9,12,24,.55);
  border:1px solid rgba(255,255,255,.32);
  backdrop-filter:blur(10px);
  letter-spacing:.01em;
  max-width:calc(100% - 40px);
  box-shadow:0 18px 32px rgba(9,12,24,.3);
}
.project-card::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:58%;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.72));
  z-index:0;
  transition:.35s ease;
  pointer-events:none;
}
.project-card:hover{transform:translateY(-4px); box-shadow:0 18px 34px rgba(17,24,39,.15);}
.project-card:hover img{transform:scale(1.06);}
.project-card:hover::after{opacity:.98;}

@media (max-width:1024px){.projects-gallery{grid-template-columns:repeat(2, minmax(0, 1fr));}}
@media (max-width:560px){
  .projects-gallery{grid-template-columns:1fr; gap:14px;}
  .project-card{min-height:clamp(220px, 68vw, 320px);}
}

/* ====== Cards grid ====== */
.cards-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
.cards-grid .card{
  background:var(--surface); border-radius:18px; overflow:hidden;
  display:flex; align-items:flex-end; justify-content:flex-start;
  aspect-ratio:16/9;
  box-shadow:var(--shadow); position:relative; isolation:isolate; cursor:pointer;
}
.cards-grid .card img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .35s ease; border-radius:0;
}
.cards-grid .card span{
  position:absolute; inset:auto 16px 16px 16px; padding:10px 14px; border-radius:12px; font-weight:700;
  color:#fff; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.35); backdrop-filter:blur(6px); pointer-events:none;
}
.cards-grid .card::after{
  content:""; position:absolute; inset:auto 0 0; height:55%; background:linear-gradient(180deg, transparent, rgba(0,0,0,.48)); opacity:.65; transition:.3s ease; pointer-events:none;
}
.cards-grid .card:hover img{transform:scale(1.05)}
.cards-grid .card:hover::after{opacity:.85}
.cards-grid .card{ transition:.25s box-shadow, .25s transform }
.cards-grid .card:hover{ transform:translateY(-2px); box-shadow:0 14px 30px rgba(17,24,39,.12) }
@media (max-width:820px){.cards-grid{grid-template-columns:1fr}}
@media (max-width:600px){.cards-grid .card{aspect-ratio:4/3}}

/* ====== Agenda ====== */
.agenda-list{list-style:none; padding:0; display:grid; gap:14px}
.agenda-list li{background:var(--surface); border-radius:16px; box-shadow:var(--shadow); overflow:hidden;}
.agenda-item-inner{
  display:flex;
  align-items:center;
  gap:0;
}
.agenda-date-block{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-width:80px;
  padding:20px 16px;
  background:var(--primary);
  color:#fff;
  flex-shrink:0;
}
.agenda-date-block .mes{
  font-size:.65rem;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.9;
}
.agenda-date-block .dia{
  font-size:2rem;
  font-weight:800;
  line-height:1;
  margin-top:2px;
}
.agenda-body{
  padding:16px 20px;
  flex:1;
  display:flex;
  align-items:center;
  gap:16px;
}
.agenda-body-text{flex:1;}
.agenda-tag-pill{
  display:inline-block;
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:3px 9px;
  border-radius:999px;
  margin-bottom:5px;
}
.agenda-tag-pill.lanzamiento{background:rgba(30,136,229,.12); color:var(--primary-600);}
.agenda-tag-pill.seminario{background:rgba(21,101,192,.1); color:#1565c0;}
.agenda-tag-pill.convocatoria{background:rgba(46,125,50,.1); color:#2e7d32;}
.agenda-tag-pill.publicacion{background:rgba(183,28,28,.08); color:#b71c1c;}
.agenda-body-text h4{margin:0 0 3px; font-size:.98rem;}
.agenda-body-text p{margin:0; font-size:.84rem; color:rgba(29,31,35,.65); line-height:1.4;}
.agenda-estado-pill{
  flex-shrink:0;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:5px 12px;
  border-radius:999px;
}
.agenda-estado-pill.confirmado{background:rgba(46,125,50,.12); color:#2e7d32;}
.agenda-estado-pill.proximo{background:rgba(30,136,229,.1); color:var(--primary-600);}
.agenda-estado-pill.desarrollo{background:rgba(245,127,23,.1); color:#e65100;}

@media (max-width:600px){
  .agenda-body{flex-wrap:wrap; gap:10px;}
  .agenda-estado-pill{margin-left:0;}
}

/* ====== Alianzas ====== */
.alianzas-cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
}
.alianzas-col h4{
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(29,31,35,.5);
  margin:0 0 18px;
}
.alianzas-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.alianza-tag{
  background:var(--surface);
  border:1px solid rgba(15,23,42,.1);
  box-shadow:var(--shadow);
  padding:9px 18px;
  border-radius:10px;
  font-size:.88rem;
  font-weight:500;
  transition:.2s ease;
}
.alianza-tag:hover{border-color:rgba(30,136,229,.3); color:var(--primary-600);}
@media (max-width:600px){.alianzas-cols{grid-template-columns:1fr; gap:28px;}}

/* ====== Contact form / Newsletter ====== */
.newsletter-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:start;
}
.newsletter-split__text h2{margin-bottom:16px;}
.newsletter-split__text p{margin-bottom:12px; color:rgba(29,31,35,.82);}
.newsletter-split__text p:last-of-type{margin-bottom:0;}
.newsletter-benefits{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.newsletter-benefits li{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.92rem;
  color:rgba(29,31,35,.8);
}
.newsletter-benefits li::before{
  content:"✓";
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;
  height:22px;
  background:rgba(30,136,229,.12);
  color:var(--primary-600);
  border-radius:6px;
  font-size:.75rem;
  font-weight:800;
  flex-shrink:0;
}
.newsletter-form-card{
  background:var(--surface);
  border-radius:20px;
  box-shadow:var(--shadow);
  padding:32px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.newsletter-form-card h3{margin:0 0 4px; font-size:1.1rem;}
.newsletter-form-card > p{margin:0 0 6px; font-size:.88rem; color:rgba(29,31,35,.65);}
.contact-form{display:grid; gap:12px;}
.contact-form input,
.contact-form select,
.contact-form textarea{
  padding:12px 16px;
  border-radius:12px;
  border:1px solid #d9dfeb;
  background:#fff;
  font-family:inherit;
  font-size:.92rem;
  color:var(--text);
  outline:none;
  transition:border-color .2s;
  width:100%;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{border-color:var(--primary);}
.contact-form select option{background:#fff;}
.nl-success{color:#2e7d32; font-size:.88rem; text-align:center; padding:10px; background:rgba(46,125,50,.08); border-radius:8px;}
.nl-error{color:#b71c1c; font-size:.88rem; text-align:center;}
@media (max-width:860px){.newsletter-split{grid-template-columns:1fr; gap:32px;}}

/* ====== Pub tipos ====== */
.pub-tipos{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:18px;
  margin-bottom:48px;
}
.pub-tipo{
  background:var(--surface);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  padding:26px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.pub-tipo.featured{
  border-color:rgba(30,136,229,.25);
  background:linear-gradient(145deg, rgba(30,136,229,.04), rgba(21,101,192,.06));
}
.pub-tipo-badge{
  display:inline-block;
  font-size:.66rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--primary-600);
  background:rgba(30,136,229,.1);
  padding:3px 10px;
  border-radius:4px;
  align-self:flex-start;
}
.pub-tipo h3{font-size:1.05rem; margin:0;}
.pub-tipo p{font-size:.86rem; margin:0; color:rgba(29,31,35,.72); flex:1;}
.pub-estado{
  display:inline-block;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:4px;
  align-self:flex-start;
  margin-top:auto;
}
.pub-estado.activo{background:rgba(46,125,50,.1); color:#2e7d32;}
.pub-estado.proximamente{background:rgba(245,127,23,.1); color:#e65100;}
@media (max-width:900px){
  .pub-tipos{grid-template-columns:1fr 1fr;}
  .pub-tipos .pub-tipo.featured{grid-column:1/-1;}
}
@media (max-width:560px){.pub-tipos{grid-template-columns:1fr;}}

/* ====== Convocatorias cards ====== */
.conv-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-bottom:32px;
}
.conv-card{
  background:var(--surface);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  padding:26px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:.25s transform, .25s box-shadow;
}
.conv-card:hover{transform:translateY(-3px); box-shadow:0 14px 32px rgba(17,24,39,.12);}
.conv-icon{font-size:2rem; line-height:1; display:flex; align-items:center; height:32px;}
.conv-type{
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--primary);
  margin:0;
  min-height:2.8em;
}
.conv-card h3{font-size:1.05rem; margin:0;}
.conv-card p{font-size:.88rem; margin:0; color:rgba(29,31,35,.72); flex:1;}
.conv-badge{
  display:inline-block;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:4px;
  align-self:flex-start;
  background:rgba(30,136,229,.1);
  color:var(--primary-600);
  border:1px solid rgba(30,136,229,.2);
}
.conv-cta-box{
  background:linear-gradient(145deg, rgba(30,136,229,.06), rgba(21,101,192,.08));
  border:1px solid rgba(30,136,229,.18);
  border-radius:16px;
  padding:28px 32px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}
.conv-cta-box p{margin:0; font-size:.95rem;}
@media (max-width:900px){.conv-cards{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.conv-cards{grid-template-columns:1fr;}}

/* ====== Observatorio cards ====== */
.obs-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.obs-card{
  background:var(--surface);
  border-radius:18px;
  padding:26px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.obs-icon{font-size:2.2rem;}
.obs-card h3{font-size:1.05rem; margin:0;}
.obs-card p{font-size:.88rem; margin:0; color:rgba(29,31,35,.72); flex:1;}
.obs-wip{
  display:inline-block;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:4px;
  background:rgba(15,23,42,.06);
  color:rgba(29,31,35,.5);
  align-self:flex-start;
  margin-top:auto;
}
@media (max-width:900px){.obs-cards{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.obs-cards{grid-template-columns:1fr;}}

/* ====== Formación cards ====== */
.form-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.form-card{
  background:var(--surface);
  border-radius:18px;
  padding:26px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  gap:12px;
  border-top:3px solid transparent;
}
.form-card.accent{border-top-color:var(--primary);}
.form-card-eyebrow{
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--primary);
  margin:0;
}
.form-card h3{font-size:1.05rem; margin:0;}
.form-card p{font-size:.88rem; margin:0; color:rgba(29,31,35,.72); flex:1;}
.form-badge{
  display:inline-block;
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:4px;
  align-self:flex-start;
  margin-top:auto;
}
.form-badge.proximo{background:rgba(30,136,229,.1); color:var(--primary-600);}
.form-badge.recurrente{background:rgba(46,125,50,.1); color:#2e7d32;}
.form-badge.desarrollo{background:rgba(245,127,23,.1); color:#e65100;}
@media (max-width:900px){.form-cards{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.form-cards{grid-template-columns:1fr;}}

/* ====== Notes grid (publicaciones web) ====== */
.notes-section-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin:40px 0 22px;
  padding-top:36px;
  border-top:1px solid rgba(15,23,42,.07);
}
.notes-section-header h3{
  font-size:1.05rem;
  font-weight:600;
  color:rgba(29,31,35,.65);
  margin:0;
}
.notes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:20px;
}
.note-card{
  background:var(--surface);
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:.25s transform, .25s box-shadow;
  border:1px solid rgba(15,23,42,.06);
}
.note-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 32px rgba(17,24,39,.13);
}
.note-card img{
  width:100%;
  height:190px;
  object-fit:cover;
  border-radius:0;
}
.note-card-body{
  padding:18px 20px;
}
.note-meta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:8px;
  flex-wrap:wrap;
}
.note-author{
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--primary-600);
  background:rgba(30,136,229,.1);
  padding:3px 9px;
  border-radius:4px;
}
.note-date{font-size:.76rem; color:rgba(29,31,35,.45);}
.note-card-body h3{
  font-size:1rem;
  margin:0 0 8px;
  line-height:1.35;
}
.note-card-body p{
  font-size:.86rem;
  color:rgba(29,31,35,.65);
  margin:0;
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:3;
  line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.loading-notes{text-align:center; padding:40px 0;}
.spinner{
  width:34px; height:34px;
  border:2px solid rgba(30,136,229,.2);
  border-top-color:var(--primary);
  border-radius:50%;
  animation:spin .75s linear infinite;
  margin:0 auto;
}
@keyframes spin{to{transform:rotate(360deg);}}
.no-notes{text-align:center; padding:40px 0; color:rgba(29,31,35,.45);}

@media (max-width:820px){.notes-grid{grid-template-columns:1fr;}}

/* ====== Modal ====== */
.modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(9,12,24,.72);
  z-index:2000;
  overflow-y:auto;
  padding:40px 20px;
  backdrop-filter:blur(4px);
}
.modal.active{display:flex; justify-content:center; align-items:flex-start;}
.modal-content{
  background:var(--surface);
  border-radius:20px;
  max-width:800px;
  width:100%;
  position:relative;
  margin:auto;
  overflow:hidden;
  box-shadow:0 48px 80px rgba(9,12,24,.3);
}
.modal-close{
  position:absolute; top:14px; right:14px;
  background:rgba(9,12,24,.55);
  border:none; color:#fff; font-size:1.5rem; cursor:pointer;
  width:36px; height:36px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  z-index:10; transition:background .2s;
}
.modal-close:hover{background:rgba(9,12,24,.82);}
.modal-content > img{width:100%; max-height:400px; object-fit:cover; border-radius:0;}
.modal-content h2{padding:22px 24px 0; font-size:1.5rem; margin:0; line-height:1.25;}
.modal-meta{display:flex; align-items:center; gap:10px; padding:10px 24px 4px; flex-wrap:wrap;}
.modal-author{
  font-size:.7rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--primary-600); background:rgba(30,136,229,.1); padding:3px 9px; border-radius:4px;
}
.modal-date{font-size:.8rem; color:rgba(29,31,35,.45);}
.modal-text{
  padding:12px 24px 28px;
  font-size:.97rem;
  line-height:1.8;
  color:rgba(29,31,35,.88);
}
.modal-text h1,.modal-text h2,.modal-text h3{color:var(--text); margin:18px 0 8px;}
.modal-text h1{font-size:1.4rem;}
.modal-text h2{font-size:1.2rem;}
.modal-text h3{font-size:1.05rem;}
.modal-text strong,.modal-text b{font-weight:700;}
.modal-text em,.modal-text i{font-style:italic;}
.modal-text ul,.modal-text ol{padding-left:22px; margin:8px 0;}
.modal-text li{margin-bottom:4px;}
.modal-text blockquote{border-left:3px solid var(--primary); padding-left:16px; margin:14px 0; color:rgba(29,31,35,.65); font-style:italic;}
.modal-text pre{background:var(--muted); padding:16px; border-radius:10px; overflow-x:auto; margin:12px 0; font-family:monospace; font-size:.87rem;}
.modal-text a{color:var(--primary); text-decoration:underline;}

/* ====== Footer ====== */
.site-footer{
  background:var(--surface);
  border-top:1px solid rgba(15,23,42,.07);
  padding:52px 0 32px;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1.4fr;
  gap:36px;
  margin-bottom:40px;
}
.footer-brand-name{font-size:1.4rem; font-weight:800; letter-spacing:.2em; display:block; margin-bottom:10px;}
.footer-brand p{font-size:.88rem; color:rgba(29,31,35,.6); margin-bottom:6px; line-height:1.55;}
.footer-brand .activá-note{font-size:.78rem; color:rgba(29,31,35,.4); margin-top:10px;}
.footer-col h5{font-size:.7rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:rgba(29,31,35,.4); margin:0 0 14px;}
.footer-col ul{list-style:none; padding:0; display:flex; flex-direction:column; gap:8px;}
.footer-col a{font-size:.88rem; color:rgba(29,31,35,.65); transition:color .2s;}
.footer-col a:hover{color:var(--primary);}
.footer-contact-email{font-size:.88rem; color:rgba(29,31,35,.65); margin-bottom:14px;}
.footer-rrss{display:flex; gap:8px;}
.footer-rrss a{
  font-size:.78rem; font-weight:600;
  padding:6px 14px; border-radius:8px;
  background:var(--muted); color:rgba(29,31,35,.6);
  border:1px solid rgba(15,23,42,.08);
  transition:.2s ease;
}
.footer-rrss a:hover{color:var(--primary); border-color:rgba(30,136,229,.3);}
.footer-bottom{border-top:1px solid rgba(15,23,42,.07); padding-top:20px; text-align:center;}
.footer-bottom p{font-size:.78rem; color:rgba(29,31,35,.38); margin:0;}
@media (max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr; row-gap:28px;}
  .footer-brand{grid-column:1/-1;}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1/-1;}
  .footer-col:last-child{grid-column:1/-1;}
}

/* ====== Admin panel ====== */
.admin-site-header{
  position:sticky; top:0; z-index:300;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(15,23,42,.07);
  box-shadow:0 4px 18px rgba(15,23,42,.06);
}
.admin-header-inner{
  display:flex; align-items:center;
  justify-content:space-between;
  padding:16px 0; gap:16px;
}
.admin-brand{font-size:1.2rem; font-weight:800; letter-spacing:.2em; color:var(--text);}
.admin-header-right{display:flex; align-items:center; gap:12px;}
.user-badge-pill{
  background:var(--primary); color:#fff;
  padding:5px 14px; border-radius:999px;
  font-size:.78rem; font-weight:700;
  letter-spacing:.04em;
}
.admin-main{padding:40px 0 80px;}
.admin-page-title{font-size:1.5rem; font-weight:800; margin:0 0 28px;}

.login-card{
  max-width:420px; margin:80px auto;
  background:var(--surface); border-radius:20px;
  box-shadow:var(--shadow); padding:40px;
  text-align:center;
}
.login-card h1{font-size:1.3rem; margin-bottom:6px;}
.login-card > p{font-size:.88rem; color:rgba(29,31,35,.6); margin-bottom:24px;}
.login-form{display:flex; flex-direction:column; gap:12px;}
.login-form input{
  padding:12px 16px; border-radius:12px;
  border:1px solid #d9dfeb; background:#fff;
  font-family:inherit; font-size:.92rem;
  outline:none; transition:border-color .2s;
}
.login-form input:focus{border-color:var(--primary);}
.error-msg{color:#b71c1c; font-size:.84rem; margin-top:8px;}

.note-form-card{
  background:var(--surface); border-radius:20px;
  box-shadow:var(--shadow); padding:32px;
}
.form-group{margin-bottom:18px;}
.form-group label{
  display:block; margin-bottom:7px;
  font-weight:600; font-size:.85rem;
  color:rgba(29,31,35,.7);
}
.form-group input[type="text"],
.form-group textarea{
  width:100%; padding:12px 16px;
  border-radius:12px; border:1px solid #d9dfeb;
  background:#fff; color:var(--text);
  font-family:inherit; font-size:.92rem;
  outline:none; transition:border-color .2s;
  resize:vertical;
}
.form-group input[type="text"]:focus,
.form-group textarea:focus{border-color:var(--primary);}
.form-group input[type="file"]{font-size:.86rem; color:rgba(29,31,35,.6);}
.hint-text{font-size:.78rem; color:rgba(29,31,35,.45); margin-top:5px; font-style:italic;}
.image-preview{margin-top:12px;}
.image-preview img{max-width:260px; max-height:170px; border-radius:10px; object-fit:cover;}

/* Quill editor light theme */
#editor-container{border-radius:10px; overflow:hidden; border:1px solid #d9dfeb;}
.ql-toolbar.ql-snow{background:#fafbfd !important; border:none !important; border-bottom:1px solid #d9dfeb !important;}
.ql-container.ql-snow{background:#fff !important; border:none !important; min-height:200px; font-family:inherit; font-size:.95rem;}
.ql-editor{min-height:200px; color:var(--text) !important;}
.ql-editor.ql-blank::before{color:rgba(29,31,35,.35) !important; font-style:italic;}
.ql-snow .ql-stroke{stroke:rgba(29,31,35,.55) !important;}
.ql-snow .ql-fill{fill:rgba(29,31,35,.55) !important;}
.ql-snow .ql-picker-label{color:rgba(29,31,35,.65) !important;}
.ql-snow .ql-picker-options{background:#fff !important; border-color:#d9dfeb !important; box-shadow:var(--shadow);}
.ql-snow .ql-picker-item{color:var(--text) !important;}
.ql-snow .ql-active .ql-stroke{stroke:var(--primary) !important;}
.ql-snow .ql-active .ql-fill{fill:var(--primary) !important;}
.ql-snow .ql-active{color:var(--primary) !important;}
.ql-snow button:hover .ql-stroke{stroke:var(--primary) !important;}
.ql-snow button:hover .ql-fill{fill:var(--primary) !important;}

.progress-wrap{margin-bottom:16px;}
.progress-bar{width:100%; height:5px; background:#eef1f6; border-radius:3px; overflow:hidden; margin-bottom:6px;}
.progress-fill{height:100%; background:var(--primary); border-radius:3px; width:0%; transition:width .3s;}
.progress-text{font-size:.82rem; color:rgba(29,31,35,.55);}

.divider{border:none; border-top:1px solid rgba(15,23,42,.07); margin:36px 0;}

.admin-notes-section h2{font-size:1.1rem; font-weight:600; color:rgba(29,31,35,.55); margin:0 0 18px;}
.admin-notes-list{display:flex; flex-direction:column; gap:12px;}
.admin-note-item{
  display:flex; align-items:center; gap:14px;
  background:var(--surface); border:1px solid rgba(15,23,42,.07);
  border-radius:14px; padding:14px; box-shadow:var(--shadow);
}
.admin-note-item img{width:68px; height:52px; object-fit:cover; border-radius:8px; flex-shrink:0;}
.admin-note-info{flex:1; min-width:0;}
.admin-note-info h4{font-size:.92rem; margin:0 0 2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.admin-note-info span{font-size:.78rem; color:rgba(29,31,35,.45);}
.admin-note-actions{display:flex; gap:8px; flex-shrink:0;}

.btn-edit{
  background:transparent; color:var(--primary);
  border:1px solid rgba(30,136,229,.3);
  padding:6px 14px; border-radius:8px;
  font-size:.78rem; cursor:pointer;
  font-family:inherit; font-weight:600;
  transition:.2s ease;
}
.btn-edit:hover{background:rgba(30,136,229,.08);}
.btn-danger{
  background:transparent; color:#b71c1c;
  border:1px solid rgba(183,28,28,.25);
  padding:6px 14px; border-radius:8px;
  font-size:.78rem; cursor:pointer;
  font-family:inherit; font-weight:600;
  transition:.2s ease;
}
.btn-danger:hover{background:rgba(183,28,28,.08);}
.btn-secondary{
  background:transparent; color:rgba(29,31,35,.6);
  border:1px solid rgba(15,23,42,.15);
  padding:8px 16px; border-radius:10px;
  font-size:.82rem; cursor:pointer;
  font-family:inherit; font-weight:600;
  transition:.2s ease;
}
.btn-secondary:hover{color:var(--text); border-color:rgba(15,23,42,.3);}

.admin-section-header{
  display:flex; align-items:center;
  justify-content:space-between; margin-bottom:28px;
}
.admin-section-header h1{font-size:1.5rem; margin:0;}
.admin-header-btns{display:flex; gap:10px;}
.cancel-btn-wrap{display:none;}
.cancel-btn-wrap.visible{display:block;}

@media (max-width:720px){
  .admin-note-item{flex-direction:column; text-align:center;}
  .admin-note-item img{width:100%; height:140px;}
  .admin-note-actions{justify-content:center;}
  .note-form-card{padding:20px;}
  .admin-section-header{flex-direction:column; gap:14px; align-items:flex-start;}
}

/* ====== Misc ====== */
.section.wave-top{position:relative; padding-top:80px;}
.section.wave-top::before{
  content:""; position:absolute; left:0; right:0; top:-40px; height:40px;
  background: radial-gradient(120% 40px at 50% 100%, var(--muted) 40%, transparent 41%);
}
.site-header::after{
  content:""; position:absolute; inset:auto 0 -1px 0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(0,0,0,.06), transparent);
}
.wide{width:100%; height:auto; border-radius:5px;}

/* ====== Preloader / Curtain ====== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  background:#ffffff;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:26px;
  transition:opacity .55s ease, visibility .55s;
}
.preloader.is-hidden{opacity:0; visibility:hidden; pointer-events:none;}
.preloader__logo{
  width:clamp(220px, 42vw, 460px); height:auto;
  border-radius:0;
  opacity:0; transform:translateY(16px) scale(.95);
  filter:drop-shadow(0 18px 34px rgba(15,23,42,.14));
}
.preloader.intro .preloader__logo{animation:pl-logo-in 1s ease forwards .15s;}
.preloader__bar{
  width:0; height:3px; border-radius:999px;
  background:linear-gradient(90deg, var(--primary), var(--primary-600));
}
.preloader.intro .preloader__bar{animation:pl-bar 1.5s ease forwards .45s;}
/* Transición entre páginas (misma sesión): fondo y logo más suaves */
.preloader.transition{
  background:rgba(255, 255, 255, 0.78);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}
.preloader.transition .preloader__logo{
  animation:pl-logo-in-soft .6s ease forwards .06s;
  filter:drop-shadow(0 10px 24px rgba(15,23,42,.08));
}
.preloader.transition .preloader__bar{
  display:block;
  opacity:.55;
  animation:pl-bar-nav .7s ease forwards .18s;
}
@keyframes pl-logo-in-soft{
  to{opacity:.42; transform:translateY(0) scale(1);}
}
@keyframes pl-bar-nav{0%{width:0;}100%{width:min(280px, 50vw);}}
.preloader.curtain .preloader__logo{opacity:.0; animation:none;}
.preloader.curtain .preloader__bar{display:none;}
@keyframes pl-logo-in{to{opacity:1; transform:translateY(0) scale(1);}}
@keyframes pl-bar{0%{width:0;}100%{width:min(320px, 56vw);}}
@media (prefers-reduced-motion:reduce){
  .preloader.intro .preloader__logo{animation:none; opacity:1; transform:none;}
  .preloader.transition .preloader__logo{animation:none; opacity:.42; transform:none;}
  .preloader.transition{background:rgba(255,255,255,.92);}
  .preloader__bar{display:none;}
}

/* ====== Page fade transition ====== */
body{opacity:1;}
body.is-leaving main,
body.is-leaving .site-footer{
  transition:opacity .26s ease, transform .26s ease;
  opacity:0; transform:translateY(8px);
}
.page-in{animation:page-in .5s ease both;}
@keyframes page-in{from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:translateY(0);}}
@media (prefers-reduced-motion:reduce){
  .page-in{animation:none;}
  body.is-leaving main, body.is-leaving .site-footer{transition:none;}
}

/* ====== Brand logo image ====== */
.brand img.brand-logo{
  height:clamp(34px, 4vw, 46px);
  width:auto; display:block;
  border-radius:0;
  filter:none;
}
.brand{gap:0;}

/* ====== Home access cards ====== */
.access-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
  margin-top:36px;
}
.access-card{
  display:flex; flex-direction:column; gap:10px;
  background:var(--surface);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  padding:28px 26px;
  box-shadow:var(--shadow);
  transition:.25s transform, .25s box-shadow, .25s border-color;
  position:relative;
  overflow:hidden;
}
.access-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 38px rgba(17,24,39,.13);
  border-color:rgba(30,136,229,.3);
}
.access-card__icon{font-size:1.9rem;}
.access-card h3{font-size:1.1rem; margin:0;}
.access-card p{font-size:.88rem; color:rgba(29,31,35,.65); margin:0; flex:1; line-height:1.55;}
.access-card__arrow{
  font-size:.85rem; font-weight:700; color:var(--primary-600);
  letter-spacing:.04em; display:inline-flex; align-items:center; gap:6px;
  transition:gap .2s ease;
}
.access-card:hover .access-card__arrow{gap:12px;}
@media (max-width:900px){.access-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:600px){.access-grid{grid-template-columns:1fr;}}

/* ====== Page hero (interior pages) ====== */
.page-hero{
  background:linear-gradient(135deg,#0f172a 0%,#1a2744 60%,#10213f 100%);
  color:#fff;
  padding:clamp(88px, 14vh, 140px) 0 clamp(48px, 8vh, 80px);
  position:relative;
}
.page-hero .container{position:relative; z-index:1;}
.page-hero__eyebrow{
  font-size:.72rem; font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(255,255,255,.62);
  margin:0 0 12px;
}
.page-hero h1{
  font-size:clamp(1.9rem, 4.4vw, 3rem);
  margin:0 0 14px; line-height:1.12;
}
.page-hero p{
  color:rgba(255,255,255,.82);
  max-width:620px; margin:0; font-size:1.02rem;
}
.breadcrumb{
  display:flex; gap:8px; align-items:center;
  font-size:.8rem; color:rgba(255,255,255,.5);
  margin-bottom:18px;
}
.breadcrumb a{color:rgba(255,255,255,.7);}
.breadcrumb a:hover{color:#fff;}


/* ====== Team Grid (Organigrama Jerárquico) ====== */
.org-tree-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 48px;
    margin-top: 48px;
}
.org-tier {
    display: flex;
    justify-content: center;
    gap: 20px;
    position: relative;
    flex-wrap: wrap;
    width: 100%;
}
.org-branch {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    position: relative;
    z-index: 1;
}
.org-branch-title {
    background: var(--primary);
    color: white;
    padding: 6px 18px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    box-shadow: 0 4px 12px rgba(15,23,42,.1);
}
.org-group {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
}
.team-card {
    background: var(--surface);
    border: 1px solid rgba(15,23,42,.06);
    border-radius: 20px;
    padding: 24px 16px;
    text-align: center;
    box-shadow: var(--shadow);
    transition: all .3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    min-width: 160px;
    max-width: 200px;
}
.team-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 18px 38px rgba(17,24,39,.1);
}
.team-photo {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    object-fit: cover;
    margin-bottom: 4px;
    border: 3px solid #fff;
    box-shadow: 0 8px 20px rgba(15,23,42,.08);
}
.team-card h3 {
    font-size: 1rem;
    margin: 0;
    color: var(--text-heading);
    line-height: 1.2;
}
.team-card p {
    font-size: 0.8rem;
    color: var(--primary);
    font-weight: 600;
    margin: 0;
}

/* Responsiveness fixes for mobile */
@media (max-width: 768px) {
    .org-group {
        flex-direction: column;
    }
}
