/* ============================================================
   CARNET — estilos del carnet digital.
   Separado de styles.css a propósito: a futuro cada plan de
   suscripción podrá cargar una hoja de carnet distinta sin
   tocar el resto de la aplicación.
   ============================================================ */

/* ===== CARNET ===== */
.carnet-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 8px;
}
.carnet {
  background: white;
  border: 1px solid var(--gray-200);
  border-radius: 16px;
  padding: 32px;
  max-width: 900px;
  margin: 0 auto;
  color: var(--gray-900);
}
.carnet-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid var(--green-300);
  padding-bottom: 12px;
  margin-bottom: 20px;
}
.carnet-brand { font-size: 18px; }
.carnet-brand span { font-size: 22px; margin-right: 4px; }
.carnet-section { margin-bottom: 24px; }
.carnet-section h2 {
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--gray-500);
  margin: 0 0 12px;
  font-weight: 600;
}
.carnet-mascota {
  display: grid;
  grid-template-columns: 130px 1fr 140px;
  gap: 20px;
  align-items: start;
}
.carnet-photo img,
.carnet-photo-placeholder {
  width: 130px;
  height: 130px;
  border-radius: 12px;
  object-fit: cover;
  border: 1px solid var(--gray-200);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 56px;
  background: var(--gray-50);
}
.carnet-info {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 20px;
}
.carnet-info > div, .carnet-tutor > div {
  display: flex;
  flex-direction: column;
  font-size: 14px;
}
.carnet-info span, .carnet-tutor span {
  font-size: 11px;
  text-transform: uppercase;
  color: var(--gray-500);
  letter-spacing: 0.4px;
}
.carnet-qr-box { text-align: center; }
.carnet-qr-box svg { width: 130px; height: 130px; }
.carnet-tutor {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 20px;
}
.carnet-notes {
  margin-top: 12px;
  padding: 10px 12px;
  background: var(--gray-50);
  border-left: 3px solid var(--green-300);
  border-radius: 4px;
  font-size: 13px;
}
.carnet-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.carnet-table th, .carnet-table td {
  border: 1px solid var(--gray-200);
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}
.carnet-table th {
  background: var(--gray-50);
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.carnet-empty { text-align: center; color: var(--gray-500); padding: 20px; }
.carnet-label-thumb {
  max-width: 90px;
  max-height: 60px;
  object-fit: contain;
  border: 1px solid var(--gray-200);
  border-radius: 4px;
}
.carnet-footer {
  margin-top: 20px;
  padding-top: 12px;
  border-top: 1px solid var(--gray-200);
  font-size: 11px;
  text-align: center;
}

/* ===== RESPONSIVE MOBILE (solo pantalla) ===== */
@media screen and (max-width: 768px) {
  .carnet { padding: 16px; border-radius: 0; border: 0; }
  .carnet-mascota {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .carnet-photo img, .carnet-photo-placeholder { margin: 0 auto; }
  .carnet-qr-box { margin: 0 auto; }
  .carnet-info, .carnet-tutor { grid-template-columns: 1fr; text-align: left; }
  .carnet-table { font-size: 11px; }
  .carnet-table th, .carnet-table td { padding: 6px; }
  .carnet-toolbar { flex-direction: column; align-items: stretch; }
  .carnet-toolbar button { width: 100%; }
}

/* ===== PRINT ===== */
@media print {
  body { background: white; }
  .navbar, .no-print, #view-login, .nav-user, footer, .modal-overlay { display: none !important; }
  .main-content { padding: 0; max-width: none; }
  .view { display: none !important; }
  .view#view-carnet { display: block !important; }
  .carnet {
    border: 0;
    box-shadow: none;
    max-width: none;
    padding: 0;
    margin: 0;
  }
  .carnet-section { page-break-inside: avoid; }
  .carnet-table { page-break-inside: auto; font-size: 10px; }
  .carnet-table th, .carnet-table td { padding: 5px 6px; }
  .carnet-table th { font-size: 9px; }
  .carnet-label-thumb { max-width: 64px; max-height: 44px; }
  a[href]::after { content: ''; }
}
