/* ==========================================================================
   Darázs Beauty – A Szépségszalon
   Design rendszer + komponensek · REELPIXELZ
   Tiszta CSS, framework nélkül. Mobil-első.
   ========================================================================== */

/* ----------------------------- TOKENEK ---------------------------------- */
:root {
  /* Base / surfaces — világos téma */
  --bg:            #FBF6EE;   /* meleg krém oldalháttér */
  --surface:       #FFFFFF;   /* kártya / felület */
  --surface-2:     #F4ECDF;   /* másodlagos felület, halvány méz */
  --bg-tint:       #F8F0E4;   /* váltakozó szekció háttér */

  /* Sötét akcentus-szekciók (vélemények, CTA-sáv, lábléc) */
  --bg-emerald:     #1F3D34;  /* mély smaragd szekció-háttér */
  --surface-emerald:#264C40;  /* kártya a smaragd szekcióban */
  --footer-bg:      #1A2722;  /* mély smaragd lábléc */

  /* Text / ink */
  --ink:           #3A332C;   /* fő szöveg (meleg sötétbarna) */
  --ink-on-dark:   #F3EEE4;   /* szöveg smaragd háttéren */
  --muted:         #6B5F52;   /* halvány szöveg világos bg-n */
  --muted-on-dark: #A9BBB2;   /* halvány szöveg sötét bg-n */

  /* Brand: méz-arany */
  --primary:       #B07A2C;
  --primary-600:   #9A6822;
  --primary-700:   #7A5C2E;
  --primary-tint:  rgba(176, 122, 44, 0.12);

  /* Accent: smaragd + púder-rózsa */
  --accent:        #2E5A4B;
  --accent-2:      #D8A7A0;
  --gold-soft:     #D8B96A;

  /* Feedback */
  --success:       #4E8C6A;
  --star-gold:     #D8B96A;
  --danger:        #B5483B;

  /* Lines */
  --border:        rgba(58, 51, 44, 0.10);
  --border-strong: rgba(58, 51, 44, 0.18);
  --border-on-dark:rgba(243, 238, 228, 0.16);

  /* Overlays */
  --overlay-hero:  linear-gradient(180deg, rgba(31,61,52,0.20) 0%, rgba(31,61,52,0.34) 45%, rgba(26,39,34,0.80) 100%);
  --overlay-card:  linear-gradient(180deg, rgba(26,39,34,0) 38%, rgba(26,39,34,0.84) 100%);
  --gold-glow:     radial-gradient(60% 80% at 50% 0%, rgba(176,122,44,0.16), transparent 70%);

  /* Fonts */
  --font-display:  "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --font-body:     "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  /* Spacing (4px alap) */
  --space-1:.25rem; --space-2:.5rem;  --space-3:.75rem; --space-4:1rem;
  --space-5:1.5rem; --space-6:2rem;   --space-8:3rem;   --space-10:4rem;
  --space-12:5rem;  --space-16:7.5rem;

  /* Layout */
  --container-max:    1180px;
  --container-narrow: 760px;
  --gutter:    1.25rem;
  --gutter-lg: 2rem;
  --section-y:    clamp(4rem, 9vw, 7.5rem);
  --section-y-sm: clamp(2.5rem, 6vw, 4rem);
  --header-h: 76px;

  /* Radius — lágy, nőies */
  --radius-sm:10px; --radius-md:16px; --radius-lg:24px; --radius-xl:32px;
  --radius-full:999px;

  /* Shadows — puha, alacsony kontraszt */
  --shadow-sm:  0 1px 2px rgba(58,51,44,.06);
  --shadow-md:  0 10px 30px rgba(58,51,44,.10);
  --shadow-lg:  0 24px 60px rgba(58,51,44,.14);
  --shadow-cta: 0 10px 26px rgba(176,122,44,.30);
  --ring-focus: 0 0 0 3px var(--primary-tint), 0 0 0 1px var(--primary);

  /* Motion */
  --ease-out:    cubic-bezier(.22, 1, .36, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);
  --dur-fast:150ms; --dur-base:280ms; --dur-slow:520ms;
}

/* ----------------------------- RESET ------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
html { scroll-padding-top: calc(var(--header-h) + 12px); }
body {
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.65;
  font-size: clamp(1rem, 0.4vw + 0.95rem, 1.0625rem);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
button { font: inherit; color: inherit; }
ul { list-style: none; padding: 0; }

/* --------------------------- TIPOGRÁFIA --------------------------------- */
h1, .h1 { font-family: var(--font-display); font-weight: 500; line-height: 1.06;
          letter-spacing: .2px; font-size: clamp(2.6rem, 6vw, 4.5rem); }
h2, .h2 { font-family: var(--font-display); font-weight: 500; line-height: 1.12;
          font-size: clamp(2rem, 4.2vw, 3.1rem); }
h3, .h3 { font-family: var(--font-display); font-weight: 600; line-height: 1.2;
          font-size: clamp(1.5rem, 2.6vw, 2rem); }
h4, .h4 { font-family: var(--font-body); font-weight: 700; line-height: 1.3;
          font-size: clamp(1.15rem, 1.8vw, 1.35rem); letter-spacing: .1px; }
h5, .h5 { font-family: var(--font-body); font-weight: 700; font-size: 1.05rem; }
.lead   { font-size: clamp(1.1rem, 1.6vw, 1.3rem); line-height: 1.6; color: var(--muted); }
.em-italic { font-style: italic; color: var(--primary-700); }

/* --------------------------- SEGÉD-OSZTÁLYOK ---------------------------- */
.container { width: 100%; max-width: var(--container-max);
  margin-inline: auto; padding-inline: var(--gutter); }
@media (min-width: 700px){ .container { padding-inline: var(--gutter-lg); } }
.narrow { max-width: var(--container-narrow); }
.section { padding-block: var(--section-y); }
.section--sm { padding-block: var(--section-y-sm); }
.bg-tint { background: var(--bg-tint); }
.center { text-align: center; }
.visually-hidden { position:absolute!important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

.eyebrow { font-family:var(--font-body); font-weight:700; font-size:.8rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--primary);
  display:inline-flex; align-items:center; gap:.6rem; }
.eyebrow::before { content:""; width:28px; height:1px; background:var(--primary); opacity:.7; }
.eyebrow--center { justify-content:center; }
.eyebrow--center::after { content:""; width:28px; height:1px; background:var(--primary); opacity:.7; }
.eyebrow--on-dark { color: var(--gold-soft); }
.eyebrow--on-dark::before, .eyebrow--on-dark::after { background: var(--gold-soft); }

.section-head { max-width:640px; margin:0 auto var(--space-8); }
.section-head--center { text-align:center; }
.section-head h2 { margin:.6rem 0 .5rem; }
.section-head p { color: var(--muted); }
.section-head--dark h2 { color: var(--ink-on-dark); }
.section-head--dark p { color: var(--muted-on-dark); }

/* ----------------------------- GOMBOK ----------------------------------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-body); font-weight:600; font-size:1rem; line-height:1;
  padding:.95rem 1.6rem; border-radius:var(--radius-full); border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; white-space:nowrap;
  transition: transform var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out),
    color var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out); }
.btn:focus-visible { outline:none; box-shadow:var(--ring-focus); }
.btn svg { width:18px; height:18px; }

.btn--primary { background:var(--primary); color:var(--bg); box-shadow:var(--shadow-cta); }
.btn--primary:hover { background:var(--primary-600); transform:translateY(-2px); }
.btn--primary:active { background:var(--primary-700); transform:translateY(0); }

.btn--secondary { background:transparent; color:var(--primary-700);
  border-color:rgba(176,122,44,.45); }
.btn--secondary:hover { background:var(--primary-tint); border-color:var(--primary); transform:translateY(-2px); }

.btn--ghost-light { background:rgba(255,255,255,.12); color:#fff;
  border-color:rgba(255,255,255,.4); backdrop-filter:blur(4px); }
.btn--ghost-light:hover { background:rgba(255,255,255,.2); transform:translateY(-2px); }

.btn--on-dark { background:var(--gold-soft); color:#2A2013; box-shadow:none; }
.btn--on-dark:hover { background:#E5C77E; transform:translateY(-2px); }

.btn--block { width:100%; }
.btn--lg { padding:1.1rem 1.9rem; font-size:1.0625rem; }

/* --------------------------- IKON-GOMBOK -------------------------------- */
.icon-btn { display:grid; place-items:center; width:46px; height:46px; border-radius:50%;
  background:transparent; border:1.5px solid var(--border-strong); color:var(--ink);
  cursor:pointer; transition: background var(--dur-base), border-color var(--dur-base), transform var(--dur-fast); }
.icon-btn:hover { background:var(--primary-tint); border-color:var(--primary); }
.icon-btn:focus-visible { outline:none; box-shadow:var(--ring-focus); }
.icon-btn svg { width:22px; height:22px; }
.icon-btn--call { background:var(--primary); color:var(--bg); border-color:var(--primary); }
.icon-btn--call:hover { background:var(--primary-600); transform:translateY(-1px); }

/* ----------------------------- SKIP LINK -------------------------------- */
.skip-link { position:absolute; left:50%; top:-60px; transform:translateX(-50%);
  background:var(--primary); color:var(--bg); padding:.7rem 1.2rem; border-radius:var(--radius-full);
  z-index:200; transition: top var(--dur-base); text-decoration:none; font-weight:600; }
.skip-link:focus { top:10px; }

/* ----------------------------- FEJLÉC ----------------------------------- */
.site-header { position:sticky; top:0; z-index:90; height:var(--header-h);
  background:rgba(251,246,238,.82); backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent; transition: box-shadow var(--dur-base) var(--ease-out),
    border-color var(--dur-base), background var(--dur-base); }
.site-header.is-scrolled { box-shadow:var(--shadow-sm); border-bottom-color:var(--border); }
.header-inner { height:var(--header-h); display:flex; align-items:center; justify-content:space-between; gap:1rem; }

.brand { display:inline-flex; align-items:center; gap:.7rem; text-decoration:none; }
.brand-mark { display:grid; place-items:center; width:42px; height:42px; border-radius:50%;
  background:var(--primary); color:var(--bg); font-family:var(--font-display);
  font-style:italic; font-weight:500; font-size:1.5rem; flex:none; }
.brand-text { font-family:var(--font-display); font-weight:600; font-size:1.25rem; line-height:1; color:var(--ink); }
.brand-text small { display:block; font-family:var(--font-body); font-weight:600; font-size:.6rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--muted); margin-top:.28rem; }

.nav { display:none; }
.nav ul { display:flex; align-items:center; gap:1.6rem; }
.nav a { position:relative; text-decoration:none; font-weight:600; font-size:.95rem;
  color:var(--ink); padding:.4rem 0; transition:color var(--dur-base); }
.nav a::after { content:""; position:absolute; left:0; bottom:-2px; height:2px; width:100%;
  background:var(--primary); transform:scaleX(0); transform-origin:left;
  transition:transform var(--dur-base) var(--ease-out); }
.nav a:hover, .nav a[aria-current="true"] { color:var(--primary-700); }
.nav a:hover::after, .nav a[aria-current="true"]::after { transform:scaleX(1); }

.header-cta { display:none; align-items:center; gap:1rem; }
.header-phone { display:flex; flex-direction:column; align-items:flex-end; line-height:1.1;
  font-weight:700; font-size:1rem; color:var(--ink); }
.header-phone span { font-weight:600; font-size:.7rem; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); }
.header-tools { display:flex; align-items:center; gap:.6rem; }

@media (min-width: 960px){
  .nav { display:block; }
  .header-cta { display:flex; }
  .header-tools { display:none; }
}

/* --------------------------- MOBIL NAV ---------------------------------- */
.mobile-nav { position:fixed; inset:0; z-index:120; background:var(--bg);
  display:flex; flex-direction:column; padding:1.2rem var(--gutter) 2rem;
  transform:translateX(100%); transition:transform var(--dur-base) var(--ease-out);
  visibility:hidden; }
.mobile-nav.is-open { transform:translateX(0); visibility:visible; }
.mobile-nav__top { display:flex; align-items:center; justify-content:space-between; margin-bottom:2rem; }
.mobile-nav ul { display:flex; flex-direction:column; gap:.25rem; }
.mobile-nav .m-link { display:block; padding:1rem .25rem; font-family:var(--font-display);
  font-size:1.7rem; font-weight:500; text-decoration:none; color:var(--ink);
  border-bottom:1px solid var(--border); }
.mobile-nav .m-link:hover { color:var(--primary-700); }
.mobile-nav__cta { margin-top:auto; display:flex; flex-direction:column; gap:.7rem; padding-top:1.5rem; }
@media (min-width: 960px){ .mobile-nav { display:none; } }

/* ----------------------------- HERO ------------------------------------- */
.hero { position:relative; min-height:clamp(560px, 92vh, 860px); display:flex; align-items:flex-end;
  color:#fff; overflow:hidden; }
.hero__bg { position:absolute; inset:0; z-index:-2; }
.hero__bg img { width:100%; height:100%; object-fit:cover; filter:saturate(.96) brightness(1.02); }
.hero::after { content:""; position:absolute; inset:0; z-index:-1; background:var(--overlay-hero); }
.hero__inner { padding-block: clamp(2.5rem, 8vh, 5rem); width:100%; }
.hero__content { max-width:680px; }
.hero h1 { color:#fff; margin:.8rem 0 1rem; text-shadow:0 2px 30px rgba(0,0,0,.25); }
.hero .lead { color:rgba(255,255,255,.92); margin-bottom:1.8rem; max-width:540px; }
.hero__eyebrow { color:var(--gold-soft); }
.hero__eyebrow::before { background:var(--gold-soft); }
.hero__cta { display:flex; flex-wrap:wrap; gap:.8rem; }
.hero__meta { display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.5rem; margin-top:1.6rem;
  font-size:.9rem; color:rgba(255,255,255,.88); }
.hero__meta-item { display:inline-flex; align-items:center; gap:.5rem; }
.hero__meta-item svg { width:17px; height:17px; opacity:.85; }

/* Status badge (most nyitva/zárva) */
.status-badge { display:inline-flex; align-items:center; gap:.5rem; padding:.4rem .9rem;
  border-radius:var(--radius-full); font-size:.82rem; font-weight:600;
  background:rgba(255,255,255,.14); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.22); color:#fff; }
.status-dot { width:9px; height:9px; border-radius:50%; background:var(--muted); flex:none;
  box-shadow:0 0 0 0 rgba(78,140,106,.6); }
.status-badge.is-open .status-dot { background:#6FD39B; animation:pulse 2.4s infinite; }
.status-badge.is-closed .status-dot { background:#E0A1A1; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(111,211,155,.55);} 70%{box-shadow:0 0 0 8px rgba(111,211,155,0);} 100%{box-shadow:0 0 0 0 rgba(111,211,155,0);} }

/* badge világos szekcióban */
.status-badge--light { background:var(--surface-2); color:var(--ink); border-color:var(--border); }

/* --------------------------- TRUST SÁV ---------------------------------- */
.trustbar { background:var(--surface); border-bottom:1px solid var(--border); }
.trustbar__grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1px;
  background:var(--border); border-inline:1px solid var(--border); }
.trust-item { background:var(--surface); display:flex; align-items:center; gap:.8rem;
  padding:1.1rem 1rem; }
.trust-item svg { width:26px; height:26px; color:var(--primary); flex:none; }
.trust-item strong { display:block; font-size:.98rem; font-weight:700; line-height:1.2; }
.trust-item span { font-size:.82rem; color:var(--muted); }
@media (min-width: 760px){ .trustbar__grid { grid-template-columns:repeat(4,1fr); } }

/* ------------------------- SZOLGÁLTATÁSOK ------------------------------- */
.acc { max-width:880px; margin-inline:auto; display:flex; flex-direction:column; gap:.9rem; }
.acc-item { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; transition:box-shadow var(--dur-base), border-color var(--dur-base); }
.acc-item.is-open { box-shadow:var(--shadow-md); border-color:rgba(176,122,44,.28); }
.acc-head { width:100%; display:flex; align-items:center; gap:1rem; padding:1.2rem 1.4rem;
  background:transparent; border:0; cursor:pointer; text-align:left; }
.acc-head:focus-visible { outline:none; box-shadow:inset 0 0 0 2px var(--primary); border-radius:var(--radius-lg); }
.acc-ico { width:46px; height:46px; border-radius:50%; background:var(--surface-2); color:var(--primary-700);
  display:grid; place-items:center; flex:none; }
.acc-ico svg { width:24px; height:24px; }
.acc-titles { flex:1; min-width:0; }
.acc-titles h3 { font-size:1.35rem; line-height:1.2; }
.acc-titles p { font-size:.88rem; color:var(--muted); margin-top:.1rem; }
.acc-tag { font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--primary-700); background:var(--primary-tint); padding:.28rem .6rem; border-radius:var(--radius-full); }
.acc-chevron { flex:none; color:var(--muted); transition:transform var(--dur-base) var(--ease-out); }
.acc-chevron svg { width:22px; height:22px; }
.acc-item.is-open .acc-chevron { transform:rotate(180deg); color:var(--primary); }
.acc-panel { overflow:hidden; height:0; transition:height var(--dur-base) var(--ease-out); }
.acc-panel__inner { padding:0 1.4rem 1.4rem; }
.acc-panel__inner .price-list { border-top:1px solid var(--border); padding-top:.4rem; }

.price-row { display:flex; align-items:baseline; gap:.8rem; padding:.85rem 0;
  border-bottom:1px dashed var(--border-strong); }
.price-row:last-child { border-bottom:0; }
.price-row__main { flex:1; min-width:0; display:flex; flex-direction:column; gap:2px; }
.price-row__name { font-weight:600; }
.price-row__desc { font-size:.85rem; color:var(--muted); }
.price-row__dots { flex:1; }
.price-row__price { font-family:var(--font-display); font-size:1.3rem; font-weight:600;
  color:var(--primary-700); white-space:nowrap; }
.acc-cta { margin-top:1.2rem; display:flex; flex-wrap:wrap; gap:.6rem; align-items:center; }
.acc-cta .note { font-size:.85rem; color:var(--muted); }

.price-note { max-width:880px; margin:1.5rem auto 0; padding:1rem 1.2rem; background:var(--surface-2);
  border-radius:var(--radius-md); font-size:.9rem; color:var(--muted); display:flex; gap:.7rem; align-items:flex-start; }
.price-note svg { width:20px; height:20px; color:var(--primary); flex:none; margin-top:2px; }

/* --------------------------- SPECIALITÁS -------------------------------- */
.feature { display:grid; gap:2rem; align-items:center; }
.feature__media { position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.feature__media img { width:100%; aspect-ratio:4/5; object-fit:cover; }
.feature__media .float-tag { position:absolute; left:1rem; bottom:1rem; background:rgba(255,255,255,.94);
  backdrop-filter:blur(6px); border-radius:var(--radius-md); padding:.7rem 1rem; box-shadow:var(--shadow-md);
  font-size:.85rem; max-width:240px; }
.feature__media .float-tag strong { color:var(--primary-700); }
.feature ul.checks { display:flex; flex-direction:column; gap:.7rem; margin:1.4rem 0 1.8rem; }
.feature ul.checks li { display:flex; gap:.7rem; align-items:flex-start; }
.feature ul.checks svg { width:22px; height:22px; color:var(--primary); flex:none; margin-top:2px; }
@media (min-width: 860px){ .feature { grid-template-columns:1fr 1.05fr; gap:3.5rem; }
  .feature--reverse .feature__media { order:2; } }

/* ----------------------------- GALÉRIA ---------------------------------- */
.gallery { display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; }
.gallery__item { position:relative; border-radius:var(--radius-md); overflow:hidden; cursor:pointer;
  border:0; padding:0; background:var(--surface-2); aspect-ratio:1/1; }
.gallery__item img { width:100%; height:100%; object-fit:cover; transition:transform var(--dur-slow) var(--ease-out); }
.gallery__item:hover img { transform:scale(1.06); }
.gallery__item:focus-visible { outline:none; box-shadow:var(--ring-focus); }
.gallery__item .g-cap { position:absolute; left:0; right:0; bottom:0; padding:1.6rem .8rem .7rem;
  background:var(--overlay-card); color:#fff; font-size:.8rem; font-weight:600; text-align:left;
  opacity:0; transform:translateY(8px); transition:opacity var(--dur-base), transform var(--dur-base); }
.gallery__item:hover .g-cap, .gallery__item:focus-visible .g-cap { opacity:1; transform:translateY(0); }
.gallery__item--wide { grid-column:span 2; aspect-ratio:2/1; }
@media (min-width: 760px){
  .gallery { grid-template-columns:repeat(4,1fr); gap:1rem; }
  .gallery__item--wide { grid-column:span 2; aspect-ratio:1/1; }
  .gallery__item--tall { grid-row:span 2; aspect-ratio:1/2; }
}
.gallery-note { text-align:center; font-size:.85rem; color:var(--muted); margin-top:1.2rem; }

/* Lightbox */
.lightbox { position:fixed; inset:0; z-index:160; background:rgba(20,18,15,.92);
  display:flex; align-items:center; justify-content:center; padding:1.5rem;
  opacity:0; visibility:hidden; transition:opacity var(--dur-base); }
.lightbox.is-open { opacity:1; visibility:visible; }
.lightbox img { max-width:min(92vw, 1000px); max-height:86vh; border-radius:var(--radius-md); box-shadow:var(--shadow-lg); }
.lightbox__close, .lightbox__nav { position:absolute; background:rgba(255,255,255,.14); color:#fff;
  border:1px solid rgba(255,255,255,.25); width:48px; height:48px; border-radius:50%; cursor:pointer;
  display:grid; place-items:center; transition:background var(--dur-base); }
.lightbox__close:hover, .lightbox__nav:hover { background:rgba(255,255,255,.28); }
.lightbox__close { top:1.2rem; right:1.2rem; }
.lightbox__close:focus-visible, .lightbox__nav:focus-visible { outline:none; box-shadow:0 0 0 3px rgba(255,255,255,.5); }
.lightbox__nav svg, .lightbox__close svg { width:24px; height:24px; }
.lightbox__nav--prev { left:1rem; }
.lightbox__nav--next { right:1rem; }
@media (min-width:760px){ .lightbox__nav--prev{ left:2rem; } .lightbox__nav--next{ right:2rem; } }

/* --------------------------- VÉLEMÉNYEK --------------------------------- */
.section--emerald { background:var(--bg-emerald); color:var(--ink-on-dark); position:relative; }
.section--emerald h2, .section--emerald h3 { color:var(--ink-on-dark); }
.reviews { display:grid; gap:1.2rem; grid-template-columns:1fr; }
@media (min-width:760px){ .reviews { grid-template-columns:repeat(3,1fr); } }
.review { background:var(--surface-emerald); border:1px solid var(--border-on-dark);
  border-radius:var(--radius-lg); padding:1.8rem; display:flex; flex-direction:column; }
.review__stars { color:var(--star-gold); letter-spacing:2px; margin-bottom:.9rem; font-size:1.05rem; }
.review__quote { font-family:var(--font-display); font-style:italic; font-size:1.22rem;
  line-height:1.5; color:var(--ink-on-dark); margin-bottom:1.2rem; flex:1; }
.review__name { font-size:.9rem; color:var(--muted-on-dark); font-weight:600; }
.reviews__foot { text-align:center; margin-top:2.2rem; }
.reviews__foot a { color:var(--gold-soft); font-weight:600; text-decoration:none; border-bottom:1px solid rgba(216,185,106,.4); padding-bottom:2px; }
.reviews__foot a:hover { color:#E5C77E; }

/* ----------------------------- RÓLAM ------------------------------------ */
.about { display:grid; gap:2.4rem; align-items:center; }
.about__media { position:relative; }
.about__media img { width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--radius-xl); box-shadow:var(--shadow-lg); }
.about__media .stat-card { position:absolute; right:-.6rem; bottom:1.5rem; background:var(--surface);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:1.1rem 1.3rem; text-align:center; }
.about__media .stat-card .num { font-family:var(--font-display); font-size:2.2rem; font-weight:600; color:var(--primary-700); line-height:1; }
.about__media .stat-card .lbl { font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-top:.3rem; }
.about__body p { color:var(--muted); margin-bottom:1rem; }
.about__sign { font-family:var(--font-display); font-style:italic; font-size:1.7rem; color:var(--primary-700); margin-top:.5rem; }
@media (min-width: 860px){ .about { grid-template-columns:.9fr 1.1fr; gap:3.5rem; } }

/* --------------------------- ELÉRHETŐSÉG -------------------------------- */
.contact { display:grid; gap:2rem; }
@media (min-width: 900px){ .contact { grid-template-columns:1fr 1fr; gap:2.5rem; } }
.contact-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg); padding:1.6rem; }
.contact-list { display:flex; flex-direction:column; gap:1.1rem; margin-bottom:1.4rem; }
.contact-list li { display:flex; gap:.9rem; align-items:flex-start; }
.contact-list .ci { width:42px; height:42px; border-radius:50%; background:var(--surface-2); color:var(--primary-700);
  display:grid; place-items:center; flex:none; }
.contact-list .ci svg { width:20px; height:20px; }
.contact-list .ct strong { display:block; font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); font-weight:700; }
.contact-list .ct a, .contact-list .ct span { font-size:1.05rem; font-weight:600; color:var(--ink); text-decoration:none; }
.contact-list .ct a:hover { color:var(--primary-700); }
.contact-cta { display:flex; flex-wrap:wrap; gap:.7rem; }

/* Nyitvatartás táblázat */
.hours { width:100%; border-collapse:collapse; }
.hours caption { text-align:left; }
.hours th, .hours td { padding:.7rem .2rem; border-bottom:1px solid var(--border); text-align:left; font-size:.98rem; }
.hours td:last-child { text-align:right; font-weight:600; }
.hours tr.is-today { color:var(--primary-700); }
.hours tr.is-today th, .hours tr.is-today td { font-weight:700; }
.hours tr.is-today th::before { content:"● "; color:var(--primary); font-size:.7em; vertical-align:middle; }
.hours .closed { color:var(--muted); font-weight:500; }
.hours-status { margin-top:1.1rem; }

/* Térkép facade */
.map-facade { position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:340px;
  cursor:pointer; border:1px solid var(--border); height:100%;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.045) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.045) 0 1px, transparent 1px 40px),
    radial-gradient(130% 110% at 50% -10%, #2E5A4B 0%, #1F3D34 55%, #18302A 100%); }
.map-facade__overlay { position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:.7rem; color:#fff; text-align:center;
  padding:1rem; transition:background var(--dur-base); }
.map-facade__overlay small { font-size:.85rem; color:var(--muted-on-dark); }
.map-facade:hover .map-facade__overlay { background:rgba(0,0,0,.07); }
.map-facade:hover .pin { transform:translateY(-3px); }
.map-facade .pin { transition:transform var(--dur-base) var(--ease-out); }
.map-facade__overlay .pin { width:54px; height:54px; border-radius:50%; background:var(--primary);
  display:grid; place-items:center; box-shadow:var(--shadow-md); }
.map-facade__overlay .pin svg { width:26px; height:26px; color:#fff; }
.map-facade__overlay span { font-weight:600; }
.map-facade:focus-visible { outline:none; box-shadow:var(--ring-focus); }
.map-facade iframe { width:100%; height:100%; border:0; min-height:340px; display:block; }

/* --------------------------- ZÁRÓ CTA ----------------------------------- */
.endcta { position:relative; background:var(--bg-emerald); color:var(--ink-on-dark); overflow:hidden; }
.endcta::before { content:""; position:absolute; inset:0; background:var(--gold-glow); }
.endcta__inner { position:relative; text-align:center; max-width:620px; margin-inline:auto; }
.endcta h2 { color:var(--ink-on-dark); margin-bottom:1rem; }
.endcta p { color:var(--muted-on-dark); margin-bottom:1.8rem; }
.endcta__cta { display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; }
.endcta__micro { margin-top:1.4rem; font-size:.85rem; color:var(--muted-on-dark); }

/* ----------------------------- LÁBLÉC ----------------------------------- */
.site-footer { background:var(--footer-bg); color:var(--muted-on-dark); padding-block:3rem 6.5rem; }
@media (min-width:960px){ .site-footer { padding-block:3.5rem 3rem; } }
.footer-grid { display:grid; gap:2rem; grid-template-columns:1fr; }
@media (min-width:760px){ .footer-grid { grid-template-columns:1.4fr 1fr 1fr; } }
.site-footer .brand-text { color:#fff; }
.site-footer .brand-text small { color:var(--muted-on-dark); }
.footer-about p { margin-top:1rem; font-size:.92rem; max-width:340px; }
.footer-col h4 { color:#fff; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; }
.footer-col ul { display:flex; flex-direction:column; gap:.6rem; }
.footer-col a { color:var(--muted-on-dark); text-decoration:none; font-size:.95rem; transition:color var(--dur-base); }
.footer-col a:hover { color:var(--gold-soft); }
.footer-social { display:flex; gap:.7rem; margin-top:1.2rem; }
.footer-social a { width:42px; height:42px; border-radius:50%; border:1px solid var(--border-on-dark);
  display:grid; place-items:center; color:#fff; transition:background var(--dur-base), border-color var(--dur-base); }
.footer-social a:hover { background:var(--primary); border-color:var(--primary); }
.footer-social svg { width:20px; height:20px; }
.footer-bottom { border-top:1px solid var(--border-on-dark); margin-top:2.5rem; padding-top:1.5rem;
  display:flex; flex-wrap:wrap; gap:.6rem 1.5rem; justify-content:space-between; font-size:.82rem; }
.footer-bottom a { color:var(--muted-on-dark); text-decoration:none; }
.footer-bottom a:hover { color:var(--gold-soft); }

/* ---------------------- MOBIL STICKY HÍVÓ SÁV --------------------------- */
.mobile-bar { position:fixed; left:0; right:0; bottom:0; z-index:80;
  display:flex; gap:.6rem; padding:.7rem .9rem calc(.7rem + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.94); backdrop-filter:blur(12px);
  border-top:1px solid var(--border); box-shadow:0 -8px 24px rgba(58,51,44,.10);
  transform:translateY(120%); transition:transform var(--dur-base) var(--ease-out); }
.mobile-bar.is-visible { transform:translateY(0); }
.mobile-bar .btn { flex:1; padding:.85rem 1rem; }
@media (min-width:960px){ .mobile-bar { display:none !important; } }

/* ---------------------- SCROLL REVEAL ----------------------------------- */
.reveal { opacity:0; transform:translateY(18px); transition:opacity var(--dur-slow) var(--ease-out),
  transform var(--dur-slow) var(--ease-out); }
.reveal.in-view { opacity:1; transform:none; }
.reveal-stagger > * { opacity:0; transform:translateY(18px); transition:opacity var(--dur-slow) var(--ease-out),
  transform var(--dur-slow) var(--ease-out); }
.reveal-stagger.in-view > * { opacity:1; transform:none; }
.reveal-stagger.in-view > *:nth-child(2){ transition-delay:.08s; }
.reveal-stagger.in-view > *:nth-child(3){ transition-delay:.16s; }
.reveal-stagger.in-view > *:nth-child(4){ transition-delay:.24s; }

/* ---------------------- REDUCED MOTION ---------------------------------- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after { animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal, .reveal-stagger > * { opacity:1 !important; transform:none !important; }
}
