@import url("https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css");

/**************************************************
 * FOGALJON.ONLINE BOOKING – MINI BS5 THEME
 * Scope: .fon-booking-widget
 **************************************************/

/* --- Alapok --- */
.fon-booking-widget,
.fon-booking-widget * {
  box-sizing: border-box;
}

.fon-booking-widget {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: #212529;
  line-height: 1.5;
  width: 100%;
  max-width: 100%;
  padding: 0 20px; /* Kis padding hogy ne érjen a szélekhez */
}

/* Link alap */
.fon-booking-widget a {
  color: #0d6efd;
  text-decoration: none;
}
.fon-booking-widget a:hover {
  text-decoration: underline;
}

/**************************************************
 * HERO / LANDING
 **************************************************/
.fon-booking-widget .fon-hero {
  min-height: 280px;
  padding: 40px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.fon-booking-widget .bg-hero2 {
  background: linear-gradient(145deg, #f5f7fa, #e8ecf1);
  border-radius: 1rem;
  padding: 2.5rem 1.5rem;
  width: 100%;
  margin: 0 auto;
}

.fon-booking-widget .hero-content h1 {
  margin-bottom: 1rem;
}

.fon-booking-widget .display-5 {
  font-size: 2.5rem;
  font-weight: 300;
}

.fon-booking-widget .fw-bold {
  font-weight: 700;
}

.fon-booking-widget .btn-book {
  font-size: 1.1rem;
  padding: .75rem 2.3rem;
  margin-top: 0.75rem;
}

/**************************************************
 * KÖZPONTI KÁRTYÁK (landing / visitor / summary / success)
 **************************************************/
.fon-booking-widget .fon-card {
  max-width: 100%;
  margin: 2rem auto;
  padding: 1.5rem;
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.95);
}

.fon-booking-widget .fon-card-header {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
}

.fon-booking-widget .fon-card-header h3 {
  margin: 0;
}

/* Kezelés-grid: teljes szélesség, több oszlop */
.fon-booking-widget .fon-card.fon-card-grid {
  max-width: 100%;       /* full-width */
  width: 100%;
  margin: 2rem auto;
  box-shadow: none;        /* opcionális, hogy ne legyen dupla keret */
  background: transparent; /* a kártyák adják a fehér hátteret */
}

/* A gridben lévő kártyák */
.fon-booking-widget .fon-card-grid .card {
  border-radius: 16px;
}

/**************************************************
 * GRID / LAYOUT (Bootstrap-szerű)
 **************************************************/
.fon-booking-widget .conteiner_inner {
  padding: 1.5rem 0;
}

/* row */
.fon-booking-widget .row {
  display: flex;
  flex-wrap: wrap;
  margin-right: -0.75rem;
  margin-left: -0.75rem;
}

/* col */
.fon-booking-widget .col {
  padding-right: 0.75rem;
  padding-left: 0.75rem;
  flex: 0 0 100%;
  max-width: 100%;
}

/* row-cols-* */
.fon-booking-widget .row.row-cols-1 > .col {
  flex: 0 0 100%;
  max-width: 100%;
}

@media (min-width: 768px) {
  .fon-booking-widget .row.row-cols-md-2 > .col {
    flex: 0 0 50%;
    max-width: 50%;
  }
}

@media (min-width: 992px) {
  .fon-booking-widget .row.row-cols-lg-4 > .col {
    flex: 0 0 25%;
    max-width: 25%;
  }
}

/* g-4 gap */
.fon-booking-widget .g-4 > .col {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

/* Align / justify helpers */
.fon-booking-widget .d-flex { display: flex; }
.fon-booking-widget .justify-content-center { justify-content: center; }
.fon-booking-widget .align-items-center { align-items: center; }
.fon-booking-widget .text-center { text-align: center; }
.fon-booking-widget .w-100 { width: 100%; }

/**************************************************
 * BUTTONOK
 **************************************************/
.fon-booking-widget .btn {
  display: inline-block;
  padding: .5rem 1.2rem;
  font-size: 1rem;
  border-radius: .375rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: transparent;
  color: #0d6efd;
  text-align: center;
  line-height: 1.5;
  white-space: nowrap;
}

.fon-booking-widget .btn-sm {
  padding: .375rem .9rem;
  font-size: .875rem;
}

.fon-booking-widget .btn-primary {
  color: #fff;
  background-color: #0d6efd;
  border-color: #0d6efd;
}
.fon-booking-widget .btn-primary:hover {
  background-color: #0b5ed7;
  border-color: #0a58ca;
}

.fon-booking-widget .btn-outline-primary {
  color: #0d6efd;
  background-color: transparent;
  border-color: #0d6efd;
}
.fon-booking-widget .btn-outline-primary:hover {
  color: #fff;
  background-color: #0d6efd;
}

.fon-booking-widget .btn-secondary {
  color: #212529;
  background-color: #e9ecef;
  border-color: #e9ecef;
}

.fon-booking-widget .btn-warning {
  background-color: #ffc107;
  border-color: #ffc107;
  color: #000;
}
.fon-booking-widget .btn-warning:hover {
  background-color: #e0a800;
  border-color: #d39e00;
}

/* FON-spec gombok */
.fon-booking-widget .fon-btn-primary,
.fon-booking-widget .fon-btn-secondary,
.fon-booking-widget .fon-btn-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: none;
  padding: .5rem 1.25rem;
  cursor: pointer;
  font-size: 0.95rem;
}

.fon-booking-widget .fon-btn-primary {
  background: #0d6efd;
  color: #fff;
}
.fon-booking-widget .fon-btn-secondary {
  background: #e9ecef;
  color: #212529;
}
.fon-booking-widget .fon-btn-link {
  background: transparent;
  color: #0d6efd;
  padding: 0;
}

/* Árnyék */
.fon-booking-widget .shadow {
  box-shadow: 0 .5rem 1rem rgba(0,0,0,.15);
}

/**************************************************
 * CARD (kezelés kártyákhoz)
 **************************************************/
.fon-booking-widget .card {
  position: relative;
  display: flex;
  flex-direction: column;
  border-radius: .75rem;
  border: 1px solid rgba(0,0,0,.125);
  background-color: #fff;
  box-shadow: 0 .25rem .75rem rgba(0,0,0,.06);
  overflow: hidden;
  /* height: 100%; */ /* Kikommentezve - cache plugin konfliktus miatt */
}

/* Card magasság csak ha van card-body (flex layout) */
.fon-booking-widget .card:has(.card-body) {
  height: auto !important;
}

.fon-booking-widget .card-body {
  flex: 1 1 auto;
  padding: 1rem 1.25rem;
}

.fon-booking-widget .card-title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: .5rem;
}

/* Ratio (1:1) kép */
.fon-booking-widget .ratio {
  position: relative;
  width: 100%;
}
.fon-booking-widget .ratio::before {
  display: block;
  padding-top: 100%;
  content: "";
}
.fon-booking-widget .ratio > img,
.fon-booking-widget .ratio > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/**************************************************
 * LIST GROUP (több alkezelés)
 **************************************************/
.fon-booking-widget .list-group {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fon-booking-widget .list-group-item {
  border: 0;
  border-top: 1px solid rgba(0,0,0,.05);
  padding: .75rem 0;
  background: transparent;
}

/**************************************************
 * KEZELÉS KÁRTYÁK SPECIFIKUS STÍLUSAI
 **************************************************/
.fon-booking-widget .fon-treatment-card .card-body {
  display: flex;
  flex-direction: column;
}

.fon-booking-widget .fon-treatment-desc {
  font-size: 0.8rem;
}

.fon-booking-widget .fon-treatment-thumb-placeholder {
  background: #f8f9fa;
}

.fon-booking-widget .fon-treatment-placeholder-icon {
  font-size: 2rem;
  opacity: 0.5;
}

.fon-booking-widget .fon-treatments-header {
  margin-bottom: 1rem;
}
.fon-booking-widget .fon-treatments-header h3 {
  font-size: 1.25rem;
  font-weight: 600;
}

/**************************************************
 * FORMAK (VISITOR LÉPÉS)
 **************************************************/
.fon-booking-widget .fon-form label {
  display: block;
  margin-bottom: .75rem;
  font-size: 0.95rem;
}

/* CSAK szöveges / dátum / email / tel mezőkre legyen 100% szélesség */
.fon-booking-widget .fon-form input[type="text"],
.fon-booking-widget .fon-form input[type="email"],
.fon-booking-widget .fon-form input[type="date"],
.fon-booking-widget .fon-form input[type="tel"],
.fon-booking-widget .fon-form input[type="password"],
.fon-booking-widget .fon-form input[type="number"] {
  width: 100%;
  padding: .5rem .75rem;
  border-radius: 8px;
  border: 1px solid #ced4da;
  font-size: 0.95rem;
}

.fon-booking-widget .fon-form input[type="text"]:focus,
.fon-booking-widget .fon-form input[type="email"]:focus,
.fon-booking-widget .fon-form input[type="date"]:focus,
.fon-booking-widget .fon-form input[type="tel"]:focus,
.fon-booking-widget .fon-form input[type="password"]:focus,
.fon-booking-widget .fon-form input[type="number"]:focus {
  outline: none;
  border-color: #0d6efd;
  box-shadow: 0 0 0 2px rgba(13,110,253,.15);
}

/* Checkboxok – ne legyenek 100% szélesek */
.fon-booking-widget .fon-form input[type="checkbox"] {
  width: auto;
  margin: 0;
}

/* Checkbox sor (ÁSZF, stb.) */
.fon-booking-widget .fon-form-check {
  margin-bottom: .75rem;
  font-size: 0.9rem;
}

/* Itt igazítjuk egy sorba a pipát és a szöveget */
.fon-booking-widget .fon-form-check label {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: 0;
}

/* A pipa maradjon kis fix méretű, ne nyúljon szét */
.fon-booking-widget .fon-form-check input[type="checkbox"] {
  flex: 0 0 auto;
}

/**************************************************
 * LISTA ALAPÚ LÉPÉSEK (DOCTORS / SLOTS)
 **************************************************/
.fon-booking-widget .fon-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.fon-booking-widget .fon-list-item {
  width: 100%;
  text-align: left;
  border-radius: 12px;
  border: 1px solid #e5e5e5;
  padding: .75rem 1rem;
  background: #fff;
  cursor: pointer;
}

.fon-booking-widget .fon-list-item-selected {
  border-color: #0d6efd;
  box-shadow: 0 0 0 2px rgba(13,110,253,.15);
}

.fon-booking-widget .fon-list-title {
  font-weight: 600;
}

.fon-booking-widget .fon-list-sub {
  font-size: 0.85rem;
  color: #6c757d;
}

/**************************************************
 * ÖSSZEGZÉS / ACTIONS
 **************************************************/
.fon-booking-widget .fon-summary p {
  margin-bottom: .25rem;
}

.fon-booking-widget .fon-actions {
  display: flex;
  justify-content: space-between;
  gap: .5rem;
  margin-top: 1.5rem;
}

/**************************************************
 * APRÓBB UTILITIES
 **************************************************/
.fon-booking-widget .mb-0 { margin-bottom: 0; }
.fon-booking-widget .mb-1 { margin-bottom: .25rem; }
.fon-booking-widget .mb-2 { margin-bottom: .5rem; }
.fon-booking-widget .mb-3 { margin-bottom: 1rem; }
.fon-booking-widget .mt-auto { margin-top: auto; }
.fon-booking-widget .me-2 { margin-right: .5rem; }
.fon-booking-widget .ms-2 { margin-left: .5rem; }
.fon-booking-widget .small { font-size: .875rem; }
.fon-booking-widget .text-muted { color: #6c757d; }
.fon-booking-widget .text-nowrap { white-space: nowrap; }

/**************************************************
 * ALERT (ha nincs kezelés, stb.)
 **************************************************/
.fon-booking-widget .alert {
  position: relative;
  padding: .75rem 1rem;
  border-radius: .375rem;
  border: 1px solid transparent;
  font-size: 0.95rem;
}

.fon-booking-widget .alert-warning {
  color: #664d03;
  background-color: #fff3cd;
  border-color: #ffecb5;
}

.fon-booking-widget .alert-light {
  color: #636464;
  background-color: #f8f9fa;
  border-color: #f8f9fa;
}


/* --- Grid-es kezelés oldal doboz --- */
.fon-booking-widget .fon-card-grid {
  max-width: 100%;          /* full-width */
  margin: 2rem auto;
  padding: 1.5rem 1.5rem 2rem;
  background: rgba(255,255,255,0.98);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
  border-radius: 24px;
}

/* A fon-card alap max-width-je marad a többi oldalnak (landing, visitor, summary), 
   de a grid-es verzió szélesebb lehet. */

/* Kártyák a gridben – 100% magasság, szép elnyúlás */
.fon-booking-widget .fon-treatment-card {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  display: flex;
  flex-direction: column;
}

.fon-booking-widget .fon-treatment-card .card-body {
  display: flex;
  flex-direction: column;
}

.fon-booking-widget .fon-treatment-thumb {
  border-bottom: 1px solid #f1f3f5;
}

.fon-booking-widget .fon-treatment-desc {
  font-size: 0.85rem;
  color: #6c757d;
  min-height: 3.5rem; /* hogy kb. egyforma legyen a kártya magassága */
}

.fon-booking-widget .fon-treatment-thumb-placeholder {
  background: #f8f9fa;
}

.fon-booking-widget .fon-treatment-placeholder-icon {
  font-size: 2.4rem;
  opacity: 0.4;
}

/* CTA gomb lent maradjon */
.fon-booking-widget .fon-treatment-card .btn {
  font-size: 0.9rem;
}

/* Kis reszponzív finomhangolás */
@media (max-width: 991.98px) {
  .fon-booking-widget .fon-card-grid {
    max-width: 100%;
    border-radius: 0;
  }
}

.fon-booking-widget .fon-doctor-card {
  border-radius: 16px;
}
.fon-booking-widget .fon-doctor-card .card-img-top {
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}

/* Időpont gombok alap */
.fon-booking-widget .fon-slot-btn {
  min-width: 90px;
  border-radius: 999px;
  font-size: 0.9rem;
  padding: 0.35rem 0.9rem;
}

/* Kijelölt időpont – legyen látványosan aktív */
.fon-booking-widget .fon-slot-btn.selected {
  background-color: #0d6efd;
  border-color: #0d6efd;
  color: #fff;
}

/* Kis átmenet, hogy ne legyen "ugrós" */
.fon-booking-widget .fon-slot-btn {
  transition: background-color .15s ease, color .15s ease, box-shadow .15s ease;
}

/* ------------ CHECKBOX FIX ------------ */
.fon-form-check label {
    display: flex;
    align-items: center;
    gap: .5rem;        /* térköz checkbox és szöveg között */
    line-height: 1.3;
}

.fon-form-check input[type="checkbox"] {
    margin: 0;
    position: relative;
    top: 0;
}

/**************************************************
 * KEZELÉS GRID – 3 / SOR, KÁRTYA NÉLKÜL
 **************************************************/
.fon-booking-widget .fon-treatment-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .fon-booking-widget .fon-treatment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 992px) {
  /* Itt jön a "3 kezelés / sor" fix */
  .fon-booking-widget .fon-treatment-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .fon-booking-widget .fon-treatment-grid:has(>div:nth-child(2):last-child) {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
  .fon-booking-widget .fon-treatment-grid > div:first-child:last-child{
    grid-column: 2/3;
  }
  .fon-booking-widget .fon-treatment-grid:has(>div:nth-child(2):last-child) div:first-child {
    grid-column: 2/4;
  }
  .fon-booking-widget .fon-treatment-grid:has(>div:nth-child(2):last-child) div:nth-child(2) {
    grid-column: 4/6;
  }
}

/* Egy-egy kezelés "tile" – nem klasszikus Bootstrap card */
.fon-booking-widget .fon-treatment-item {
  border-radius: 16px;
  border: 1px solid #e5e5e5;
  background: #ffffff;
  padding: 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  box-shadow: 0 .3rem .9rem rgba(15, 23, 42, 0.05);
}

/* Fejléc: kép + szöveg egymás mellett */
.fon-booking-widget .fon-treatment-head {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

/* Avatar (kép vagy ikon) */
.fon-booking-widget .fon-treatment-avatar {
  width: 52px;
  height: 52px;
  border-radius: 999px;
  overflow: hidden;
  background: #f8f9fa;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fon-booking-widget .fon-treatment-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fon-booking-widget .fon-treatment-avatar-placeholder {
  background: #eef1f5;
}

.fon-booking-widget .fon-treatment-placeholder-icon {
  font-size: 1.6rem;
  opacity: 0.5;
}

/* Cím + leírás blokk */
.fon-booking-widget .fon-treatment-head-text {
  flex: 1 1 auto;
}

.fon-booking-widget .fon-treatment-title {
  font-size: 0.98rem;
  font-weight: 600;
}

.fon-booking-widget .fon-treatment-desc {
  font-size: 0.85rem;
  color: #6c757d;
  margin: 0;
}

/* Tartalom (alkezelések) */
.fon-booking-widget .fon-treatment-body {
  margin-top: 0.4rem;
}

/* Egyetlen alkezelés esetén a név + ár */
.fon-booking-widget .fon-treatment-single {
  display: flex;
  flex-direction: column;
}

.fon-booking-widget .fon-treatment-single-main {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
}

.fon-booking-widget .fon-treatment-single-name {
  font-size: 0.9rem;
  font-weight: 600;
}

.fon-booking-widget .fon-treatment-single-price {
  font-size: 0.9rem;
  font-weight: 600;
  white-space: nowrap;
}

/* Több alkezelés – a meglévő list-group-ra finomhangolás */
.fon-booking-widget .fon-treatment-item .list-group {
  margin-top: 0.25rem;
}

.fon-booking-widget .fon-treatment-item .list-group-item {
  padding: 0.5rem 0;
}

/* Gombok a tile-on belül */
.fon-booking-widget .fon-treatment-item .btn {
  margin-top: 0.5rem;
}


/**************************************************
 * ORVOS GRID – 3 / SOR, KÁRTYA NÉLKÜL
 **************************************************/
.fon-booking-widget .fon-doctors-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

@media (min-width: 768px) {
  .fon-booking-widget .fon-doctors-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 992px) {
  /* nagyobb kijelzőn 3 orvos / sor */
  .fon-booking-widget .fon-doctors-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .fon-booking-widget .fon-doctors-grid > div:first-child:last-child{
    grid-column: 2/3;
  }
}

/* Egy orvos "tile" */
.fon-booking-widget .fon-doctor-item {
  border-radius: 16px;
  border: 1px solid #e5e5e5;
  background: #ffffff;
  padding: 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  box-shadow: 0 .3rem .9rem rgba(15, 23, 42, 0.05);

  /* egységesebb magasság a sorban */
  min-height: 210px;      /* ha magasnak érzed, nyugodtan állítsd 190–230 közé */
}

/* Fejléc: avatar + szöveg */
.fon-booking-widget .fon-doctor-head {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

/* Avatar körben */
.fon-booking-widget .fon-doctor-avatar {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  overflow: hidden;
  background: #f8f9fa;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.fon-booking-widget .fon-doctor-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fon-booking-widget .fon-doctor-avatar-placeholder {
  background: #eef1f5;
}

.fon-booking-widget .fon-doctor-placeholder-icon {
  font-size: 1.7rem;
  opacity: 0.7;
}

/* Név + leírás blokk */
.fon-booking-widget .fon-doctor-head-text {
  flex: 1 1 auto;
}

.fon-booking-widget .fon-doctor-name {
  font-size: 0.98rem;
  font-weight: 600;
}

.fon-booking-widget .fon-doctor-desc {
  font-size: 0.85rem;
  color: #6c757d;
  margin: 0;

  /* max 3 sor, utána vágás ... */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Gomb a tile alján */
.fon-booking-widget .fon-doctor-body {
  margin-top: auto;       /* gomb mindig lecsúszik a kártya aljára */
}

.fon-booking-widget .fon-doctor-item .btn {
  margin-top: 0.25rem;
  font-size: 0.9rem;
}


/* ---- FLEX HELPERek KIEGÉSZÍTÉSE ---- */
.fon-booking-widget .justify-content-between {
  justify-content: space-between;
}

.fon-booking-widget .align-items-center {
  align-items: center;
}

.fon-booking-widget .fon-subtreatment-list {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-top: 0.25rem;
}

.fon-booking-widget .fon-subtreatment-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.35rem 0;
  border-top: 1px solid #eee;
}

.fon-booking-widget .fon-subtreatment-main {
  flex: 1 1 auto;
  min-width: 0;
}

.fon-booking-widget .fon-subtreatment-name {
  font-size: 0.9rem;
  font-weight: 600;
  word-break: break-word;
}

.fon-booking-widget .fon-subtreatment-price {
  font-size: 0.85rem;
}

/* Gomb – fix, nem törik, nem mászik rá a következő sorra */
.fon-booking-widget .fon-subtreatment-row .btn {
  flex: 0 0 auto;
  white-space: nowrap;
  margin-top: 0.1rem;
}
/**************************************************
 * PROGRESS STEPPER
 **************************************************/
.fon-booking-widget .fon-stepper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  margin-bottom: 20px;
  max-width: 100%;
  overflow-x: auto;
}

.fon-booking-widget .fon-stepper-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  flex: 1;
  min-width: 100px;
}

.fon-booking-widget .fon-stepper-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 15px;
  left: 50%;
  right: -50%;
  height: 2px;
  background-color: #dee2e6;
  z-index: 0;
}

.fon-booking-widget .fon-stepper-step.active:not(:last-child)::after {
  background-color: #0d6efd;
}

.fon-booking-widget .fon-stepper-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #dee2e6;
  border: 2px solid #dee2e6;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 14px;
  color: #6c757d;
  z-index: 1;
  transition: all 0.3s ease;
  margin-bottom: 8px;
}

.fon-booking-widget .fon-stepper-step.active .fon-stepper-circle {
  background-color: #0d6efd;
  border-color: #0d6efd;
  color: white;
}

.fon-booking-widget .fon-stepper-step.completed .fon-stepper-circle {
  background-color: #198754;
  border-color: #198754;
  color: white;
}

.fon-booking-widget .fon-stepper-label {
  font-size: 13px;
  color: #6c757d;
  text-align: center;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.fon-booking-widget .fon-stepper-step.active .fon-stepper-label {
  color: #0d6efd;
  font-weight: 600;
}

.fon-booking-widget .fon-stepper-step.completed .fon-stepper-label {
  color: #198754;
}

/* Responsive */
@media (max-width: 768px) {
  .fon-booking-widget .fon-stepper {
    padding: 15px 0;
  }
  
  .fon-booking-widget .fon-stepper-step {
    min-width: 80px;
  }
  
  .fon-booking-widget .fon-stepper-circle {
    width: 28px;
    height: 28px;
    font-size: 12px;
  }
  
  .fon-booking-widget .fon-stepper-label {
    font-size: 11px;
  }
}

@media (max-width: 576px) {
  .fon-booking-widget .fon-stepper {
    padding: 10px 0;
  }
  
  .fon-booking-widget .fon-stepper-step {
    min-width: 60px;
  }
  
  .fon-booking-widget .fon-stepper-circle {
    width: 24px;
    height: 24px;
    font-size: 11px;
  }
  
  .fon-booking-widget .fon-stepper-label {
    font-size: 10px;
  }
}

/**************************************************
 * FULL-WIDTH RESPONSIVE PADDING
 **************************************************/
/* Desktop-on nagyobb paddingek */
@media (min-width: 768px) {
  .fon-booking-widget {
    padding: 0 40px;
  }
}

@media (min-width: 1200px) {
  .fon-booking-widget {
    padding: 0 60px;
  }
}

/* Extra nagy képernyőkön maximum szélesség opcionálisan */
@media (min-width: 1920px) {
  .fon-booking-widget {
    max-width: 1800px;
    margin: 0 auto;
    padding: 0 80px;
  }
}

/**************************************************
 * v1.3.1 - INTL-TEL-INPUT CUSTOMIZATION
 **************************************************/
/* intl-tel-input wrapper styling to match our form inputs */
.fon-booking-widget .iti {
  width: 100%;
  display: block;
}

.fon-booking-widget .iti__flag-container {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  padding: 1px;
}

.fon-booking-widget .iti__selected-flag {
  padding: 0 8px 0 8px;
  height: 100%;
  display: flex;
  align-items: center;
}

.fon-booking-widget .iti input[type="tel"] {
  width: 100%;
  padding: 0.5rem 60px 0.5rem 0.75rem; /* Extra padding for flag */
  border: 1px solid #ced4da;
  border-radius: 0.375rem;
  font-size: 1rem;
  line-height: 1.5;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

.fon-booking-widget .iti input[type="tel"]:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}

/* Dropdown styling */
.fon-booking-widget .iti__country-list {
  border-radius: 0.375rem;
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  max-height: 250px;
  overflow-y: auto;
}

.fon-booking-widget .iti__country {
  padding: 8px 12px;
}

.fon-booking-widget .iti__country:hover {
  background-color: #f8f9fa;
}

.fon-booking-widget .iti__country.iti__highlight {
  background-color: #e9ecef;
}
