:root {
  --surface: #121414;
  --surface-low: #1a1c1c;
  --surface-container: #1e2020;
  --surface-high: #282a2b;
  --surface-highest: #333535;
  --surface-lowest: #0c0f0f;
  --on-surface: #e6e6e6;
  --on-surface-variant: #d8c9b2;
  --outline: #9d8f79;
  --outline-variant: #504533;
  --primary: #f9b722;
  --primary-container: #f9b722;
  --on-primary: #3a2800;
  --secondary: #c9c8d6;
  --success: #7fd18b;
  --danger: #ffb4ab;
  --ink-dark: #1a1200;
  --ff: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --maxw: 1180px;
  --gutter: 20px;
  --radius: 4px;
  --radius-lg: 8px;
  --radius-xl: 14px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  margin: 0; font-family: var(--ff); font-size: 17px; line-height: 1.7;
  color: var(--on-surface); background: var(--surface);
  overflow-x: clip; -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
svg { display: block; }
a { color: var(--primary); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--primary-container); }
h1,h2,h3,h4,h5 {
  font-weight: 800; line-height: 1.18; margin: 0 0 .5em;
  letter-spacing: -.01em; color: #fff;
}
h1 { font-size: clamp(30px, 5vw, 50px); text-transform: uppercase; }
h2 { font-size: clamp(24px, 3.4vw, 34px); text-transform: uppercase; }
h3 { font-size: clamp(19px, 2.4vw, 23px); }
h4 { font-size: 18px; }
h5 { font-size: 16px; text-transform: uppercase; letter-spacing: .04em; }
p { margin: 0 0 1.05em; }
strong { color: #fff; }
ul,ol { margin: 0 0 1.1em; padding-left: 1.2em; }
li { margin: .3em 0; }
:focus-visible { outline: 3px solid var(--primary); outline-offset: 2px; border-radius: 3px; }

/* ---------- Layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: clamp(48px, 7vw, 84px) 0; }
.section--alt { background: var(--surface-low); border-block: 1px solid var(--surface-high); }
.eyebrow {
  display: inline-block; background: var(--primary-container); color: var(--on-primary);
  font-weight: 700; font-size: 12.5px; letter-spacing: .08em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 999px; margin-bottom: 14px;
}
.lead { font-size: 19px; color: var(--on-surface-variant); max-width: 62ch; }
.center { text-align: center; }
.center .lead { margin-inline: auto; }
.muted { color: var(--on-surface-variant); }
.mt0 { margin-top: 0; }

/* ---------- Skip link ---------- */
.skip {
  position: absolute; left: 8px; top: -60px; z-index: 200;
  background: var(--primary-container); color: var(--on-primary); font-weight: 700;
  padding: 10px 16px; border-radius: 6px; transition: top .15s; text-decoration: none;
}
.skip:focus { top: 8px; }

/* ---------- Top info bar ---------- */
.topbar { background: var(--surface-lowest); border-bottom: 1px solid var(--surface-low); font-size: 13px; }
.topbar .wrap { display: flex; justify-content: space-between; align-items: center; gap: 12px; min-height: 38px; flex-wrap: wrap; }
.topbar a { color: var(--on-surface-variant); text-decoration: none; }
.topbar a:hover { color: var(--primary); }
.topbar__group { display: flex; gap: 18px; align-items: center; flex-wrap: wrap; }
.topbar__social { display: flex; gap: 10px; }
.topbar__social a { display: inline-flex; }
.ico { width: 18px; height: 18px; flex: none; vertical-align: middle; fill: currentColor; }
.ico--sm { width: 15px; height: 15px; }
.ico--lg { width: 24px; height: 24px; }

/* ---------- Header / nav ---------- */
.site-header {
  position: sticky; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(18,20,20,.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--surface-high);
}
.nav { display: flex; align-items: center; justify-content: space-between; min-height: 66px; gap: 16px; }
.brand {
  font-weight: 800; font-size: 25px; letter-spacing: -.02em; font-style: italic;
  color: var(--primary); text-decoration: none; text-transform: uppercase; flex: none;
}
.brand span { color: #fff; }
.nav__toggle { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.nav__menu { display: flex; align-items: center; gap: 26px; margin: 0 auto; list-style: none; padding: 0; }
.nav__menu a {
  color: var(--on-surface); text-decoration: none; font-weight: 600; font-size: 14px;
  text-transform: uppercase; letter-spacing: .04em; padding: 6px 0; border-bottom: 2px solid transparent;
}
.nav__menu a:hover { color: var(--primary); }
.nav__menu a[aria-current="page"] { color: var(--primary); border-bottom-color: var(--primary); }
.nav__cta { flex: none; display: inline-flex; align-items: center; gap: 8px; }
.nav__burger { display: none; }
.nav__burger label {
  display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px;
  border: 1px solid var(--outline-variant); border-radius: 8px; color: var(--primary); cursor: pointer;
}
.nav__burger .ico { width: 24px; height: 24px; }
.nav__burger .close { display: none; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-weight: 700; font-size: 14.5px; text-transform: uppercase; letter-spacing: .04em;
  padding: 13px 22px; border-radius: var(--radius); border: 1px solid transparent;
  cursor: pointer; text-decoration: none; transition: filter .15s, background .15s, color .15s;
  line-height: 1; text-align: center;
}
.btn--primary { background: var(--primary-container); color: var(--on-primary); }
.btn--primary:hover { filter: brightness(1.08); color: var(--on-primary); }
.btn--ghost { background: transparent; border-color: var(--outline); color: #fff; }
.btn--ghost:hover { background: #fff; color: var(--surface); }
.btn--block { width: 100%; }
.btn--sm { padding: 10px 16px; font-size: 13px; }
.btn .ico { width: 18px; height: 18px; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--surface-high); }
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg svg, .hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero__scrim { position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(90deg, var(--surface) 12%, rgba(18,20,20,.82) 48%, rgba(18,20,20,.35) 100%); }
.hero__inner { position: relative; z-index: 2; padding: clamp(52px, 8vw, 104px) 0; }
.hero__content { max-width: 640px; }
.hero h1 { margin-bottom: 18px; }
.hero .accent { color: var(--primary-container); }
.hero__lead { font-size: 19px; color: var(--on-surface-variant); margin-bottom: 26px; max-width: 54ch; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 26px; }
.hero__proof { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; color: var(--on-surface-variant); font-size: 14px; }
.stars { display: inline-flex; gap: 2px; color: var(--primary-container); }
.stars .ico { width: 18px; height: 18px; }

/* ---------- Grids / cards ---------- */
.grid { display: grid; gap: 20px; }
.grid--2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
.grid > * { min-width: 0; }
.bento { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; }
.bento > * { min-width: 0; }
.bento .col2 { grid-column: span 2; }
.card {
  background: var(--surface-container); border: 1px solid var(--surface-high);
  border-radius: var(--radius-lg); padding: 26px; transition: border-color .15s;
}
.card:hover { border-color: var(--outline); }
.card h3 { text-transform: uppercase; }
.card__icon {
  width: 52px; height: 52px; border-radius: 999px; display: inline-flex; align-items: center;
  justify-content: center; background: rgba(249,183,34,.16); border: 1px solid rgba(249,183,34,.4);
  color: var(--primary-container); margin-bottom: 16px;
}
.card__icon .ico { width: 26px; height: 26px; }
.card--feature { position: relative; overflow: hidden; min-height: 230px; display: flex; flex-direction: column; justify-content: flex-end; }
.card--feature .card__bg { position: absolute; inset: 0; opacity: .22; z-index: 0; }
.card--feature > *:not(.card__bg) { position: relative; z-index: 1; }

/* ---------- Stat tiles ---------- */
.stats { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 16px; }
.stats > * { min-width: 0; }
.stat { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); padding: 22px; }
.stat .ico { width: 26px; height: 26px; color: var(--primary-container); margin-bottom: 8px; }
.stat__num { font-size: 30px; font-weight: 800; color: #fff; line-height: 1.1; }
.stat__label { font-size: 13.5px; color: var(--on-surface-variant); margin-top: 4px; }

/* ---------- Process timeline ---------- */
.timeline { position: relative; margin: 0; padding: 0; list-style: none; }
.timeline::before { content: ""; position: absolute; left: 21px; top: 8px; bottom: 8px; width: 2px; background: var(--outline-variant); }
.timeline li { position: relative; padding: 0 0 26px 60px; margin: 0; }
.timeline li:last-child { padding-bottom: 0; }
.timeline__num {
  position: absolute; left: 0; top: 0; width: 44px; height: 44px; border-radius: 999px;
  background: var(--primary-container); color: var(--on-primary); font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center; font-size: 18px;
}
.timeline h3 { margin-bottom: .3em; }

/* ---------- Callout ---------- */
.callout {
  background: var(--surface-high); border-left: 5px solid var(--primary-container);
  border-radius: var(--radius-lg); padding: 18px 22px; margin: 0 0 1.2em;
}
.callout--tip { border-left-color: var(--success); }
.callout h4 { margin: 0 0 .35em; color: #fff; }
.callout__t { margin: 0 0 .35em; color: #fff; font-weight: 800; font-size: 17px; }
.callout p:last-child { margin-bottom: 0; }

/* ---------- TL;DR ---------- */
.tldr {
  background: var(--surface-container); border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg); padding: 22px 24px; margin: 0 0 26px;
}
.tldr h2 { font-size: 17px; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .5em; color: var(--primary); }
.tldr ul { margin: 0; }

/* ---------- Price cards ---------- */
.prices { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; align-items: start; }
.prices > * { min-width: 0; }
.price {
  position: relative; background: var(--surface-container); border: 1px solid var(--surface-high);
  border-radius: var(--radius-xl); padding: 28px; display: flex; flex-direction: column;
}
.price--hot { border-color: var(--primary-container); box-shadow: 0 0 0 1px var(--primary-container); }
.price__ribbon {
  position: absolute; top: 16px; right: -1px; background: var(--primary-container); color: var(--on-primary);
  font-weight: 800; font-size: 11.5px; letter-spacing: .06em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 6px 0 0 6px;
}
.price h3 { text-transform: uppercase; margin-bottom: .2em; }
.price__tag { font-size: 14px; color: var(--on-surface-variant); min-height: 42px; margin-bottom: 8px; }
.price__amount { font-size: 34px; font-weight: 800; color: #fff; }
.price__amount span { font-size: 15px; font-weight: 600; color: var(--on-surface-variant); }
.price__meta { font-size: 13.5px; color: var(--primary); margin: 4px 0 16px; }
.price ul { list-style: none; padding: 0; margin: 0 0 20px; }
.price li { display: flex; gap: 9px; align-items: flex-start; font-size: 14.5px; margin: 9px 0; color: var(--on-surface-variant); }
.price li .ico { width: 18px; height: 18px; color: var(--primary-container); flex: none; margin-top: 2px; }
.price .btn { margin-top: auto; }
.price__nohidden { font-size: 12.5px; color: var(--success); margin-top: 10px; display: flex; gap: 6px; align-items: center; justify-content: center; }

/* ---------- Forms ---------- */
.form { display: grid; gap: 16px; }
.form__row { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.form__row > * { min-width: 0; }
.field label { display: block; font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 6px; color: var(--on-surface-variant); }
.field input, .field select, .field textarea {
  width: 100%; background: var(--surface-high); border: 1px solid var(--surface-highest);
  color: var(--on-surface); border-radius: var(--radius); padding: 12px 14px; font: inherit;
  font-size: 15px;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--primary-container); outline: none; }
.field textarea { resize: vertical; min-height: 110px; }
.consent { display: flex; gap: 10px; align-items: flex-start; font-size: 13.5px; color: var(--on-surface-variant); }
.consent input { margin-top: 3px; width: 18px; height: 18px; flex: none; accent-color: var(--primary-container); }

/* ---------- Tables ---------- */
.table-scroll { overflow-x: auto; max-width: 100%; border-radius: var(--radius-lg); border: 1px solid var(--surface-high); }
table.data { width: 100%; border-collapse: collapse; font-size: 14.5px; min-width: 420px; }
table.data caption { text-align: left; padding: 12px 14px; font-weight: 700; color: var(--on-surface-variant); }
table.data th, table.data td { padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--surface-high); }
table.data thead th { background: var(--surface-high); color: #fff; font-size: 12.5px; text-transform: uppercase; letter-spacing: .03em; }
table.data tbody tr:hover { background: rgba(255,255,255,.02); }

/* ---------- Breadcrumb ---------- */
.crumbs { font-size: 13px; color: var(--on-surface-variant); padding: 16px 0 0; }
.crumbs ol { list-style: none; display: flex; flex-wrap: wrap; gap: 6px; padding: 0; margin: 0; }
.crumbs a { color: var(--on-surface-variant); text-decoration: none; }
.crumbs a:hover { color: var(--primary); text-decoration: underline; }
.crumbs li::after { content: "/"; margin-left: 6px; color: var(--outline); }
.crumbs li:last-child::after { content: ""; }
.crumbs [aria-current] { color: var(--on-surface); }

/* ---------- Article + sidebar layout ---------- */
.layout { display: grid; grid-template-columns: minmax(0,1fr) 320px; gap: 40px; align-items: start; }
.layout > * { min-width: 0; }
.content { min-width: 0; overflow-wrap: break-word; }
.content h2 { margin-top: 1.6em; }
.content h3 { margin-top: 1.3em; }
.content > *:first-child { margin-top: 0; }
.content figure { margin: 24px 0; }
.content figure img { border-radius: var(--radius-lg); border: 1px solid var(--surface-high); width: 100%; }
.content figcaption { font-size: 13px; color: var(--on-surface-variant); margin-top: 8px; text-align: center; }

/* ---------- TOC (a torzs elott) ---------- */
.toc { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); padding: 18px 22px; margin: 0 0 28px; }
.toc h2 { font-size: 14px; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .6em; color: var(--primary); }
.toc ol { margin: 0; padding-left: 1.2em; columns: 2; column-gap: 28px; font-size: 14.5px; }
.toc a { color: var(--on-surface-variant); text-decoration: none; }
.toc a:hover { color: var(--primary); text-decoration: underline; }

/* ---------- Sidebar (konverzio elso) ---------- */
.sidebar { position: sticky; top: 84px; align-self: start; display: grid; gap: 20px; }
.side-cta { background: var(--surface-container); border: 1px solid var(--primary-container); border-radius: var(--radius-xl); padding: 24px; }
.side-cta__badge { display: inline-block; background: var(--primary-container); color: var(--on-primary); font-weight: 800; font-size: 11.5px; letter-spacing: .06em; text-transform: uppercase; padding: 4px 11px; border-radius: 999px; margin-bottom: 12px; }
.side-cta__price { font-size: 28px; font-weight: 800; color: #fff; }
.side-cta__price span { font-size: 14px; font-weight: 600; color: var(--on-surface-variant); }
.side-cta p { font-size: 14.5px; color: var(--on-surface-variant); }
.side-cta ul { list-style: none; padding: 0; margin: 14px 0; }
.side-cta li { display: flex; gap: 8px; align-items: flex-start; font-size: 14px; margin: 8px 0; color: var(--on-surface-variant); }
.side-cta li .ico { width: 17px; height: 17px; color: var(--primary-container); flex: none; margin-top: 2px; }
.side-cta .btn { margin-top: 6px; }
.side-cta__tel { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 10px; font-weight: 700; color: #fff; text-decoration: none; }
.side-cta__tel .ico { width: 17px; height: 17px; color: var(--primary-container); flex: none; }
.side-facts { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); padding: 20px; }
.side-facts h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .05em; color: var(--primary); margin-bottom: 12px; }
.side-facts dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: 6px 14px; font-size: 14px; }
.side-facts dt { color: var(--on-surface-variant); }
.side-facts dd { margin: 0; color: #fff; font-weight: 600; text-align: right; }
.side-rating { display: flex; align-items: center; gap: 8px; justify-content: center; margin-top: 10px; font-size: 13px; color: var(--on-surface-variant); }

/* ---------- FAQ (CSS-only accordion) ---------- */
.faq { display: grid; gap: 12px; }
.faq details { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); }
.faq summary { cursor: pointer; padding: 16px 20px; font-weight: 700; color: #fff; list-style: none; display: flex; justify-content: space-between; gap: 14px; align-items: center; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--primary-container); font-size: 22px; font-weight: 700; flex: none; }
.faq details[open] summary::after { content: "-"; }
.faq summary:hover { color: var(--primary); }
.faq__body { padding: 0 20px 18px; color: var(--on-surface-variant); }
.faq__body p:last-child { margin-bottom: 0; }

/* ---------- Author box ---------- */
.author { display: flex; gap: 18px; background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); padding: 24px; margin: 34px 0; align-items: flex-start; }
.author > div { min-width: 0; }
.avatar { width: 66px; height: 66px; border-radius: 999px; background: var(--primary-container); color: var(--on-primary); font-weight: 800; font-size: 24px; display: inline-flex; align-items: center; justify-content: center; flex: none; }
.avatar--lg { width: 92px; height: 92px; font-size: 34px; }
.author__name { font-weight: 800; color: #fff; font-size: 18px; }
.author__name a { color: #fff; text-decoration: none; }
.author__name a:hover { color: var(--primary); }
.author__title { font-size: 13.5px; color: var(--primary); margin-bottom: 6px; }
.author__bio { font-size: 14.5px; color: var(--on-surface-variant); margin-bottom: 10px; }
.socials { display: flex; gap: 10px; flex-wrap: wrap; }
.socials a { width: 36px; height: 36px; border-radius: 999px; background: var(--surface-high); color: var(--on-surface); display: inline-flex; align-items: center; justify-content: center; }
.socials a:hover { background: var(--primary-container); color: var(--on-primary); }
.socials .ico { width: 18px; height: 18px; }

/* ---------- Chips / tags ---------- */
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: var(--surface-high); color: var(--on-surface); border: 1px solid var(--outline-variant); border-radius: 999px; padding: 5px 13px; font-size: 13px; text-decoration: none; }
a.chip:hover { border-color: var(--primary-container); color: var(--primary); }

/* ---------- Post/car cards (listing) ---------- */
.cards { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 22px; }
.cards > * { min-width: 0; }
.pcard { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: border-color .15s, transform .15s; }
.pcard:hover { border-color: var(--outline); }
.pcard__thumb { aspect-ratio: 16/9; background: var(--surface-high); overflow: hidden; }
.pcard__thumb img, .pcard__thumb svg { width: 100%; height: 100%; object-fit: cover; }
.pcard__body { padding: 18px 20px 20px; display: flex; flex-direction: column; flex: 1; }
.pcard__cat { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--primary); font-weight: 700; margin-bottom: 7px; }
.pcard h3 { font-size: 18px; margin-bottom: 8px; }
.pcard h3 a { color: #fff; text-decoration: none; }
.pcard h3 a:hover { color: var(--primary); }
.pcard p { font-size: 14px; color: var(--on-surface-variant); margin-bottom: 14px; }
.pcard__meta { margin-top: auto; font-size: 12.5px; color: var(--on-surface-variant); display: flex; gap: 12px; align-items: center; }

/* ---------- Contact split ---------- */
.contact-info { display: grid; gap: 22px; }
.contact-item { display: flex; gap: 14px; align-items: flex-start; }
.contact-item .ico { width: 26px; height: 26px; color: var(--primary-container); flex: none; margin-top: 2px; }
.contact-item h3 { margin: 0 0 3px; text-transform: uppercase; font-size: 13px; letter-spacing: .04em; }
.contact-item p { margin: 0; font-size: 15px; color: var(--on-surface-variant); }
.map-embed { width: 100%; aspect-ratio: 16/9; border: 1px solid var(--surface-high); border-radius: var(--radius-lg); margin-top: 8px; }

/* ---------- Coverage ---------- */
.coverage { display: flex; flex-wrap: wrap; gap: 8px; }

/* ---------- Footer ---------- */
.footer { background: var(--surface-lowest); border-top: 1px solid var(--outline-variant); }
.footer__cta { background: linear-gradient(120deg, var(--surface-high), var(--surface-container)); border: 1px solid var(--outline-variant); border-radius: var(--radius-xl); padding: 30px; margin: 0 0 48px; display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer__cta h2 { margin: 0; font-size: 26px; }
.footer__cta p { margin: 6px 0 0; color: var(--on-surface-variant); }
.footer__chips { display: flex; gap: 12px; flex-wrap: wrap; margin: 0 0 40px; }
.fchip { display: inline-flex; align-items: center; gap: 9px; background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: 999px; padding: 9px 16px; color: var(--on-surface); text-decoration: none; font-size: 14px; }
.fchip .ico { color: var(--primary-container); }
.fchip:hover { border-color: var(--primary-container); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 30px; padding-bottom: 34px; border-bottom: 1px solid var(--surface-high); }
.footer__grid > * { min-width: 0; }
.footer__brand { font-weight: 800; font-size: 24px; font-style: italic; color: var(--primary); text-transform: uppercase; margin-bottom: 12px; display: inline-block; text-decoration: none; }
.footer p { font-size: 14px; color: var(--on-surface-variant); }
.footer h3 { text-transform: uppercase; font-size: 13px; letter-spacing: .05em; margin-bottom: 14px; color: #fff; }
.footer ul { list-style: none; padding: 0; margin: 0; }
.footer li { margin: 8px 0; }
.footer li a { color: var(--on-surface-variant); text-decoration: none; font-size: 14px; }
.footer li a:hover { color: var(--primary); }
.footer__hours { font-size: 13.5px; color: var(--on-surface-variant); }
.footer__hours span { color: #fff; }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; padding: 22px 0; font-size: 13px; color: var(--on-surface-variant); }
.footer__bottom a { color: var(--on-surface-variant); text-decoration: none; }
.footer__bottom a:hover { color: var(--primary); }
.footer__legal { display: flex; gap: 18px; flex-wrap: wrap; }
.totop { display: inline-flex; align-items: center; gap: 7px; color: var(--primary); text-decoration: none; font-weight: 600; font-size: 13px; }

/* ---------- Prose helpers ---------- */
.readmeta { font-size: 13.5px; color: var(--on-surface-variant); display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 18px; }
.readmeta .ico { width: 16px; height: 16px; color: var(--primary); vertical-align: -3px; margin-right: 4px; }
.updated { font-size: 13px; color: var(--on-surface-variant); margin-top: 6px; }
.tag-row { display: flex; gap: 10px; flex-wrap: wrap; margin: 20px 0; }

/* ---------- Alpha index (details) ---------- */
.azindex { margin: 0 0 20px; }
.azindex summary { cursor: pointer; font-weight: 700; padding: 12px 0; color: var(--primary); }
.azcols { columns: 3; column-gap: 26px; font-size: 14.5px; }
.azcols a { display: block; padding: 3px 0; color: var(--on-surface-variant); text-decoration: none; }
.azcols a:hover { color: var(--primary); }

/* ---------- Tetel-lista kartyak (Mit nezunk at tetelesen) ---------- */
.kwgrid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 20px; }
.kwgrid > * { min-width: 0; }
.kwcard { background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-xl); padding: 24px; transition: border-color .15s, transform .15s; }
.kwcard:hover { border-color: var(--primary-container); transform: translateY(-3px); }
.kwcard__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.kwcard__icon { width: 46px; height: 46px; flex: none; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; background: rgba(249,183,34,.16); border: 1px solid rgba(249,183,34,.45); color: var(--primary-container); }
.kwcard__icon .ico { width: 24px; height: 24px; }
.kwcard__head h3 { margin: 0; font-size: 18px; text-transform: none; }
.kwlist { list-style: none; padding: 0; margin: 0; }
.kwlist li { display: flex; gap: 9px; align-items: flex-start; font-size: 14px; color: var(--on-surface-variant); margin: 10px 0; line-height: 1.5; }
.kwlist li .ico { width: 17px; height: 17px; color: var(--primary-container); flex: none; margin-top: 3px; }
.kwcta { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-top: 26px; padding: 24px 28px; background: linear-gradient(120deg, var(--surface-high), var(--surface-container)); border: 1px solid var(--primary-container); border-radius: var(--radius-xl); }
.kwcta > div { color: var(--on-surface-variant); font-size: 15px; }
.kwcta strong { color: #fff; font-size: 17px; }
.kwaccent { font-size: 12.5px; color: var(--on-surface-variant); margin-top: 18px; opacity: .85; }

/* ---------- Kompakt kapcsolodo-tartalom kartyak (blog<->auto belso linkek) ---------- */
.linkgrid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.linkgrid > * { min-width: 0; }
.linkcard { display: block; background: var(--surface-container); border: 1px solid var(--surface-high); border-left: 3px solid var(--primary-container); border-radius: var(--radius-lg); padding: 14px 16px; text-decoration: none; transition: border-color .12s, transform .12s; }
.linkcard:hover { border-color: var(--primary-container); border-left-color: var(--primary-container); transform: translateY(-2px); }
.linkcard__cat { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--primary); font-weight: 700; margin-bottom: 5px; }
.linkcard__title { color: #fff; font-weight: 600; font-size: 14.5px; line-height: 1.35; }
.linkcard:hover .linkcard__title { color: var(--primary); }
.linkcard__meta { font-size: 12px; color: var(--on-surface-variant); margin-top: 7px; display: flex; gap: 6px; align-items: center; }

/* ---------- Kompakt auto-lista (/autok) ---------- */
.azgrid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 10px; }
.azgrid > * { min-width: 0; }
.autochip { display: flex; align-items: center; justify-content: space-between; gap: 8px; background: var(--surface-container); border: 1px solid var(--surface-high); border-radius: var(--radius-lg); padding: 10px 14px; text-decoration: none; transition: border-color .12s, background .12s; }
.autochip:hover { border-color: var(--primary-container); background: var(--surface-high); }
.autochip__name { color: var(--on-surface); font-weight: 600; font-size: 14px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.autochip:hover .autochip__name { color: var(--primary); }
.autochip__pt { flex: none; font-size: 10.5px; text-transform: uppercase; letter-spacing: .03em; color: var(--on-surface-variant); border: 1px solid var(--outline-variant); border-radius: 999px; padding: 2px 8px; }
.segblock { margin: 0 0 34px; }
.segblock__head { display: flex; align-items: baseline; gap: 10px; border-bottom: 1px solid var(--surface-high); padding-bottom: 10px; margin-bottom: 16px; }
.segblock__head h2 { margin: 0; font-size: 22px; }
.segblock__count { font-size: 13px; color: var(--on-surface-variant); }

/* ---------- Utility (inline-style helyett, szigoru CSP) ---------- */
.mb-lg { margin-bottom: 40px; }
.mb-md { margin-bottom: 30px; }
.mb-sm { margin-bottom: 20px; }
.mt-lg { margin-top: 30px; }
.mt-md { margin-top: 20px; }
.mt-sm { margin-top: 12px; }
.mt-xs { margin-top: 8px; }
.pt-md { padding-top: 24px; }
.pt-lg { padding-top: 60px; }
.pb-0 { padding-bottom: 0; }
.m0 { margin: 0; }
.tight-y { margin: .2em 0; }
.mx-auto { margin-left: auto; margin-right: auto; }
.narrow { max-width: 820px; margin-left: auto; margin-right: auto; }
.narrow-sm { max-width: 640px; margin-left: auto; margin-right: auto; }
.gap-lg { gap: 40px; }
.jc-center { justify-content: center; }
.inherit { color: inherit; }
.chips-row { margin: 20px 0 30px; }
.consent-label { text-transform: none; font-weight: 400; letter-spacing: 0; margin: 0; }

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .layout { grid-template-columns: minmax(0, 1fr); }
  .sidebar { position: static; order: 2; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .bento .col2 { grid-column: span 3; }
  .kwgrid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .azgrid { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .linkgrid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 760px) {
  body { font-size: 16px; }
  .nav__menu {
    position: fixed; inset: 66px 0 auto 0; flex-direction: column; gap: 0;
    background: var(--surface-low); border-bottom: 1px solid var(--surface-high);
    padding: 8px 0; margin: 0; max-height: 0; overflow: hidden; transition: max-height .25s ease;
  }
  .nav__menu li { width: 100%; text-align: center; }
  .nav__menu a { display: block; padding: 14px 0; border-bottom: none; }
  .nav__toggle:checked ~ .nav__menu { max-height: 420px; }
  .nav__toggle:checked ~ .nav__burger .open { display: none; }
  .nav__toggle:checked ~ .nav__burger .close { display: block; }
  .nav__burger { display: inline-flex; }
  .nav__cta { display: none; }
  .nav__menu .nav__cta--mobile { display: block; padding: 14px 0; }
  .grid--2, .grid--3, .grid--4, .bento, .prices, .cards, .stats, .kwgrid, .linkgrid { grid-template-columns: 1fr; }
  .azgrid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .kwcta { flex-direction: column; align-items: flex-start; }
  .bento .col2 { grid-column: auto; }
  .form__row { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__cta { flex-direction: column; align-items: flex-start; }
  .toc ol { columns: 1; }
  .azcols { columns: 1; }
  .hero__scrim { background: linear-gradient(180deg, rgba(18,20,20,.55), var(--surface) 88%); }
  /* Tablazat -> kartya mobilon */
  table.data.responsive { min-width: 0; }
  table.data.responsive thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
  table.data.responsive tr { display: block; border-bottom: 2px solid var(--surface-high); padding: 8px 0; }
  table.data.responsive td { display: flex; justify-content: space-between; gap: 16px; border: none; padding: 6px 14px; }
  table.data.responsive td::before { content: attr(data-label); font-weight: 700; color: var(--on-surface-variant); }
}
@media (max-width: 430px) {
  .nav__cta .label { display: none; }
  .stat__num { font-size: 26px; }
}
@media print {
  .site-header, .footer, .sidebar, .topbar { display: none; }
}
