.page{max-width:1100px;margin:0 auto;padding:18px 14px 40px}
.head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin:10px 0 14px}
.head h1{margin:0;font-size:38px;letter-spacing:-.02em}
.muted{opacity:.72}
.head-actions{display:flex;gap:10px;flex-wrap:wrap}

.panel{background:#fff;border:1px solid rgba(15,23,42,.14);border-radius:18px;padding:14px;box-shadow:0 6px 24px rgba(2,6,23,.06);margin:12px 0}
.filters{display:grid;grid-template-columns:1.4fr .8fr .7fr auto;gap:12px;align-items:end}
.filters .f{display:flex;flex-direction:column;gap:6px}
.filters .right{justify-self:end}

input,select,textarea{
  width:100%;
  border:1px solid rgba(15,23,42,.14);
  border-radius:14px;
  padding:12px 12px;
  font:inherit;
  outline:none;
  transition:box-shadow .15s ease,border-color .15s ease,transform .15s ease;
  background:#fff;
}
textarea{resize:vertical;min-height:120px}
input:focus,select:focus,textarea:focus{
  border-color:rgba(15,23,42,.22);
  box-shadow:0 0 0 4px rgba(2,6,23,.06);
}

.list{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:12px}
.card{
  border:1px solid rgba(15,23,42,.14);
  border-radius:18px;
  padding:12px;
  background:#fff;
  box-shadow:0 6px 22px rgba(2,6,23,.04);
  display:flex;
  flex-direction:column;
  gap:10px;
  overflow:hidden;
}
.card h3{margin:0;font-size:15px}
.card .meta{display:flex;gap:8px;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:999px;
  background:rgba(15,23,42,.06);
  border:1px solid rgba(15,23,42,.12);
  font-size:12px;
  opacity:.92;
}
.preview{
  font-size:12px;line-height:1.35;
  opacity:.78;
  white-space:pre-wrap;
  max-height:120px;
  overflow:auto;
  border:1px dashed rgba(15,23,42,.14);
  border-radius:14px;
  padding:10px;
}
.actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}

.empty{padding:26px;text-align:center}
.empty-title{font-weight:900;font-size:16px;margin-bottom:6px}

/* ============================================================
   MODAL — siempre arriba (y scrollea adentro)
============================================================ */
.modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:9999;
}
.modal.open{display:block}

.modal .overlay{
  position:fixed;
  inset:0;
  background:rgba(2,6,23,.45);
  backdrop-filter: blur(6px);
  z-index:10000;
}

.modal .dialog{
  position:relative;
  z-index:10001;

  width:min(920px, calc(100vw - 24px));
  max-height:calc(100vh - 24px);
  margin:12px auto;

  background:#fff;
  border:1px solid rgba(15,23,42,.14);
  border-radius:20px;
  box-shadow:0 30px 80px rgba(2,6,23,.35);

  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.m-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-bottom:1px solid rgba(15,23,42,.10);
  background:#fff;
}
.m-title{font-size:16px;font-weight:900}
.m-body{padding:14px;overflow:auto}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.span2{grid-column:1 / -1}

.m-foot{
  padding:14px;
  border-top:1px solid rgba(15,23,42,.10);
  display:flex;
  gap:10px;
  align-items:center;
  background:#fff;
}
.m-foot .spacer{flex:1}

.btn.danger{border-color:rgba(220,38,38,.25)!important;color:rgb(185,28,28)!important}
.btn.danger:hover{background:rgba(220,38,38,.06)!important}

@media (max-width: 920px){
  .list{grid-template-columns:repeat(2,minmax(0,1fr))}
  .filters{grid-template-columns:1fr 1fr}
  .filters .right{justify-self:stretch}
}
@media (max-width: 560px){
  .head{flex-direction:column;align-items:stretch}
  .filters{grid-template-columns:1fr}
  .list{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
}
/* =====================================================
   NAV 5B — FIX MOBILE (CELULAR)
===================================================== */
@media (max-width: 768px){

  /* ---------- Header ---------- */
  .masthead{
    padding: 8px 12px;
  }

  .masthead .brand{
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .masthead .logo{
    width: 44px;
    height: auto;
  }

  .masthead .titles{
    line-height: 1.1;
  }

  .masthead .title{
    font-size: 15px;
    font-weight: 800;
  }

  .masthead .subtitle{
    font-size: 12px;
    color: #666;
  }

  .masthead .api-status{
    font-size: 11px;
    padding: 4px 8px;
    border-radius: 999px;
  }

  /* ---------- Nav principal ---------- */
  #topnav{
    position: sticky;
    top: 0;
    z-index: 50;
    background: #fff;
    border-bottom: 1px solid rgba(0,0,0,.1);
  }

  #topnav .inner{
    overflow-x: auto;
  }

  #navList{
    display: flex;
    flex-direction: row;
    gap: 6px;
    padding: 8px 6px;
    white-space: nowrap;
  }

  #navList li{
    flex: 0 0 auto;
  }

  #navList a{
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 10px;
    font-size: 13px;
    border-radius: 12px;
  }

  #navList a span{
    display: none; /* texto largo fuera */
  }

  #navList a i,
  #navList a svg{
    font-size: 18px;
  }

  /* ---------- Activo ---------- */
  #navList a.active{
    background: rgba(245,196,0,.25);
    font-weight: 800;
  }

}
