/* ═══════════════════════════════════════════════════════════
   AlfoldKlima — css/style.css
   Brand: #254B7C (kek) + #E6760F (narancs)
   Font: Inter
   ═══════════════════════════════════════════════════════════ */

/* ── Reset & Base ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.7;color:#2D3748;background:#f8f9fb}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{color:#1A202C;line-height:1.2;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:1.2rem}
input,select,textarea,button{font-family:inherit;font-size:inherit}

/* ── CSS Variables ──────────────────────────────────────── */
:root{
    --clr-primary:#E6760F;
    --clr-primary-dim:#C96410;
    --clr-primary-light:rgba(230,118,15,0.08);
    --clr-secondary:#254B7C;
    --clr-secondary-dim:#1A3A63;
    --clr-secondary-light:rgba(37,75,124,0.06);
    --clr-dark:#1A202C;
    --clr-text:#2D3748;
    --clr-muted:#718096;
    --clr-border:#E2E8F0;
    --clr-bg:#f8f9fb;
    --clr-bg-alt:#ffffff;
    --clr-footer:#1A202C;
    --radius:12px;
    --radius-sm:8px;
    --radius-lg:20px;
    --shadow:0 1px 3px rgba(0,0,0,0.06),0 4px 12px rgba(0,0,0,0.04);
    --shadow-lg:0 4px 24px rgba(0,0,0,0.08);
    --container:1180px;
    --transition:0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ── Skip link (akadálymentesség) ──────────────────────── */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--clr-primary);color:#fff;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;z-index:10000;font-size:0.9rem}
.skip-link:focus{top:16px}

/* ── Container ──────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ── Section Base ───────────────────────────────────────── */
.section{padding:80px 0}
.section--alt{background:var(--clr-bg-alt)}
.section__header{text-align:center;max-width:640px;margin:0 auto 48px}
.section__header p{color:var(--clr-muted);margin-top:12px;font-size:1.05rem}

/* ── Buttons ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-sm);font-weight:600;font-size:1rem;cursor:pointer;transition:var(--transition);border:2px solid transparent}
.btn--primary{background:var(--clr-primary);color:#fff;border-color:var(--clr-primary)}
.btn--primary:hover{background:var(--clr-primary-dim);border-color:var(--clr-primary-dim);transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn--outline{background:transparent;color:var(--clr-secondary);border-color:var(--clr-secondary)}
.btn--outline:hover{background:var(--clr-secondary);color:#fff}
.btn--white{background:#fff;color:var(--clr-primary);border-color:#fff}
.btn--white:hover{background:#f0f0f0}
.btn--lg{padding:16px 32px;font-size:1.05rem}
.btn--full{width:100%;justify-content:center}
.btn:disabled{opacity:0.6;cursor:not-allowed;transform:none!important}

/* ══════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════ */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.95);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:var(--transition)}
.header--scrolled{border-bottom-color:var(--clr-border);box-shadow:0 1px 8px rgba(0,0,0,0.04)}
.header .container{max-width:var(--container)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:80px}
.header__logo img{height:60px;width:auto}
.header__right{display:flex;align-items:center;gap:8px}
.header__nav{display:flex;gap:4px}
.header__nav a{padding:8px 14px;border-radius:var(--radius-sm);color:var(--clr-text);font-weight:500;font-size:0.92rem;transition:var(--transition)}
.header__nav a:hover,.header__nav a.active{color:var(--clr-primary);background:var(--clr-primary-light)}
.header__phone{display:flex;align-items:center;gap:6px;padding:8px 14px;color:var(--clr-secondary);font-weight:600;font-size:0.92rem;border-radius:var(--radius-sm);transition:var(--transition)}
.header__phone:hover{background:var(--clr-secondary-light)}
.header__phone i{color:var(--clr-primary)}
.header__cta{padding:10px 20px;background:var(--clr-primary);color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:0.92rem;transition:var(--transition)}
.header__cta:hover{background:var(--clr-primary-dim);transform:translateY(-1px)}
.header__back{display:flex;align-items:center;gap:8px;color:var(--clr-muted);font-size:0.92rem}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--clr-dark);border-radius:2px;transition:var(--transition)}

/* Mobile Nav */
.mobile-nav{position:fixed;inset:0;z-index:2000;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transform:translateX(100%);transition:transform 0.35s ease;opacity:0;pointer-events:none}
.mobile-nav.active{transform:translateX(0);opacity:1;pointer-events:all}
.mobile-nav__close{position:absolute;top:20px;right:20px;font-size:1.5rem;cursor:pointer;color:var(--clr-dark);padding:8px}
.mobile-nav__links{display:flex;flex-direction:column;align-items:center;gap:16px}
.mobile-nav__links a{font-size:1.3rem;font-weight:600;color:var(--clr-dark)}
.mobile-nav__phone{display:flex;align-items:center;gap:8px;color:var(--clr-secondary);font-weight:600;font-size:1.1rem}
.mobile-nav__cta{padding:14px 32px;background:var(--clr-primary);color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:1.1rem}

/* Sticky CTA bar */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1500;background:#fff;border-top:1px solid var(--clr-border);padding:10px 16px;gap:10px;box-shadow:0 -2px 12px rgba(0,0,0,0.08);transform:translateY(100%);transition:transform 0.3s ease}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta__phone{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:12px 16px;background:var(--clr-secondary);color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:0.9rem}
.sticky-cta__btn{flex:1;display:flex;align-items:center;justify-content:center;padding:12px 16px;background:var(--clr-primary);color:#fff;border-radius:var(--radius-sm);font-weight:600;font-size:0.9rem}

/* ── Breadcrumb ───────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:0.85rem;margin-bottom:12px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,0.7);transition:var(--transition)}
.breadcrumb a:hover{color:#fff}
.breadcrumb__sep{color:rgba(255,255,255,0.4);font-size:0.7rem}
.breadcrumb__current{color:rgba(255,255,255,0.9);font-weight:500}

/* ── Social share ─────────────────────────────────────── */
.share-bar{display:flex;align-items:center;gap:10px;margin-top:40px;padding-top:24px;border-top:1px solid var(--clr-border)}
.share-bar__label{font-size:0.9rem;color:var(--clr-muted);font-weight:500}
.share-bar__btn{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.95rem;color:#fff;transition:var(--transition)}
.share-bar__btn:hover{transform:scale(1.1)}
.share-bar__btn--fb{background:#1877F2}
.share-bar__btn--wa{background:#25D366}
.share-bar__btn--email{background:var(--clr-secondary)}

/* ── Kapcsolódó cikkek ─────────────────────────────────── */
.related-posts{margin-top:56px;padding-top:40px;border-top:1px solid var(--clr-border)}
.related-posts h3{text-align:center;margin-bottom:24px;font-size:1.4rem}

/* ── Email feliratkozás ────────────────────────────────── */
.subscribe-form{display:flex;gap:8px;max-width:440px;margin:0 auto}
.subscribe-form__input{flex:1;padding:14px 16px;border:2px solid var(--clr-border);border-radius:var(--radius-sm);font-size:1rem;transition:var(--transition)}
.subscribe-form__input:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px var(--clr-primary-light)}
@media(max-width:480px){.subscribe-form{flex-direction:column}.subscribe-form .btn{width:100%;justify-content:center}}

/* ── Szezonális banner ─────────────────────────────────── */
.season-banner{background:linear-gradient(135deg,#E6760F,#C96410);color:#fff;padding:12px 0;text-align:center}
.season-banner__inner{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;font-size:0.95rem}
.season-banner__inner i{font-size:1.2rem}
.season-banner__inner a{color:#fff;text-decoration:underline;font-weight:600}
.season-banner__inner a:hover{text-decoration:none}

/* ══════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════ */
.hero{padding:120px 0 60px;background:var(--clr-bg-alt);overflow:hidden}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--clr-secondary-light);color:var(--clr-secondary);border-radius:40px;font-size:0.85rem;font-weight:600;margin-bottom:24px}
.hero__accent{color:var(--clr-primary)}
.hero__sub{font-size:1.15rem;color:var(--clr-muted);margin:20px 0 32px;max-width:480px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}
.hero__visual{display:flex;justify-content:center}
.hero__illustration{width:100%;max-width:480px}
.hero-svg{width:100%;height:auto}

/* Hero SVG — belépő animációk */
.hero-svg__house{animation:fadeSlideUp 0.8s ease-out both}
.hero-svg__ac{animation:fadeSlideUp 0.8s ease-out 0.3s both}
.hero-svg__temp{animation:fadeScale 0.6s ease-out 0.6s both}
.hero-svg__temp-outside{animation:fadeScale 0.6s ease-out 0.7s both}
.hero-svg__badge{animation:fadeScale 0.6s ease-out 0.8s both}

@keyframes fadeSlideUp{
    from{opacity:0;transform:translateY(20px)}
    to{opacity:1;transform:translateY(0)}
}
@keyframes fadeScale{
    from{opacity:0;transform:scale(0.7)}
    to{opacity:1;transform:scale(1)}
}

/* ═══ Nyár/Tél ciklus — 6s (3s nyár + 3s tél) ═══ */

/* Nap: látható nyáron, eltűnik télen */
.hero-svg__sun{animation:sunCycle 6s ease-in-out infinite}
.sun-rays{animation:raysSpin 6s linear infinite}
@keyframes sunCycle{
    0%,45%{opacity:1;transform:translateY(0)}
    47%,97%{opacity:0;transform:translateY(-15px)}
    99%,100%{opacity:1;transform:translateY(0)}
}
@keyframes raysSpin{
    0%{transform:rotate(0deg);transform-origin:150px 42px}
    100%{transform:rotate(360deg);transform-origin:150px 42px}
}

/* Felhő: láthatatlan nyáron, megjelenik télen */
.hero-svg__cloud{opacity:0;animation:cloudCycle 6s ease-in-out infinite}
@keyframes cloudCycle{
    0%,45%{opacity:0;transform:translateY(-10px)}
    48%,97%{opacity:1;transform:translateY(0)}
    99%,100%{opacity:0;transform:translateY(-10px)}
}

/* Hóréteg a tetőn: csak télen látható */
.hero-svg__snow-roof{opacity:0;animation:snowRoofCycle 6s ease-in-out infinite}
@keyframes snowRoofCycle{
    0%,50%{opacity:0}
    55%,97%{opacity:1}
    99%,100%{opacity:0}
}

/* Hó: láthatatlan nyáron, hull télen */
.hero-svg__snow{opacity:0;animation:snowCycle 6s ease-in-out infinite}
@keyframes snowCycle{
    0%,45%{opacity:0}
    48%,97%{opacity:1}
    99%,100%{opacity:0}
}
/* Ház melletti hópelyhek — teljes magasságban hullanak */
.snowflake{animation:snowFallFull 4s linear infinite}
.sf-1{animation-delay:0s}
.sf-2{animation-delay:0.6s}
.sf-3{animation-delay:0.3s}
.sf-4{animation-delay:0.9s}
.sf-7{animation-delay:1.2s}
.sf-8{animation-delay:0.5s}
@keyframes snowFallFull{
    0%{transform:translateY(0) translateX(0);opacity:0.7}
    25%{transform:translateY(90px) translateX(6px)}
    50%{transform:translateY(180px) translateX(-4px)}
    75%{transform:translateY(280px) translateX(5px)}
    100%{transform:translateY(370px) translateX(0);opacity:0.2}
}
/* Tető fölötti hópelyhek — csak a tetővonalig hullanak (~100px) */
.sf-roof-1,.sf-roof-2,.sf-roof-3{animation:snowFallRoof 3s linear infinite}
.sf-roof-1{animation-delay:0.2s}
.sf-roof-2{animation-delay:0.8s}
.sf-roof-3{animation-delay:1.4s}
@keyframes snowFallRoof{
    0%{transform:translateY(0) translateX(0);opacity:0.7}
    80%{transform:translateY(90px) translateX(4px);opacity:0.5}
    100%{transform:translateY(105px) translateX(3px);opacity:0}
}

/* Légáram — kék nyáron, piros télen + hullámzó mozgás */
.airflow-line{animation:airflowMove 2.5s ease-in-out infinite, airflowColor 6s ease-in-out infinite}
.airflow-2{animation-delay:0.4s, 0s}
.airflow-3{animation-delay:0.8s, 0s}
@keyframes airflowMove{
    0%,100%{opacity:0.2;transform:translateX(0)}
    50%{opacity:0.7;transform:translateX(-12px)}
}
@keyframes airflowColor{
    0%,45%{stroke:#3B82F6}
    47%{stroke:#9CA3AF}
    48%,97%{stroke:#EF4444}
    99%,100%{stroke:#3B82F6}
}

/* Belső hőfok — háttér és szöveg váltás */
.temp-inner-bg{animation:tempInnerBg 6s ease-in-out infinite}
.temp-inner-summer{animation:showSummer 6s ease-in-out infinite}
.temp-inner-winter{animation:showWinter 6s ease-in-out infinite}
@keyframes tempInnerBg{
    0%,45%{fill:#254B7C;opacity:0.12}
    48%,97%{fill:#E6760F;opacity:0.12}
    99%,100%{fill:#254B7C;opacity:0.12}
}
@keyframes showSummer{
    0%,45%{opacity:1;fill:#254B7C}
    47%{opacity:0;fill:#254B7C}
    48%,97%{opacity:0}
    99%,100%{opacity:1;fill:#254B7C}
}
@keyframes showWinter{
    0%,45%{opacity:0}
    47%{opacity:0}
    48%,97%{opacity:1;fill:#E6760F}
    99%,100%{opacity:0}
}

/* Külső hőfok — háttér és szöveg váltás */
.temp-outer-bg{animation:tempOuterBg 6s ease-in-out infinite}
.temp-outer-summer{animation:showSummer 6s ease-in-out infinite;fill:#E6760F}
.temp-outer-winter{animation:showWinter 6s ease-in-out infinite;fill:#3B82F6}
@keyframes tempOuterBg{
    0%,45%{fill:#E6760F;opacity:0.12}
    48%,97%{fill:#3B82F6;opacity:0.12}
    99%,100%{fill:#E6760F;opacity:0.12}
}

/* Külső szöveg színek felülírása */
.temp-outer-summer{animation:showSummerOuter 6s ease-in-out infinite}
.temp-outer-winter{animation:showWinterOuter 6s ease-in-out infinite}
@keyframes showSummerOuter{
    0%,45%{opacity:1}
    47%,97%{opacity:0}
    99%,100%{opacity:1}
}
@keyframes showWinterOuter{
    0%,45%{opacity:0}
    47%{opacity:0}
    48%,97%{opacity:1}
    99%,100%{opacity:0}
}

/* ══════════════════════════════════════════════════════════
   TRUST BAR
   ══════════════════════════════════════════════════════════ */
.trust-bar{background:var(--clr-secondary);color:#fff;padding:24px 0}
.trust-bar__grid{display:flex;justify-content:center;flex-wrap:wrap;gap:24px 48px}
.trust-bar__item{display:flex;align-items:center;gap:10px;font-size:0.95rem}
.trust-bar__item i{color:var(--clr-primary);font-size:1.2rem}

/* ══════════════════════════════════════════════════════════
   WHY US
   ══════════════════════════════════════════════════════════ */
.why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why__card{background:var(--clr-bg-alt);padding:32px 24px;border-radius:var(--radius);border:1px solid var(--clr-border);transition:var(--transition)}
.why__card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.why__icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--clr-primary-light);color:var(--clr-primary);border-radius:var(--radius-sm);font-size:1.3rem;margin-bottom:16px}
.why__card h3{margin-bottom:8px}
.why__card p{color:var(--clr-muted);font-size:0.92rem;line-height:1.6}

/* ══════════════════════════════════════════════════════════
   TYPES (Szerelesi tipusok)
   ══════════════════════════════════════════════════════════ */
.types__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.types__card{background:var(--clr-bg);padding:32px 28px;border-radius:var(--radius);border:2px solid var(--clr-border);text-align:center;position:relative;transition:var(--transition)}
.types__card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-lg)}
.types__badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--clr-primary);color:#fff;padding:4px 16px;border-radius:20px;font-size:0.8rem;font-weight:600;white-space:nowrap}
.types__illustration{margin:-8px -8px 20px;padding:12px 0}
.types__illustration svg{width:100%;max-width:260px;height:auto;margin:0 auto;display:block}
.types__card h3{font-size:1.3rem;margin-bottom:12px;color:var(--clr-secondary)}
.types__card p{color:var(--clr-muted);font-size:0.92rem;margin-bottom:20px;min-height:64px}
.types__price{font-size:1.6rem;font-weight:800;color:var(--clr-primary)}
.types__note{font-size:0.8rem;color:var(--clr-muted)}

/* ══════════════════════════════════════════════════════════
   PRICING (Klima berendezesek)
   ══════════════════════════════════════════════════════════ */
.pricing__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pricing__card{background:var(--clr-bg-alt);padding:32px 28px;border-radius:var(--radius);border:2px solid var(--clr-border);text-align:center;transition:var(--transition)}
.pricing__card--featured{border-color:var(--clr-primary);box-shadow:0 0 0 2px var(--clr-primary-light),var(--shadow-lg);transform:scale(1.03)}
.pricing__tier{display:inline-block;padding:6px 20px;border-radius:20px;font-size:0.85rem;font-weight:700;color:#fff;background:var(--clr-primary);margin-bottom:16px}
.pricing__card--featured .pricing__tier{background:var(--clr-secondary)}
.pricing__temp{font-size:0.85rem;color:var(--clr-muted);margin-bottom:12px;font-weight:500}
.pricing__card p{color:var(--clr-muted);font-size:0.92rem;margin-bottom:20px;min-height:68px}
.pricing__price{font-size:1.8rem;font-weight:800;color:var(--clr-dark)}
.pricing__note{font-size:0.8rem;color:var(--clr-muted)}
.pricing__cta{text-align:center;margin-top:48px}
.pricing__cta p{color:var(--clr-muted);margin-bottom:16px;font-size:1.05rem}

/* ══════════════════════════════════════════════════════════
   PROCESS (Arajanlat menete)
   ══════════════════════════════════════════════════════════ */
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.process__step{text-align:center;padding:24px 16px}
.process__number{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--clr-primary);color:#fff;font-size:1.4rem;font-weight:800;border-radius:50%;margin:0 auto 16px}
.process__step h3{margin-bottom:8px}
.process__step p{color:var(--clr-muted);font-size:0.9rem}

/* ══════════════════════════════════════════════════════════
   FAQ
   ══════════════════════════════════════════════════════════ */
.faq__list{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.faq__item{background:var(--clr-bg-alt);border-radius:var(--radius-sm);border:1px solid var(--clr-border);overflow:hidden;transition:var(--transition)}
.faq__item.open{border-color:var(--clr-primary)}
.faq__trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 24px;background:none;border:none;cursor:pointer;text-align:left;font-weight:600;font-size:1rem;color:var(--clr-dark)}
.faq__trigger i{color:var(--clr-primary);transition:transform 0.3s ease;flex-shrink:0;margin-left:12px}
.faq__item.open .faq__trigger i{transform:rotate(180deg)}
.faq__answer{max-height:0;overflow:hidden;transition:max-height 0.35s ease,padding 0.35s ease}
.faq__item.open .faq__answer{max-height:300px;padding:0 24px 18px}
.faq__answer p{color:var(--clr-muted);line-height:1.7}

/* ══════════════════════════════════════════════════════════
   FORM SECTION (Ajanlatkero)
   ══════════════════════════════════════════════════════════ */
.form-section__inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-section__text h2{margin-bottom:16px}
.form-section__text > p{color:var(--clr-muted);margin-bottom:24px;font-size:1.05rem}
.form-section__benefits{display:flex;flex-direction:column;gap:12px}
.form-section__benefits li{display:flex;align-items:center;gap:10px;font-weight:500}
.form-section__benefits i{color:var(--clr-primary);font-size:1.1rem}
.form-section__form{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius);padding:32px}
.form__group{margin-bottom:16px}
.form__group label{display:block;font-weight:600;font-size:0.9rem;margin-bottom:6px;color:var(--clr-dark)}
.form__group label span{color:var(--clr-primary)}
.form__group input,.form__group select,.form__group textarea{width:100%;padding:12px 16px;border:1px solid var(--clr-border);border-radius:var(--radius-sm);background:#fff;transition:var(--transition);font-size:1rem}
.form__group input:focus,.form__group select:focus,.form__group textarea:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px var(--clr-primary-light)}
.form__group textarea{resize:vertical}
.form__privacy{font-size:0.8rem;color:var(--clr-muted);margin-top:12px;text-align:center}
.form__privacy a{color:var(--clr-secondary);text-decoration:underline}

/* ══════════════════════════════════════════════════════════
   TESTIMONIALS
   ══════════════════════════════════════════════════════════ */
.google-rating{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:16px;font-size:0.95rem}
.google-rating__stars{color:var(--clr-primary);display:flex;gap:2px;font-size:1.1rem}
.google-rating__score{font-weight:700;color:var(--clr-dark)}
.google-rating__count{color:var(--clr-muted)}
.google-rating__link{display:inline-flex;align-items:center;gap:6px;color:var(--clr-secondary);font-weight:600;padding:4px 12px;border:1px solid var(--clr-border);border-radius:var(--radius-sm);font-size:0.85rem;transition:var(--transition)}
.google-rating__link:hover{background:var(--clr-secondary-light)}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonials__card{background:var(--clr-bg-alt);padding:28px;border-radius:var(--radius);border:1px solid var(--clr-border);transition:var(--transition)}
.testimonials__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.testimonials__stars{color:var(--clr-primary);margin-bottom:12px;font-size:0.9rem;display:flex;gap:2px}
.testimonials__card p{color:var(--clr-text);font-size:0.92rem;line-height:1.7;margin-bottom:16px;font-style:italic}
.testimonials__card strong{color:var(--clr-dark);font-size:0.9rem}

/* ══════════════════════════════════════════════════════════
   ABOUT / RÓLUNK
   ══════════════════════════════════════════════════════════ */
.about__inner{display:grid;grid-template-columns:280px 1fr;gap:48px;align-items:center}
.about__photo img{width:280px;height:320px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.about__photo-placeholder{width:280px;height:320px;border-radius:var(--radius-lg);background:var(--clr-secondary-light);display:flex;align-items:center;justify-content:center;color:var(--clr-muted);font-size:4rem}
.about__role{color:var(--clr-primary);font-weight:600;font-size:1.05rem;margin-bottom:16px}
.about__text p{color:var(--clr-text);line-height:1.7;margin-bottom:12px}
.about__stats{display:flex;gap:32px;margin-top:24px;padding-top:24px;border-top:1px solid var(--clr-border)}
.about__stat{text-align:center}
.about__stat strong{display:block;font-size:1.1rem;color:var(--clr-secondary)}
.about__stat span{font-size:0.85rem;color:var(--clr-muted)}

/* ══════════════════════════════════════════════════════════
   REFERENCES / MUNKÁK
   ══════════════════════════════════════════════════════════ */
.references__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.references__item{border-radius:var(--radius);overflow:hidden;background:var(--clr-bg-alt);border:1px solid var(--clr-border)}
.references__item img{width:100%;height:220px;object-fit:cover;transition:transform 0.4s ease}
.references__item:hover img{transform:scale(1.05)}
.references__placeholder{width:100%;height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:var(--clr-secondary-light);color:var(--clr-muted);font-size:0.9rem}
.references__placeholder i{font-size:2rem;opacity:0.4}
.references__caption{padding:12px 16px;font-size:0.88rem;font-weight:600;color:var(--clr-dark)}
.references__caption strong{display:block}
.references__desc{padding:0 16px 12px;font-size:0.82rem;color:var(--clr-muted);line-height:1.5}
.references__img-wrap{overflow:hidden}
.references__img{width:100%;height:220px;object-fit:cover;transition:transform 0.4s ease}
.references__item:hover .references__img{transform:scale(1.05)}
.references__loading{grid-column:1/-1;text-align:center;padding:40px 0;color:var(--clr-muted);font-size:0.95rem}
.references__empty{grid-column:1/-1;text-align:center;padding:40px 0;color:var(--clr-muted);font-size:0.95rem}

/* ══════════════════════════════════════════════════════════
   BRANDS
   ══════════════════════════════════════════════════════════ */
.brands__grid{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:40px 56px}
.brands__item img{height:40px;width:auto;filter:grayscale(100%) opacity(0.5);transition:var(--transition)}
.brands__item img:hover{filter:grayscale(0%) opacity(1)}
.brands__logo{height:45px;width:auto;color:var(--clr-secondary);opacity:0.35;transition:var(--transition)}
.brands__item:hover .brands__logo{opacity:1;color:var(--clr-primary)}
.brands__text{font-size:1.4rem;font-weight:800;letter-spacing:0.12em;color:var(--clr-secondary);opacity:0.35;transition:var(--transition);text-transform:uppercase}
.brands__item:hover .brands__text{opacity:1;color:var(--clr-primary)}

/* ══════════════════════════════════════════════════════════
   GUARANTEE
   ══════════════════════════════════════════════════════════ */
.guarantee__inner{display:flex;align-items:flex-start;gap:32px;background:var(--clr-bg-alt);padding:48px;border-radius:var(--radius);border:2px solid var(--clr-secondary);box-shadow:var(--shadow)}
.guarantee__icon{flex-shrink:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--clr-secondary);color:#fff;border-radius:50%;font-size:1.6rem}
.guarantee__inner h2{margin-bottom:12px}
.guarantee__inner p{color:var(--clr-muted);margin-bottom:8px}

/* ══════════════════════════════════════════════════════════
   BLOG PREVIEW
   ══════════════════════════════════════════════════════════ */
.blog-preview__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-preview__fallback{grid-column:1/-1;text-align:center;padding:32px 0}

/* ══════════════════════════════════════════════════════════
   CTA BANNER
   ══════════════════════════════════════════════════════════ */
.cta-banner{padding:0}
.cta-banner__inner{background:var(--clr-secondary);color:#fff;padding:56px 48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:space-between;gap:32px;margin:0 auto;max-width:var(--container)}
.cta-banner__inner h2{font-size:1.6rem;color:#fff;margin-bottom:8px}
.cta-banner__inner p{color:rgba(255,255,255,0.8);font-size:1.05rem}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */
.footer{background:var(--clr-footer);color:#fff;padding:64px 0 0;margin-top:80px}
.footer__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:40px}
.footer__logo{margin-bottom:16px}
.footer__logo img{height:60px;width:auto;border-radius:6px}
.footer__desc{color:rgba(255,255,255,0.6);font-size:0.9rem;line-height:1.7;margin-bottom:16px}
.footer__social{display:flex;gap:12px}
.footer__social a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:50%;color:#fff;transition:var(--transition)}
.footer__social a:hover{background:var(--clr-primary)}
.footer h4{font-size:0.95rem;font-weight:700;margin-bottom:16px;color:#fff}
.footer ul li{margin-bottom:8px}
.footer ul li a,.footer ul li span{color:rgba(255,255,255,0.6);font-size:0.9rem;transition:var(--transition)}
.footer ul li a:hover{color:var(--clr-primary)}
.footer__contact li{display:flex;align-items:flex-start;gap:10px}
.footer__contact i{color:var(--clr-primary);margin-top:3px;width:16px;text-align:center}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:24px 0;margin-top:48px;border-top:1px solid rgba(255,255,255,0.1);font-size:0.85rem;color:rgba(255,255,255,0.4)}
.footer__bottom a{color:rgba(255,255,255,0.6)}
.footer__bottom a:hover{color:var(--clr-primary)}
.footer__credit{opacity:0.72;font-size:0.85rem}
.footer__credit a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.3);transition:border-color 0.2s,opacity 0.2s}
.footer__credit a:hover{border-bottom-color:var(--clr-primary);opacity:1}

/* ══════════════════════════════════════════════════════════
   PAGE HERO (aloldalak)
   ══════════════════════════════════════════════════════════ */
.page-hero{padding:140px 0 60px;background:var(--clr-secondary);color:#fff;text-align:center}
.page-hero h1{color:#fff;margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,0.8);max-width:560px;margin:0 auto}

/* ══════════════════════════════════════════════════════════
   KLIMAVÁLASZTÓ PDF OLDAL
   ══════════════════════════════════════════════════════════ */
.pdf-hero{padding:140px 0 50px;background:var(--clr-secondary);color:#fff;text-align:center}
.pdf-hero h1{color:#fff;margin-bottom:16px;font-size:2.4rem}
.pdf-hero__sub{color:rgba(255,255,255,0.85);max-width:640px;margin:0 auto;font-size:1.1rem;line-height:1.7}
.pdf-hero__sub strong{color:#fff}

.pdf-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.pdf-layout__left{display:flex;flex-direction:column;align-items:center;gap:28px}

/* eBook mockup */
.pdf-mockup{display:flex;justify-content:center}
.pdf-mockup__img{max-width:100%;height:auto;border-radius:8px;box-shadow:6px 6px 24px rgba(0,0,0,0.15)}

.pdf-benefits{display:flex;flex-direction:column;gap:12px;width:100%;max-width:380px}
.pdf-benefits li{display:flex;align-items:flex-start;gap:10px;font-size:0.95rem;font-weight:500}
.pdf-benefits i{color:var(--clr-primary);font-size:1rem;margin-top:3px;flex-shrink:0}
.pdf-cta-text{color:var(--clr-muted);font-size:0.95rem;max-width:380px;text-align:center}

/* PDF form card */
.pdf-form-card{background:#fff;border:1px solid var(--clr-border);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow-md)}
.pdf-form-card h3{margin-bottom:8px;font-size:1.3rem}
.pdf-form-card > p{color:var(--clr-muted);font-size:0.9rem;margin-bottom:24px;line-height:1.6}

/* Kinek szól szekció */
.pdf-audience{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:32px}
.pdf-audience__item{display:flex;flex-direction:column;align-items:center;gap:8px}
.pdf-audience__item i{font-size:2rem;color:var(--clr-primary)}
.pdf-audience__item strong{font-size:1rem}
.pdf-audience__item p{font-size:0.85rem;color:var(--clr-muted);margin:0}

/* ══════════════════════════════════════════════════════════
   KALKULÁTOR OLDAL
   ══════════════════════════════════════════════════════════ */
.calc-hero{padding:140px 0 50px;background:var(--clr-secondary);color:#fff;text-align:center}
.calc-hero h1{color:#fff;margin-bottom:12px}
.calc-hero p{color:rgba(255,255,255,0.8);max-width:560px;margin:0 auto}

.calc-container{max-width:720px;margin:0 auto}

/* Progress bar */
.calc-progress{display:flex;gap:8px;margin-bottom:40px}
.calc-progress__step{flex:1;height:6px;border-radius:3px;background:var(--clr-border);transition:background 0.3s ease}
.calc-progress__step.active{background:var(--clr-primary)}
.calc-progress__step.done{background:var(--clr-secondary)}

/* Step cards */
.calc-step{display:none;animation:fadeSlideUp 0.4s ease-out}
.calc-step.active{display:block}
.calc-step h2{text-align:center;margin-bottom:8px;font-size:1.5rem}
.calc-step > p{text-align:center;color:var(--clr-muted);margin-bottom:32px}

/* Option cards (vizuális válaszlehetőségek) */
.calc-options{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.calc-option{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;border:2px solid var(--clr-border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);text-align:center;background:#fff}
.calc-option:hover{border-color:var(--clr-primary);box-shadow:0 0 0 3px var(--clr-primary-light)}
.calc-option.selected{border-color:var(--clr-primary);background:var(--clr-primary-light)}
.calc-option i{font-size:2rem;color:var(--clr-primary)}
.calc-option strong{font-size:1rem}
.calc-option span{font-size:0.8rem;color:var(--clr-muted)}

/* Slider */
.calc-slider{width:100%;max-width:480px;margin:0 auto;text-align:center}
.calc-slider input[type="range"]{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,var(--clr-primary) 0%,var(--clr-border) 0%);outline:none;margin:24px 0}
.calc-slider input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:var(--clr-primary);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,0.2)}
.calc-slider__value{font-size:2.5rem;font-weight:800;color:var(--clr-primary)}
.calc-slider__unit{font-size:1rem;color:var(--clr-muted);margin-left:4px}
.calc-slider__labels{display:flex;justify-content:space-between;font-size:0.8rem;color:var(--clr-muted)}

/* Count selector (gomb csoport) */
.calc-counts{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.calc-count{width:64px;height:64px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;border:2px solid var(--clr-border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);background:#fff}
.calc-count:hover{border-color:var(--clr-primary)}
.calc-count.selected{border-color:var(--clr-primary);background:var(--clr-primary);color:#fff}

/* Result card */
.calc-result{background:linear-gradient(135deg,var(--clr-secondary) 0%,#1e3a5f 100%);color:#fff;border-radius:var(--radius);padding:40px;text-align:center}
.calc-result h2{color:#fff;margin-bottom:16px}
.calc-result__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0}
.calc-result__card{background:rgba(255,255,255,0.1);border-radius:var(--radius-sm);padding:20px 12px}
.calc-result__card strong{display:block;font-size:1.3rem;margin-bottom:4px}
.calc-result__card span{font-size:0.8rem;opacity:0.7}
.calc-result__note{font-size:0.85rem;opacity:0.7;margin-top:16px}

/* Calc nav buttons */
.calc-nav{display:flex;justify-content:space-between;margin-top:32px}
.calc-nav .btn{min-width:140px}

/* ══════════════════════════════════════════════════════════
   BLOG OLDAL
   ══════════════════════════════════════════════════════════ */

/* Blog grid — kártya rács */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--clr-border);border-radius:var(--radius);padding:28px 24px;transition:var(--transition);text-decoration:none;color:inherit}
.blog-card:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.blog-card__icon{font-size:1.6rem;color:var(--clr-primary);margin-bottom:12px}
.blog-card__tag{display:inline-block;background:var(--clr-primary-light);color:var(--clr-primary);font-size:0.7rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:12px;width:fit-content;letter-spacing:0.3px;text-transform:uppercase}
.blog-card__title{font-size:1.05rem;line-height:1.4;margin-bottom:8px;color:var(--clr-dark)}
.blog-card__excerpt{font-size:0.88rem;color:var(--clr-muted);line-height:1.6;flex:1}
.blog-card__link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:0.88rem;font-weight:600;color:var(--clr-primary)}
.blog-card:hover .blog-card__link{gap:10px}

/* Blog post layout — cikk + sidebar */
.blog-post-layout{display:grid;grid-template-columns:1fr 340px;gap:48px;align-items:start}

/* Blog post tartalom */
.blog-post__tag{display:inline-block;background:rgba(255,255,255,0.15);color:#fff;font-size:0.75rem;font-weight:700;padding:4px 14px;border-radius:20px;margin-bottom:16px;letter-spacing:0.3px;text-transform:uppercase}

.blog-post__content{min-width:0}

/* Prose — cikk szöveges formázás */
.prose{font-size:1rem;line-height:1.8;color:var(--clr-text)}
.prose h2{margin:40px 0 16px;font-size:1.5rem}
.prose h3{margin:32px 0 12px;font-size:1.2rem}
.prose p{margin-bottom:16px}
.prose ul,.prose ol{margin:0 0 16px 20px}
.prose ul{list-style:disc}
.prose ol{list-style:decimal}
.prose li{margin-bottom:6px}
.prose a{color:var(--clr-primary);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--clr-primary-dim)}
.prose img{border-radius:var(--radius-sm);margin:24px 0}
.prose blockquote{border-left:4px solid var(--clr-primary);padding:12px 20px;margin:24px 0;background:var(--clr-primary-light);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-style:italic}
.prose strong{color:var(--clr-dark)}
.prose table{width:100%;border-collapse:collapse;margin:24px 0}
.prose th,.prose td{padding:10px 14px;border:1px solid var(--clr-border);text-align:left;font-size:0.9rem}
.prose th{background:var(--clr-secondary-light);font-weight:700}

/* Placeholder */
.blog-post__placeholder{text-align:center;padding:80px 20px;color:var(--clr-muted)}
.blog-post__placeholder i{display:block;margin-bottom:16px}

/* Sidebar */
.blog-post__sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:100px}
.sidebar-card{background:#fff;border:1px solid var(--clr-border);border-radius:var(--radius);padding:24px}
.sidebar-card h4{display:flex;align-items:center;gap:8px;font-size:1rem;margin-bottom:8px}
.sidebar-card h4 i{color:var(--clr-primary)}
.sidebar-card p{font-size:0.88rem;color:var(--clr-muted);margin-bottom:16px;line-height:1.6}
.sidebar-card--cta{border-color:var(--clr-primary);background:var(--clr-primary-light)}

/* ══════════════════════════════════════════════════════════
   JOGI OLDALAK (impresszum, adatkezelés)
   ══════════════════════════════════════════════════════════ */
.legal-content{max-width:820px;margin:0 auto;font-size:1rem;line-height:1.8;color:var(--clr-text)}
.legal-content h2{margin:40px 0 16px;font-size:1.35rem;color:var(--clr-dark);border-bottom:2px solid var(--clr-border);padding-bottom:8px}
.legal-content p{margin-bottom:16px}
.legal-content ul{margin:0 0 16px 20px;list-style:disc}
.legal-content ul li{margin-bottom:6px}
.legal-content a{color:var(--clr-primary);text-decoration:underline;text-underline-offset:2px}
.legal-content a:hover{color:var(--clr-primary-dim)}
.legal-date{font-size:0.9rem;color:var(--clr-muted);font-style:italic;margin-bottom:24px}

.legal-table{width:100%;border-collapse:collapse;margin:0 0 24px}
.legal-table th,.legal-table td{padding:10px 14px;border:1px solid var(--clr-border);font-size:0.92rem;text-align:left;vertical-align:top}
.legal-table th{background:var(--clr-secondary-light);font-weight:600;white-space:nowrap;width:180px}
.legal-table thead th{background:var(--clr-secondary);color:#fff;font-weight:700}

/* ══════════════════════════════════════════════════════════
   FORM VALIDACIO
   ══════════════════════════════════════════════════════════ */
.input--error{border-color:#e53e3e !important;box-shadow:0 0 0 3px rgba(229,62,62,0.12) !important}
.form__error{display:block;color:#e53e3e;font-size:0.8rem;margin-top:4px;font-weight:500}

/* ══════════════════════════════════════════════════════════
   404 OLDAL
   ══════════════════════════════════════════════════════════ */
.error-page{padding:140px 0 80px;text-align:center;min-height:70vh;display:flex;align-items:center}
.error-page__inner{max-width:600px;margin:0 auto}
.error-page__code{font-size:clamp(6rem,15vw,10rem);font-weight:900;color:var(--clr-primary);opacity:0.15;line-height:1;margin-bottom:-16px}
.error-page h1{font-size:1.8rem;margin-bottom:12px}
.error-page p{color:var(--clr-muted);font-size:1.05rem;line-height:1.7;margin-bottom:32px}
.error-page__links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.error-page__suggestions{text-align:left;background:#fff;border:1px solid var(--clr-border);border-radius:var(--radius);padding:28px 32px}
.error-page__suggestions h3{font-size:1rem;margin-bottom:16px;color:var(--clr-dark)}
.error-page__suggestions ul{display:flex;flex-direction:column;gap:10px}
.error-page__suggestions li a{display:flex;align-items:center;gap:10px;padding:8px 0;color:var(--clr-text);font-size:0.95rem;transition:var(--transition)}
.error-page__suggestions li a:hover{color:var(--clr-primary)}
.error-page__suggestions li a i{width:20px;text-align:center;color:var(--clr-primary);font-size:0.9rem}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
    .hero .container{grid-template-columns:1fr;text-align:center}
    .hero__sub{margin-left:auto;margin-right:auto}
    .hero__actions{justify-content:center}
    .pdf-layout{grid-template-columns:1fr}
    .pdf-audience{grid-template-columns:1fr;gap:24px}
    .hero__visual{order:-1}
    .hero__image-wrapper img{max-height:300px;width:auto;margin:0 auto}
    .why__grid{grid-template-columns:repeat(2,1fr)}
    .types__grid,.pricing__grid,.testimonials__grid{grid-template-columns:repeat(2,1fr)}
    .process__grid{grid-template-columns:repeat(2,1fr)}
    .form-section__inner{grid-template-columns:1fr}
    .footer__grid{grid-template-columns:repeat(2,1fr)}
    .cta-banner__inner{flex-direction:column;text-align:center}
    .pricing__card--featured{transform:none}
    .blog-grid{grid-template-columns:repeat(2,1fr)}
    .blog-post-layout{grid-template-columns:1fr}
    .blog-post__sidebar{position:static}
    .references__grid{grid-template-columns:repeat(2,1fr)}
    .about__inner{grid-template-columns:1fr;text-align:center}
    .about__photo-placeholder,.about__photo img{margin:0 auto}
    .about__stats{justify-content:center}
}

@media(max-width:768px){
    .header__nav,.header__phone,.header__cta{display:none}
    .hamburger{display:flex}
    .sticky-cta{display:flex}
    .hero{padding:100px 0 40px}
    .section{padding:56px 0}
    .why__grid,.types__grid,.pricing__grid,.testimonials__grid{grid-template-columns:1fr}
    .process__grid{grid-template-columns:repeat(2,1fr)}
    .trust-bar__grid{gap:16px 32px}
    .footer__grid{grid-template-columns:1fr}
    .guarantee__inner{flex-direction:column;padding:32px}
    .blog-preview__grid{grid-template-columns:1fr}
    .form-section__form{padding:24px}
    .pdf-hero h1{font-size:1.8rem}
    .pdf-form-card{padding:24px}
    .calc-options{grid-template-columns:1fr}
    .calc-result__cards{grid-template-columns:1fr}
    .blog-grid{grid-template-columns:1fr}
    .legal-table th{white-space:normal;width:auto}
    .references__grid{grid-template-columns:1fr}
    .references__item img,.references__placeholder{height:180px}
}

@media(max-width:480px){
    .container{padding:0 16px}
    .hero__actions{flex-direction:column;width:100%}
    .hero__actions .btn{width:100%;justify-content:center}
    .process__grid{grid-template-columns:1fr}
    .cta-banner__inner{padding:40px 24px}
    .footer__bottom{flex-direction:column;gap:8px;text-align:center}
}

/* ══════════════════════════════════════════════════════════
   SCROLL REVEAL ANIMACIOK
   ══════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.9);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* Stagger delay a child elemekre */
.stagger > *:nth-child(1){transition-delay:0s}
.stagger > *:nth-child(2){transition-delay:0.1s}
.stagger > *:nth-child(3){transition-delay:0.2s}
.stagger > *:nth-child(4){transition-delay:0.3s}
.stagger > *:nth-child(5){transition-delay:0.4s}
.stagger > *:nth-child(6){transition-delay:0.5s}

/* Hover micro-interactions */
.why__card,.types__card,.pricing__card,.testimonials__card,.process__step{transition:transform 0.3s ease,box-shadow 0.3s ease,border-color 0.3s ease}

/* Szerelési típus SVG animációk */
.types-air{opacity:0;animation:typesAirFlow 3s ease-in-out infinite}
.types-air-1{animation-delay:0s}
.types-air-2{animation-delay:0.4s}
.types-air-3{animation-delay:0.8s}
@keyframes typesAirFlow{
    0%,100%{opacity:0;stroke-dasharray:0 40}
    20%{opacity:0.7;stroke-dasharray:20 40}
    50%{opacity:0.5;stroke-dasharray:40 40}
    80%{opacity:0;stroke-dasharray:40 0}
}
/* Klíma készülék pulzálás */
.hero-svg__ac rect:first-child{animation:acPulse 6s ease-in-out infinite}
@keyframes acPulse{
    0%,42%{filter:drop-shadow(0 0 6px rgba(59,130,246,0.3))}
    48%,50%{filter:drop-shadow(0 0 0 transparent)}
    52%,92%{filter:drop-shadow(0 0 6px rgba(239,68,68,0.3))}
    98%,100%{filter:drop-shadow(0 0 6px rgba(59,130,246,0.3))}
}

/* ══════════════════════════════════════════════════════════
   PRINT
   ══════════════════════════════════════════════════════════ */
@media print{
    *{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}
    body{font-size:12pt;line-height:1.5}
    a[href]{text-decoration:underline}
    a[href^="tel:"]{text-decoration:none}
    .header,.mobile-nav,.sticky-cta,.hamburger,.skip-link,.cta-banner,.form-section,.hero__actions,.btn{display:none!important}
    .container{max-width:100%;padding:0}
    .section{padding:24px 0}
    .footer{padding:16px 0;border-top:1px solid #ccc}
    .footer__grid{display:block}
    .footer__social,.footer__desc{display:none}
    .legal-content{max-width:100%}
    .legal-table th,.legal-table td{border:1px solid #999;padding:6px 10px}
    .blog-post__sidebar{display:none}
    .blog-post-layout{grid-template-columns:1fr}
    .prose img{max-width:100%;page-break-inside:avoid}
    h2,h3{page-break-after:avoid}
    .pricing__grid,.why__grid,.types__grid{display:block}
    .pricing__card,.why__card,.types__card{margin-bottom:16px;border:1px solid #ccc;padding:16px;page-break-inside:avoid}
}

/* ── Accessibility: reduced motion ─────────────────────── */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
    .hero-svg__airflow,.types-air,.hero-svg__snow *{animation:none!important}
    .reveal,.reveal-left,.reveal-right,.reveal-scale{opacity:1!important;transform:none!important}
}

/* ── Accessibility: focus-visible ──────────────────────── */
:focus-visible{outline:2px solid var(--clr-primary);outline-offset:3px;border-radius:4px}
a:focus-visible,button:focus-visible,.btn:focus-visible{outline:2px solid var(--clr-primary);outline-offset:3px}
.header__nav a:focus-visible{outline-color:#fff}
.breadcrumb a:focus-visible{outline-color:rgba(255,255,255,0.8)}
