.vn-tc {
  --vn-tc-accent: #1E5EFF;
  --vn-tc-card-bg: #FFFFFF;
  --vn-tc-header-bg: #F5F8FF;
  --vn-tc-border: #E4EAF5;
  --vn-tc-text: #1B2430;
  --vn-tc-muted: #6D7A8C;
  background: var(--vn-tc-card-bg);
  border: 1px solid var(--vn-tc-border);
  border-radius: 22px;
  padding: 24px;
  box-shadow: 0 10px 35px rgba(18, 35, 73, 0.06);
  color: var(--vn-tc-text);
}

.vn-tc__title {
  margin: 0 0 8px;
  font-size: 28px;
  line-height: 1.2;
}

.vn-tc__subtitle {
  margin-bottom: 20px;
  color: var(--vn-tc-muted);
  line-height: 1.65;
}

.vn-tc__table-wrap {
  overflow-x: auto;
}

.vn-tc__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.vn-tc__table thead th {
  background: var(--vn-tc-header-bg);
  text-align: left;
  font-weight: 700;
  padding: 16px 18px;
  border-top: 1px solid var(--vn-tc-border);
  border-bottom: 1px solid var(--vn-tc-border);
}

.vn-tc__table thead th:first-child {
  border-left: 1px solid var(--vn-tc-border);
  border-top-left-radius: 16px;
}

.vn-tc__table thead th:last-child {
  border-right: 1px solid var(--vn-tc-border);
  border-top-right-radius: 16px;
}

.vn-tc__table tbody td,
.vn-tc__table tfoot td {
  padding: 16px 18px;
  border-left: 1px solid var(--vn-tc-border);
  border-bottom: 1px solid var(--vn-tc-border);
  vertical-align: middle;
  background: #fff;
}

.vn-tc__table tbody td:last-child,
.vn-tc__table tfoot td:last-child {
  border-right: 1px solid var(--vn-tc-border);
}

.vn-tc__service-name {
  font-weight: 600;
  line-height: 1.5;
}

.vn-tc__service-extra {
  margin-top: 10px;
}

.vn-tc__row--package-picker td {
  background: #FAFCFF;
}

.vn-tc__ops-value,
.vn-tc__text-price,
.vn-tc__price-display {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 90px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #F3F7FF;
  color: #24438F;
  font-weight: 600;
}

.vn-tc__text-price {
  background: #F6F8FC;
  color: var(--vn-tc-text);
}

.vn-tc__price-display {
  gap: 8px;
}

.vn-tc__package-input {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  min-width: 110px;
  border: 1px solid var(--vn-tc-border);
  background: #fff;
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 15px;
  line-height: 1.2;
  transition: 0.2s ease;
}

.vn-tc__package-input:focus {
  outline: none;
  border-color: var(--vn-tc-accent);
  box-shadow: 0 0 0 3px rgba(30, 94, 255, 0.12);
}

.vn-tc__row-qty-input {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  min-width: 90px;
  border: 1px solid var(--vn-tc-border);
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 15px;
  line-height: 1.2;
  transition: 0.2s ease;
}

.vn-tc__row-qty-input:focus {
  outline: none;
  border-color: var(--vn-tc-accent);
  box-shadow: 0 0 0 3px rgba(30, 94, 255, 0.12);
}

.vn-tc__qty-suffix {
  white-space: nowrap;
  color: var(--vn-tc-muted);
  font-weight: 600;
}

.vn-tc__qty-editor {
  display: flex;
  align-items: center;
  gap: 8px;
}

.vn-tc__currency {
  white-space: nowrap;
  color: var(--vn-tc-muted);
  font-weight: 700;
}

.vn-tc__price-meta {
  margin-top: 8px;
  font-size: 13px;
  color: var(--vn-tc-muted);
  line-height: 1.55;
}

.vn-tc__row-base-value,
.vn-tc__row-total-value,
.vn-tc__row-extra-value {
  color: var(--vn-tc-accent);
  font-weight: 700;
}

.vn-tc__row-extra.is-hidden {
  display: none;
}

.vn-tc__price-cell--text {
  color: var(--vn-tc-muted);
}

.vn-tc__subitem {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  background: #F8FAFF;
  border: 1px solid var(--vn-tc-border);
  border-radius: 12px;
  cursor: pointer;
  user-select: none;
}

.vn-tc__subitem input {
  width: 16px;
  height: 16px;
  accent-color: var(--vn-tc-accent);
  margin: 0;
}

.vn-tc__subitem-percent {
  color: var(--vn-tc-accent);
  font-weight: 700;
  white-space: nowrap;
}

.vn-tc__total-label,
.vn-tc__total-cell {
  background: #FBFCFF !important;
  font-size: 18px;
}

.vn-tc__total-label {
  font-weight: 700;
}

.vn-tc__total-value {
  color: var(--vn-tc-accent);
  font-size: 20px;
}

.vn-tc__table tfoot td:first-child {
  border-bottom-left-radius: 16px;
}

.vn-tc__table tfoot td:last-child {
  border-bottom-right-radius: 16px;
}

@media (max-width: 767px) {
  .vn-tc {
    padding: 16px;
    border-radius: 18px;
  }

  .vn-tc__title {
    font-size: 24px;
  }

  .vn-tc__table thead th,
  .vn-tc__table tbody td,
  .vn-tc__table tfoot td {
    padding: 12px;
  }

  .vn-tc__qty-editor {
    min-width: 140px;
  }

  .vn-tc__subitem {
    width: 100%;
    justify-content: space-between;
  }
}
