:root{
  --bg:#f6f8fb; --ink:#101418; --muted:#555;
  --card:#fff; --card2:#f1f3f6; --sep:rgba(0,0,0,.12);
  --accent:#d07b00; --radius:16px; --shadow:0 6px 16px rgba(0,0,0,.12);

  /* tabla */
  --thead:#fafbff; --row:#ffffff; --rowAlt:#fcfdff;
  --cell:#e9edf3; --hover:#f6f9ff;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Arial,sans-serif
}
.wrap{max-width:1100px;margin:28px auto;padding:0 16px}
h1{margin:0 0 14px;font-weight:800}
.sub{color:var(--muted);margin:0 0 16px}

/* Grid principal */
.grid{display:grid;gap:12px}
@media(min-width:1000px){.grid{grid-template-columns:1fr 1fr}}

.card{
  background:var(--card);border:1px solid var(--sep);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:12px
}
.card h2{margin:0 0 8px;font-size:1.02rem}

.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:6px 0}

/* Campos superiores (Momento / Orbe) */
.form-grid{
  display:grid;
  grid-template-columns: 1fr 160px;
  gap:12px; margin-bottom:10px;
}
.form-grid .lbl{display:block;font-weight:700;margin:0 0 6px;color:var(--muted)}
input[type="text"],input[type="number"]{
  width:100%;
  background:var(--card2);color:var(--ink);border:1px solid var(--sep);
  border-radius:10px;padding:10px;min-height:40px
}

/* Área de pegado */
textarea{
  width:100%;min-height:150px;background:var(--card2);color:var(--ink);
  border:1px solid var(--sep);border-radius:12px;padding:10px;
  font-family:ui-monospace,Consolas,monospace; font-size:14px;
}

/* Check inclusión */
.chk{display:flex;align-items:center;gap:8px;margin:0 0 8px}

/* Botones */
.btn{
  background:var(--accent);color:#1a1200;border:0;border-radius:12px;
  padding:10px 14px;font-weight:800;cursor:pointer;box-shadow:var(--shadow)
}
.btn:hover{filter:brightness(1.05)}
.btn.gold{
  background: var(--accent); color:#1a1200; text-decoration:none; display:inline-flex; align-items:center; justify-content:center
}
.actions{display:flex;gap:10px;margin:12px 0;flex-wrap:wrap}
.small{font-size:.85rem;color:var(--muted)}
.muted{color:var(--muted)}
.tag{display:inline-block;background:#ececec;border:1px solid var(--sep);
  padding:3px 7px;border-radius:999px;font-size:.78rem;color:#333}

/* Bloque con botón lateral (desktop) */
.block-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 220px;
  gap:12px; align-items:start;
}
.block-grid .right{display:flex;flex-direction:column}
.wfull{width:100%}

/* Tabla “moderna”: separadores verticales suaves + zebra + hover */
.table{overflow:auto;border:1px solid var(--sep);border-radius:12px;background:#fff}
.table table{width:100%;border-collapse:separate;border-spacing:0}
.table thead th{
  background:var(--thead); position:sticky; top:0;
  border-bottom:1px solid var(--cell);
  font-weight:800; text-align:left; padding:10px 12px
}
.table tbody td{
  padding:9px 12px; border-bottom:1px solid var(--cell);
  background:var(--row)
}
.table tbody tr:nth-child(even) td{ background:var(--rowAlt) }
.table tbody tr:hover td{ background:var(--hover) }
/* separadores verticales (no en la 1ª col) */
.table td + td, .table th + th{ border-left:1px solid var(--cell) }

/* Tablas compactas de diagnóstico */
.det-table{width:100%;border-collapse:collapse}
.det-table th,.det-table td{padding:6px 8px;border-bottom:1px solid var(--sep);text-align:left}
.det-table th{font-weight:800}

/* Botonera segmentada para filtros */
.seg{display:inline-flex;gap:6px;flex-wrap:wrap}
.seg-btn{
  border:1px solid var(--sep);background:var(--card2);color:var(--ink);
  padding:6px 10px;border-radius:999px;cursor:pointer;font-weight:700
}
.seg-btn.is-active{background:var(--accent);color:#1a1200;border-color:transparent}

/* Bloque diagnóstico (?debug=1) */
.diag{margin:10px 0;padding:14px;border:2px dashed #d9a84a;border-radius:12px;background:#fff9e8}

/* ---------- Responsive ---------- */
@media (max-width: 860px){
  .form-grid{ grid-template-columns: 1fr } /* Momento/Orbe en dos filas */
}
@media (max-width: 720px){
  .block-grid{ grid-template-columns: 1fr } /* botón debajo del textarea */
  .block-grid .right{ order:2 }
  .block-grid .left{ order:1 }
  textarea{ min-height:220px }
}