/* =========================================================
   partner.szerelvenycenter.hu — Mockup design system
   Tokenek a BRAND.md alapján (1:1 átemelve), komponensek
   B2B-fókusszal: letisztult, funkcionális, sok whitespace.
   ========================================================= */

:root {
  /* ---- Színek (BRAND.md UI paletta) ----
     Igazítva a fő szerelvenycenter.hu brand-jéhez (P&S Pipes Kft.):
     a kék #0553A4 (logo külső kör) a primary, a piros #ED1C24
     (logo belső kör) az accent. A navy #2F3A56 továbbra is secondary
     ink-szín (sötét szövegekhez, header / chip-háttér). */
  --color-primary: #0553A4;
  --color-primary-hover: #04457B;
  --color-primary-light: rgba(5, 83, 164, 0.14);
  --color-secondary: #2F3A56;
  --color-secondary-light: #6E86C5;
  --color-accent: #ED1C24;
  --color-accent-hover: #C81720;
  --color-text: #525869;
  --color-surface: #E1E6EA;
  --color-bg: #FFFFFF;
  --color-black: #000000;

  /* Származtatott */
  --color-text-strong: #1F2738;
  --color-border: #E1E6EA;
  --color-muted: #8A92A3;
  --color-bg-soft: #F6F8FA;
  --color-success-bg: #E8F4EC;
  --color-success-text: #2F6B45;
  --color-warning-bg: #FFF5E5;
  --color-warning-text: #8A5A00;

  /* ---- Tipográfia ---- */
  --font-family: "Montserrat", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-size-display: clamp(2rem, 4vw, 3rem);
  --font-size-h1: clamp(1.5rem, 2.5vw, 2rem);
  --font-size-h2: 1.5rem;
  --font-size-h3: 1.25rem;
  --font-size-body: 1rem;
  --font-size-small: 0.875rem;
  --font-size-xs: 0.75rem;

  /* ---- Border-radius ---- */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* ---- Spacing (8 px alap) ---- */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 40px;
  --space-8: 48px;
  --space-9: 56px;
  --space-10: 64px;
  --space-11: 80px;
  --space-12: 96px;

  /* ---- Container ---- */
  --container-max: 1200px;
  --container-padding: var(--space-5);

  /* ---- Egyéb ---- */
  --shadow-card: 0 1px 2px rgba(31, 39, 56, 0.04), 0 4px 12px rgba(31, 39, 56, 0.06);
  --shadow-elev: 0 2px 4px rgba(31, 39, 56, 0.06), 0 12px 32px rgba(31, 39, 56, 0.10);
  --header-height: 72px;
  --transition: 0.18s ease;
}

/* =========================================================
   Reset / alap
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  font-family: var(--font-family);
  font-size: var(--font-size-body);
  font-weight: 400;
  line-height: 1.55;
  color: var(--color-text);
  background-color: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-secondary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-primary); }

h1, h2, h3, h4 {
  color: var(--color-text-strong);
  margin: 0 0 var(--space-3);
  font-weight: 700;
  line-height: 1.25;
}
h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); font-weight: 600; }
h3 { font-size: var(--font-size-h3); font-weight: 600; }
p  { margin: 0 0 var(--space-3); }

ul, ol { margin: 0 0 var(--space-3); padding-left: 1.25rem; }

/* =========================================================
   Layout primitívek
   ========================================================= */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-padding);
}

.section { padding: var(--space-10) 0; }
.section--tight { padding: var(--space-6) 0; }
.section--soft { background-color: var(--color-bg-soft); }

.stack > * + * { margin-top: var(--space-4); }
.stack-lg > * + * { margin-top: var(--space-6); }

.cluster { display: flex; flex-wrap: wrap; gap: var(--space-3); align-items: center; }

.grid { display: grid; gap: var(--space-5); }
.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)); }

/* Mockup annotation banner (deploy előtt el lesz távolítva) */
.mockup-annotation {
  background: #FFF8E1;
  color: #6B4A00;
  border-bottom: 1px solid #F1D98A;
  padding: var(--space-2) var(--space-5);
  font-size: var(--font-size-small);
  font-weight: 500;
  text-align: center;
}

/* =========================================================
   Header
   ========================================================= */
.site-header {
  height: var(--header-height);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  position: sticky; top: 0; z-index: 50;
}
.site-header__inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-5);
}
.site-header__logo {
  display: flex; align-items: center; gap: var(--space-3);
  text-decoration: none;
}
.site-header__logo-text {
  display: flex; flex-direction: column; line-height: 1.1;
}
.site-header__logo-text strong {
  color: var(--color-primary);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}
.site-header__logo-text span {
  color: var(--color-secondary);
  font-weight: 600;
  font-size: 0.78rem;
}

.site-nav {
  display: flex; align-items: center; gap: var(--space-5);
  margin-left: var(--space-4);
}
.site-nav a {
  color: var(--color-text);
  font-weight: 500;
  font-size: var(--font-size-small);
  padding: var(--space-2) 0;
  border-bottom: 2px solid transparent;
}
.site-nav a:hover, .site-nav a.is-active {
  color: var(--color-secondary);
  border-bottom-color: var(--color-primary);
}

.site-header__spacer { flex: 1 1 auto; }

.site-header__search {
  position: relative;
  flex: 0 1 280px;
}
.site-header__search input {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-4) 0 36px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-bg-soft);
  font-family: inherit;
  font-size: var(--font-size-small);
  color: var(--color-text-strong);
}
.site-header__search input:focus {
  outline: none;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(47, 58, 86, 0.15);
  background: var(--color-bg);
}
.site-header__search svg {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--color-muted);
}

.site-header__actions {
  display: flex; align-items: center; gap: var(--space-3);
}
.site-header__user {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text-strong);
  font-weight: 500;
}
.site-header__cart {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-bg-soft);
  color: var(--color-text-strong);
  font-weight: 600;
  font-size: var(--font-size-small);
  border: 1px solid var(--color-border);
}
.site-header__cart:hover { background: var(--color-surface); color: var(--color-secondary); }
.site-header__cart-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 22px; padding: 0 6px;
  border-radius: var(--radius-pill);
  background: var(--color-primary); color: #fff;
  font-size: var(--font-size-xs); font-weight: 700;
}

/* =========================================================
   Footer
   ========================================================= */
/* =========================================================
   Footer V2 — premium navy footer brand-anchor + ikonos kontakt
   ========================================================= */
.site-footer {
  position: relative;
  background: linear-gradient(180deg, #2F3A56 0%, #1F2840 100%);
  color: rgba(255, 255, 255, 0.78);
  padding: var(--space-10) 0 var(--space-5);
  margin-top: var(--space-12);
  overflow: hidden;
}
.site-footer__accent {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.site-footer::after {
  content: "";
  position: absolute;
  top: -120px; right: -100px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.20), transparent 65%);
  pointer-events: none;
}
.site-footer .container { position: relative; z-index: 1; }

.site-footer__grid {
  display: grid;
  gap: var(--space-7);
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  padding-bottom: var(--space-7);
}

/* Brand-anchor blokk */
.site-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 360px;
}
.site-footer__logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: #fff;
}
.site-footer__logo:hover { color: #fff; }
.site-footer__logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.site-footer__logo__text strong {
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -0.005em;
}
.site-footer__logo__text span {
  color: rgba(255, 255, 255, 0.55);
  font-size: var(--font-size-xs);
  font-weight: 500;
  margin-top: 2px;
}
.site-footer__brand__eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.site-footer__brand__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: var(--space-1);
}
.site-footer__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.85);
}
.site-footer__pill svg { color: var(--color-secondary-light); }

/* Oszlopok */
.site-footer__col {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.site-footer__title {
  margin: 0 0 var(--space-2);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
}
.site-footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.site-footer__list li {
  font-size: var(--font-size-small);
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.72);
}
.site-footer__list a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  transition: color var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.site-footer__list a:hover {
  color: #fff;
}
.site-footer__list a:hover .site-footer__ext {
  color: var(--color-secondary-light);
}
.site-footer__ext {
  color: rgba(255, 255, 255, 0.40);
  font-size: 0.78em;
  transition: color var(--transition);
}

/* Ikonos kontakt-lista */
.site-footer__list--icons li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: rgba(255, 255, 255, 0.78);
}
.site-footer__list--icons a {
  display: inline;
}
.site-footer__icon {
  flex-shrink: 0;
  margin-top: 3px;
  color: var(--color-secondary-light);
  opacity: 0.85;
}

/* Linkek előtti kicsi piktogramok (Partneri felület + Jogi tudnivalók) */
.site-footer__list--linkicons a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.site-footer__linkicon {
  flex-shrink: 0;
  color: var(--color-secondary-light);
  opacity: 0.65;
  transition: opacity var(--transition), color var(--transition);
}
.site-footer__list--linkicons a:hover .site-footer__linkicon {
  opacity: 1;
  color: #fff;
}

/* Bottom row — copyright + sub */
.site-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.10);
  padding-top: var(--space-4);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.55);
}
.site-footer__bottom__legal strong {
  color: rgba(255, 255, 255, 0.85);
  font-weight: 700;
}
.site-footer__bottom__sub {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.site-footer__bottom__sub a {
  color: rgba(255, 255, 255, 0.72);
  border-bottom: 1px dotted rgba(255, 255, 255, 0.30);
  transition: color var(--transition), border-color var(--transition);
}
.site-footer__bottom__sub a:hover {
  color: #fff;
  border-color: #fff;
}
.site-footer__bottom__sep {
  color: rgba(255, 255, 255, 0.30);
  font-weight: 700;
}

/* Mobil */
@media (max-width: 880px) {
  .site-footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
  }
  .site-footer__brand { grid-column: 1 / -1; max-width: 100%; }
}
@media (max-width: 540px) {
  .site-footer__grid { grid-template-columns: 1fr; }
  .site-footer__bottom { justify-content: flex-start; }
}

/* =========================================================
   Buttons
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  height: 44px;
  padding: 0 var(--space-5);
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: var(--font-size-body);
  font-weight: 600;
  line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
  text-decoration: none;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.btn--primary:hover { background: #04457B; border-color: #04457B; color: #fff; }

.btn--secondary {
  background: transparent;
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}
.btn--secondary:hover { background: var(--color-secondary); color: #fff; }

.btn--tertiary {
  background: transparent;
  color: var(--color-secondary);
  border-color: transparent;
  padding: 0 var(--space-2);
  height: auto;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.btn--tertiary:hover { color: var(--color-primary); }

.btn--sm { height: 36px; padding: 0 var(--space-4); font-size: var(--font-size-small); }
.btn--block { width: 100%; }

/* =========================================================
   Inputs / forms
   ========================================================= */
.field { display: block; }
.field + .field { margin-top: var(--space-4); }
.field__label {
  display: block;
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--color-text-strong);
  margin-bottom: var(--space-2);
}
.field__hint {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  margin-top: var(--space-1);
}

.input,
.select,
.textarea {
  width: 100%;
  height: 44px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  font-family: inherit;
  font-size: var(--font-size-body);
  color: var(--color-text-strong);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.textarea {
  height: auto;
  min-height: 110px;
  padding: var(--space-3);
  resize: vertical;
  line-height: 1.5;
}
.input:focus,
.select:focus,
.textarea:focus {
  outline: none;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(47, 58, 86, 0.18);
}

/* Honeypot — vizuálisan rejtve, screen-readeren is rejtve */
.honeypot {
  position: absolute !important;
  left: -10000px !important;
  width: 1px !important; height: 1px !important;
  overflow: hidden;
}

/* Quantity input */
.qty {
  display: inline-flex; align-items: stretch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-bg);
}
.qty button {
  width: 36px; border: 0; background: var(--color-bg-soft);
  color: var(--color-text-strong);
  font-size: 1.1rem; font-weight: 600;
  cursor: pointer;
}
.qty button:hover { background: var(--color-surface); }
.qty input {
  width: 56px; border: 0; text-align: center;
  font-family: inherit; font-size: var(--font-size-body);
  font-weight: 600; color: var(--color-text-strong);
  background: var(--color-bg);
}
.qty input:focus { outline: none; }

/* =========================================================
   Cards
   ========================================================= */
.card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow: var(--shadow-card);
}
.card--flat { box-shadow: none; }

/* Termékkártya */
.product-card {
  display: flex; flex-direction: column;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
}
.product-card:hover { box-shadow: var(--shadow-elev); transform: translateY(-2px); }
.product-card__media {
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  background: var(--color-bg-soft);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: var(--font-size-small);
  position: relative;
  overflow: hidden;
}
.product-card__body { padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3); flex: 1; }
.product-card__brand { font-size: var(--font-size-xs); color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; }
.product-card__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text-strong);
  margin: 0;
  line-height: 1.35;
  /* Fix 2-soros magasság hogy minden kártyán a stock-badge és az ár-blokk
     ugyanazon vertikális pozíción legyen, csoport-rácsban. */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(1rem * 1.35 * 2);
}
.product-card__title a { color: inherit; }
.product-card__title a:hover { color: var(--color-primary); }
.product-card__meta { font-size: var(--font-size-small); color: var(--color-text); }
.product-card__footer {
  margin-top: auto; display: flex; flex-direction: column; gap: var(--space-3);
}

/* Kategória kártya */
.category-card {
  display: flex; flex-direction: column; gap: var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  transition: box-shadow var(--transition), transform var(--transition);
  color: var(--color-text-strong);
}
.category-card:hover { box-shadow: var(--shadow-elev); transform: translateY(-2px); color: var(--color-text-strong); }
.category-card__icon {
  width: 48px; height: 48px; border-radius: var(--radius-md);
  background: rgba(5, 83, 164, 0.10);
  color: var(--color-primary);
  display: flex; align-items: center; justify-content: center;
}
.category-card h3 { margin: 0; font-size: 1.05rem; }
.category-card p { margin: 0; font-size: var(--font-size-small); color: var(--color-text); }

/* =========================================================
   Badges
   ========================================================= */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  background: var(--color-surface);
  color: var(--color-text-strong);
  white-space: nowrap;
}
.badge--success { background: var(--color-success-bg); color: var(--color-success-text); }
.badge--warning { background: var(--color-warning-bg); color: var(--color-warning-text); }
.badge--neutral { background: var(--color-bg-soft); color: var(--color-text); }
.badge--accent { background: rgba(5, 83, 164, 0.12); color: var(--color-primary); }

.badge-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: currentColor; flex-shrink: 0;
}

/* Stacked badge motívum (csak hero — max 1×) */
.stacked-badge {
  display: inline-flex; flex-direction: column; align-items: flex-start; gap: 0;
}
.stacked-badge__top {
  background: var(--color-secondary);
  color: #fff;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-lg);
  font-weight: 600;
  font-size: var(--font-size-small);
  letter-spacing: 0.02em;
}
.stacked-badge__bottom {
  margin-top: -4px;
  margin-left: var(--space-5);
  background: var(--color-bg);
  color: var(--color-text);
  padding: 6px var(--space-3);
  border-radius: var(--radius-lg);
  font-weight: 500;
  font-size: var(--font-size-xs);
  border: 1px solid var(--color-border);
}

/* Ár-bontás */
.price-block {
  display: flex; flex-direction: column; gap: var(--space-1);
}
.price-block__net {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.1;
}
.price-block__gross {
  font-size: var(--font-size-small);
  color: var(--color-muted);
}
.price-block__label {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}

.price-block--lg .price-block__net { font-size: 2rem; }
.price-block--inline { flex-direction: row; align-items: baseline; gap: var(--space-3); }

/* Ár-zárolt info (publikus) */
.price-locked {
  display: flex; gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-bg-soft);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  align-items: flex-start;
}
.price-locked__icon {
  width: 40px; height: 40px; border-radius: var(--radius-md);
  background: var(--color-secondary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.price-locked__body strong { display: block; color: var(--color-text-strong); margin-bottom: 2px; }
.price-locked__body p { margin: 0; font-size: var(--font-size-small); }
.price-locked__body a { font-weight: 600; }

/* =========================================================
   Tables
   ========================================================= */
.table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg);
  font-size: var(--font-size-small);
}
.table th, .table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid var(--color-border);
}
.table thead th {
  background: var(--color-bg-soft);
  font-weight: 600;
  color: var(--color-text-strong);
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.table tbody tr:nth-child(even) { background: rgba(225, 230, 234, 0.32); }
.table tbody tr:hover { background: var(--color-bg-soft); }
.table--rounded {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.table .num { text-align: right; font-variant-numeric: tabular-nums; }

/* Kompakt műszaki adattábla */
.spec-table th { width: 40%; background: var(--color-bg-soft); }
.spec-table td { color: var(--color-text-strong); }

/* =========================================================
   Hero
   ========================================================= */
.hero {
  background: var(--color-bg-soft);
  padding: var(--space-9) 0;
  position: relative;
}
.hero__card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: clamp(var(--space-5), 4vw, var(--space-9));
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
  box-shadow: var(--shadow-card);
}
.hero__col {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-align: left;
}
.hero__col--action {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.hero__col--action h3 {
  margin: 0 0 var(--space-1);
  font-size: 1.05rem;
  color: var(--color-text-strong);
}
.hero__col--action__hint {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin: 0;
  line-height: 1.5;
}
.hero__eyebrow {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  background: rgba(5, 83, 164, 0.10);
  color: var(--color-primary);
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.hero__eyebrow__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--color-primary);
}
.hero__title {
  font-size: clamp(1.875rem, 3.6vw, 2.625rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--color-text-strong);
  font-weight: 700;
  text-wrap: balance;
}
.hero__subtitle {
  font-size: 1.0625rem;
  color: var(--color-text);
  margin: 0;
  line-height: 1.55;
}
.hero__search {
  width: 100%;
  display: flex;
  align-items: stretch;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.hero__search:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.14);
}
.hero__search__icon {
  display: flex; align-items: center;
  padding-left: var(--space-4);
  color: var(--color-muted);
}
.hero__search__input {
  flex: 1;
  min-width: 0;
  border: 0;
  outline: 0;
  padding: var(--space-3);
  font: inherit;
  font-size: 0.95rem;
  background: transparent;
  color: var(--color-text-strong);
}
.hero__search__input::placeholder { color: var(--color-muted); }
.hero__search__submit {
  border: 0;
  padding: 0 var(--space-5);
  background: var(--color-primary);
  color: #ffffff;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--transition);
}
.hero__search__submit:hover { background: var(--color-primary-hover); }
.hero__ctas {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-2);
}

@media (max-width: 880px) {
  .hero__card { grid-template-columns: 1fr; gap: var(--space-5); }
  .hero__title { font-size: 1.625rem; }
}

/* =========================================================
   Bizonyíték-strip a hero alatt
   ========================================================= */
.proof-strip {
  background: #ffffff;
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-5) 0;
}
.proof-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
}
.proof-strip__cell {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.proof-strip__icon {
  width: 36px; height: 36px;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  background: rgba(47, 58, 86, 0.08);
  color: var(--color-secondary);
}
.proof-strip__value {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.2;
}
.proof-strip__label {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}

/* =========================================================
   Department-cards — két termékvonal egyenrangúan
   ========================================================= */
.departments {
  padding: var(--space-10) 0;
  background: var(--color-bg);
}
.departments__intro {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: var(--space-6);
}
.departments__title { margin: 0; font-size: 1.5rem; }
.departments__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}
.department-card {
  position: relative;
  display: flex; flex-direction: column;
  padding: var(--space-7);
  border-radius: var(--radius-lg);
  background: #ffffff;
  border: 1px solid var(--color-border);
  color: var(--color-text-strong);
  text-decoration: none;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.department-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-primary);
  box-shadow: var(--shadow-elev);
  color: var(--color-text-strong);
}
.department-card__head {
  display: flex; align-items: center; gap: var(--space-4);
  margin-bottom: var(--space-3);
}
.department-card__glyph {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-secondary);
}
.department-card__title { margin: 0; font-size: 1.5rem; line-height: 1.1; letter-spacing: -0.01em; }
.department-card__count {
  font-size: var(--font-size-small);
  color: var(--color-muted);
  margin: 2px 0 0;
}
.department-card__lead {
  font-size: var(--font-size-small);
  color: var(--color-text);
  line-height: 1.5;
  margin: 0 0 var(--space-4);
}
.department-card__chips__label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.department-card__chips {
  display: flex; flex-wrap: wrap; gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.dep-chip {
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  color: var(--color-text-strong);
  font-size: var(--font-size-xs);
  font-weight: 600;
}
.department-card__cta {
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-weight: 700;
  font-size: var(--font-size-small);
  color: var(--color-primary);
}
.department-card__cta::after { content: "→"; transition: transform var(--transition); }
.department-card:hover .department-card__cta::after { transform: translateX(4px); }

@media (max-width: 720px) {
  .proof-strip__grid { grid-template-columns: 1fr 1fr; gap: var(--space-3); }
}
.hero__visual {
  background: #ffffff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  padding: var(--space-7);
  display: flex; flex-direction: column; gap: var(--space-4);
  position: relative;
  overflow: hidden;
}
.hero__login__title {
  font-size: 1.25rem;
  font-weight: 700;
  margin: 0;
  color: var(--color-text-strong);
}
.hero__login__sub {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin: 0;
}
.hero__login__field {
  display: flex; flex-direction: column; gap: 4px;
  margin: 0;
}
.hero__login__field .field__label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  font-weight: 600;
}
.hero__login__footer {
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
}
.hero__greeting__pills {
  display: flex; flex-direction: column; gap: var(--space-2);
}
.hero__greeting__pill {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-strong);
  font-weight: 600;
  font-size: var(--font-size-small);
  text-decoration: none;
  transition: border-color var(--transition), background var(--transition);
}
.hero__greeting__pill:hover {
  border-color: var(--color-secondary);
  background: var(--color-bg);
  color: var(--color-text-strong);
}
.hero__greeting__pill::after { content: "→"; opacity: 0.6; }

@media (max-width: 720px) {
  .hero__visual { padding: var(--space-5); }
}

/* =========================================================
   Auth (login / register) layout
   ========================================================= */
.auth-shell {
  min-height: calc(100vh - var(--header-height) - 200px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-10) var(--container-padding);
  background: var(--color-bg-soft);
}
.auth-card {
  width: 100%;
  max-width: 460px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  box-shadow: var(--shadow-card);
}
.auth-card--wide { max-width: 640px; }
.auth-card h1 { margin-bottom: var(--space-2); }
.auth-card__lead { color: var(--color-text); margin-bottom: var(--space-6); }
.auth-card__divider {
  border: 0; border-top: 1px solid var(--color-border);
  margin: var(--space-6) 0;
}
.auth-card__footer {
  text-align: center;
  font-size: var(--font-size-small);
  color: var(--color-text);
}

/* =========================================================
   B2B catalog: szűrők + grid
   ========================================================= */
.catalog {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: var(--space-6);
  align-items: start;
}
.filter-panel {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  position: sticky; top: calc(var(--header-height) + var(--space-4));
}
.filter-panel h3 {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-muted);
  margin: 0 0 var(--space-3);
}
.filter-group { margin-bottom: var(--space-5); }
.filter-group:last-child { margin-bottom: 0; }
.filter-group label {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text-strong);
  padding: 6px 0;
  cursor: pointer;
}
.filter-group input[type="checkbox"] { accent-color: var(--color-secondary); }
.filter-group__count { color: var(--color-muted); margin-left: auto; font-size: var(--font-size-xs); }

.catalog__toolbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.catalog__count { color: var(--color-text); font-size: var(--font-size-small); }

/* =========================================================
   Cart
   ========================================================= */
.cart-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--space-6);
  align-items: start;
}
.cart-summary {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  position: sticky; top: calc(var(--header-height) + var(--space-4));
}
.cart-summary h3 { margin-bottom: var(--space-4); }
.cart-summary__row {
  display: flex; justify-content: space-between;
  padding: var(--space-2) 0;
  font-size: var(--font-size-small);
}
.cart-summary__row--total {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text-strong);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-3);
  margin-top: var(--space-2);
}

/* =========================================================
   Admin dashboard
   ========================================================= */
.admin-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.stat-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
}
.stat-card__label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  margin-bottom: var(--space-2);
  font-weight: 600;
}
.stat-card__value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1;
}
.stat-card__delta {
  margin-top: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-muted);
}

.tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.tabs__btn {
  background: transparent;
  border: 0;
  padding: var(--space-3) var(--space-5);
  font-family: inherit;
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--color-text);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.tabs__btn.is-active {
  color: var(--color-secondary);
  border-bottom-color: var(--color-primary);
}

.admin-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-3); margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

/* Toggle switch (admin aktív kapcsoló) */
.switch {
  position: relative; display: inline-block;
  width: 38px; height: 22px;
}
.switch input { opacity: 0; width: 0; height: 0; }
.switch__slider {
  position: absolute; inset: 0;
  background: var(--color-surface);
  border-radius: var(--radius-pill);
  transition: background var(--transition);
  cursor: pointer;
}
.switch__slider::before {
  content: "";
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #fff;
  transition: transform var(--transition);
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.switch input:checked + .switch__slider { background: var(--color-secondary); }
.switch input:checked + .switch__slider::before { transform: translateX(16px); }

/* Inline price override input */
.price-input {
  width: 110px; height: 36px;
  padding: 0 var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: inherit; font-size: var(--font-size-small);
  text-align: right;
}
.price-input:focus { outline: none; border-color: var(--color-secondary); box-shadow: 0 0 0 2px rgba(47,58,86,0.15); }

/* =========================================================
   Egyéb segéd-osztályok
   ========================================================= */
.text-muted { color: var(--color-muted); }
.text-small { font-size: var(--font-size-small); }
.text-xs { font-size: var(--font-size-xs); }
.text-strong { color: var(--color-text-strong); font-weight: 600; }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }

.divider { border: 0; border-top: 1px solid var(--color-border); margin: var(--space-6) 0; }

.callout {
  background: var(--color-bg-soft);
  border-left: 3px solid var(--color-secondary-light);
  border-radius: var(--radius-sm);
  padding: var(--space-4);
  font-size: var(--font-size-small);
}

.feature {
  display: flex; flex-direction: column; gap: var(--space-3);
}
.feature__icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: var(--color-secondary);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
}
.feature h3 { margin: 0; font-size: 1.05rem; }
.feature p { margin: 0; font-size: var(--font-size-small); }

/* Index / overview oldal */
.overview-list {
  display: grid; gap: var(--space-4);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.overview-item {
  display: flex; gap: var(--space-4);
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  transition: box-shadow var(--transition), transform var(--transition);
  color: var(--color-text-strong);
}
.overview-item:hover { box-shadow: var(--shadow-elev); transform: translateY(-2px); color: var(--color-text-strong); }
.overview-item__num {
  width: 40px; height: 40px; flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--color-secondary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.overview-item h3 { margin: 0 0 4px; font-size: 1rem; }
.overview-item p { margin: 0; font-size: var(--font-size-small); color: var(--color-text); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalog { grid-template-columns: 1fr; }
  .filter-panel { position: static; }
  .cart-grid { grid-template-columns: 1fr; }
  .cart-summary { position: static; }
  .admin-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  :root { --container-padding: var(--space-4); }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .hero { padding: var(--space-7) 0; }
  .hero__card { grid-template-columns: 1fr; gap: var(--space-5); }
  .site-nav { display: none; }
  .site-header__search { display: none; }
  .site-footer__grid { grid-template-columns: 1fr; }
  .overview-list { grid-template-columns: 1fr; }
  .admin-stats { grid-template-columns: 1fr; }
  .table { font-size: var(--font-size-xs); }
  .table th, .table td { padding: var(--space-2) var(--space-3); }
}

/* ============================================================
   Auth feedback — alert + form-grid + required marker
   (Hozzáadva az auth modul implementálásakor)
   ============================================================ */

.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-5);
  font-size: var(--font-size-small);
  border: 1px solid transparent;
}
.alert--error {
  background: #FEEBEC;
  border-color: var(--color-primary-light);
  color: #8C1D20;
}
.alert--success {
  background: #E7F4EC;
  border-color: #B6DEC4;
  color: #1F5A33;
}
.alert div + div { margin-top: var(--space-1); }

.field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4) var(--space-5);
}
@media (max-width: 768px) {
  .field-grid { grid-template-columns: 1fr; }
}

.field__required {
  color: var(--color-primary);
  font-weight: 700;
  margin-left: 2px;
}

/* ============================================================
   Admin felület — admin-nav + reject-details
   (Hozzáadva az admin partneri jóváhagyás modulnál)
   ============================================================ */

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  border-bottom: 1px solid var(--color-surface);
  margin-bottom: var(--space-6);
}
.admin-nav a {
  display: inline-block;
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  text-decoration: none;
  font-weight: 500;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 120ms, border-color 120ms;
}
.admin-nav a:hover {
  color: var(--color-secondary);
}
.admin-nav a.is-active {
  color: var(--color-secondary);
  border-bottom-color: var(--color-primary);
}
.admin-nav a[aria-disabled="true"] {
  opacity: 0.4;
  pointer-events: none;
}

.reject-details {
  display: inline-block;
  position: relative;
}
.reject-details > summary {
  list-style: none;
  cursor: pointer;
}
.reject-details > summary::-webkit-details-marker {
  display: none;
}
.reject-details[open] > summary {
  background: var(--color-secondary);
  color: var(--color-bg);
  border-color: var(--color-secondary);
}
.reject-form {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  width: 320px;
  padding: var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px rgba(47, 58, 86, 0.15);
  z-index: 10;
  text-align: left;
}
.reject-form .field__label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text);
}
.reject-form .input {
  width: 100%;
  resize: vertical;
}

/* ============================================================
   Admin termékek lista — szűrő + key-value lista
   (Hozzáadva az admin termékek modulnál)
   ============================================================ */

.filter-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr auto;
  gap: var(--space-4);
  align-items: end;
}
@media (max-width: 1100px) {
  .filter-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .filter-grid { grid-template-columns: 1fr; }
}

.kv-list {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--space-2) var(--space-4);
  margin: 0;
  font-size: var(--font-size-small);
}
.kv-list dt {
  color: var(--color-text);
  opacity: 0.75;
}
.kv-list dd {
  margin: 0;
  color: var(--color-secondary);
}

/* ============================================================
   Katalógus modul (#8) — kiegészítések a meglévő .product-card-hoz
   ============================================================ */

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-4);
}

.product-card__locked {
  display: inline-block;
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  color: var(--color-text);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-small);
  font-weight: 500;
}

.price-block__gross {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin-top: 2px;
  display: block;
}

/* ── Manufacturer grid (homepage) ── */
.manufacturer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3);
}
.manufacturer-card {
  display: block;
  padding: var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-surface);
  border-radius: var(--radius-md);
  text-decoration: none;
  text-align: center;
  transition: transform 120ms, box-shadow 120ms, border-color 120ms;
}
.manufacturer-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-primary);
  box-shadow: 0 4px 12px rgba(47, 58, 86, 0.08);
}
.manufacturer-card__name {
  font-weight: 700;
  color: var(--color-secondary);
  font-size: var(--font-size-h3);
}
.manufacturer-card__count {
  font-size: var(--font-size-small);
  color: var(--color-text);
  opacity: 0.7;
  margin-top: var(--space-1);
}

/* ── Breadcrumb ── */
.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}
.breadcrumb a {
  color: var(--color-text);
  text-decoration: none;
}
.breadcrumb a:hover { color: var(--color-secondary); }
.breadcrumb span { color: var(--color-text); opacity: 0.4; }

/* ── Product detail ── */
.product-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-6);
}
@media (max-width: 800px) {
  .product-detail-grid { grid-template-columns: 1fr; }
}
.product-detail__image,
.product-detail__image-placeholder {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  overflow: hidden;
}
.product-detail__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.product-detail__manufacturer {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  color: var(--color-text);
  opacity: 0.7;
  margin-bottom: var(--space-2);
}
.product-detail__title {
  margin: 0 0 var(--space-2);
  color: var(--color-secondary);
  font-size: var(--font-size-h1);
}
.product-detail__sku {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin-bottom: var(--space-5);
}
.product-detail__price-block {
  background: var(--color-surface);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
}
.product-detail__price-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--space-1) 0;
}
.product-detail__price-label {
  font-size: var(--font-size-small);
  color: var(--color-text);
}
.product-detail__price-net {
  font-size: var(--font-size-h2);
  color: var(--color-secondary);
}
.product-detail__price-gross {
  font-size: var(--font-size-body);
  color: var(--color-text);
}
.product-detail__stock {
  margin-bottom: var(--space-4);
}
.product-detail__actions {
  margin-top: var(--space-4);
}
.product-detail__price-locked-block {
  background: var(--color-surface);
  padding: var(--space-5);
  border-radius: var(--radius-md);
  text-align: center;
  color: var(--color-secondary);
}

/* Termék-leírás HTML zone — hosszú UNAS HTML, korlátozzuk a stílust */
.product-detail-description {
  max-width: 800px;
}
.product-detail-description h2 {
  margin: 0 0 var(--space-4);
  font-size: var(--font-size-h2);
  color: var(--color-secondary);
}
.product-detail-description__short,
.product-detail-description__long {
  font-size: var(--font-size-body);
  color: var(--color-text);
  line-height: 1.7;
}
.product-detail-description img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
}
.product-detail-description h3 {
  font-size: var(--font-size-h3);
  color: var(--color-secondary);
  margin: var(--space-5) 0 var(--space-2);
}
.product-detail-description p { margin: 0 0 var(--space-3); }
.product-detail-description ul,
.product-detail-description ol { margin: 0 0 var(--space-3); padding-left: var(--space-5); }
.product-detail-description li { margin: var(--space-1) 0; }

/* ============================================================
   Kosár modul (#9) — invalid sor kiemelése + muted badge
   ============================================================ */

.cart-row--invalid {
  background: #FFF5F5;
}
.cart-row--invalid td {
  opacity: 0.7;
}

.badge--muted {
  background: var(--color-surface);
  color: var(--color-text);
}

/* ============================================================
   UNAS termékkép — 404 esetén nincs broken-icon, csak a háttér
   (a CSS-trükk: alt text láthatatlan, broken-image overlay-jel
    a parent elem szín-háttere maradja meg)
   ============================================================ */

.product-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: var(--space-3);
  display: block;
  /* Broken image: szöveg alt + broken icon helyett csak a parent háttér */
  color: transparent;
  font-size: 0;
}

.product-detail__image img {
  /* Ugyanaz: 404 esetén a placeholder háttér jön elő */
  color: transparent;
  font-size: 0;
}

/* ============================================================
   Két-ár megjelenítés (Partneri + Ajánlott fogyasztói) + AKCIÓ badge
   (Klimaplaza inspiráció — quick-win a katalógus-kártyán és termékoldalon)
   ============================================================ */

/* AKCIÓ sticker a kártya bal felső sarkán */
.product-card__media {
  position: relative;
}
.product-card__sale-badge {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  background: var(--color-primary);
  color: var(--color-bg);
  font-weight: 700;
  font-size: var(--font-size-small);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  z-index: 1;
  box-shadow: 0 2px 6px rgba(226, 71, 75, 0.35);
  letter-spacing: 0.02em;
}

/* Kártyán: ajánlott fogyasztói + marzs sor */
.price-block__retail {
  display: block;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-surface);
  font-size: var(--font-size-small);
  color: var(--color-text);
  line-height: 1.5;
}
.price-block__retail strong {
  color: var(--color-secondary);
}
.price-block__margin {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--color-primary);
  font-weight: 600;
  margin-top: 2px;
}

/* Termékoldali ár-blokk: AKCIÓS banner + ajánlott fogyasztói + marzs sor */
.product-detail__sale-banner {
  background: var(--color-primary);
  color: var(--color-bg);
  font-weight: 600;
  text-align: center;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-3);
  font-size: var(--font-size-small);
  letter-spacing: 0.02em;
}
.product-detail__price-row--retail {
  border-top: 1px dashed var(--color-surface);
  margin-top: var(--space-2);
  padding-top: var(--space-3);
}
.product-detail__price-retail {
  color: var(--color-secondary);
  font-weight: 600;
}
.product-detail__price-row--margin {
  background: rgba(226, 71, 75, 0.08);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  margin-top: var(--space-2);
}

/* ============================================================
   Két ár egymás MELLETT (klimaplaza-inspiráció): viszonteladói + fogyasztói
   A két ár-kártya független adat — nincs "akció" badge köztük.
   ============================================================ */

.price-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
@media (max-width: 480px) {
  .price-pair { grid-template-columns: 1fr; }
}

.price-card {
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  position: relative;
  overflow: hidden;
}

.price-card--reseller {
  background: linear-gradient(135deg, rgba(226, 71, 75, 0.08), rgba(226, 71, 75, 0.03));
  border: 1px solid rgba(226, 71, 75, 0.18);
}
.price-card--retail {
  background: var(--color-surface);
  border: 1px solid var(--color-surface);
}

.price-card__label {
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--color-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.price-card__sublabel {
  font-size: var(--font-size-xs);
  color: var(--color-text);
  opacity: 0.65;
  margin-bottom: var(--space-2);
}
.price-card--reseller .price-card__value {
  font-size: var(--font-size-h1);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.1;
}
.price-card--retail .price-card__value {
  font-size: var(--font-size-h2);
  font-weight: 700;
  color: var(--color-secondary);
  line-height: 1.1;
}
.price-card__detail {
  font-size: var(--font-size-xs);
  color: var(--color-text);
  opacity: 0.75;
  margin-top: var(--space-2);
}
.price-card__detail--margin {
  color: var(--color-primary);
  font-weight: 700;
  opacity: 1;
}

/* ============================================================
   Műszaki adatok táblázat (UNAS Paraméter mezőkből — strukturált)
   + Termékdokumentumok lista
   ============================================================ */

.tech-params-group {
  font-size: var(--font-size-h3);
  color: var(--color-secondary);
  margin: var(--space-4) 0 var(--space-2);
}

.tech-params-table {
  width: 100%;
  max-width: 720px;
  border-collapse: collapse;
  margin-bottom: var(--space-4);
  font-size: var(--font-size-small);
}
.tech-params-table tr {
  border-bottom: 1px solid var(--color-surface);
}
.tech-params-table tr:nth-child(even) {
  background: rgba(225, 230, 234, 0.3);
}
.tech-params-table th {
  text-align: left;
  font-weight: 500;
  color: var(--color-text);
  padding: var(--space-2) var(--space-3);
  width: 50%;
  vertical-align: top;
}
.tech-params-table td {
  padding: var(--space-2) var(--space-3);
  color: var(--color-secondary);
  font-weight: 600;
}

.documents-list {
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: 720px;
}
.documents-list li {
  margin: var(--space-2) 0;
}
.documents-list a {
  display: inline-flex;
  align-items: center;
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  color: var(--color-secondary);
  text-decoration: none;
  font-weight: 500;
  font-size: var(--font-size-small);
  transition: background 120ms;
}
.documents-list a:hover {
  background: var(--color-surface);
  color: var(--color-primary);
}

/* ============================================================
   Katalógus oldal — bal oldali szűrő-sidebar + termékek grid (D)
   ============================================================ */

.catalog-search {
  display: flex;
  gap: var(--space-2);
}
.catalog-search .input { flex: 1; }

.catalog-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-5);
  align-items: start;
}
@media (max-width: 800px) {
  .catalog-layout { grid-template-columns: 1fr; }
}

.catalog-sidebar {
  position: sticky;
  top: var(--space-4);
}
@media (max-width: 800px) {
  .catalog-sidebar { position: static; }
}

.catalog-filters {
  background: var(--color-bg);
  border: 1px solid var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.catalog-filter-group {
  border-bottom: 1px solid var(--color-surface);
  padding-bottom: var(--space-4);
  margin-bottom: var(--space-4);
}
.catalog-filter-group:last-of-type {
  border-bottom: 0;
  padding-bottom: 0;
  margin-bottom: 0;
}
.catalog-filter-group h3 {
  font-size: var(--font-size-small);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-secondary);
  margin: 0 0 var(--space-3);
  font-weight: 700;
}

.catalog-filter-checkboxes {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  max-height: 320px;
  overflow-y: auto;
  padding-right: var(--space-2);
}
.catalog-filter-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text);
  cursor: pointer;
  padding: 4px 0;
  user-select: none;
}
.catalog-filter-item input[type="checkbox"] {
  cursor: pointer;
  margin: 0;
  flex-shrink: 0;
}
.catalog-filter-item:hover { color: var(--color-secondary); }

.catalog-filter-toggle {
  cursor: pointer;
  color: var(--color-text);
  font-size: var(--font-size-small);
  list-style: none;
  padding: var(--space-1) 0;
}
.catalog-filter-toggle::before { content: '▸ '; }
details[open] > .catalog-filter-toggle::before { content: '▾ '; }

.catalog-main { min-width: 0; /* prevent grid blowout */ }

/* ============================================================
   UNAS API import — kategória-lista row stílus
   ============================================================ */

.api-import-cat-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-surface);
  cursor: pointer;
  transition: background 120ms;
}
.api-import-cat-row:last-child { border-bottom: 0; }
.api-import-cat-row:hover { background: rgba(225, 230, 234, 0.4); }
.api-import-cat-row input[type="checkbox"] { cursor: pointer; flex-shrink: 0; }

/* =========================================================
   Termékvonal-hub (klíma + hőszivattyú) — főoldal hero alatt
   és a /katalogus/<group> oldal tetején
   ========================================================= */
.product-lines-hub {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  margin-bottom: var(--space-8);
}
@media (max-width: 720px) { .product-lines-hub { grid-template-columns: 1fr; } }

.product-line-card {
  position: relative;
  display: flex; flex-direction: column;
  padding: var(--space-6);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-strong);
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
  overflow: hidden;
  text-decoration: none;
  min-height: 200px;
}
.product-line-card:hover {
  box-shadow: var(--shadow-elev);
  transform: translateY(-2px);
  color: var(--color-text-strong);
}
.product-line-card[aria-current="page"],
.product-line-card.is-active {
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px rgba(47, 58, 86, 0.12);
}
.product-line-card__icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
}
.product-line-card--klima .product-line-card__icon {
  background: rgba(47, 58, 86, 0.10);
  color: var(--color-secondary);
}
.product-line-card--hoszivattyu .product-line-card__icon {
  background: rgba(225, 230, 234, 0.6);
  color: var(--color-secondary);
}
.product-line-card__title { margin: 0 0 var(--space-1); font-size: 1.25rem; }
.product-line-card__count {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin: 0 0 var(--space-4);
}
.product-line-card__cta {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-weight: 600;
  color: var(--color-primary);
}
.product-line-card__cta::after {
  content: "→";
  transition: transform var(--transition);
}
.product-line-card:hover .product-line-card__cta::after { transform: translateX(4px); }

/* =========================================================
   Segment-chip — termékkártya overlay és breadcrumb mellett
   ========================================================= */
.segment-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.segment-chip--klima {
  background: rgba(47, 58, 86, 0.10);
  color: var(--color-secondary);
}
.segment-chip--hoszivattyu {
  background: rgba(225, 230, 234, 0.7);
  color: var(--color-secondary);
}
.segment-chip__dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* =========================================================
   Termékkártya — overlay, qty-stepper, ár-doboz
   ========================================================= */
.product-card__media {
  position: relative; /* az overlay-knek kell */
}
.product-card__media-overlay {
  position: absolute;
  top: var(--space-3);
  z-index: 1;
}
.product-card__media-overlay--tl { left: var(--space-3); }
.product-card__media-overlay--tr {
  right: var(--space-3);
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 600;
  background: rgba(255, 255, 255, 0.95);
  color: var(--color-text-strong);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.qty-stepper {
  display: inline-flex; align-items: stretch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-bg);
}
.qty-stepper button {
  width: 32px;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-size: 1.1rem;
  color: var(--color-text-strong);
}
.qty-stepper button:hover { background: var(--color-surface); }
.qty-stepper input {
  width: 44px; text-align: center;
  border: 0;
  border-left: 1px solid var(--color-border);
  border-right: 1px solid var(--color-border);
  background: transparent;
  font-weight: 600;
}
.qty-stepper input:focus { outline: none; background: var(--color-surface); }

.product-card__action-row {
  display: flex; gap: var(--space-2);
  align-items: stretch;
  margin: 0;
}
.product-card__action-row .btn { flex: 1; }

/* =========================================================
   Termékoldal — spec-highlight + sticky aside + doc-card-grid
   ========================================================= */
.product-detail__breadcrumb {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin-bottom: var(--space-4);
}
.product-detail__breadcrumb a { color: var(--color-secondary); }
.product-detail__breadcrumb-sep { color: var(--color-muted); }

.product-detail__aside--sticky {
  position: sticky;
  top: calc(72px + var(--space-4));
  align-self: start;
}

.spec-highlight {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
  margin: var(--space-5) 0;
}
.spec-highlight__item {
  display: flex; flex-direction: column; gap: 4px;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}
.spec-highlight__label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-muted);
  font-weight: 600;
}
.spec-highlight__value {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.2;
}

.doc-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}
.doc-card {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text-strong);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.doc-card:hover {
  border-color: var(--color-secondary);
  box-shadow: var(--shadow-card);
  color: var(--color-text-strong);
}
.doc-card__icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(47, 58, 86, 0.10);
  color: var(--color-secondary);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.doc-card__label {
  font-size: var(--font-size-small);
  font-weight: 600;
  line-height: 1.3;
  flex: 1;
}
.doc-card__cta {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  white-space: nowrap;
}

/* =========================================================
   Header dropdown a Katalógus alatt
   ========================================================= */
.site-nav__item {
  position: relative;
}
.site-nav__item--has-dropdown > a::after {
  content: "▾";
  margin-left: 4px;
  font-size: 0.75em;
  opacity: 0.7;
}
.site-nav__dropdown {
  position: absolute;
  top: 100%; left: 0;
  min-width: 220px;
  display: none;
  flex-direction: column;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-elev);
  padding: var(--space-2);
  z-index: 20;
}
.site-nav__item:hover > .site-nav__dropdown,
.site-nav__item:focus-within > .site-nav__dropdown {
  display: flex;
}
.site-nav__dropdown a {
  display: block;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-weight: 500;
  white-space: nowrap;
  color: var(--color-text-strong);
}
.site-nav__dropdown a:hover {
  background: var(--color-surface);
  color: var(--color-secondary);
}

/* =========================================================
   Hero termékvonal-tile a homepage-en
   ========================================================= */
.hero__lines {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  width: 100%;
}
.hero__line-tile {
  display: flex; flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  background: rgba(255, 255, 255, 0.65);
  border-radius: var(--radius-md);
  text-align: left;
  color: var(--color-text-strong);
  transition: background var(--transition), transform var(--transition);
}
.hero__line-tile:hover {
  background: rgba(255, 255, 255, 0.9);
  transform: translateY(-2px);
  color: var(--color-text-strong);
}
.hero__line-tile__icon {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-sm);
  background: rgba(47, 58, 86, 0.10);
  color: var(--color-secondary);
}
.hero__line-tile__title { font-weight: 700; font-size: 1rem; }
.hero__line-tile__count { font-size: var(--font-size-xs); color: var(--color-muted); }

/* =========================================================
   Termékkártya ár-blokk — két szimmetrikus oszlop
   (viszonteladói + kiskereskedelmi, ugyanazzal a vizuális hierarchiával)
   ========================================================= */
.card-prices {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.card-price {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.card-price__label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-muted);
  font-weight: 600;
}
.card-price__value {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.1;
}
.card-price--retail .card-price__value {
  color: var(--color-secondary);
}
.card-price__margin {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  margin-top: 2px;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  background: var(--color-success-bg, rgba(46, 160, 67, 0.12));
  color: var(--color-success-text, #1a7f37);
  font-size: var(--font-size-xs);
  font-weight: 700;
}

/* =========================================================
   Brand-groups — kiemelt gyártók csoportonként szétválasztva
   ========================================================= */
.brand-groups {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
.brand-group__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.brand-group__title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-secondary);
  letter-spacing: -0.01em;
}

/* =========================================================
   USP-kártyák — bal-igazított content, modern kártyás
   ========================================================= */
.usp-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}
.usp-card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-elev);
  transform: translateY(-2px);
}
.usp-card__icon {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  background: rgba(5, 83, 164, 0.10);
  color: var(--color-primary);
}
.usp-card__title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--color-text-strong);
}
.usp-card__body {
  margin: 0;
  color: var(--color-text);
  font-size: var(--font-size-small);
  line-height: 1.55;
}

/* =========================================================
   Sidebar filter-card — szűrők kártyás formátumban
   ========================================================= */
.filter-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-4);
  transition: border-color var(--transition);
}
.filter-card:hover { border-color: var(--color-secondary-light); }
.filter-card__title {
  margin: 0 0 var(--space-3);
  font-size: var(--font-size-small);
  font-weight: 700;
  color: var(--color-text-strong);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.filter-card__count {
  color: var(--color-muted);
  font-weight: 500;
  font-size: var(--font-size-xs);
  margin-left: 4px;
}
.filter-card__hint {
  margin: var(--space-2) 0 0;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
}
.filter-card__pricerange {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.filter-card__pricerange .input {
  flex: 1;
  min-width: 0;
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-small);
}
.filter-card__pricerange-sep {
  color: var(--color-muted);
  font-weight: 600;
}
.catalog-sidebar__actions {
  position: sticky;
  bottom: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding: var(--space-3);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.04);
}

/* =========================================================
   Stock-badge — termékkártyán a body-ban, a price-block előtt
   ========================================================= */
.product-card__stock {
  display: flex;
  margin: 0;
}
.stock-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.stock-badge__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.stock-badge--in {
  background: var(--color-success-bg);
  color: var(--color-success-text);
}
.stock-badge--order {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
}

/* =========================================================
   Admin-nav badge (Kérelmek pending-számláló)
   ========================================================= */
.admin-nav__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  margin-left: 6px;
  border-radius: var(--radius-pill);
  background: var(--color-accent);
  color: #ffffff;
  font-size: var(--font-size-xs);
  font-weight: 700;
  line-height: 1;
}

/* =========================================================
   Definition list (admin részletes nézet kérelem-adatokhoz)
   ========================================================= */
.def-list {
  display: grid;
  grid-template-columns: minmax(140px, auto) 1fr;
  gap: var(--space-2) var(--space-4);
  margin: 0;
}
.def-list dt {
  color: var(--color-muted);
  font-size: var(--font-size-small);
  font-weight: 600;
  margin: 0;
}
.def-list dd {
  margin: 0;
  color: var(--color-text-strong);
  font-size: var(--font-size-small);
}

/* =========================================================
   Wide auth-card (regisztráció-igénylés form)
   ========================================================= */
.auth-card--wide {
  max-width: 520px;
}

/* =========================================================
   Btn — accent variáns (piros, accent szerepben)
   ========================================================= */
.btn--accent {
  background: var(--color-accent);
  color: #ffffff;
  border-color: var(--color-accent);
}
.btn--accent:hover {
  background: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
  color: #ffffff;
}

/* =========================================================
   Hero — partneri jelentkezés CTA (anonim user-eknek)
   "Anchored persuasion card": bal kék szalag + ikon + 3-soros copy
   + jobb-oldali CTA-gomb + alá meta-pillula a turn-around-time-ról.
   ========================================================= */
.hero__signup-card {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  margin-top: var(--space-5);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 1px 2px rgba(31, 39, 56, 0.04);
  overflow: hidden;
}
.hero__signup-card::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  background: var(--color-primary);
}

.hero__signup-card__icon {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(5, 83, 164, 0.10);
  color: var(--color-primary);
}

.hero__signup-card__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.hero__signup-card__eyebrow {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.hero__signup-card__title {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.25;
}
.hero__signup-card__lead {
  margin: 0;
  font-size: var(--font-size-small);
  line-height: 1.5;
  color: var(--color-text);
}

.hero__signup-card__action {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.hero__signup-card__action .btn {
  white-space: nowrap;
}
.hero__signup-card__meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  font-weight: 500;
}
.hero__signup-card__meta__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-success-text, #2F6B45);
  box-shadow: 0 0 0 3px rgba(47, 107, 69, 0.18);
}

@media (max-width: 720px) {
  .hero__signup-card {
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "icon body"
      "action action";
    align-items: start;
  }
  .hero__signup-card__icon  { grid-area: icon; }
  .hero__signup-card__body  { grid-area: body; }
  .hero__signup-card__action {
    grid-area: action;
    align-items: stretch;
    margin-top: var(--space-2);
  }
  .hero__signup-card__action .btn { width: 100%; text-align: center; }
  .hero__signup-card__meta { justify-content: center; }
}

/* =========================================================
   HERO REDESIGN (2026-05-12) — sötét navy gradient + split layout
   ========================================================= */
.hero--dark {
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 60%, #182037 100%);
  color: #fff;
  padding: var(--space-10) 0 var(--space-12);
  position: relative;
  overflow: hidden;
}
.hero--dark .hero__bg {
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 18%, rgba(5, 83, 164, 0.32), transparent 45%),
    radial-gradient(circle at 88% 90%, rgba(237, 28, 36, 0.10), transparent 50%);
}
.hero--dark .container { position: relative; z-index: 1; }

.hero__card--split {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: var(--space-9);
  align-items: stretch;
}

.hero__col--side {
  display: flex;
  align-items: stretch;
}

/* Eyebrow — sötét háttérre */
.hero__eyebrow--ondark {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.16);
  backdrop-filter: blur(4px);
}
.hero__eyebrow--ondark .hero__eyebrow__dot {
  background: var(--color-accent);
  box-shadow: 0 0 0 4px rgba(237, 28, 36, 0.25);
}
.hero__sub-eyebrow {
  align-self: flex-start;
  display: inline-block;
  margin-top: -2px;
  padding: 4px 10px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.62);
  background: rgba(255, 255, 255, 0.04);
  border-left: 2px solid rgba(255, 255, 255, 0.18);
}

.hero__title--ondark {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.02em;
  font-weight: 700;
}
.hero__title__accent {
  position: relative;
  display: inline-block;
  white-space: nowrap;
}
.hero__title__accent::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 4px;
  background: var(--color-accent);
  border-radius: 2px;
}

.hero__subtitle--ondark {
  color: rgba(255, 255, 255, 0.78);
  font-size: 1.0625rem;
  line-height: 1.6;
  max-width: 56ch;
}
.hero__subtitle--ondark strong {
  color: #fff;
  font-weight: 700;
}

/* Ghost CTA világos szövegen */
.btn--ghost-light {
  background: transparent;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.28);
  font-weight: 600;
}
.btn--ghost-light:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.55);
  color: #fff;
}

/* =========================================================
   SIGNUP-CARD V2 — kiemelt jelentkezési kártya a hero jobb oszlopában
   ========================================================= */
.signup-card-v2 {
  width: 100%;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  box-shadow:
    0 24px 48px -16px rgba(15, 23, 42, 0.45),
    0 8px 16px -4px rgba(15, 23, 42, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.10);
  position: relative;
  overflow: hidden;
}
.signup-card-v2::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.signup-card-v2__head {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.signup-card-v2__eyebrow {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.signup-card-v2__title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.2;
}
.signup-card-v2__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.signup-card-v2__bullets li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.9375rem;
  color: var(--color-text-strong);
  line-height: 1.45;
}
.signup-card-v2__check {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-primary);
}
.signup-card-v2__profile {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
}
.signup-card-v2__profile__label {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.signup-card-v2__profile__chips {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
}
/* a fő .profile-chip-stílus (form is használja) lent jön — az anchor variáns: */
.signup-card-v2__profile__chips .profile-chip {
  text-align: center;
  font-size: var(--font-size-xs);
  padding: 8px 6px;
  cursor: pointer;
  text-decoration: none;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-strong);
  font-weight: 600;
  transition: border-color var(--transition), background var(--transition), color var(--transition);
}
.signup-card-v2__profile__chips .profile-chip:hover {
  border-color: var(--color-primary);
  background: rgba(5, 83, 164, 0.05);
  color: var(--color-primary);
}
.signup-card-v2__meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  font-weight: 500;
  align-self: center;
}
.signup-card-v2__meta__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--color-success-text);
  box-shadow: 0 0 0 3px rgba(47, 107, 69, 0.18);
}

/* =========================================================
   HERO SEARCH STRIP — anonim user-nek a hero alatt önálló soron
   ========================================================= */
.hero-search-strip {
  background: #fff;
  padding: var(--space-5) 0 0;
  position: relative;
  z-index: 2;
  margin-top: calc(-1 * var(--space-8));
}
.hero-search-strip .hero__search {
  max-width: 720px;
  margin: 0 auto;
  box-shadow: 0 8px 24px -4px rgba(15, 23, 42, 0.16);
  border: 1px solid var(--color-border);
}

/* =========================================================
   PROOF-STRIP V2 — fehér kártya, ami "beleharap" a hero-ba
   ========================================================= */
.proof-strip {
  background: transparent;
  border: 0;
  padding: 0;
  position: relative;
  z-index: 2;
}
.proof-strip .container { padding-top: 0; padding-bottom: var(--space-8); }
.proof-strip__grid {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow:
    0 18px 32px -16px rgba(15, 23, 42, 0.20),
    0 4px 8px -2px rgba(15, 23, 42, 0.06);
  border: 1px solid var(--color-border);
  margin-top: var(--space-5);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.proof-strip__cell {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  border-left: 1px solid var(--color-border);
}
.proof-strip__cell:first-child { border-left: 0; padding-left: var(--space-2); }
.proof-strip__icon {
  width: 40px; height: 40px;
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.proof-strip__value {
  font-size: 1.375rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--color-text-strong);
  line-height: 1.1;
}
.proof-strip__label {
  font-size: 0.7rem;
  margin-top: 2px;
}

/* anonim user-nél a search-strip miatt a proof-stripet kicsit lejjebb húzzuk */
.hero-search-strip + .proof-strip .container { padding-top: var(--space-5); }

@media (max-width: 880px) {
  .proof-strip__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-3);
  }
  .proof-strip__cell:nth-child(odd) { border-left: 0; padding-left: var(--space-2); }
  .proof-strip__cell:nth-child(even) { border-left: 1px solid var(--color-border); }
}
@media (max-width: 540px) {
  .proof-strip__grid { grid-template-columns: 1fr; }
  .proof-strip__cell { border-left: 0 !important; padding: var(--space-2); }
  .proof-strip__cell + .proof-strip__cell { border-top: 1px solid var(--color-border); padding-top: var(--space-3); }
}

/* =========================================================
   MANUFACTURER-CARD V2 — monogram + modell-arány bar
   ========================================================= */
.manufacturer-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4);
  text-align: left;
  border: 1px solid var(--color-border);
  background: #fff;
}
.manufacturer-card__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.manufacturer-card__monogram {
  width: 38px; height: 38px;
  flex-shrink: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-secondary);
  color: #fff;
  font-weight: 700;
  font-size: 1.0625rem;
  line-height: 1;
  letter-spacing: -0.01em;
}
.manufacturer-card:hover .manufacturer-card__monogram {
  background: var(--color-primary);
}
.manufacturer-card__meta {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.manufacturer-card__name {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.2;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
.manufacturer-card__count {
  font-size: var(--font-size-xs);
  color: var(--color-muted);
  margin-top: 0;
  opacity: 1;
  font-weight: 500;
}
.manufacturer-card__bar {
  width: 100%;
  height: 4px;
  border-radius: 2px;
  background: var(--color-surface);
  overflow: hidden;
}
.manufacturer-card__bar__fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-secondary-light) 100%);
  border-radius: 2px;
  transition: width var(--transition);
}

/* =========================================================
   REG-FORM V2 — 2 oszlopos investment layout, navy aside
   ========================================================= */
.auth-shell--wide {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-8) var(--container-padding);
  width: 100%;
  display: block;
  background: var(--color-bg-soft);
}
.auth-shell--wide { background: transparent; }

main.auth-shell--wide {
  background: var(--color-bg-soft);
  display: block;
  align-items: stretch;
  justify-content: stretch;
}

.auth-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 0;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border);
  margin: 0 auto;
  max-width: 1040px;
}

.auth-grid__form {
  padding: var(--space-8) clamp(var(--space-5), 4vw, var(--space-8));
  background: #fff;
}
.auth-grid__form__head { margin-bottom: var(--space-6); }
.auth-grid__form__head h1 {
  margin: 0 0 var(--space-2);
  font-size: 1.75rem;
}

.field-group {
  border: 0;
  padding: 0;
  margin: 0;
}
.field-group + .field-group { margin-top: var(--space-7); }
.field-group__legend {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--color-primary);
  font-weight: 700;
  margin-bottom: var(--space-4);
  padding: 0;
}
.field-group__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--color-primary-light);
  color: var(--color-primary);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}
.field-group .field + .field { margin-top: var(--space-4); }
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.field-row .field { margin-top: 0 !important; }

.field__label__opt {
  color: var(--color-muted);
  font-weight: 500;
  font-size: 0.85em;
}

/* Profile-chips — radio-button forma */
.profile-chip-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.profile-chip {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text-strong);
  background: #fff;
  transition: border-color var(--transition), background var(--transition), color var(--transition), box-shadow var(--transition);
  user-select: none;
}
.profile-chip:hover {
  border-color: var(--color-secondary-light);
}
.profile-chip input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.profile-chip:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.10);
}
.profile-chip:focus-within {
  border-color: var(--color-primary);
}

/* Submit gomb — emelt méret */
.btn--lg {
  padding: 14px 24px;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

/* JOBB: navy aside */
.auth-aside {
  background: linear-gradient(160deg, #2F3A56 0%, #1F2840 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.auth-aside::before {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.30), transparent 65%);
  pointer-events: none;
}
.auth-aside__inner {
  padding: var(--space-8) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  position: sticky;
  top: var(--space-5);
}
.auth-aside__block {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.auth-aside__eyebrow {
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.auth-aside__divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.10);
  margin: 0;
}

/* Timeline */
.auth-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.auth-timeline__step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: flex-start;
  position: relative;
}
.auth-timeline__step + .auth-timeline__step::before {
  content: "";
  position: absolute;
  top: -14px;
  left: 13px;
  width: 2px;
  height: 14px;
  background: rgba(255, 255, 255, 0.16);
}
.auth-timeline__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
  font-weight: 700;
  font-size: 0.8125rem;
  border: 1.5px solid rgba(255, 255, 255, 0.22);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.auth-timeline__step strong {
  display: block;
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  margin-bottom: 2px;
}
.auth-timeline__step p {
  margin: 0;
  font-size: var(--font-size-small);
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.5;
}

/* Aside bullets */
.auth-aside__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.auth-aside__bullets li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.4;
}
.auth-aside__check {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-secondary-light);
}

/* Aside contact */
.auth-aside__contact {
  margin: 0;
  font-size: var(--font-size-small);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.7;
}
.auth-aside__contact a {
  color: #fff;
  text-decoration: none;
  border-bottom: 1px dotted rgba(255, 255, 255, 0.30);
  transition: border-color var(--transition);
}
.auth-aside__contact a:hover {
  border-color: #fff;
  color: #fff;
}

/* Mobil-stack: aside a form fölé csúszik, sticky kikapcsolva */
@media (max-width: 880px) {
  .auth-grid {
    grid-template-columns: 1fr;
  }
  .auth-aside { order: -1; }
  .auth-aside__inner { position: static; padding: var(--space-6); }
  .auth-grid__form { padding: var(--space-6) var(--space-5); }
}

@media (max-width: 540px) {
  .field-row { grid-template-columns: 1fr; gap: var(--space-4); }
  .profile-chip-group { grid-template-columns: 1fr; }
  .signup-card-v2__profile__chips { grid-template-columns: 1fr; }
}

/* =========================================================
   HERO SPLIT — mobil breakpoint felülírás
   ========================================================= */
@media (max-width: 880px) {
  .hero__card--split {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
  .hero__col--side { align-items: stretch; }
  .signup-card-v2 { padding: var(--space-5); }
  .hero__title--ondark { font-size: 1.75rem; }
}

/* =========================================================
   PREMIUM PASS — CATALOG + PRODUCT (2026-05-12)
   A hero/footer/signup-card vizuális nyelvét kiterjeszti a katalógusra
   és a termékoldalra. Felülírja a fent definiált szabályokat.
   ========================================================= */

/* ─── #2 ÁR-PÁR HIERARCHIA ─────────────────────────────── */

.price-pair {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: var(--space-3);
  margin: var(--space-5) 0 var(--space-4);
}

.price-card {
  position: relative;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow: hidden;
  transition: box-shadow var(--transition);
}

/* Viszonteladói = hero (navy gradient + radial-glow + kék-piros szalag) */
.price-card--reseller {
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
  color: #fff;
  border: 0;
  box-shadow: 0 12px 28px -12px rgba(15, 23, 42, 0.40);
}
.price-card--reseller::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.price-card--reseller::after {
  content: "";
  position: absolute;
  top: -40px; right: -40px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.30), transparent 65%);
  pointer-events: none;
}
.price-card--reseller .price-card__label {
  color: rgba(255, 255, 255, 0.55);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.price-card--reseller .price-card__sublabel {
  color: rgba(255, 255, 255, 0.40);
  font-size: var(--font-size-xs);
  font-weight: 500;
}
.price-card--reseller .price-card__value {
  color: #fff;
  font-size: 1.875rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin-top: 2px;
}
.price-card--reseller .price-card__detail {
  color: rgba(255, 255, 255, 0.65);
  font-size: var(--font-size-small);
  margin-top: 4px;
}

/* Retail = ghost (transparent + thin border) */
.price-card--retail {
  background: transparent;
  border: 1px solid var(--color-border);
}
.price-card--retail .price-card__label {
  color: var(--color-muted);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}
.price-card--retail .price-card__sublabel {
  color: var(--color-muted);
  font-size: var(--font-size-xs);
}
.price-card--retail .price-card__value {
  color: var(--color-text-strong);
  font-size: 1.375rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  margin-top: 2px;
}
.price-card--retail .price-card__detail {
  font-size: var(--font-size-small);
  color: var(--color-text);
  margin-top: 4px;
}
.price-card--retail .price-card__detail--margin {
  display: inline-block;
  background: var(--color-success-bg);
  color: var(--color-success-text);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: var(--font-size-xs);
  font-weight: 700;
  align-self: flex-start;
}

@media (max-width: 720px) {
  .price-pair { grid-template-columns: 1fr; }
}

/* ─── #1 TERMÉKKÁRTYA: 2-rétegű árnyék + accent-piros aláhúzás ─── */

.product-card {
  background: var(--color-bg);
  border: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 0 0 1px rgba(31, 39, 56, 0.06);
  transition: box-shadow var(--transition), transform var(--transition);
}
.product-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 12px 28px -8px rgba(15, 23, 42, 0.12),
    0 0 0 1px rgba(5, 83, 164, 0.25);
}
.product-card__media {
  background: #F5F6FA;
  border-bottom: 1px solid rgba(31, 39, 56, 0.06);
}
.product-card__title {
  font-weight: 700;
  letter-spacing: -0.005em;
}

/* Accent-piros aláhúzás a viszonteladói nettó szám alatt (kártyán) */
.card-price__value {
  position: relative;
  display: inline-block;
  padding-bottom: 6px;
  font-variant-numeric: tabular-nums;
}
.card-price:not(.card-price--retail) .card-price__value::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 24px;
  height: 2px;
  background: var(--color-accent);
  border-radius: 1px;
}
.card-price__label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  font-weight: 700;
  color: var(--color-muted);
}
.card-price--retail .card-price__label {
  color: var(--color-muted);
}
.card-price__margin {
  display: inline-block;
  margin-top: 2px;
  background: var(--color-success-bg);
  color: var(--color-success-text);
  padding: 3px 8px;
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  font-weight: 700;
  align-self: flex-start;
}

/* ─── #4 TERMÉKVONAL-HUB: navy-gradient + active piros ring ─── */

.product-line-card {
  position: relative;
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
  border: 0;
  color: #fff;
  overflow: hidden;
  box-shadow: 0 12px 28px -16px rgba(15, 23, 42, 0.40);
  transition: transform var(--transition), box-shadow var(--transition);
}
.product-line-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
  z-index: 1;
}
.product-line-card::after {
  content: "";
  position: absolute;
  top: -60px; right: -60px;
  width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.30), transparent 65%);
  pointer-events: none;
}
.product-line-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 36px -16px rgba(15, 23, 42, 0.50);
  color: #fff;
}
.product-line-card__icon {
  background: rgba(255, 255, 255, 0.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.12);
  position: relative;
  z-index: 1;
}
.product-line-card__title {
  color: #fff;
  position: relative;
  z-index: 1;
}
.product-line-card__count {
  color: rgba(255, 255, 255, 0.65);
  position: relative;
  z-index: 1;
}
.product-line-card__cta {
  color: var(--color-secondary-light);
  font-weight: 700;
  position: relative;
  z-index: 1;
}
.product-line-card[aria-current="page"],
.product-line-card.is-active {
  box-shadow:
    0 0 0 2px var(--color-accent),
    0 12px 28px -12px rgba(15, 23, 42, 0.40);
}
.product-line-card[aria-current="page"]:hover,
.product-line-card.is-active:hover {
  box-shadow:
    0 0 0 2px var(--color-accent),
    0 18px 36px -16px rgba(15, 23, 42, 0.50);
}

/* ─── #3 SIDEBAR FILTER-CARD: border-less + custom checkboxok ─── */

.filter-card {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0 0 var(--space-5);
  margin: 0 0 var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.filter-card:hover { border-color: var(--color-border); }
.filter-card:last-of-type {
  border-bottom: 0;
  margin-bottom: var(--space-3);
}
.filter-card__title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--color-muted);
  margin-bottom: var(--space-3);
}
.filter-card__count {
  color: var(--color-muted);
  font-weight: 500;
}

/* Custom-checkbox: 18px square, navy-fill ha checked, ✓ SVG bg */
.catalog-filter-checkboxes {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.catalog-filter-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--font-size-small);
  color: var(--color-text);
  cursor: pointer;
  padding: 4px 0;
  transition: color var(--transition);
}
.catalog-filter-item:hover {
  color: var(--color-text-strong);
}
.catalog-filter-item input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-border);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: border-color var(--transition), background var(--transition);
}
.catalog-filter-item input[type="checkbox"]:hover {
  border-color: var(--color-secondary-light);
}
.catalog-filter-item input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: 12px 12px;
  background-position: center;
  background-repeat: no-repeat;
}
.catalog-filter-item input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.catalog-filter-item:has(input:checked) {
  color: var(--color-text-strong);
  font-weight: 600;
}

/* Sticky-sidebar action-bar: kék-piros gradient szegély (két-réteg trükk) */
.catalog-sidebar__actions {
  position: sticky;
  bottom: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding: var(--space-3);
  background: #fff;
  background-image:
    linear-gradient(#fff, #fff),
    linear-gradient(90deg, var(--color-primary), var(--color-accent));
  background-origin: border-box;
  background-clip: padding-box, border-box;
  border: 2px solid transparent;
  border-radius: var(--radius-md);
  box-shadow: 0 12px 24px -8px rgba(15, 23, 42, 0.12);
}

/* Filter-card pricerange refinement */
.filter-card__pricerange .input {
  background: #fff;
  border-color: var(--color-border);
}
.filter-card__pricerange .input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.10);
}

/* ─── #5 TERMÉKOLDAL HERO: stúdió-fehér frame + eyebrow-breadcrumb ─── */

.product-detail__breadcrumb {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--color-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.product-detail__breadcrumb a {
  color: var(--color-muted);
  transition: color var(--transition);
}
.product-detail__breadcrumb a:hover {
  color: var(--color-primary);
}
.product-detail__breadcrumb-sep {
  color: rgba(31, 39, 56, 0.20);
}

.product-detail__image,
.product-detail__image-placeholder {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow:
    inset 0 0 0 1px rgba(5, 83, 164, 0.04),
    0 1px 2px rgba(31, 39, 56, 0.04);
}

.product-detail__manufacturer {
  display: inline-block;
  padding: 4px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-bg-soft);
  color: var(--color-text-strong);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2);
}

.product-detail__title {
  font-size: clamp(1.5rem, 3vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--color-text-strong);
  line-height: 1.2;
  margin: 0 0 var(--space-3);
}

.product-detail__sku {
  font-size: var(--font-size-small);
  color: var(--color-muted);
  margin-bottom: var(--space-3);
}
.product-detail__sku code {
  background: var(--color-bg-soft);
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid var(--color-border);
  font-family: var(--font-family-mono, monospace);
  font-size: 0.85em;
  color: var(--color-text-strong);
}

/* ─── #6 SPEC-HIGHLIGHT: navy top-border + eyebrow ─── */

.spec-highlight {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
  margin: var(--space-5) 0 0;
  padding: 0;
  list-style: none;
}
.spec-highlight__item {
  background: #fff;
  border: 1px solid var(--color-border);
  border-top: 2px solid var(--color-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: border-top-color var(--transition);
}
.spec-highlight__item:hover {
  border-top-color: var(--color-primary);
}
.spec-highlight__label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--color-muted);
}
.spec-highlight__value {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-strong);
  line-height: 1.25;
}

/* ─── #7 TECH-PARAMS TÁBLÁZAT + DOC-CARD: brand-szín ─── */

.tech-params-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.tech-params-table tr {
  border-bottom: 1px solid var(--color-border);
}
.tech-params-table tr:last-child { border-bottom: 0; }
.tech-params-table tr:nth-child(even) {
  background: rgba(5, 83, 164, 0.03);
}
.tech-params-table tr:hover {
  background: rgba(5, 83, 164, 0.07);
}
.tech-params-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-weight: 600;
  color: var(--color-text-strong);
  width: 50%;
  border-left: 2px solid transparent;
  transition: border-left-color var(--transition);
}
.tech-params-table tr:hover th {
  border-left-color: var(--color-primary);
}
.tech-params-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
}

.tech-params-group {
  margin: var(--space-5) 0 var(--space-2);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--color-muted);
}

/* Doc-card: kék-soft ikon */
.doc-card__icon {
  background: rgba(5, 83, 164, 0.10);
  color: var(--color-primary);
}
.doc-card:hover {
  border-color: var(--color-primary);
}
.doc-card:hover .doc-card__icon {
  background: var(--color-primary);
  color: #fff;
}

/* =========================================================
   PREMIUM PASS — HEADER (2026-05-12)
   Sűrűbb, definiált, user-pill avatarral, dropdown-os menüvel
   ========================================================= */

:root {
  --header-height: 64px;
}

.site-header {
  height: var(--header-height);
  background: #fff;
  border-bottom: 1px solid rgba(31, 39, 56, 0.06);
  box-shadow: 0 1px 0 rgba(31, 39, 56, 0.04);
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: saturate(180%);
}

.site-header__inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

/* Logó kompaktabb */
.site-header__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}
.site-header__logo__mark {
  flex-shrink: 0;
}
.site-header__logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
}
.site-header__logo-text strong {
  color: var(--color-primary);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
}
.site-header__logo-text span {
  color: var(--color-muted);
  font-weight: 600;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 1px;
}

/* Nav-linkek finomítva */
.site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-left: var(--space-3);
}
.site-nav a {
  position: relative;
  color: var(--color-text);
  font-weight: 600;
  font-size: 0.875rem;
  padding: var(--space-2) 0;
  border-bottom: 0;
  transition: color var(--transition);
}
.site-nav a::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -2px;
  height: 2px;
  background: var(--color-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition);
}
.site-nav a:hover {
  color: var(--color-text-strong);
}
.site-nav a:hover::after,
.site-nav a.is-active::after {
  transform: scaleX(1);
}
.site-nav a.is-active {
  color: var(--color-text-strong);
}

/* Admin-link finom piros pajzs-ikon-pillel */
.site-nav__admin-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-accent) !important;
}
.site-nav__admin-link::after {
  background: var(--color-accent) !important;
}
.site-nav__admin-link svg {
  flex-shrink: 0;
}

/* Search-doboz tisztább */
.site-header__search {
  position: relative;
  flex: 0 1 280px;
}
.site-header__search input {
  width: 100%;
  height: 38px;
  padding: 0 var(--space-4) 0 36px;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  background: var(--color-bg-soft);
  font-family: inherit;
  font-size: var(--font-size-small);
  color: var(--color-text-strong);
  transition: background var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.site-header__search input::placeholder {
  color: var(--color-muted);
}
.site-header__search input:focus {
  outline: none;
  border-color: var(--color-primary);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.10);
}
.site-header__search svg {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-muted);
}

.site-header__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

/* Kerek ikon-button (kosár) */
.site-header__icon-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--color-bg-soft);
  color: var(--color-text-strong);
  transition: background var(--transition), color var(--transition);
}
.site-header__icon-btn:hover {
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.site-header__icon-btn__badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: var(--color-accent);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #fff;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* User-pill: avatar + name + chevron + dropdown menü */
.site-header__user {
  position: relative;
}
.site-header__user[open] .site-header__user__chevron {
  transform: rotate(180deg);
}
.site-header__user__trigger {
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 4px 10px 4px 4px;
  background: var(--color-bg-soft);
  border-radius: var(--radius-pill);
  cursor: pointer;
  user-select: none;
  transition: background var(--transition);
  border: 1px solid transparent;
}
.site-header__user__trigger::-webkit-details-marker {
  display: none;
}
.site-header__user__trigger:hover {
  background: var(--color-surface);
}
.site-header__user[open] .site-header__user__trigger {
  background: #fff;
  border-color: var(--color-border);
  box-shadow: 0 4px 12px -4px rgba(31, 39, 56, 0.12);
}
.site-header__user__avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  color: #fff;
  font-weight: 700;
  font-size: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -0.01em;
}
.site-header__user__name {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
  max-width: 180px;
}
.site-header__user__role {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.site-header__user__name strong {
  color: var(--color-text-strong);
  font-weight: 700;
  font-size: 0.825rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
}
.site-header__user__chevron {
  color: var(--color-muted);
  flex-shrink: 0;
  transition: transform var(--transition);
}

/* Dropdown menü */
.site-header__user__menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow:
    0 12px 32px -8px rgba(31, 39, 56, 0.18),
    0 4px 12px -4px rgba(31, 39, 56, 0.08);
  padding: 6px;
  display: flex;
  flex-direction: column;
  z-index: 60;
  overflow: hidden;
}
.site-header__user__menu::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.site-header__user__menu a,
.site-header__user__menu button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 6px;
  font-size: var(--font-size-small);
  font-weight: 500;
  color: var(--color-text-strong);
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
  width: 100%;
  font-family: inherit;
  transition: background var(--transition), color var(--transition);
}
.site-header__user__menu a:hover,
.site-header__user__menu button:hover {
  background: var(--color-bg-soft);
  color: var(--color-primary);
}
.site-header__user__menu svg {
  flex-shrink: 0;
  color: var(--color-muted);
  transition: color var(--transition);
}
.site-header__user__menu a:hover svg,
.site-header__user__menu button:hover svg {
  color: var(--color-primary);
}
.site-header__user__menu__count {
  margin-left: auto;
  color: var(--color-muted);
  font-size: var(--font-size-xs);
  font-weight: 700;
}
.site-header__user__menu__divider {
  height: 1px;
  background: var(--color-border);
  margin: 4px 6px;
}
.site-header__user__menu__form {
  display: flex;
  margin: 0;
}

/* Mobil — search elrejtjük, user-name csak avatár */
@media (max-width: 880px) {
  .site-header__search { display: none; }
  .site-header__user__name { display: none; }
  .site-header__user__trigger { padding: 4px; }
  .site-nav { gap: var(--space-3); }
  .site-header__logo-text { display: none; }
}
@media (max-width: 540px) {
  .site-nav { display: none; }
}

/* =========================================================
   PREMIUM PASS — CART (2026-05-13)
   ========================================================= */

/* ─── #1 Page-header ─────────────────────────────────────── */
.cart-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
}
.cart-header__main {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cart-header__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.cart-header__title {
  margin: 0;
  font-size: clamp(1.625rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text-strong);
  line-height: 1.1;
}
.cart-header__title__accent {
  position: relative;
  display: inline-block;
}
.cart-header__title__accent::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -4px;
  height: 4px;
  background: var(--color-accent);
  border-radius: 2px;
}
.cart-header__pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  font-size: 0.85rem;
  color: var(--color-text-strong);
  font-weight: 500;
}
.cart-header__pill svg {
  color: var(--color-primary);
}
.cart-header__pill strong {
  color: var(--color-text-strong);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.cart-gradient-divider {
  height: 3px;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
  margin: 0 0 var(--space-6);
  opacity: 0.55;
}

/* ─── Grid ─────────────────────────────────────────────── */
.cart-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: var(--space-6);
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .cart-grid { grid-template-columns: 1fr; }
}

/* ─── #2 Tételsorok kártyásan ─────────────────────────── */
.cart-items-wrap {
  /* Üres wrapper, hogy a table--cart-os shadow-elemek ne essenek le. */
}

.table--cart {
  border-collapse: separate;
  border-spacing: 0 var(--space-3);
  margin-top: calc(-1 * var(--space-3));
  width: 100%;
}

/* Header-row finomítva — az új layout-ban kicsi info-sor */
.table--cart thead tr { background: transparent; }
.table--cart .cart-th {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  padding: 0 var(--space-3) var(--space-1);
  background: transparent;
  border-bottom: 0;
  text-align: left;
}
.table--cart .cart-th--num { text-align: right; }
.table--cart .cart-th--action { width: 48px; }
.table--cart .cart-th--product { padding-left: var(--space-4); }

/* Tételsorok — kártyaszerűek */
.table--cart tbody tr {
  background: #fff;
  border: 0;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 0 0 1px rgba(31, 39, 56, 0.06);
  transition: box-shadow var(--transition);
}
.table--cart tbody tr:hover {
  box-shadow:
    0 4px 12px -4px rgba(31, 39, 56, 0.10),
    0 0 0 1px rgba(5, 83, 164, 0.20);
}
.table--cart tbody tr:nth-child(even) { background: #fff; }

.table--cart .cart-cell {
  padding: var(--space-4);
  vertical-align: middle;
  border-top: 0;
  border-bottom: 0;
}
.table--cart .cart-cell--product {
  border-radius: var(--radius-md) 0 0 var(--radius-md);
  padding-right: var(--space-3);
}
.table--cart .cart-cell--num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.table--cart .cart-cell--qty { width: 130px; }
.table--cart .cart-cell--action {
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  text-align: right;
  width: 56px;
  padding-left: var(--space-2);
}

/* Termék-cella belseje */
.cart-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.cart-item__thumb {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-sm);
  background: #F5F6FA;
  border: 1px solid rgba(31, 39, 56, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-decoration: none;
}
.cart-item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.cart-item__thumb--missing {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
}
.cart-item__info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.cart-item__name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text-strong);
  text-decoration: none;
  line-height: 1.3;
  letter-spacing: -0.005em;
  transition: color var(--transition);
}
.cart-item__name:hover { color: var(--color-primary); }
.cart-item__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.cart-item__sku-pill {
  display: inline-block;
  padding: 2px 8px;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  font-size: 0.72rem;
}
.cart-item__sku-pill code {
  font-family: var(--font-family-mono, ui-monospace, monospace);
  color: var(--color-muted);
  background: transparent;
  border: 0;
  padding: 0;
  font-size: inherit;
}
.cart-item__sku {
  font-size: 0.78rem;
  color: var(--color-muted);
}
.cart-item__sku code {
  background: transparent;
  border: 0;
  padding: 0;
}

/* ─── #3 Ár-cellák tipográfia ────────────────────────── */
.cart-price {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  line-height: 1.2;
}
.cart-price__net {
  font-weight: 600;
  color: var(--color-text-strong);
  font-size: 0.95rem;
}
.cart-price__gross {
  font-size: 0.72rem;
  color: var(--color-muted);
  letter-spacing: 0.01em;
}
.cart-price--total .cart-price__net {
  font-weight: 800;
  font-size: 1.0625rem;
  color: var(--color-secondary);
  position: relative;
  padding-bottom: 4px;
}
.cart-price--total .cart-price__net::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 24px;
  height: 2px;
  background: var(--color-accent);
  border-radius: 1px;
}
.cart-price--total .cart-price__gross {
  margin-top: 4px;
}

/* ─── #4 Mennyiség stepper ────────────────────────────── */
.cart-qty {
  display: inline-flex;
  align-items: stretch;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: #fff;
  margin: 0;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.cart-qty:focus-within {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.12);
}
.cart-qty__input {
  width: 56px;
  height: 36px;
  border: 0;
  background: transparent;
  text-align: center;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-text-strong);
  font-variant-numeric: tabular-nums;
  outline: none;
  -moz-appearance: textfield;
  appearance: textfield;
}
.cart-qty__input::-webkit-outer-spin-button,
.cart-qty__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.cart-qty__save {
  background: var(--color-bg-soft);
  border: 0;
  border-left: 1px solid var(--color-border);
  color: var(--color-primary);
  cursor: pointer;
  padding: 0 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition), color var(--transition);
}
.cart-qty__save:hover {
  background: var(--color-primary);
  color: #fff;
}

/* Eltávolítás-ikon (kis kuka, hover-on piros) */
.cart-remove {
  background: transparent;
  border: 0;
  color: var(--color-muted);
  cursor: pointer;
  padding: 8px;
  border-radius: var(--radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition), color var(--transition);
}
.cart-remove:hover {
  background: rgba(237, 28, 36, 0.08);
  color: var(--color-accent);
}

/* ─── #5 Invalid-sor erősítve ────────────────────────── */
.cart-row--invalid {
  background: #FFF5F5 !important;
  box-shadow:
    inset 3px 0 0 var(--color-accent),
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 0 0 1px rgba(237, 28, 36, 0.20) !important;
}
.cart-row--invalid:hover {
  box-shadow:
    inset 3px 0 0 var(--color-accent),
    0 4px 12px -4px rgba(237, 28, 36, 0.16),
    0 0 0 1px rgba(237, 28, 36, 0.30) !important;
}
.cart-warning-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--color-accent);
  color: #fff;
  border-radius: var(--radius-pill);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.cart-warning-pill--inline {
  font-size: 0.68rem;
  padding: 2px 8px;
}

/* Cart-actions-row alul */
.cart-actions-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-4);
  flex-wrap: wrap;
  gap: var(--space-2);
}
.cart-actions-row__clear {
  color: var(--color-muted);
}
.cart-actions-row__clear:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
}

/* Általános ghost-line button (használjuk a katalógusra-vissza link-et is) */
.btn--ghost-line {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text-strong);
  font-weight: 600;
}
.btn--ghost-line:hover {
  background: var(--color-bg-soft);
  border-color: var(--color-secondary-light);
  color: var(--color-secondary);
}

/* ─── #6 Sticky aside premium ────────────────────────── */
.cart-summary-wrap {
  position: sticky;
  top: calc(var(--header-height) + var(--space-4));
}
.cart-summary {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 12px 32px -16px rgba(31, 39, 56, 0.20);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.cart-summary__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
  display: block;
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}

.cart-summary__warning {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: #FFF5F5;
  border: 1px solid rgba(237, 28, 36, 0.20);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-sm);
  font-size: 0.82rem;
  color: var(--color-text-strong);
  line-height: 1.45;
}
.cart-summary__warning svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-accent);
}

.cart-summary__list {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.cart-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(47, 58, 86, 0.12);
}
.cart-summary__row:last-child { border-bottom: 0; }
.cart-summary__row dt {
  font-size: var(--font-size-small);
  color: var(--color-text);
  font-weight: 500;
  margin: 0;
}
.cart-summary__row dd {
  font-size: var(--font-size-small);
  color: var(--color-text-strong);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  margin: 0;
}

/* Bruttó végösszeg — navy gradient blokk */
.cart-summary__total {
  position: relative;
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
  color: #fff;
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin-top: var(--space-2);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  overflow: hidden;
  box-shadow: 0 12px 24px -12px rgba(31, 39, 56, 0.45);
}
.cart-summary__total::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.cart-summary__total::after {
  content: "";
  position: absolute;
  top: -40px; right: -40px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.30), transparent 65%);
  pointer-events: none;
}
.cart-summary__total__label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.65);
  position: relative;
  z-index: 1;
}
.cart-summary__total__value {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #fff;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  position: relative;
  z-index: 1;
}

/* Check-bullet lista */
.cart-summary__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: var(--space-2);
}
.cart-summary__bullets li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.85rem;
  color: var(--color-text);
  line-height: 1.4;
}
.cart-summary__check {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-success-text);
}

.cart-submit-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.cart-summary__footnote {
  margin: 0;
  text-align: center;
  font-size: 0.72rem;
  color: var(--color-muted);
  line-height: 1.5;
}

/* ─── #7 Üres-állapot ────────────────────────────────── */
.cart-empty {
  position: relative;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-10) var(--space-6);
  text-align: center;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 12px 32px -16px rgba(31, 39, 56, 0.18);
  overflow: hidden;
}
.cart-empty__glow {
  position: absolute;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.08), transparent 65%);
  pointer-events: none;
}
.cart-empty__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: var(--color-bg-soft);
  color: var(--color-secondary);
  margin: 0 auto var(--space-4);
  position: relative;
  z-index: 1;
  opacity: 0.85;
}
.cart-empty__eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-2);
  position: relative;
  z-index: 1;
}
.cart-empty__title {
  margin: 0 0 var(--space-2);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--color-text-strong);
  position: relative;
  z-index: 1;
}
.cart-empty__lead {
  margin: 0 auto var(--space-5);
  font-size: var(--font-size-small);
  color: var(--color-text);
  max-width: 42ch;
  line-height: 1.55;
  position: relative;
  z-index: 1;
}
.cart-empty__ctas {
  display: inline-flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
  z-index: 1;
}

/* ─── Mobil ──────────────────────────────────────────── */
@media (max-width: 720px) {
  .table--cart thead { display: none; }
  .table--cart, .table--cart tbody, .table--cart tr { display: block; }
  .table--cart tbody tr {
    padding: var(--space-3);
    margin-bottom: var(--space-3);
    border-radius: var(--radius-md);
  }
  .table--cart .cart-cell {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    text-align: left;
    border-radius: 0 !important;
  }
  .table--cart .cart-cell--product { padding-bottom: var(--space-3); }
  .table--cart .cart-cell--num { text-align: right; }
  .cart-price { align-items: flex-end; }
  .cart-empty { padding: var(--space-8) var(--space-4); }
}

/* =========================================================
   PREMIUM PASS — ORDERS (lista + visszaigazolás + detail) (2026-05-13)
   ========================================================= */

/* ─── Rendeléseim lista ──────────────────────────────── */
.orders-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.order-row {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.4fr) auto;
  gap: var(--space-5);
  align-items: center;
  padding: var(--space-4) var(--space-5);
  background: #fff;
  border-radius: var(--radius-md);
  text-decoration: none;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 0 0 1px rgba(31, 39, 56, 0.06);
  transition: box-shadow var(--transition), transform var(--transition);
  color: inherit;
}
.order-row:hover {
  transform: translateY(-1px);
  box-shadow:
    0 8px 22px -8px rgba(31, 39, 56, 0.12),
    0 0 0 1px rgba(5, 83, 164, 0.25);
  color: inherit;
}
.order-row__main {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.order-row__number {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text-strong);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.005em;
}
.order-row__date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  color: var(--color-muted);
}
.order-row__date svg { flex-shrink: 0; }

.order-row__meta {
  display: flex;
  align-items: stretch;
  gap: var(--space-5);
  justify-content: flex-end;
}
.order-row__stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: right;
  min-width: 70px;
}
.order-row__stat__label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.order-row__stat__value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text-strong);
  font-variant-numeric: tabular-nums;
}
.order-row__stat--total .order-row__stat__value {
  font-size: 1.05rem;
  color: var(--color-secondary);
  position: relative;
  padding-bottom: 4px;
  display: inline-block;
}
.order-row__stat--total .order-row__stat__value::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 22px;
  height: 2px;
  background: var(--color-accent);
  border-radius: 1px;
}

.order-row__status {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.order-row__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-bg-soft);
  color: var(--color-muted);
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.order-row:hover .order-row__chevron {
  background: var(--color-primary);
  color: #fff;
  transform: translateX(2px);
}

/* ─── Status-badge színkód ────────────────────────────── */
.order-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-transform: uppercase;
}
.order-status-badge__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.order-status-badge--lg {
  padding: 8px 14px;
  font-size: 0.82rem;
}

.order-status-badge--new {
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.order-status-badge--reviewing {
  background: rgba(237, 28, 36, 0.10);
  color: var(--color-accent);
}
.order-status-badge--confirmed,
.order-status-badge--fulfilled {
  background: var(--color-success-bg);
  color: var(--color-success-text);
}
.order-status-badge--cancelled {
  background: var(--color-surface);
  color: var(--color-muted);
}
.order-status-badge--muted {
  background: var(--color-bg-soft);
  color: var(--color-muted);
}

/* Mobil: order-row 1 oszlopossá válik */
@media (max-width: 720px) {
  .order-row {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .order-row__meta {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: var(--space-4);
  }
  .order-row__stat { text-align: left; min-width: 60px; }
  .order-row__stat--total .order-row__stat__value::after { left: 0; right: auto; }
  .order-row__status { justify-content: space-between; }
}

/* ─── Visszaigazolás-oldal hero ──────────────────────── */
.confirm-hero {
  position: relative;
  text-align: center;
  padding: var(--space-9) var(--space-6) var(--space-8);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 18px 38px -20px rgba(31, 39, 56, 0.22);
  overflow: hidden;
  margin-bottom: var(--space-6);
}
.confirm-hero::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-success-text) 50%, var(--color-accent) 100%);
}
.confirm-hero__glow {
  position: absolute;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(47, 107, 69, 0.10), transparent 60%);
  pointer-events: none;
}
.confirm-hero__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--color-success-bg);
  color: var(--color-success-text);
  margin-bottom: var(--space-4);
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 6px rgba(47, 107, 69, 0.08);
}
.confirm-hero__eyebrow {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-success-text);
  margin-bottom: var(--space-2);
  position: relative;
  z-index: 1;
}
.confirm-hero__title {
  margin: 0 0 var(--space-3);
  font-size: clamp(1.5rem, 3vw, 1.875rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--color-text-strong);
  position: relative;
  z-index: 1;
}
.confirm-hero__lead {
  margin: 0 auto var(--space-5);
  font-size: var(--font-size-small);
  color: var(--color-text);
  max-width: 50ch;
  line-height: 1.55;
  position: relative;
  z-index: 1;
}
.confirm-hero__number {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-3) var(--space-5);
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
  color: #fff;
  border-radius: var(--radius-md);
  position: relative;
  z-index: 1;
  box-shadow: 0 8px 22px -8px rgba(15, 23, 42, 0.35);
}
.confirm-hero__number__label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.confirm-hero__number__value {
  font-size: 1.25rem;
  font-weight: 800;
  color: #fff;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}

/* ─── 4-lépéses timeline (confirmation-on) ────────────── */
.confirm-timeline-wrap {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
}
.confirm-timeline__title {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-4);
}
.confirm-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
.confirm-timeline__step {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  padding-right: var(--space-4);
}
.confirm-timeline__step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 14px;
  right: 0;
  width: calc(100% - 36px - var(--space-4));
  height: 2px;
  background: rgba(47, 58, 86, 0.10);
  z-index: 0;
}
.confirm-timeline__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--color-border);
  color: var(--color-muted);
  font-weight: 700;
  font-size: 0.8125rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  font-variant-numeric: tabular-nums;
}
.confirm-timeline__step.is-done .confirm-timeline__num {
  background: var(--color-success-text);
  border-color: var(--color-success-text);
  color: #fff;
}
.confirm-timeline__step.is-done div strong {
  color: var(--color-success-text);
}
.confirm-timeline__step strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-text-strong);
  margin-bottom: 2px;
}
.confirm-timeline__step p {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-text);
  line-height: 1.45;
}

@media (max-width: 720px) {
  .confirm-timeline {
    grid-template-columns: 1fr;
    gap: var(--space-3);
  }
  .confirm-timeline__step {
    padding-right: 0;
    padding-left: 0;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--space-3);
  }
  .confirm-timeline__step:not(:last-child)::after {
    top: 36px;
    left: 13px;
    right: auto;
    width: 2px;
    height: calc(100% - 24px);
  }
}

/* ─── Közös: items-tábla, totals, megjegyzés, CTA-k ──── */
.orders-items {
  margin-bottom: var(--space-4);
}
.orders-totals {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-4);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 8px 20px -12px rgba(31, 39, 56, 0.14);
}
.orders-note {
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.orders-note__body {
  margin: 0;
  white-space: pre-wrap;
  color: var(--color-text-strong);
  font-size: var(--font-size-small);
  line-height: 1.55;
}

.orders-ctas {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-5);
}

/* ─── Rendelés-részletoldal extra ────────────────────── */
.order-detail__back {
  margin-bottom: var(--space-3);
}
.order-detail__back a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
  text-decoration: none;
  transition: color var(--transition);
}
.order-detail__back a:hover { color: var(--color-primary); }

.order-detail__date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--color-muted);
  margin-top: 6px;
}

.order-detail__status-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 8px 20px -12px rgba(31, 39, 56, 0.10);
}

/* =========================================================
   PREMIUM PASS — ADMIN ORDERS (lista + feldolgozó) (2026-05-13)
   ========================================================= */

/* ─── Filter-bar (lista tetején) ──────────────────────── */
.admin-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
  padding: var(--space-3);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 1px 0 rgba(31, 39, 56, 0.04);
}
.admin-filter-bar__search {
  position: relative;
  flex: 1 1 auto;
  display: flex;
  align-items: center;
}
.admin-filter-bar__search svg {
  position: absolute;
  left: 14px;
  color: var(--color-muted);
  pointer-events: none;
}
.admin-filter-bar__search .input {
  width: 100%;
  padding-left: 40px;
  height: 40px;
  border-color: var(--color-border);
  background: var(--color-bg-soft);
  border-radius: var(--radius-pill);
}
.admin-filter-bar__search .input:focus {
  border-color: var(--color-primary);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(5, 83, 164, 0.10);
}
.admin-filter-bar__status .input {
  height: 40px;
  min-width: 180px;
  border-radius: var(--radius-pill);
  border-color: var(--color-border);
  background: var(--color-bg-soft);
  padding: 0 var(--space-4);
}
@media (max-width: 720px) {
  .admin-filter-bar {
    flex-wrap: wrap;
  }
  .admin-filter-bar__search {
    flex: 1 1 100%;
  }
  .admin-filter-bar__status {
    flex: 1 1 auto;
  }
}

/* ─── Admin order-row partner-blokk ──────────────────── */
.admin-order-row {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.3fr) minmax(0, 1.1fr) auto;
}
.admin-order-row__note {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  color: var(--color-muted);
  font-style: italic;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-top: 2px;
}
.admin-order-row__note svg {
  flex-shrink: 0;
  color: var(--color-primary);
}

.admin-order-row__partner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.admin-order-row__partner__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  color: #fff;
  font-weight: 700;
  font-size: 0.875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.admin-order-row__partner__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.admin-order-row__partner__name {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-text-strong);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin-order-row__partner__contact {
  font-size: 0.72rem;
  color: var(--color-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 880px) {
  .admin-order-row {
    grid-template-columns: 1fr 1fr;
  }
  .admin-order-row__partner {
    grid-column: 1 / -1;
    order: 2;
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-border);
  }
  .order-row__meta { order: 3; }
  .order-row__status { order: 4; grid-column: 1 / -1; justify-content: space-between; }
}
@media (max-width: 540px) {
  .admin-order-row { grid-template-columns: 1fr; }
  .admin-order-row__partner { grid-column: 1; }
}

/* ─── Admin order-detail grid ─────────────────────────── */
.admin-order-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: var(--space-6);
  align-items: flex-start;
}
@media (max-width: 1024px) {
  .admin-order-grid { grid-template-columns: 1fr; }
}

/* ─── Partner-kártya ─────────────────────────────────── */
.admin-partner-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-5);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 8px 20px -12px rgba(31, 39, 56, 0.10);
}
.admin-partner-card__head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.admin-partner-card__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -0.01em;
}
.admin-partner-card__title {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.admin-partner-card__title strong {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text-strong);
  letter-spacing: -0.005em;
}
.admin-partner-card__tax {
  font-size: 0.78rem;
  color: var(--color-muted);
}
.admin-partner-card__tax code {
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--color-text);
  font-family: var(--font-family-mono, ui-monospace, monospace);
}
.admin-partner-card__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin: 0;
}
.admin-partner-card__list > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.admin-partner-card__list dt {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin: 0;
}
.admin-partner-card__list dd {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-text-strong);
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-partner-card__list dd a {
  color: var(--color-primary);
}
@media (max-width: 720px) {
  .admin-partner-card__list { grid-template-columns: 1fr; gap: var(--space-3); }
}

/* ─── Admin belső jegyzet kártya (admin tinted) ──────── */
.admin-note-card {
  background: linear-gradient(180deg, #FFFDF5 0%, #FFFBE8 100%);
  border: 1px solid rgba(138, 90, 0, 0.16);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
  position: relative;
  overflow: hidden;
}
.admin-note-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 3px;
  height: 100%;
  background: var(--color-warning-text);
}
.admin-note-card__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.admin-note-card__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-warning-text);
}
.admin-note-card textarea {
  background: #fff;
  border-color: rgba(138, 90, 0, 0.20);
}
.admin-note-card textarea:focus {
  border-color: var(--color-warning-text);
  box-shadow: 0 0 0 3px rgba(138, 90, 0, 0.10);
}

/* ─── Műveletek-aside ─────────────────────────────────── */
.admin-actions-wrap {
  position: sticky;
  top: calc(var(--header-height) + var(--space-4));
}
.admin-actions {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 12px 32px -16px rgba(31, 39, 56, 0.20);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  overflow: hidden;
}
.admin-actions::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.admin-actions__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.admin-action-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin: 0;
}
.admin-action-block__hint {
  margin: 0;
  font-size: 0.72rem;
  color: var(--color-muted);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1.4;
}
.admin-action-block__hint svg {
  flex-shrink: 0;
  color: var(--color-muted);
}

/* Success-zöld gomb (visszaigazolás) */
.btn--success {
  background: var(--color-success-text);
  color: #fff;
  border-color: var(--color-success-text);
}
.btn--success:hover {
  background: #25563A;
  border-color: #25563A;
  color: #fff;
}

/* Lemondás details (collapsible) */
.admin-action-cancel {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-3);
  margin-top: 0;
}
.admin-action-cancel[open] {
  background: rgba(237, 28, 36, 0.04);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin: 0;
  border: 1px solid rgba(237, 28, 36, 0.16);
  border-top: 1px solid rgba(237, 28, 36, 0.16);
}
.admin-action-cancel__trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-size: var(--font-size-small);
  font-weight: 600;
  color: var(--color-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  list-style: none;
  transition: background var(--transition), color var(--transition);
}
.admin-action-cancel__trigger::-webkit-details-marker {
  display: none;
}
.admin-action-cancel__trigger:hover {
  background: rgba(237, 28, 36, 0.06);
  color: var(--color-accent);
}
.admin-action-cancel[open] .admin-action-cancel__trigger {
  color: var(--color-accent);
}
.admin-action-cancel__form {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.admin-action-cancel__form textarea {
  background: #fff;
  border-color: rgba(237, 28, 36, 0.24);
}
.admin-action-cancel__form textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px rgba(237, 28, 36, 0.12);
}

.admin-action-final {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: var(--space-3);
  background: var(--color-bg-soft);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-small);
  color: var(--color-muted);
  text-align: center;
}

/* =========================================================
   PREMIUM PASS — ADMIN PRODUCTS LIST (filter + bulk) (2026-05-13)
   ========================================================= */

/* ─── Szűrők ──────────────────────────────────────────── */
.admin-product-filters {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-5);
  box-shadow: 0 1px 0 rgba(31, 39, 56, 0.04);
}
.admin-product-filters__grid {
  display: grid;
  grid-template-columns: 2fr repeat(5, 1fr);
  gap: var(--space-3);
}
.admin-product-filters__grid .field { margin: 0; }
.admin-product-filters__grid .field__label {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 4px;
}
.admin-product-filters__grid .input {
  height: 36px;
  padding: 0 var(--space-3);
  font-size: var(--font-size-small);
}
.admin-product-filters__actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
@media (max-width: 1024px) {
  .admin-product-filters__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 720px) {
  .admin-product-filters__grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ─── Bulk-bar (sticky) ──────────────────────────────── */
.bulk-bar {
  position: sticky;
  top: var(--header-height);
  z-index: 10;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
  color: #fff;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 12px 28px -16px rgba(15, 23, 42, 0.45);
  overflow: hidden;
}
.bulk-bar::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.bulk-bar__left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  position: relative;
  z-index: 1;
}
.bulk-bar__counter {
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
}
.bulk-bar__counter strong {
  color: #fff;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.bulk-bar__right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.bulk-bar__group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bulk-bar__group__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.bulk-bar__group__label strong {
  color: #fff;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.bulk-bar__divider {
  width: 1px;
  align-self: stretch;
  background: rgba(255, 255, 255, 0.15);
}
/* A bulk-bar-on belül a btn--ghost-line legyen sötét-háttéren is olvasható */
.bulk-bar .btn--ghost-line {
  border-color: rgba(255, 255, 255, 0.30);
  color: #fff;
  background: rgba(255, 255, 255, 0.05);
}
.bulk-bar .btn--ghost-line:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.55);
  color: #fff;
}
.bulk-bar .btn[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}

@media (max-width: 880px) {
  .bulk-bar { flex-direction: column; align-items: flex-start; }
  .bulk-bar__divider { display: none; width: 100%; height: 1px; }
}

/* ─── Admin products táblázat ────────────────────────── */
.admin-products-table-wrap {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 8px 20px -12px rgba(31, 39, 56, 0.08);
}
.admin-products-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.admin-products-table thead th {
  background: var(--color-bg-soft);
  color: var(--color-muted);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: var(--space-3) var(--space-3);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
.admin-products-table thead th.num { text-align: right; }
.admin-products-table tbody tr {
  border-bottom: 1px solid var(--color-border);
  transition: background var(--transition);
}
.admin-products-table tbody tr:last-child { border-bottom: 0; }
.admin-products-table tbody tr:hover { background: rgba(5, 83, 164, 0.03); }
.admin-products-table tbody tr.no-stock {
  background: rgba(237, 28, 36, 0.025);
}
.admin-products-table tbody tr.no-stock:hover {
  background: rgba(237, 28, 36, 0.05);
}
.admin-products-table tbody td {
  padding: var(--space-3);
  font-size: var(--font-size-small);
  color: var(--color-text);
  vertical-align: middle;
}
.admin-products-table tbody td.num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.admin-products-table__check {
  width: 44px;
  text-align: center !important;
  padding-left: var(--space-3) !important;
  padding-right: var(--space-2) !important;
}
.admin-products-table__name {
  color: var(--color-text-strong);
  font-weight: 600;
  text-decoration: none;
  transition: color var(--transition);
}
.admin-products-table__name:hover { color: var(--color-primary); }

/* Custom checkboxok (master + sor) — kék-fill ✓ */
.admin-products-table input[type="checkbox"],
#bulk-master {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--color-border);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  position: relative;
  vertical-align: middle;
  transition: border-color var(--transition), background var(--transition);
}
.admin-products-table input[type="checkbox"]:hover,
#bulk-master:hover {
  border-color: var(--color-primary);
}
.admin-products-table input[type="checkbox"]:checked,
#bulk-master:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-size: 12px 12px;
  background-position: center;
  background-repeat: no-repeat;
}
#bulk-master:indeterminate {
  background: var(--color-primary);
  border-color: var(--color-primary);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round'><line x1='5' y1='12' x2='19' y2='12'/></svg>");
  background-size: 12px 12px;
  background-position: center;
  background-repeat: no-repeat;
}

/* =========================================================
   PREMIUM PASS — AUTH FORMS (login + change-password) (2026-05-13)
   ========================================================= */

/* Auth-shell soft variáns — háttér + radial-glow */
.auth-shell--soft {
  position: relative;
  min-height: calc(100vh - var(--header-height) - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--container-padding);
  background: var(--color-bg-soft);
  overflow: hidden;
}
.auth-shell__glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 30% 20%, rgba(5, 83, 164, 0.08), transparent 50%),
    radial-gradient(circle at 80% 90%, rgba(237, 28, 36, 0.05), transparent 50%);
}

/* Auth-form-card — közepes méretű, kék-piros gradient szalaggal */
.auth-form-card {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 460px;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: var(--space-8) clamp(var(--space-5), 4vw, var(--space-7));
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 24px 48px -16px rgba(31, 39, 56, 0.18),
    0 8px 16px -8px rgba(31, 39, 56, 0.08);
  overflow: hidden;
  border: 1px solid rgba(31, 39, 56, 0.06);
}
.auth-form-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}

.auth-form-card__header {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: var(--space-5);
}
.auth-form-card__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.auth-form-card__title {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 1.75rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--color-text-strong);
  line-height: 1.15;
}
.auth-form-card__lead {
  margin: 4px 0 0;
  font-size: var(--font-size-small);
  color: var(--color-text);
  line-height: 1.55;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.auth-form .field { margin: 0; }
.auth-form .btn--lg { margin-top: var(--space-2); }

/* Vagy-elválasztó — divider „vagy" felirattal középen */
.auth-form-card__divider {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-5) 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.auth-form-card__divider::before,
.auth-form-card__divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--color-border);
}

.auth-form-card__footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: stretch;
  text-align: center;
}
.auth-form-card__footer__lead {
  font-size: var(--font-size-small);
  color: var(--color-text);
}
.auth-form-card__footnote {
  margin: var(--space-2) 0 0;
  text-align: center;
  font-size: 0.72rem;
  color: var(--color-muted);
}

/* Auth-progress — 3-lépéses mini-indikátor (force pwd change) */
.auth-progress {
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
}
.auth-progress__step {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  padding-right: var(--space-3);
}
.auth-progress__step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 11px;
  right: 0;
  width: calc(100% - 30px - var(--space-3));
  height: 2px;
  background: var(--color-border);
}
.auth-progress__step.is-done .auth-progress__num {
  background: var(--color-success-text);
  border-color: var(--color-success-text);
  color: #fff;
}
.auth-progress__step.is-done::after { background: var(--color-success-text); }
.auth-progress__step.is-current .auth-progress__num {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(5, 83, 164, 0.15);
}
.auth-progress__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--color-border);
  color: var(--color-muted);
  font-weight: 700;
  font-size: 0.78rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  font-variant-numeric: tabular-nums;
}
.auth-progress__label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--color-muted);
  white-space: nowrap;
}
.auth-progress__step.is-current .auth-progress__label {
  color: var(--color-text-strong);
}
.auth-progress__step.is-done .auth-progress__label {
  color: var(--color-success-text);
}

/* Mobil */
@media (max-width: 540px) {
  .auth-form-card { padding: var(--space-6) var(--space-5); }
  .auth-progress {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }
  .auth-progress__step:not(:last-child)::after {
    display: none;
  }
}

/* =========================================================
   AUTH FIX-PASS (2026-05-13) — login szövegtörési hiba + 2-oszlopos
   ========================================================= */

/* P5 — Több levegő a header alatt + erősebb radial-glow */
.auth-shell--soft {
  padding-top: clamp(var(--space-8), 8vh, var(--space-10));
  padding-bottom: clamp(var(--space-8), 8vh, var(--space-10));
}
.auth-shell__glow {
  background:
    radial-gradient(circle at 25% 20%, rgba(5, 83, 164, 0.12), transparent 50%),
    radial-gradient(circle at 80% 90%, rgba(237, 28, 36, 0.08), transparent 50%);
}

/* P3 — Login 2-oszlopos layout (≥960px) — EGY összenőtt kártya */
.auth-shell--split {
  align-items: center;
}
.auth-shell__split {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 480px);
  gap: 0;
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  align-items: stretch;
}
@media (min-width: 960px) {
  .auth-shell__split {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    max-width: 920px;
    background: #fff;
    border: 1px solid rgba(31, 39, 56, 0.06);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow:
      0 1px 0 rgba(31, 39, 56, 0.04),
      0 24px 48px -16px rgba(31, 39, 56, 0.18),
      0 8px 16px -8px rgba(31, 39, 56, 0.08);
  }
  .auth-shell__split::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
    z-index: 2;
  }
  /* Belül a két oszlop "olvad" a parent kártyába — saját szegélyük, árnyékuk, szalagjuk eltűnik */
  .auth-shell--split .auth-form-card {
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    max-width: none;
    padding: clamp(var(--space-7), 5vw, var(--space-8)) clamp(var(--space-6), 4vw, var(--space-7));
  }
  .auth-shell--split .auth-form-card::before {
    display: none;
  }
  .auth-shell--split .auth-aside-promo {
    border-radius: 0;
    box-shadow: none;
  }
  .auth-shell--split .auth-aside-promo::before {
    display: none;
  }
}

/* P2 — Kártya szélesítése + h1 visszafogása */
.auth-form-card {
  max-width: 480px;
  padding: clamp(var(--space-7), 5vw, var(--space-8)) clamp(var(--space-5), 4vw, var(--space-7));
}
.auth-form-card__title {
  font-size: clamp(1.4rem, 2.6vw, 1.625rem);
  letter-spacing: -0.01em;
}

/* P4 — Kulcs-ikon a header tetején */
.auth-form-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--color-primary-light);
  color: var(--color-primary);
  margin-bottom: var(--space-3);
  align-self: flex-start;
}

/* P1 — Aláhúzás a span belsejéhez kötve (overflow-független) */
.auth-form-card__title__accent {
  position: relative;
  display: inline;
  padding-bottom: 4px;
  background-image: linear-gradient(var(--color-accent), var(--color-accent));
  background-repeat: no-repeat;
  background-size: 100% 3px;
  background-position: 0 100%;
}

/* JOBB OSZLOP: navy-aside promo (≥960px-en látszik) */
.auth-aside-promo {
  display: none;
}
@media (min-width: 960px) {
  .auth-aside-promo {
    display: flex;
    background: linear-gradient(135deg, #2F3A56 0%, #1F2840 100%);
    border-radius: var(--radius-lg);
    color: #fff;
    position: relative;
    overflow: hidden;
    box-shadow:
      0 1px 0 rgba(31, 39, 56, 0.04),
      0 24px 48px -16px rgba(31, 39, 56, 0.30);
  }
}
.auth-aside-promo::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.auth-aside-promo::after {
  content: "";
  position: absolute;
  top: -60px; right: -60px;
  width: 240px; height: 240px;
  background: radial-gradient(circle, rgba(5, 83, 164, 0.30), transparent 65%);
  pointer-events: none;
}
.auth-aside-promo__inner {
  position: relative;
  z-index: 1;
  padding: var(--space-7) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  width: 100%;
}
.auth-aside-promo__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
.auth-aside-promo__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.auth-aside-promo__bullets li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}
.auth-aside-promo__check {
  flex-shrink: 0;
  margin-top: 4px;
  color: var(--color-secondary-light);
}
.auth-aside-promo__bullets li strong {
  display: block;
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  margin-bottom: 2px;
}
.auth-aside-promo__bullets li p {
  margin: 0;
  font-size: 0.82rem;
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.5;
}
.auth-aside-promo__divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.10);
  margin: var(--space-2) 0;
}
.auth-aside-promo__cta {
  margin: 0;
  font-size: var(--font-size-small);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.6;
}
.auth-aside-promo__cta strong {
  color: #fff;
  font-weight: 700;
}
.auth-aside-promo__cta a {
  color: #fff;
  text-decoration: none;
  border-bottom: 1px dotted rgba(255, 255, 255, 0.40);
  font-weight: 600;
  transition: border-color var(--transition);
}
.auth-aside-promo__cta a:hover {
  border-color: #fff;
}

/* =========================================================
   ERROR-CARD (404 / 403 / 500 / CSRF) — premium error oldal
   ========================================================= */
.error-card {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid rgba(31, 39, 56, 0.06);
  border-radius: var(--radius-lg);
  padding: clamp(var(--space-7), 5vw, var(--space-9)) clamp(var(--space-5), 4vw, var(--space-7));
  text-align: center;
  box-shadow:
    0 1px 0 rgba(31, 39, 56, 0.04),
    0 24px 48px -16px rgba(31, 39, 56, 0.18),
    0 8px 16px -8px rgba(31, 39, 56, 0.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}
.error-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}
.error-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  margin-bottom: var(--space-2);
}
/* Ikon-variánsok színkóddal */
.error-card__icon--not-found {
  background: var(--color-primary-light);
  color: var(--color-primary);
}
.error-card__icon--locked {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
}
.error-card__icon--csrf {
  background: var(--color-surface);
  color: var(--color-secondary);
}
.error-card__icon--warning {
  background: rgba(237, 28, 36, 0.10);
  color: var(--color-accent);
}
.error-card__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.error-card__title {
  margin: 0;
  font-size: clamp(1.4rem, 2.6vw, 1.625rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-text-strong);
  line-height: 1.2;
}
.error-card__message {
  margin: 0 auto;
  font-size: var(--font-size-small);
  color: var(--color-text);
  line-height: 1.55;
  max-width: 42ch;
}
.error-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-3);
}
.error-card__footnote {
  margin: var(--space-3) 0 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
  font-size: 0.72rem;
  color: var(--color-muted);
  width: 100%;
}
.error-card__footnote a {
  color: var(--color-primary);
  font-weight: 600;
}

/* =========================================================
   ADMIN FORM-WRAP — közös admin-form konténer (új partner / kezelő / settings stb.)
   ========================================================= */
.admin-form-wrap {
  max-width: 760px;
  margin: 0;
}
.admin-form-wrap .admin-partner-card + .admin-partner-card,
.admin-form-wrap .admin-partner-card + section.admin-partner-card {
  margin-top: var(--space-5);
}

/* =========================================================
   MOBILE-AUDIT FIXES (2026-05-13) — apró 320-540px hibák
   A fő bulk-bar-fix már beépítve a fő szabályba (sticky működik most).
   ========================================================= */

/* MOBIL #2 — Hero accent szöveg-vágás kis viewport-on */
@media (max-width: 540px) {
  .hero__title__accent,
  .auth-form-card__title__accent,
  .cart-header__title__accent {
    white-space: normal;
  }
  .hero__title--ondark {
    font-size: clamp(1.5rem, 6vw, 1.75rem);
  }
}

/* MOBIL #4 — Touch-targetek minimum 40×40 (Apple HIG: 44, Material: 48) */
@media (max-width: 720px) {
  .cart-qty {
    min-height: 44px;
  }
  .cart-qty__input {
    height: 44px;
    width: 60px;
  }
  .cart-qty__save {
    min-width: 44px;
    min-height: 44px;
    padding: 0 12px;
  }
  .cart-remove {
    min-width: 44px;
    min-height: 44px;
    padding: 12px;
  }
  /* Filter-checkbox label-zóna: a 18×18px input nem tap-target,
     de a label körülveszi — tegyük 40px-magasra a tapot */
  .catalog-filter-item {
    min-height: 40px;
    padding: 8px 0;
  }
}

/* MOBIL #6 — Site-nav 540px alatt CSS-only hamburger menü.
   A korábbi `display: none` helyett egy <details> elemet vártunk volna,
   de mivel a header.ejs-be nem akarunk JS-t tenni, és a meglévő struktúrát
   meg kell tartani, használjunk a meglévő .site-nav-on belül egy "scroll-bar"-ozott
   horizontális layoutot — nem optimális, de jobb mint a teljes elrejtés.
   (HA később valódi hamburger kell, header.ejs-ben adunk <details>-summary-t.) */
@media (max-width: 540px) {
  .site-nav {
    display: flex !important; /* megkerüli a régi display:none-t */
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin-left: var(--space-2);
    gap: var(--space-3);
    flex: 1 1 auto;
    min-width: 0;
  }
  .site-nav::-webkit-scrollbar { display: none; }
  .site-nav a {
    flex-shrink: 0;
    font-size: 0.85rem;
    padding: 8px 4px;
    white-space: nowrap;
  }
  /* A search-doboz mobil rejtve marad, hely megspórolódik a navnak */
}

/* MOBIL #7 — cart-summary__total mobile flex-wrap nagy összegnél */
@media (max-width: 540px) {
  .cart-summary__total {
    flex-wrap: wrap;
    gap: 6px;
  }
  .cart-summary__total__value {
    font-size: 1.25rem;
    width: 100%;
    text-align: right;
  }
}

/* MOBIL #9 — product-detail aside hard-coded 72px → header-height var */
.product-detail__aside--sticky {
  top: calc(var(--header-height) + var(--space-4));
}

/* MOBIL #11 — eyebrow font min 12px (volt 0.65-0.72rem = 10-11px) */
@media (max-width: 540px) {
  .cart-header__eyebrow,
  .auth-form-card__eyebrow,
  .cart-summary__eyebrow,
  .admin-actions__eyebrow,
  .order-row__stat__label,
  .admin-partner-card__list dt,
  .field-group__legend,
  .filter-card__title,
  .product-card__brand {
    font-size: 0.78rem; /* min 12.5px */
  }
}

/* MOBIL #13 — admin filter mobile 1 oszlop */
@media (max-width: 540px) {
  .admin-product-filters__grid {
    grid-template-columns: 1fr;
  }
}

/* MOBIL #5 — confirm-timeline connector a num közepe alá */
@media (max-width: 720px) {
  .confirm-timeline__step:not(:last-child)::after {
    left: 14px; /* num 28px / 2 = 14 */
    top: 32px;
    height: calc(100% - 24px);
  }
}

/* MOBIL #15 — signup-card chips 380-540px szűk */
@media (max-width: 540px) {
  .signup-card-v2__profile__chips {
    grid-template-columns: 1fr;
  }
}

/* MOBIL — apró: hero-search-strip mobilon margin-top csökkentés */
@media (max-width: 720px) {
  .hero-search-strip {
    margin-top: 0;
    padding: var(--space-3) 0;
  }
}

/* MOBIL #3 — Catalog-sidebar (most <details>) — desktopon mindig nyitva,
   mobile-on (<800px) csukva indul, summary-vel toggleli a user. */
.catalog-sidebar > .catalog-sidebar__summary {
  display: none; /* desktopon a summary el van rejtve */
}
@media (min-width: 801px) {
  /* Desktopon a details mindig nyitva — a summary-toggle érvénytelen.
     Trükk: a `details > *:not(summary)` mindig megjelenik, ha a CSS-szel
     a `[open]` selector-t nem használjuk; viszont a HTML5 `<details>` alapból
     csukva indul. Megoldás: az 'open' attribútumot JS-szel desktopon
     beállítjuk, vagy CSS-trükk: a > .catalog-filters legyen mindig display: block.
     Egyszerűbb: a details-on belül a content mindig megjelenik desktopon. */
  .catalog-sidebar > .catalog-filters {
    display: block !important;
  }
}
@media (max-width: 800px) {
  .catalog-sidebar {
    border: 1px solid var(--color-border);
    background: #fff;
    border-radius: var(--radius-md);
    padding: 0;
    margin-bottom: var(--space-4);
  }
  .catalog-sidebar > .catalog-sidebar__summary {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
    font-weight: 700;
    font-size: 0.875rem;
    color: var(--color-text-strong);
    list-style: none;
    user-select: none;
  }
  .catalog-sidebar > .catalog-sidebar__summary::-webkit-details-marker {
    display: none;
  }
  .catalog-sidebar > .catalog-sidebar__summary svg {
    color: var(--color-primary);
    flex-shrink: 0;
  }
  .catalog-sidebar__summary__chevron {
    margin-left: auto;
    transition: transform var(--transition);
    color: var(--color-muted);
  }
  .catalog-sidebar[open] .catalog-sidebar__summary__chevron {
    transform: rotate(180deg);
  }
  .catalog-sidebar[open] .catalog-sidebar__summary span:not(.catalog-sidebar__summary__chevron) {
    /* "Szűrők megnyitása" → "Szűrők bezárása" — CSS content-szwap nem lehet
       fordított-szöveggel; egyszerűbb: hagyjuk a szöveget, csak a chevron jelzi az állapotot. */
  }
  .catalog-sidebar > .catalog-filters {
    padding: 0 var(--space-4) var(--space-4);
  }
}
