
/* ===== Alapok, tokenek ===== */
:root{
  --ink:#14181c; --ink-2:#454d54; --muted:#525a62; --paper:#f5f7fa;
  --surface:#ffffff; --surface-2:#eaeef3; --surface-3:#e1e7ee;
  --line:#d2dae2; --line-2:#c2ccd6;
  --brand:#f26a1b; --brand-deep:#b3470a; --brand-soft:#fde7d4;
  --steel:#1f5fa6; --ink-deep:#0e1316;
  --acc:#f26a1b; --acc-deep:#b3470a; --acc-soft:#fde7d4;
  --rad:6px; --rad-lg:14px; --rad-xl:22px;
  --shadow:0 1px 2px rgba(16,24,32,.06),0 8px 24px rgba(16,24,32,.07);
  --shadow-lg:0 2px 6px rgba(16,24,32,.08),0 22px 50px rgba(16,24,32,.13);
  --maxw:1200px; --ff:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --mono:var(--ff);  /* EGYETLEN betűtípus az egész oldalon (a H1 betűje) */
  --grid:rgba(18,26,36,.045); --dot:rgba(18,26,36,.06);
}
/* per-modell akcentus témák (6 állapot; nincs inline style) */
.acc-1{--acc:#f26a1b;--acc-deep:#b3470a;--acc-soft:#fde7d4}
.acc-2{--acc:#0e9488;--acc-deep:#0f766e;--acc-soft:#cdeeea}
.acc-3{--acc:#5560e0;--acc-deep:#4338ca;--acc-soft:#e0e2fb}
.acc-4{--acc:#c2299a;--acc-deep:#9d2089;--acc-soft:#f7d9ef}
.acc-5{--acc:#2f8f4e;--acc-deep:#1f7a3d;--acc-soft:#d3eddc}
.acc-6{--acc:#c2410c;--acc-deep:#8a3608;--acc-soft:#fbe0d0}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--ff);color:var(--ink);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
  background-color:var(--paper);
  background-image:
    radial-gradient(var(--dot) 1.1px, transparent 1.4px),
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:26px 26px,26px 26px,26px 26px}
/* halvány grid+pötty a világos szekciók hátterén is */
.sec-tint{background-image:
    radial-gradient(var(--dot) 1.1px, transparent 1.4px),
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:26px 26px,26px 26px,26px 26px}
h1,h2,h3,h4{line-height:1.15;margin:0 0 .5em;font-weight:780;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(1.9rem,1.2rem+2.7vw,3.2rem)}
h2{font-size:clamp(1.5rem,1.05rem+1.7vw,2.25rem)}
h3{font-size:clamp(1.18rem,1rem+.7vw,1.5rem);letter-spacing:-.01em}
p{margin:0 0 1em}
a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;
  text-decoration-thickness:1.5px;text-decoration-color:var(--line-2)}
a:hover{color:var(--brand-deep);text-decoration-color:var(--brand)}
img{max-width:100%;height:auto;display:block}
strong{font-weight:720}
:focus-visible{outline:3px solid var(--brand);outline-offset:2px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--ink);
  color:#fff;padding:10px 16px;border-radius:0 0 8px 0;text-decoration:none}
.skip:focus{left:0}
.mono{font-family:var(--mono);font-weight:600}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
section{position:relative}
.muted{color:var(--muted)}
.narrow{max-width:780px}
.canon{background:var(--surface);border-left-color:var(--ink);color:#23292f}

/* ===== Gombok ===== */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;
  font-size:.98rem;padding:.72em 1.25em;border-radius:var(--rad);
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease;
  line-height:1.1;min-height:44px}
.btn .ic{width:20px;height:20px;flex:0 0 auto;fill:currentColor}
.btn:hover{transform:translateY(-2px)}
.btn-lg{font-size:1.06rem;padding:.92em 1.6em;min-height:52px}
.btn-primary{background:var(--brand);color:#1a1205;border-color:#d9560f;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.45),0 6px 16px rgba(242,106,27,.28)}
.btn-primary:hover{background:#ff7a2b;color:#1a1205}
.btn-ink{background:var(--ink);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.btn-ink:hover{background:#23292f;color:#fff}
.btn-phone{background:var(--ink);color:#fff}
.btn-phone:hover{background:#23292f;color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--ink);background:var(--surface)}
.btn-acc{background:var(--acc-deep);color:#fff}
.btn-acc:hover{background:var(--acc);color:#1a1205}

/* ===== Chip / címke ===== */
.chip{display:inline-flex;align-items:center;gap:.4em;font-size:.74rem;
  letter-spacing:.04em;text-transform:uppercase;background:var(--surface-2);
  color:var(--ink-2);padding:.36em .7em;border-radius:50px;border:1px solid var(--line)}
.chip.mono{font-family:var(--mono)}
.eyebrow{display:inline-flex;align-items:center;gap:.5em;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#14181c;background:var(--brand);padding:.45em .9em;
  border-radius:50px;border:1px solid #d9560f;margin-bottom:14px}
.eyebrow .ic{fill:#14181c}

/* ===== Fejléc ===== */
.site-head{position:sticky;top:0;z-index:100;background:rgba(245,247,250,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.head-in{max-width:var(--maxw);margin:0 auto;padding:0 20px;height:68px;
  display:flex;align-items:center;gap:14px;justify-content:space-between}
.brand{display:inline-flex;align-items:center;gap:.5em;font-weight:800;
  font-size:1.04rem;text-decoration:none;color:var(--ink);letter-spacing:-.01em;flex:0 0 auto}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;
  background:var(--ink);color:#fff}
.brand-mark .ic{width:20px;height:20px;fill:var(--brand)}
.mainnav{flex:1 1 auto}
.mainnav-in{display:flex;gap:4px;justify-content:center;align-items:center}
.navlink{font-size:.96rem;font-weight:600;text-decoration:none;color:var(--ink-2);
  padding:.5em .8em;border-radius:7px;white-space:nowrap}
.navlink:hover{color:var(--ink);background:var(--surface-2)}
.navlink.active{color:var(--ink);background:var(--surface-2);box-shadow:inset 0 -2px 0 var(--brand)}
.head-cta{flex:0 0 auto}
.head-cta .btn{padding:.5em .9em;min-height:40px}
.mnu-btn{display:none}
.mnu-x{display:none}

/* ===== Hero ===== */
.hero{position:relative;padding:clamp(48px,7vw,104px) 0 clamp(40px,5vw,72px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.12fr) minmax(0,.88fr);gap:48px;align-items:center}
.hero-grid>div{min-width:0}
.hero h1{margin-bottom:.35em}
.lead{font-size:clamp(1.06rem,1rem+.5vw,1.32rem);color:var(--ink-2);max-width:38ch;margin-bottom:1.4em}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:1.5em}
.hero-proof{display:flex;flex-wrap:wrap;align-items:center;gap:18px;font-size:.92rem;color:var(--muted)}
.stars{display:inline-flex;color:var(--brand)}
.stars .ic{width:18px;height:18px;fill:var(--brand)}
.hero-art{position:relative;aspect-ratio:1/1;border-radius:var(--rad-xl);
  background:linear-gradient(160deg,#1b2127,#0e1316);box-shadow:var(--shadow-lg);
  overflow:hidden;display:grid;place-items:center;padding:28px}
.hero-art img{width:100%;border-radius:14px}
.hero-badge{position:absolute;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:10px 14px;box-shadow:var(--shadow-lg);font-size:.86rem;
  display:flex;align-items:center;gap:.5em;font-weight:700}
.hero-badge .ic{width:22px;height:22px;fill:var(--brand-deep)}
.hb-1{left:-14px;top:18%}.hb-2{right:-10px;bottom:16%}
@media(min-width:900px){.hb-1{animation:floaty 6s ease-in-out infinite}
  .hb-2{animation:floaty 7s ease-in-out .8s infinite}}

/* dekor alakzatok */
.deco{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.deco>*{position:absolute}
.blob{border-radius:50%;filter:blur(8px);opacity:.5}
.b1{width:340px;height:340px;background:radial-gradient(circle,var(--brand-soft),transparent 70%);top:-120px;right:-60px}
.b2{width:300px;height:300px;background:radial-gradient(circle,#cfe0f3,transparent 70%);bottom:-120px;left:-80px}
.ring{width:180px;height:180px;border:2px dashed var(--line-2);border-radius:50%;opacity:.6;right:8%;bottom:-60px}
.tri{width:0;height:0;border-left:46px solid transparent;border-right:46px solid transparent;
  border-bottom:80px solid var(--surface-2);left:6%;top:-30px;transform:rotate(18deg);opacity:.8}
.grid-dots{width:200px;height:160px;left:50%;top:30%;opacity:.5;
  background-image:radial-gradient(var(--line-2) 1.4px,transparent 1.4px);background-size:18px 18px}
.hero>.wrap{position:relative;z-index:1}

/* ===== Szekciók, csempék ===== */
.sec{padding:clamp(44px,6vw,84px) 0}
.sec-tint{background-color:var(--surface-2)}
.sec-ink{background:var(--ink-deep);color:#e7ecf1}
.sec-ink h2,.sec-ink h3{color:#fff}
.sec-ink p{color:#c2ccd4}
.sec-head{max-width:62ch;margin-bottom:36px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.tiles{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:26px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.tile-ico{display:grid;place-items:center;width:50px;height:50px;border-radius:13px;
  background:var(--acc-soft);margin-bottom:16px}
.tile-ico .ic{width:27px;height:27px;fill:var(--acc-deep)}
.tile h3{margin-bottom:.35em}
.tile p{color:var(--ink-2);margin:0;font-size:.97rem}
.tile::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--acc)}

/* ===== Stat sáv ===== */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--rad-lg);overflow:hidden}
.stat{background:var(--surface);padding:24px 20px;text-align:center}
.stat .num{font-size:clamp(1.7rem,1.2rem+1.6vw,2.5rem);font-weight:820;letter-spacing:-.03em;color:var(--ink)}
.stat .lab{font-size:.84rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--mono)}

/* ===== Lépések ===== */
.steps{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));counter-reset:s}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:24px;position:relative}
.step .snum{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;
  background:var(--ink);color:#fff;font-weight:800;font-family:var(--mono);margin-bottom:14px}
.step h3{font-size:1.12rem}.step p{margin:0;color:var(--ink-2);font-size:.95rem}

/* ===== Ár csempék ===== */
.prices{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));align-items:start}
.price{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:28px 26px;box-shadow:var(--shadow);position:relative;display:flex;flex-direction:column}
.price.feat{border:2px solid var(--brand);box-shadow:var(--shadow-lg)}
.price .ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--brand);color:#1a1205;font-weight:800;font-size:.74rem;letter-spacing:.05em;
  text-transform:uppercase;padding:.4em .9em;border-radius:50px;white-space:nowrap}
.price .ribbon-akcio{background:var(--ink);color:#fff}
.price.akcio{border-color:var(--ink)}
.faq-center{margin:0 auto}
.faq-center summary{justify-content:center;text-align:center;gap:.6em}
.faq-center summary::after{margin-left:.3em}
.price h3{margin-bottom:.2em}
.price .sub{color:var(--muted);font-size:.9rem;margin-bottom:1em;min-height:2.6em}
.price .amount{font-size:2.5rem;font-weight:840;letter-spacing:-.03em}
.price .per{color:var(--muted);font-size:.92rem;margin-bottom:1.1em}
.price ul{list-style:none;padding:0;margin:0 0 1.4em;display:grid;gap:.6em}
.price li{display:flex;gap:.6em;align-items:flex-start;font-size:.95rem}
.price li .ic{width:20px;height:20px;flex:0 0 auto;fill:var(--brand-deep);margin-top:2px}
.price li.no{color:var(--muted)}.price li.no .ic{fill:var(--muted)}
.price .btn{margin-top:auto;justify-content:center}

/* ===== FAQ ===== */
.faq{display:grid;gap:12px;max-width:820px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-weight:700;font-size:1.04rem;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1em}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:1.5rem;color:var(--brand-deep);
  transition:transform .2s ease;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--brand-deep)}
.faq .ans{padding:0 22px 20px;color:var(--ink-2);font-size:.98rem}

/* ===== Táblázat (Google-barát, gépi olvasásra) ===== */
.table-scroll{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:var(--rad-lg);
  background:var(--surface);box-shadow:var(--shadow)}
table.spec{width:100%;border-collapse:collapse;font-size:.94rem;min-width:560px}
table.spec caption{text-align:left;padding:16px 18px;font-weight:700;font-size:1.05rem;
  border-bottom:1px solid var(--line);color:var(--ink)}
table.spec th,table.spec td{padding:11px 16px;text-align:left;border-bottom:1px solid var(--surface-3)}
table.spec thead th{position:sticky;top:0;background:var(--ink);color:#fff;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.04em;font-family:var(--mono);font-weight:600;white-space:nowrap}
table.spec tbody tr:nth-child(even){background:var(--surface-2)}
table.spec tbody tr:hover{background:var(--brand-soft)}
table.spec td.mono{font-family:var(--mono);font-weight:600;white-space:nowrap}
.tag{display:inline-block;font-family:var(--mono);font-size:.72rem;padding:.2em .55em;border-radius:5px;
  background:var(--surface-3);color:var(--ink-2);font-weight:600}
.tag.ev{background:#d3eddc;color:#1f7a3d}.tag.hyb{background:#cdeeea;color:#0f766e}
.tag.ben{background:#fde7d4;color:#b3470a}.tag.die{background:#e0e2fb;color:#4338ca}

/* ===== Breadcrumb ===== */
.crumb{font-size:.85rem;margin:0 0 18px}
.crumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5em;padding:0;margin:0}
.crumb li{display:flex;align-items:center;gap:.5em;color:var(--muted)}
.crumb li+li::before{content:"›";color:var(--line-2)}
.crumb a{color:var(--ink-2);text-decoration:none}.crumb a:hover{color:var(--brand-deep);text-decoration:underline}
.crumb [aria-current]{color:var(--ink);font-weight:600}

/* ===== Modell-oldal elrendezés ===== */
.entity{padding:clamp(22px,3vw,40px) 0 0}
.entity-grid{display:grid;grid-template-columns:minmax(0,1fr) 332px;gap:42px;align-items:start}
.prose{min-width:0}
.prose>h2{margin-top:1.6em}.prose>h3{margin-top:1.3em}
.prose p{color:#23292f;overflow-wrap:break-word}
.prose section{min-width:0}
.answer{background:var(--acc-soft);border-left:5px solid var(--acc);border-radius:0 12px 12px 0;
  padding:16px 20px;margin:0 0 1.4em;font-size:1.02rem;color:#23292f;overflow-wrap:break-word}
.answer p{margin:0}
.answer strong{color:var(--ink)}
.callout{display:flex;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--rad-lg);padding:18px 20px;margin:1.4em 0;box-shadow:var(--shadow)}
.callout .ic{width:26px;height:26px;flex:0 0 auto;fill:var(--acc-deep);margin-top:2px}
.callout h3{margin:0 0 .25em;font-size:1.05rem}.callout p{margin:0;color:var(--ink-2);font-size:.95rem}
.sidebar{position:sticky;top:88px;display:grid;gap:18px;min-width:0}
.side-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  padding:22px;box-shadow:var(--shadow);min-width:0;overflow-wrap:break-word}
.side-card.price-card{border-top:5px solid var(--acc)}
.side-card h2,.side-card h3{font-size:1.1rem;margin-bottom:.6em}
.side-price{font-size:1.9rem;font-weight:840;letter-spacing:-.02em}
.side-price small{font-size:.8rem;color:var(--muted);font-weight:600}
.side-card .btn{width:100%;justify-content:center;margin-top:6px}
.specsum{list-style:none;padding:0;margin:0;display:grid;gap:.55em;font-size:.92rem}
.specsum li{display:flex;justify-content:space-between;gap:1em;border-bottom:1px solid var(--surface-3);padding-bottom:.5em}
.specsum li span:first-child{color:var(--muted);flex:0 0 auto}
.specsum li span:last-child{font-weight:700;text-align:right;min-width:0;overflow-wrap:anywhere}
.toc{font-size:.92rem}.toc ol{margin:.3em 0 0;padding-left:1.1em}
.toc a{color:var(--ink-2);text-decoration:none}.toc a:hover{color:var(--brand-deep);text-decoration:underline}
.toc h2{font-size:.78rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}

/* belső linkek / rokon modellek */
.relgrid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.relcard{display:flex;align-items:center;gap:.7em;background:var(--surface);border:1px solid var(--line);
  border-radius:11px;padding:13px 16px;text-decoration:none;color:var(--ink);font-weight:650;
  transition:transform .12s,border-color .12s,box-shadow .12s}
.relcard:hover{transform:translateY(-3px);border-color:var(--acc);box-shadow:var(--shadow);color:var(--ink)}
.relcard .ic{width:22px;height:22px;fill:var(--acc-deep);flex:0 0 auto}
.relcard small{display:block;color:var(--muted);font-weight:500;font-size:.8rem}

/* A–Z modell-lista */
.azbar{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 28px}
.azbar a{font-family:var(--mono);font-weight:700;width:38px;height:38px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:9px;text-decoration:none;color:var(--ink)}
.azbar a:hover{background:var(--ink);color:#fff}
.brandblock{margin:0 0 34px;scroll-margin-top:84px}
.brandblock h2,.brandblock h3{display:flex;align-items:baseline;gap:.5em}
.brandblock h2 small,.brandblock h3 small{font-size:.8rem;color:var(--muted);font-weight:600}
/* lenyíló (details) blokkok */
.acc{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  box-shadow:var(--shadow);overflow:hidden;margin:0}
.acc>summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:700;font-size:1.05rem;
  display:flex;align-items:center;gap:.6em}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary .ic{width:22px;height:22px;fill:var(--brand-deep);flex:0 0 auto}
.acc>summary::after{content:"+";margin-left:auto;font-size:1.5rem;color:var(--brand-deep);line-height:1}
.acc[open]>summary::after{content:"–"}
.acc>summary:hover{color:var(--brand-deep)}
.acc-body{padding:8px 22px 22px;border-top:1px solid var(--line)}
.subh{margin:48px 0 18px;font-size:1.3rem}
.map-side .map-wrap{aspect-ratio:auto;height:100%;min-height:340px}
.modlist{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(215px,1fr))}
.modlink{display:flex;justify-content:space-between;align-items:center;gap:.5em;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;padding:11px 15px;text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem}
.modlink:hover{border-color:var(--brand);color:var(--brand-deep);background:#fff}
.modlink .v{font-family:var(--mono);font-size:.74rem;color:var(--muted);font-weight:600}

/* keresési chip-felhő (egyszer, a 13.5-höz) */
.keycloud{display:flex;flex-wrap:wrap;gap:8px}
.keycloud span{font-size:.84rem;background:var(--surface);border:1px solid var(--line);
  color:var(--ink-2);padding:.4em .8em;border-radius:50px}

/* CTA sáv */
.ctaband{background:linear-gradient(135deg,#1b2127,#0e1316);border-radius:var(--rad-xl);
  padding:clamp(30px,5vw,56px);text-align:center;color:#fff;position:relative;overflow:hidden}
.ctaband h2{color:#fff}.ctaband p{color:#c2ccd4;max-width:54ch;margin:0 auto 1.5em}
.ctaband .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.ctaband::before{content:"";position:absolute;width:260px;height:260px;border:2px dashed rgba(255,255,255,.12);
  border-radius:50%;top:-90px;right:-60px}

/* blog */
.bloggrid{display:grid;gap:22px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.postcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.postcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.postcard img{aspect-ratio:16/9;object-fit:cover;width:100%}
.postcard .pc-body{padding:20px;display:flex;flex-direction:column;gap:.5em;flex:1}
.postcard h3{margin:0;font-size:1.15rem}.postcard a{text-decoration:none}
.postcard time{font-family:var(--mono);font-size:.78rem;color:var(--muted)}
.postcard p{color:var(--ink-2);font-size:.93rem;margin:0}
.article{max-width:760px;margin:0 auto}
.article .lead{max-width:none}
/* blog elrendezés sticky sidebarral */
.article-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:42px;align-items:start}
.article-grid .article{max-width:none;margin:0}
.blog-side{position:sticky;top:88px;display:grid;gap:18px}
.tldr{background:var(--brand-soft);border:1px solid #f5cca7;border-radius:var(--rad-lg);padding:20px 24px;margin:1.5em 0}
.tldr h2{font-size:1rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5em;color:var(--brand-deep)}
.tldr ul{margin:0;padding-left:1.2em}
.faq-tldr{list-style:none;padding:0;margin:0;display:grid;gap:.8em;max-width:820px}
.faq-tldr li{display:flex;gap:.6em;align-items:flex-start;font-size:1.02rem}
.faq-tldr li .ic{width:23px;height:23px;flex:0 0 auto;fill:var(--brand);margin-top:3px}
figure.tile{margin:0}
figure.tile blockquote{margin:0}
figure.tile blockquote .ic{width:18px;height:18px;fill:var(--brand)}
figure.tile blockquote p{margin:.6em 0 0;font-size:1.02rem;color:#23292f;font-style:italic}
figure.tile figcaption{margin-top:1.1em;font-size:.92rem}
.article h2{margin-top:1.7em}.article figure{margin:1.5em 0}
.article figcaption{font-size:.84rem;color:var(--muted);text-align:center;margin-top:.5em}
.byline{display:flex;flex-wrap:wrap;align-items:center;gap:.35em .55em;color:var(--muted);
  font-size:.9rem;line-height:1.5;margin:0 0 1.5em;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:12px 16px}
.byline .ic{width:20px;height:20px;fill:var(--brand-deep);flex:0 0 auto}
.byline strong{color:var(--ink);font-weight:700}
.byline .sep{color:var(--line-2)}
.byline time{white-space:nowrap}

/* térkép */
.map-wrap{border-radius:var(--rad-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:16/7}
.map{width:100%;height:100%;border:0;display:block}

/* 404 */
.notfound{text-align:center;padding:clamp(50px,9vw,120px) 0}
.notfound .big{font-family:var(--mono);font-size:clamp(4rem,18vw,9rem);font-weight:800;color:var(--brand);line-height:1}
.notfound .hero-ctas{justify-content:center;flex-wrap:wrap}

/* kapcsolat */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--rad-lg);padding:28px;box-shadow:var(--shadow)}
.contact-card .row{display:flex;align-items:center;gap:.7em;padding:12px 0;border-bottom:1px solid var(--surface-3);font-weight:600}
.contact-card .row .ic{width:24px;height:24px;fill:var(--brand-deep)}
.contact-card .row a{text-decoration:none}

/* ===== Lábléc — modern, csempés ===== */
.site-foot{background:var(--ink-deep);color:#c2ccd4;margin-top:64px;position:relative;overflow:hidden}
.foot-cta{max-width:var(--maxw);margin:0 auto;padding:40px 20px;display:flex;
  flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.09)}
.foot-cta-txt{max-width:46ch}
.foot-cta-txt h2{color:#fff;margin:.3em 0 .3em;font-size:clamp(1.4rem,1.1rem+1.2vw,2rem)}
.foot-cta-txt p{color:#aebac6;margin:0}
.foot-cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.foot-in{max-width:var(--maxw);margin:0 auto;padding:48px 20px 30px;display:grid;
  grid-template-columns:1.35fr 2fr;gap:40px}
.f-brand .f-logo{display:inline-flex;align-items:center;gap:.5em;color:#fff;font-weight:800;
  font-size:1.08rem;margin-bottom:.7em;text-decoration:none}
.f-brand .f-logo .ic{fill:var(--brand);width:24px;height:24px}
.f-nap{font-size:.92rem;line-height:1.6;color:#aebac6;margin-bottom:1em}
.f-rating{display:flex;align-items:center;gap:.5em;font-size:.9rem;color:#dbe2e9;margin:0 0 1.2em}
.f-rating .stars{display:inline-flex}.f-rating .stars .ic{width:16px;height:16px;fill:var(--brand)}
.f-tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.f-tile{display:flex;align-items:center;gap:.7em;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:12px 14px;
  text-decoration:none;color:#e7ecf1;transition:background .15s,border-color .15s,transform .15s}
a.f-tile:hover{background:rgba(255,255,255,.08);border-color:var(--brand);transform:translateY(-2px);color:#fff}
.f-tile .ic,.f-tile .ic-wrap .ic{width:22px;height:22px;fill:var(--brand);flex:0 0 auto}
.f-tile>span{display:flex;flex-direction:column;font-weight:700;font-size:.9rem;line-height:1.25;min-width:0}
.f-tile>span small{font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#8c99a5}
.f-links{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.f-h{font-size:.74rem;text-transform:uppercase;letter-spacing:.07em;color:#8c99a5;margin:0 0 1em;font-weight:700}
.f-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.6em}
.f-col a{color:#c2ccd4;text-decoration:none;font-size:.92rem}.f-col a:hover{color:#fff;text-decoration:underline}
.foot-bar{border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;
  gap:8px 24px;justify-content:space-between;max-width:var(--maxw);margin:0 auto;padding:18px 20px}
.foot-bar p{margin:0;font-size:.82rem;color:#8c99a5}
.f-nyitva{font-weight:600}

/* reveal-on-scroll (progresszív; alapból látható) */
.reveal{}
html.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
html.js .reveal.in{opacity:1;transform:none}

/* ===== Reszponzív ===== */
@media(max-width:900px){
  .hero-grid{grid-template-columns:minmax(0,1fr);gap:32px}
  .hero-art{max-width:440px;margin:0 auto;order:-1}
  .entity-grid{grid-template-columns:minmax(0,1fr)}
  .sidebar{position:static;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
  .article-grid{grid-template-columns:1fr}
  .blog-side{position:static;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
  .contact-grid{grid-template-columns:1fr}
  .foot-in{grid-template-columns:1fr}
  .foot-cta{flex-direction:column;align-items:flex-start}
}
@media(max-width:760px){
  body{font-size:16px}
  .mainnav{position:fixed;inset:68px 0 auto 0;background:var(--paper);
    border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
    max-height:0;overflow:hidden;transition:max-height .28s ease;flex:none}
  .mainnav-in{flex-direction:column;align-items:stretch;padding:10px 16px;gap:2px}
  .navlink{padding:.85em 1em;font-size:1.05rem}
  .mnu-cb:checked~.mainnav{max-height:80vh}
  .mnu-btn{display:grid;place-items:center;width:46px;height:46px;border-radius:10px;
    border:1px solid var(--line);background:var(--surface);cursor:pointer;order:3}
  .mnu-btn .ic{width:26px;height:26px;fill:var(--ink)}
  .mnu-cb:checked~.mnu-btn .ic:first-child{display:none}
  .mnu-cb:checked~.mnu-btn .mnu-x{display:block}
  .mnu-x{position:static}
  .head-cta{display:none}
  .head-in{flex-wrap:wrap}
}
@media(max-width:540px){
  .foot-in{grid-template-columns:1fr}
  .f-links{grid-template-columns:1fr 1fr}
  .f-tiles{grid-template-columns:1fr}
  .tiles,.steps,.prices{grid-template-columns:1fr}
  .hero-ctas .btn,.ctaband .btn,.foot-cta-btns .btn{width:100%;justify-content:center}
}

/* mozgáscsökkentés (15.8) */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  html.js .reveal{opacity:1;transform:none}
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
