:root{
  --bg:#06071a;
  --card:rgba(255,255,255,.06);
  --border:rgba(103,232,249,.15);
  --text:#f0f4ff;
  --muted:#94a3c0;
  --blue:#3b82f6;
  --blue2:#1d4ed8;
  --cyan:#22d3ee;
  --purple:#8b5cf6;
  --purple2:#6d28d9;
  --star:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Segoe UI',system-ui,sans-serif;
  background:
    radial-gradient(ellipse at top right,rgba(139,92,246,.20),transparent 35%),
    radial-gradient(ellipse at top left,rgba(34,211,238,.18),transparent 35%),
    radial-gradient(ellipse at bottom center,rgba(59,130,246,.12),transparent 50%),
    linear-gradient(180deg,#06071a 0%,#030410 100%);
  color:var(--text);
  overflow-x:hidden
}
body:before{
  content:"";position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:linear-gradient(to bottom,black,transparent 70%);
  pointer-events:none;z-index:-2
}
a{text-decoration:none;color:inherit}
.container{width:min(1120px,calc(100% - 40px));margin:0 auto}

/* ── HEADER ── */
header{
  position:sticky;top:0;z-index:20;
  backdrop-filter:blur(20px);
  background:rgba(6,7,26,.78);
  border-bottom:1px solid rgba(139,92,246,.2)
}
nav{height:76px;display:flex;justify-content:space-between;align-items:center}

/* ── LOGO ── */
.logo{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.06em;font-size:15px}
.logo-wordmark{height:18px;width:auto;object-fit:contain}
.logo-img{
  width:42px;height:42px;object-fit:contain;
  filter:drop-shadow(0 0 12px rgba(34,211,238,.55)) drop-shadow(0 0 24px rgba(139,92,246,.35));
}
.nav-links{display:flex;align-items:center;gap:24px;color:var(--muted);font-size:14px}
.lang-switch{display:inline-flex;align-items:center;justify-content:center;min-width:38px;padding:6px 10px;border:1px solid rgba(139,92,246,.4);border-radius:10px;font-weight:700;font-size:13px;letter-spacing:.06em;color:var(--text);transition:.2s}
.lang-switch:hover{border-color:var(--cyan);color:var(--cyan)}
.nav-links a:hover{color:var(--cyan);transition:.2s}
.nav-toggle{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:6px;line-height:0}
.nav-toggle svg{width:28px;height:28px}
.nav-bar-right{display:flex;align-items:center;gap:12px}
.lang-switch--mobile{display:none}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 22px;border-radius:999px;font-weight:700;
  border:1px solid rgba(139,92,246,.4);transition:.2s ease;
  color:var(--text)
}
.btn-primary{
  background:linear-gradient(135deg,var(--cyan),var(--blue),var(--purple));
  color:#fff;border:none;
  box-shadow:0 0 32px rgba(139,92,246,.35),0 0 12px rgba(34,211,238,.2)
}
.btn:hover{transform:translateY(-2px);box-shadow:0 4px 24px rgba(139,92,246,.4)}
.btn-primary:hover{box-shadow:0 0 44px rgba(139,92,246,.5),0 0 16px rgba(34,211,238,.3)}

/* ── HERO ── */
.hero{padding:110px 0 84px;text-align:center}
.eyebrow{
  display:inline-flex;padding:8px 16px;
  border:1px solid rgba(34,211,238,.35);border-radius:999px;
  color:var(--cyan);background:rgba(34,211,238,.08);
  font-size:13px;margin-bottom:24px;letter-spacing:.05em
}
h1{
  font-size:clamp(42px,7vw,82px);line-height:.98;
  letter-spacing:-.06em;max-width:980px;margin:0 auto 26px
}
.gradient-text{
  background:linear-gradient(95deg,#fff 0%,var(--cyan) 35%,var(--purple) 70%,var(--blue) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent
}
.lead{
  color:var(--muted);font-size:clamp(18px,2vw,22px);
  line-height:1.6;max-width:840px;margin:0 auto 34px
}
.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.trust{color:var(--muted);font-size:13px;letter-spacing:.08em;text-transform:uppercase}

/* ── SECTIONS ── */
.section{padding:92px 0;border-top:1px solid rgba(139,92,246,.1)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:34px}
.section h2{font-size:clamp(32px,4vw,54px);letter-spacing:-.04em;line-height:1;max-width:760px}
.section p{color:var(--muted);line-height:1.7;font-size:17px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{grid-template-columns:repeat(2,1fr)}

/* ── CARDS ── */
.card{
  background:linear-gradient(160deg,rgba(139,92,246,.10),rgba(34,211,238,.04),rgba(255,255,255,.03));
  border:1px solid rgba(139,92,246,.18);
  border-radius:26px;padding:26px;
  box-shadow:0 8px 40px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.06)
}
.card:hover{
  border-color:rgba(139,92,246,.35);
  box-shadow:0 12px 50px rgba(139,92,246,.15),0 0 0 1px rgba(139,92,246,.1);
  transition:.3s ease
}
.card h3{font-size:22px;margin-bottom:12px;letter-spacing:-.02em}
.tag{
  display:inline-block;margin-bottom:16px;
  color:var(--cyan);font-size:12px;
  text-transform:uppercase;letter-spacing:.1em
}

/* ── MODULE TABLE ── */
.module-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:24px}
.module-table th,.module-table td{padding:18px;border-bottom:1px solid rgba(139,92,246,.12);text-align:left;vertical-align:top}
.module-table th{
  color:var(--cyan);font-size:12px;letter-spacing:1.5px;
  text-transform:uppercase;background:rgba(139,92,246,.08)
}
.module-table td{color:var(--muted)}
.module-table strong{color:white}
.module-table tr:hover td{background:rgba(139,92,246,.05);transition:.2s}

/* ── PILLS ── */
.pill-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.pill{
  padding:8px 14px;
  border:1px solid rgba(139,92,246,.25);border-radius:999px;
  color:var(--muted);background:rgba(139,92,246,.06);font-size:13px
}

/* ── FINAL CTA ── */
.final{
  text-align:center;padding:96px 0;
  background:radial-gradient(ellipse at center,rgba(139,92,246,.18) 0%,rgba(34,211,238,.08) 40%,transparent 65%)
}

/* ── FOOTER ── */
footer{border-top:1px solid rgba(139,92,246,.15);color:var(--muted);padding:34px 0;font-size:14px}
.footer-content{display:flex;justify-content:space-between;align-items:flex-start;gap:60px;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-logo{height:200px;width:auto;object-fit:contain}
.footer-social{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.footer-legal{margin-top:32px;padding:24px 0;background:rgba(6,7,26,.78);border-top:1px solid rgba(139,92,246,.12);text-align:center;color:var(--muted);font-size:13px;line-height:1.7}
.footer-legal p{margin:0}
.footer-column{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:180px}
.footer-column h4{color:var(--cyan);font-size:11px;letter-spacing:2.5px;margin-bottom:10px;text-transform:uppercase}
.footer-column a{display:block;color:#7a8eab;font-size:14px;line-height:1.8;transition:.2s}
.footer-column a:hover{color:var(--cyan)}
.linkedin-link{
  width:26px;height:26px;display:flex;align-items:center;justify-content:center;
  color:#fff;opacity:.75;transition:all .2s ease
}
.linkedin-link:hover{opacity:1;color:var(--cyan)}
.linkedin-link svg{width:16px;height:16px}
.linkedin-link--lg{width:34px;height:34px;flex-shrink:0}
.linkedin-link--lg svg{width:22px;height:22px}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-toggle{display:inline-flex;align-items:center}
  .lang-switch--mobile{display:inline-flex}
  .nav-links .lang-switch{display:none}
  .nav-links{
    display:none;position:absolute;top:76px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:6px;
    background:rgba(6,7,26,.97);backdrop-filter:blur(20px);
    border-bottom:1px solid rgba(139,92,246,.2);
    padding:16px 20px 24px
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:10px 2px;font-size:15px}
  .nav-links .lang-switch{align-self:flex-start;margin:4px 0}
  .nav-links .btn{text-align:center}
  .section-head{display:grid;grid-template-columns:1fr}
  .grid,.grid-2{grid-template-columns:1fr}
  .module-table{display:block;overflow-x:auto}
  .final{padding-bottom:48px}
  .footer-content{flex-direction:row;flex-wrap:wrap;gap:32px}
  .footer-brand{flex:1 1 100%;justify-content:center}
  .footer-logo{height:360px}
  .footer-column{flex:1 1 0;min-width:0}
  .hero{padding-top:76px}
}

/* ══════════════════════════════════════════
   CUSTOM / PAGE-SPECIFIC STYLES
   ══════════════════════════════════════════ */

/* ── SUCCESS CARDS ── */
.success-card{display:flex;flex-direction:column;gap:14px}
.success-num{
  font-size:42px;font-weight:900;letter-spacing:-.05em;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1
}
/* ── TRAINER CARDS ── */
.trainer-card{position:relative;overflow:hidden}
.trainer-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:10px;font-weight:900;font-size:13px;
  letter-spacing:.08em;margin-bottom:14px
}
.trainer-badge.hu{background:rgba(139,92,246,.2);color:var(--purple);border:1px solid rgba(139,92,246,.35)}
.trainer-badge.en{background:rgba(34,211,238,.15);color:var(--cyan);border:1px solid rgba(34,211,238,.3)}
.trainer-card h3{margin-bottom:4px}

/* ── SIGNUP FORM ── */
.contact-intro{
  margin:36px auto 0;max-width:680px;text-align:center;
  padding:36px 40px;border-radius:22px;
  background:linear-gradient(160deg,rgba(139,92,246,.12),rgba(34,211,238,.05));
  border:1px solid rgba(139,92,246,.25)
}
.contact-intro h2{margin-bottom:14px}
.contact-intro .lead{margin:0 auto}
.contact-intro-divider{height:1px;margin:24px auto;background:linear-gradient(90deg,transparent,rgba(139,92,246,.4),transparent)}
.price-main{font-size:22px;font-weight:700;letter-spacing:-.02em;text-align:center}
.price-main strong{color:var(--cyan)}
.price-net{color:var(--muted);font-size:15px;font-weight:500}
.price-desc{margin-top:12px;color:var(--muted);font-size:14px;line-height:1.6;text-align:center}
.audience-note{
  margin:38px auto 0;max-width:780px;text-align:center;
  color:var(--text);font-size:clamp(18px,2.3vw,21px);font-weight:500;line-height:1.55;
  padding:24px 30px;border-radius:16px;
  background:linear-gradient(180deg,rgba(34,211,238,.07),rgba(139,92,246,.05));
  border:1px solid rgba(103,232,249,.18)
}
.audience-note .accent{
  background:linear-gradient(95deg,var(--cyan) 0%,var(--purple) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700
}
.signup-form-wrap{margin-top:48px;display:flex;justify-content:center;width:100%}
.final h2{margin-left:auto;margin-right:auto;font-size:36px;letter-spacing:-.04em;line-height:1.05}
.signup-form-card{
  background:linear-gradient(160deg,rgba(139,92,246,.12),rgba(34,211,238,.05),rgba(255,255,255,.03));
  border:1px solid rgba(139,92,246,.25);
  border-radius:28px;padding:40px 36px;
  width:100%;max-width:480px;
  text-align:left;
  box-shadow:0 20px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter:blur(12px)
}
.signup-form-header h3{font-size:28px;font-weight:800;letter-spacing:-.03em;margin-bottom:8px;text-align:center}
.signup-form-header p{color:var(--muted);font-size:15px;margin-bottom:28px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.form-group label{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.02em}
.form-group input{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(139,92,246,.22);
  border-radius:12px;padding:14px 16px;
  color:var(--text);font-size:15px;
  outline:none;transition:.2s ease;
  font-family:inherit
}
.form-group input::placeholder{color:rgba(148,163,192,.5)}
.form-group input:focus{
  border-color:rgba(139,92,246,.6);
  box-shadow:0 0 0 3px rgba(139,92,246,.12);
  background:rgba(255,255,255,.07)
}
/* Hibás mező kiemelése + mező alatti hibaszöveg */
.form-group input.field-invalid,
.form-group select.field-invalid{
  border-color:#fb7185;
  box-shadow:0 0 0 3px rgba(244,63,94,.18);
  background:rgba(244,63,94,.06)
}
.field-error{
  margin:2px 0 0;color:#fca5a5;font-size:13px;line-height:1.4;font-weight:500
}
/* Nem-prod (teszt) környezeti figyelmeztető csík az oldal tetején */
#envBanner{
  position:relative;z-index:50;
  background:#fde047;color:#3a2d00;
  text-align:center;font-size:14px;font-weight:700;letter-spacing:.01em;
  padding:8px 14px;border-bottom:1px solid rgba(0,0,0,.18)
}
@media (max-width:560px){ #envBanner{font-size:12.5px;padding:7px 10px} }
.form-consent{display:flex;align-items:flex-start;gap:10px;margin-bottom:20px;text-align:left}
.form-consent input{margin-top:3px;width:16px;height:16px;flex-shrink:0;accent-color:var(--cyan);cursor:pointer}
.form-consent label{font-size:12.5px;line-height:1.5;color:var(--muted);cursor:pointer}
.signup-btn{width:100%;margin-top:8px;padding:16px;font-size:16px;border-radius:14px}
.signup-success{
  display:none;margin-top:16px;text-align:center;
  color:var(--cyan);font-size:15px;font-weight:600
}
.signup-success-box{
  display:none;text-align:center;padding:8px 4px 4px;
  animation:successFade .4s ease both
}
@keyframes successFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.success-check{
  width:68px;height:68px;margin:0 auto 20px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.45);
  box-shadow:0 0 24px rgba(34,197,94,.25)
}
.success-check svg{width:36px;height:36px;color:#22c55e}
.signup-success-box h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:14px;color:var(--text)}
.signup-success-box p{color:var(--muted);font-size:15px;line-height:1.7;margin-bottom:10px}
.signup-success-box .success-closing{margin-top:14px;margin-bottom:0;color:var(--cyan);font-weight:700}

/* ── INFO BAR ── */
.info-bar{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:0;
  margin-top:32px;
  background:linear-gradient(135deg,rgba(139,92,246,.10),rgba(34,211,238,.06));
  border:1px solid rgba(139,92,246,.22);
  border-radius:20px;padding:6px 0;
  overflow:hidden
}
.info-item{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:18px 32px;flex:1;min-width:160px
}
.info-label{
  font-size:11px;text-transform:uppercase;letter-spacing:.12em;
  color:var(--cyan);font-weight:700
}
.info-value{
  font-size:15px;font-weight:700;color:var(--text);
  letter-spacing:-.01em;white-space:nowrap
}
.info-divider{
  width:1px;height:44px;
  background:rgba(139,92,246,.25);
  flex-shrink:0
}
@media(max-width:700px){
  .info-bar{flex-direction:column;gap:0;padding:0}
  .info-item{width:100%;border-bottom:1px solid rgba(139,92,246,.12);padding:16px 24px;flex-direction:row;justify-content:space-between;align-items:center}
  .info-item:last-child{border-bottom:none}
  .info-divider{display:none}
}

/* ── EVENT BANNER ── */
.event-banner{
  margin-top:20px;
  background:linear-gradient(135deg,rgba(139,92,246,.14),rgba(34,211,238,.08));
  border:1px solid rgba(139,92,246,.3);
  border-radius:18px;overflow:hidden;
  position:relative
}
.event-banner::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(139,92,246,.06),transparent,rgba(34,211,238,.06));
  pointer-events:none
}
.event-banner-inner{
  display:flex;align-items:center;gap:0;
  flex-wrap:wrap;padding:8px 8px
}
.event-col{
  display:flex;align-items:center;gap:16px;
  padding:24px 32px;flex:1;min-width:200px;color:var(--text)
}
.event-col svg{color:var(--cyan);flex-shrink:0}
.event-col div{display:flex;flex-direction:column;gap:2px}
.event-label{font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan);font-weight:700;margin-bottom:4px}
.event-value{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.02em}
.event-sep{width:1px;height:56px;background:rgba(139,92,246,.25);flex-shrink:0}
.event-cta{margin:12px 16px 12px auto;white-space:nowrap;padding:12px 20px;font-size:14px}
@media(max-width:700px){
  .event-banner-inner{flex-direction:column;align-items:stretch;padding:0}
  .event-col{border-bottom:1px solid rgba(139,92,246,.12);padding:14px 20px}
  .event-sep{display:none}
  .event-cta{margin:12px 20px;width:calc(100% - 40px)}
}

/* ── MODULES GRID ── */
.modules-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-bottom:48px
}
.module-card{
  background:linear-gradient(160deg,rgba(139,92,246,.10),rgba(34,211,238,.04),rgba(255,255,255,.03));
  border:1px solid rgba(139,92,246,.18);
  border-radius:20px;padding:22px;
  display:flex;flex-direction:column;gap:10px;
  box-shadow:0 8px 30px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.06);
  transition:.3s ease
}
.module-card:hover{border-color:rgba(139,92,246,.4);box-shadow:0 12px 40px rgba(139,92,246,.15)}
.module-num{
  font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;
  color:var(--cyan)
}
.module-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1.3}
.module-desc{font-size:14px;color:var(--muted);line-height:1.6;flex:1}
.module-footer{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.badge{
  display:inline-flex;align-items:center;
  padding:5px 10px;border-radius:999px;font-size:12px;font-weight:700;
  letter-spacing:.04em
}
.badge-time{background:rgba(255,255,255,.07);color:var(--muted);border:1px solid rgba(255,255,255,.1)}
.badge-hu{background:rgba(139,92,246,.15);color:#c4b5fd;border:1px solid rgba(139,92,246,.3)}
.badge-en{background:rgba(34,211,238,.12);color:#67e8f9;border:1px solid rgba(34,211,238,.3)}

/* ── SCHEDULE ── */
.schedule-wrap{
  background:linear-gradient(160deg,rgba(139,92,246,.08),rgba(34,211,238,.04));
  border:1px solid rgba(139,92,246,.18);
  border-radius:24px;padding:32px;
  margin-top:16px
}
.schedule-head{margin-bottom:24px}
.schedule-head h3{font-size:clamp(22px,3vw,32px);font-weight:800;letter-spacing:-.03em;margin:8px 0}
.schedule-head p{color:var(--muted);font-size:15px}
.schedule{display:flex;flex-direction:column;gap:0}
.schedule-row{
  display:grid;
  grid-template-columns:140px 40px 1fr 160px 60px;
  align-items:center;gap:12px;
  padding:14px 0;
  border-bottom:1px solid rgba(139,92,246,.1)
}
.schedule-row:last-child{border-bottom:none}
.break-row{opacity:.55}
.sched-time{font-size:13px;color:var(--cyan);font-weight:600;font-variant-numeric:tabular-nums}
.sched-num{font-size:13px;font-weight:900;color:var(--text);letter-spacing:.05em}
.sched-title{font-size:15px;font-weight:600;color:var(--text)}
.sched-trainer{font-size:13px;color:var(--muted)}
.schedule-row .badge{justify-self:start}
.muted{color:var(--muted) !important}

@media(max-width:900px){
  .modules-grid{grid-template-columns:1fr}
  .schedule-row{grid-template-columns:1fr 1fr;gap:6px}
  .sched-time{grid-column:1/3;font-size:12px}
  .sched-num{font-size:12px}
  .sched-trainer{display:none}
}

/* ── LANGUAGE SWITCHER ── */
.lang-switcher{
  display:flex;align-items:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(139,92,246,.3);
  border-radius:999px;
  padding:4px;
  gap:2px
}
.lang-btn{
  background:none;border:none;cursor:pointer;
  padding:6px 12px;border-radius:999px;
  font-size:13px;font-weight:700;letter-spacing:.06em;
  color:var(--muted);
  transition:.2s ease;font-family:inherit
}
.lang-btn.active{
  background:linear-gradient(135deg,var(--cyan),var(--blue),var(--purple));
  color:#fff;
  box-shadow:0 0 12px rgba(139,92,246,.4)
}
.lang-btn:not(.active):hover{color:var(--text)}
.lang-divider{width:1px;height:14px;background:rgba(139,92,246,.25)}

/* ── TEAM SZEKCIÓ ── */
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}
.profile-card{
  background:linear-gradient(160deg,rgba(139,92,246,.10),rgba(34,211,238,.04),rgba(255,255,255,.02));
  border:1px solid rgba(139,92,246,.18);
  border-radius:28px;overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.06);
  transition:.3s ease
}
.profile-card:hover{border-color:rgba(139,92,246,.4);box-shadow:0 16px 60px rgba(139,92,246,.15),inset 0 1px 0 rgba(255,255,255,.08)}
.profile-top{
  padding:32px 32px 24px;
  display:flex;gap:20px;align-items:flex-start;
  border-bottom:1px solid rgba(139,92,246,.1)
}
.profile-avatar{
  width:72px;height:72px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:900;letter-spacing:-.02em;
  border:2px solid rgba(139,92,246,.35)
}
.avatar-csaba{background:linear-gradient(135deg,rgba(139,92,246,.3),rgba(34,211,238,.2));color:#c4b5fd}
.avatar-chris{background:linear-gradient(135deg,rgba(34,211,238,.3),rgba(59,130,246,.2));color:#67e8f9}
.avatar-zoltan{background:linear-gradient(135deg,rgba(59,130,246,.3),rgba(139,92,246,.2));color:#93c5fd}
.avatar-krisztian{background:linear-gradient(135deg,rgba(34,211,238,.2),rgba(139,92,246,.3));color:#22d3ee}
.profile-avatar-photo{
  width:115px;height:115px;border-radius:50%;flex-shrink:0;
  overflow:hidden;
  border:2px solid rgba(139,92,246,.4);
  box-shadow:0 0 20px rgba(139,92,246,.3),0 0 8px rgba(34,211,238,.2)
}
.profile-photo{width:100%;height:100%;object-fit:cover;object-position:center top}
.profile-identity{flex:1}
.profile-identity h2{font-size:26px;font-weight:800;letter-spacing:-.03em;margin-bottom:8px}
.profile-role{color:var(--cyan);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.profile-location{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}
.profile-location svg{color:var(--cyan);flex-shrink:0}
.badge-lang{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.08em;margin-top:8px}
.badge-hu{background:rgba(139,92,246,.15);color:#c4b5fd;border:1px solid rgba(139,92,246,.3)}
.badge-en{background:rgba(34,211,238,.12);color:#67e8f9;border:1px solid rgba(34,211,238,.3)}
.profile-body{padding:24px 32px 32px;display:flex;flex-direction:column;gap:22px}
.profile-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--cyan);font-weight:700;margin-bottom:10px}
.summary-text{color:var(--muted);font-size:14px;line-height:1.7}
.timeline{display:flex;flex-direction:column;gap:10px}
.timeline-item{display:flex;gap:14px;align-items:flex-start}
.timeline-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--purple));flex-shrink:0;margin-top:5px}
.timeline-content{flex:1}
.timeline-period{font-size:11px;color:var(--cyan);font-weight:700;letter-spacing:.05em;margin-bottom:2px}
.timeline-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.4}
.timeline-org{font-size:13px;color:var(--muted)}
.skills-list{display:flex;flex-wrap:wrap;gap:8px}
.skill-pill{padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.2);color:var(--muted)}
.modules-row{display:flex;flex-wrap:wrap;gap:8px}
.mod-badge{padding:6px 12px;border-radius:10px;font-size:12px;font-weight:700;background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.2);color:#67e8f9}
@media(max-width:900px){
  .team-grid{grid-template-columns:1fr}
  .profile-top{flex-direction:row;align-items:center;gap:16px;padding:24px 20px}
  .profile-avatar-photo{width:88px;height:88px}
  .profile-identity h2{font-size:22px}
}

.profile-two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:600px){.profile-two-col{grid-template-columns:1fr}}

/* Mobil: a HU/EN nyelvi badge maradjon kompakt pill (fit-content, nem tördel) */
@media(max-width:768px){
  .badge-lang{
    display:inline-flex;
    width:fit-content;
    max-width:100%;
    align-self:flex-start;
    white-space:nowrap;
    padding:8px 16px;
  }
}

/* ── VÉLEMÉNYEK ── */
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:48px}
.review-card{
  background:linear-gradient(160deg,rgba(139,92,246,.10),rgba(34,211,238,.04),rgba(255,255,255,.02));
  border:1px solid rgba(139,92,246,.18);
  border-radius:24px;padding:32px;
  box-shadow:0 8px 40px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.06);
  display:flex;flex-direction:column;gap:18px;
  transition:.3s ease
}
.review-card:hover{
  border-color:rgba(139,92,246,.4);
  box-shadow:0 16px 60px rgba(139,92,246,.15),inset 0 1px 0 rgba(255,255,255,.08)
}
.review-card .stars{display:flex;gap:4px}
.review-card .stars svg{width:20px;height:20px;color:#fbbf24}
.review-text{color:var(--muted);font-size:15px;line-height:1.75}
.review-author{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:6px}
.review-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:1px solid rgba(103,232,249,.25)}
.review-author-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.review-name{font-weight:700;color:var(--text);font-size:15px}
.review-role{color:var(--cyan);font-size:13px}
@media(max-width:900px){.reviews-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════
   REWRITE v1 — meleg narancs CTA, hero-rotáció, kiemelés-variánsok
   ══════════════════════════════════════════ */
:root{ --accent-orange:#f97316; --accent-orange-2:#ea580c; }
.btn-primary{
  background:linear-gradient(135deg,#fb923c,#f97316,#ea580c);
  color:#fff;border:none;
  box-shadow:0 0 26px rgba(249,115,22,.42),0 6px 20px rgba(234,88,12,.25)
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 40px rgba(249,115,22,.6),0 8px 26px rgba(234,88,12,.35)
}

/* Hero rotátor — 3 szlogen keresztúsztatással */
.hero-rotator{position:relative;min-height:clamp(110px,16vw,180px)}
.hero-rotator .rot{position:absolute;left:0;right:0;opacity:0;transition:opacity .6s ease}
.hero-rotator .rot.active{opacity:1}

/* Kiemelés A) animált gradient-átsöprés (default) */
.hl-gradient .hl{
  background:linear-gradient(90deg,#fb923c,#f59e0b,#22d3ee,#fb923c);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  filter:drop-shadow(0 0 14px rgba(251,146,60,.38));
  animation:hl-sweep 5s linear infinite
}
@keyframes hl-sweep{to{background-position:200% center}}

/* Kiemelés B) meleg-narancs aláhúzás + glow */
.hl-underline .hl{
  color:#fff;
  background-image:linear-gradient(transparent 58%, rgba(249,115,22,.9) 58%);
  padding:0 .06em;border-radius:2px;
  filter:drop-shadow(0 0 10px rgba(249,115,22,.45))
}

@media(prefers-reduced-motion: reduce){
  .hero-rotator .rot{transition:none}
  .hl-gradient .hl{animation:none}
}

/* ══════════════════════════════════════════
   REWRITE v2 — CTA finomítás, egyoszlopos fejlécek, sorkizárás, scroll-reveal
   ══════════════════════════════════════════ */

/* Csak EGY hangsúlyos narancs gomb: a fő CTA filled, glow letompítva */
.btn-primary{
  background:linear-gradient(135deg,#fb923c,#f97316,#ea580c);
  box-shadow:0 6px 18px rgba(234,88,12,.28)
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(234,88,12,.38)
}
/* A menüsori "Jelentkezés" halványabb (ghost), hogy ne üsse a hero CTA-t */
.nav-links .btn-primary{
  background:transparent;
  border:1.5px solid rgba(249,115,22,.6);
  color:#fff;box-shadow:none
}
.nav-links .btn-primary:hover{
  background:rgba(249,115,22,.12);
  border-color:var(--accent-orange);
  box-shadow:none;transform:none
}

/* Egyoszlopos szekciófejlécek: a cím egy sorban, alatta a leírás */
.section-head{display:block}
.section-head h2{max-width:none}
.section-head p{margin-top:14px;max-width:820px}

/* Sorkizárás a tartalmi (apró betűs, többsoros) szövegekre */
.card p,.summary-text,.review-text{
  text-align:justify;text-justify:inter-word
}
/* A kártyák alatti üzenet kicsit kiemelve, hogy ne olvadjon bele */
.card p{color:#c3cde6}

/* Scroll-reveal: finom felúszás belépéskor */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
}


/* Fél-csillag (4,5★) */
.review-card .stars .half-star{position:relative;display:inline-block;width:20px;height:20px;line-height:0}
.review-card .stars .half-star svg{position:absolute;inset:0;width:20px;height:20px}
.review-card .stars .half-star .bg{color:rgba(251,191,36,.30)}
.review-card .stars .half-star .fg{color:#fbbf24;clip-path:inset(0 50% 0 0)}

/* Miért a Claude: forrás-sor */
.source-note{margin:26px 0 0;font-size:14px;color:var(--muted);text-align:center}
.source-note a{color:var(--cyan);text-decoration:none}
.source-note a:hover{text-decoration:underline}

/* A workshopon érintett eszközök: úszó logó-csík */
.tools-band{padding-bottom:34px}
.tool-marquee{
  position:relative;overflow:hidden;margin:32px auto 0;display:flex;padding:10px 0;
  width:min(1120px,calc(100% - 40px));
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)
}
.tool-track{display:flex;flex:0 0 auto;width:max-content;animation:tool-scroll 42s linear infinite}
.tool-marquee:hover .tool-track{animation-play-state:paused}
@keyframes tool-scroll{to{transform:translateX(-100%)}}
.tool-chip{
  display:flex;flex-direction:column;justify-content:center;flex:0 0 auto;
  margin-right:16px;padding:14px 24px;border-radius:14px;text-decoration:none;
  background:rgba(255,255,255,.04);border:1px solid rgba(103,232,249,.15);
  transition:border-color .2s ease,background .2s ease,transform .2s ease
}
.tool-chip:hover{border-color:rgba(34,211,238,.45);background:rgba(34,211,238,.08);transform:translateY(-2px)}
.tool-logo{height:22px;width:auto;margin-bottom:6px;opacity:.92}
.tool-name{color:var(--text);font-weight:700;font-size:16px;letter-spacing:-.01em}
.tool-sub{color:var(--muted);font-size:12.5px;margin-top:2px;letter-spacing:.02em}
@media(prefers-reduced-motion:reduce){
  .tool-marquee{-webkit-mask-image:none;mask-image:none}
  .tool-track{animation:none;flex-wrap:wrap;width:auto;justify-content:center;gap:12px}
  .tool-track[aria-hidden="true"]{display:none}
  .tool-chip{margin-right:0}
}

/* Beleegyező jelölőnégyzet linkjei */
.form-consent label a{color:var(--cyan);text-decoration:underline;text-underline-offset:2px}

/* Honeypot: ember nem látja, bot kitölti -> spam-szűrés */
.hp-field{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* Lebegő, mindig elérhető jelentkezés gomb */
.floating-cta{
  position:fixed;z-index:60;bottom:22px;right:max(22px, calc((100vw - 1120px) / 2 + 22px));
  opacity:0;visibility:hidden;transform:translateY(14px);pointer-events:none;
  box-shadow:0 12px 34px rgba(0,0,0,.45);
  transition:opacity .3s ease,transform .3s ease,visibility .3s
}
.floating-cta.show{opacity:1;visibility:visible;transform:none;pointer-events:auto}
@media(max-width:640px){
  .floating-cta{left:auto;right:16px;bottom:16px;width:auto;padding:12px 20px;font-size:14px;border-radius:999px}
}
@media(prefers-reduced-motion:reduce){
  .floating-cta{transition:opacity .15s linear}
}

/* Időpontok listája (Időpont szekció) — bannerszerű kártyák soronkénti gombbal */
.event-dates{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.date-card{display:flex;flex-wrap:wrap;align-items:center;gap:16px 28px;padding:18px 22px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(103,232,249,.18)}
.date-card--tbd{border-style:dashed;background:rgba(34,211,238,.05)}
.date-col{display:flex;align-items:center;gap:12px;color:var(--cyan)}
.date-col>div{display:flex;flex-direction:column}
.date-label{color:var(--muted);font-size:12px;letter-spacing:.04em;text-transform:uppercase}
.date-when{color:var(--text);font-weight:700;font-size:16px}
.date-where{color:var(--text);font-weight:600;font-size:15px}
.date-apply{margin-left:auto;white-space:nowrap}
@media(max-width:640px){ .date-apply{margin-left:0;width:100%;text-align:center} }

/* Ár-doboz (a kupon után): NETTÓ kiemelve, bruttó kicsiben, kedvezmény-plecsnik */
.price-box{margin:4px 0 18px;padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(103,232,249,.18)}
.price-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.price-badge{background:#f59e0b;color:#241300;font-weight:800;font-size:12px;padding:3px 10px;border-radius:999px;letter-spacing:.02em}
.price-badge--coupon{background:var(--cyan);color:#06283d}
.price-line{display:flex;align-items:baseline;flex-wrap:wrap;gap:10px}
.price-orig-net{color:var(--muted);text-decoration:line-through;font-size:16px}
.price-now-net{color:var(--text);font-weight:800;font-size:26px;letter-spacing:-.02em}
.price-gross{color:var(--muted);font-size:13px;margin-top:4px}

/* Időpont legördülő (mint a többi mező) */
.form-group select{
  width:100%;padding:12px 14px;border-radius:10px;font-size:15px;font-family:inherit;
  background:rgba(255,255,255,.05);border:1px solid rgba(103,232,249,.2);color:var(--text);
  -webkit-appearance:none;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3c0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center
}
.form-group select:focus{outline:none;border-color:var(--cyan)}
.form-group select option{background:#0b1020;color:var(--text)}

/* Kupon mező */
.coupon-input{display:flex;gap:8px}
.coupon-input input{flex:1}
.btn-ghost{
  background:transparent;border:1px solid rgba(103,232,249,.4);color:var(--cyan);
  padding:0 18px;border-radius:10px;font-weight:600;cursor:pointer;white-space:nowrap;font-size:14px
}
.btn-ghost:hover{background:rgba(34,211,238,.1)}
.btn-ghost:disabled{opacity:.5;cursor:default}
.coupon-msg{margin:8px 0 0;font-size:13px;min-height:1em}
.price-summary{margin:6px 0 16px;font-weight:800;color:var(--text);font-size:17px;text-align:right}

/* Cookie-consent banner */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:1000;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;
  padding:16px 20px;background:rgba(15,18,28,.97);border-top:1px solid rgba(255,255,255,.12);
  box-shadow:0 -8px 24px rgba(0,0,0,.35);backdrop-filter:blur(6px)
}
.cookie-text{margin:0;max-width:760px;font-size:14px;line-height:1.6;color:var(--text)}
.cookie-text a{color:var(--cyan)}
.cookie-actions{display:flex;gap:10px;flex:0 0 auto}
@media (max-width:640px){
  .cookie-banner{flex-direction:column;align-items:stretch;text-align:center}
  .cookie-actions{justify-content:center}
}
