/* EducaRommel — style.css */
:root{
  --bg:#0b1020;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.09);
  --text:#eaf0ff;
  --muted: rgba(234,240,255,.75);
  --brand1:#1e40af;
  --brand2:#7c3aed;
  --good:#16a34a;
  --warn:#f59e0b;
  --bad:#ef4444;
  --shadow: 0 12px 40px rgba(0,0,0,.25);
  --radius: 18px;
  --radius2: 22px;
  --container: 1120px;
}

/* Light theme */
[data-theme="light"]{
  --bg:#f7f8ff;
  --panel: rgba(15,23,42,.06);
  --panel2: rgba(15,23,42,.08);
  --text:#0b1020;
  --muted: rgba(15,23,42,.7);
  --shadow: 0 10px 34px rgba(15,23,42,.12);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background: radial-gradient(1000px 500px at 10% 0%, rgba(124,58,237,.25), transparent 55%),
              radial-gradient(900px 600px at 80% 10%, rgba(30,64,175,.25), transparent 60%),
              var(--bg);
  color:var(--text);
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{max-width:var(--container); margin:0 auto; padding:0 18px}
.section{padding:34px 0}

.muted{color:var(--muted)}
.small{font-size:.88rem}

.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(10,16,32,.6);
  border-bottom:1px solid rgba(255,255,255,.08);
}
[data-theme="light"] .site-header{
  background: rgba(247,248,255,.75);
  border-bottom:1px solid rgba(15,23,42,.1)
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px 0
}
.brand{display:flex; align-items:center; gap:10px}

/* Badge antiguo ER (si ya usas imagen, esto no se usa, pero no estorba) */
.brand-badge{
  width:40px; height:40px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg,var(--brand1),var(--brand2));
  box-shadow: var(--shadow);
  font-weight:800;
}

.brand-text{font-weight:800; letter-spacing:.2px}

.nav{display:flex; align-items:center; gap:16px}
.nav-link{opacity:.88; padding:10px 10px; border-radius:12px}
.nav-link:hover{opacity:1; background:var(--panel)}
.nav-link.active{background:var(--panel2); opacity:1}
.nav-actions{display:flex; gap:10px; margin-left:6px}

.icon-btn{border:0; background:transparent; color:inherit; cursor:pointer}
.pill{
  border:1px solid rgba(255,255,255,.15);
  background:var(--panel);
  padding:9px 12px;
  border-radius:999px;
  font-weight:600;
}
.pill:hover{background:var(--panel2)}

.mobile-toggle{display:none}
.burger{
  display:block;
  width:22px; height:2px;
  background:currentColor;
  position:relative
}
.burger::before,.burger::after{
  content:"";
  position:absolute; left:0;
  width:22px; height:2px;
  background:currentColor
}
.burger::before{top:-7px}
.burger::after{top:7px}

/* ===== HERO (general) ===== */
.hero{padding:22px 0 6px}

/* Botones */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:11px 14px; border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: var(--panel);
  font-weight:700; cursor:pointer;
}
.btn:hover{background:var(--panel2)}
.btn.primary{background: linear-gradient(135deg,var(--brand1),var(--brand2)); border:0}
.btn.primary:hover{filter:saturate(1.05) brightness(1.02)}
.btn.ghost{background:transparent}
.btn.light{background: rgba(255,255,255,.9); color:#0b1020; border:0}
.btn.light:hover{background:#fff}
.btn.small{padding:7px 10px; border-radius:12px; font-weight:700}
.btn.danger{background: rgba(239,68,68,.14); border:1px solid rgba(239,68,68,.35)}

.regimen{margin-top:14px; display:flex; align-items:center; gap:10px; flex-wrap:wrap}
.seg{
  border:1px solid rgba(255,255,255,.18);
  background:transparent;
  color:inherit;
  padding:7px 11px;
  border-radius:999px;
  cursor:pointer;
  font-weight:700
}
.seg[aria-pressed="true"]{background: var(--panel2)}

.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:10px;
  margin-bottom:14px
}
.section-head h3,.section-head h1{margin:0}
.link{color:rgba(234,240,255,.92); font-weight:700}
[data-theme="light"] .link{color: rgba(15,23,42,.9)}

.grid{display:grid; gap:14px}
.grid.cards{grid-template-columns: repeat(4, minmax(0,1fr))}
.card{
  display:flex; gap:12px; align-items:flex-start;
  padding:16px; border-radius:var(--radius);
  background: var(--panel);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  transition: transform .18s ease, background .18s ease;
}
.card:hover{transform: translateY(-3px); background: var(--panel2)}
.card-icon{
  font-size:1.4rem;
  width:44px; height:44px;
  border-radius:16px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(30,64,175,.35), rgba(124,58,237,.25));
}
.card h4{margin:0 0 6px}
.card p{margin:0}

.grid.news{grid-template-columns: repeat(3, minmax(0,1fr))}
.news-item{
  padding:16px; border-radius:var(--radius);
  background: var(--panel);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.news-item h4{margin:0 0 8px}
.news-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-top:10px
}

.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px;
  border-radius:999px;
  background: var(--panel2);
  border:1px solid rgba(255,255,255,.12);
  font-weight:700;
  font-size:.86rem
}

.note{
  margin-top:16px;
  padding:14px 14px;
  border-radius:var(--radius);
  background: rgba(245,158,11,.10);
  border:1px solid rgba(245,158,11,.25);
}

.cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px;
  border-radius:var(--radius2);
  background: linear-gradient(135deg, rgba(2,132,199,.22), rgba(30,64,175,.18));
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.cta.small{padding:14px}

.page-head{margin-bottom:14px}
.page-head h1{margin:0 0 6px}

.stack{display:grid; gap:14px}
.post{
  padding:18px;
  border-radius:var(--radius2);
  background: var(--panel);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow)
}
.post h2{margin:0 0 8px}
.post-content{line-height:1.6}
.post-content p{margin:10px 0}

.site-footer{
  margin-top:26px;
  padding:28px 0 18px;
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(10,16,32,.55);
  backdrop-filter: blur(10px)
}
[data-theme="light"] .site-footer{
  background: rgba(247,248,255,.78);
  border-top:1px solid rgba(15,23,42,.1)
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.3fr .7fr .7fr;
  gap:16px
}
.footer-links{
  list-style:none;
  padding:0;
  margin:10px 0 0;
  display:grid;
  gap:8px
}
.footer-links a{opacity:.9}
.footer-links a:hover{opacity:1}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding-top:14px;
  margin-top:14px;
  border-top:1px solid rgba(255,255,255,.08)
}
.footer-badges{display:flex; gap:8px; flex-wrap:wrap; margin-top:12px}

/* Modal */
.modal{position:fixed; inset:0; display:none; z-index:80}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute; inset:0; background: rgba(0,0,0,.55)}
.modal-card{
  position:relative;
  margin:10vh auto 0;
  max-width:560px;
  background: var(--bg);
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  overflow:hidden
}
.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 16px;
  background: var(--panel)
}
.modal-body{padding:16px}

/* ===== ✅ MEJORA: HERO FULL WIDTH (banner ocupa TODO) ===== */
.hero-full { padding: 22px 0 10px; }
.hero-fullwidth { width: 100%; margin: 0; }

/* Barra inferior (botones + régimen) */
.hero-underbar{
  margin-top: 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding:16px;
  border-radius: var(--radius2);
  background: linear-gradient(135deg, rgba(30,64,175,.18), rgba(124,58,237,.12));
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.hero-underbar-left{ min-width: 220px; }
.hero-title{
  margin:0;
  font-size: 1.4rem;
  line-height: 1.1;
}
.hero-subtitle{ margin:6px 0 0; }
.hero-underbar-right{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap}

/* Responsive */
@media (max-width: 980px){
  .grid.cards{grid-template-columns: repeat(2, minmax(0,1fr))}
  .grid.news{grid-template-columns: repeat(2, minmax(0,1fr))}
}
@media (max-width: 720px){
  .mobile-toggle{display:inline-flex}
  .nav{
    position:fixed;
    left:0; right:0;
    top:66px;
    padding:12px 16px;
    display:none;
    flex-direction:column;
    gap:6px;
    background: rgba(10,16,32,.92);
    border-bottom:1px solid rgba(255,255,255,.08)
  }
  [data-theme="light"] .nav{background: rgba(247,248,255,.95)}
  .nav.open{display:flex}
  .nav-actions{width:100%; justify-content:space-between; margin-top:6px}
  .grid.cards{grid-template-columns: 1fr}
  .grid.news{grid-template-columns: 1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column; align-items:flex-start}
  .hero-underbar-right{ align-items:flex-start; width:100%; }
  .hero-underbar-left{ width:100%; }
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .card{transition:none}
}
:focus-visible{
  outline:2px solid rgba(124,58,237,.65);
  outline-offset:3px;
  border-radius:12px
}

/* ================================
   ✅ LOGO CON IMAGEN EN NAVBAR (ÚNICO)
================================ */
.brand-logo{
  width:40px;
  height:40px;
  border-radius:999px;      /* circular */
  object-fit: cover;         /* recorte limpio */
  object-position:center;    /* centrado */
  border: 2px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  box-shadow: var(--shadow);
}
[data-theme="light"] .brand-logo{
  border: 2px solid rgba(15,23,42,.12);
  background: rgba(15,23,42,.04);
}
/* Logo un poco más grande solo en el footer */
.footer-brand .brand-logo{
  width:44px;
  height:44px;
}
/* MODAL POST */
.modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999;
}

.modal[aria-hidden="false"]{
  display:flex;
}

.modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.6);
}

.modal-card{
  position:relative;
  width:90%;
  max-width:800px;
  background:#111827;
  border-radius:16px;
  padding:20px;
  z-index:2;
  color:white;
  max-height:90vh;
  overflow:auto;
}

.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
}

.modal-head button{
  background:none;
  border:none;
  font-size:20px;
  cursor:pointer;
  color:white;
}
/* ===============================
✨ BLOQUE BUSCADOR + CONSULTAS PRO
=============================== */

.hero-underbar{
  background: linear-gradient(
    135deg,
    rgba(124,58,237,.25),
    rgba(30,64,175,.25)
  );
  border-radius: 20px;
  padding: 22px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
}

/* GRID PARA ORDENAR */
.hero-underbar{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

/* COLUMNA IZQUIERDA */
.hero-underbar-left{
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* INPUT BUSCADOR */
#smartSearchInput{
  width:100%;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.05);
  color:var(--text);
}

/* RESULTADOS */
#smartSearchResults{
  margin-top:6px;
  border-radius:12px;
  overflow:hidden;
}

/* CONSULTAS BOTÓN */
.consultas-btn{
  border-radius:999px;
  padding:10px 16px;
  font-weight:700;
  background: linear-gradient(135deg,#1e40af,#7c3aed);
  color:white;
  border:none;
  box-shadow: 0 6px 18px rgba(0,0,0,.3);
}

/* HOVER */
.consultas-btn:hover{
  transform:translateY(-2px);
}

/* MENÚ MÁS MODERNO */
.consultas-menu{
  border-radius:16px;
  animation:fadeIn .2s ease;
}

@keyframes fadeIn{
  from{
    opacity:0;
    transform: translateY(10px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}

/* DERECHA → NOTICIA DESTACADA */
.hero-underbar-right{
  padding:16px;
  border-radius:16px;
  background: rgba(255,255,255,.05);
}

/* TITULO NOTICIA */
.hero-underbar-right h4{
  margin-bottom:10px;
}

/* ===============================
📱 RESPONSIVE
=============================== */
@media (max-width: 768px){
  .hero-underbar{
    grid-template-columns:1fr;
  }
}
/* =========================
✅ CONSULTAS ARREGLADO
========================= */

.consultas {
  position: relative;
  display: inline-block;
  z-index: 300;
}

/* MENÚ LIMPIO */
.consultas-menu {
  position: absolute;
  top: 120%;
  left: 0;

  display: none;

  min-width: 240px;
  padding: 12px;

  border-radius: 14px;
  background: #111827;

  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 12px 30px rgba(0,0,0,.4);

  z-index: 9999;
}

/* ACTIVAR */
.consultas-menu.open {
  display: block;
}

/* ITEMS */
.consultas-menu a {
  display: block;
  padding: 10px;
  border-radius: 10px;
}
/* ✅ CONSULTAS AJUSTADO FINAL */

.consultas-menu {
  position: absolute;

  top: 100%;
  margin-top: 4px; /* 🔥 clave para que no se monte */
  left: 0;

  display: none;

  width: 200px; /* 👈 más pequeño = menos invasivo */
  padding: 6px;

  border-radius: 12px;

  background: linear-gradient(
    135deg,
    rgba(30,64,175,.95),
    rgba(124,58,237,.95)
  );

  border: 1px solid rgba(255,255,255,.2);
  box-shadow: 0 8px 20px rgba(0,0,0,.3);

  z-index: 9999;
}
/* ===== Modal institucional PRO (ÚNICO) ===== */
.inst-modal{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
}
.inst-modal[aria-hidden="false"]{ display: flex; }

.inst-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.65);
}

/* Caja */
.inst-card{
  position: relative;
  width: min(900px, 92vw);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(15,23,42,.96);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 55px rgba(0,0,0,.55);
  animation: instIn .25s ease;
}

@keyframes instIn{
  from{ opacity: 0; transform: scale(.96); }
  to{ opacity: 1; transform: scale(1); }
}

/* Header */
.inst-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: rgba(255,255,255,.06);
}

/* Slides */
.inst-slider{ position: relative; }
.inst-slide{ display: none; position: relative; }
.inst-slide.active{ display: block; }

.inst-slide img{
  width: 100%;
  height: auto;
  display: block;
}

/* Botón del banner */
.inst-cta{
  position: absolute;
  right: 16px;
  bottom: 16px;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 900;
  color: #fff;
  background: linear-gradient(135deg,#1e40af,#7c3aed);
  box-shadow: 0 10px 25px rgba(0,0,0,.35);
  text-decoration: none;
}

/* Footer */
.inst-footer{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: rgba(255,255,255,.06);
}

.inst-check{
  font-size: .92rem;
  color: rgba(234,240,255,.85);
}

.inst-dots{
  display: flex;
  gap: 8px;
  align-items: center;
}

.inst-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.18);
  cursor: pointer;
}

.inst-dot.active{ background: #fff; }

/* ✅ Responsive: botón más cómodo en móvil */
@media (max-width: 520px){
  .inst-cta{
    right: 12px;
    bottom: 12px;
    padding: 9px 14px;
    font-size: .95rem;
  }
}
/* ✅ FIX: asegurar que las tarjetas del admin sean clickeables */
.admin-grid { position: relative; z-index: 1; }
.admin-tile { display: block; position: relative; z-index: 2; cursor: pointer; pointer-events: auto; }
/* Imagen clickeable */
.inst-image-link { display:block; cursor:pointer; }

/* Footer derecha: Cerrar + dots */
.inst-footer-right{
  display:flex;
  align-items:center;
  gap:10px;
}

/* Botón Cerrar dentro del modal */
.inst-footer .btn.small{
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: rgba(234,240,255,.95);
  font-weight:800;
}
.inst-footer .btn.small:hover{
  background: rgba(255,255,255,.14);
}
/* ===== Tarjeta tipo Quito Informa (EducaRommel) ===== */
.post-card{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.post-card__link{ display:block; color:inherit; text-decoration:none; }
.post-card__img{ width:100%; height:180px; object-fit:cover; display:block; }
.post-card__body{ padding:12px 14px 16px; }
.post-card__tag{ font-size:.85rem; opacity:.85; margin-bottom:6px; }
.post-card__title{ margin:0 0 8px; font-weight:900; }
.post-card__excerpt{ margin:0 0 10px; opacity:.9; }
.post-card__meta{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.post-card__read{ font-weight:800; opacity:.9; }

.post-card__actions{
  position:absolute;
  right:10px;
  bottom:10px;
  display:flex;
  gap:8px;
  z-index:5;
}
.icon-action{
  width:36px; height:36px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.20);
  background: rgba(10,16,32,.35);
  color: rgba(255,255,255,.95);
  cursor:pointer;
  display:grid;
  place-items:center;
  backdrop-filter: blur(8px);
}
.icon-action:hover{ background: rgba(10,16,32,.55); }
/* ===== Layout noticia/blog con sidebar (tipo Quito Informa) ===== *//* ===== Layout noticia padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}

.sidebar-title{
  font-weight: 900;
  margin: 0 0 10px 0;
}

.sidebar-search{
  display:flex;
  gap: 8px;
}

.sidebar-search input{
  flex:1;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
  color: inherit;
}

.sidebar-search button{
  padding: 10px 12px;
  border-radius: 12px;
  border: 0;
  cursor: pointer;
  font-weight: 900;
  background: rgba(255,255,255,.12);
}

.sidebar-item{
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}

.sidebar-item:first-child{
  border-top: 0;
  padding-top: 0;
}

.sidebar-thumb{
  width: 64px;
  height: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
}

.sidebar-link{
  font-weight: 800;
  line-height: 1.15;
}

.sidebar-meta{
  font-size: .85rem;
  opacity: .8;
  margin-top: 2px;
}

.sidebar-list a{
  display:block;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .92;
}
.sidebar-list a:first-child{ border-top: 0; padding-top: 0; }

/* Responsive */
@media (max-width: 980px){
  .content-with-sidebar{
    grid-template-columns: 1fr;
  }
  .sidebar{
    position: static;
  }
}
.content-with-sidebar{
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 18px;
  align-items: start;
}

.sidebar{
  position: sticky;
  top: 86px; /* header sticky + margen */
  display: grid;
  gap: 12px;
}

.sidebar-box{
/* ===== Layout con sidebar (tipo Quito Informa) ===== */
.content-with-sidebar{
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 18px;
  align-items: start;
}
.sidebar{
  position: sticky;
  top: 86px;
  display: grid;
  gap: 12px;
}
.sidebar-box{
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.sidebar-title{ font-weight: 900; margin: 0 0 10px; }
.sidebar-search{ display:flex; gap: 8px; }
.sidebar-search input{
  flex:1;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
  color: inherit;
}
.sidebar-search button{
  padding: 10px 12px;
  border-radius: 12px;
  border: 0;
  cursor: pointer;
  font-weight: 900;
  background: rgba(255,255,255,.12);
}
.sidebar-item{
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sidebar-item:first-child{ border-top: 0; padding-top: 0; }
.sidebar-thumb{
  width: 64px;
  height: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
}
.sidebar-link{ font-weight: 800; line-height: 1.15; }
.sidebar-meta{ font-size: .85rem; opacity: .8; margin-top: 2px; }
.sidebar-list a{
  display:block;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .92;
}
.sidebar-list a:first-child{ border-top: 0; padding-top: 0; }

/* Responsive */
@media (max-width: 980px){
  .content-with-sidebar{ grid-template-columns: 1fr; }
  .sidebar{ position: static; }
}
.content-with-sidebar{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}
.sidebar{position:sticky;top:86px;display:grid;gap:12px}
.sidebar-box{padding:14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10)}
.sidebar-title{font-weight:900;margin:0 0 10px}
.sidebar-search{display:flex;gap:8px}
.sidebar-search input{flex:1;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.12);color:inherit}
.sidebar-search button{padding:10px 12px;border-radius:12px;border:0;cursor:pointer;font-weight:900;background:rgba(255,255,255,.12)}
.sidebar-item{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:center;padding:8px 0;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-item:first-child{border-top:0;padding-top:0}
.sidebar-thumb{width:64px;height:44px;object-fit:cover;border-radius:10px;border:1px solid rgba(255,255,255,.10)}
.sidebar-link{font-weight:800;line-height:1.15}
.sidebar-meta{font-size:.85rem;opacity:.8;margin-top:2px}
.sidebar-list a{display:block;padding:8px 0;border-top:1px solid rgba(255,255,255,.08);opacity:.92}
.sidebar-list a:first-child{border-top:0;padding-top:0}
@media (max-width:980px){.content-with-sidebar{grid-template-columns:1fr}.sidebar{position:static}}
/* ===== Layout con sidebar (tipo Quito Informa) ===== */
.content-with-sidebar{
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 18px;
  align-items: start;
}

.sidebar{
  position: sticky;
  top: 86px;
  display: grid;
  gap: 12px;
}

.sidebar-box{
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}

.sidebar-title{ font-weight: 900; margin: 0 0 10px; }

.sidebar-search{ display:flex; gap: 8px; }
.sidebar-search input{
  flex: 1;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
  color: inherit;
}
.sidebar-search button{
  padding: 10px 12px;
  border-radius: 12px;
  border: 0;
  cursor: pointer;
  font-weight: 900;
  background: rgba(255,255,255,.12);
}

.sidebar-item{
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sidebar-item:first-child{ border-top: 0; padding-top: 0; }

.sidebar-thumb{
  width: 64px;
  height: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
}

.sidebar-link{ font-weight: 800; line-height: 1.15; }
.sidebar-meta{ font-size: .85rem; opacity: .8; margin-top: 2px; }

.sidebar-list a{
  display:block;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .92;
}
.sidebar-list a:first-child{ border-top: 0; padding-top: 0; }

@media (max-width: 980px){
  .content-with-sidebar{ grid-template-columns: 1fr; }
  .sidebar{ position: static; }
}
.content-with-sidebar{
  display: grid;
  grid-template-template-columns: 64px 1fr;  grid-template-columns: 1fr 320px;
  gap: 10px;
  align-items: center;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sidebar-item:first-child{ border-top: 0; padding-top: 0; }
.sidebar-thumb{
  width: 64px; height: 44px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
}
.sidebar-link{ font-weight: 800; line-height: 1.15; }
.sidebar-meta{ font-size: .85rem; opacity: .8; margin-top: 2px; }
.sidebar-list a{
  display:block;
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .92;
}
.sidebar-list a:first-child{ border-top: 0; padding-top: 0; }

@media (max-width: 980px){
  .content-with-sidebar{ grid-template-columns: 1fr; }
  .sidebar{ position: static; }
}
  gap: 18px;
  align-items: start;
}
.sidebar{
  position: sticky;
  top: 86px;
  display: grid;
  gap: 12px;
}
.sidebar-box{
  padding: 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.sidebar-title{ font-weight: 900; margin: 0 0 10px; }
.sidebar-search{ display:flex; gap: 8px; }
.sidebar-search input{
  flex: 1; padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
  color: inherit;
}
.sidebar-search button{
  padding: 10px 12px;
  border-radius: 12px;
  border: 0;
  cursor: pointer;
  font-weight: 900;
  background: rgba(255,255,255,.12);
}
.sidebar-item{
  display: grid;
/* ===== Bloque de iconos grandes estilo institucional ===== */
.quick-icons{
  background: rgba(255,255,255,.06);
  padding: 26px 0;
}

.quick-icons__grid{
  display:flex;
  flex-wrap:wrap;
  justify-content: center;
  gap: 26px;
}

.quick-icons__item{
  width: 140px;
  text-align:center;
  text-decoration:none;
  color: inherit;
  padding: 14px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.06);
}

.quick-icons__item i{
  font-size: 34px;
  margin-bottom: 10px;
  display:block;
  color: #1e40af;
}

.quick-icons__item span{
  font-weight: 800;
  display:block;
  opacity: .95;
}

.quick-icons__item:hover{
  transform: translateY(-3px);
  transition: .2s;
  border-color: rgba(255,255,255,.25);
}
/* ===== Iconos en el navbar ===== */
.nav-link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.nav-link i{
  font-size: 0.95rem;
  opacity: .95;
}

/* Si quieres que el icono tenga color institucional */
.nav-link i{
  color: #1e40af;
}

/* En dark mode (si tu tema cambia colores) */
body.dark .nav-link i{
  color: #93c5fd;
}
