/* ════════════════════════════════════════════════════════════════════════
   ViVeSec AI Box — kipróbálási felugró ablak (promo modal)
   Önálló, könnyen kivehető modul. Minden szelektor a .vsb-aibox /
   .vsb-aibox-trigger / .vsb-aibox-flyer névtérben él, hogy ne ütközzön
   a meglévő stílusokkal. A globális design tokeneket (var(--grad) stb.)
   a main.css :root-ja adja.
   ════════════════════════════════════════════════════════════════════════ */

:root {
  --vsb-ease: cubic-bezier(.22, 1, .36, 1);
  --vsb-ease-soft: cubic-bezier(.4, 0, .2, 1);
}

/* Görgetészár, amíg a modal nyitva van */
html.vsb-aibox-lock,
body.vsb-aibox-lock { overflow: hidden; }

/* ───────────────────────── Overlay + konténer ───────────────────────── */
.vsb-aibox {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(.75rem, 3vw, 2rem);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s var(--vsb-ease-soft), visibility .35s var(--vsb-ease-soft);
  -webkit-tap-highlight-color: transparent;
}
.vsb-aibox[hidden] { display: none; }
.vsb-aibox.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.vsb-aibox__overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(124, 92, 255, .28), transparent 60%),
    rgba(4, 4, 14, .72);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
  backdrop-filter: blur(8px) saturate(120%);
  opacity: 0;
  transition: opacity .4s var(--vsb-ease-soft);
}
.vsb-aibox.is-open .vsb-aibox__overlay { opacity: 1; }

/* ───────────────────────── Dialógus ───────────────────────── */
.vsb-aibox__dialog {
  position: relative;
  width: 100%;
  max-width: 560px;
  max-height: calc(100vh - 2rem);
  max-height: calc(100dvh - 2rem);
  overflow: hidden auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 24px;
  padding: clamp(1.5rem, 4vw, 2.75rem);
  color: var(--ink);
  background:
    linear-gradient(180deg, rgba(28, 30, 60, .92), rgba(14, 15, 38, .96));
  border: 1px solid var(--line-2);
  box-shadow:
    0 40px 90px -30px rgba(10, 8, 40, .9),
    0 0 0 1px rgba(124, 92, 255, .12),
    inset 0 1px 0 rgba(255, 255, 255, .06);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  backdrop-filter: blur(20px) saturate(140%);
  /* enter */
  opacity: 0;
  transform: translateY(26px) scale(.96);
  transition: opacity .5s var(--vsb-ease), transform .5s var(--vsb-ease);
}
.vsb-aibox.is-open .vsb-aibox__dialog {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.vsb-aibox.is-closing .vsb-aibox__dialog {
  opacity: 0;
  transform: translateY(14px) scale(.97);
}

/* Dekorációk a dialóguson belül */
.vsb-aibox__aura {
  position: absolute;
  top: -40%;
  left: 50%;
  width: 140%;
  height: 80%;
  transform: translateX(-50%);
  background: radial-gradient(50% 50% at 50% 50%, rgba(34, 211, 238, .22), transparent 70%);
  pointer-events: none;
  filter: blur(10px);
  z-index: 0;
}
.vsb-aibox__grid-deco {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(124, 92, 255, .07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124, 92, 255, .07) 1px, transparent 1px);
  background-size: 34px 34px;
  -webkit-mask-image: radial-gradient(80% 60% at 50% 0%, #000, transparent 75%);
  mask-image: radial-gradient(80% 60% at 50% 0%, #000, transparent 75%);
  pointer-events: none;
  z-index: 0;
}

.vsb-aibox__viewport { position: relative; z-index: 1; }

/* ───────────────────────── Bezáró gomb ───────────────────────── */
.vsb-aibox__close {
  position: absolute;
  top: clamp(.75rem, 2vw, 1.1rem);
  right: clamp(.75rem, 2vw, 1.1rem);
  z-index: 3;
  width: 40px;
  height: 40px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: var(--ink-dim);
  background: rgba(255, 255, 255, .05);
  border: 1px solid var(--line-2);
  cursor: pointer;
  transition: transform .25s var(--vsb-ease), background .25s, color .25s, border-color .25s;
  touch-action: manipulation;
}
.vsb-aibox__close:hover {
  color: #fff;
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .28);
  transform: rotate(90deg);
}
.vsb-aibox__close:active { transform: rotate(90deg) scale(.92); }

/* ───────────────────────── Lépések (cross-fade) ───────────────────────── */
.vsb-aibox__step { display: none; }
.vsb-aibox__step.is-active {
  display: block;
  animation: vsb-step-in .5s var(--vsb-ease) both;
}
@keyframes vsb-step-in {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ───────────────────────── Tipográfia / badge ───────────────────────── */
.vsb-aibox__badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .8rem;
  border-radius: 999px;
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #d9e4ff;
  background: linear-gradient(135deg, rgba(124, 92, 255, .25), rgba(34, 211, 238, .18));
  border: 1px solid rgba(124, 92, 255, .35);
  margin-bottom: 1.1rem;
}
.vsb-aibox__badge-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(34, 211, 238, .6);
  animation: vsb-pulse 2s infinite;
}
@keyframes vsb-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(34, 211, 238, .55); }
  70%  { box-shadow: 0 0 0 8px rgba(34, 211, 238, 0); }
  100% { box-shadow: 0 0 0 0 rgba(34, 211, 238, 0); }
}

.vsb-aibox__eyebrow {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: .6rem;
}

/* Lépés-fejléc: „vissza" gomb + eyebrow egy sorban */
.vsb-aibox__stephead {
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .7rem;
  padding-right: 46px; /* helyet hagy a jobb felső X gombnak */
}
.vsb-aibox__stephead .vsb-aibox__eyebrow { margin-bottom: 0; }

.vsb-aibox__back {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: var(--ink-dim);
  background: rgba(255, 255, 255, .05);
  border: 1px solid var(--line-2);
  cursor: pointer;
  transition: transform .25s var(--vsb-ease), background .25s, color .25s, border-color .25s;
  touch-action: manipulation;
}
.vsb-aibox__back:hover {
  color: #fff;
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .28);
  transform: translateX(-3px);
}
.vsb-aibox__back:active { transform: translateX(-3px) scale(.92); }

.vsb-aibox__title {
  margin: 0 0 .85rem;
  font-family: 'Space Grotesk', 'Inter', system-ui, sans-serif;
  font-size: clamp(1.45rem, 1rem + 1.9vw, 2rem);
  font-weight: 700;
  line-height: 1.14;
  letter-spacing: -.02em;
  color: #fff;
}
.vsb-aibox__title--sm { font-size: clamp(1.3rem, 1rem + 1.3vw, 1.65rem); }

.vsb-aibox__lead {
  margin: 0 0 1.4rem;
  font-size: clamp(.95rem, .9rem + .25vw, 1.05rem);
  line-height: 1.6;
  color: var(--ink-dim);
}
.vsb-aibox__lead--sm { margin-bottom: 1.2rem; }

/* Záró, kiemelt sor a bevezető lépésben (intro_outro) */
.vsb-aibox__outro {
  margin: -0.4rem 0 1.5rem;
  color: var(--ink, #0f172a);
  font-weight: 600;
}

/* ───────────────────────── Előny-lista ───────────────────────── */
.vsb-aibox__points {
  list-style: none;
  margin: 0 0 1.6rem;
  padding: 0;
  display: grid;
  gap: .7rem;
}
.vsb-aibox__points li {
  display: flex;
  align-items: center;
  gap: .7rem;
  font-size: .96rem;
  font-weight: 500;
  color: var(--ink);
}
.vsb-aibox__check {
  flex: 0 0 auto;
  width: 26px;
  height: 26px;
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  background: linear-gradient(135deg, #7C5CFF, #22D3EE);
  box-shadow: 0 6px 16px -6px rgba(34, 211, 238, .6);
}

/* ───────────────────────── Gombok ───────────────────────── */
.vsb-aibox__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .7rem;
  align-items: center;
}
.vsb-aibox__actions--split { justify-content: space-between; }

.vsb-aibox__btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .8rem 1.4rem;
  border-radius: 999px;
  font-family: inherit;
  font-size: .95rem;
  font-weight: 700;
  line-height: 1;
  color: var(--ink);
  background: rgba(255, 255, 255, .04);
  border: 1px solid var(--line-2);
  cursor: pointer;
  overflow: hidden;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .2s var(--vsb-ease), box-shadow .25s, background .25s, color .25s, border-color .25s, opacity .2s;
  touch-action: manipulation;
}
.vsb-aibox__btn--block { width: 100%; }
.vsb-aibox__btn:hover { transform: translateY(-2px); }
.vsb-aibox__btn:active { transform: translateY(0) scale(.98); }

.vsb-aibox__btn--primary {
  color: #fff;
  background: linear-gradient(135deg, #7C5CFF 0%, #22D3EE 100%);
  border-color: transparent;
  box-shadow: 0 14px 34px -12px rgba(124, 92, 255, .8);
}
.vsb-aibox__btn--primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 25%, rgba(255, 255, 255, .35) 50%, transparent 75%);
  transform: translateX(-120%);
  transition: transform .7s var(--vsb-ease);
}
.vsb-aibox__btn--primary:hover::after { transform: translateX(120%); }
.vsb-aibox__btn--ghost { background: rgba(255, 255, 255, .05); color: var(--ink-dim); }
.vsb-aibox__btn--ghost:hover { color: #fff; background: rgba(255, 255, 255, .1); }

.vsb-aibox__btn[disabled] {
  opacity: .45;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}
.vsb-aibox__btn[disabled]::after { display: none; }

.vsb-aibox__btn-spark { display: inline-flex; }

/* Spinner a betöltéshez */
.vsb-aibox__spinner {
  display: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, .35);
  border-top-color: #fff;
  animation: vsb-spin .7s linear infinite;
}
.vsb-aibox__btn.is-loading { pointer-events: none; }
.vsb-aibox__btn.is-loading .vsb-aibox__spinner { display: inline-block; }
.vsb-aibox__btn.is-loading .vsb-aibox__btn-label { opacity: .7; }
@keyframes vsb-spin { to { transform: rotate(360deg); } }

/* ───────────────────────── Űrlap ───────────────────────── */
.vsb-aibox__form { margin: 0; }
.vsb-aibox__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .85rem 1rem;
  margin-bottom: 1rem;
}
.vsb-aibox__field { display: flex; flex-direction: column; gap: .4rem; }
.vsb-aibox__field--full { grid-column: 1 / -1; }

.vsb-aibox__label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-dim);
  display: flex;
  align-items: center;
  gap: .35rem;
}
.vsb-aibox__req { color: var(--accent); font-weight: 800; }
.vsb-aibox__opt {
  font-size: .7rem;
  font-weight: 500;
  text-transform: lowercase;
  color: var(--muted);
  opacity: .8;
}

.vsb-aibox__input {
  width: 100%;
  padding: .8rem .95rem;
  border-radius: 12px;
  font-family: inherit;
  font-size: .98rem; /* >=16px-hez közeli, hogy iOS Safari ne zoomoljon a 0.98rem ~ 15.7px miatt: lásd alább a mobil override-ot */
  color: var(--ink);
  background: rgba(8, 9, 24, .6);
  border: 1px solid var(--line-2);
  transition: border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance: none;
  appearance: none;
}
.vsb-aibox__input::placeholder { color: var(--muted); opacity: .7; }
.vsb-aibox__input:focus {
  outline: none;
  border-color: rgba(124, 92, 255, .7);
  background: rgba(8, 9, 24, .85);
  box-shadow: 0 0 0 3px rgba(124, 92, 255, .2);
}
.vsb-aibox__input.is-invalid {
  border-color: #ff6b8a;
  box-shadow: 0 0 0 3px rgba(255, 107, 138, .18);
}

/* honeypot — vizuálisan elrejtve, de elérhető a botoknak */
.vsb-aibox__hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* ───────────────────────── Hozzájárulások ───────────────────────── */
.vsb-aibox__consent {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  margin-bottom: .7rem;
  font-size: .85rem;
  line-height: 1.45;
  color: var(--ink-dim);
  cursor: pointer;
}
.vsb-aibox__consent input { position: absolute; opacity: 0; width: 0; height: 0; }
.vsb-aibox__consent-box {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  margin-top: 1px;
  display: inline-grid;
  place-items: center;
  border-radius: 6px;
  color: transparent;
  background: rgba(8, 9, 24, .6);
  border: 1px solid var(--line-2);
  transition: background .2s var(--vsb-ease), border-color .2s, color .2s, transform .15s;
}
.vsb-aibox__consent input:checked ~ .vsb-aibox__consent-box {
  color: #fff;
  background: linear-gradient(135deg, #7C5CFF, #22D3EE);
  border-color: transparent;
  transform: scale(1.06);
}
.vsb-aibox__consent input:focus-visible ~ .vsb-aibox__consent-box {
  box-shadow: 0 0 0 3px rgba(124, 92, 255, .35);
}
.vsb-aibox__consent-text { flex: 1; }
.vsb-aibox__link { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.vsb-aibox__link:hover { color: #7fe9ff; }

/* ───────────────────────── Üzenetek / váltó ───────────────────────── */
.vsb-aibox__msg {
  min-height: 0;
  margin: 0 0 .8rem;
  font-size: .85rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--ink-dim);
}
.vsb-aibox__msg:empty { margin: 0; }
.vsb-aibox__msg.is-error { color: #ff8aa3; }
.vsb-aibox__msg.is-success { color: #5ee6b0; }

.vsb-aibox__switch {
  margin: 1rem 0 0;
  font-size: .85rem;
  color: var(--ink-dim);
  text-align: center;
}
.vsb-aibox__textbtn {
  background: none;
  border: 0;
  padding: 0;
  margin-left: .3rem;
  font: inherit;
  font-weight: 700;
  color: var(--accent);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.vsb-aibox__textbtn:hover { color: #7fe9ff; }

.vsb-aibox__note {
  margin: 1rem 0 0;
  font-size: .8rem;
  color: var(--muted);
  text-align: center;
}

/* ───────────────────────── Siker lépés ───────────────────────── */
.vsb-aibox__step--success { text-align: center; }
.vsb-aibox__success-ring {
  width: 76px;
  height: 76px;
  margin: 0 auto 1.2rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, #7C5CFF, #22D3EE);
  box-shadow: 0 0 0 8px rgba(124, 92, 255, .14), 0 18px 40px -12px rgba(34, 211, 238, .7);
  animation: vsb-pop .6s var(--vsb-ease) both;
}
.vsb-aibox__step--success .vsb-aibox__btn { margin-top: .4rem; }
@keyframes vsb-pop {
  0%   { opacity: 0; transform: scale(.4); }
  60%  { transform: scale(1.12); }
  100% { opacity: 1; transform: scale(1); }
}

/* ════════════════════════════════════════════════════════════════════════
   Állandó menü-trigger (a felugró ablak bezárása után jelenik meg)
   ════════════════════════════════════════════════════════════════════════ */
.vsb-aibox-trigger {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .55rem 1rem;
  border-radius: 999px;
  font-family: inherit;
  font-size: .9rem;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  background: linear-gradient(135deg, #7C5CFF 0%, #22D3EE 100%);
  border: 1px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 10px 26px -12px rgba(124, 92, 255, .75);
  transition: transform .2s var(--vsb-ease), box-shadow .25s, filter .25s;
  touch-action: manipulation;
  position: relative;
  overflow: hidden;
}
.vsb-aibox-trigger:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 32px -10px rgba(124, 92, 255, .9);
  filter: saturate(1.1);
}
.vsb-aibox-trigger:active { transform: translateY(0) scale(.97); }
/* rejtett kezdőállapot, amíg a "felrepülés" / belépés meg nem történik */
.vsb-aibox-trigger.vsb-pending {
  opacity: 0;
  transform: scale(.8);
  pointer-events: none;
}
.vsb-aibox-trigger__spark {
  display: inline-flex;
  animation: vsb-spark 3.5s var(--vsb-ease-soft) infinite;
}
@keyframes vsb-spark {
  0%, 100% { transform: rotate(0) scale(1); opacity: .9; }
  50%      { transform: rotate(18deg) scale(1.15); opacity: 1; }
}
/* belépő animáció amikor megjelenik a fejlécben */
.vsb-aibox-trigger.vsb-enter {
  animation: vsb-trigger-in .55s var(--vsb-ease) both;
}
@keyframes vsb-trigger-in {
  from { opacity: 0; transform: translateY(-8px) scale(.8); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* a fejléc-akciókban (desktop) */
.header-actions .vsb-aibox-trigger { order: -1; }

/* mobil menü CTA-ban teljes szélességű */
.mobile-nav-cta .vsb-aibox-trigger {
  width: 100%;
  justify-content: center;
  padding: .85rem 1.5rem;
  font-size: 1rem;
}

/* A FLIP „repülő” klón (JS hozza létre záráskor) */
.vsb-aibox-flyer {
  position: fixed;
  margin: 0;
  z-index: 1300;
  pointer-events: none;
  will-change: transform, opacity;
}

/* ════════════════════════════════════════════════════════════════════════
   Reszponzív finomhangolás
   ════════════════════════════════════════════════════════════════════════ */

/* Mobil: az iOS Safari ne zoomoljon fókuszkor → 16px input betűméret */
@media (max-width: 600px) {
  .vsb-aibox__input { font-size: 16px; }
  .vsb-aibox__grid { grid-template-columns: 1fr; }
  .vsb-aibox__dialog { border-radius: 20px; }
  .vsb-aibox__actions { flex-direction: column-reverse; align-items: stretch; }
  .vsb-aibox__actions--split { flex-direction: row; }
  .vsb-aibox__actions .vsb-aibox__btn { width: 100%; }
  .vsb-aibox__actions--split .vsb-aibox__btn { width: auto; }
}

@media (hover: none) and (pointer: coarse) {
  .vsb-aibox__overlay {
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    background: rgba(4, 4, 14, .82);
  }
  .vsb-aibox__dialog {
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }
}

/* Nagyon alacsony képernyő: a dialógus görgethető marad */
@media (max-height: 640px) {
  .vsb-aibox { align-items: flex-start; }
}

/* Desktop trigger kompaktabb a szűkebb fejlécben (a login gomb mellett) */
@media (max-width: 1100px) and (min-width: 1000px) {
  .header-actions .vsb-aibox-trigger__label { display: none; }
  .header-actions .vsb-aibox-trigger { padding: .55rem .7rem; }
}

/* Mobilon (a hamburger nézet) a fejléc-trigger ikon-only, hogy ne törje a sort.
   A teljes szövegű gomb a mobil menüben (drawer) jelenik meg. */
@media (max-width: 999px) {
  .header-actions .vsb-aibox-trigger__label { display: none; }
  .header-actions .vsb-aibox-trigger { padding: .5rem .6rem; }
}
@media (max-width: 380px) {
  .header-actions .vsb-aibox-trigger { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   prefers-reduced-motion — minden mozgás kikapcsolása
   ════════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .vsb-aibox,
  .vsb-aibox__overlay,
  .vsb-aibox__dialog,
  .vsb-aibox__step.is-active,
  .vsb-aibox__close,
  .vsb-aibox__btn,
  .vsb-aibox-trigger,
  .vsb-aibox__badge-dot,
  .vsb-aibox__success-ring,
  .vsb-aibox-trigger__spark,
  .vsb-aibox__btn--primary::after {
    animation: none !important;
    transition-duration: .01ms !important;
  }
  .vsb-aibox__dialog { transform: none !important; }
}
