/* =========================================================
   QR SERVICES
   Узкоспециализированный слой для однотипных QR-страниц:
   url-max.html, url-telegram.html, url-instagram.html и т.д.
   Здесь НЕ должно быть глобальных .btn, .card, .form-control,
   .accordion, body, html и прочих базовых правил.
========================================================= */

/* =========================================================
   STEP CARDS
========================================================= */

#step1Card,
#step2Card {
  background:
    linear-gradient(180deg, rgba(16, 21, 33, 0.96), rgba(10, 14, 22, 0.96)) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 24px !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28) !important;
  outline: none !important;
}

#step1Card .card-body,
#step2Card .card-body {
  padding: 1.35rem;
}

/* =========================================================
   STEP 1 FORM
========================================================= */

#urlForm {
  max-width: 860px;
  margin: 0 auto;
}

#urlForm .form-floating > .form-control {
  min-height: 58px;
}

#btnStep1Submit {
  min-height: 52px;
  font-size: 15px;
  font-weight: 700;
  border-radius: 16px !important;
}

/* =========================================================
   AUTH MODAL
========================================================= */

#authModal .modal-content {
  border-radius: 22px !important;
}

#authModal .modal-header,
#authModal .modal-footer {
  border-color: rgba(255, 255, 255, 0.07);
}

#authModal .modal-title {
  font-weight: 700;
}

/* =========================================================
   STEP 2 LOCAL POLISH
   Только точечные стили для блока настроек QR внутри step2
========================================================= */

#step2Card .accordion-button {
  font-size: 15px;
}

#step2Card .accordion-body {
  font-size: 14px;
}

/* Превью плиток настроек */
#step2Card .dot-img-wrapper {
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04);
}

/* Активная плитка внутри Step 2 */
#step2Card .qr-opt-active {
  outline: 2px solid rgba(124, 92, 255, 0.95);
  outline-offset: -2px;
  box-shadow: 0 0 0 4px rgba(124, 92, 255, 0.14);
  border-radius: 12px !important;
}

/* =========================================================
   QR PREVIEW BLOCK
========================================================= */

#step2Card #qr-bg-wrapper {
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

#step2Card #qr-preview {
  width: 100%;
  aspect-ratio: 1 / 1;
}

/* =========================================================
   EXPORT PANEL
========================================================= */

#step2Card .qr-export-panel {
  max-width: 380px;
  margin-left: auto;
  margin-right: auto;
}

/* =========================================================
   BREADCRUMBS INSIDE QR PAGES
========================================================= */

section.container.py-5 .breadcrumb-wrapper {
  margin-bottom: 1.5rem;
}

/* =========================================================
   RELATED / SEO CARD BELOW GENERATOR
   Очень мягкая корректировка, без вмешательства в глобальную card-систему
========================================================= */

section.container.py-5 > .card:last-of-type {
  margin-top: 1.25rem;
}

/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 767.98px) {
  section.container.py-5 {
    padding-top: 1.2rem !important;
    padding-bottom: 1.2rem !important;
  }

  #step1Card .card-body,
  #step2Card .card-body {
    padding: 1rem;
  }

  #btnStep1Submit {
    min-height: 50px;
    font-size: 14px;
  }

  #step2Card .accordion-button {
    font-size: 14px;
  }

  #step2Card .accordion-body {
    font-size: 13.5px;
  }
}

/* =========================================================
   QR PAGE – SERVICE CARDS
========================================================= */

.qr-page .qr-top-grid,
.qr-page .qr-dynamic-grid {
  row-gap: 18px;
}

.qr-page .qr-section-head {
  margin-top: 1.5rem;
  margin-bottom: 0.35rem;
  padding-inline: 0.35rem;
}

.qr-page .qr-section-head .h5 {
  font-size: 2rem;
  line-height: 1.15;
  color: #f7f9ff;
  margin-bottom: 0;
}

.qr-page .qr-section-head .small {
  color: #91a3be !important;
  font-size: 0.95rem;
}

/* Ссылка-карточка */
.qr-page .qr-card-link {
  display: block;
  text-decoration: none !important;
  color: inherit !important;
}

/* Сама карточка */
.qr-page .qr-service-card {
  position: relative;
  min-height: 74px;
  height: 100%;
  padding: 12px 15px;
  border-radius: 18px;

  background:
    linear-gradient(180deg, rgba(14, 20, 32, 0.95), rgba(9, 14, 24, 0.96));
  border: 1px solid rgba(255, 255, 255, 0.075);
  box-shadow:
    0 10px 24px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.025);

  overflow: hidden;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}

/* Мягкий декоративный засвет */
.qr-page .qr-service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, rgba(76, 201, 255, 0.10), transparent 34%),
    radial-gradient(circle at bottom left, rgba(124, 92, 255, 0.10), transparent 34%);
  opacity: 0.9;
  pointer-events: none;
}

/* Ховер */
.qr-page .qr-card-link:hover .qr-service-card,
.qr-page .qr-card-link:focus-visible .qr-service-card {
  transform: translateY(-3px);
  border-color: rgba(124, 92, 255, 0.26);
  box-shadow:
    0 16px 34px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(124, 92, 255, 0.06);
}

/* Внутренняя компоновка */
.qr-page .qr-service-card__inner {
  position: relative;
  z-index: 1;

  display: flex;
  align-items: center;
  gap: 11px;
  min-height: 46px;
}

/* Контейнер иконки */
.qr-page .qr-service-card__icon {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 12px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255, 255, 255, 0.045);
  border: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.04),
    0 6px 16px rgba(0, 0, 0, 0.18);
}

/* Размеры иконок */
.qr-page .qr-service-card__icon svg,
.qr-page .qr-service-card__icon img,
.qr-page .qr-service-card__icon i {
  width: 20px;
  height: 20px;
  display: block;
  flex-shrink: 0;
}

.qr-page .qr-service-card__icon i {
  font-size: 19px;
  line-height: 1;
  color: #eaf2ff;
}

/* Текстовая часть */
.qr-page .qr-service-card__content {
  min-width: 0;
  flex: 1 1 auto;
}

.qr-page .qr-service-card__title {
  margin: 0;
  color: #f3f7ff;
  font-weight: 700;
  font-size: 0.96rem;
  line-height: 1.22;
  letter-spacing: -0.01em;
  text-decoration: none !important;
}

/* Небольшая стрелка справа */
.qr-page .qr-service-card__arrow {
  width: 26px;
  height: 26px;
  min-width: 26px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: #9eb1ca;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.04);

  transition:
    transform 0.18s ease,
    color 0.18s ease,
    background 0.18s ease;
}

.qr-page .qr-card-link:hover .qr-service-card__arrow,
.qr-page .qr-card-link:focus-visible .qr-service-card__arrow {
  transform: translateX(3px);
  color: #ffffff;
  background: rgba(124, 92, 255, 0.12);
}

/* Две верхние карточки делаем немного заметнее */
.qr-page .qr-top-card .qr-service-card {
  min-height: 80px;
}

/* Чуть разный акцент для разных карточек */
.qr-page .qr-accent-blue .qr-service-card__icon {
  background: rgba(56, 189, 248, 0.10);
}

.qr-page .qr-accent-violet .qr-service-card__icon {
  background: rgba(124, 92, 255, 0.12);
}

.qr-page .qr-accent-green .qr-service-card__icon {
  background: rgba(34, 197, 94, 0.10);
}

.qr-page .qr-accent-orange .qr-service-card__icon {
  background: rgba(245, 158, 11, 0.12);
}

.qr-page .qr-accent-pink .qr-service-card__icon {
  background: rgba(236, 72, 153, 0.11);
}

/* Убираем любые подчеркивания у текста в карточках */
.qr-page .qr-card-link,
.qr-page .qr-card-link:hover,
.qr-page .qr-card-link:focus,
.qr-page .qr-card-link:active,
.qr-page .qr-card-link h6,
.qr-page .qr-card-link:hover h6,
.qr-page .qr-card-link:focus h6 {
  text-decoration: none !important;
}

/* Адаптив */
@media (max-width: 991.98px) {
  .qr-page .qr-section-head {
    margin-top: 1.2rem;
    margin-bottom: 0.25rem;
    padding-inline: 0.15rem;
  }

  .qr-page .qr-section-head .h5 {
    font-size: 1.6rem;
  }

  .qr-page .qr-service-card {
    min-height: 70px;
    padding: 11px 13px;
    border-radius: 16px;
  }

  .qr-page .qr-top-card .qr-service-card {
    min-height: 76px;
  }

  .qr-page .qr-service-card__icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 11px;
  }

  .qr-page .qr-service-card__title {
    font-size: 0.94rem;
  }
}

.qr-page .qr-accent-dark .qr-service-card__icon {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.09);
}

@media (max-width: 575.98px) {
  .qr-page .qr-service-card {
    min-height: 66px;
    padding: 10px 12px;
  }

  .qr-page .qr-service-card__inner {
    gap: 10px;
    min-height: 42px;
  }

  .qr-page .qr-service-card__icon {
    width: 34px;
    height: 34px;
    min-width: 34px;
  }

  .qr-page .qr-service-card__icon svg,
  .qr-page .qr-service-card__icon img,
  .qr-page .qr-service-card__icon i {
    width: 18px;
    height: 18px;
  }

  .qr-page .qr-service-card__title {
    font-size: 0.91rem;
    line-height: 1.2;
  }

  .qr-page .qr-service-card__arrow {
    width: 24px;
    height: 24px;
    min-width: 24px;
  }
}