:root {
  /* Anthracite galéria, vörös-okker akcent */
  --ink:        #1A1D20;   /* legmélyebb háttér */
  --obsidian:   #25282B;   /* fő háttér */
  --walnut:     #2E3236;   /* felület 1 (kártya) */
  --smoke:      #383C40;   /* felület 2 (raised) */
  --line:       #4A4E52;   /* vékony határ */
  --dust:       #FFFFFF;   /* szöveg fehér */
  --mist:       #FFFFFF;   /* szöveg fehér */
  --bone:       #FFFFFF;   /* szöveg fehér */
  --paper:      #FFFFFF;   /* szöveg fehér */
  --ochre:      #B14A2A;   /* AKCENT — vörös okker, max 5% */
  --ochre-deep: #7E2F18;

  /* Visszafelé kompatibilis aliasok */
  --onyx:     var(--obsidian);
  --void:     var(--ink);
  --charcoal: var(--walnut);
  --graphite: var(--walnut);
  --slate:    var(--smoke);
  --steel:    var(--line);
  --stone:    var(--dust);
  --pearl:    var(--bone);
  --ash:      var(--bone);
  --brass:    var(--ochre);
  --brass-deep: var(--ochre-deep);
  --smoke-rgb: 56, 60, 64;
  --ochre-rgb: 177, 74, 42;

  --font-display: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: 'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-title: 'Cardo', 'Times New Roman', serif;
  --nav-h: 84px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--obsidian);
  color: var(--bone);
  font-family: var(--font-body);
  font-weight: 300;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ============ FESTŐI HÁTTÉR-RÉTEG ============ */
/* Vászon-grain noise + meleg vignette, az egész oldalt áthatja. */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.92  0 0 0 0 0.85  0 0 0 0 0.72  0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 240px 240px;
  opacity: 0.10;
  mix-blend-mode: overlay;
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(ellipse 95% 75% at 62% 26%, rgba(var(--ochre-rgb), 0.10) 0%, transparent 62%),
    radial-gradient(ellipse 120% 90% at 50% 100%, rgba(0,0,0,0.55) 0%, transparent 70%);
}
.nav, section, footer, .ar-modal { position: relative; z-index: 2; }

/* ============ NAVIGATION ============ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  background: rgba(var(--smoke-rgb), 0.78);
  backdrop-filter: blur(18px) saturate(1.2);
  -webkit-backdrop-filter: blur(18px) saturate(1.2);
  border-bottom: 1px solid var(--line);
  z-index: 100;
  display: flex;
  align-items: center;
  padding: 0 40px;
}
.nav-inner {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 28px;
}
.brand { margin-right: auto; }
.brand {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--bone);
  display: inline-flex;
  align-items: center;
  gap: 0;
}
.brand .art { color: var(--ochre); font-weight: 300; }
.brand-logo { height: 64px; width: auto; display: block; margin-right: 11px; filter: invert(1); }
.footer-brand { display: flex; align-items: center; gap: 24px; }
.footer-logo { height: 96px; width: auto; display: block; flex-shrink: 0; filter: invert(1); }
.footer-brand-text { display: flex; flex-direction: column; gap: 8px; }
.footer-social { display: inline-flex; align-items: center; color: var(--mist); transition: color 0.2s ease; }
.footer-social svg { width: 36px; height: 36px; }
.footer-social:hover { color: var(--bone); }

.nav-links {
  display: flex;
  gap: 44px;
  list-style: none;
}
.nav-links a {
  font-size: 11px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bone);
  font-weight: 400;
  padding: 8px 0;
  position: relative;
  transition: color 0.3s ease;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: -6px; right: -6px; bottom: -5px;
  height: 11px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 14' preserveAspectRatio='none'><path d='M3 7.2 C 14 4.2, 52 3.6, 100 4.4 C 148 5.2, 180 5.8, 197 6.9 C 188 9, 150 9.6, 100 9.2 C 50 8.8, 16 9.4, 3 7.2 Z' fill='%23b14a2a' opacity='0.92'/><path d='M12 7 C 50 6, 100 6.5, 150 7 C 175 7.3, 188 7.6, 194 7.8' stroke='%23ffffff' stroke-width='0.5' fill='none' opacity='0.16'/><path d='M186 5.8 L 199 5.6 M 188 7.4 L 198 7.3 M 187 9 L 196 8.9' stroke='%23b14a2a' stroke-width='0.45' stroke-linecap='round' opacity='0.55'/></svg>") no-repeat left center / 100% 100%;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}
.nav-links a:hover { color: var(--paper); }
.nav-links a:hover::after { clip-path: inset(0 0 0 0); }

.nav-cta a {
  background: var(--ochre);
  color: var(--ink) !important;
  padding: 12px 22px;
  letter-spacing: 0.28em;
  font-weight: 600;
  border: 1px solid var(--ochre);
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
.nav-cta a::after { display: none; }
.nav-cta a:hover {
  background: transparent;
  color: var(--ochre) !important;
  border-color: var(--ochre);
}

.nav-toggle {
  display: none;
  background: transparent;
  border: 0;
  color: var(--bone);
  cursor: pointer;
  padding: 8px;
}
.nav-toggle span {
  display: block;
  width: 24px; height: 1px;
  background: var(--bone);
  margin: 6px 0;
  transition: transform 0.3s, opacity 0.3s;
}

/* ============ SECTION COMMON ============ */
section { padding: 140px 40px; }
.wrap { max-width: 1440px; margin: 0 auto; }

.eyebrow {
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--ochre);
  font-weight: 500;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 14px;
}

.section-title {
  font-family: var(--font-title);
  font-weight: 500;
  font-size: clamp(24px, 4.6vw, 68px);
  line-height: 1.05;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--bone);
  margin-bottom: 32px;
  white-space: nowrap;
}
.section-title .accent {
  color: var(--ochre);
  font-weight: 300;
}

.lead {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: clamp(16px, 1.35vw, 19px);
  letter-spacing: 0.02em;
  line-height: 1.55;
  color: var(--mist);
  max-width: 620px;
}

/* ============ HERO / RÓLAM ============ */
.hero {
  min-height: 100vh;
  padding: calc(var(--nav-h) + 40px) 40px 80px;
  display: grid;
  grid-template-columns: 4fr 9fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: center;
  position: relative;
  background: transparent;
  overflow: hidden;
}
.hero-text {
  position: relative;
  z-index: 3;
  order: 1;
  padding: 20px 0 20px clamp(0px, 5vw, 150px);
}
.hero-name {
  font-family: var(--font-title);
  font-size: clamp(30px, 3.4vw, 84px);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--bone);
  margin-bottom: 18px;
  white-space: nowrap;
}
.hero-name .accent {
  color: var(--ochre);
  font-weight: 300;
}
.hero-role {
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--mist);
  font-weight: 500;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero-bio p {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 16px;
  letter-spacing: 0.02em;
  line-height: 1.9;
  color: var(--bone);
  margin-bottom: 18px;
  max-width: 540px;
}
.hero-bio p.opening {
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.7;
  color: var(--paper);
  margin-bottom: 28px;
  font-weight: 300;
}
.hero-bio .accent { color: var(--ochre); font-weight: 400; }
.hero-motto {
  margin-top: 48px;
  padding-top: 36px;
  border-top: 1px solid var(--line);
  max-width: 640px;
}
.hero-motto-text {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.3vw, 40px);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--paper);
  line-height: 1.1;
  display: block;
}
.hero-motto-text .accent { color: var(--ochre); font-weight: 600; }
.hero-motto-cite { display: block; margin-top: 14px; font-family: var(--font-display); font-size: clamp(13px, 1.1vw, 16px); font-style: italic; letter-spacing: 0.04em; color: var(--ochre); opacity: 0.85; }

.hero-image {
  position: relative;
  width: 100%;
  height: 100%;
  order: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}
.hero-image-frame {
  position: relative;
  width: 100%;
  max-width: 1160px;
  aspect-ratio: 1 / 1;
  transform-origin: left center;
  transform: translateX(-90px) scale(1.12);
  overflow: hidden;
}
.hero-image-frame img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: contrast(1.04) saturate(1.05);
}
.hero-signature {
  position: absolute;
  bottom: 24px;
  left: 24px;
  z-index: 3;
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--ochre);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}

/* ============ TERMÉKEK — ASZIMMETRIKUS MOZAIK ============ */
.products {
  background: transparent;
  border-bottom: 1px solid var(--line);
}
.products-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 80px;
  gap: 40px;
  flex-wrap: wrap;
}
.products-head .head-text { max-width: 700px; }

.product-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(0, auto);
  gap: 24px;
}
.products-more {
  display: block;
  width: 100%;
  margin-top: 40px;
  padding: 28px 32px;
  text-align: center;
  font-family: var(--font-body);
  font-size: 13px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--paper);
  background: transparent;
  border: 1px solid var(--ochre);
  transition: background 0.35s ease, color 0.35s ease, letter-spacing 0.35s ease;
}
.products-more:hover {
  background: var(--ochre);
  color: var(--ink);
  letter-spacing: 0.38em;
}
.product {
  display: flex;
  flex-direction: column;
  background: var(--walnut);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
  transition: border-color 0.4s ease, transform 0.4s ease;
}
.product:hover {
  border-color: rgba(var(--ochre-rgb), 0.5);
}
.product.feature,
.product.tile {
  /* Egységes nagy kártyák: 3 egyenlő oszlop, kép felül */
  grid-column: span 4;
  grid-row: span 1;
}
.product.tile .product-body { padding: 28px 32px 32px; display: flex; flex-direction: column; }

.product-image {
  position: relative;
  aspect-ratio: 1 / 1;
  background: var(--smoke);
  overflow: visible;
  margin-bottom: 0;
  transition: transform 0.5s ease;
}
.product.feature .product-image { aspect-ratio: 1 / 1; }
.product-badge {
  position: absolute;
  top: 16px; left: 16px;
  z-index: 3;
  background: rgba(var(--smoke-rgb), 0.85);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: var(--ochre);
  font-size: 9px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 8px 12px;
  border: 1px solid var(--ochre);
}
.product-image img {
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity 0.4s ease, transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.product:hover .product-image img {
  transform: scale(1.03);
}
.product-image.loupe-active img { opacity: 0.55; }
.product-image::after {
  /* Vászon-grain a kép fölött, minimális 3% */
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' seed='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
  background-size: 180px 180px;
  opacity: 0.08;
  mix-blend-mode: overlay;
}

.product-body {
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}
.product.feature .product-body { padding: 36px 32px 32px; }

.product-num {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--ochre);
  font-weight: 500;
  margin-bottom: 12px;
  text-transform: uppercase;
}
.product-title {
  font-family: var(--font-display);
  font-size: clamp(26px, 2.4vw, 34px);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--bone);
  margin-bottom: 10px;
  line-height: 1.02;
}
.product-meta {
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--mist);
  margin-bottom: 18px;
  font-weight: 500;
}
.product-type {
  display: block;
  margin: 0 0 10px;
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bone);
  font-weight: 500;
  line-height: 1.5;
}
.product-desc {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 13px;
  letter-spacing: 0.02em;
  line-height: 1.6;
  color: var(--mist);
  margin-bottom: 24px;
  white-space: pre-line;
}
.product-desc strong, .product-desc b { font-weight: 700; color: var(--bone); }
.product-desc__hl {
  display: block;
  margin-top: 12px;
  font-weight: 700;
  color: var(--bone);
  letter-spacing: 0.01em;
}
.product-stock {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.product-stock-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 10px;
}
.product-stock-label {
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--mist);
  font-weight: 500;
}
.product-stock-count {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--bone);
  font-weight: 400;
  letter-spacing: -0.005em;
}
.product-stock-count .available { color: var(--ochre); }
.product-stock-bar {
  height: 2px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
}
.product-stock-bar > span {
  display: block;
  height: 100%;
  background: var(--ochre);
}

.product-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 18px;
  margin-top: 18px;
  border-top: 1px solid var(--line);
}

/* "Lássuk a falon" (AR) gombok átmenetileg elrejtve — későbbi fejlesztés. Töröld ezt a sort a visszahozáshoz. */
.product-ar { display: none !important; }
.product-ar {
  margin-top: 16px;
  width: 100%;
  background: transparent;
  color: var(--bone);
  border: 1px solid var(--line);
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 14px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: border-color 0.3s, color 0.3s, background 0.3s;
}
.product-ar:hover {
  border-color: var(--ochre);
  color: var(--ochre);
  background: rgba(var(--ochre-rgb), 0.06);
}
.product-ar svg {
  width: 14px; height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.4;
}

.product-price {
  font-family: var(--font-display);
  font-size: 20px;
  color: var(--bone);
  font-weight: 400;
  letter-spacing: -0.01em;
}
.product-cta {
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ochre);
  font-weight: 500;
  padding: 10px 0;
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s, color 0.3s;
  cursor: pointer;
}
.product-cta:hover {
  color: var(--bone);
  border-bottom-color: var(--ochre);
}

/* ============ AR MODAL (model-viewer) ============ */
.ar-modal {
  position: fixed;
  inset: 0;
  background: rgba(8, 6, 5, 0.94);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: 1100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  transition: opacity 0.28s ease;
}
.ar-modal.open {
  display: flex;
  opacity: 1;
}
.ar-modal-inner {
  position: relative;
  width: 100%;
  max-width: 820px;
  max-height: calc(100vh - 48px);
  background: var(--walnut);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6);
}
.ar-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.ar-modal-title {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--bone);
  font-weight: 500;
  line-height: 1.2;
}
.ar-modal-meta {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ochre);
  margin-top: 4px;
}
.ar-modal-close {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--bone);
  width: 40px;
  height: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
  flex-shrink: 0;
}
.ar-modal-close:hover {
  border-color: var(--ochre);
  color: var(--ochre);
  background: rgba(var(--ochre-rgb), 0.06);
}
.ar-modal-close svg {
  width: 14px; height: 14px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
}
.ar-modal-body {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  max-height: 60vh;
  background:
    radial-gradient(ellipse 70% 55% at 50% 45%, rgba(var(--ochre-rgb), 0.06) 0%, transparent 70%),
    var(--ink);
  overflow: hidden;
  flex-shrink: 0;
}
.ar-modal-body model-viewer {
  width: 100%;
  height: 100%;
  background-color: transparent;
  --poster-color: transparent;
  --progress-bar-color: var(--ochre);
  --progress-bar-height: 2px;
}
.ar-poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 8%;
  opacity: 1;
  transition: opacity 0.45s ease;
  pointer-events: none;
}
.ar-poster.hidden { opacity: 0; }
.ar-loading {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  background: rgba(11, 8, 7, 0.55);
  opacity: 0;
  transition: opacity 0.25s ease;
  pointer-events: none;
}
.ar-loading.show { opacity: 1; }
.ar-loading-spinner {
  width: 36px;
  height: 36px;
  border: 2px solid rgba(var(--ochre-rgb), 0.18);
  border-top-color: var(--ochre);
  border-radius: 50%;
  animation: ar-spin 0.85s linear infinite;
}
.ar-loading-text {
  font-family: var(--font-body);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--mist);
  font-weight: 500;
}
@keyframes ar-spin { to { transform: rotate(360deg); } }

.ar-modal-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  padding: 22px 24px 24px;
  border-top: 1px solid var(--line);
  flex-shrink: 0;
}
.ar-hint {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--mist);
  line-height: 1.55;
  text-align: center;
  margin: 0;
}
.ar-hint-mobile { display: none; }
.ar-hint-desktop { display: inline; }
@media (hover: none), (pointer: coarse) {
  .ar-hint-mobile { display: inline; }
  .ar-hint-desktop { display: none; }
}
.ar-launch-btn {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  background: var(--ochre);
  color: var(--ink);
  border: 1px solid var(--ochre);
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 18px 22px;
  cursor: pointer;
  transition: background 0.25s ease, color 0.25s ease, letter-spacing 0.25s ease;
}
.ar-launch-btn:not([hidden]) { display: flex; }
.ar-launch-btn:hover {
  background: transparent;
  color: var(--ochre);
  letter-spacing: 0.38em;
}
.ar-launch-btn svg {
  width: 16px; height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
}

/* Mobil teljes-képernyős modal */
@media (max-width: 640px) {
  .ar-modal { padding: 0; }
  .ar-modal-inner {
    max-height: 100vh;
    height: 100vh;
    border: 0;
  }
  .ar-modal-body { aspect-ratio: auto; flex: 1; max-height: none; }
  .ar-modal-head { padding: 16px 20px; }
  .ar-modal-actions { padding: 16px 20px 20px; }
  .ar-modal-title { font-size: 18px; }
}

/* Body lock — iOS-kompatibilis fixáció */
body.ar-locked { position: fixed; width: 100%; }

/* ============ KAPCSOLAT ============ */
.contact {
  background: transparent;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 80px;
  align-items: start;
  max-width: 1440px;
  margin: 0 auto;
  padding: 160px 40px;
}
.contact-info { padding-top: 8px; }
.contact-details {
  margin-top: 50px;
  display: grid;
  gap: 28px;
}
.detail-item {
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.detail-label {
  font-size: 11px;
  letter-spacing: 0.4em;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--mist);
  margin-bottom: 8px;
}
.detail-value {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--bone);
  font-weight: 400;
  letter-spacing: -0.005em;
}

.form { display: grid; gap: 26px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label {
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--mist);
  font-weight: 500;
}
.field input,
.field textarea,
.field select {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--line);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 300;
  padding: 12px 0;
  outline: 0;
  transition: border-color 0.3s;
  border-radius: 0;
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  border-bottom-color: var(--ochre);
}
.field textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.5;
  border: 1px solid var(--line);
  padding: 14px 16px;
  transition: border-color 0.3s;
  background: var(--walnut);
}
.field textarea:focus {
  border-color: var(--ochre);
}
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.consent {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 8px;
}
.consent input {
  margin-top: 4px;
  accent-color: var(--ochre);
}
.consent label {
  font-size: 12px;
  color: var(--mist);
  letter-spacing: 0;
  text-transform: none;
  line-height: 1.5;
  font-weight: 300;
  font-family: var(--font-body);
}
.consent a { color: var(--ochre); border-bottom: 1px solid transparent; }
.consent a:hover { border-bottom-color: var(--ochre); }

.submit {
  margin-top: 12px;
  align-self: flex-start;
  background: transparent;
  color: var(--bone);
  border: 1px solid var(--ochre);
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 18px 38px;
  cursor: pointer;
  transition: background 0.3s, color 0.3s;
}
.submit:hover {
  background: var(--ochre);
  color: var(--ink);
}

/* ============ MŰVEIM (bento galéria) ============ */
.gallery {
  background: transparent;
  border-top: 1px solid var(--line);
}
.gallery-head {
  margin-bottom: 64px;
  max-width: 700px;
}
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: 240px 240px 240px;
  grid-template-areas:
    "a a b c"
    "a a d e"
    "f f d e";
  gap: 16px;
}
.gallery-item.area-a { grid-area: a; }
.gallery-item.area-b { grid-area: b; }
.gallery-item.area-c { grid-area: c; }
.gallery-item.area-d { grid-area: d; }
.gallery-item.area-e { grid-area: e; }
.gallery-item.area-f { grid-area: f; }
/* Szabad kollázs-elrendezés (adminban beállított x/y/méret). A grid helyett
   abszolút pozícionált cellák egy rögzített arányú vásznon, hogy mobilon is
   arányosan kicsinyedjen. Az inline style adja a left/top/width/height %-ot. */
#muveim .gallery-grid.collage-free {
  display: block;
  position: relative;
  grid-template: none;
  height: auto;
  aspect-ratio: 5 / 3;
  gap: 0;
}
#muveim .gallery-grid.collage-free .gallery-item {
  position: absolute;
  margin: 0;
}
.gallery-item {
  position: relative;
  background: var(--walnut);
  border: 1px solid var(--line);
  overflow: hidden;
  cursor: pointer;
}
.gallery-item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), filter 0.5s;
  filter: saturate(0.92) contrast(1.02);
}
.gallery-item:hover img {
  transform: scale(1.05);
  filter: saturate(1.08) contrast(1.08);
}
.gallery-item::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 60%;
  background: linear-gradient(to top,
    rgba(0,0,0,0.85) 0%,
    rgba(0,0,0,0.45) 50%,
    transparent 100%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
  z-index: 1;
}
.gallery-item:hover::after { opacity: 1; }
.gallery-item-cap {
  position: absolute;
  left: 18px; bottom: 18px; right: 18px;
  font-size: 11px;
  letter-spacing: 0.4em;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--bone);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.35s, transform 0.35s;
  pointer-events: none;
  z-index: 2;
}
.gallery-item:hover .gallery-item-cap {
  opacity: 1;
  transform: translateY(0);
  color: var(--ochre);
}

/* ============ FOOTER ============ */
.footer {
  background: var(--walnut);
  border-top: 1px solid var(--line);
  padding: 40px 40px 22px;
}
.footer-inner {
  max-width: 1440px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 30px;
  align-items: center;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
}
.footer-brand .brand { font-size: 24px; margin: 0; display: inline-flex; }
.footer-tag {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.02em;
  color: var(--mist);
  font-weight: 300;
  line-height: 1.55;
  max-width: 420px;
  margin: 0;
}
.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  align-items: center;
  justify-content: flex-end;
}
.footer-links a {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--bone);
  font-weight: 400;
  transition: color 0.3s;
}
.footer-links a:hover { color: var(--ochre); }

.footer-bottom {
  max-width: 1440px;
  margin: 0 auto;
  padding-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 9px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--dust);
  font-weight: 400;
}
.footer-bottom a {
  color: var(--ochre);
  font-weight: 600;
  transition: color 0.3s, opacity 0.3s;
}
.footer-bottom a:hover { opacity: 0.78; }

/* ============ LOUPE (nagyító) ============ */
.loupe {
  position: absolute;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  border: 1px solid var(--ochre);
  box-shadow:
    0 14px 40px rgba(0,0,0,0.7),
    0 0 0 1px rgba(0,0,0,0.5) inset;
  background-repeat: no-repeat;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.85);
  transition: opacity 0.25s ease, transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 5;
  will-change: transform, opacity, background-position;
}
.loupe.active {
  opacity: 1;
  transform: scale(1);
}
@media (hover: none), (pointer: coarse) {
  .loupe { display: none !important; }
}

/* ============ SLOW REVEAL ============ */
.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition:
    opacity 1.05s cubic-bezier(0.22, 1, 0.36, 1),
    transform 1.05s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity, transform;
}
.reveal.is-visible {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .loupe { display: none !important; }
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px) {
  .product.feature, .product.tile { grid-column: span 6; }
}
@media (max-width: 700px) {
  .product.feature, .product.tile { grid-column: span 12; }
}
@media (max-width: 960px) {
  .nav { padding: 0 20px; }
  .nav-inner { gap: 12px; }
  .brand-logo { height: 44px; margin-right: 8px; }
  .brand { font-size: 18px; white-space: nowrap; }
  .lang-switch { padding: 5px 9px; letter-spacing: 0.08em; gap: 5px; font-size: 10px; flex-shrink: 0; }
  .nav-cart { margin-left: 0; flex-shrink: 0; }
  .nav-toggle { padding: 6px; flex-shrink: 0; }
  .nav-links {
    position: fixed;
    top: var(--nav-h); left: 0; right: 0;
    background: rgba(var(--smoke-rgb), 0.97);
    backdrop-filter: blur(14px);
    flex-direction: column;
    gap: 0;
    padding: 24px;
    border-bottom: 1px solid var(--line);
    transform: translateY(calc(-100% - var(--nav-h) - 8px));
    transition: transform 0.35s ease;
    will-change: transform;
  }
  .nav-links.open { transform: translateY(0); }
  .nav-links li { border-bottom: 1px solid var(--line); }
  .nav-links li:last-child { border-bottom: 0; }
  .nav-links a { display: block; padding: 18px 0; }
  .nav-toggle { display: block; }

  section { padding: 90px 24px; }

  /* HERO mobilon: nagy portré jobbra lebegtetve, a szöveg szorosan körbefolyik a bal oldalon */
  .hero {
    display: block;
    padding: calc(var(--nav-h) + 32px) 24px 52px;
    min-height: auto;
  }
  .hero::after { content: ""; display: block; clear: both; }
  .hero-text { padding-left: 0; }
  .hero-image {
    float: right;
    width: 56%;
    height: auto;
    max-width: none;
    display: block;
    margin: 4px -24px 10px 18px;   /* a jobb képernyő-szélig kifut, nagyobb */
  }
  .hero-image-frame { width: 100%; max-width: none; margin: 0; aspect-ratio: 3 / 4; transform: none; }
  .hero-name { font-size: clamp(22px, 5.6vw, 56px); white-space: normal; }
  .section-title { white-space: normal; }

  .product-grid { grid-template-columns: 1fr; gap: 30px; }
  .product.feature, .product.tile { grid-column: span 1; grid-row: span 1; }
  .product.tile { grid-template-columns: 1fr; }
  .products-head { flex-direction: column; align-items: flex-start; gap: 16px; }

  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 200px 200px 180px 180px 180px;
    grid-template-areas:
      "a a"
      "a a"
      "b c"
      "d e"
      "f f";
  }

  .contact {
    grid-template-columns: 1fr;
    gap: 50px;
    padding: 90px 24px;
  }
  .field-row { grid-template-columns: 1fr; }

  /* FOOTER mobilon: egységes, középre zárt; a jogi linkek egy sorban */
  .footer { padding: 44px 20px 26px; }
  .footer-inner {
    grid-template-columns: 1fr;
    gap: 22px;
    justify-items: center;
    text-align: center;
  }
  .footer-brand { flex-direction: column; gap: 12px; text-align: center; }
  .footer-brand-text { align-items: center; }
  .footer-logo { height: 72px; }
  .footer-tag { max-width: none; }
  .footer-links {
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px 16px;
    row-gap: 12px;
  }
  /* FB ikon külön, középre zárt sorba a jogi linkek fölé */
  .footer-social { flex-basis: 100%; justify-content: center; }
  .footer-social svg { width: 28px; height: 28px; }
  /* a négy jogi link egy sorban, középen, görgethető ha a hosszú HU címkék nem férnek */
  .footer-links a {
    font-size: 9px;
    letter-spacing: 0.06em;
    white-space: nowrap;
  }
  .footer-bottom { flex-direction: column; gap: 10px; text-align: center; justify-content: center; }
}

@media (max-width: 600px) {
  :root { --nav-h: 64px; }
  .nav { padding: 0 14px; }
  .nav-inner { gap: 9px; }
  .brand-logo { height: 36px; margin-right: 6px; }
  .brand { font-size: 15px; }
  .lang-switch { padding: 4px 7px; letter-spacing: 0.04em; gap: 4px; }
  .nav-cart svg { width: 22px; height: 22px; }
  .nav-toggle { padding: 5px; }
  .nav-toggle span { width: 22px; }

  .product-grid { gap: 28px; }

  /* keskeny telefon: a lebegtetett portré igazítása + tipográfia */
  .hero { padding: calc(var(--nav-h) + 24px) 16px 44px; }
  .hero-text { padding-top: 0; }
  .hero-image { width: 58%; margin: 2px -16px 10px 14px; }
  .hero-image-frame { aspect-ratio: 3 / 4; }
  .eyebrow { margin-bottom: 12px; font-size: 10px; letter-spacing: 0.28em; }
  .hero-name { font-size: clamp(20px, 6.6vw, 40px); margin-bottom: 10px; }
  .hero-role { margin-bottom: 18px; letter-spacing: 0.22em; font-size: 10px; }
  .hero-bio p { font-size: 13px; line-height: 1.6; margin-bottom: 12px; }
  .hero-bio p.opening { font-size: 15px; line-height: 1.5; margin-bottom: 16px; }
  .hero-motto { margin-top: 22px; padding-top: 18px; }
  .hero-motto-text { font-size: clamp(16px, 4.6vw, 24px); }
  .section-title { font-size: clamp(22px, 6.4vw, 40px); }
}

@media (max-width: 400px) {
  /* nagyon keskeny telefon: tovább szorítjuk a fejlécet, hogy maradjon rés a brand mellett */
  .nav { padding: 0 12px; }
  .nav-inner { gap: 6px; }
  .brand-logo { height: 30px; margin-right: 5px; }
  .brand { font-size: 13px; }
  .nav-cart { margin-left: 6px; }
  .nav-cart svg { width: 20px; height: 20px; }
  .lang-switch { padding: 3px 5px; gap: 3px; font-size: 9px; letter-spacing: 0; }
}

/* ============ I18N — EN/HU/DE SWITCH ============ */
html[lang="en"] .lang-hu, html[lang="en"] .lang-de { display: none !important; }
html[lang="hu"] .lang-en, html[lang="hu"] .lang-de { display: none !important; }
html[lang="de"] .lang-en, html[lang="de"] .lang-hu { display: none !important; }

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 1px solid var(--line);
  padding: 8px 14px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.28em;
  color: var(--bone);
  cursor: pointer;
}
.lang-switch .lang-opt {
  cursor: pointer;
  opacity: 0.45;
  transition: opacity 0.25s ease, color 0.25s ease;
  background: none;
  border: 0;
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  padding: 0;
}
.lang-switch .lang-opt:hover { opacity: 0.85; }
.lang-switch .lang-sep { opacity: 0.35; user-select: none; }
html[lang="en"] .lang-switch .lang-opt[data-set-lang="en"],
html[lang="hu"] .lang-switch .lang-opt[data-set-lang="hu"],
html[lang="de"] .lang-switch .lang-opt[data-set-lang="de"] {
  opacity: 1;
  color: var(--ochre);
}

/* ============ ANTRACIT + FEHÉR SZÖVEG OVERRIDE ============ */
.brand .art,
.eyebrow,
.section-title .accent,
.hero-name .accent,
.hero-signature,
.hero-motto-text .accent,
.product-num,
.product-badge,
.product-stock-count .available,
.product-cta,
.ar-modal-meta,
.gallery-item:hover .gallery-item-cap,
.footer-links a:hover,
.footer-bottom a:hover,
.nav-cta a,
.nav-cta a:hover,
.products-more:hover,
.ar-launch-btn,
.submit:hover {
  color: #FFFFFF !important;
}



/* ============ WEBSHOP + KOSÁR (SzabadosArt) ============ */
html.modal-open { overflow: hidden; }

/* Nav kosár-ikon */
.nav-cart {
  position: relative;
  display: inline-flex;
  align-items: center;
  color: var(--bone);
  margin-left: 4px;
  transition: color 0.25s ease;
}
.nav-cart:hover { color: var(--ochre); }
.nav-cart svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.cart-badge {
  position: absolute;
  top: -7px; right: -9px;
  min-width: 17px; height: 17px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--ochre);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  display: none;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* Vásárlás modal */
.buy-modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 24px; }
.buy-modal[hidden] { display: none; }
.buy-modal__overlay { position: absolute; inset: 0; background: rgba(10,10,12,0.72); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
.buy-modal__panel {
  position: relative;
  width: 100%; max-width: 760px;
  max-height: calc(100vh - 48px); overflow-y: auto;
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 38px 40px;
  text-align: center;
  box-shadow: 0 30px 80px rgba(0,0,0,0.55);
  animation: buyIn 0.28s cubic-bezier(0.22,1,0.36,1);
}
@keyframes buyIn { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.buy-modal__close { position: absolute; top: 12px; right: 14px; background: none; border: 0; color: var(--mist); font-size: 26px; line-height: 1; cursor: pointer; transition: color 0.2s; }
.buy-modal__close:hover { color: var(--bone); }
.buy-modal__img { width: 180px; height: 180px; object-fit: cover; border-radius: 12px; margin: 0 auto 18px; }
.buy-modal__title { font-family: var(--font-display); font-size: 26px; color: var(--paper); margin-bottom: 6px; }
.buy-modal__label { font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase; font-weight: 500; color: var(--mist); margin-bottom: 16px; }
.buy-modal__sizes { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 18px; }
.buy-size { flex: 1 1 calc(50% - 6px); }
.buy-size {
  flex: 1;
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px 10px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--bone);
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
  font-family: inherit;
}
.buy-size span { font-size: 13px; letter-spacing: 0.06em; }
.buy-size strong { font-family: var(--font-display); font-size: 20px; font-weight: 500; color: var(--paper); }
.buy-size__left { font-style: normal; font-size: 11px; letter-spacing: 0.04em; color: var(--ochre); opacity: 0.9; }
.buy-size:hover { border-color: var(--ochre); }
.buy-size.is-sel { border-color: var(--ochre); background: rgba(var(--ochre-rgb), 0.12); }
.buy-size.is-sold { opacity: 0.4; cursor: not-allowed; }
.buy-size.is-sold:hover { border-color: var(--line); }
.buy-size.is-sold strong { font-family: inherit; font-size: 13px; letter-spacing: 0.06em; }
.buy-modal__add {
  width: 100%;
  padding: 14px 18px;
  background: var(--ochre);
  color: #fff;
  border: 0; border-radius: 10px;
  font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  transition: opacity 0.2s, transform 0.15s;
}
.buy-modal__add:hover:not(:disabled) { transform: translateY(-1px); }
.buy-modal__add:disabled { opacity: 0.4; cursor: not-allowed; }

/* Toast */
.sa-toast {
  position: fixed; left: 50%; bottom: 32px; transform: translateX(-50%) translateY(20px);
  background: var(--ochre); color: #fff;
  padding: 12px 22px; border-radius: 999px;
  font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600;
  z-index: 300; opacity: 0; transition: opacity 0.3s, transform 0.3s;
  box-shadow: 0 12px 36px rgba(0,0,0,0.4);
}
.sa-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Webshop / kosár oldalak közös szekció */
.shop-section { padding: calc(var(--nav-h) + 56px) 40px 96px; max-width: 1280px; margin: 0 auto; }
.shop-head { margin-bottom: 40px; }
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
@media (max-width: 980px) { .shop-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .shop-grid { grid-template-columns: 1fr; } .shop-section { padding-left: 22px; padding-right: 22px; } }
.product-cta { cursor: pointer; font-family: inherit; }

/* Lapozó */
.shop-pager { display: flex; gap: 8px; justify-content: center; align-items: center; margin-top: 52px; }
.pg {
  min-width: 40px; height: 40px; padding: 0 12px;
  background: transparent; border: 1px solid var(--line); border-radius: 8px;
  color: var(--bone); cursor: pointer; font-family: var(--font-body); font-size: 14px;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.pg:hover:not(:disabled):not(.is-cur) { border-color: var(--ochre); color: var(--ochre); }
.pg.is-cur { background: var(--ochre); border-color: var(--ochre); color: #fff; }
.pg:disabled { opacity: 0.3; cursor: not-allowed; }

/* Kosár oldal */
.cart-empty { font-family: var(--font-display); font-size: 22px; color: var(--mist); padding: 40px 0; }
.cart-cont { display: inline-block; color: var(--ochre); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500; }
.cart-list { border-top: 1px solid var(--line); }
.cart-row { display: grid; grid-template-columns: 72px 1fr auto auto auto; gap: 18px; align-items: center; padding: 18px 0; border-bottom: 1px solid var(--line); }
.cart-row__img { width: 72px; height: 72px; object-fit: cover; border-radius: 8px; }
.cart-row__title { font-family: var(--font-display); font-size: 18px; color: var(--paper); }
.cart-row__size { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--mist); margin-top: 4px; }
.cart-row__qty { display: inline-flex; align-items: center; gap: 12px; }
.cart-row__qty button { width: 28px; height: 28px; border: 1px solid var(--line); background: transparent; color: var(--bone); border-radius: 7px; cursor: pointer; font-size: 15px; }
.cart-row__qty button:hover { border-color: var(--ochre); color: var(--ochre); }
.cart-row__qty span { min-width: 18px; text-align: center; font-variant-numeric: tabular-nums; }
.cart-row__price { font-family: var(--font-display); font-size: 18px; color: var(--paper); min-width: 92px; text-align: right; }
.cart-row__del { background: none; border: 0; color: var(--mist); font-size: 22px; line-height: 1; cursor: pointer; transition: color 0.2s; }
.cart-row__del:hover { color: #d05; }
.cart-foot { display: flex; justify-content: flex-end; align-items: center; gap: 28px; margin-top: 28px; flex-wrap: wrap; }
.cart-total { font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mist); }
.cart-total strong { font-family: var(--font-display); font-size: 26px; color: var(--paper); margin-left: 10px; letter-spacing: 0; }
.cart-checkout { padding: 16px 32px; background: var(--ochre); color: #fff; border: 0; border-radius: 10px; font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase; font-weight: 600; cursor: pointer; font-family: var(--font-body); transition: transform 0.15s; }
.cart-checkout:hover { transform: translateY(-1px); }
@media (max-width: 620px) {
  .cart-row { grid-template-columns: 56px 1fr auto; grid-template-areas: "img info del" "img qty price"; gap: 10px 14px; }
  .cart-row__img { grid-area: img; width: 56px; height: 56px; }
  .cart-row__info { grid-area: info; }
  .cart-row__qty { grid-area: qty; }
  .cart-row__price { grid-area: price; }
  .cart-row__del { grid-area: del; align-self: start; }
}

/* Webshop rács: a homepage .product.tile span-4 felülírása, hogy 3 férjen egy sorba */
.shop-grid .product { grid-column: auto; }

/* Vásárlás (Buy) gombok = WebShop nav-gomb stílusa: kitöltött okker, fehér szöveg, szögletes */
.product-cta {
  background: var(--ochre);
  border: 1px solid var(--ochre);
  border-radius: 0;
  padding: 12px 22px;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 600;
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
.product-cta:hover {
  background: transparent;
  border-color: var(--ochre);
}


/* Pénztár űrlap */
.checkout-form { margin-top: 8px; }
.cf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-row.cf-full { grid-column: 1 / -1; }
.cf-row label { display: block; font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--mist); margin-bottom: 6px; }
.cf-row input, .cf-row textarea { width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: 8px; background: var(--ink); color: var(--bone); font: inherit; font-size: 14px; }
.cf-row input:focus, .cf-row textarea:focus { outline: none; border-color: var(--ochre); }
.cf-row textarea { min-height: 70px; resize: vertical; }
/* checkout — szekciók, ország-select, vám-jegyzet, összesítő */
.cf-section { border: 1px solid var(--line); border-radius: 12px; padding: 18px 18px 20px; margin-bottom: 16px; }
.cf-section-title { font-family: var(--font-display); font-size: 18px; color: var(--paper); margin-bottom: 14px; }
.cf-row select { width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: 8px; background: var(--ink); color: var(--bone); font: inherit; font-size: 14px; }
.cf-row select:focus { outline: none; border-color: var(--ochre); }
.cf-customs { margin-top: 7px; font-size: 12px; line-height: 1.4; color: var(--ochre); opacity: 0.9; }
.cf-check { display: flex; align-items: flex-start; gap: 10px; margin: 0 2px 16px; cursor: pointer; font-size: 13px; color: var(--bone); }
.cf-check input { width: 17px; height: 17px; margin-top: 1px; accent-color: var(--ochre); flex: none; }
.cf-foot { align-items: flex-end; }
.cf-totals { margin-right: auto; min-width: 240px; }
.cf-tot-row { display: flex; justify-content: space-between; gap: 24px; font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mist); padding: 3px 0; }
.cf-tot-row strong { color: var(--bone); letter-spacing: 0; font-weight: 600; }
.cf-tot-grand { margin-top: 6px; padding-top: 8px; border-top: 1px solid var(--line); font-size: 14px; }
.cf-tot-grand strong { font-family: var(--font-display); font-size: 24px; color: var(--paper); }
.cf-prepaid { margin-top: 10px; font-size: 12px; color: var(--mist); letter-spacing: 0.04em; }
@media (max-width: 620px) { .cf-grid { grid-template-columns: 1fr; } .cf-totals { min-width: 0; width: 100%; } }

/* lebegő „Tovább a kosárhoz" gomb — csak ha van tétel a kosárban (JS kapcsolja a .is-show-ot) */
.cart-fab {
  position: fixed; right: 22px; bottom: 22px; z-index: 180;
  display: none; align-items: center; gap: 10px;
  padding: 13px 20px;
  background: var(--ochre); color: #fff;
  border-radius: 999px;
  font-size: 13px; letter-spacing: 0.04em; font-weight: 600; font-family: var(--font-body);
  box-shadow: 0 12px 30px rgba(0,0,0,0.4);
  transform: translateY(14px); opacity: 0;
  transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), opacity 0.25s, box-shadow 0.2s;
}
.cart-fab.is-show { display: flex; transform: none; opacity: 1; }
.cart-fab:hover { box-shadow: 0 16px 38px rgba(0,0,0,0.5); }
.cart-fab svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; flex: none; }
.cart-fab__count {
  min-width: 22px; height: 22px; padding: 0 6px;
  display: inline-flex; align-items: center; justify-content: center;
  background: #fff; color: var(--ochre);
  border-radius: 999px; font-size: 12px; font-weight: 700;
}
@media (max-width: 620px) { .cart-fab { right: 14px; bottom: 14px; padding: 12px 18px; } }
/* mobilon, ha van tétel a kosárban, a felső nav-ikon helyett a jobb-lenti lebegő gomb visz a kosárhoz (kis telefonon ne csússzon össze a nav) */
@media (max-width: 700px) { body.cart-has-items .nav-cart { display: none; } }

/* Hero arány laptop-tartományban (15"): kisebb cím, nagyobb kép */
@media (min-width: 961px) and (max-width: 1600px) {
  .hero { grid-template-columns: 3.2fr 9fr; gap: 36px; }
  .hero-text { padding-left: clamp(0px, 2.4vw, 56px); }
  .hero-image-frame { transform: translateX(-40px) scale(1.18); }
}

/* ============================================================
   KERET-VÁLASZTÓ + falra akasztott megjelenítés (Legfrissebb művek)
   ============================================================ */

/* --- Kapcsoló-sáv --- */
.frame-toolbar{
  display:flex; flex-wrap:wrap; align-items:center; gap:20px 42px;
  margin:0 0 36px; padding:18px 24px;
  background:var(--walnut); border:1px solid var(--line);
}
.frame-tool-group{ display:flex; align-items:center; gap:16px; }
.frame-tool-label{
  font-size:10px; letter-spacing:.28em; text-transform:uppercase;
  color:rgba(255,255,255,.55); font-weight:600;
}
.frame-types{ display:flex; gap:8px; }
.frame-type{
  font-family:inherit; cursor:pointer; font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; font-weight:600; padding:9px 17px;
  background:transparent; color:rgba(255,255,255,.78);
  border:1px solid var(--line); transition:background .25s,border-color .25s,color .25s;
}
.frame-type:hover{ border-color:rgba(var(--ochre-rgb),.6); color:#fff; }
.frame-type.is-active{ background:var(--ochre); border-color:var(--ochre); color:#fff; }
.frame-colors{ display:flex; gap:11px; }
.frame-colors[hidden]{ display:none; }
.frame-color{
  width:27px; height:27px; border-radius:50%; cursor:pointer; padding:0;
  border:2px solid rgba(255,255,255,.22);
  transition:transform .2s,border-color .2s,box-shadow .2s;
}
.frame-color:hover{ transform:scale(1.12); }
.frame-color.is-active{ border-color:#fff; box-shadow:0 0 0 2px var(--ochre); }
.frame-color[data-swatch="black"]{     background:#161616; }
.frame-color[data-swatch="white"]{     background:#f6f5f2; }
.frame-color[data-swatch="darkbrown"]{ background:#3a2417; }
.frame-color[data-swatch="gold"]{   background:linear-gradient(135deg,#f7e9b0,#c9a227 60%,#8a6d1f); }
.frame-color[data-swatch="silver"]{ background:linear-gradient(135deg,#fbfbfd,#b8bcc2 60%,#6f757d); }
.frame-color[data-swatch="wood"]{   background:linear-gradient(135deg,#c69a6b,#8a5a2b 60%,#5c3a17); }

/* --- A kép úgy, mintha fehér falon lógna --- */
.product-grid .product-image{
  background:radial-gradient(125% 90% at 50% 2%, #ffffff 0%, #f2f0ea 66%, #e7e3db 100%);
  display:flex; align-items:center; justify-content:center;
}
.product-grid .art-frame{
  width:70%; aspect-ratio:1/1; box-sizing:border-box;
  padding:var(--fw,16px);
  background:#191919;
  --hang:0 30px 46px -16px rgba(35,25,15,.55), 0 11px 22px rgba(35,25,15,.30);
  box-shadow:var(--molding, inset 0 0 0 1px rgba(0,0,0,.55)), var(--hang);
  transition:padding .3s ease, background .3s ease, box-shadow .3s ease;
}
.product.feature .art-frame{ width:62%; }
.product-grid .art-canvas{
  width:100%; height:100%; box-sizing:border-box;
  position:relative; overflow:hidden;
  padding:var(--mat,0%); background:var(--mat-col,#f4f3ef);
  box-shadow:var(--mat-bevel, none);
}
.product-grid .art-canvas.loupe-active img { opacity:.55; }
.product-grid .art-canvas img{
  width:100%; height:100%; object-fit:cover; display:block;
  box-shadow:var(--sight, inset 0 0 0 1px rgba(0,0,0,.22), inset 0 3px 10px rgba(0,0,0,.32));
}

/* ============================================================
   MODERN: vékony, lapos, MATT léc + nagy fehér paszpartu (galéria-stílus)
   valódi modern gallery-frame: sík felület, éles élek, matt, fény nélkül
   ============================================================ */
.product-grid[data-frame-type="modern"] .art-frame{ --fw:10.5px; }
.product-grid[data-frame-type="modern"] .art-canvas{
  --mat:10%;
  --mat-bevel:inset 0 0 0 1px rgba(0,0,0,.05);
}
.product-grid[data-frame-type="modern"] .art-canvas img{
  --sight:inset 0 0 0 1px rgba(0,0,0,.20), inset 0 2px 7px rgba(0,0,0,.16);
}
.product-grid[data-frame-type="modern"][data-frame-color="black"] .art-frame{
  background:#191919;
  --molding:
    inset 0 0 0 1px rgba(0,0,0,.7),
    inset 1.5px 1.5px 1px rgba(255,255,255,.05),
    inset -1.5px -1.5px 2px rgba(0,0,0,.55);
}
.product-grid[data-frame-type="modern"][data-frame-color="silver"] .art-frame{
  background:linear-gradient(135deg,#cfd2d6,#bcc0c5 55%,#a4a9af);
  --molding:
    inset 0 0 0 1px rgba(0,0,0,.22),
    inset 1.5px 1.5px 1px rgba(255,255,255,.7),
    inset -1.5px -1.5px 2px rgba(0,0,0,.2);
}
.product-grid[data-frame-type="modern"][data-frame-color="silver"] .art-canvas{ --mat-col:#f4f4f5; }
.product-grid[data-frame-type="modern"][data-frame-color="darkbrown"] .art-frame{
  background:#2c1d12;
  --molding:
    inset 0 0 0 1px rgba(0,0,0,.6),
    inset 1.5px 1.5px 1px rgba(170,120,82,.18),
    inset -1.5px -1.5px 2px rgba(0,0,0,.5);
}

/* ============================================================
   KLASSZIKUS: széles, díszes léc, paszpartu NÉLKÜL (a kép a belső
   díszléchez ér), domború fémes profil — koncentrikus fény-árnyék
   sávok adják a faragott keresztmetszetet, a fémes csillogást a
   sávok alatti gradiens-alap.
   ============================================================ */
.product-grid[data-frame-type="classic"] .art-frame{ --fw:24px; }
.product-grid[data-frame-type="classic"] .art-canvas{ --mat:0%; }
.product-grid[data-frame-type="classic"] .art-canvas img{
  --sight:inset 0 0 0 2px var(--liner,#9c7820), inset 0 0 0 4px rgba(0,0,0,.5), inset 0 3px 12px rgba(0,0,0,.4);
}
.product-grid[data-frame-type="classic"][data-frame-color="gold"] .art-frame{
  --liner:#9c7820;
  background:linear-gradient(135deg,#efd98c 0%,#caa53c 34%,#9a7720 66%,#dcbb5c 100%);
  --molding:
    inset 0 0 0 1px rgba(70,48,8,.9),
    inset 0 0 0 3px rgba(255,246,200,.55),
    inset 0 0 0 5px rgba(120,88,20,.5),
    inset 0 0 0 14px rgba(92,66,14,.5),
    inset 0 0 0 17px rgba(255,243,190,.55),
    inset 0 3px 6px rgba(255,250,225,.4),
    inset 0 -5px 10px rgba(40,26,4,.5);
}
.product-grid[data-frame-type="classic"][data-frame-color="silver"] .art-frame{
  --liner:#888f99;
  background:linear-gradient(135deg,#f2f4f7 0%,#bcc2ca 34%,#888f99 66%,#e2e6eb 100%);
  --molding:
    inset 0 0 0 1px rgba(55,60,70,.85),
    inset 0 0 0 3px rgba(255,255,255,.6),
    inset 0 0 0 5px rgba(120,128,138,.5),
    inset 0 0 0 14px rgba(78,85,96,.5),
    inset 0 0 0 17px rgba(248,250,253,.6),
    inset 0 3px 6px rgba(255,255,255,.45),
    inset 0 -5px 10px rgba(45,50,60,.45);
}
.product-grid[data-frame-type="classic"][data-frame-color="wood"] .art-frame{
  --liner:#4d2f15;
  background:linear-gradient(135deg,#9c6b3a 0%,#6e461f 36%,#4d2f15 66%,#85562b 100%);
  --molding:
    inset 0 0 0 1px rgba(20,10,3,.9),
    inset 0 0 0 3px rgba(225,185,135,.38),
    inset 0 0 0 5px rgba(90,58,28,.5),
    inset 0 0 0 14px rgba(40,24,10,.55),
    inset 0 0 0 17px rgba(210,168,118,.4),
    inset 0 3px 6px rgba(235,200,150,.3),
    inset 0 -5px 10px rgba(22,12,4,.55);
}

/* --- mobil --- */
@media (max-width:760px){
  .frame-toolbar{ gap:16px 28px; padding:16px 18px; }
  .product-grid .art-frame,
  .product.feature .art-frame{ width:66%; }
}

/* ============================================================
   HÁTTÉR-VÁLASZTÓ — opcionális fal-jelenetek a festmények mögé
   ============================================================ */
.frame-walls{ display:flex; gap:9px; flex-wrap:wrap; }
.frame-wall{
  width:46px; height:31px; border-radius:5px; cursor:pointer; padding:0;
  background-size:cover; background-position:center 30%; background-color:#f0efeb;
  border:2px solid rgba(255,255,255,.22);
  transition:transform .2s, border-color .2s, box-shadow .2s;
}
.frame-wall:hover{ transform:scale(1.08); }
.frame-wall.is-active{ border-color:#fff; box-shadow:0 0 0 2px var(--ochre); }
.frame-wall[data-wall="white"]{ background-image:linear-gradient(135deg,#ffffff,#e7e4dd); }

/* a 3 tile együtt egy folytonos falat ad ki: bal / közép / jobb harmad */
.product-grid:not([data-wall="white"]) .product-image{
  background-repeat:no-repeat;
  background-size:auto 132%;
  background-position:50% 26%;
}
.product-grid:not([data-wall="white"]) .product:nth-child(1) .product-image{ background-position-x:6%; }
.product-grid:not([data-wall="white"]) .product:nth-child(2) .product-image{ background-position-x:50%; }
.product-grid:not([data-wall="white"]) .product:nth-child(3) .product-image{ background-position-x:94%; }

.product-grid[data-wall="wall1"] .product-image{ background-image:url('/wall1.jpg'); }
.product-grid[data-wall="wall2"] .product-image{ background-image:url('/wall2.jpg'); }
.product-grid[data-wall="wall3"] .product-image{ background-image:url('/wall3.jpg'); }
.product-grid[data-wall="wall4"] .product-image{ background-image:url('/wall4.jpg'); }
.product-grid[data-wall="wall5"] .product-image{ background-image:url('/wall5.jpg'); }
.product-grid[data-wall="wall6"] .product-image{ background-image:url('/wall6.jpg'); }

/* mobilon 1 oszlop: minden tile a fal közepét mutassa */
@media (max-width:760px){
  .product-grid:not([data-wall="white"]) .product:nth-child(1) .product-image,
  .product-grid:not([data-wall="white"]) .product:nth-child(2) .product-image,
  .product-grid:not([data-wall="white"]) .product:nth-child(3) .product-image{ background-position-x:50%; }
  .product-grid:not([data-wall="white"]) .product-image{ background-size:cover; }
}


/* ================= PNG fotó-keretek (keretek.zip) 2026-05-31 ================= */
.product-grid .art-frame{
  width:74%; aspect-ratio:1/1; margin:0 auto; box-sizing:border-box;
  background:none !important; padding:0 !important;
  background-image:var(--frame-img) !important;
  background-size:100% 100% !important; background-repeat:no-repeat !important;
  box-shadow:none !important;
  filter:drop-shadow(0 16px 24px rgba(35,25,15,.34));
  position:relative; overflow:visible; transition:filter .3s ease;
}
.product.feature .art-frame{ width:66%; }
.product-grid .art-canvas{
  position:absolute; top:50%; left:50%;
  width:calc(100% - 2*var(--in,8%)); height:calc(100% - 2*var(--in,8%));
  transform:translate(-50%,-50%);
  padding:0 !important; background:none !important;
  box-shadow:none !important; overflow:hidden; border-radius:1px;
}
.product-grid .art-canvas img{
  width:100%; height:100%; object-fit:cover; display:block; box-shadow:none !important;
}
.product-grid[data-frame-type="modern"][data-frame-color="black"]     .art-frame{ --frame-img:url('/keretek/fekete_keret.png'); }
.product-grid[data-frame-type="modern"][data-frame-color="black"]     .art-canvas{ --in:13%; }
.product-grid[data-frame-type="modern"][data-frame-color="silver"]    .art-frame{ --frame-img:url('/keretek/feher_keret.png'); }
.product-grid[data-frame-type="modern"][data-frame-color="silver"]    .art-canvas{ --in:13%; }
.product-grid[data-frame-type="modern"][data-frame-color="darkbrown"] .art-frame{ --frame-img:url('/keretek/barna_keret.png'); }
.product-grid[data-frame-type="modern"][data-frame-color="darkbrown"] .art-canvas{ --in:13%; }
.product-grid[data-frame-type="classic"][data-frame-color="gold"]     .art-frame{ --frame-img:url('/keretek/arany_keret.png'); }
.product-grid[data-frame-type="classic"][data-frame-color="gold"]     .art-canvas{ --in:15.4%; }
.product-grid[data-frame-type="classic"][data-frame-color="silver"]   .art-frame{ --frame-img:url('/keretek/feher_keret.png'); }
.product-grid[data-frame-type="classic"][data-frame-color="silver"]   .art-canvas{ --in:13%; }
.product-grid[data-frame-type="classic"][data-frame-color="wood"]     .art-frame{ --frame-img:url('/keretek/fa_barna_keret.png'); }
.product-grid[data-frame-type="classic"][data-frame-color="wood"]     .art-canvas{ --in:16.1%; }
/* ================= /PNG fotó-keretek ================= */



/* loupe a teljes kereten lebeg, nem szorul a nyílásba */
.product-grid .art-frame{ overflow:visible !important; }
.product-grid .art-frame.loupe-active .art-canvas img{ opacity:.55; }
.product-grid .art-frame .loupe{ z-index:6; }

/* vékony fehér szegély a kép körül, középen a keretben */
.product-grid .art-canvas{ background:#fff !important; padding:2.4% !important; box-sizing:border-box; }
.product-grid .art-canvas img{ width:100%; height:100%; object-fit:cover; display:block; }


/* ====== per-kép keret + háttér (state a .product-on) ====== */
.product[data-frame-type="modern"][data-frame-color="black"]     { --frame-img:url('/keretek/fekete_keret.png'); }
.product[data-frame-type="modern"][data-frame-color="silver"]    { --frame-img:url('/keretek/feher_keret.png'); }
.product[data-frame-type="modern"][data-frame-color="darkbrown"] { --frame-img:url('/keretek/barna_keret.png'); }
.product[data-frame-type="classic"][data-frame-color="gold"]     { --frame-img:url('/keretek/arany_keret.png'); }
.product[data-frame-type="classic"][data-frame-color="silver"]   { --frame-img:url('/keretek/feher_keret.png'); }
.product[data-frame-type="classic"][data-frame-color="wood"]     { --frame-img:url('/keretek/fa_barna_keret.png'); }
.product[data-frame-type="modern"][data-frame-color="black"]     .art-canvas{ --in:13%; }
.product[data-frame-type="modern"][data-frame-color="silver"]    .art-canvas{ --in:13%; }
.product[data-frame-type="modern"][data-frame-color="darkbrown"] .art-canvas{ --in:13%; }
.product[data-frame-type="classic"][data-frame-color="gold"]     .art-canvas{ --in:15.4%; }
.product[data-frame-type="classic"][data-frame-color="silver"]   .art-canvas{ --in:13%; }
.product[data-frame-type="classic"][data-frame-color="wood"]     .art-canvas{ --in:16.1%; }
.product[data-wall="wall1"] .product-image{ background-image:url('/wall1.jpg') !important; }
.product[data-wall="wall2"] .product-image{ background-image:url('/wall2.jpg') !important; }
.product[data-wall="wall3"] .product-image{ background-image:url('/wall3.jpg') !important; }
.product[data-wall="wall4"] .product-image{ background-image:url('/wall4.jpg') !important; }
.product[data-wall="wall5"] .product-image{ background-image:url('/wall5.jpg') !important; }
.product[data-wall="wall6"] .product-image{ background-image:url('/wall6.jpg') !important; }
.product-grid .product-image{ background-size:cover !important; background-position:center !important; cursor:pointer; }
.product.selected .art-frame{ outline:3px solid var(--ochre,#c9a227); outline-offset:8px; }
.frame-tool-sel{ width:100%; font-size:13px; opacity:.85; margin-bottom:4px; }
.frame-tool-sel strong{ color:var(--ochre,#c9a227); }

/* ============================================================
   2026-06-01: háttér-választó kikapcsolva → minden kép fehér falon,
   keretválasztó a képre helyezve (kis felirat + kör-swatch gombok)
   ============================================================ */
/* a régi felső toolbar és a fal-választó teljesen elrejtve */
#frameToolbar, .frame-toolbar, .frame-tool-wall, .frame-walls{ display:none !important; }

/* minden festmény mögött egyenletes, finoman világító fehér fal */
.product-grid .product-image{
  background:radial-gradient(125% 92% at 50% 0%, #ffffff 0%, #f5f3ed 60%, #ece8df 100%) !important;
  background-size:auto !important;
  background-position:center !important;
}

/* --- képre helyezett keretválasztó --- */
.frame-picker{
  position:absolute; left:50%; bottom:14px; transform:translateX(-50%);
  z-index:5; display:flex; flex-direction:column; align-items:center; gap:7px;
  padding:9px 14px 10px; border-radius:16px;
  background:rgba(20,18,16,.42);
  backdrop-filter:blur(7px); -webkit-backdrop-filter:blur(7px);
  box-shadow:0 6px 20px rgba(20,15,8,.22);
  opacity:.92; transition:opacity .25s ease, transform .25s ease;
}
.product-image:hover .frame-picker,
.frame-picker:focus-within{ opacity:1; }
.frame-picker-label{
  font-size:9px; letter-spacing:.26em; text-transform:uppercase;
  font-weight:600; color:#fff; opacity:.92;
}
.frame-picker-opts{ display:flex; gap:8px; }
.fp-opt{
  width:22px; height:22px; border-radius:50%; padding:0; cursor:pointer;
  border:2px solid rgba(255,255,255,.55); box-sizing:border-box;
  box-shadow:0 1px 3px rgba(0,0,0,.35); background-size:cover;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.fp-opt:hover{ transform:scale(1.18); }
.fp-opt.is-active{
  border-color:#fff;
  box-shadow:0 0 0 2px var(--ochre,#c9a227), 0 1px 4px rgba(0,0,0,.4);
  transform:scale(1.12);
}
.fp-opt[data-swatch="black"]{     background:#161616; }
.fp-opt[data-swatch="darkbrown"]{ background:#3a2417; }
.fp-opt[data-swatch="gold"]{   background:linear-gradient(135deg,#f7e9b0,#c9a227 60%,#8a6d1f); }
.fp-opt[data-swatch="silver"]{ background:linear-gradient(135deg,#fbfbfd,#b8bcc2 60%,#6f757d); }
.fp-opt[data-swatch="wood"]{   background:linear-gradient(135deg,#c69a6b,#8a5a2b 60%,#5c3a17); }

@media (max-width:760px){
  .frame-picker{ opacity:1; bottom:10px; padding:8px 12px; }
  .fp-opt{ width:24px; height:24px; }
}

/* ============================================================
   2026-06-01: a FESTMÉNY (a kép) mérete keretváltáskor sem változik.
   A belső nyílás minden keretnél azonos (~54% kártyaszélesség), a
   keret vastagsága szerint a teljes keret-méretet igazítjuk, így a
   legvastagabb (klasszikus) keret is teljesen látszik. A festmény
   mindig középre van rögzítve, a keret köré nő.
   nyílás-faktor = 1 − 2·(--in):  modern .85/.88, klasszikus .60–.65
   ============================================================ */
.product[data-frame-type="modern"][data-frame-color="black"]     .art-frame{ width:82.5% !important; }
.product[data-frame-type="modern"][data-frame-color="silver"]    .art-frame{ width:79%   !important; }
.product[data-frame-type="modern"][data-frame-color="darkbrown"] .art-frame{ width:82.5% !important; }
.product[data-frame-type="classic"][data-frame-color="gold"]     .art-frame{ width:87%   !important; }
.product[data-frame-type="classic"][data-frame-color="silver"]   .art-frame{ width:83%   !important; }
.product[data-frame-type="classic"][data-frame-color="wood"]     .art-frame{ width:90%   !important; }

/* a keret árnyéka beleférjen a képkeretbe (nincs levágás) */
.product-grid .art-frame{ filter:drop-shadow(0 11px 17px rgba(35,25,15,.30)) !important; }

/* reszponzív: keskenyebb kártyákon arányosan kisebb (a nyílás-arány marad) */
@media (max-width:760px){
  .product[data-frame-type="modern"][data-frame-color="black"]     .art-frame{ width:73%  !important; }
  .product[data-frame-type="modern"][data-frame-color="silver"]    .art-frame{ width:70%  !important; }
  .product[data-frame-type="modern"][data-frame-color="darkbrown"] .art-frame{ width:73%  !important; }
  .product[data-frame-type="classic"][data-frame-color="gold"]     .art-frame{ width:77%  !important; }
  .product[data-frame-type="classic"][data-frame-color="silver"]   .art-frame{ width:73%  !important; }
  .product[data-frame-type="classic"][data-frame-color="wood"]     .art-frame{ width:80%  !important; }
}

/* ============================================================
   2026-06-01: alapból KERET NÉLKÜL; "Megnézem keretben" kapcsoló.
   ============================================================ */
.fp-toggle{
  display:inline-flex; align-items:center; gap:7px;
  background:none; border:0; color:#fff; cursor:pointer;
  font-size:11px; font-weight:600; letter-spacing:.02em; padding:2px 4px; line-height:1;
}
.fp-toggle svg{ width:15px; height:15px; fill:none; stroke:currentColor; stroke-width:1.6; }
.fp-framed{ display:none; flex-direction:column; align-items:center; gap:7px; }
.product:not(.no-frame) .fp-toggle{ display:none; }
.product:not(.no-frame) .fp-framed{ display:flex; }
.fp-remove{
  background:none; border:0; color:#fff; opacity:.72; cursor:pointer;
  font-size:9px; letter-spacing:.18em; text-transform:uppercase; padding:0;
}
.fp-remove:hover{ opacity:1; text-decoration:underline; }

/* keret nélküli állapot: csak a festmény a fehér falon, enyhe vetett árnyékkal.
   A [data-frame-color] biztosítja az azonos specificitást a keretes szabályokkal,
   és mivel ez később jön a fájlban, no-frame esetén ez nyer. */
.product.no-frame[data-frame-color] .art-frame{
  width:86% !important; background:none !important;
  filter:drop-shadow(0 16px 26px rgba(20,15,8,.30)) !important;
}
.product.no-frame[data-frame-color] .art-canvas{
  --in:0% !important; padding:0 !important; background:none !important;
}
@media (max-width:760px){
  .product.no-frame[data-frame-color] .art-frame{ width:82% !important; }
}

/* ============================================================
   2026-06-01: "Nézd meg a falon" gomb + 2D enteriőr modál
   ============================================================ */
.product-wall{
  display:flex; align-items:center; justify-content:center; gap:9px;
  width:100%; margin-top:14px; padding:13px 16px;
  background:none; border:1px solid var(--line); border-radius:999px;
  color:var(--bone); cursor:pointer;
  font:inherit; font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  transition:border-color .2s ease, color .2s ease, background .2s ease;
}
.product-wall:hover{ border-color:var(--ochre); color:var(--ochre); }
.product-wall svg{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.5; stroke-linejoin:round; stroke-linecap:round; flex:none; }

/* ---- modál ---- */
.wall-view{ position:fixed; inset:0; z-index:1000; display:none; }
.wall-view.open{ display:block; }
.wv-backdrop{ position:absolute; inset:0; background:rgba(10,9,8,.72); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px); }
.wv-panel{
  position:absolute; inset:0; margin:auto;
  width:min(1040px,94vw); height:auto; max-height:94vh;
  display:flex; flex-direction:column;
  background:var(--walnut); border:1px solid var(--line); border-radius:0; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.wv-scroll{ flex:1 1 auto; min-height:0; overflow-y:auto; display:flex; flex-direction:column; }
.wv-close{
  position:absolute; top:12px; right:12px; z-index:5;
  width:40px; height:40px; border-radius:50%; cursor:pointer;
  background:rgba(20,18,16,.55); border:1px solid rgba(255,255,255,.18); color:#fff;
  display:flex; align-items:center; justify-content:center;
}
.wv-close svg{ width:20px; height:20px; fill:none; stroke:currentColor; stroke-width:2; }
.wv-close:hover{ background:var(--ochre); border-color:var(--ochre); }

.wv-stage{
  position:relative; flex:none; overflow:hidden; background:#15120f;
}
.wv-bg{ width:100%; height:auto; display:block; }
.wv-art{
  position:absolute; aspect-ratio:1/1; transform:translate(-50%,-50%);
  transition:left .25s ease, top .25s ease, width .25s ease;
}
.wv-art:not(.framed){ filter:drop-shadow(0 14px 26px rgba(0,0,0,.5)); }
.wv-art.framed{
  background-image:var(--frame-img); background-size:100% 100%; background-repeat:no-repeat;
  filter:drop-shadow(0 20px 34px rgba(0,0,0,.55));
}
.wv-canvas{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:calc(100% - 2*var(--in,0%)); height:calc(100% - 2*var(--in,0%));
  overflow:hidden; border-radius:1px; box-shadow:0 0 0 1px rgba(0,0,0,.12);
}
.wv-art:not(.framed) .wv-canvas{ box-shadow:0 0 0 1px rgba(0,0,0,.18); }
.wv-canvas img{ width:100%; height:100%; object-fit:cover; display:block; }
.wv-art[data-frame="fekete"]{   --frame-img:url('/keretek/fekete_keret.png');   --in:13%; }
.wv-art[data-frame="feher"]{    --frame-img:url('/keretek/feher_keret.png');    --in:13%; }
.wv-art[data-frame="barna"]{    --frame-img:url('/keretek/barna_keret.png');    --in:13%; }
.wv-art[data-frame="arany"]{    --frame-img:url('/keretek/arany_keret.png');    --in:15.4%; }
.wv-art[data-frame="fa_barna"]{ --frame-img:url('/keretek/fa_barna_keret.png'); --in:16.1%; }
.wv-art[data-frame="none"]{ --in:0%; }

/* világítás overlay */
.wv-light{ position:absolute; inset:0; pointer-events:none; transition:background .45s ease, opacity .45s ease; mix-blend-mode:soft-light; }
.wv-stage[data-light="day"]  .wv-light{ background:linear-gradient(180deg, rgba(220,235,255,.18) 0%, rgba(255,255,255,.04) 40%, rgba(0,0,0,.06) 100%); }
.wv-stage[data-light="spot"] .wv-light{
  mix-blend-mode:normal;
  background:radial-gradient(circle at var(--lx,50%) var(--ly,42%),
    rgba(255,238,205,.34) 0%, rgba(255,232,190,.10) 20%, rgba(8,6,4,.42) 58%, rgba(4,3,2,.66) 100%);
}

/* vezérlők */
.wv-controls{ flex:none; padding:16px 20px 20px; background:var(--walnut); border-top:1px solid var(--line); }
.wv-title{ font-family:'Cardo',serif; font-size:20px; margin-bottom:12px; color:var(--bone); }
.wv-row{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:12px; }
.wv-label{ flex:0 0 92px; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted,#9a968f); opacity:.85; }
.wv-bgs{ display:flex; gap:8px; flex-wrap:wrap; }
.wv-bg-opt{ width:54px; height:36px; border-radius:6px; cursor:pointer; padding:0;
  background-size:cover; background-position:center; border:2px solid rgba(255,255,255,.2); transition:transform .18s, border-color .18s; }
.wv-bg-opt:hover{ transform:scale(1.06); }
.wv-bg-opt.is-active{ border-color:var(--ochre); box-shadow:0 0 0 2px rgba(177,74,42,.4); }
.wv-frames{ display:flex; gap:9px; align-items:center; }
.wv-frame-opt{ cursor:pointer; font:inherit; }
.wv-frame-opt:not(.wv-sw){ padding:7px 14px; border-radius:999px; background:none; border:1px solid var(--line); color:var(--bone); font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; }
.wv-frame-opt:not(.wv-sw).is-active{ background:var(--ochre); border-color:var(--ochre); color:#fff; }
.wv-sw{ width:26px; height:26px; border-radius:50%; padding:0; border:2px solid rgba(255,255,255,.5); background-size:cover; box-shadow:0 1px 3px rgba(0,0,0,.4); transition:transform .18s, box-shadow .18s; }
.wv-sw:hover{ transform:scale(1.12); }
.wv-sw.is-active{ border-color:#fff; box-shadow:0 0 0 2px var(--ochre); }
.wv-sw[data-swatch="black"]{ background:#161616; }
.wv-sw[data-swatch="white"]{ background:#f0eee9; }
.wv-sw[data-swatch="brown"]{ background:#5c3a1c; }
.wv-sw[data-swatch="gold"]{ background:linear-gradient(135deg,#f7e9b0,#c9a227 60%,#8a6d1f); }
.wv-sw[data-swatch="wood"]{ background:linear-gradient(135deg,#c69a6b,#8a5a2b 60%,#5c3a17); }
.wv-sw[data-swatch="darkbrown"]{ background:#3a2417; }
.wv-sw[data-swatch="silver"]{ background:linear-gradient(135deg,#fbfbfd,#b8bcc2 60%,#6f757d); }
.wv-lights{ display:flex; gap:9px; }
.wv-light-opt{ padding:7px 14px; border-radius:999px; cursor:pointer; background:none; border:1px solid var(--line); color:var(--bone); font:inherit; font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; }
.wv-light-opt.is-active{ background:var(--ochre); border-color:var(--ochre); color:#fff; }
.wv-sizes{ display:flex; gap:8px; flex-wrap:wrap; }
.wv-size-opt{ padding:7px 13px; border-radius:999px; cursor:pointer; background:none; border:1px solid var(--line); color:var(--bone); font:inherit; font-size:11px; font-weight:600; letter-spacing:.06em; }
.wv-size-opt.is-active{ background:var(--ochre); border-color:var(--ochre); color:#fff; }
.wv-foot{ margin-bottom:0; margin-top:4px; }
.wv-ar{ display:inline-flex; align-items:center; gap:9px; padding:11px 20px; border-radius:999px; cursor:pointer;
  background:none; border:1px solid var(--line); color:var(--bone); font:inherit; font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; }
.wv-ar:hover{ border-color:var(--ochre); color:var(--ochre); }
.wv-ar svg{ width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.5; }
.wv-ar.is-disabled{ opacity:.45; cursor:not-allowed; }
.wv-ar.is-disabled:hover{ border-color:var(--line); color:var(--bone); }
.wv-ar-hint{ font-size:11px; color:#9a968f; opacity:.9; align-self:center; }
@media (pointer:coarse){ .wv-ar-hint{ display:none; } }

@media (max-width:760px){
  .wv-panel{ width:100vw; height:auto; max-height:100vh; min-height:100vh; border-radius:0; border:0; }
  .wv-label{ flex-basis:100%; margin-bottom:-4px; }
}

/* ====== Képgaléria oldal (galeria.html) ====== */
.gal-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:980px){ .gal-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .gal-grid{ grid-template-columns:1fr; } }
.gal-tile{ position:relative; aspect-ratio:1/1; overflow:hidden; border-radius:12px; border:1px solid var(--line); background:#15110d; cursor:pointer; padding:0; display:block; }
.gal-tile img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease, opacity .3s; }
.gal-tile:hover img{ transform:scale(1.05); }
.gal-empty{ grid-column:1/-1; text-align:center; color:var(--mist); font-family:var(--font-display); font-size:20px; padding:48px 0; }

/* Lightbox */
.gal-lb{ position:fixed; inset:0; z-index:1000; background:rgba(10,8,6,.94); display:none; align-items:center; justify-content:center; }
.gal-lb.open{ display:flex; }
.gal-lb img{ max-width:92vw; max-height:86vh; object-fit:contain; border-radius:6px; box-shadow:0 20px 60px rgba(0,0,0,.6); }
.gal-lb__close, .gal-lb__nav{ position:absolute; background:rgba(0,0,0,.4); border:1px solid rgba(255,255,255,.22); color:#fff; cursor:pointer; border-radius:999px; display:flex; align-items:center; justify-content:center; line-height:1; font-family:var(--font-body); }
.gal-lb__close{ top:20px; right:20px; width:46px; height:46px; font-size:26px; }
.gal-lb__nav{ top:50%; transform:translateY(-50%); width:52px; height:52px; font-size:30px; }
.gal-lb__prev{ left:18px; } .gal-lb__next{ right:18px; }
.gal-lb__close:hover, .gal-lb__nav:hover{ border-color:var(--ochre); color:var(--ochre); }
@media (max-width:620px){ .gal-lb__nav{ width:42px; height:42px; font-size:26px; } .gal-lb__close{ top:14px; right:14px; } }

/* 2026-06-06: Â»LÃ¡ssuk az Ã©n falamon Â· VirtuÃ¡lis ValÃ³sÃ¡gÂ« (AR/VR) gomb ideiglenesen elrejtve mindenhol */
.wv-foot, .wv-ar, .wv-ar-hint { display: none !important; }

/* ===== Portré-rendelés: fotó-feltöltés a vásárlás-modálban ===== */
.buy-modal__photo { margin: 0 0 18px; text-align: center; padding: 16px; border: 1px dashed rgba(var(--ochre-rgb), 0.45); border-radius: 12px; background: rgba(var(--ochre-rgb), 0.05); }
.buy-photo__label { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; color: var(--ochre); margin-bottom: 12px; }
.buy-photo__btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 10px 18px; border: 1px solid var(--ochre); border-radius: 999px; background: transparent; color: var(--paper); font: inherit; font-size: 13px; font-weight: 500; cursor: pointer; transition: background 0.2s, transform 0.15s; }
.buy-photo__btn:hover { background: rgba(var(--ochre-rgb), 0.14); transform: translateY(-1px); }
.buy-photo__preview { display: block; max-width: 160px; max-height: 160px; width: auto; height: auto; margin: 14px auto 0; border-radius: 10px; border: 1px solid var(--line); object-fit: cover; }
.buy-photo__status { font-size: 12.5px; margin-top: 10px; min-height: 16px; color: var(--mist); }
.buy-photo__btn svg { flex: 0 0 auto; }
.buy-photo__status.is-busy { color: var(--mist); }
.buy-photo__status.is-ok { color: #6fae5a; font-weight: 600; }
.cart-row__note { font-size: 11.5px; color: var(--ochre); margin-top: 4px; letter-spacing: 0.02em; }

/* ===== Sajat-portre hero CTA ===== */
.hero-cta { margin-top: 30px; }
.hero-cta .btn-portrait {
  display: inline-block; padding: 15px 32px; border-radius: 999px;
  background: var(--ochre); color: #fff; font-family: var(--font-body);
  font-size: 14px; font-weight: 600; letter-spacing: 0.04em; cursor: pointer;
  border: 0; transition: transform 0.18s, box-shadow 0.18s;
  box-shadow: 0 10px 26px rgba(var(--ochre-rgb), 0.28);
}
.hero-cta .btn-portrait:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(var(--ochre-rgb), 0.38); }
.hero-cta .hero-cta-sub { display: block; margin-top: 12px; font-size: clamp(15px, 1.6vw, 18px); font-weight: 600; color: var(--ochre); letter-spacing: 0.04em; }

/* ============================================================
   Portré-oldal (#portre-hero) — a cím és a fotó ne lógjon egymásba.
   A közös .hero a művész-kivágatra van hangolva (balra húzott, nagyított
   kép + nowrap cím); a portré-fotónál ez átfedést okozna.
   ============================================================ */
#portre-hero .hero-name { white-space: normal; }
#portre-hero { gap: clamp(20px, 2.4vw, 40px); }
#portre-hero .hero-image-frame { transform: none; max-width: none; }
#portre-hero .hero-image { justify-content: stretch; }


/* ===== 2026-06-12: limitált példányszám — élő elérhetőség + sold-out ===== */
.product-avail{ font-family:var(--font-body); font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:600; color:var(--ochre); min-height:14px; margin:-4px 0 14px; }
.product-avail:empty{ margin:0; min-height:0; }
.product.is-soldout{ opacity:.96; }
.product .product-cta.is-sold,.product-cta.is-sold{ opacity:.5; cursor:not-allowed; pointer-events:none; }

/* ============ Főoldali Portré-festés promo (#portre-promo) ============ */
.portre-promo { border-top: 1px solid var(--line); background: transparent; }
.portre-promo-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 76px);
  align-items: center;
}
.portre-promo-media {
  display: block;
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--walnut);
  border: 1px solid var(--line);
}
.portre-promo-media img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top center; display: block;
  filter: contrast(1.04) saturate(1.05);
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.portre-promo-media:hover img { transform: scale(1.04); }
.portre-promo-text { max-width: 600px; }
.portre-promo .section-title { white-space: normal; margin-bottom: 22px; }
.portre-promo .lead { margin-bottom: 0; max-width: none; }
.portre-promo-cta { margin-top: 34px; display: flex; flex-wrap: wrap; gap: 14px; }
.portre-promo .promo-cta {
  display: inline-block; padding: 15px 34px; border-radius: 999px;
  background: var(--ochre); color: #fff; font-family: var(--font-body);
  font-size: 14px; font-weight: 600; letter-spacing: 0.04em; cursor: pointer;
  border: 1.5px solid var(--ochre); box-shadow: 0 10px 26px rgba(var(--ochre-rgb), 0.28);
  transition: transform 0.18s, box-shadow 0.18s, background 0.18s, color 0.18s;
}
.portre-promo .promo-cta:hover { transform: translateY(-2px); box-shadow: 0 14px 34px rgba(var(--ochre-rgb), 0.38); text-decoration: none; }
.portre-promo .promo-cta-ghost {
  background: transparent; color: var(--ochre); box-shadow: none;
}
.portre-promo .promo-cta-ghost:hover { background: var(--ochre); color: #fff; box-shadow: 0 12px 30px rgba(var(--ochre-rgb), 0.32); }
@media (max-width: 860px) {
  .portre-promo-inner { grid-template-columns: 1fr; gap: 26px; }
  .portre-promo-media { aspect-ratio: 4 / 3; }
  .portre-promo-text { max-width: none; }
}


/* ---- Webshop tipus-szuro gombsor ---- */
.shop-filters{display:flex;flex-wrap:wrap;gap:10px;margin:4px 0 30px}
.shop-filter{font:inherit;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;padding:9px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:transparent;color:rgba(255,255,255,.82);cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease}
.shop-filter:hover{border-color:var(--ochre);color:#fff}
.shop-filter.is-active{background:var(--ochre);border-color:var(--ochre);color:#fff}

/* ---- Termek-leiras a vasarlasi modalban ---- */
.buy-modal__desc{margin:12px 0 6px;font-family:var(--font-body);font-weight:300;font-size:13.5px;line-height:1.65;letter-spacing:.02em;color:var(--mist)}
.buy-modal__desc strong,.buy-modal__desc b{font-weight:700;color:var(--bone)}
.buy-modal__desc em,.buy-modal__desc i{font-style:italic}
