/* ========= Brand palette ========= */
:root {
    /* alapszínek (Bootstrap színváltozók) */
    --bs-primary: #2563eb;               /* Blue 600 */
    --bs-primary-rgb: 37, 99, 235;

    --bs-secondary: #334155;             /* Slate 700 */
    --bs-secondary-rgb: 51, 65, 85;

    --bs-success: #22c55e;
    --bs-success-rgb: 34, 197, 94;

    --bs-danger: #ef4444;
    --bs-danger-rgb: 239, 68, 68;

    --bs-warning: #f59e0b;
    --bs-warning-rgb: 245, 158, 11;

    --bs-info: #06b6d4;                  /* Cyan 500 */
    --bs-info-rgb: 6, 182, 212;

    --bs-dark: #0f172a;
    --bs-dark-rgb: 15, 23, 42;

    /* brand gradiensek */
    --brand-grad: linear-gradient(90deg, #2563eb 0%, #06b6d4 50%, #7c3aed 100%);
    --brand-grad-hover: linear-gradient(90deg, #1e40af 0%, #0891b2 50%, #6d28d9 100%);
    --brand-shadow: rgba(37, 99, 235, .35);
}

/* ========= Buttons ========= */
.btn-primary {
    background-image: var(--brand-grad);
    background-size: 200% 100%;
    background-position: 0% 50%;
    border: 0;
    color: #fff;
    font-weight: 600;
    transition: background-position .25s ease, transform .06s ease;
}
.btn-primary:hover,
.btn-primary:focus {
    background-image: var(--brand-grad-hover);
    background-position: 100% 50%;
    color: #fff;
}
.btn-primary:active {
    transform: translateY(1px);
}

/* Körvonalas változat – finom gradientes border és szöveg */
.btn-outline-primary {
    color: #2563eb;
    border: 2px solid rgba(var(--bs-primary-rgb), .35);
    background: transparent;
    font-weight: 600;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    color: #fff;
    border-color: transparent;
    background-image: var(--brand-grad);
}

/* Kis segédosztály a gradientes hátterekhez */
.bg-primary-gradient {
    background-image: var(--brand-grad) !important;
}
.text-primary-gradient {
    background-image: var(--brand-grad);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

/* ========= Links ========= */
a, .link-primary {
    color: #2563eb;
}
a:hover, .link-primary:hover {
    color: #06b6d4;
}

/* ========= Forms / focus ring ========= */
.form-control:focus, .form-select:focus, .btn-check:focus + .btn, .btn:focus {
    box-shadow: 0 0 0 .25rem var(--brand-shadow) !important;
    border-color: rgba(var(--bs-primary-rgb), .35);
}

/* ========= Badges, Alerts, Progress ========= */
.badge.bg-primary {
    background-image: var(--brand-grad);
    border: 0;
}
.alert-primary {
    color: #0b3bba;
    background-color: rgba(var(--bs-primary-rgb), .08);
    border-color: rgba(var(--bs-primary-rgb), .18);
}
.progress-bar.bg-primary,
.progress-bar {
    background-image: var(--brand-grad);
}

/* ========= Nav / Pagination ========= */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background-image: var(--brand-grad);
    border: 0;
}
.page-item.active .page-link {
    background-image: var(--brand-grad);
    border-color: transparent;
}
.page-link {
    color: #2563eb;
}
.page-link:hover {
    color: #06b6d4;
}

/* ========= Cards / subtle surfaces ========= */
.card-border-primary {
    border: 1px solid rgba(var(--bs-primary-rgb), .18);
}


.hero__v6 .hero-subtitle:hover,
.hero__v6 .hero-subtitle:focus{
    background-image: var(--brand-grad-hover) !important;
}

.hero__v6 .hero-img .rounded-5{
    border-radius: 150px!important;
}

.mission-statement {
    background: #fff;
    border-left: 5px solid #5a2be7; /* lila */
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.mission-statement h4 {
    font-size: 0.9rem;
    text-transform: uppercase;
    font-weight: 600;
    color: #666;
    margin-bottom: 5px;
}
.mission-statement p {
    font-size: 1rem;
    color: #333;
}
.profile-pic {
    border-radius: 50%;
    border: 4px solid transparent;
    background: linear-gradient(135deg, #3B82F6, #9333EA);
    padding: 4px;
}

.myhero-img {
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.08);
}
.mission-icon .img-fluid{
    border-radius: 50px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08);
}


/* ===== Stats (light skin by default) ===== */
:root{
    --vz-indigo: #6366f1;   /* indigo-500 */
    --vz-blue:   #3b82f6;   /* blue-500 */
    --vz-ink:    #111827;   /* gray-900 */
    --vz-text:   #374151;   /* gray-700 */
}

.stats__v3 .content{
    position: relative;
    overflow: hidden;
    padding: 36px 28px;
    background: linear-gradient(160deg, rgba(99,102,241,.08), rgba(59,130,246,.06));
    border: 1px solid rgba(99,102,241,.15);
    border-radius: 18px;
    box-shadow: 0 12px 28px rgba(17,24,39,.08);
}

/* finom fényfolt bal-fent */
.stats__v3 .content::before{
    content:"";
    position:absolute;
    inset:-120px auto auto -120px;
    width:320px;
    height:320px;
    border-radius:50%;
    background: radial-gradient(closest-side, rgba(99,102,241,.18), transparent 70%);
    pointer-events:none;
}

/* a három dísz-ív a jobb alsó sarokban */
.stats__v3 .rounded-borders > div{
    position:absolute;
    right:-180px;
    bottom:-180px;
    border-radius:50%;
    border:2px solid rgba(17,24,39,.08);
    pointer-events:none;
}
.stats__v3 .rounded-border-1{
    width:520px;
    height:520px;
    opacity:.9;
}
.stats__v3 .rounded-border-2{
    width:600px;
    height:600px;
    opacity:.7;
}
.stats__v3 .rounded-border-3{
    width:680px;
    height:680px;
    opacity:.5;
}

/* tartalom tipó + ritmus */
.stats__v3 .stat-item{
    padding: 8px 14px;
}
.stats__v3 .stat-item h3{
    color: var(--vz-ink);
    font-weight: 800;
    letter-spacing: .2px;
    line-height: 1.1;
    font-size: clamp(2rem, 3vw, 2.5rem);
    margin-bottom: .35rem;
}
.stats__v3 .stat-item h3 span:last-child{
    margin-left: 2px;
}
.stats__v3 .stat-item p{
    color: var(--vz-text);
}
.stats__v3 .stat-item p.fs-6{
    opacity: .9;
}

/* rács-reszponzivitás */
@media (max-width: 991.98px){
    .stats__v3 .content{
	padding: 28px 22px;
    }
}
@media (max-width: 767.98px){
    .stats__v3 .content{
	padding: 24px 18px;
    }
    .stats__v3 .stat-item{
	margin-bottom: 16px;
    }
    .stats__v3 .rounded-borders > div{
	transform: scale(.8);
    }
}

/* ===== Opcionális: Blue skin =====
   Használat:  <div class="d-flex ... content rounded-4 is-blue"> ... */
.stats__v3 .content.is-blue{
    background: linear-gradient(135deg, #2f6df6, #6a5cff);
    border: 0;
    box-shadow: 0 16px 36px rgba(31,41,55,.18);
}
.stats__v3 .content.is-blue .stat-item h3{
    color:#fff;
}
.stats__v3 .content.is-blue .stat-item p{
    color: rgba(255,255,255,.92);
}
.stats__v3 .content.is-blue .rounded-borders > div{
    border-color: rgba(255,255,255,.16);
}
.stats__v3 .content.is-blue::before{
    background: radial-gradient(closest-side, rgba(255,255,255,.25), transparent 70%);
}
/* ---------- Services v3 ---------- */
.services__v3 .subtitle{
    display:inline-block;
    padding:6px 12px;
    border-radius:10px;
    font-weight:600;
    font-size:.75rem;
    letter-spacing:.06em;
    color:#fff;
    background:linear-gradient(135deg,var(--bs-primary),#7b61ff);
    box-shadow:0 4px 16px rgba(123,97,255,.25);
}

.services__v3 .service-card{
    background:var(--bs-body-bg);
    border:1px solid var(--bs-border-color);
    box-shadow:0 2px 12px rgba(0,0,0,.04);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    position:relative;
}

@media (hover:hover){
    .services__v3 .service-card:hover{
	transform:translateY(-4px);
	border-color:color-mix(in srgb, var(--bs-primary), transparent 70%);
	box-shadow:0 12px 30px rgba(15, 23, 42, .12);
    }
}

/* ikon badge (kör, brand gradiens, finom árnyék) */
.services__v3 .icon{
    position:relative;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:60px;
    height:60px;
    isolation:isolate; /* hogy a ::before a háttérben maradjon */
}
.services__v3 .icon::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:999px;
    background:radial-gradient(120% 120% at 20% 20%, #8da8ff 0%, #7b61ff 30%, var(--bs-primary) 100%);
    box-shadow:0 6px 18px rgba(123,97,255,.35);
    opacity:.95;
}
.services__v3 .icon i{
    position:relative;
    z-index:1;
    font-size:1.35rem; /* fs-1 maradhat, ez csak finomítás */
    color:#fff;                     /* fehér piktogram a gradiencen */
    filter:drop-shadow(0 1px 1px rgba(0,0,0,.2));
}

/* címsor + tagline ritmus */
.services__v3 h3{
    font-weight:700;
    margin-bottom:.25rem!important;
}
.services__v3 .fst-italic{
    color:var(--bs-secondary-color);
    font-weight:500;
}

/* kártya belső tipó finomítás */
.services__v3 .service-card p{
    line-height:1.6;
}

/* rács távolság és kerekítés konzisztencia */
.services__v3 .row.g-4 > [class*="col"] .service-card{
    border-radius:16px;
}

/* sötét mód (ha van) */
@media (prefers-color-scheme: dark){
    .services__v3 .service-card{
	background:#0f1220;
	border-color:rgba(255,255,255,.08);
	box-shadow:0 2px 14px rgba(0,0,0,.35);
    }
    .services__v3 .icon::before{
	box-shadow:0 10px 24px rgba(123,97,255,.45);
    }
}


/* --- Services: pro icon badges & cards --- */
.services__v3 .service-card, .testimonial{
    background:#fff;
    border:1px solid rgba(17, 24, 39, .08);           /* finom határvonal */
    border-radius:16px;
    transition: box-shadow .25s ease, transform .25s ease, border-color .25s ease;
}

.services__v3 .service-card:hover, .testimonial:hover{
    transform: translateY(-2px);
    border-color: rgba(99,102,241,.35);               /* primary-400 */
    box-shadow: 0 12px 30px rgba(17, 24, 39, .08),
	0 2px 8px rgba(99,102,241,.15);
}

/* Ikon-badge (egységes méret + gyűrű) */
.services__v3 .icon-badge{
    --size: 52px;
    width: var(--size);
    height: var(--size);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    position: relative;
    isolation: isolate;
    background: #f8fafc;                               /* világos háttér */
    box-shadow: inset 0 0 0 1px rgba(17,24,39,.06);    /* vékony kontúr */
}

/* külső, finom színes gyűrű */
.services__v3 .icon-badge::before{
    content:"";
    position:absolute;
    inset:-6px;
    border-radius:inherit;
    background:
	radial-gradient(60% 60% at 50% 40%,
	rgba(99,102,241,.25), transparent 60%) ,        /* kék aura */
	radial-gradient(60% 60% at 60% 70%,
	rgba(124,58,237,.18), transparent 60%);         /* lila aura */
    z-index:-1;
    filter: blur(6px);
    opacity:.75;
    transition: opacity .25s ease, transform .25s ease;
}

/* ikon (egységes méret/szín) */
.services__v3 .icon-badge i{
    font-size: 1.55rem;                                 /* ~25px */
    color: #3b82f6;                                     /* primary-500 */
    transition: transform .25s ease, color .25s ease;
}

/* hover: ikon és aura finoman mozdul */
.services__v3 .service-card:hover .icon-badge i{
    transform: translateY(-2px);
    color: #6366f1;                                     /* primary-500 → indigo */
}
.services__v3 .service-card:hover .icon-badge::before{
    opacity: 1;
    transform: scale(1.03);
}

/* alcím (tagline) finom szürke és dőlt – már használod, csak biztosra: */
.services__v3 .service-card .fst-italic{
    color: #6b7280 !important;                          /* slate-500 */
}

.service-card .bi{
    display: block;
    position: absolute;
    right: -5px;
    top: -5px;
    background:radial-gradient(120% 120% at 20% 20%, #8da8ff 0%, #7b61ff 30%, var(--bs-primary) 100%);
    height: 50px;
    width: 50px;
    border-radius: 25px;
    color: #fff!important;
    font-size: 30px!important;
    text-align: center;
}

/* sötét mód támogatás (ha használsz) */
@media (prefers-color-scheme: dark){
    .services__v3 .service-card{
	background: #0b1020;
	border-color: rgba(255,255,255,.06);
    }
    .services__v3 .icon-badge{
	background: #0e1426;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
    }
    .services__v3 .icon-badge i{
	color:#8ea2ff;
    }
}

.contact-left a{
    color: var(--bs-body-color);
    text-decoration: none;
}
.contact-left a:hover{
    color:#8ea2ff;
}

.cta-gradient{
    background: linear-gradient(120deg,#6a5cff, #7b5dff, #31c6ff);
    background-size: 200% 200%;
    animation: gradientMove 8s ease infinite;
    position: relative;
}
@keyframes gradientMove{
    0%{
	background-position:0% 50%
    }
    50%{
	background-position:100% 50%
    }
    100%{
	background-position:0% 50%
    }
}
.glass-btn{
    backdrop-filter: blur(6px);
    border-color: rgba(255,255,255,.6)!important;
    background: rgba(255,255,255,.08);
}
.sparkle{
    position:absolute;
    width:10px;
    height:10px;
    border-radius:50%;
    background: rgba(255,255,255,.7);
    filter: blur(1px);
    animation: float 10s linear infinite;
}
.s1{
    top:10%;
    left:8%
}
.s2{
    bottom:12%;
    right:10%
}
.s3{
    top:20%;
    right:25%
}
@keyframes float{
    0%{
	transform:translateY(0)
    }
    50%{
	transform:translateY(-12px)
    }
    100%{
	transform:translateY(0)
    }
}

.logo-pill{
    padding:.4rem .8rem;
    border-radius:999px;
    background:#f3f4f6;
    color:#6b7280;
    transition: all .2s ease;
    border:1px solid #e5e7eb;
}
.logo-pill:hover{
    background:#fff;
    color:#111827;
    transform: translateY(-2px);
    box-shadow:0 6px 20px rgba(0,0,0,.07)
}

.backtop{
    position: fixed;
    right: 18px;
    bottom: 18px;
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    animation: pulse 2.2s infinite;
}
@keyframes pulse {
    0%{
	box-shadow:0 0 0 0 rgba(98,84,255,.45)
    }
    70%{
	box-shadow:0 0 0 18px rgba(98,84,255,0)
    }
    100%{
	box-shadow:0 0 0 0 rgba(98,84,255,0)
    }
}
.footer-section a.btn:hover{
    background-color: #000!important;
}

/* Contact (no-form) polish */
.contact__v2 .icon {
  width: 44px; height: 44px;
  background: rgba(13,110,253,.08); /* halvány primary */
  font-size: 1.2rem;
}
.contact__v2 .icon i { line-height: 1; }

.contact__v2 .contact-left a:hover { text-decoration: underline; }

.contact__v2 .contact-card {
  border-radius: 1rem;
}
.contact__v2 .contact-card .btn-lg {
  padding-top: .9rem; padding-bottom: .9rem;
  border-radius: .9rem;
}
.contact__v2 .contact-card .btn-outline-primary:hover {
  color: #fff;
}

/* LANG SWITCH – gradient + glassy pill */
.lang-switch {
  --pill-radius: 999px;
  --btn-pad-x: .9rem;
  --btn-pad-y: .35rem;
  --border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--pill-radius);
  padding: .15rem;             /* keret a gombok körül */
}
[data-bs-theme="dark"] .lang-switch {
  --border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 2px 14px rgba(0,0,0,.35);
}
.lang-switch .lang-btn {
  position: relative;
  border: var(--border);
  border-radius: calc(var(--pill-radius) - .15rem);
  padding: var(--btn-pad-y) var(--btn-pad-x);
  line-height: 1.1;
  font-weight: 600;
  background:
    linear-gradient(135deg, rgba(255,255,255,.9), rgba(255,255,255,.65));
  transition: transform .15s ease, background-position .35s ease, box-shadow .2s ease, color .2s ease;
  background-size: 200% 100%;
  background-position: 0% 0%;
  color: #0b1220;
}
[data-bs-theme="dark"] .lang-switch .lang-btn {
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  color: #e8eef9;
}

/* aktív állapot – élő, átmenetes primary */
.lang-switch .lang-btn.active {
  color: #fff;
  background:
    linear-gradient(135deg, var(--bs-primary), #00c7ff);
  box-shadow: 0 6px 18px rgba(13,110,253,.35);
  pointer-events: none;
}
.lang-switch .lang-btn:hover:not(.active) {
  background-position: 100% 0%;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
}

/* kis flag + spacing */
.lang-switch .flag { display:inline-block; margin-right:.35rem; }
.lang-switch .lbl   { letter-spacing:.3px; }

/* finom méret egységesítés a headerben */
.header-social .lang-switch { margin-right: .25rem; }
.header-social .btn-primary { border-radius: .75rem; }
