/* ============================================================
   Layout y componentes del directorio
   ============================================================ */

/* ---- Barra superior / menu ---- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: var(--gradient-navy); color: #fff;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  padding: 10px 24px; box-shadow: var(--shadow);
}
/* Izquierda: logo Ley de Ajuste · Centro: MVC · Derecha: menú */
.topbar .brand { justify-self: start; display: flex; align-items: center; text-decoration: none; }
.topbar .brand .bar-flag { height: 130px; width: auto; object-fit: contain; display: block; }
.topbar .bar-logos { justify-self: center; display: flex; align-items: center; text-decoration: none; }
.topbar .bar-logos .bar-logo { height: 120px; width: auto; display: block; }
.topbar nav { justify-self: end; }
.topbar nav { display: flex; gap: 10px; align-items: center; }
.topbar nav a, .topbar nav button {
  color: #fff; text-decoration: none; font-family: var(--font-heading);
  font-weight: 700; font-size: 14px; padding: 9px 16px; border-radius: var(--radius-sm);
  border: 1.5px solid rgba(255,255,255,.25); background: transparent; cursor: pointer;
}
.topbar nav a.cta { background: var(--gradient-gold); color: var(--color-navy-deep); border: none; }
.topbar nav a:hover { background: rgba(255,255,255,.12); }
.topbar nav a.cta:hover { box-shadow: var(--shadow-glow-gold); }

/* ---- Hero ---- */
.hero {
  background: var(--gradient-navy); color: #fff;
  padding: 24px 24px 72px; text-align: center;
}
.hero-logos {
  display: flex; align-items: center; justify-content: center;
  gap: 10px; margin: 0 auto 18px; flex-wrap: wrap;
}
.hero-logos .logo-mvc { width: min(150px, 45vw); height: auto; }
.hero-logos .logo-vzla { width: 40px; height: 40px; object-fit: contain; }
.hero h1 { color: #fff; font-size: clamp(28px, 5vw, 46px); margin: 0 0 14px; }
.hero h1 .accent { color: var(--color-gold-light); }
.hero p { max-width: 720px; margin: 0 auto 26px; font-size: 18px; opacity: .92; }
.hero .actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---- Contenedor ---- */
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.section { padding: 56px 0; }
.section h2 { font-size: 28px; text-align: center; margin: 0 0 8px; }
.section .sub { text-align: center; color: var(--color-gray-600); margin: 0 0 36px; }

/* ---- Grilla de logos de ONG ---- */
.org-grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
}
.org-card {
  background: #fff; border: 1px solid var(--color-gray-100); border-radius: var(--radius);
  padding: 22px 16px; text-align: center; cursor: pointer; text-decoration: none;
  color: inherit; box-shadow: var(--shadow-sm); transition: transform .12s ease, box-shadow .2s ease;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.org-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.org-card .logo-box {
  width: 96px; height: 96px; border-radius: 12px; background: var(--color-gray-50);
  display: grid; place-items: center; overflow: hidden; border: 1px solid var(--color-gray-100);
}
.org-card .logo-box img { width: 100%; height: 100%; object-fit: contain; }
.org-card .logo-box .ph {
  font-family: var(--font-heading); font-weight: 900; font-size: 30px; color: var(--color-navy-lav);
}
.org-card .name { font-family: var(--font-heading); font-weight: 700; font-size: 15px; color: var(--color-navy); }
.org-card .loc { font-size: 12px; color: var(--color-gray-600); }
.empty-state { text-align: center; color: var(--color-gray-600); padding: 40px 0; }

/* ---- Formularios centrados (login/registro) ---- */
.auth-wrap { max-width: 520px; margin: 40px auto; padding: 0 20px; }
.auth-card { padding: 34px 30px; }

/* Formulario de registro ancho (2 columnas) — la ficha es la única vertical */
.reg-wrap { max-width: 920px; margin: 36px auto; padding: 0 20px; }
.reg-card { padding: 34px 38px; }
.reg-card h2 { text-align: center; margin: 0 0 4px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 24px; }
.form-grid .full { grid-column: 1 / -1; }
@media (max-width: 680px) { .form-grid { grid-template-columns: 1fr; } }
.auth-card h2 { text-align: center; margin: 0 0 6px; }
.auth-card .sub { text-align: center; color: var(--color-gray-600); margin: 0 0 24px; font-size: 14px; }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ein-status { font-size: 13px; margin-top: 6px; min-height: 18px; }
.ein-status.ok { color: var(--color-teal-dark); font-weight: 600; }
.ein-status.bad { color: var(--color-error); font-weight: 600; }

/* ---- Ficha publica (formato VERTICAL / retrato 9:16 para redes) ---- */
.ficha { max-width: 460px; margin: 36px auto; padding: 0 20px; }
.ficha-head {
  background: var(--gradient-navy); color: #fff; border-radius: var(--radius) var(--radius) 0 0;
  padding: 30px; display: flex; flex-direction: column; gap: 16px; align-items: center; text-align: center;
}
.ficha-head .logo-box {
  width: 130px; height: 130px; border-radius: 14px; background: transparent; flex: none;
  display: grid; place-items: center; overflow: hidden;
}
.ficha-head .logo-box img { width: 100%; height: 100%; object-fit: contain; }
.ficha-head .logo-box .ph { font-family: var(--font-heading); font-weight: 900; font-size: 44px; color: #fff; }
.ficha-head h1 { color: #fff; margin: 0 0 6px; font-size: 26px; }
.ficha-body { background: #fff; border-radius: 0 0 var(--radius) var(--radius); box-shadow: var(--shadow); padding: 28px 30px; }
.data-grid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 8px; }
.data-item .k { font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--color-gray-600); font-weight: 700; }
.data-item .v { font-size: 16px; color: var(--color-gray-900); }
.centros { margin-top: 26px; }
.centros h3 { margin: 0 0 14px; font-size: 18px; }
.centro {
  border: 1px solid var(--color-gray-100); border-left: 4px solid var(--color-teal);
  border-radius: var(--radius-sm); padding: 14px 16px; margin-bottom: 12px; background: var(--color-gray-50);
}
.centro .cn { font-family: var(--font-heading); font-weight: 700; color: var(--color-navy); }
.centro .cd { font-size: 14px; color: var(--color-gray-800); }
.centro .ch { font-size: 13px; color: var(--color-teal-dark); font-weight: 600; margin-top: 4px; }

/* ---- Panel ---- */
.panel-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
.panel-card { padding: 24px; }
.panel-card h3 { margin: 0 0 16px; }
.logo-upload { display: flex; align-items: center; gap: 16px; margin-bottom: 18px; }
.logo-upload .prev { width: 80px; height: 80px; border-radius: 12px; border: 1px solid var(--color-gray-200); object-fit: contain; background: #fff; }

/* ---- Footer ---- */
.foot { background: var(--color-navy-deep); color: rgba(255,255,255,.75); text-align: center; padding: 28px 20px; font-size: 13px; }
.foot b { color: var(--color-gold-light); }

@media (max-width: 640px) {
  .row2, .data-grid { grid-template-columns: 1fr; }
  .ficha-head { flex-direction: column; text-align: center; }
  .topbar { padding: 10px 14px; }
  .topbar .brand small { display: none; }
}
