/* ============================================================
   VISIÓN INTEGRAL · IGLESIA
   Landing oficial — Espíritu · Alma · Cuerpo
   Layout: 2 módulos (Visión + Proyecto) con tabs top
   ============================================================ */

:root{
  --ink-900:#0A1F3D;
  --ink-800:#12305C;
  --ink-700:#1C4380;
  --ink-500:#3C67A6;
  --teal-600:#0FB5A6;
  --teal-500:#22C8B8;
  --teal-100:#D6F4F0;
  --green-700:#1F7A54;
  --green-600:#2E9B6B;
  --green-500:#3BB87E;
  --green-100:#E4F5EC;
  --amber:#E09428;
  --amber-100:#FEF6E7;
  --sand:#FAF7F2;
  --paper:#FFFFFF;
  --bg:#F4F7FB;
  --line:#E4EAF2;
  --muted:#5A6B85;
  --ink-60: rgba(10,31,61,.6);
  --ink-12: rgba(10,31,61,.12);
  --shadow-sm: 0 1px 2px rgba(10,31,61,.06), 0 1px 1px rgba(10,31,61,.04);
  --shadow-md: 0 10px 30px -12px rgba(10,31,61,.18), 0 2px 6px rgba(10,31,61,.06);
  --shadow-lg: 0 30px 60px -20px rgba(10,31,61,.28), 0 8px 20px -10px rgba(10,31,61,.12);
  --radius: 20px;
  --radius-sm: 12px;
  --maxw: 1240px;
  --nav-h: 70px;
  --tabs-h: 60px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color:var(--ink-900);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4{
  font-family:'Fraunces', Georgia, serif;
  font-weight:600;
  letter-spacing:-0.02em;
  line-height:1.08;
  margin:0;
  text-wrap:balance;
}
p{margin:0; text-wrap:pretty}

button{font-family:inherit}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-700);
  padding:8px 14px;
  background:rgba(15,181,166,.1);
  border:1px solid rgba(15,181,166,.25);
  border-radius:999px;
}
.eyebrow .dot{width:6px;height:6px;background:var(--teal-600);border-radius:999px;box-shadow:0 0 0 4px rgba(15,181,166,.18)}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:600; font-size:14.5px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space:nowrap;
  font-family:inherit;
}
.btn-primary{background:var(--ink-900); color:#fff; box-shadow: 0 10px 24px -10px rgba(10,31,61,.55)}
.btn-primary:hover{transform:translateY(-1px); background:var(--ink-800)}
.btn-accent{background:var(--teal-600); color:#fff; box-shadow: 0 10px 24px -10px rgba(15,181,166,.55)}
.btn-accent:hover{transform:translateY(-1px); background:#0CA397}
.btn-ghost{background:transparent; color:var(--ink-900); border-color:var(--ink-12)}
.btn-ghost:hover{border-color:var(--ink-700); background:#fff}
.btn-ghost-light{background:transparent; color:#fff; border-color:rgba(255,255,255,.3)}
.btn-ghost-light:hover{border-color:#fff; background:rgba(255,255,255,.08)}
.btn-sm{padding:9px 16px; font-size:13px}
.btn-icon{
  width:34px; height:34px; padding:0; border-radius:50%;
  background:#fff; border:1px solid var(--line); color:var(--ink-700);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition: all .2s;
}
.btn-icon:hover{border-color:var(--teal-500); color:var(--teal-600)}
.btn-icon svg{width:15px; height:15px}
.btn svg{width:16px; height:16px; flex-shrink:0}

/* save / favorite */
.btn-save{background:#fff; color:var(--ink-900); border-color:var(--ink-12); position:relative}
.btn-save:hover{border-color:var(--teal-600); color:var(--teal-600)}
.btn-save .heart{ width:18px; height:18px; transition: transform .25s ease, fill .25s ease, stroke .25s ease; fill:none; stroke:currentColor }
.btn-save.saved{ background:var(--teal-100); color:var(--green-700); border-color:rgba(15,181,166,.4) }
.btn-save.saved .heart{ fill:var(--teal-600); stroke:var(--teal-600); transform:scale(1.1) }
.btn-save .saved-only{display:none}
.btn-save.saved .default-only{display:none}
.btn-save.saved .saved-only{display:inline}
@keyframes savePulse{ 0%{transform:scale(1)} 30%{transform:scale(1.25)} 60%{transform:scale(.95)} 100%{transform:scale(1.1)} }
.btn-save.just-saved .heart{ animation: savePulse .55s ease }

/* ─── NAV PRINCIPAL ─── */
.nav{
  position:sticky; top:0; z-index:60;
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  background:rgba(255,255,255,.88);
  border-bottom:1px solid var(--line);
  height: var(--nav-h);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 28px; max-width:var(--maxw); margin:0 auto;
  height:100%;
}
.brand{display:flex; align-items:center; gap:12px; font-weight:700}
.brand-mark{
  width:36px; height:36px; border-radius:10px;
  background:linear-gradient(135deg, var(--ink-900), var(--teal-600));
  display:grid; place-items:center; color:#fff;
  box-shadow:var(--shadow-sm);
}
.brand-mark svg{width:20px;height:20px}
.brand-text{display:flex; flex-direction:column; line-height:1.1}
.brand-text small{font-size:11px; font-weight:500; color:var(--muted); letter-spacing:.06em; text-transform:uppercase}
.brand-text strong{font-family:'Fraunces',serif; font-size:18px; font-weight:600}
@media (max-width: 520px){ .brand-text small{display:none} }

/* ─── TABS TOP entre módulos ─── */
.module-tabs{
  position:sticky; top: var(--nav-h); z-index:55;
  background:rgba(244,247,251,.94);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
  height: var(--tabs-h);
}
.module-tabs-inner{
  max-width:var(--maxw); margin:0 auto;
  padding: 0 28px;
  height:100%;
  display:flex; align-items:center; gap:8px;
}
.mtab{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 18px;
  border-radius:999px;
  font-size:14px; font-weight:600;
  color:var(--muted);
  cursor:pointer;
  border:1px solid transparent;
  background:transparent;
  transition: all .2s;
  font-family:inherit;
}
.mtab:hover{ color:var(--ink-900); background:#fff; border-color:var(--line) }
.mtab.active{
  background:var(--ink-900); color:#fff;
  box-shadow:var(--shadow-md);
}
.mtab .mt-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:20px; height:20px; border-radius:50%;
  background:rgba(255,255,255,.15); color:inherit;
  font-family:'Fraunces',serif; font-size:11px; font-weight:600;
}
.mtab:not(.active) .mt-num{ background:var(--bg); color:var(--ink-700) }

/* ─── MÓDULO ROUTING ─── */
.module-view{display:none}
.module-view.active{display:block; animation: fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0; transform:translateY(8px)} to{opacity:1; transform:none}}

/* ─── HERO ─── */
.hero{
  position:relative;
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(34,200,184,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(59,184,126,.14), transparent 60%),
    linear-gradient(180deg, #F4F9FE 0%, #EAF3FB 100%);
  overflow:hidden;
}
.hero-inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:60px;
  align-items:center;
  padding:80px 28px 90px;
  max-width:var(--maxw); margin:0 auto;
}
.hero h1{
  font-size: clamp(40px, 5.6vw, 70px);
  color:var(--ink-900);
}
.hero h1 em{font-style:italic; color:var(--green-700); font-weight:500}
.hero-sub{margin-top:22px; font-size:18.5px; color:var(--muted); max-width:560px}
.hero-meta{
  margin-top:36px;
  display:flex; gap:28px; flex-wrap:wrap;
  padding-top:24px; border-top:1px solid var(--ink-12);
}
.hero-meta div{display:flex; flex-direction:column; gap:2px}
.hero-meta span{font-size:12px; color:var(--muted); font-weight:600; letter-spacing:.08em; text-transform:uppercase}
.hero-meta strong{font-size:16.5px; color:var(--ink-900); font-weight:600}

.hero-art{position:relative}
.hero-photo{
  position:relative;
  aspect-ratio: 4/5;
  border-radius:28px;
  overflow:hidden;
  box-shadow: var(--shadow-lg);
  background:#eee;
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,31,61,.45) 100%);
}
.hero-chip{
  position:absolute; background:#fff; border-radius:18px;
  padding:14px 16px; box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:12px; min-width:200px;
}
.hero-chip .ico{width:38px;height:38px; border-radius:11px; display:grid;place-items:center}
.hero-chip .ico svg{width:20px;height:20px}
.hero-chip small{font-size:11px; color:var(--muted); letter-spacing:.08em; text-transform:uppercase; font-weight:600}
.hero-chip strong{font-size:14.5px; color:var(--ink-900)}
.chip-1{top:32px; left:-28px; animation: float1 6s ease-in-out infinite}
.chip-2{bottom:80px; right:-28px; animation: float2 7s ease-in-out infinite}
.chip-3{bottom:-10px; left:40px; animation: float1 8s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)}}
@keyframes float2{0%,100%{transform:translateY(0)} 50%{transform:translateY(10px)}}

@media (max-width: 900px){
  .hero-inner{grid-template-columns: 1fr; gap:40px; padding:56px 20px 70px}
  .hero-photo{aspect-ratio: 4/3}
  .hero-chip{display:none}
}

/* ─── LAYOUT VISIÓN: SIDEBAR + CONTENT ─── */
.vision-shell{
  max-width:var(--maxw); margin:0 auto;
  padding: 30px 28px 80px;
  display:grid;
  grid-template-columns: 240px 1fr;
  gap: 50px;
  align-items:flex-start;
}
.vision-side{
  position:sticky;
  top: calc(var(--nav-h) + var(--tabs-h) + 24px);
  align-self:flex-start;
  padding: 22px 0;
}
.vision-side h6{
  font-family:'Plus Jakarta Sans';
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:700; color:var(--muted); margin:0 0 18px; padding-left:14px;
}
.vision-side ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px}
.vision-side a{
  display:flex; align-items:center; gap:12px;
  padding:11px 14px;
  font-size:14px; font-weight:500; color:var(--muted);
  border-radius:10px;
  transition: all .2s;
  border-left:2px solid transparent;
}
.vision-side a:hover{color:var(--ink-900); background:#fff}
.vision-side a.active{
  color:var(--ink-900); background:#fff;
  border-left-color: var(--teal-600);
  font-weight:600;
}
.vision-side a .num{
  font-family:'Fraunces',serif;
  font-size:11px; opacity:.55;
  width:18px; flex:none;
}
.vision-side a.active .num{color:var(--teal-600); opacity:1}
.vision-content{ min-width:0 }
.vision-content section.block{ padding: 70px 0; scroll-margin-top: calc(var(--nav-h) + var(--tabs-h) + 20px) }
.vision-content section.block:first-of-type{padding-top:30px}
.vision-content section.block.alt{
  background:transparent;
}
.vision-content section.block.dark{
  background: var(--ink-900);
  color:#fff;
  border-radius: 24px;
  padding: 70px 40px;
}
.vision-content section.block.sand{
  background: var(--sand);
  border-radius: 24px;
  padding: 70px 40px;
}
@media(max-width:1000px){
  .vision-shell{grid-template-columns:1fr; gap:0; padding:20px 20px 60px}
  .vision-side{
    position:relative; top:0;
    padding: 0 0 20px;
    overflow-x:auto;
    border-bottom:1px solid var(--line);
    margin-bottom:30px;
  }
  .vision-side h6{display:none}
  .vision-side ul{flex-direction:row; flex-wrap:nowrap; gap:6px; padding-bottom:8px}
  .vision-side a{white-space:nowrap; padding:8px 14px; border-left:none; border-bottom:2px solid transparent}
  .vision-side a.active{border-left:none; border-bottom-color:var(--teal-600)}
}

/* ─── GENERIC SECTION ─── */
section.block{ padding: 110px 0; position:relative }
section.block.tight{padding:80px 0}
section.block.dark .muted{color:rgba(255,255,255,.65)}
section.block.dark h2{color:#fff}

.section-head{ max-width:780px; margin: 0 auto 60px; text-align:center }
.section-head.left{text-align:left; margin: 0 0 60px}
.section-head h2{font-size:clamp(30px, 3.6vw, 46px); margin-top:18px}
.section-head p{margin-top:18px; color:var(--muted); font-size:17px}
section.block.dark .section-head p{color:rgba(255,255,255,.7)}

.muted{color:var(--muted)}

/* ─── VISION / PILARES ─── */
.pillars{display:grid; grid-template-columns:repeat(3, 1fr); gap:22px}
.pillar{
  position:relative; background:#fff; border-radius:var(--radius);
  padding:36px 32px 34px; border:1px solid var(--line);
  overflow:hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.pillar:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent}
.pillar::before{content:''; position:absolute; top:0; left:0; right:0; height:5px}
.pillar.p1::before{background:var(--ink-700)}
.pillar.p2::before{background:var(--teal-600)}
.pillar.p3::before{background:var(--green-600)}
.pillar .ico{
  width:54px; height:54px; border-radius:15px;
  display:grid; place-items:center; margin-bottom:22px;
}
.pillar.p1 .ico{background:rgba(28,67,128,.1); color:var(--ink-700)}
.pillar.p2 .ico{background:rgba(15,181,166,.12); color:var(--teal-600)}
.pillar.p3 .ico{background:rgba(46,155,107,.12); color:var(--green-700)}
.pillar .ico svg{width:26px;height:26px}
.pillar h3{font-size:24px; margin-bottom:6px}
.pillar .tag{font-size:12.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:14px; display:block}
.pillar p{color:var(--muted); font-size:15.5px}

.vision-quote{
  margin: 60px auto 0; max-width:760px; text-align:center;
  font-family:'Fraunces',serif; font-style:italic;
  font-size:24px; color:var(--ink-800); line-height:1.4;
  position:relative; padding: 28px 24px;
}
.vision-quote::before{
  content:'\201C'; position:absolute; top:-18px; left:50%; transform:translateX(-50%);
  font-size:90px; color:var(--teal-600); line-height:1; font-family:'Fraunces',serif;
}
.vision-quote cite{display:block; margin-top:14px; font-style:normal; font-family:'Plus Jakarta Sans'; font-size:13px; color:var(--muted); letter-spacing:.14em; text-transform:uppercase; font-weight:600}

@media (max-width:900px){ .pillars{grid-template-columns:1fr} }

/* ─── WHY SECTION ─── */
.why-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:50px; align-items:center}
.why-grid .photo{aspect-ratio: 4/5; border-radius:24px; overflow:hidden; box-shadow:var(--shadow-md); position:relative}
.why-grid .photo img{width:100%;height:100%;object-fit:cover}
.why-stats{
  position:absolute; bottom:20px; left:20px; right:20px;
  background:rgba(255,255,255,.96); backdrop-filter:blur(4px);
  border-radius:16px; padding:18px;
  display:grid; grid-template-columns:repeat(3,1fr); gap:10px;
  box-shadow:var(--shadow-md);
}
.why-stats div{text-align:center; padding:4px}
.why-stats div + div{border-left:1px solid var(--line)}
.why-stats strong{display:block; font-family:'Fraunces',serif; font-size:26px; color:var(--ink-900)}
.why-stats span{font-size:11.5px; letter-spacing:.08em; color:var(--muted); text-transform:uppercase; font-weight:600}

.why-list{list-style:none;padding:0;margin:28px 0 0; display:grid; gap:18px}
.why-list li{display:flex; gap:16px; align-items:flex-start; padding:18px 20px; border-radius:14px; background:#fff; border:1px solid var(--line); transition: border-color .2s}
.why-list li:hover{border-color:var(--teal-500)}
.why-list .ic{flex:none; width:40px; height:40px; border-radius:11px; background:var(--teal-100); color:var(--teal-600); display:grid; place-items:center}
.why-list .ic svg{width:20px;height:20px}
.why-list h4{font-family:'Plus Jakarta Sans'; font-size:16px; font-weight:700; margin-bottom:3px}
.why-list p{font-size:14.5px; color:var(--muted)}
@media (max-width:900px){ .why-grid{grid-template-columns:1fr; gap:40px} }

/* ─── OBJETIVOS ─── */
.obj-grid{display:grid; grid-template-columns: repeat(2, 1fr); gap:22px}
.obj{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius); padding:36px;
  position:relative;
  transition: transform .25s ease, box-shadow .25s ease;
  overflow:hidden;
}
.obj:hover{transform:translateY(-4px); box-shadow:var(--shadow-md)}
.obj .num{
  font-family:'Fraunces',serif; font-size:64px; line-height:1;
  color:var(--teal-600); opacity:.18; font-weight:600;
  position:absolute; top:22px; right:28px;
}
.obj .ic{
  width:52px; height:52px; border-radius:14px;
  background: linear-gradient(135deg, var(--ink-900), var(--ink-700));
  color:#fff; display:grid; place-items:center; margin-bottom:22px;
}
.obj .ic svg{width:24px;height:24px}
.obj h3{font-size:22px; margin-bottom:10px}
.obj p{color:var(--muted); font-size:15px}
.obj .principle{
  margin-top:18px; padding-top:16px; border-top:1px dashed var(--line);
  font-size:13px; color:var(--green-700); font-weight:600; letter-spacing:.02em;
  display:flex; align-items:center; gap:8px;
}
.obj .principle::before{content:'\2726'; color:var(--teal-600)}
@media (max-width:800px){ .obj-grid{grid-template-columns:1fr} }

/* ─── POBLACIONES / IMPACTO ─── */
.pop-grid{display:grid; grid-template-columns: repeat(4, 1fr); gap:16px}
.pop{
  padding:26px 22px; border-radius:var(--radius-sm);
  background:#fff; border:1px solid var(--line);
  display:flex; flex-direction:column; gap:14px;
  min-height:180px;
  transition: all .25s; position:relative; overflow:hidden;
}
.pop:hover{border-color:var(--teal-500); transform:translateY(-3px); box-shadow:var(--shadow-md)}
.pop .ic{width:44px; height:44px; border-radius:12px; background:var(--teal-100); color:var(--teal-600); display:grid; place-items:center}
.pop .ic svg{width:22px;height:22px}
.pop h4{font-family:'Plus Jakarta Sans'; font-size:16px; font-weight:700; margin:0}
.pop p{font-size:13.5px; color:var(--muted)}
.pop.primary{background:var(--ink-900); color:#fff; border-color:var(--ink-900)}
.pop.primary .ic{background:rgba(34,200,184,.2); color:var(--teal-500)}
.pop.primary p{color:rgba(255,255,255,.7)}
.pop.primary h4{color:#fff}

.pop-principle{margin-top:40px; text-align:center; font-family:'Fraunces', serif; font-style:italic; font-size:18px; color:var(--ink-700)}
.pop-principle span{color:var(--green-700); font-weight:600}

@media (max-width: 1100px){ .pop-grid{grid-template-columns: repeat(3, 1fr)} }
@media (max-width: 800px){ .pop-grid{grid-template-columns: repeat(2, 1fr)} }
@media (max-width: 500px){ .pop-grid{grid-template-columns: 1fr} }

/* ─── PRESUPUESTO (sección block dark, también usada en proyecto) ─── */
.budget-hero{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:18px;
  margin-bottom:42px;
}
.bcard{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  padding:24px;
  backdrop-filter: blur(6px);
}
.bcard .blabel{font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.55); font-weight:600; margin-bottom:14px}
.bcard .bnum{font-family:'Fraunces',serif; font-size:38px; color:#fff; line-height:1; font-weight:500}
.bcard .bnum .cur{font-size:18px; color:var(--teal-500); vertical-align:top; margin-right:4px; font-family:'Plus Jakarta Sans'; font-weight:500}
.bcard .bnum .unit{font-size:15px; color:rgba(255,255,255,.6); font-family:'Plus Jakarta Sans'; font-weight:500}
.bcard .bsub{font-size:12.5px; color:rgba(255,255,255,.55); margin-top:10px}
.bcard.featured{background:rgba(15,181,166,.1); border-color:rgba(15,181,166,.35)}
.bcard.featured .blabel{color:var(--teal-500)}

.budget-main{display:grid; grid-template-columns: 1.15fr .85fr; gap:28px}
.budget-table{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius); overflow:hidden;
}
.bt-row{display:grid; grid-template-columns: 1fr auto; gap:16px; padding:16px 24px; border-bottom:1px solid rgba(255,255,255,.08); align-items:center}
.bt-row:last-child{border-bottom:none}
.bt-row.header{background:rgba(15,181,166,.1); padding:14px 24px; font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; color:var(--teal-500)}
.bt-row.total{background:rgba(34,200,184,.08); border-top: 1px solid rgba(34,200,184,.3)}
.bt-row .bt-label{font-size:15px; color:#fff; font-weight:500}
.bt-row .bt-sub{font-size:12.5px; color:rgba(255,255,255,.6); margin-top:2px}
.bt-row .bt-val{font-family:'Fraunces',serif; font-size:20px; color:#fff; font-weight:500; white-space:nowrap}
.bt-row .bt-val.pos{color:var(--green-500)}
.bt-row .bt-val.neg{color:#F4A86B}
.bt-row .bt-val.big{font-size:26px}

.margin-card{
  background: linear-gradient(160deg, var(--teal-600), var(--ink-800) 85%);
  border-radius:var(--radius); padding:32px;
  position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
}
.margin-card::before{
  content:''; position:absolute; inset:auto -40% -60% auto;
  width:320px; height:320px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.2), transparent 70%);
}
.margin-card .mlabel{font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.7); font-weight:700; margin-bottom:14px; position:relative}
.margin-card .mnum{font-family:'Fraunces',serif; font-size:60px; color:#fff; line-height:1; font-weight:500; position:relative}
.margin-card .mnum .cur{font-size:22px; vertical-align:top; opacity:.8; margin-right:4px; font-family:'Plus Jakarta Sans'}
.margin-card .mnum .plus{font-size:18px; opacity:.6; font-family:'Plus Jakarta Sans'}
.margin-card .msub{color:rgba(255,255,255,.8); font-size:14px; margin-top:18px; position:relative}
.margin-card .mbar{margin-top:24px; height:8px; background:rgba(255,255,255,.15); border-radius:999px; overflow:hidden; position:relative}
.margin-card .mbar div{background:linear-gradient(90deg, var(--green-500), var(--teal-500)); height:100%; border-radius:999px; transition: width .5s ease}
.margin-card .mbar-labels{display:flex; justify-content:space-between; margin-top:8px; font-size:12px; color:rgba(255,255,255,.7); position:relative}

.budget-note{
  margin-top:36px; padding:20px 24px;
  background:rgba(255,255,255,.04); border:1px dashed rgba(255,255,255,.2);
  border-radius:14px;
  display:flex; gap:18px; align-items:flex-start;
  color:rgba(255,255,255,.8); font-size:14px;
}
.budget-note .ic{width:38px; height:38px; border-radius:10px; background:rgba(15,181,166,.2); color:var(--teal-500); display:grid; place-items:center; flex:none}
.budget-note .ic svg{width:18px;height:18px}
.budget-note strong{color:#fff; font-weight:600; display:block; margin-bottom:3px}

@media (max-width:1000px){
  .budget-hero{grid-template-columns: repeat(2,1fr)}
  .budget-main{grid-template-columns: 1fr}
}

/* ─── TOAST ─── */
.toast{
  position:fixed; left:50%; bottom:30px; transform:translate(-50%, 80px);
  background:var(--ink-900); color:#fff;
  padding:14px 22px; border-radius:999px;
  font-size:14px; font-weight:600;
  box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:10px;
  z-index:200; opacity:0; pointer-events:none;
  transition: transform .35s cubic-bezier(.2,.9,.3,1.4), opacity .25s ease;
}
.toast.show{ opacity:1; transform:translate(-50%, 0) }
.toast .ic{width:22px; height:22px; border-radius:50%; background:var(--teal-500); color:#fff; display:grid; place-items:center}
.toast .ic svg{width:13px; height:13px}

/* ─── FOOTER ─── */
footer{background:#050F1F; color:rgba(255,255,255,.7); padding: 60px 28px 30px}
.foot-inner{max-width:var(--maxw); margin:0 auto}
.foot-top{
  display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.1);
}
.foot-top h5{font-family:'Plus Jakarta Sans'; color:#fff; font-size:13px; letter-spacing:.14em; text-transform:uppercase; font-weight:700; margin:0 0 18px}
.foot-top p, .foot-top a{font-size:14.5px; color:rgba(255,255,255,.6); display:block; padding:4px 0}
.foot-top a:hover{color:var(--teal-500)}
.foot-brand strong{color:#fff; font-family:'Fraunces',serif; font-size:22px; font-weight:500}
.foot-brand p{margin-top:12px; max-width:340px; line-height:1.6}
.foot-final{padding-top:26px; display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; font-size:13px; color:rgba(255,255,255,.5)}
.foot-final em{color:var(--teal-500); font-style:normal}
@media (max-width:800px){ .foot-top{grid-template-columns:1fr 1fr} }
@media (max-width:500px){ .foot-top{grid-template-columns:1fr} }

/* reveal animation */
.reveal{opacity:0; transform:translateY(20px); transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform:none}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .chip-1, .chip-2, .chip-3{animation:none !important}
}

/* ============================================================
   ─── MÓDULO 2: PROYECTO DÍA DE SALUD EN FAMILIA ───
   ============================================================ */

/* HEADER del módulo proyecto */
.proj-header{
  background:
    radial-gradient(800px 400px at 100% 0%, rgba(15,181,166,.18), transparent 60%),
    linear-gradient(135deg, var(--ink-900) 0%, #0F2A50 100%);
  color:#fff;
  padding: 70px 0 30px;
  position:relative;
  overflow:hidden;
}
.proj-header::before{
  content:''; position:absolute; top:-100px; right:-100px;
  width:400px; height:400px; border-radius:50%;
  border:1.5px dashed rgba(15,181,166,.18);
  animation: rotate 80s linear infinite;
}
@keyframes rotate{to{transform:rotate(360deg)}}
.proj-header-inner{
  max-width:var(--maxw); margin:0 auto; padding:0 28px;
  position:relative;
}
.proj-tag{
  display:inline-flex; align-items:center; gap:10px;
  font-size:11.5px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--teal-500);
  padding:8px 14px;
  background:rgba(15,181,166,.12);
  border:1px solid rgba(15,181,166,.3);
  border-radius:999px;
}
.proj-tag .dot{width:6px;height:6px;background:var(--teal-500);border-radius:999px;box-shadow:0 0 0 4px rgba(15,181,166,.18)}
.proj-header h1{
  margin-top:18px;
  font-size: clamp(36px, 5vw, 60px);
  color:#fff;
}
.proj-header h1 em{font-style:italic; color:var(--teal-500); font-weight:500}
.proj-header p{margin-top:16px; max-width:680px; color:rgba(255,255,255,.75); font-size:17px}
.proj-header-meta{
  margin-top:26px; display:flex; gap:32px; flex-wrap:wrap;
  padding-top:24px; border-top:1px solid rgba(255,255,255,.12);
}
.proj-header-meta div{display:flex; flex-direction:column; gap:2px}
.proj-header-meta span{font-size:11px; color:rgba(255,255,255,.55); letter-spacing:.1em; text-transform:uppercase; font-weight:600}
.proj-header-meta strong{font-size:16px; color:#fff; font-family:'Fraunces',serif; font-weight:500}

/* Tabs internos del proyecto */
.proj-tabs-wrap{
  background:#fff;
  border-bottom:1px solid var(--line);
  position:sticky;
  top: calc(var(--nav-h) + var(--tabs-h));
  z-index: 50;
}
.proj-tabs{
  max-width:var(--maxw); margin:0 auto;
  padding: 8px 28px;
  display:flex; gap:6px; overflow-x:auto;
}
.proj-tabs::-webkit-scrollbar{height:0}
.ptab{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 16px;
  border-radius:10px;
  font-size:13.5px; font-weight:600;
  color:var(--muted);
  cursor:pointer;
  border:none; background:transparent;
  transition: all .2s;
  font-family:inherit;
  white-space:nowrap;
}
.ptab:hover{background:var(--bg); color:var(--ink-900)}
.ptab.active{background:var(--ink-900); color:#fff}
.ptab svg{width:15px; height:15px}

.proj-body{
  max-width:var(--maxw); margin:0 auto;
  padding: 50px 28px 80px;
}

.proj-pane{display:none}
.proj-pane.active{display:block; animation: fadeIn .35s ease}

.pane-head{margin-bottom:36px}
.pane-head h2{font-size:clamp(26px, 3vw, 36px); margin-bottom:8px}
.pane-head p{color:var(--muted); font-size:16px; max-width:720px}

/* ─── INFOGRAFÍA DE ESPACIOS ─── */
.infograph{
  display:grid; gap:24px;
  margin-bottom:30px;
}
.spaces-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:18px;
}
.space-card{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  position:relative;
  overflow:hidden;
  transition: all .25s;
}
.space-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:transparent}
.space-card::before{content:''; position:absolute; top:0; left:0; right:0; height:4px}
.space-card.s1::before{background:var(--ink-700)}
.space-card.s2::before{background:var(--green-600)}
.space-card.s3::before{background:var(--teal-600)}
.space-card.s4::before{background:#A06CD5}
.space-card.s5::before{background:var(--amber)}
.space-ico{
  width:48px; height:48px; border-radius:14px;
  display:grid; place-items:center; margin-bottom:18px;
}
.space-ico svg{width:24px; height:24px}
.space-card.s1 .space-ico{background:rgba(28,67,128,.1); color:var(--ink-700)}
.space-card.s2 .space-ico{background:rgba(46,155,107,.12); color:var(--green-700)}
.space-card.s3 .space-ico{background:rgba(15,181,166,.12); color:var(--teal-600)}
.space-card.s4 .space-ico{background:rgba(160,108,213,.14); color:#7E4FB9}
.space-card.s5 .space-ico{background:rgba(224,148,40,.14); color:#A3621A}
.space-card .stag{
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  font-weight:700; color:var(--muted); margin-bottom:6px; display:block;
}
.space-card h3{font-size:20px; margin-bottom:8px}
.space-card p{font-size:14px; color:var(--muted); margin-bottom:14px}
.space-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px}
.space-list li{
  font-size:13px; color:var(--ink-700);
  display:flex; align-items:flex-start; gap:8px;
  padding:6px 0;
}
.space-list li::before{
  content:''; flex:none; margin-top:7px;
  width:5px; height:5px; border-radius:50%;
  background:var(--teal-600);
}

/* Flujo del día */
.day-flow{
  background: linear-gradient(135deg, #F0FAF4 0%, #EAF7F5 100%);
  border:1px solid rgba(15,181,166,.2);
  border-radius: var(--radius);
  padding:32px;
  margin-top: 18px;
}
.day-flow h4{font-size:18px; margin-bottom:18px; display:flex; align-items:center; gap:10px}
.day-flow h4 svg{width:18px; height:18px; color:var(--teal-600)}
.day-flow-steps{
  display:grid; gap:14px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.day-step{
  background:#fff; border-radius:14px;
  padding:16px 18px; border:1px solid rgba(15,181,166,.14);
  position:relative;
}
.day-step .time{
  font-family:'Fraunces',serif; font-size:18px;
  color:var(--teal-600); font-weight:600;
  display:block; margin-bottom:4px;
}
.day-step .label{font-size:13.5px; color:var(--ink-900); font-weight:600; display:block}
.day-step .desc{font-size:12.5px; color:var(--muted); margin-top:4px}

/* ─── EQUIPO PANE: Header con estado ─── */
.team-pane-head{
  display:grid; grid-template-columns: 1fr auto;
  gap:20px; align-items:center;
  padding:24px 28px;
  background: linear-gradient(135deg, var(--ink-900) 0%, #0F2A50 100%);
  color:#fff;
  border-radius: var(--radius);
  margin-bottom:28px;
  position:relative; overflow:hidden;
}
.team-pane-head::before{
  content:''; position:absolute; top:-50%; right:-10%;
  width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(15,181,166,.2), transparent 70%);
  pointer-events:none;
}
.team-pane-head .lbl{
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--teal-500); font-weight:700; margin-bottom:6px;
  position:relative;
}
.team-pane-head h3{font-size:28px; color:#fff; position:relative; margin:0}
.team-pane-head .desc{font-size:14px; color:rgba(255,255,255,.7); margin-top:6px; max-width:560px; position:relative}
.team-pane-head .ico{
  width:60px; height:60px; border-radius:16px;
  background:rgba(15,181,166,.2); color:var(--teal-500);
  display:grid; place-items:center;
  position:relative;
  flex:none;
}
.team-pane-head .ico svg{width:30px; height:30px}

/* ─── EDITABLE PANELS / FORMS ─── */
.edit-card{
  background:#fff; border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px;
  margin-bottom: 18px;
}
.edit-card-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; margin-bottom:18px; flex-wrap:wrap;
}
.edit-card-head h4{font-size:18px; display:flex; align-items:center; gap:10px}
.edit-card-head h4 .ic{
  width:30px; height:30px; border-radius:8px;
  background: var(--teal-100); color: var(--teal-600);
  display:grid; place-items:center;
  flex:none;
}
.edit-card-head h4 .ic svg{width:15px; height:15px}
.edit-card-head .saved-pill{
  font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  color:var(--green-700); background:var(--green-100);
  padding:5px 11px; border-radius:999px;
  display:inline-flex; align-items:center; gap:6px;
  opacity:0; transition: opacity .3s;
}
.edit-card-head .saved-pill.show{opacity:1}
.edit-card-head .saved-pill::before{
  content:''; width:6px; height:6px; border-radius:50%; background:var(--green-600);
}

.field{display:flex; flex-direction:column; gap:6px; margin-bottom:14px}
.field label{
  font-size:12px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--muted);
}
.field input, .field textarea, .field select{
  font-family:inherit; font-size:14.5px;
  padding: 11px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background:#fff; color:var(--ink-900);
  resize:vertical;
  transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none;
  border-color: var(--teal-500);
  box-shadow: 0 0 0 3px rgba(15,181,166,.12);
}
.field textarea{min-height:80px; line-height:1.5}
.field .hint{font-size:12px; color:var(--muted); margin-top:2px}
.field-row{display:grid; gap:14px; grid-template-columns: 1fr 1fr}
@media(max-width:600px){ .field-row{grid-template-columns:1fr} }

.edit-actions{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:flex-end;
  margin-top:6px;
  padding-top:18px;
  border-top:1px solid var(--line);
}

/* Conferencias list (multi-row) */
.confs-list{display:flex; flex-direction:column; gap:14px; margin-bottom:18px}
.conf-row{
  background: var(--bg); border:1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
  position:relative;
}
.conf-row .conf-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:14px;
}
.conf-row .conf-num{
  font-family:'Fraunces',serif; font-size:13px; font-weight:600;
  color:var(--teal-600); letter-spacing:.05em;
}
.conf-row .field{margin-bottom:10px}
.conf-row .field label{font-size:11px}
.conf-row .field input, .conf-row .field textarea{font-size:13.5px; padding:9px 12px}

/* ─── PRESUPUESTO EDITABLE ─── */
.budget-edit{
  background:#fff; border:1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  margin-bottom: 24px;
}
.budget-edit-head{
  padding: 22px 26px;
  background: linear-gradient(135deg, var(--ink-900), #0F2A50);
  color:#fff;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
}
.budget-edit-head h3{font-size:20px; color:#fff; font-family:'Fraunces',serif; margin:0}
.budget-edit-head .totals{
  display:flex; gap:24px; flex-wrap:wrap;
}
.budget-edit-head .totals div{display:flex; flex-direction:column}
.budget-edit-head .totals span{font-size:11px; color:rgba(255,255,255,.6); letter-spacing:.08em; text-transform:uppercase; font-weight:600}
.budget-edit-head .totals strong{font-family:'Fraunces',serif; font-size:22px; color:var(--teal-500); font-weight:500}
.budget-edit-head .totals strong.neg{color:#F4A86B}
.budget-edit-head .totals strong.pos{color:var(--green-500)}

.budget-rows{ padding: 8px 0 }
.budget-row{
  display:grid;
  grid-template-columns: 1fr 130px 160px;
  gap:14px;
  align-items:center;
  padding: 10px 22px;
  border-bottom:1px solid var(--line);
}
.budget-row.custom-row{
  grid-template-columns: 1fr 130px 160px 36px;
  background: rgba(15,181,166,.03);
}
.budget-row:last-child{border-bottom:none}
.btn-del-row{
  width:30px; height:30px; border-radius:8px;
  background:transparent; border:1px solid transparent;
  color:var(--muted); cursor:pointer;
  display:grid; place-items:center;
  font-size:20px; line-height:1;
  transition: all .15s; font-family:inherit;
}
.btn-del-row:hover{background:#FEE; color:#C44; border-color:#FCC}
.custom-row .custom-label{
  border:1px dashed var(--line) !important;
  background: rgba(15,181,166,.04) !important;
}
.budget-row .br-type{
  font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  text-align:center;
  white-space:nowrap;
}
.budget-row .br-type.in{background:var(--green-100); color:var(--green-700)}
.budget-row .br-type.out{background:var(--amber-100); color:#A3621A}
.budget-row input[type=text]{
  border: none; background:transparent;
  font-size:14.5px; padding: 8px 10px; border-radius:8px;
  width:100%;
  font-family:inherit; color:var(--ink-900);
  transition: background .15s;
}
.budget-row input[type=text]:hover{background:var(--bg)}
.budget-row input[type=text]:focus{
  outline:none; background:#fff;
  box-shadow: 0 0 0 3px rgba(15,181,166,.12), 0 0 0 1px var(--teal-500);
}
.budget-row input[type=number]{
  border: none; background:transparent;
  font-family:'Fraunces',serif; font-size:16px; font-weight:500;
  text-align:right; padding:8px 10px; border-radius:8px;
  width:100%; color:var(--ink-900);
  transition: background .15s;
  -moz-appearance:textfield;
}
.budget-row input[type=number]::-webkit-outer-spin-button,
.budget-row input[type=number]::-webkit-inner-spin-button{
  -webkit-appearance:none; margin:0;
}
.budget-row input[type=number]:hover{background:var(--bg)}
.budget-row input[type=number]:focus{
  outline:none; background:#fff;
  box-shadow: 0 0 0 3px rgba(15,181,166,.12), 0 0 0 1px var(--teal-500);
}
.budget-row .br-del{
  width:28px; height:28px; border-radius:8px;
  background:transparent; border:1px solid transparent;
  color:var(--muted); cursor:pointer;
  display:grid; place-items:center;
  transition: all .15s;
}
.budget-row .br-del:hover{background:#FEE; color:#C44; border-color:#FCC}
.budget-row .br-del svg{width:14px; height:14px}

.budget-add{
  margin: 6px 22px 16px;
  display:flex; gap:10px; flex-wrap:wrap;
  padding-top:14px;
  border-top: 1px dashed var(--line);
}
.budget-add button{
  border:1px dashed var(--line);
  background:transparent;
  color:var(--ink-700);
  padding: 9px 16px;
  border-radius: 999px;
  font-size: 13px; font-weight:600;
  cursor:pointer;
  display:inline-flex; align-items:center; gap:8px;
  transition: all .15s;
  font-family:inherit;
}
.budget-add button:hover{border-color:var(--teal-500); color:var(--teal-600); background:var(--teal-100)}
.budget-add button svg{width:13px; height:13px}

@media(max-width:700px){
  .budget-row{grid-template-columns: 1fr 90px; gap:8px}
  .budget-row .br-type{display:none}
  .budget-row.custom-row{grid-template-columns: 1fr 90px 30px}
  .btn-del-row{width:28px; height:28px; font-size:16px}
}

/* ─── PENDIENTES (TODO list) ─── */
.todo-card{
  background:#fff; border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px 26px;
  margin-bottom: 18px;
}
.todo-card-head{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; margin-bottom:18px; flex-wrap:wrap;
}
.todo-card-head h4{font-size:18px}
.todo-stats{
  font-size:12.5px; color:var(--muted); display:flex; gap:14px; align-items:center; font-weight:500;
}
.todo-stats strong{color:var(--ink-900); font-weight:700}
.todo-add{
  display:grid; grid-template-columns: 1fr auto auto; gap:10px;
  margin-bottom:18px;
  padding: 14px;
  background: var(--bg);
  border-radius: 14px;
}
.todo-add input, .todo-add select{
  border:1px solid var(--line);
  border-radius:10px; padding:10px 12px; font-size:14px;
  background:#fff; font-family:inherit;
}
.todo-add input:focus, .todo-add select:focus{outline:none; border-color:var(--teal-500); box-shadow:0 0 0 3px rgba(15,181,166,.12)}
.todo-add button{
  background: var(--ink-900); color:#fff;
  border:none; padding: 10px 18px;
  border-radius:10px; font-size:13.5px; font-weight:600;
  cursor:pointer; display:inline-flex; align-items:center; gap:8px;
  transition: background .15s;
  font-family:inherit;
}
.todo-add button:hover{background:var(--ink-800)}
.todo-add button svg{width:14px; height:14px}
@media(max-width:600px){ .todo-add{grid-template-columns:1fr} }

.todo-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
.todo-item{
  display:grid; grid-template-columns: auto 1fr auto auto;
  gap: 14px; align-items:center;
  padding: 12px 16px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  transition: all .15s;
}
.todo-item:hover{border-color:var(--ink-12)}
.todo-item.done{ background: #FAFCFA; }
.todo-item.done .todo-text{text-decoration:line-through; color:var(--muted)}
.todo-check{
  width:22px; height:22px; border-radius:50%;
  border:2px solid var(--line);
  cursor:pointer;
  display:grid; place-items:center;
  background:#fff;
  transition: all .15s;
  flex:none;
}
.todo-check:hover{border-color:var(--teal-500)}
.todo-item.done .todo-check{background:var(--green-600); border-color:var(--green-600); color:#fff}
.todo-check svg{width:12px; height:12px; opacity:0; transition:opacity .15s}
.todo-item.done .todo-check svg{opacity:1}
.todo-text{font-size:14.5px; color:var(--ink-900); font-weight:500; line-height:1.4}
.todo-prio{
  font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 9px; border-radius:999px;
  white-space:nowrap;
}
.todo-prio.high{background:#FEE; color:#A33}
.todo-prio.med{background:var(--amber-100); color:#A3621A}
.todo-prio.low{background:var(--bg); color:var(--muted)}
.todo-del{
  width:28px; height:28px; border-radius:8px;
  background:transparent; border:1px solid transparent;
  color:var(--muted); cursor:pointer;
  display:grid; place-items:center;
  transition: all .15s;
}
.todo-del:hover{background:#FEE; color:#C44; border-color:#FCC}
.todo-del svg{width:14px; height:14px}
.todo-empty{
  text-align:center;
  padding: 30px 20px;
  color:var(--muted);
  font-size:14px;
  border: 2px dashed var(--line);
  border-radius:14px;
}

/* ─── PATROCINADORES (módulo proyecto) ─── */
.spons-grid{
  display:grid; gap:18px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  margin-bottom:24px;
}
.spons-card{
  padding: 28px 26px;
  border-radius: var(--radius);
  background:#fff; border:1px solid var(--line);
  position:relative;
  transition: all .25s;
}
.spons-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.spons-card.featured{
  background: linear-gradient(160deg, var(--ink-900) 0%, #0E2A52 100%);
  color:#fff; border-color:transparent;
  box-shadow:var(--shadow-md);
}
.spons-card.featured h4{color:#fff}
.spons-card.featured p{color:rgba(255,255,255,.7)}
.spons-card .lbl{
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  font-weight:700; color:var(--teal-600);
  margin-bottom:8px;
}
.spons-card.featured .lbl{color:var(--teal-500)}
.spons-card h4{font-family:'Fraunces',serif; font-size:22px; font-weight:600; margin:0 0 8px}
.spons-card p{font-size:14px; color:var(--muted); margin-bottom:16px}
.spons-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
.spons-list li{
  font-size:13.5px; line-height:1.4;
  display:flex; gap:10px; align-items:flex-start;
  color: inherit;
  opacity:.85;
}
.spons-card.featured .spons-list li{color:rgba(255,255,255,.85)}
.spons-list li::before{
  content:''; flex:none; margin-top:7px;
  width:5px; height:5px; border-radius:50%;
  background:var(--teal-600);
}
.spons-card.featured .spons-list li::before{background:var(--teal-500)}

.spons-aporte-types{
  display:grid; gap:14px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin-top: 8px;
}
.aporte{
  background: linear-gradient(135deg, #FFF 0%, var(--bg) 100%);
  border:1px solid var(--line);
  padding: 20px;
  border-radius: 14px;
}
.aporte .ico{
  width:38px; height:38px; border-radius:10px;
  background:var(--teal-100); color:var(--teal-600);
  display:grid; place-items:center; margin-bottom:12px;
}
.aporte .ico svg{width:18px; height:18px}
.aporte h5{font-family:'Plus Jakarta Sans'; font-size:14.5px; font-weight:700; margin:0 0 4px}
.aporte p{font-size:12.5px; color:var(--muted)}

/* ─── MARKETING: ángulos / conceptos ─── */
.angles-grid{
  display:grid; gap:16px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.angle{
  padding: 24px;
  border-radius: var(--radius);
  background:#fff; border:1px solid var(--line);
  position:relative;
  transition: all .25s;
}
.angle:hover{transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--teal-500)}
.angle .anum{
  font-family:'Fraunces',serif; font-size:14px; font-weight:600;
  color:var(--teal-600); margin-bottom:6px;
}
.angle h4{font-family:'Fraunces',serif; font-size:18px; font-weight:600; margin:0 0 8px; line-height:1.2}
.angle p{font-size:13.5px; color:var(--muted); line-height:1.5}
.angle .copy{
  margin-top: 14px; padding-top:14px; border-top:1px dashed var(--line);
  font-family:'Fraunces',serif; font-style:italic; font-size:14px; color:var(--ink-800); line-height:1.4;
}

.kids-callout{
  background: linear-gradient(135deg, var(--green-100) 0%, var(--teal-100) 100%);
  border: 1px solid rgba(15,181,166,.3);
  border-radius: var(--radius);
  padding: 28px 32px;
  margin-top: 24px;
  display:grid; grid-template-columns: 60px 1fr; gap:22px; align-items:center;
}
.kids-callout .ico{
  width:60px; height:60px; border-radius:16px;
  background: var(--green-600); color:#fff;
  display:grid; place-items:center;
}
.kids-callout .ico svg{width:30px; height:30px}
.kids-callout h4{font-family:'Fraunces',serif; font-size:22px; font-weight:600; margin:0 0 6px; color:var(--green-700)}
.kids-callout p{font-size:14.5px; color:var(--ink-800)}
@media(max-width:600px){
  .kids-callout{grid-template-columns:1fr; text-align:center}
  .kids-callout .ico{margin:0 auto}
}

/* ─── LOGÍSTICA: timeline integrado ─── */
.timeline{
  position:relative;
  padding: 6px 0 6px 28px;
  border-left: 2px solid var(--line);
  display:flex; flex-direction:column; gap:18px;
}
.timeline-item{
  position:relative;
  padding: 18px 22px;
  background:#fff; border:1px solid var(--line);
  border-radius:14px;
  transition: all .2s;
}
.timeline-item:hover{border-color:var(--teal-500)}
.timeline-item::before{
  content:''; position:absolute;
  left:-37px; top:24px;
  width:14px; height:14px; border-radius:50%;
  background:var(--teal-600);
  border: 3px solid #fff;
  box-shadow: 0 0 0 2px var(--teal-600);
}
.timeline-item .ti-time{
  font-family:'Fraunces',serif; font-size:18px;
  color:var(--teal-600); font-weight:600;
  display:block; margin-bottom:4px;
}
.timeline-item h5{font-family:'Plus Jakarta Sans'; font-size:15px; font-weight:700; margin:0 0 4px; color:var(--ink-900)}
.timeline-item p{font-size:13.5px; color:var(--muted); line-height:1.5}
.timeline-item.highlight{
  background: linear-gradient(135deg, #F0FAF4 0%, #EAF7F5 100%);
  border-color: rgba(15,181,166,.3);
}
.timeline-item.highlight::before{background:var(--green-600); box-shadow:0 0 0 2px var(--green-600)}

/* ─── ALERTS ─── */
.alert{
  display:grid; grid-template-columns: 36px 1fr; gap:16px;
  padding: 18px 20px;
  border-radius: 14px;
  margin-bottom: 22px;
  align-items:flex-start;
}
.alert.info{background:rgba(15,181,166,.08); border:1px solid rgba(15,181,166,.25); color:var(--ink-800)}
.alert.warn{background:var(--amber-100); border:1px solid rgba(224,148,40,.3); color:#7A4A0F}
.alert .ico{
  width:36px; height:36px; border-radius:10px;
  display:grid; place-items:center; flex:none;
}
.alert.info .ico{background:var(--teal-600); color:#fff}
.alert.warn .ico{background:var(--amber); color:#fff}
.alert .ico svg{width:18px; height:18px}
.alert strong{display:block; font-weight:700; margin-bottom:3px; font-size:14.5px}
.alert p{font-size:13.5px; line-height:1.45; color:inherit; opacity:.85}

/* ============================================================
   ─── ÁREAS TEMÁTICAS (Visión) ───
   ============================================================ */
.areas-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
}
.area-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 24px;
  position:relative;
  transition: all .25s;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.area-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent}
.area-icon{
  width:48px; height:48px; border-radius:14px;
  display:grid; place-items:center;
}
.area-icon svg{width:24px; height:24px}
.area-card h3{font-size:22px; margin:0; line-height:1.2}
.area-card p{font-size:14px; color:var(--muted); line-height:1.5; margin:0; flex:1}
.area-tag{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted);
  padding:6px 12px;
  background:var(--bg);
  border-radius:999px;
  width:fit-content;
}
.area-tag::before{
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--line);
}
.area-tag.active-tag{
  background:rgba(239,68,68,.08);
  color:#DC2626;
  border:1px solid rgba(239,68,68,.2);
}
.area-tag.active-tag::before{
  background:#DC2626;
  box-shadow: 0 0 0 3px rgba(239,68,68,.15);
}

.areas-note{
  margin-top:32px;
  padding:20px 24px;
  background:rgba(15,181,166,.06);
  border:1px dashed rgba(15,181,166,.25);
  border-radius:14px;
  display:flex; gap:18px; align-items:flex-start;
}
.areas-note .ic{
  width:38px; height:38px; border-radius:10px;
  background:rgba(15,181,166,.12); color:var(--teal-600);
  display:grid; place-items:center; flex:none;
}
.areas-note .ic svg{width:18px; height:18px}
.areas-note strong{display:block; font-weight:700; margin-bottom:4px; font-size:15px; color:var(--ink-900)}
.areas-note p{font-size:14px; color:var(--muted); margin:0}

@media (max-width:900px){ .areas-grid{grid-template-columns: repeat(2, 1fr)} }
@media (max-width:550px){ .areas-grid{grid-template-columns: 1fr} }

/* ============================================================
   ─── PATROCINIO · Visión (rediseñado) ───
   ============================================================ */
.sponsor-section{
  max-width:100%;
}
.sponsor-header{
  margin-bottom:32px;
}
.sponsor-stats-bar{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:16px;
  margin-bottom:36px;
}
.sponsor-stat{
  text-align:center;
  padding:22px 16px;
  background:#fff;
  border-radius:var(--radius-sm);
  border:1px solid var(--line);
  transition: all .2s;
}
.sponsor-stat:hover{border-color:var(--teal-500); transform:translateY(-2px); box-shadow:var(--shadow-sm)}
.sponsor-stat strong{
  display:block;
  font-family:'Fraunces',serif;
  font-size:32px;
  font-weight:600;
  color:var(--ink-900);
  line-height:1;
  margin-bottom:6px;
}
.sponsor-stat span{
  font-size:12px;
  color:var(--muted);
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.sponsor-benefits{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:16px;
  margin-bottom:28px;
}
.sponsor-benefit{
  padding:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  transition: all .2s;
  position:relative;
}
.sponsor-benefit:hover{border-color:var(--teal-500); transform:translateY(-2px); box-shadow:var(--shadow-sm)}
.sb-num{
  font-family:'Fraunces',serif;
  font-size:13px;
  font-weight:600;
  color:var(--teal-600);
  letter-spacing:.05em;
  margin-bottom:8px;
}
.sponsor-benefit h4{
  font-family:'Plus Jakarta Sans';
  font-size:16px;
  font-weight:700;
  margin:0 0 6px;
}
.sponsor-benefit p{
  font-size:13.5px;
  color:var(--muted);
  line-height:1.5;
  margin:0;
}

.sponsor-cta{
  padding:16px 22px;
  background:rgba(15,181,166,.06);
  border:1px dashed rgba(15,181,166,.25);
  border-radius:10px;
}
.sponsor-cta p{
  font-size:14px;
  color:var(--muted);
  margin:0;
}
.sponsor-cta strong{color:var(--ink-900)}

@media (max-width:800px){
  .sponsor-stats-bar{grid-template-columns: repeat(2, 1fr)}
  .sponsor-benefits{grid-template-columns: 1fr}
}
@media (max-width:500px){
  .sponsor-stats-bar{grid-template-columns: 1fr}
}

/* ============================================================
   ─── CONFERENCIAS EN INFOGRAFÍA ───
   ============================================================ */
.infografia-conferences{
  background: linear-gradient(135deg, #F4F9FE 0%, #EDF5FC 100%);
  border:1px solid rgba(28,67,128,.12);
  border-radius: var(--radius);
  padding:32px;
  margin-top:24px;
}
.conf-topics-grid{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.conf-topic{
  display:grid;
  grid-template-columns: 40px 1fr;
  gap:16px;
  padding:18px 20px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  transition: all .2s;
}
.conf-topic:hover{border-color:var(--teal-500); box-shadow:var(--shadow-sm)}
.conf-topic.featured{
  background: linear-gradient(135deg, rgba(15,181,166,.06), rgba(46,155,107,.06));
  border-color:rgba(15,181,166,.25);
}
.ct-num{
  font-family:'Fraunces',serif;
  font-size:18px;
  font-weight:600;
  color:var(--teal-600);
  text-align:center;
  padding-top:2px;
}
.ct-body{}
.ct-eye{
  font-size:11px;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:4px;
  display:block;
}
.ct-body h5{
  font-family:'Fraunces',serif;
  font-size:17px;
  font-weight:600;
  color:var(--ink-900);
  margin:0 0 4px;
  line-height:1.25;
}
.ct-body p{
  font-size:13.5px;
  color:var(--muted);
  line-height:1.5;
  margin:0;
}
.ct-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
}
.ct-tags span{
  font-size:11px;
  font-weight:600;
  letter-spacing:.06em;
  padding:4px 10px;
  background:rgba(15,181,166,.08);
  color:var(--teal-600);
  border-radius:999px;
  border:1px solid rgba(15,181,166,.15);
}

/* Space card s6 (Proyección financiera) */
.space-card.s6::before{background:var(--green-600)}
.space-card.s6 .space-ico{background:rgba(46,155,107,.12); color:var(--green-700)}

@media(max-width:600px){
  .conf-topic{grid-template-columns:1fr}
  .ct-num{text-align:left; font-size:14px}
}
