.vaccine-card-page {
  display: grid;
  gap: 18px;
  padding: 0 16px 32px;
}

.vaccine-card-shell {
  display: grid;
  gap: 16px;
}

.vaccine-card-hero,
.vaccine-card-panel,
.vaccine-card-status-card,
.vaccine-card-empty,
.vaccine-card-modal-card {
  border-radius: 12px;
  border: 0.5px solid #d8e2dc;
  background: #ffffff;
  box-shadow: 0 18px 34px rgba(12, 61, 43, 0.08);
}

.vaccine-card-hero,
.vaccine-card-panel,
.vaccine-card-empty {
  padding: 18px 16px;
}

.vaccine-card-hero {
  background:
    radial-gradient(320px 140px at 100% 0%, rgba(24, 95, 165, 0.12), transparent 62%),
    linear-gradient(180deg, #ffffff 0%, #f7fbf9 100%);
  display: grid;
  gap: 10px;
}

.vaccine-card-kicker,
.vaccine-card-section-title {
  margin: 0;
  font-size: 11px;
  line-height: 1.3;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #7a8f84;
}

.vaccine-card-hero h1,
.vaccine-card-panel h2,
.vaccine-card-empty h2,
.vaccine-card-modal-copy h3 {
  margin: 0;
  color: #17382b;
}

.vaccine-card-hero h1 {
  font-size: clamp(28px, 5vw, 38px);
  line-height: 1.05;
}

.vaccine-card-hero p,
.vaccine-card-panel p,
.vaccine-card-empty p,
.vaccine-card-modal-copy p,
.vaccine-card-input-help,
.vaccine-card-summary-label,
.vaccine-card-card-subtitle,
.vaccine-card-card-description,
.vaccine-card-feedback {
  margin: 0;
  color: #61776b;
  line-height: 1.55;
}

.vaccine-card-grid {
  display: grid;
  gap: 16px;
}

.vaccine-card-form {
  display: grid;
  gap: 14px;
}

.vaccine-card-field {
  display: grid;
  gap: 8px;
}

.vaccine-card-label {
  font-size: 13px;
  font-weight: 700;
  color: #244537;
}

.vaccine-card-species {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.vaccine-card-species-btn {
  min-height: 86px;
  border-radius: 16px;
  border: 1px solid #d6e1db;
  background: #ffffff;
  color: #244537;
  display: grid;
  place-items: center;
  gap: 8px;
  padding: 14px;
  cursor: pointer;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background-color 0.16s ease;
}

.vaccine-card-species-btn i {
  font-size: 26px;
}

.vaccine-card-species-btn strong {
  font-size: 16px;
  line-height: 1.2;
}

.vaccine-card-species-btn span {
  font-size: 12px;
  color: #6b8075;
}

.vaccine-card-species-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(10, 63, 45, 0.08);
}

.vaccine-card-species-btn.is-active[data-species="cachorro"] {
  border-color: #185fa5;
  background: rgba(24, 95, 165, 0.1);
  color: #185fa5;
}

.vaccine-card-species-btn.is-active[data-species="cachorro"] span {
  color: #185fa5;
}

.vaccine-card-species-btn.is-active[data-species="gato"] {
  border-color: #993556;
  background: rgba(153, 53, 86, 0.1);
  color: #993556;
}

.vaccine-card-species-btn.is-active[data-species="gato"] span {
  color: #993556;
}

.vaccine-card-age-input {
  width: 100%;
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid #cedbd4;
  padding: 10px 14px;
  font-size: 17px;
  line-height: 1.2;
  color: #17382b;
  background: #ffffff;
  outline: none;
  appearance: textfield;
  -moz-appearance: textfield;
}

.vaccine-card-age-input::-webkit-outer-spin-button,
.vaccine-card-age-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.vaccine-card-age-input:focus,
.vaccine-card-unit-btn:focus,
.vaccine-card-species-btn:focus,
.vaccine-card-primary-btn:focus,
.vaccine-card-card-toggle:focus,
.vaccine-card-card-action:focus,
.vaccine-card-modal-action:focus {
  outline: 2px solid rgba(24, 95, 165, 0.16);
  outline-offset: 2px;
}

.vaccine-card-units {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.vaccine-card-unit-btn,
.vaccine-card-primary-btn,
.vaccine-card-card-action,
.vaccine-card-modal-action {
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid transparent;
  cursor: pointer;
  font: inherit;
  font-weight: 700;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease, background-color 0.16s ease;
}

.vaccine-card-unit-btn {
  background: #f4f7f5;
  border-color: #d4dfd8;
  color: #325141;
}

.vaccine-card-unit-btn.is-active {
  background: #17382b;
  border-color: #17382b;
  color: #ffffff;
}

.vaccine-card-primary-btn {
  width: 100%;
  background: #185fa5;
  color: #ffffff;
  justify-content: center;
  padding: 0 14px;
  box-shadow: 0 16px 26px rgba(24, 95, 165, 0.18);
}

.vaccine-card-primary-btn:hover,
.vaccine-card-card-action:hover,
.vaccine-card-modal-action:hover {
  transform: translateY(-1px);
}

.vaccine-card-feedback {
  min-height: 22px;
  font-size: 13px;
}

.vaccine-card-feedback.is-error {
  color: #9f3939;
}

.vaccine-card-feedback.is-success {
  color: #27500a;
}

.vaccine-card-feedback.is-info {
  color: #4f675a;
}

.vaccine-card-summary {
  display: grid;
  gap: 14px;
}

.vaccine-card-banner {
  border-radius: 12px;
  padding: 12px 14px;
  border: 0.5px solid #d4dfd8;
  display: grid;
  gap: 4px;
}

.vaccine-card-banner strong,
.vaccine-card-summary-value,
.vaccine-card-card-title,
.vaccine-card-status-badge {
  color: #17382b;
}

.vaccine-card-banner.is-warning {
  background: #faeeda;
  border-color: #ef9f27;
}

.vaccine-card-banner.is-success {
  background: #eaf3de;
  border-color: #639922;
}

.vaccine-card-progress-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.vaccine-card-progress-percent {
  font-size: 28px;
  font-weight: 800;
  color: #17382b;
}

.vaccine-card-progress-track {
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: #edf2ef;
  overflow: hidden;
}

.vaccine-card-progress-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #185fa5 0%, #2d84d5 100%);
  transition: width 0.2s ease;
}

.vaccine-card-summary-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.vaccine-card-status-card {
  padding: 14px 12px;
  display: grid;
  gap: 4px;
}

.vaccine-card-status-card strong {
  font-size: 20px;
  line-height: 1;
}

.vaccine-card-status-card span {
  font-size: 12px;
  color: #5b7366;
}

.vaccine-card-status-card.is-confirmed {
  background: #eaf3de;
  border-color: #639922;
}

.vaccine-card-status-card.is-pending {
  background: #faeeda;
  border-color: #ef9f27;
}

.vaccine-card-status-card.is-future {
  background: #f4f6f6;
  border-color: #ced7d3;
}

.vaccine-card-sections {
  display: grid;
  gap: 16px;
}

.vaccine-card-section {
  display: grid;
  gap: 10px;
}

.vaccine-card-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.vaccine-card-section-count {
  min-width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #eef3f0;
  color: #436355;
  font-size: 12px;
  font-weight: 800;
}

.vaccine-card-list {
  display: grid;
  gap: 10px;
}

.vaccine-card-card {
  border-radius: 12px;
  border: 0.5px solid #d8e2dc;
  background: #ffffff;
  overflow: hidden;
}

.vaccine-card-card-head {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 14px;
  display: grid;
  gap: 10px;
  text-align: left;
}

.vaccine-card-card-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.vaccine-card-card-main {
  display: grid;
  gap: 4px;
  flex: 1;
  min-width: 0;
}

.vaccine-card-card-title {
  font-size: 14px;
  line-height: 1.4;
  font-weight: 700;
}

.vaccine-card-card-subtitle {
  font-size: 12px;
}

.vaccine-card-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex: 0 0 auto;
  margin-top: 5px;
}

.vaccine-card-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  border-radius: 999px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 800;
  flex: 0 0 auto;
}

.vaccine-card-chevron {
  font-size: 15px;
  color: #577064;
  transition: transform 0.18s ease;
}

.vaccine-card-card.is-open .vaccine-card-chevron {
  transform: rotate(180deg);
}

.vaccine-card-card-body {
  padding: 0 14px 14px;
  display: grid;
  gap: 12px;
}

.vaccine-card-card-description {
  font-size: 13px;
}

.vaccine-card-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.vaccine-card-tag {
  min-height: 26px;
  border-radius: 999px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f0f5f2;
  color: #395647;
  font-size: 12px;
  font-weight: 700;
}

.vaccine-card-tag.is-required {
  background: #17382b;
  color: #ffffff;
}

.vaccine-card-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.vaccine-card-card-action {
  min-height: 34px;
  padding: 0 14px;
}

.vaccine-card-card-action.is-primary {
  background: #17382b;
  color: #ffffff;
}

.vaccine-card-card-action.is-secondary {
  background: #ffffff;
  border-color: #cfdad3;
  color: #29473a;
}

.vaccine-card-card-action.is-accent {
  background: rgba(24, 95, 165, 0.1);
  border-color: rgba(24, 95, 165, 0.24);
  color: #185fa5;
}

.vaccine-card-card.is-overdue {
  background: #fcebeb;
  border-color: #e24b4a;
}

.vaccine-card-card.is-overdue .vaccine-card-status-dot,
.vaccine-card-status-badge.is-overdue {
  background: #e24b4a;
  color: #791f1f;
}

.vaccine-card-card.is-pending {
  background: #faeeda;
  border-color: #ef9f27;
}

.vaccine-card-card.is-pending .vaccine-card-status-dot,
.vaccine-card-status-badge.is-pending {
  background: #ef9f27;
  color: #633806;
}

.vaccine-card-card.is-confirmed {
  background: #eaf3de;
  border-color: #639922;
}

.vaccine-card-card.is-confirmed .vaccine-card-status-dot,
.vaccine-card-status-badge.is-confirmed {
  background: #639922;
  color: #27500a;
}

.vaccine-card-card.is-future {
  background: #f6f8f7;
  border-color: #cfd7d4;
}

.vaccine-card-card.is-future .vaccine-card-status-dot,
.vaccine-card-status-badge.is-future {
  background: #98a4a0;
  color: #4c5a55;
}

.vaccine-card-empty {
  display: grid;
  gap: 8px;
}

.vaccine-card-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(10, 24, 20, 0.52);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(14px, env(safe-area-inset-top)) 14px max(14px, env(safe-area-inset-bottom));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.vaccine-card-modal-card {
  position: relative;
  width: min(100%, 420px);
  max-height: min(88vh, 560px);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 20px;
  display: grid;
  gap: 16px;
}

.vaccine-card-modal-close {
  position: sticky;
  top: 0;
  justify-self: end;
  width: 36px;
  height: 36px;
  margin: -8px -8px -4px 0;
  border: 1px solid #cfdbd4;
  border-radius: 999px;
  background: #ffffff;
  color: #29473a;
  font-size: 18px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
}

.vaccine-card-modal-copy {
  display: grid;
  gap: 8px;
}

.vaccine-card-modal-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.vaccine-card-modal-action {
  flex: 1 1 160px;
  padding: 0 14px;
}

.vaccine-card-modal-action.is-primary {
  background: #185fa5;
  color: #ffffff;
}

.vaccine-card-modal-action.is-secondary {
  background: #ffffff;
  border-color: #cfdbd4;
  color: #29473a;
}

@media (min-width: 860px) {
  .vaccine-card-page {
    padding-bottom: 40px;
  }

  .vaccine-card-grid {
    grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
    align-items: start;
  }
}

@media (max-width: 560px) {
  .vaccine-card-summary-metrics,
  .vaccine-card-species {
    grid-template-columns: 1fr;
  }

  .vaccine-card-card-actions,
  .vaccine-card-modal-actions {
    flex-direction: column;
  }

  .vaccine-card-card-action,
  .vaccine-card-modal-action {
    width: 100%;
  }

  .vaccine-card-modal {
    align-items: flex-start;
    justify-content: stretch;
  }

  .vaccine-card-modal-card {
    width: 100%;
    max-height: calc(100vh - 28px - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    padding: 16px;
  }
}
