.elementor-6423 .elementor-element.elementor-element-2ae92ab{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-6423 .elementor-element.elementor-element-2ae92ab:not(.elementor-motion-effects-element-type-background), .elementor-6423 .elementor-element.elementor-element-2ae92ab > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#C9C1B0;}/* Start custom CSS for html, class: .elementor-element-b085819 *//* ===== MQ APP BASE ===== */
.mq-app{
  max-width: 900px;
  margin: 0 auto;
  padding: 0 12px;            /* mobil széleken ne tapadjon */
  box-sizing: border-box;
}

.mq-app *{
  box-sizing: border-box;     /* overflow elleni alap */
}

.mq-step{
  margin: 14px 0;
  border: 1px solid #333;
  border-radius: 12px;
  overflow: hidden;           /* semmi ne lógjon ki */
}

/* ===== STEP BAR (desktop default) ===== */
.mq-stepbar{
  width: 100%;
  display: grid;
  grid-template-columns: 120px 1fr 160px;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  background: rgba(255,255,255,0.03);
}

.mq-stepbar-left{
  opacity: .9;
  font-weight: 800;
  text-align: left;
  white-space: nowrap;
}

.mq-stepbar-mid{
  text-align: center;
  min-width: 0; /* grid overflow fix */
}

.mq-stepbar-right{
  text-align: right;
  font-weight: 900;
  white-space: nowrap;
}

.mq-step-title{
  font-weight: 900;
  overflow-wrap: anywhere;
}

.mq-step-desc{
  font-size: 13px;
  opacity: .85;
  margin-top: 4px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.mq-step-picked{
  margin-top: 8px;
  font-size: 13px;
  opacity: .92;
  overflow-wrap: anywhere;
}

.mq-step-total{
  display: inline-block;
  min-height: 18px;
  overflow-wrap: anywhere;
}

/* ===== STEP BODY ===== */
.mq-stepbody{
  padding: 14px;
  border-top: 1px solid #333;
  text-align: center;
  overflow: hidden;
}

/* ===== BUTTONS (fix: long text, responsive sizing) ===== */
.mq-btnrow{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  align-items: stretch;
}

.mq-btn{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #555;
  background: transparent;
  cursor: pointer;
  color: inherit;
  appearance: none;
  -webkit-appearance: none;

  /* critical for long text: */
  white-space: normal;        /* tördelhető */
  overflow-wrap: anywhere;    /* sose lógjon ki */
  word-break: break-word;
  line-height: 1.2;

  /* make sure button grows to fit text */
  height: auto;
  min-height: 44px;           /* touch-friendly */
  max-width: 100%;
}

/* hover state: BLACK BG + WHITE TEXT */
.mq-btn:hover{
  background: #000;
  color: #fff;
  border-color: #000;
}

/* selected/active state: BLACK BG + WHITE TEXT */
.mq-btn.mq-active,
.mq-choice.mq-active,
.mq-paymethod.mq-active{
  background: #000 !important;
  color: #fff !important;
  border-color: #000 !important;
  outline: none !important;   /* kivesszük a dupla szegélyt */
  box-shadow: none !important;
}

/* focus for accessibility */
.mq-btn:focus-visible{
  outline: 2px solid #000;
  outline-offset: 2px;
}

/* secondary buttons remain same logic, but also follow hover/active */
.mq-secondary{ opacity: .9; }

.mq-muted{
  opacity: .8;
  margin-left: 6px;
  font-weight: 600;
}

/* ===== GRID BUTTON GROUPS ===== */
.mq-btngrid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  max-width: 820px;
  margin: 0 auto;
}

/* Tablet: 3 columns */
@media (min-width: 680px){
  .mq-btngrid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Desktop: up to 5 columns */
@media (min-width: 980px){
  .mq-btngrid{
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

/* ===== TYPO / SECTIONS ===== */
.mq-label{
  font-weight: 800;
  margin: 10px 0 8px;
  text-align: center;
  overflow-wrap: anywhere;
}

.mq-subtitle{
  font-weight: 900;
  margin: 4px 0 10px;
  text-align: center;
  overflow-wrap: anywhere;
}

.mq-divider{
  height: 1px;
  background: #333;
  margin: 14px 0;
  opacity: .9;
}

/* ===== INPUTS (responsive safe) ===== */
.mq-input{
  width: 100%;
  padding: 10px;
  border-radius: 10px;
  border: 1px solid #555;
  background: transparent;
  color: inherit;
  outline: none;
  max-width: 100%;
}

.mq-input:focus{
  border-color: #000;
}

.mq-center-input{
  max-width: 520px;
  margin: 0 auto;
  display: block;
}

.mq-hint{
  margin-top: 8px;
  opacity: .85;
  text-align: center;
  overflow-wrap: anywhere;
}

/* ===== SUMMARY / PANELS ===== */
.mq-summarybox{
  padding: 12px;
  border: 1px solid #333;
  border-radius: 12px;
  text-align: left;
  overflow-wrap: anywhere;
}

.mq-totalline{
  font-size: 18px;
  text-align: center;
  margin-top: 10px;
  overflow-wrap: anywhere;
}

.mq-panel{
  padding: 12px;
  border: 1px solid #333;
  border-radius: 12px;
  text-align: left;
  overflow: hidden;
}

.mq-panel .mq-subtitle{
  text-align: center;
}

/* ===== FORMS ===== */
.mq-formgrid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  max-width: 820px;
  margin: 0 auto;
  text-align: left;
}

/* Tablet/desktop */
@media (min-width: 768px){
  .mq-formgrid{ grid-template-columns: 1fr 1fr; }
}

.mq-field{
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.mq-flabel{
  font-size: 13px;
  font-weight: 800;
  opacity: .9;
  overflow-wrap: anywhere;
}

.mq-ferror{
  min-height: 16px;
  font-size: 12px;
  opacity: .95;
  margin-top: 2px;
  overflow-wrap: anywhere;
}

.mq-invalid{
  border-color: #e74c3c !important;
  box-shadow: 0 0 0 2px rgba(231,76,60,0.25);
}

/* ===== TOGGLES ===== */
.mq-toggle{
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  justify-content: center;
}

.mq-toggle input{ transform: scale(1.1); }

/* ===== CTA ===== */
.mq-cta{
  padding: 12px 16px;
  font-weight: 900;
}

/* ===== HELPERS ===== */
.mq-center{ text-align: center; }

/* ===== RESPONSIVE STEP BAR (mobile) ===== */
@media (max-width: 720px){
  .mq-stepbar{
    grid-template-columns: 1fr; /* egymás alá */
    gap: 6px;
    text-align: center;
  }
  .mq-stepbar-left,
  .mq-stepbar-right{
    text-align: center;
  }
}

/* ===== RESPONSIVE BUTTON SIZING (mobile) ===== */
@media (max-width: 520px){
  .mq-btnrow{ gap: 8px; }
  .mq-btn{
    width: 100%;            /* mobilon “kártya gomb” jelleg */
    max-width: 520px;
  }
  .mq-btngrid{
    grid-template-columns: 1fr; /* mobilon 1 oszlop, biztos nem lóg ki */
  }
}/* End custom CSS */