/* sologym — style.css */
:root{
  --ch:#2C2C2A;--ch-mid:#3A3A37;--ch-lt:#4A4A46;
  --ww:#F5F3EF;--ww-dk:#EBE8E2;
  --yel:#F5C518;--yel-dk:#D4A910;--yel-lt:#FDF3D0;
  --sg:#A3A095;--sg-dk:#7A7972;
  --max:1200px;
  --px:48px;
  /* v3 alias tokens (single source — see Brand Guideline v3 §3.1) */
  --ink:#2C2C2A; --ink-2:#3A3A37; --ink-3:#4A4A46;
  --ww-2:#EBE8E2; --cream:#FAF8F3;
  --grey:#A3A095; --grey-dk:#7A7870; --grey-lt:#C9C6BC; --grey-bg:#F2F0EA;
  --line:#E0DCD0;
  --success:#4A7A45; --error:#B4432C;
  --f-display:'DM Sans', ui-sans-serif, system-ui, sans-serif;
  --f-body:'Inter','DM Sans', ui-sans-serif, system-ui, sans-serif;
  --f-mono:'JetBrains Mono', ui-monospace, 'SF Mono', monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;color:var(--ch);background:var(--ch);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.nav-open{overflow:hidden}
img{max-width:100%;display:block}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
:focus-visible{outline:2px solid var(--yel);outline-offset:2px}
button{background:none;border:none;cursor:pointer;font:inherit;color:inherit}

/* ── UTILITY ── */
.light{background:var(--ww);color:var(--ch)}
.dark{background:var(--ch);color:var(--ww)}
section{padding:100px var(--px)}
.si{max-width:var(--max);margin:0 auto}
.st{font-size:11px;font-weight:500;color:var(--yel-dk);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:14px}
.st-dark{color:var(--yel)}
.sh{font-family:'DM Sans',sans-serif;font-weight:600;font-size:36px;letter-spacing:-.5px;line-height:1.15;margin-bottom:48px}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(44,44,42,0.95);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
.nav-i{max-width:1400px;margin:0 auto;padding:20px var(--px);display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;letter-spacing:-.5px;text-decoration:none;color:var(--ww)}
.nav-logo b{color:var(--yel)}
.nav-r{display:flex;gap:28px;align-items:center}
.nav-r a{font-size:13px;color:rgba(245,243,239,0.5);text-decoration:none;transition:color .2s;letter-spacing:.3px}
.nav-r a:hover{color:var(--ww)}
.nav-cta{font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px;background:var(--yel);color:var(--ch);padding:9px 22px;border-radius:6px;text-decoration:none;transition:background .2s}
.nav-cta:hover{background:var(--yel-dk)}

/* Hamburger */
.nav-ham{display:none;width:32px;height:32px;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;padding:4px}
.nav-ham span{display:block;height:2px;background:var(--ww);border-radius:1px;transition:all .2s}
.nav-mob{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(44,44,42,0.98);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px}
.nav-mob.open{display:flex}
.nav-mob a{font-family:'DM Sans',sans-serif;font-size:20px;color:var(--ww);text-decoration:none;font-weight:500;transition:color .2s}
.nav-mob a:hover{color:var(--yel)}
.nav-mob-close{position:absolute;top:20px;right:var(--px);width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.nav-mob-close svg{stroke:var(--ww);stroke-width:2}

/* ── HERO ── */
.hero{min-height:100vh;background:var(--ch);display:flex;flex-direction:column;justify-content:flex-end;padding:0 var(--px) 72px;position:relative;overflow:hidden}
/* legacy hero ::before stripe gradient removed (v3 §3.2 rule 04 — no gradient) */
.hero-content{position:relative;z-index:1;max-width:1400px;margin:0 auto;width:100%}
.hero h1{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(42px,7vw,88px);line-height:1.0;letter-spacing:-2px;color:var(--ww);margin-bottom:28px;opacity:0;animation:fu .8s .3s forwards}
.hero h1 em{font-style:normal;color:rgba(245,243,239,0.35)}
.hero-sub{font-size:16px;color:rgba(245,243,239,0.65);max-width:440px;line-height:1.7;margin-bottom:48px;opacity:0;animation:fu .8s .5s forwards}

/* ── BUTTONS ── */
.btn-p{font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;background:var(--yel);color:var(--ch);padding:14px 32px;border-radius:22px;text-decoration:none;transition:background .2s;display:inline-block}
.btn-p:hover{background:var(--yel-dk)}

/* ── PHOTO STRIP ── */
.photo-strip{display:grid;grid-template-columns:1fr 1fr 1fr;height:45vh;min-height:280px}
.photo-strip div,.photo-strip img{background:var(--ch-mid);display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(245,243,239,0.2);letter-spacing:1px;border-right:1px solid rgba(245,243,239,0.04);object-fit:cover;width:100%;height:100%}
.photo-strip div:last-child,.photo-strip img:last-child{border-right:none}

/* ── BOOKING ── */
.booking-section{background:var(--ww);border-top:1px solid var(--ww-dk);padding:80px var(--px) 100px}
.booking-inner{max-width:var(--max);margin:0 auto}
.booking-layout{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}

/* Calendar */
.cal-wrap{background:#fff;border:1px solid var(--ww-dk);border-radius:12px;padding:20px;margin-bottom:28px}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-month{font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px}
.cal-nav{display:flex;gap:4px}
.cal-nav button{width:32px;height:32px;border:1px solid var(--ww-dk);background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;color:var(--ch);padding:0}
.cal-nav button:hover{border-color:var(--ch);background:var(--ch);color:var(--ww)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0}
.cal-day-label{font-size:10px;color:var(--sg);text-align:center;padding:4px 0;font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.cal-day{display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-weight:500;font-size:13px;border-radius:8px;cursor:pointer;transition:all .1s;position:relative;height:44px;-webkit-tap-highlight-color:transparent}
.cal-day:hover{background:var(--ww-dk)}
.cal-day:active{background:var(--ww-dk)}
.cal-day.today{font-weight:700;color:var(--yel-dk)}
.cal-day.selected{background:var(--ch);color:var(--ww)}
.cal-day.selected:hover{background:var(--ch)}
.cal-day.other-month{color:rgba(0,0,0,.12);pointer-events:none}
.cal-day.past{color:rgba(0,0,0,.15);pointer-events:none}
.cal-day.has-slots::after{content:'';position:absolute;bottom:4px;width:3px;height:3px;background:var(--yel);border-radius:50%}

/* Slots */
.slots-header{font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;margin-bottom:14px;color:var(--ch)}
.slots-sub{font-size:13px;font-weight:400;color:var(--sg);margin-left:6px}
.slots-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.slot-card{padding:12px 8px;background:#fff;border:1px solid var(--ww-dk);border-radius:8px;cursor:pointer;transition:all .1s;text-align:center;-webkit-tap-highlight-color:transparent;min-height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center}
/* 1c. Skeleton */
.slot-skeleton{background:var(--ww-dk);border-radius:8px;min-height:48px;animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:.8}}
.slot-card:hover{border-color:var(--ch)}
.slot-card:active{border-color:var(--ch)}
.slot-card.in-cart{border-color:var(--yel);background:var(--yel);color:var(--ch)}
.slot-card.in-cart .slot-price{color:var(--ch)}
.slot-card.in-cart:hover{background:var(--yel-dk);border-color:var(--yel-dk)}
.slots-empty{grid-column:1/-1;text-align:center;padding:24px 16px;color:var(--sg);font-size:14px}
.slot-card.booked{background:transparent;border-color:var(--ww-dk);cursor:default;opacity:.3}
.slot-card.booked:hover,.slot-card.booked:active{border-color:var(--ww-dk)}
.slot-time{font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px}
.slot-price{font-size:11px;color:var(--sg);margin-top:1px}

/* ── Sidebar + Kosár ── */
.booking-sidebar{position:sticky;top:100px}
.sidebar-card{background:var(--ww-dk);border:1px solid rgba(163,160,149,0.3);box-shadow:0 -2px 12px rgba(0,0,0,0.06);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:16px;position:relative}
.sidebar-card::before{content:'';display:block;width:28px;height:3px;background:var(--yel);border-radius:2px}
.sidebar-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:17px}
.cart-count{font-weight:400;font-size:13px;color:var(--sg)}
.cart-empty{color:var(--sg);font-size:13px}

/* Kosár lista */
.cart-items{display:flex;flex-direction:column;gap:4px}
.cart-group{margin-bottom:8px}
.cart-group-label{font-size:11px;font-weight:500;color:var(--yel-dk);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.cart-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0;border-bottom:1px solid var(--ww-dk)}
.cart-item:last-child{border-bottom:none}
.cart-item-time{flex:1;font-family:'DM Sans',sans-serif;font-weight:500}
.cart-item-price{font-size:12px;color:var(--sg)}
.cart-item-remove{background:none;border:none;color:var(--sg);cursor:pointer;font-size:18px;line-height:1;padding:12px;margin:-12px -8px -12px 0;transition:color .15s;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.cart-item-remove:hover{color:var(--ch)}

/* Kosár összesítés */
.cart-summary{border-top:1px solid var(--ww-dk);padding-top:12px;display:flex;flex-direction:column;gap:6px}
.cart-summary-row{display:flex;justify-content:space-between;font-size:13px}
.cart-discount{color:var(--yel-dk)}
.cart-total-row{align-items:baseline}
.cart-total{font-family:'DM Sans',sans-serif;font-weight:700;font-size:22px}
.cart-max-warn{font-size:12px;color:#d44;text-align:center;padding:8px 0}

/* Sidebar mezők + gomb */
.sidebar-fields{display:flex;flex-direction:column;gap:8px}
.sidebar-fields input{width:100%;padding:12px;border:1px solid var(--ww-dk);border-radius:8px;font-family:'Inter',sans-serif;font-size:14px;transition:border-color .15s;background:#fff;-webkit-appearance:none}
.sidebar-fields input:focus{outline:none;border-color:var(--ch)}
.sidebar-fields input::placeholder{color:var(--sg)}
.sidebar-btn{width:100%;padding:14px;font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;background:var(--yel);color:var(--ch);border:none;border-radius:8px;cursor:pointer;transition:all .15s;-webkit-appearance:none}
.sidebar-btn:hover{background:var(--yel-dk)}
.sidebar-btn:disabled{opacity:.35;cursor:default;background:var(--ww-dk);color:var(--sg)}
.sidebar-note{font-size:11px;color:var(--sg);text-align:center;line-height:1.5}

/* 3b. Spinner */
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(44,44,42,0.3);border-top-color:var(--ch);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* 5. Cart error */
.cart-error{background:var(--yel-lt);color:var(--ch);padding:10px 14px;border-radius:8px;font-size:14px;margin-bottom:12px;border-left:3px solid var(--yel);display:none}

/* 7. Progress indicator */
.progress-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px;font-size:13px;color:var(--sg)}
.step{display:flex;align-items:center;gap:6px;transition:color .2s}
.step.active{color:var(--ch)}
.step.completed{color:var(--ch)}
.step.active .step-num,.step.completed .step-num{background:var(--yel);color:var(--ch)}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--ww-dk);font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px}
.step-line{width:32px;height:2px;background:var(--ww-dk);margin:0 8px}

/* Mobil: sticky bottom bar */
.mobile-cart-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:99;background:var(--ch);padding:14px var(--px);align-items:center;justify-content:space-between;transform:translateY(100%);transition:transform .25s ease}
.mobile-cart-bar.visible{transform:translateY(0)}

/* Sidebar close gomb + overlay (mobil) */
.sidebar-close{display:none}
.cart-overlay{display:none}
.mcb-text{color:var(--ww);font-size:14px;font-weight:500}
.mcb-btn{background:var(--yel);color:var(--ch);font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px;padding:10px 20px;border-radius:8px}

/* ── FOOTER ── */
footer{background:var(--ch);border-top:1px solid rgba(245,243,239,0.06);padding:64px var(--px) 48px}
.f-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr auto auto;gap:80px;align-items:start}
.f-logo{font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;color:var(--ww);margin-bottom:10px}
.f-logo b{color:var(--yel)}
.f-tag{font-size:13px;color:rgba(245,243,239,0.25);line-height:1.6;max-width:240px}
.f-col h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:11px;color:rgba(245,243,239,0.35);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px}
.f-col a{display:block;font-size:13px;color:rgba(245,243,239,0.5);text-decoration:none;margin-bottom:9px;transition:color .2s}
.f-col a:hover{color:var(--ww)}
.f-btm{max-width:var(--max);margin:36px auto 0;padding-top:20px;border-top:1px solid rgba(245,243,239,0.06);display:flex;justify-content:space-between;font-size:12px;color:rgba(245,243,239,0.18)}

/* ── PAGE (GYIK, Házirend) ── */
.page-section{padding:120px var(--px) 80px}
.page-inner{max-width:720px;margin:0 auto}
.page-intro{font-size:16px;color:var(--sg);line-height:1.7;margin-top:-32px;margin-bottom:48px}

/* FAQ Accordion */
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid rgba(44,44,42,0.08)}
.faq-item:first-child{border-top:1px solid rgba(44,44,42,0.08)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:600;font-size:16px;color:var(--ch);padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;line-height:1.4}
.faq-q:hover{color:var(--yel-dk)}
.faq-icon{flex-shrink:0;transition:transform .25s ease;color:var(--sg)}
.faq-item.open .faq-icon{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease, padding .3s ease}
.faq-item.open .faq-a{max-height:300px;padding-bottom:20px}
.faq-a p{font-size:15px;color:var(--sg);line-height:1.7}
.faq-a a{color:var(--yel-dk);text-decoration:none}
.faq-a a:hover{text-decoration:underline}

/* Házirend */
.rules-list{list-style:none;counter-reset:rule}
.rules-list li{counter-increment:rule;padding:18px 0;border-bottom:1px solid rgba(44,44,42,0.08);font-size:15px;color:var(--ch);line-height:1.7;display:flex;gap:16px}
.rules-list li:first-child{border-top:1px solid rgba(44,44,42,0.08)}
.rules-list li::before{content:counter(rule) ".";font-family:'DM Sans',sans-serif;font-weight:600;color:var(--yel-dk);flex-shrink:0;min-width:24px}
.rules-list a{color:var(--yel-dk);text-decoration:none}
.rules-list a:hover{text-decoration:underline}

/* ÁSZF */
.legal h2{font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;color:var(--ch);letter-spacing:-.2px;line-height:1.3;margin:40px 0 16px}
.legal h2:first-child{margin-top:0}
.legal p{font-size:15px;color:var(--ch);line-height:1.7;margin-bottom:14px}
.legal ul,.legal ol{margin:0 0 14px 20px;padding:0}
.legal li{font-size:15px;color:var(--ch);line-height:1.7;margin-bottom:8px}
.legal a{color:var(--yel-dk);text-decoration:none}
.legal a:hover{text-decoration:underline}
.legal strong{font-weight:600;color:var(--ch)}

/* ── THANK YOU ── */
.ty-section{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:120px var(--px) 80px}
.ty-inner{max-width:720px;text-align:center}
.ty-check{margin-bottom:32px}
.ty-heading{font-family:'DM Sans',sans-serif;font-weight:600;font-size:36px;color:var(--ww);letter-spacing:-.5px;line-height:1.2;margin-bottom:16px}
.ty-sub{font-size:16px;color:var(--sg);line-height:1.6;margin-bottom:56px;max-width:480px;margin-left:auto;margin-right:auto}
.ty-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px;margin-bottom:48px}
.ty-card{background:var(--ch-mid);padding:32px 28px;text-align:left}
.ty-card:first-child{border-radius:10px 0 0 10px}
.ty-card:last-child{border-radius:0 10px 10px 0}
.ty-card-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;color:var(--yel);margin-bottom:10px}
.ty-card p{font-size:14px;color:rgba(245,243,239,0.6);line-height:1.6}
.ty-card a{color:var(--yel);text-decoration:none}
.ty-card a:hover{text-decoration:underline}

/* ── ANIMATIONS ── */
@keyframes fu{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── TABLET (768px) ── */
@media(max-width:768px){
  :root{--px:24px}
  .nav-r{display:none}
  .nav-ham{display:flex}
  .hero{padding:0 var(--px) 60px}
  .hero h1{letter-spacing:-1px}
  section{padding:72px var(--px)}
  .sh{font-size:28px}
  .photo-strip{grid-template-columns:1fr;height:auto}
  .photo-strip div,.photo-strip img{height:200px}
  .ty-cards{grid-template-columns:1fr}
  .ty-card{border-radius:0}
  .ty-card:first-child{border-radius:10px 10px 0 0}
  .ty-card:last-child{border-radius:0 0 10px 10px}
  .ty-heading{font-size:28px}
  .booking-section{padding:60px var(--px) 72px}
  .booking-layout{grid-template-columns:1fr;gap:24px}
  .booking-sidebar{position:fixed;bottom:0;left:0;right:0;z-index:98;transform:translateY(100%);transition:transform .3s ease;max-height:75vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .booking-sidebar .sidebar-card{border-radius:16px 16px 0 0;padding-bottom:32px}
  .booking-sidebar.mobile-open{transform:translateY(0)}
  .mobile-cart-bar{display:flex}
  .booking-sidebar.mobile-open + .cart-overlay{display:block;position:fixed;inset:0;z-index:97;background:rgba(0,0,0,0.4)}
  .booking-sidebar.mobile-open + .cart-overlay + .mobile-cart-bar{display:none}
  .booking-sidebar.mobile-open .sidebar-close{display:flex;position:absolute;top:12px;right:12px;width:44px;height:44px;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--sg);font-size:20px}
  .booking-sidebar.mobile-open .sidebar-close:hover{color:var(--ch)}
  .cal-wrap{max-width:100%}
  .slots-grid{grid-template-columns:repeat(3,1fr)}
  .f-inner{grid-template-columns:1fr;gap:36px}
  .f-btm{flex-direction:column;gap:6px}
}

/* ── MOBILE (480px) ── */
@media(max-width:480px){
  :root{--px:16px}
  .hero{padding:0 var(--px) 48px}
  .hero h1{font-size:36px;letter-spacing:-1px}
  .hero-sub{font-size:14px}
  section{padding:56px var(--px)}
  .sh{font-size:24px;margin-bottom:32px}
  .btn-p{padding:12px 24px;font-size:14px;width:100%;text-align:center}
  .slots-grid{grid-template-columns:repeat(2,1fr)}
  .slot-card{padding:8px 6px}
  .sidebar-card{padding:20px}
  .booking-section{padding:48px var(--px) 56px}
}

/* ═══════════════════════════════════════════
   V6 REDESIGN — Landing + Location
   ═══════════════════════════════════════════ */

/* ── V6 Nav ── */
/* legacy nav.nav rules removed — superseded by .nav block in v3 single-source layer below */

/* ── V6 Button ── */
.btn-primary{display:inline-flex;align-items:center;background:var(--yel);color:var(--ch);font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;padding:14px 32px;border-radius:8px;text-decoration:none;transition:background .2s,transform .15s}
.btn-primary:hover{background:var(--yel-dk);transform:translateY(-1px)}

/* ── V6 Hero (overrides old hero) ── */
body.v6 .hero{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center;background:var(--ch);overflow:hidden;position:relative;padding:0 clamp(24px,6vw,80px)}
body.v6 .hero::before{display:none}
/* legacy v6 .hero-bg gradient + sárga radial fog removed (Task 3b — flat charcoal hero) */
.hero-bg{position:absolute;inset:0;background:var(--ink)}
.hero-bg::before{display:none}
body.v6 .hero-content{max-width:760px;margin:0;width:auto;position:relative;z-index:1}
body.v6 .hero h1{font-size:clamp(38px,7vw,80px);line-height:1.05;letter-spacing:normal;margin-bottom:20px;animation:none;opacity:1}
body.v6 .hero h1 em{font-style:italic;color:var(--yel)}
.hero-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--sg);margin-bottom:20px}
body.v6 .hero-sub{font-size:clamp(15px,2vw,18px);line-height:1.6;color:var(--sg);max-width:480px;margin-bottom:36px;animation:none;opacity:1}
.hero-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.hero-secondary{color:var(--sg);text-decoration:none;font-size:14px;font-family:'DM Sans',sans-serif;font-weight:500;transition:color .2s}
.hero-secondary:hover{color:var(--ww)}
.hero-image{position:relative;z-index:1;aspect-ratio:4/5;max-height:78vh;overflow:hidden;border-radius:2px}
.hero-image img{width:100%;height:100%;object-fit:cover;display:block}

/* ── V6 Photo placeholder ── */
.ph{display:flex;align-items:center;justify-content:center;color:rgba(163,160,149,0.25);font-size:11px;letter-spacing:1px;text-transform:uppercase;position:relative;overflow:hidden}
.ph-dark{background:var(--ch-mid)}
.ph-mid{background:#333330}

/* ── V6 Photo strip (override) ── */
body.v6 .photo-strip{gap:2px;background:var(--ch);height:auto;min-height:auto}
body.v6 .photo-strip div{border-right:none}
.photo-strip .ph{height:clamp(180px,30vh,320px)}

/* ── V6 Section containers ── */
.section-dark{background:var(--ch);color:var(--ww);padding:0}
.section-light{background:var(--ww);color:var(--ch);padding:0}
.section-inner{max-width:1080px;margin:0 auto;padding:clamp(60px,10vh,100px) clamp(24px,4vw,48px)}
.section-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:12px}
.section-dark .section-label{color:var(--yel)}
.section-light .section-label{color:var(--sg)}
.section-heading{font-family:'DM Sans',sans-serif;font-weight:600;font-size:clamp(28px,4vw,36px);line-height:1.2;margin-bottom:48px}

/* ── V6 Bento Grid (landing) ── */
.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.bento-card{background:var(--ww);padding:32px 28px;position:relative}
.bento-card .bento-accent{width:28px;height:3px;background:var(--yel);border-radius:2px;margin-bottom:20px}
.bento-card .bento-num{position:absolute;top:20px;right:24px;font-family:'DM Sans',sans-serif;font-weight:700;font-size:64px;color:rgba(163,160,149,0.08);line-height:1}
.bento-icon{width:44px;height:44px;margin-bottom:16px;background:var(--ww-dk);border-radius:12px;display:flex;align-items:center;justify-content:center}
.bento-icon svg{width:22px;height:22px;stroke:var(--ch);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.bento-card h3{font-family:'DM Sans',sans-serif;font-weight:600;font-size:16px;margin-bottom:8px}
.bento-card p{font-size:14px;line-height:1.7;color:var(--sg)}

/* ── V6 Feature Strips ── */
.feature-strip{display:grid;grid-template-columns:1fr 1fr;min-height:300px}
.feature-strip.reverse{direction:rtl}
.feature-strip.reverse>*{direction:ltr}
.f-text{display:flex;flex-direction:column;justify-content:center;padding:clamp(28px,4vw,52px)}
.f-text-dark{background:var(--ch-mid)}
.f-text-light{background:var(--ww)}
.f-eyebrow{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--yel);margin-bottom:10px}
.f-title{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(20px,2.5vw,26px);line-height:1.2;margin-bottom:10px}
.f-text-dark .f-title{color:var(--ww)}
.f-text-light .f-title{color:var(--ch)}
.f-desc{font-size:14px;line-height:1.7;color:var(--sg);margin-bottom:14px}
.trust-micro{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--sg);background:rgba(245,243,239,0.05);padding:5px 12px;border-radius:6px;border:1px solid rgba(245,243,239,0.06)}
.trust-micro svg{width:14px;height:14px;stroke:var(--yel);fill:none;stroke-width:1.5}
.f-text-light .trust-micro{background:var(--ww-dk);border-color:transparent}

/* ── V6 Contrast (Variant A) ── */
.contrast-heading{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(26px,4vw,38px);color:var(--ww);line-height:1.15;margin-bottom:10px}
.contrast-sub{font-size:15px;color:var(--sg);line-height:1.7;margin-bottom:40px;max-width:540px}
.va-grid{display:flex;flex-direction:column;border:1px solid rgba(245,243,239,0.06);border-radius:14px;overflow:hidden;max-width:880px}
.va-header{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid rgba(245,243,239,0.06)}
.va-hc{padding:12px 24px;font-size:11px;letter-spacing:2px;text-transform:uppercase}
.va-hp{color:rgba(163,160,149,0.4);background:rgba(245,243,239,0.02);border-right:1px solid rgba(245,243,239,0.04)}
.va-hs{color:var(--yel);background:rgba(245,197,24,0.03)}
.va-row{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid rgba(245,243,239,0.04)}
.va-row:last-child{border-bottom:none}
.va-p{padding:18px 24px;background:rgba(245,243,239,0.02);border-right:1px solid rgba(245,243,239,0.04)}
.va-s{padding:18px 24px;background:rgba(245,197,24,0.03)}
.va-pt{font-family:'DM Sans',sans-serif;font-weight:500;font-size:14px;color:rgba(245,243,239,0.35);text-decoration:line-through;text-decoration-color:rgba(245,243,239,0.18);text-decoration-thickness:1.5px}
.va-ps{font-size:12px;color:rgba(163,160,149,0.3);margin-top:2px}
.va-st{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;color:var(--ww)}
.va-ss{font-size:12px;color:var(--sg);margin-top:2px}

/* ── V6 Pricing ── */
.pricing-center{text-align:center;max-width:560px;margin:0 auto}
.price-big{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(56px,10vw,88px);color:var(--ww);line-height:1}
.price-unit-v6{font-family:'DM Sans',sans-serif;font-weight:400;font-size:clamp(18px,3vw,24px);color:var(--sg);margin-bottom:28px;display:block}
.price-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:20px}
.price-pill{background:rgba(245,243,239,0.08);color:var(--sg);font-size:13px;padding:6px 16px;border-radius:20px;border:1px solid rgba(245,243,239,0.06)}
.price-note-v6{font-size:14px;line-height:1.7;color:var(--sg);margin-bottom:36px}

/* ── V6 Locations Grid ── */
.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}
.loc-card-v6{border-radius:14px;overflow:hidden;border:1px solid var(--ww-dk);background:var(--ww);transition:box-shadow .2s,transform .15s;text-decoration:none;color:inherit;display:block}
.loc-card-v6:hover{box-shadow:0 4px 20px rgba(0,0,0,0.08);transform:translateY(-2px)}
.loc-card-v6 .ph{height:200px}
.loc-ci{padding:20px}
.loc-ci h3{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;margin-bottom:4px}
.loc-ci p{font-size:13px;color:var(--sg);margin-bottom:14px;line-height:1.5}
.loc-cm{display:flex;align-items:center;gap:16px;font-size:12px;color:var(--sg)}
.loc-cm span{display:flex;align-items:center;gap:4px}
.loc-cm svg{width:14px;height:14px;stroke:var(--sg);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.loc-cp{margin-top:14px;padding-top:14px;border-top:1px solid var(--ww-dk);display:flex;align-items:baseline;justify-content:space-between}
.loc-cp strong{font-family:'DM Sans',sans-serif;font-weight:700;font-size:18px}
.loc-cp span{font-size:13px;color:var(--sg)}
.loc-cta{font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px;color:var(--yel);text-decoration:none}

/* ── V6 Footer ── */
.footer{background:var(--ch);color:var(--sg);padding:clamp(40px,5vh,56px) clamp(24px,4vw,48px)}
.footer-inner{max-width:1080px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px}
.footer-logo{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;letter-spacing:-.5px;margin-bottom:6px}
.footer-logo .solo{color:var(--ww)}
.footer-logo .gym{color:var(--yel)}
.footer-tagline{font-size:13px;max-width:260px}
.footer-col h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ww);margin-bottom:10px}
.footer-col a{display:block;color:var(--sg);text-decoration:none;font-size:13px;margin-bottom:5px;transition:color .2s}
.footer-col a:hover{color:var(--ww)}
.footer-bottom{max-width:1080px;margin:24px auto 0;padding-top:16px;border-top:1px solid rgba(245,243,239,0.06);font-size:11px;color:rgba(163,160,149,0.4)}

/* ═══ V6 Location Page ═══ */

/* ── Gallery (override old) ── */
body.v6 .gallery{margin-top:56px;display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:3px;height:clamp(320px,50vh,480px);background:var(--ch);padding:0}
.gallery-main{grid-row:1/3}

/* ── Listing layout ── */
/* Listing top: kétoszlopos (tartalom + sidebar) */
.listing-top{max-width:1080px;margin:0 auto;padding:0 clamp(20px,4vw,48px);display:grid;grid-template-columns:1fr 340px;gap:48px}
.content-top{padding:28px 0 60px}
/* Listing bottom: foglalás + loc info (teljes szélesség) */
.listing-bottom{max-width:1080px;margin:0 auto;padding:0 clamp(20px,4vw,48px) 60px}

/* ── Property header ── */
.prop-header{padding-bottom:24px;border-bottom:1px solid var(--ww-dk)}
.prop-title{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(22px,3vw,28px);line-height:1.2;margin-bottom:6px}
.prop-sub{font-size:13px;color:var(--sg);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.prop-dot{width:3px;height:3px;border-radius:50%;background:var(--sg);display:inline-block}

/* ── Highlights ── */
.highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px 0;border-bottom:1px solid var(--ww-dk)}
.hl{display:flex;align-items:flex-start;gap:12px}
.hl-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.hl-icon svg{width:24px;height:24px;stroke:var(--ch);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}
.hl h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px;margin-bottom:1px}
.hl p{font-size:12px;color:var(--sg);line-height:1.5}

/* ── Description ── */
.loc-desc{padding:24px 0;border-bottom:1px solid var(--ww-dk)}
.loc-desc p{font-size:14px;line-height:1.8;color:var(--ch)}

/* ── Amenities ── */
.amen{padding:24px 0;border-bottom:1px solid var(--ww-dk)}
.amen-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;margin-bottom:24px}
.amen-cat-label{font-family:'DM Sans',sans-serif;font-weight:600;font-size:13px;letter-spacing:.5px;color:var(--sg);padding:18px 0 8px;border-bottom:1px solid var(--ww-dk);margin-bottom:0}
.amen-cat-label:first-of-type{padding-top:0}
.amen-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:8px}
.amen-item{display:flex;align-items:center;gap:12px;padding:10px 0}
.amen-item svg{width:20px;height:20px;stroke:var(--ch);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.amen-item span{font-size:13px}

/* ── How it works (location) ── */
.loc-how{padding:24px 0;border-bottom:1px solid var(--ww-dk)}
.loc-how-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;margin-bottom:20px}
.hw-step{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid rgba(235,232,226,0.5)}
.hw-step:last-child{border-bottom:none}
.hw-step-n{width:28px;height:28px;flex-shrink:0;border-radius:50%;background:var(--ww-dk);display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px}
.hw-step h4{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;margin-bottom:2px}
.hw-step p{font-size:12px;color:var(--sg);line-height:1.5}

/* ── Booking section (v6 context — inside listing content column) ── */
body.v6 .booking-section{padding:32px 0;background:transparent;border-top:1px solid var(--ww-dk);border-bottom:1px solid var(--ww-dk)}
body.v6 .booking-inner{max-width:none}
body.v6 .booking-layout{grid-template-columns:1fr 340px;gap:24px}
body.v6 .booking-sidebar{position:static}

/* ── Booking header ── */
.book-header{margin-bottom:24px}
.book-label{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--yel);margin-bottom:8px;font-family:'DM Sans',sans-serif;font-weight:600}
.book-heading{font-family:'DM Sans',sans-serif;font-weight:600;font-size:22px;margin-bottom:6px}
.book-sub{font-size:13px;color:var(--sg)}

/* ── Book card sidebar (listing right column) ── */
.listing-sidebar{padding:28px 0 60px}
.book-card{position:sticky;top:72px;background:var(--ww);border:1px solid var(--ww-dk);border-radius:14px;padding:24px;box-shadow:0 2px 16px rgba(0,0,0,0.06)}
.bc-price{display:flex;align-items:baseline;gap:5px;margin-bottom:6px}
.bc-price strong{font-family:'DM Sans',sans-serif;font-weight:700;font-size:24px}
.bc-price span{font-size:14px;color:var(--sg)}
.bc-per{font-size:12px;color:var(--sg);margin-bottom:18px}
.bc-cta{display:block;width:100%;background:var(--yel);color:var(--ch);font-family:'DM Sans',sans-serif;font-weight:600;font-size:15px;padding:13px;border-radius:10px;text-align:center;text-decoration:none;transition:background .2s;border:none;cursor:pointer}
.bc-cta:hover{background:var(--yel-dk)}
.bc-sub{text-align:center;font-size:11px;color:var(--sg);margin-top:8px}
.bc-div{height:1px;background:var(--ww-dk);margin:18px 0}
.bc-list{list-style:none}
.bc-list li{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px}
.bc-list li svg{width:15px;height:15px;stroke:var(--yel);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.bc-trust{margin-top:18px;padding:12px;background:var(--ww-dk);border-radius:10px;font-size:12px;color:var(--sg);line-height:1.6;text-align:center}
.bc-pay{text-align:center;font-size:11px;color:var(--sg);margin-top:12px}

/* ── Sticky mobile bar (location page) ── */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:99;background:var(--ww);border-top:1px solid var(--ww-dk);padding:10px clamp(20px,4vw,48px);display:none;align-items:center;justify-content:space-between;box-shadow:0 -2px 12px rgba(0,0,0,0.06)}
.sb-left strong{font-family:'DM Sans',sans-serif;font-weight:700;font-size:17px}
.sb-left span{font-size:12px;color:var(--sg);margin-left:3px}
.sb-btn{background:var(--yel);color:var(--ch);font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;padding:11px 24px;border-radius:8px;text-decoration:none}
.sb-btn:hover{background:var(--yel-dk)}

/* ── Location info ── */
.loc-info-section{padding:24px 0}
.loc-info-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;margin-bottom:16px}
.loc-detail{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px;color:var(--sg)}
.loc-detail svg{width:18px;height:18px;stroke:var(--sg);fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.map-placeholder{margin-top:16px;height:180px;border-radius:12px;overflow:hidden}

/* ═══ V6 Responsive ═══ */
@media(max-width:900px){
  body.v6 .hero{grid-template-columns:1fr;gap:32px}
  .hero-image{aspect-ratio:3/2;max-height:52vh;order:-1}
  .feature-strip,.feature-strip.reverse{grid-template-columns:1fr;direction:ltr}
  .feature-strip.reverse>*{direction:ltr}
  .va-row,.va-header{grid-template-columns:1fr}
  .va-p{border-right:none;border-bottom:1px solid rgba(245,243,239,0.04)}
  .va-hp{border-right:none}
  .listing-top{grid-template-columns:1fr;gap:0}
  .listing-sidebar{display:none}
  .sticky-bar{display:flex}
  body.v6 .gallery{grid-template-columns:1fr 1fr;height:auto}
  .gallery-main{grid-column:1/-1;height:clamp(200px,35vh,300px)}
  body.v6 .gallery .ph{height:clamp(120px,18vh,160px)}
  body.v6 .gallery .ph:nth-child(n+4){display:none}
  .highlights{grid-template-columns:1fr}
  body.loc-page{padding-bottom:60px}
}
@media(max-width:768px){
  .nav-links{display:none}
  nav.nav .nav-cta{display:none}
  .bento-grid{grid-template-columns:1fr}
  body.v6 .photo-strip{grid-template-columns:1fr}
  .locations-grid{grid-template-columns:1fr}
  body.v6 .gallery{grid-template-columns:1fr}
  body.v6 .gallery .ph:nth-child(n+3){display:none}
  .footer-inner{flex-direction:column}
  body.v6 .hero{padding:0}
  body.v6 .hero-content{padding:0 var(--px)}
  body.v6 .booking-layout{grid-template-columns:1fr}
}
@media(max-width:480px){
  body.v6 .hero h1{font-size:36px}
  .bento-card{padding:24px 20px}
}

/* ═══════════════════════════════
   INSTAGRAM SZEKCIÓ (helyszín oldal)
   — háttér: --ww (warm-white), igazítva a .listing-bottom konténerhez
     (max-width:1080px; padding: clamp(20px,4vw,48px))
═══════════════════════════════ */
.ig-section{background:var(--ww);padding:80px 0 80px}
.ig-header{max-width:1080px;margin:0 auto 40px;padding:0 clamp(20px,4vw,48px);display:flex;align-items:flex-end;justify-content:space-between;gap:24px}
.ig-meta{flex:1}
.ig-label-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ig-accent{width:28px;height:3px;background:var(--yel);border-radius:2px;flex-shrink:0}
.ig-label-text{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--yel-dk)}
.ig-heading{font-family:'DM Sans',sans-serif;font-size:34px;font-weight:600;color:var(--ch);line-height:1.2}
.ig-heading span{color:var(--sg);font-weight:400}
.ig-handle{font-size:14px;color:var(--sg);margin-top:8px}
.ig-follow-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;background:transparent;border:1px solid rgba(44,42,42,0.2);border-radius:8px;color:var(--ch);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap;transition:border-color .18s,color .18s;flex-shrink:0;align-self:center}
.ig-follow-btn:hover{border-color:var(--yel-dk);color:var(--ch)}
.ig-icon{width:18px;height:18px}
/* Scroll track — bal széle a konténer bal széléhez igazodik, jobbra szabadon kifut */
.ig-scroll{overflow-x:auto;padding-left:max(clamp(20px,4vw,48px),calc((100vw - 1080px) / 2 + clamp(20px,4vw,48px)));padding-right:0;padding-bottom:8px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab}
.ig-scroll::-webkit-scrollbar{display:none}
.ig-scroll:active{cursor:grabbing}
.ig-track{display:flex;gap:12px;width:max-content}
.ig-card{flex-shrink:0;border-radius:10px;overflow:hidden;background:#fff;border:1px solid var(--ww-dk);transition:transform .22s ease,box-shadow .22s ease;cursor:pointer}
.ig-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,0.12)}
.ig-card--wide{width:340px}
.ig-card--wide .ig-photo{aspect-ratio:4/3}
.ig-card--sq{width:220px}
.ig-card--sq .ig-photo{aspect-ratio:1/1}
.ig-photo{width:100%;position:relative;overflow:hidden;background:var(--ww-dk)}
.ig-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.ig-card:hover .ig-photo img{transform:scale(1.04)}
.ig-overlay{position:absolute;inset:0;background:rgba(44,44,42,0);transition:background .22s;display:flex;align-items:center;justify-content:center;gap:24px}
.ig-card:hover .ig-overlay{background:rgba(44,44,42,0.55)}
.ig-stat{color:white;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;display:flex;align-items:center;gap:5px;opacity:0;transform:translateY(5px);transition:opacity .22s,transform .22s}
.ig-card:hover .ig-stat{opacity:1;transform:translateY(0)}
.ig-card-body{padding:12px 14px 14px}
.ig-caption{font-size:13px;color:var(--ch);line-height:1.5;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ig-caption-meta{display:flex;align-items:center;justify-content:space-between}
.ig-likes{font-size:12px;color:var(--sg);display:flex;align-items:center;gap:4px}
.ig-time{font-size:11px;color:rgba(163,160,149,0.6)}
.ig-dots{max-width:1080px;margin:0 auto;padding:16px clamp(20px,4vw,48px) 0;display:flex;align-items:center;gap:6px}
.ig-dots .dot{height:5px;width:5px;border-radius:3px;background:var(--sg);opacity:0.35;transition:width .2s,opacity .2s}
.ig-dots .dot.active{width:20px;background:var(--yel);opacity:1}
@media(max-width:768px){
  .ig-header{flex-direction:column;align-items:flex-start;gap:16px}
  .ig-heading{font-size:26px}
  .ig-card--wide{width:280px}
  .ig-card--sq{width:180px}
}

/* ═══════════════════════════════
   GOOGLE REVIEWS SZEKCIÓ (landing)
   — sötét háttér (charcoal), 6 review kártya 3×2 grid
═══════════════════════════════ */
.reviews-section{background:var(--ch);padding:80px 24px;color:var(--ww)}
.reviews-inner{max-width:1120px;margin:0 auto}
.reviews-accent{width:28px;height:3px;background:var(--yel);border-radius:2px;margin-bottom:14px}
.reviews-label{font-family:'DM Sans',sans-serif;font-weight:600;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--sg);margin-bottom:28px}
.reviews-header{display:flex;align-items:center;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.reviews-score{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(48px,6vw,72px);line-height:1;color:var(--ww)}
.reviews-meta{flex:1;min-width:0}
.reviews-stars{display:flex;gap:2px;margin-bottom:6px}
.reviews-stars svg{width:18px;height:18px}
.reviews-count{font-size:13px;color:var(--sg)}
.reviews-count a{color:var(--ww);text-decoration:underline;text-decoration-color:rgba(245,243,239,0.3);text-underline-offset:2px;transition:text-decoration-color .15s}
.reviews-count a:hover{text-decoration-color:var(--yel)}
.google-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(245,243,239,0.05);border:1px solid rgba(245,243,239,0.08);border-radius:8px;font-family:'DM Sans',sans-serif;font-weight:500;font-size:13px;color:var(--ww);margin-left:auto}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review-card{background:var(--ch-mid);border-radius:12px;padding:28px 24px;display:flex;flex-direction:column;gap:18px}
.review-card-stars{display:flex;gap:2px}
.review-card-stars svg{width:14px;height:14px}
.review-text{font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.7;color:var(--ww);margin:0;flex:1}
.review-text em{font-style:normal;color:var(--yel)}
.review-author{display:flex;align-items:center;gap:12px;padding-top:4px}
.review-avatar{width:36px;height:36px;border-radius:50%;background:var(--ch);color:var(--ww);font-family:'DM Sans',sans-serif;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.review-name{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;color:var(--ww);line-height:1.3}
.review-date{font-size:12px;color:var(--sg);line-height:1.3;margin-top:2px}

@media(max-width:900px){
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .reviews-section{padding:60px 20px}
  .reviews-grid{grid-template-columns:1fr;gap:12px}
  .google-badge{margin-left:0;width:100%;justify-content:center}
  .reviews-header{gap:16px}
}

/* ═══ HOGYAN MŰKÖDIK — rich variant (v3) ═══ */
:root{--f-mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;--ww-2:#EBE8E2;--grey-bg:#F2F0EA;--grey-lt:#C9C6BC;--line:#E0DCD0}
.how-head{text-align:center;max-width:780px;margin:0 auto 56px}
.how-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--sg-dk);margin-bottom:24px}
.how-eyebrow::before{content:"";display:block;width:40px;height:1px;background:var(--grey-lt)}
.how-h{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(36px,5.5vw,64px);line-height:1.02;letter-spacing:-.02em;color:var(--ch);margin-bottom:20px}
.how-sub{font-family:'DM Sans',sans-serif;font-size:clamp(15px,1.4vw,18px);line-height:1.5;color:var(--sg-dk);max-width:580px;margin:0 auto}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.how-card{background:var(--grey-bg);border:1px solid var(--line);border-radius:22px;padding:36px;display:flex;flex-direction:column;gap:20px;transition:border-color .2s}
.how-card.active{border-color:var(--yel);border-width:2px;padding:35px}
.how-card-eye{font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--sg-dk);display:flex;gap:10px}
.how-card-eye em{font-style:normal;color:var(--ch);font-weight:500}
.how-card h3{font-family:'DM Sans',sans-serif;font-weight:700;font-size:clamp(22px,2vw,28px);line-height:1.15;color:var(--ch);letter-spacing:-.01em;margin:0}
.how-card p{font-size:15px;line-height:1.55;color:var(--sg-dk);margin:0}
.how-mock{margin-top:auto;background:var(--ww);border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;justify-content:center;min-height:150px}
.mock-cal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.mc-day{background:var(--ww);border:1px solid var(--line);border-radius:10px;padding:14px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:6px}
.mc-day .mcd-n{font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;color:var(--ch);letter-spacing:-.01em}
.mc-day .mcd-c{font-family:var(--f-mono);font-size:11px;color:var(--sg-dk)}
.mc-day.selected{background:var(--ch);border-color:var(--ch)}
.mc-day.selected .mcd-n{color:var(--ww)}
.mc-day.selected .mcd-c{color:var(--yel)}
.mock-sms{display:flex;flex-direction:column;gap:10px}
.sms-meta{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--sg-dk)}
.sms-bubble{background:var(--ch);color:var(--ww);border-radius:14px 14px 14px 4px;padding:14px 16px;font-family:'Inter',sans-serif;font-size:14px;line-height:1.45;max-width:95%}
.sms-pin{font-family:var(--f-mono);font-weight:500;color:var(--yel);letter-spacing:.04em}
.mock-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:180px;margin:0 auto}
.kp{aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-weight:500;font-size:15px;background:var(--ww);border:1px solid var(--line);color:var(--grey-lt)}
.kp.used{background:var(--ch);border-color:var(--ch);color:var(--yel)}
.kp.ok{background:var(--yel);border-color:var(--yel);color:var(--ch);font-size:17px}
@media(max-width:768px){.how-grid{grid-template-columns:1fr;gap:14px}.how-card{padding:28px}.how-card.active{padding:27px}.how-head{margin-bottom:36px}}

/* ════════════════════════════════════════════════════════════════════════
   v3 SINGLE-SOURCE — landing (index.html) + helyszín (sg1.html)
   Brand Guideline v3 §1.1–§9.1
   Architecture: this block is the canonical layer; appears LAST so it
   wins source-order against legacy v6/v1 rules above.
   ════════════════════════════════════════════════════════════════════════ */

/* ── Resets / base ── */
html{scroll-padding-top:72px}
body{font-family:var(--f-body);color:var(--ink);background:var(--ww);font-size:16px;line-height:1.625;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── NAV (Task 4c — option 1: warm-white nav, sits above charcoal hero) ── */
.nav{position:sticky;top:0;left:auto;right:auto;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:16px var(--px);background:rgba(245,243,239,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-logo{font-family:var(--f-display);font-weight:700;font-size:22px;letter-spacing:-.01em}
.nav-logo .solo{color:var(--ink)}
.nav-logo .gym{color:var(--yel)}
.nav .nav-links{display:flex;gap:28px;align-items:center}
.nav .nav-links a{font-family:var(--f-body);font-size:14px;color:var(--ink);transition:color .15s;letter-spacing:0}
.nav .nav-links a:hover{color:var(--ink)}
.nav .nav-cta{padding:10px 20px;background:var(--yel);color:var(--ink);border-radius:22px;font-weight:600;font-size:14px;font-family:var(--f-display);transition:background .15s}
.nav .nav-cta:hover{background:var(--yel-dk)}
.nav .nav-ham{display:none;background:transparent;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:4px}
.nav .nav-ham span{display:block;width:22px;height:2px;background:var(--ink);border-radius:1px}
.nav-mob{position:fixed;top:0;left:auto;right:0;bottom:0;width:min(320px,85vw);background:var(--ink);color:var(--ww);padding:60px 28px 28px;display:flex;flex-direction:column;gap:6px;align-items:flex-start;justify-content:flex-start;transform:translateX(100%);transition:transform .3s ease;z-index:100}
.nav-mob.open{transform:translateX(0);display:flex}
.nav-mob a{font-family:var(--f-display);font-weight:500;font-size:18px;padding:12px 0;color:var(--ww-2);border-bottom:1px solid var(--ink-3);width:100%;text-align:left}
.nav-mob a:hover{color:var(--ww)}
.nav-mob-close{position:absolute;top:20px;right:20px;background:transparent;border:none;cursor:pointer;padding:6px;color:var(--ww)}
.nav-mob-close svg{stroke:var(--ww);stroke-width:2}

/* ── HERO (Task 4a + Task 1 + Task 9a) — Charcoal-grounded ── */
section.hero{padding:88px var(--px) 64px;max-width:none;margin:0;display:block;background:var(--ink);color:var(--ww);min-height:auto;border-bottom:none;position:relative;overflow:hidden}
section.hero::before{display:none}
section.hero .hero-text,
section.hero > .hero-text{display:block}
section.hero .hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:48px;align-items:center}
.hero-label{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey);margin-bottom:20px;display:block;animation:none;opacity:1}
section.hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(48px,7vw,88px);line-height:1.05;letter-spacing:-.02em;color:var(--ww);margin-bottom:20px;animation:none;opacity:1}
section.hero h1 em{font-style:italic;font-weight:400;color:var(--grey)}
section.hero .hero-sub{font-family:var(--f-display);font-size:clamp(17px,1.6vw,20px);line-height:1.5;color:var(--grey);max-width:500px;margin-bottom:32px;animation:none;opacity:1}
.hero-row{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.btn-primary{padding:14px 28px;background:var(--yel);color:var(--ink);border-radius:22px;font-family:var(--f-display);font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:background .15s;text-decoration:none;border:none;cursor:pointer}
.btn-primary:hover{background:var(--yel-dk);transform:none}
.hero-secondary{font-family:var(--f-display);font-weight:500;font-size:15px;color:var(--grey);text-transform:none;letter-spacing:0;transition:color .15s}
.hero-secondary:hover{color:var(--ww)}
.hero-image{aspect-ratio:4/5;border-radius:14px;overflow:hidden;background:var(--ch-mid);position:relative;display:flex;align-items:flex-end;padding:24px;max-height:none}
.hero-image::before{display:none}
.hero-image::after{content:"fotó · a tér · reggeli fény";font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;background:rgba(0,0,0,.35);color:var(--ww-2);border-radius:4px}

/* ── PHOTO STRIP (Task 3a + 4b) — flat charcoal mosaic, 2px gap ── */
.photo-strip{max-width:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--ink);height:auto;min-height:0}
.photo-strip .ph{aspect-ratio:4/3;border-radius:0;overflow:hidden;display:flex;align-items:flex-end;justify-content:flex-start;padding:14px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ww-2);position:relative;border:none;background:var(--ink);height:auto}
.photo-strip .ph span{padding:4px 10px;background:rgba(0,0,0,.35);border-radius:4px;color:var(--ww-2)}
.photo-strip .ph-dark{background:var(--ink)}
.photo-strip .ph-mid{background:var(--ch-mid)}
.photo-strip .ph-warm{background:var(--ww-dk);color:var(--ink)}
.photo-strip .ph-warm span{background:rgba(44,44,42,.12);color:var(--ink)}

/* ── SECTIONS ── */
section{padding:72px 0}
.section-inner{max-width:var(--max);margin:0 auto;padding:0 var(--px)}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:16px;display:inline-block;font-weight:500}
.section-heading{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,4vw,36px);line-height:1.15;letter-spacing:-.01em;color:var(--ink);margin-bottom:48px;max-width:760px;text-wrap:balance}
.section-light{background:var(--ww);color:var(--ink);padding:72px 0}
.section-tint{background:var(--grey-bg);padding:72px 0}
.section-dark{background:var(--ink);color:var(--ww);padding:72px 0}
.section-dark .eyebrow{color:var(--grey)}
.section-dark .section-heading{color:var(--ww)}

/* ── HOGYAN MŰKÖDIK (rich variant — Task 7b cards 14px) ── */
.how-head{text-align:center;max-width:780px;margin:0 auto 56px}
.how-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:24px}
.how-eyebrow::before{content:"";display:block;width:40px;height:1px;background:var(--grey-lt)}
.how-h{font-family:var(--f-display);font-weight:600;font-size:clamp(30px,3vw,38px);line-height:1.1;letter-spacing:-.018em;color:var(--ink);margin-bottom:20px;text-wrap:balance}
.how-sub{font-family:var(--f-display);font-size:clamp(16px,1.4vw,19px);line-height:1.5;color:var(--grey-dk);max-width:580px;margin:0 auto}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.how-card{background:var(--grey-bg);border:1px solid var(--line);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:14px;transition:border-color .2s}
.how-card.active{border-color:var(--yel);border-width:2px;padding:23px}
.how-card .how-card-eye{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);display:flex;gap:8px}
.how-card .how-card-eye em{font-style:normal;color:var(--ink);font-weight:500}
.how-card h3{font-family:var(--f-display);font-weight:600;font-size:19px;line-height:1.25;color:var(--ink);letter-spacing:-.01em;margin:0}
.how-card p{font-size:14px;line-height:1.55;color:var(--grey-dk);margin:0}
.how-mock{margin-top:auto;background:var(--ww);border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;justify-content:center;min-height:118px}
.mock-cal{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.mc-day{background:var(--ww);border:1px solid var(--line);border-radius:6px;padding:10px 6px 8px;display:flex;flex-direction:column;align-items:center;gap:4px}
.mc-day .mcd-n{font-family:var(--f-display);font-weight:600;font-size:16px;color:var(--ink);letter-spacing:-.01em}
.mc-day .mcd-c{font-family:var(--f-mono);font-size:10px;color:var(--grey-dk)}
.mc-day.selected{background:var(--ink);border-color:var(--ink)}
.mc-day.selected .mcd-n{color:var(--ww)}
.mc-day.selected .mcd-c{color:var(--yel)}
.mock-sms{display:flex;flex-direction:column;gap:8px}
.sms-meta{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk)}
.sms-bubble{background:var(--ink);color:var(--ww);border-radius:12px 12px 12px 4px;padding:11px 14px;font-family:var(--f-body);font-size:13px;line-height:1.45;max-width:95%}
.sms-pin{font-family:var(--f-mono);font-weight:500;color:var(--yel);letter-spacing:.04em}
.mock-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;max-width:144px;margin:0 auto}
.kp{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-weight:500;font-size:13px;background:var(--ww);border:1px solid var(--line);color:var(--grey-lt)}
.kp.used{background:var(--ink);border-color:var(--ink);color:var(--yel)}
.kp.ok{background:var(--yel);border-color:var(--yel);color:var(--ink);font-size:15px}

/* ── FEATURE STRIPS (Task 3a — flat, no gradients) ── */
.feature-strip{max-width:var(--max);margin:0 auto;padding:12px var(--px);display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;min-height:0;direction:ltr}
.feature-strip.reverse .f-text{order:-1;direction:ltr}
.feature-strip .ph{aspect-ratio:auto;min-height:360px;border-radius:14px;display:flex;align-items:flex-end;justify-content:flex-start;padding:14px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ww-2);position:relative;background:var(--ch-mid);height:auto;border:none}
.feature-strip .ph span{padding:4px 10px;background:rgba(0,0,0,.35);border-radius:4px;color:var(--ww-2)}
.feature-strip .ph-dark{background:var(--ink)}
.feature-strip .ph-mid{background:var(--ch-mid)}
.feature-strip .ph-warm{background:var(--ww-dk);color:var(--ink)}
.feature-strip .ph-warm span{background:rgba(44,44,42,.12);color:var(--ink)}
.f-text{padding:0;background:transparent;display:block}
.f-eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:14px}
.f-title{font-family:var(--f-display);font-weight:600;font-size:clamp(26px,3vw,36px);line-height:1.15;letter-spacing:-.01em;color:var(--ink);margin-bottom:16px}
.f-desc{font-size:16px;line-height:1.625;color:var(--grey-dk);max-width:440px;margin-bottom:20px}
/* Trust micro — Task 7c badges 8px */
.trust-micro{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;color:var(--grey-dk);display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--grey-bg);border:1px solid var(--grey-lt);border-radius:8px;text-transform:none}
.trust-micro svg{width:14px;height:14px;fill:none;stroke:var(--grey-dk);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── PRICING — Task 2a price color swap, Task 7c pills 8px ── */
.pricing-center{text-align:center;max-width:640px;margin:0 auto}
.pricing-center .eyebrow{display:block;color:var(--grey)}
.price-big{font-family:var(--f-display);font-weight:700;font-size:clamp(72px,10vw,128px);line-height:1;letter-spacing:-.03em;color:var(--ww);margin-top:8px;margin-bottom:0}
.price-big small{font-size:.35em;font-weight:400;color:var(--grey)}
.price-unit{font-family:var(--f-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey);display:block;margin-top:8px;margin-bottom:32px}
.price-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px}
.price-pill{padding:8px 16px;background:var(--ink-2);border:1px solid var(--ink-3);border-radius:8px;font-family:var(--f-mono);font-size:12px;color:var(--ww-2);letter-spacing:.04em}
.price-note{font-family:var(--f-display);font-style:italic;font-size:16px;color:var(--grey);line-height:1.625;margin-bottom:32px}
.section-dark .btn-primary{background:var(--yel);color:var(--ink)}

/* ── LOCATIONS — Task 7b cards 14px, Task 8b no shadow lift ── */
.locations-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.loc-card{background:var(--ww);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .15s;display:block;text-decoration:none;color:inherit;box-shadow:none}
.loc-card:hover{border-color:var(--grey);box-shadow:none;transform:none}
.loc-card .ph{aspect-ratio:auto;height:240px;border-radius:0;background:var(--ink);display:flex;align-items:flex-end;padding:14px;font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ww-2);position:relative;border:none}
.loc-card .ph-mid{background:var(--ch-mid)}
.loc-card .ph span{padding:4px 10px;background:rgba(0,0,0,.35);border-radius:4px}
.loc-ci{padding:28px}
.loc-ci h3{font-family:var(--f-display);font-weight:600;font-size:24px;color:var(--ink);margin-bottom:8px;letter-spacing:-.01em}
.loc-ci p{font-size:14px;color:var(--grey-dk);line-height:1.5;margin-bottom:20px}
.loc-cm{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px;font-family:var(--f-mono);font-size:12px;color:var(--grey-dk);align-items:center}
.loc-cm span{display:inline-flex;align-items:center;gap:6px}
.loc-cm svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.loc-cp{display:flex;justify-content:flex-start;align-items:baseline;padding-top:20px;border-top:1px solid var(--line)}
.loc-cp strong{font-family:var(--f-display);font-weight:600;font-size:20px;color:var(--ink)}
.loc-cp span{font-size:13px;color:var(--grey-dk)}
.loc-cta{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);font-weight:500}
.loc-actions{display:flex;gap:10px;margin-top:16px}
.loc-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;padding:14px 18px;border-radius:999px;font-family:var(--f-display);font-weight:600;font-size:14px;letter-spacing:-.005em;text-decoration:none;text-align:center;transition:background .15s,border-color .15s,transform .15s;cursor:pointer;border:1px solid transparent}
.loc-btn--primary{background:var(--yel);color:var(--ink)}
.loc-btn--primary:hover{background:var(--yel-dk);transform:translateY(-1px)}
.loc-btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.loc-btn--ghost:hover{border-color:var(--ink);background:var(--ww-dk)}
.loc-card.disabled{opacity:.55;pointer-events:none}
.loc-card.disabled .loc-btn{cursor:not-allowed}

/* ── FOOTER (overrides legacy v6 footer) ── */
.footer{background:var(--ink);color:var(--ww);padding:56px var(--px) 32px;display:block}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;padding-bottom:32px;border-bottom:1px solid var(--ink-3);justify-content:flex-start;align-items:flex-start}
.footer-logo{font-family:var(--f-display);font-weight:700;font-size:22px;margin-bottom:12px;letter-spacing:-.01em}
.footer-logo .solo{color:var(--ww)}
.footer-logo .gym{color:var(--yel)}
.footer-tagline{font-size:14px;color:var(--grey);line-height:1.55;max-width:300px}
.footer-col h4{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey);margin-bottom:14px;font-weight:500}
.footer-col a{display:block;font-size:14px;color:var(--ww-2);margin-bottom:8px;transition:color .15s}
.footer-col a:hover{color:var(--ww)}
.footer-bottom{max-width:var(--max);margin:32px auto 0;font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--grey-dk);text-align:center;padding-top:0;border-top:none;display:block}

/* ── LANDING RESPONSIVE ── */
@media (max-width:900px){
  section.hero{padding:56px var(--px) 48px}
  section.hero .hero-inner{grid-template-columns:1fr;gap:32px}
  section.hero .hero-text{order:0}
  section.hero .hero-image{order:1;aspect-ratio:4/3;max-height:52vh}
  .photo-strip{grid-template-columns:1fr}
  .photo-strip .ph{height:auto}
  .how-grid,.locations-grid{grid-template-columns:1fr}
  .how-card{padding:28px}
  .feature-strip{grid-template-columns:1fr;gap:24px;padding:8px var(--px)}
  .feature-strip.reverse .f-text{order:0}
  .nav .nav-links{display:none}
  .nav .nav-ham{display:flex}
  section{padding:56px 0}
  .section-light,.section-dark,.section-tint{padding:56px 0}
  .footer-inner{grid-template-columns:1fr;gap:24px}
}

/* ════════════════════════════════════════════════════════════════════════
   v3 — HELYSZÍN (sg1.html)
   ════════════════════════════════════════════════════════════════════════ */

/* ── LOC HERO ── */
.loc-hero{padding:clamp(32px,3.5vw,56px) var(--px) clamp(20px,2vw,28px);background:var(--ww);border-bottom:none}
.loc-hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,3.5vw,48px);align-items:start}
.loc-crumb{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:18px;display:flex;gap:8px}
.loc-crumb a{color:var(--grey-dk);transition:color .15s}
.loc-crumb a:hover{color:var(--ink)}
.loc-hero h1{font-family:var(--f-display);font-weight:700;font-size:clamp(30px,3.2vw,42px);line-height:1.1;letter-spacing:-.018em;color:var(--ink);margin:0;text-wrap:balance}
.loc-hero h1 em{font-style:italic;font-weight:400;color:var(--grey-dk)}
.loc-hero .lede{font-family:var(--f-display);font-size:clamp(15px,1.3vw,17px);line-height:1.55;color:var(--grey-dk);max-width:520px;margin:20px 0 28px}
.loc-hero-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 22px;margin-bottom:28px;max-width:520px}
.loc-fact{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:var(--grey-bg);border-radius:8px}
.loc-fact .k{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk)}
.loc-fact .v{font-family:var(--f-display);font-weight:500;font-size:15px;color:var(--ink)}
.loc-hero-cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center;margin-bottom:24px}
.loc-hero-skip{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--grey-dk);text-decoration:none;transition:color .15s}
.loc-hero-skip:hover{color:var(--ink)}
.btn-ghost{padding:13px 22px;border:1px solid var(--ink);color:var(--ink);background:transparent;border-radius:22px;font-weight:500;font-size:15px;font-family:var(--f-display);transition:background .15s,color .15s;text-decoration:none;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
.btn-ghost:hover{background:var(--ink);color:var(--ww)}

/* Hero photos — Task 3a flat tones */
.loc-hero-photos{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:auto auto;gap:8px;min-height:380px}
.lhp{position:relative;border-radius:14px;overflow:hidden;background:var(--ww-2)}
.lhp::after{content:attr(data-label);position:absolute;bottom:12px;left:12px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ww-2);padding:4px 10px;background:rgba(0,0,0,.35);border-radius:4px}
.lhp-a{grid-row:span 2;background:var(--ink)}
.lhp-b{background:var(--ch-mid)}
.lhp-c{background:var(--ww-dk)}
.lhp-c::after{color:var(--ink);background:rgba(44,44,42,.12)}

/* ── LOC PLACE (address + map, hero-aligned columns) ── */
.loc-place{background:var(--ww);padding:clamp(20px,2vw,28px) var(--px) clamp(28px,3vw,40px);border-bottom:1px solid var(--line)}
.loc-place-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,3.5vw,48px);align-items:start}
.loc-place-map{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--grey-bg)}
.loc-place-map iframe{display:block;width:100%;height:240px;border:0}
.loc-place-text{padding:4px 0}
.lp-eyebrow{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:10px;font-weight:500}
.lp-address{font-family:var(--f-display);font-weight:600;font-size:clamp(17px,1.4vw,20px);color:var(--ink);line-height:1.3;margin-bottom:6px;letter-spacing:-.005em}
.lp-note{font-family:var(--f-body);font-size:13px;color:var(--grey-dk);line-height:1.5;margin-bottom:14px}
.lp-transit{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.lp-transit li{font-family:var(--f-body);font-size:13px;color:var(--grey-dk);line-height:1.5;padding-left:14px;position:relative}
.lp-transit li::before{content:"·";position:absolute;left:2px;top:-1px;color:var(--ink);font-weight:700}

/* First-free CTA — Task 7c (chip 8px not 100px) */
.first-free-cta{max-width:var(--max);margin:0 auto;padding:24px var(--px) 0}
.ff-card{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--grey-bg);border-left:3px solid var(--ink);border-radius:8px}
.ff-pulse{width:10px;height:10px;background:var(--yel);border-radius:50%;flex-shrink:0;box-shadow:0 0 0 0 rgba(245,197,24,.5);animation:ff-pulse 2s infinite}
@keyframes ff-pulse{0%{box-shadow:0 0 0 0 rgba(245,197,24,.5)}100%{box-shadow:0 0 0 14px rgba(245,197,24,0)}}
.ff-text{flex:1;font-size:14px;line-height:1.4;color:var(--ink)}
.ff-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);display:block;margin-bottom:2px}
.ff-text strong{font-weight:600}
.ff-btn{padding:10px 20px;background:var(--ink);color:var(--ww);border-radius:22px;font-size:13px;font-weight:600;font-family:var(--f-display);white-space:nowrap;cursor:pointer;border:none;transition:background .15s}
.ff-btn:hover{background:var(--ink-2)}

/* ── LISTING TOP ── */
.listing-top{max-width:calc(var(--max) + var(--px) * 2);margin:0 auto;padding:40px var(--px);display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:48px;align-items:start}
.content-top{padding:0}
.listing-bottom{max-width:var(--max);margin:0 auto;padding:0 var(--px) 60px}
.prop-header{padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:28px}
.prop-title{font-family:var(--f-display);font-weight:600;font-size:clamp(24px,3vw,32px);line-height:1.2;color:var(--ink);margin-bottom:8px;letter-spacing:-.01em}
.prop-sub{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em;color:var(--grey-dk);display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.prop-dot{width:3px;height:3px;border-radius:50%;background:var(--grey-lt);display:inline-block}
.highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:36px}
.hl{display:flex;gap:14px;padding:20px;background:var(--grey-bg);border-radius:14px;align-items:flex-start}
.hl-icon{width:36px;height:36px;flex-shrink:0;background:var(--ww);border-radius:8px;display:flex;align-items:center;justify-content:center}
.hl-icon svg{width:18px;height:18px;fill:none;stroke:var(--ink);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.hl h4{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:4px}
.hl p{font-size:13px;color:var(--grey-dk);line-height:1.4}
.loc-desc{font-family:var(--f-display);font-size:18px;line-height:1.55;color:var(--grey-dk);padding:0 0 36px;border-bottom:1px solid var(--line);margin-bottom:36px;max-width:640px;background:transparent}
.amen-title,.loc-how-title,.loc-info-title{font-family:var(--f-display);font-weight:600;font-size:20px;color:var(--ink);margin-bottom:18px;letter-spacing:0}
.amen-cat-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin:24px 0 12px;padding:0;border:none}
.amen-cat-label:first-of-type{padding-top:0}
.amen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:0}
.amen-item{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--ww);border:1px solid var(--line);border-radius:8px;font-size:13px;color:var(--ink)}
.amen-item svg{width:18px;height:18px;flex-shrink:0;fill:none;stroke:var(--ink);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.amen-grid--single{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:0}
.loc-how{margin-top:36px;padding:28px 0 0;border-top:1px solid var(--line);border-bottom:none}
.hw-step{display:flex;gap:18px;padding:16px 0;border-bottom:1px dashed var(--line);align-items:flex-start}
.hw-step:last-child{border-bottom:none}
.hw-step-n{width:28px;height:28px;flex-shrink:0;background:var(--grey-bg);color:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-weight:600;font-size:12px}
.hw-step h4{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:3px}
.hw-step p{font-size:13px;color:var(--grey-dk);line-height:1.5}

/* Sidebar book card — Task 7b 14px, Task 8b no shadow */
.listing-sidebar{position:sticky;top:90px;display:block;padding:0}
.book-card{background:var(--ww);border:1px solid var(--line);border-radius:14px;padding:22px;box-shadow:none;position:static}
.bc-price{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.bc-price strong{font-family:var(--f-display);font-weight:700;font-size:26px;line-height:1.1;color:var(--ink);letter-spacing:-.02em}
.bc-price span{font-size:13px;color:var(--grey-dk)}
.bc-per{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:16px}
.bc-cta{display:block;width:100%;padding:12px;background:var(--yel);color:var(--ink);border:none;border-radius:22px;text-align:center;text-decoration:none;font-family:var(--f-display);font-weight:600;font-size:14px;cursor:pointer;transition:background .15s}
.bc-cta:hover{background:var(--yel-dk)}
.bc-sub{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;color:var(--success);text-align:center;margin-top:10px}
.bc-div{height:1px;background:var(--line);margin:20px 0}
.bc-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0;padding:0}
.bc-list li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink)}
.bc-list svg{width:16px;height:16px;flex-shrink:0;fill:none;stroke:var(--ink);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.bc-trust{margin-top:20px;padding:14px 16px;background:var(--grey-bg);border-radius:8px;font-size:12px;line-height:1.5;color:var(--grey-dk);font-style:italic}
.bc-pay{margin-top:14px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);text-align:center}

/* ── BOOKING SECTION (sg1) ── */
body.v6 .booking-section,
.booking-section{background:var(--grey-bg);padding:36px 0 48px;margin-top:16px;border:none}
.booking-inner{max-width:calc(var(--max) + var(--px) * 2);margin:0 auto;padding:0 var(--px)}
.book-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:8px;font-weight:500}
.book-heading{font-family:var(--f-display);font-weight:600;font-size:clamp(22px,2.6vw,28px);line-height:1.15;color:var(--ink);margin-bottom:6px;letter-spacing:-.01em}
.book-sub{font-size:13px;color:var(--grey-dk);margin-bottom:18px}

/* Progress steps — Task 7c badges 8px not 100px */
.progress-steps{position:relative;display:flex;align-items:center;gap:12px;padding:6px 0;margin-bottom:14px;background:transparent;font-size:13px;color:var(--grey-dk);justify-content:flex-start;top:auto;z-index:auto}
.progress-steps::before,.progress-steps::after{display:none}
.step{display:flex;align-items:center;gap:8px;font-family:var(--f-mono);font-size:12px;letter-spacing:.06em;color:var(--grey-dk);padding:8px 14px;background:var(--ww);border:1px solid var(--line);border-radius:8px;white-space:nowrap;transition:none}
.step.active{background:var(--ink);color:var(--ww);border-color:var(--ink)}
.step.active .step-num{background:var(--yel);color:var(--ink)}
.step-num{width:22px;height:22px;border-radius:50%;background:var(--grey-bg);color:var(--grey-dk);display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:11px;margin:0}
.step-line{flex:1;height:1px;background:var(--line);width:auto;margin:0}
.drawer-progress{position:static;margin:0 auto 22px;padding:0;background:transparent;border-radius:0;gap:14px;font-size:12px;display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;width:fit-content;max-width:100%}
.drawer-progress .step{padding:0;font-size:12px;gap:8px;justify-content:flex-start;white-space:nowrap;background:transparent;border:none;border-radius:0;color:var(--grey-dk);font-family:var(--f-display);font-weight:500;letter-spacing:-.005em;transition:color .2s}
.drawer-progress .step-num{display:inline-flex;align-items:center;justify-content:center;width:auto;height:auto;min-width:18px;padding:0;background:transparent;border:none;border-radius:0;color:var(--grey);font-family:var(--f-mono);font-size:10px;font-weight:500;letter-spacing:.08em;flex:none;transition:color .2s}
.drawer-progress .step-num::before{content:"0"}
.drawer-progress .step.active{color:var(--ink);font-weight:600}
.drawer-progress .step.active .step-num{color:var(--yel-dk)}
.drawer-progress .step.completed{color:var(--ink)}
.drawer-progress .step.completed .step-num{color:var(--ink)}
.drawer-progress .step-line{display:block;width:18px;height:1px;background:var(--line);margin:0;flex:none}

.booking-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:32px;grid-template-rows:auto;align-items:start}
.cal-and-slots{display:grid;grid-template-columns:minmax(260px,300px) minmax(0,1fr);gap:20px;align-items:start}
.cal-and-slots .slots-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.cal-and-slots .slot-card{padding:10px 8px;min-height:48px}
.cal-wrap{background:var(--ww);border:1px solid var(--line);border-radius:14px;padding:14px 18px;margin-bottom:0}
.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.cal-month{font-family:var(--f-display);font-weight:600;font-size:17px;color:var(--ink)}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:32px;height:32px;border-radius:8px;background:var(--grey-bg);border:1px solid var(--line);color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}
.cal-nav button:hover{background:var(--ink);color:var(--ww);border-color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-dow,.cal-day-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-dk);text-align:center;padding:4px 0;font-weight:500}
.cal-day{aspect-ratio:1;max-width:44px;width:100%;margin:0 auto;border-radius:999px;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-size:13px;color:var(--ink);background:transparent;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s,transform .1s ease;height:auto;font-weight:500;-webkit-tap-highlight-color:transparent;position:relative}
.cal-day:hover{background:rgba(44,44,42,.06);border-color:transparent}
.cal-day:active{background:rgba(44,44,42,.08);transform:scale(.96)}
.cal-day.empty{background:transparent;cursor:default;border:none;pointer-events:none}
.cal-day.past,.cal-day.other-month{color:rgba(44,44,42,.22);cursor:not-allowed;pointer-events:none;text-decoration:line-through;text-decoration-color:rgba(44,44,42,.18)}
.cal-day.other-month{text-decoration:none;color:rgba(44,44,42,.22)}
/* Other-month cells in booking range stay subtle but become clickable
   (jump the view to that month and select). */
.cal-day.other-month.has-slots{cursor:pointer;pointer-events:auto;color:rgba(44,44,42,.45)}
.cal-day.other-month.has-slots:hover{background:rgba(44,44,42,.06);color:var(--ink)}
.cal-day.other-month.selected{background:var(--yel);border-color:var(--yel);color:var(--ink);font-weight:700}
.cal-day.today{border-color:rgba(44,44,42,.35);color:var(--ink);font-weight:600}
.cal-day.has-slots{color:var(--ink);font-weight:500}
.cal-day.has-slots::after{display:none}
.cal-day.selected,.cal-day.selected.has-slots,.cal-day.today.selected{background:var(--yel);color:var(--ink);font-weight:700;border-color:var(--yel)}
.cal-day.selected:hover{background:var(--yel);border-color:var(--yel)}

.slots-header{font-family:var(--f-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:10px;font-weight:500}
.slots-sub{font-family:var(--f-mono);font-size:10px;color:var(--grey-dk);letter-spacing:.06em;text-transform:uppercase;margin-left:8px;font-weight:400}
.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.slot-card{padding:12px 14px;background:var(--ww);border:1px solid var(--line);border-radius:8px;font-family:var(--f-mono);font-size:13px;color:var(--ink);text-align:center;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:2px;align-items:center;min-height:52px;justify-content:center}
.slot-card:hover{border-color:var(--ink)}
.slot-card:active{border-color:var(--ink)}
.slot-card.in-cart,.slot-card.selected{background:var(--yel);border-color:var(--yel);color:var(--ink);font-weight:600}
.slot-card.in-cart:hover{background:var(--yel-dk);border-color:var(--yel-dk)}
.slot-card.in-cart .slot-price,.slot-card.selected .slot-price{color:var(--ink)}
.slot-card[disabled],.slot-card.taken,.slot-card.booked{background:var(--grey-bg);color:var(--grey-lt);text-decoration:line-through;cursor:not-allowed;border-color:var(--line);opacity:1}
.slot-card.booked:hover{border-color:var(--line)}
.slot-card.booked .slot-price{color:var(--grey-lt)}
.slot-time{font-family:var(--f-mono);font-weight:500;font-size:13px}
.slot-price{font-family:var(--f-mono);font-size:11px;color:var(--grey-dk);letter-spacing:.04em;margin-top:1px}
.slots-empty{grid-column:1/-1;padding:20px;text-align:center;color:var(--grey-dk);font-size:14px;font-style:italic}
.slot-skeleton{background:var(--grey-bg);border-radius:8px;min-height:48px;animation:pulse 1.2s ease-in-out infinite}

/* Sidebar / cart — Task 7b 14px */
.booking-sidebar{position:sticky;top:90px}
.sidebar-card{background:var(--ww);border:1px solid var(--line);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:16px;position:sticky;top:90px;box-shadow:none}
.sidebar-card::before{display:none}
.sidebar-title{font-family:var(--f-display);font-weight:600;font-size:17px;color:var(--ink);margin-bottom:0;display:flex;align-items:center;gap:8px}
.cart-count{font-family:var(--f-mono);font-size:11px;padding:2px 8px;background:var(--yel);color:var(--ink);border-radius:8px;font-weight:500}
.cart-empty{color:var(--grey-dk);font-size:13px;font-style:italic}
.cart-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px dashed var(--line);font-size:13px}
.cart-row-meta{font-family:var(--f-mono);font-size:11px;color:var(--grey-dk)}
.cart-row strong{font-family:var(--f-display);font-weight:600;font-size:14px}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;margin-top:8px}
.cart-total span{font-size:13px;color:var(--grey-dk)}
.cart-total strong{font-family:var(--f-display);font-weight:700;font-size:20px;color:var(--ink)}
.sidebar-fields{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.sidebar-fields input{padding:13px 14px;border:1px solid var(--line);border-radius:8px;font-family:var(--f-body);font-size:15px;background:var(--ww);outline:none;color:var(--ink);width:100%;min-height:48px;-webkit-appearance:none;transition:border-color .15s,box-shadow .15s}
.sidebar-fields input:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(245,197,24,.25)}
.sidebar-fields input::placeholder{color:var(--grey-dk)}
.sidebar-btn{width:100%;padding:14px;margin-top:16px;background:var(--yel);color:var(--ink);border:none;border-radius:22px;font-family:var(--f-display);font-weight:600;font-size:15px;cursor:pointer;transition:background .15s;-webkit-appearance:none}
.sidebar-btn:hover{background:var(--yel-dk)}
.sidebar-btn:disabled{background:var(--grey-lt);color:var(--grey-dk);cursor:not-allowed;opacity:1}
.sidebar-note{margin-top:14px;font-size:12px;line-height:1.5;color:var(--grey-dk);text-align:center}
.consent-notice{font-family:var(--f-body);font-size:12px;line-height:1.5;color:var(--grey-dk);text-align:center;margin:12px 0 4px}
.consent-notice a{color:var(--grey-dk);text-decoration:underline;text-underline-offset:2px}
.consent-notice a:hover{color:var(--ink)}

/* Cart inner content (booking.js generated) */
#cartContent .cart-row{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px dashed var(--line);font-size:13px;gap:8px}
#cartContent .cart-item-time{flex:1;font-family:var(--f-display);font-weight:600;font-size:14px;color:var(--ink)}
#cartContent .cart-item-loc{font-family:var(--f-mono);font-size:11px;color:var(--grey-dk);margin-top:2px}
#cartContent .cart-item-price{font-family:var(--f-display);font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap}
#cartContent .cart-item-remove{background:transparent;border:none;color:var(--grey-dk);cursor:pointer;padding:4px;font-size:14px;line-height:1}
#cartContent .cart-item-remove:hover{color:var(--ink)}
#cartContent .cart-empty{color:var(--grey-dk);font-style:italic;font-size:13px;padding:8px 0}
#cartContent .cart-total-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0 4px;margin-top:4px;border-top:1px solid var(--line)}
#cartContent .cart-total-row span{font-size:13px;color:var(--grey-dk)}
#cartContent .cart-total-row strong{font-family:var(--f-display);font-weight:700;font-size:20px;color:var(--ink)}
#cartContent .cart-discount{font-family:var(--f-mono);font-size:11px;color:var(--success);padding:4px 0}
#cartContent .cart-summary{padding-top:12px;margin-top:8px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:6px}
#cartContent .cart-summary-row{display:flex;justify-content:space-between;font-size:13px}

/* Kupon UI (in-cart) */
.promo-toggle{background:none;border:none;color:var(--grey-dk);font-family:var(--f-body),'Inter',sans-serif;font-size:13px;cursor:pointer;padding:6px 0;text-align:left;transition:color .15s;align-self:flex-start}
.promo-toggle:hover{color:var(--ink)}
.promo-input-row{display:flex;gap:8px;margin:4px 0 0}
.promo-input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--ww);font-family:var(--f-mono),'JetBrains Mono',monospace;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink);outline:none;-webkit-appearance:none;min-width:0}
.promo-input:focus{border-color:var(--ink)}
.promo-apply-btn{padding:10px 14px;background:var(--ink);color:var(--ww);border:none;border-radius:8px;font-family:var(--f-display),'DM Sans',sans-serif;font-weight:500;font-size:13px;cursor:pointer;transition:background .15s;white-space:nowrap}
.promo-apply-btn:hover{background:var(--ink-2)}
.promo-error{color:var(--error);font-size:12px;margin-top:4px;font-family:var(--f-body),'Inter',sans-serif}
.promo-applied{display:flex;align-items:center;gap:8px;background:var(--yel-lt);border-left:3px solid var(--yel);border-radius:8px;padding:10px 12px;margin:4px 0 0;font-family:var(--f-body),'Inter',sans-serif;font-size:13px;color:var(--ink);flex-wrap:wrap}
.promo-applied .promo-icon{color:var(--success);font-weight:700}
.promo-applied .promo-code-label{font-family:var(--f-mono),'JetBrains Mono',monospace;font-weight:500;letter-spacing:.04em}
.promo-applied .promo-note{margin-left:auto;color:var(--grey-dk);font-size:12px}
.promo-applied .promo-remove{background:none;border:none;color:var(--grey-dk);font-size:18px;line-height:1;cursor:pointer;padding:0 4px;transition:color .15s}
.promo-applied .promo-remove:hover{color:var(--ink)}

.cart-error{background:var(--yel-lt);color:var(--ink);padding:10px 14px;border-radius:8px;font-size:13px;line-height:1.4;margin:10px 0;border-left:3px solid var(--yel);display:none}
.sidebar-close{display:none;position:absolute;top:14px;right:14px;background:transparent;border:none;font-size:24px;color:var(--grey-dk);cursor:pointer;padding:4px 10px;line-height:1;z-index:2}
.sheet-handle{display:none}
.sheet-bar{display:none}
.cart-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:94;opacity:0;pointer-events:none;transition:opacity .3s cubic-bezier(.4,0,.2,1)}
.cart-overlay.visible{opacity:1;pointer-events:auto}

/* ── LOC INFO ── */
.loc-info-section{max-width:var(--max);margin:0 auto;padding:80px var(--px)}
.loc-detail{display:flex;align-items:center;gap:14px;padding:16px 20px;margin-bottom:8px;background:var(--grey-bg);border-radius:8px;font-size:14px;color:var(--ink)}
.loc-detail svg{width:18px;height:18px;flex-shrink:0;fill:none;stroke:var(--grey-dk);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.map-placeholder{margin-top:20px}
.map-ph{aspect-ratio:16/7;border-radius:14px;background:var(--grey-bg);display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-size:12px;color:var(--grey-dk);letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line)}

/* ── IG SECTION (sg1) ── */
.ig-section{max-width:var(--max);margin:0 auto;padding:80px var(--px);border-top:1px solid var(--line);background:var(--ww)}
.ig-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:36px;max-width:none}
.ig-label-text{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:12px;display:inline-block;font-weight:500}
.ig-heading{font-family:var(--f-display);font-weight:600;font-size:clamp(28px,3.5vw,36px);line-height:1.15;color:var(--ink);letter-spacing:-.01em}
.ig-heading span{color:var(--grey-dk);font-weight:400}
.ig-handle{margin-top:10px;font-family:var(--f-mono);font-size:13px;color:var(--grey-dk)}
.ig-follow-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--ink);color:var(--ww);border-radius:22px;font-size:14px;font-weight:500;font-family:var(--f-display);text-decoration:none;border:none;cursor:pointer}
.ig-follow-btn:hover{background:var(--ink-2);color:var(--ww);border-color:var(--ink-2)}
.ig-follow-btn svg{width:18px;height:18px}
.ig-grid-preview{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.ig-grid-preview .ig-card{aspect-ratio:4/5;border-radius:14px;overflow:hidden;background:var(--ww-2);position:relative;display:flex;align-items:flex-end;padding:14px;flex-shrink:0;width:auto;border:none;cursor:default;transform:none;box-shadow:none}
.ig-grid-preview .ig-card:hover{transform:none;box-shadow:none}
.ig-grid-preview .ig-card[data-tone="dark-1"]{background:var(--ink)}
.ig-grid-preview .ig-card[data-tone="dark-2"]{background:var(--ch-mid)}
.ig-grid-preview .ig-card[data-tone="wood"]{background:var(--ch-mid)}
.ig-grid-preview .ig-card[data-tone="textile"]{background:var(--ww-dk)}
.ig-grid-preview .ig-card[data-tone="light"]{background:var(--ww-dk)}
.ig-caption-chip{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;background:rgba(0,0,0,.35);color:var(--ww-2);border-radius:4px}
.ig-grid-preview .ig-card[data-tone="textile"] .ig-caption-chip,
.ig-grid-preview .ig-card[data-tone="light"] .ig-caption-chip{background:rgba(44,44,42,.12);color:var(--ink)}

/* ── STICKY BAR (sg1) ── */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:40;display:none;align-items:center;justify-content:space-between;padding:12px 20px calc(12px + env(safe-area-inset-bottom));background:var(--ww);border-top:1px solid var(--line);border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:none}
.sticky-bar.has-selection{background:var(--ink);border-top-color:var(--ink)}
.sb-left{display:flex;flex-direction:column;gap:2px;line-height:1.1}
.sb-left strong{font-family:var(--f-display);font-size:15px;font-weight:600;color:var(--ink);margin-left:0}
.sb-left span{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey-dk);margin-left:0}
.sticky-bar.has-selection .sb-left strong,.sticky-bar.has-selection .sb-left span{color:var(--ww)}
.sb-btn{padding:10px 20px;background:var(--yel);color:var(--ink);border-radius:22px;font-size:14px;font-weight:600;font-family:var(--f-display);text-decoration:none}
.sb-btn:hover{background:var(--yel-dk)}

/* ── HELYSZÍN RESPONSIVE ── */
@media (min-width:1001px){
  .cal-day{aspect-ratio:1;height:auto}
}
@media (max-width:1000px){
  .listing-top{grid-template-columns:1fr;gap:32px}
  .listing-sidebar{position:static}
  .booking-layout{grid-template-columns:1fr;gap:24px}
  .cal-and-slots{grid-template-columns:1fr;gap:16px}
  .ig-grid-preview{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:900px){
  .loc-hero-inner{grid-template-columns:1fr;gap:32px}
  .loc-hero-photos{min-height:300px}
  .highlights{grid-template-columns:1fr}
  .loc-place-inner{grid-template-columns:1fr;gap:20px}
  .loc-place-map iframe{height:200px}
  .amen-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .loc-hero-facts{grid-template-columns:1fr}
  .progress-steps{gap:6px;padding:8px 0}
  .progress-steps .step-line{display:none}
  .step{padding:6px 10px;font-size:11px;gap:6px;flex:1;justify-content:center}
  .step-num{width:18px;height:18px;font-size:10px}
  .slots-grid{grid-template-columns:repeat(2,1fr)}
  .ig-grid-preview{grid-template-columns:repeat(2,1fr)}
  .amen-grid,.amen-grid--single{grid-template-columns:repeat(2,1fr);gap:8px}
  .amen-item{padding:10px 12px;font-size:13px}
}

/* sg1 mobile bottom-sheet (preserved as-is from sg1 inline) */
@media (min-width:901px){
  .cart-overlay{display:none}
  .booking-inner > .progress-steps{display:none}
}
@media (max-width:900px){
  .nav .nav-ham{display:flex}
  body.loc-page{padding-bottom:0}
  .sticky-bar{display:flex}
  body.has-cart .sticky-bar{display:none}
  .booking-sidebar{display:flex !important;flex-direction:column;position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;height:auto;max-height:calc(var(--vvh, 100dvh) - env(safe-area-inset-top, 0px) - 48px);background:var(--ink);color:var(--ww);border-top-left-radius:16px;border-top-right-radius:16px;padding:0;z-index:95;overflow:hidden;box-shadow:0 -4px 24px rgba(0,0,0,.25);transform:translateY(calc(100% - 92px - env(safe-area-inset-bottom)));transition:transform .3s cubic-bezier(.4,0,.2,1)}
  .booking-sidebar.empty{transform:translateY(100%)}
  .booking-sidebar.expanded{transform:translateY(0)}
  .sheet-handle{display:flex;justify-content:center;align-items:center;padding:10px 0 6px;cursor:pointer;flex-shrink:0;touch-action:none}
  .handle-pill{width:36px;height:4px;background:var(--grey);border-radius:2px}
  .sheet-bar{display:flex;align-items:center;justify-content:space-between;padding:4px 20px calc(14px + env(safe-area-inset-bottom));cursor:pointer;flex-shrink:0;gap:12px}
  .sheet-bar-info{display:flex;flex-direction:column;gap:2px;line-height:1.1;min-width:0}
  .sheet-bar-info strong{font-family:var(--f-display);font-size:15px;font-weight:600;color:var(--ww);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sheet-bar-info span{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--grey)}
  .sheet-bar-cta{padding:10px 20px;background:var(--yel);color:var(--ink);border:none;border-radius:22px;font-family:var(--f-display);font-weight:600;font-size:14px;cursor:pointer;white-space:nowrap;flex-shrink:0}
  .sheet-bar-cta:hover{background:var(--yel-dk)}
  .booking-sidebar.expanded .sheet-bar{display:none}
  .booking-sidebar .sidebar-card{position:static;background:var(--ink);color:var(--ww);border:none;border-radius:0;padding:18px 20px calc(20px + env(safe-area-inset-bottom));overflow-y:auto;flex:1;border-top:1px solid rgba(245,243,239,.08);box-shadow:none}
  .sidebar-close{display:none;color:var(--ww);font-size:22px}
  .booking-sidebar.expanded .sidebar-close{display:block}
  .booking-sidebar .sidebar-title{color:var(--ww)}
  .booking-sidebar .cart-count{background:var(--yel);color:var(--ink)}
  .booking-sidebar .drawer-progress{background:transparent;margin-bottom:14px}
  .booking-sidebar .drawer-progress .step{background:transparent;border-color:rgba(245,243,239,.15);color:var(--grey)}
  .booking-sidebar .drawer-progress .step.active{background:var(--ink-2);color:var(--ww);border-color:var(--ink-2)}
  .booking-sidebar .drawer-progress .step.active .step-num{background:var(--yel);color:var(--ink)}
  .booking-sidebar .drawer-progress .step:not(.active) .step-num{background:var(--ink-3);color:var(--grey)}
  .booking-sidebar #cartContent{margin-bottom:12px}
  .booking-sidebar #cartContent .cart-group{padding:6px 0}
  .booking-sidebar #cartContent .cart-group-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--grey);padding:8px 0 4px}
  .booking-sidebar #cartContent .cart-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(245,243,239,.08)}
  .booking-sidebar #cartContent .cart-item:last-child{border-bottom:none}
  .booking-sidebar #cartContent .cart-item-time{flex:1;font-family:var(--f-display);font-weight:600;font-size:14px;color:var(--ww)}
  .booking-sidebar #cartContent .cart-item-price{font-family:var(--f-display);font-weight:600;font-size:14px;color:var(--ww);white-space:nowrap}
  .booking-sidebar #cartContent .cart-item-remove{background:transparent;border:none;color:var(--grey);cursor:pointer;padding:4px 8px;font-size:18px;line-height:1}
  .booking-sidebar #cartContent .cart-item-remove:hover{color:var(--ww)}
  .booking-sidebar #cartContent .cart-summary{padding-top:12px;margin-top:8px;border-top:1px solid rgba(245,243,239,.15)}
  .booking-sidebar #cartContent .cart-summary-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--grey)}
  .booking-sidebar #cartContent .cart-total-row{padding:10px 0 4px;border-top:none;margin-top:0}
  .booking-sidebar #cartContent .cart-total-row span:first-child{color:var(--grey)}
  .booking-sidebar #cartContent .cart-total{font-family:var(--f-display);font-weight:700;font-size:20px;color:var(--ww)}
  .booking-sidebar #cartContent .cart-discount{color:var(--yel)}
  .booking-sidebar #cartContent .promo-toggle{color:var(--grey)}
  .booking-sidebar #cartContent .promo-toggle:hover{color:var(--ww)}
  .booking-sidebar #cartContent .promo-input{background:var(--ink-2);color:var(--ww);border-color:var(--ink-3)}
  .booking-sidebar #cartContent .promo-input:focus{border-color:var(--yel)}
  .booking-sidebar #cartContent .promo-applied{background:rgba(245,197,24,.12);color:var(--ww)}
  .booking-sidebar #cartContent .promo-applied .promo-note{color:var(--grey)}
  .booking-sidebar #cartContent .promo-applied .promo-remove{color:var(--grey)}
  .booking-sidebar #cartContent .promo-applied .promo-remove:hover{color:var(--ww)}
  .booking-sidebar .cart-error{background:rgba(245,197,24,.14);color:var(--ww)}
  .booking-sidebar .sidebar-fields input{background:var(--ink-2);color:var(--ww);border-color:var(--ink-3)}
  .booking-sidebar .sidebar-fields input::placeholder{color:var(--grey)}
  .booking-sidebar .sidebar-fields input:focus{border-color:var(--yel)}
  .booking-sidebar .sidebar-btn{min-height:48px;border-radius:22px}
  .booking-sidebar .consent-notice{color:var(--grey)}
  .booking-sidebar .consent-notice a{color:var(--ww)}
  .booking-sidebar .consent-notice a:hover{color:var(--yel)}
  .booking-sidebar .sidebar-note{color:var(--grey)}
  .sidebar-card{position:static}
}

/* ═══════════════════════════════════════════════════════════════
   NEW SECTIONS — »A privát itt nem szlogen« + »Egy slot, akár négyen«
   Append to web/css/style.css (után a v3 single-source blokk után)
   Brand Guideline v3 §1.1 §3.2 §4.1 §9.1
   ═══════════════════════════════════════════════════════════════ */

/* shared eyebrow / heading / lede — only used inside these sections */
#privat .s-eyebrow,
#slot .s-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-dk);margin-bottom:24px}
#privat .s-eyebrow::before,
#slot .s-eyebrow::before{content:"";display:block;width:40px;height:1px;background:var(--grey-lt)}
#privat .s-headline,
#slot .s-headline{font-family:var(--f-display);font-weight:700;font-size:clamp(36px,5.5vw,64px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin-bottom:20px;max-width:14ch}
#privat .s-lede,
#slot .s-lede{font-family:var(--f-display);font-size:clamp(15px,1.4vw,18px);line-height:1.55;color:var(--grey-dk);max-width:560px}
#privat .s-lede em,
#slot .s-lede em{font-style:italic;color:var(--ink)}

/* dark-section overrides (slot) */
#slot.section-dark .s-eyebrow{color:var(--grey)}
#slot.section-dark .s-eyebrow::before{background:var(--ink-3)}
#slot.section-dark .s-headline{color:var(--ww)}
#slot.section-dark .s-lede{color:var(--grey)}
#slot.section-dark .s-lede em{color:var(--ww)}

/* ─── SECTION 1 — privát (Soft Grey Bg) ─── */
.sec-private{background:var(--grey-bg);padding:clamp(72px,10vh,120px) var(--px)}
.sec-private .sec-inner{max-width:var(--max);margin:0 auto}
.sec-private .sec-head{max-width:760px;margin-bottom:56px}

.priv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:32px}
.priv-card{background:var(--ww);border:1px solid var(--line);border-radius:22px;padding:40px;display:flex;flex-direction:column;gap:24px;transition:border-color .2s}
.priv-card:hover{border-color:var(--ink)}
.priv-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center}
.priv-icon svg{width:48px;height:48px;stroke:var(--ink);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.priv-card h3{font-family:var(--f-display);font-weight:700;font-size:clamp(24px,2.4vw,30px);line-height:1.15;letter-spacing:-.01em;color:var(--ink)}
.priv-card p{font-size:15px;line-height:1.65;color:var(--grey-dk)}
.priv-divider{height:1px;background:var(--line);margin:4px 0}
.priv-list{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0;margin:0}
.priv-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;line-height:1.55;color:var(--ink)}
.priv-list li::before{content:"";display:block;flex-shrink:0;width:14px;height:1px;background:var(--ink);margin-top:11px}

/* comparison strip — charcoal */
.compare-strip{display:grid;grid-template-columns:1fr 1fr;background:var(--ink);color:var(--ww);border-radius:18px;overflow:hidden;margin-top:8px}
.cmp-half{padding:28px 32px;display:flex;flex-direction:column;gap:6px;position:relative}
.cmp-half + .cmp-half{border-left:1px solid var(--ink-3)}
.cmp-half.right{background:rgba(245,197,24,.04)}
.cmp-eye{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey)}
.cmp-half.right .cmp-eye{color:var(--yel)}
.cmp-line{font-family:var(--f-display);font-weight:500;font-size:15px;line-height:1.4;color:var(--ww-dk)}
.cmp-half.right .cmp-line{color:var(--ww);font-weight:600}
.cmp-line .strike{color:var(--grey);text-decoration:line-through;text-decoration-color:var(--ink-3);text-decoration-thickness:1.5px}

/* ─── SECTION 2 — slot (Charcoal) ─── */
.sec-slot{background:var(--ink);color:var(--ww);padding:clamp(72px,10vh,120px) var(--px)}
.sec-slot .sec-inner{max-width:var(--max);margin:0 auto}
.sec-slot .sec-head{max-width:760px;margin-bottom:32px}

.slot-cta{display:inline-flex;align-items:center;margin-top:28px;padding:16px 28px;background:var(--yel);color:var(--ink);font-family:var(--f-display);font-weight:600;font-size:15px;letter-spacing:-.005em;border-radius:999px;text-decoration:none;transition:transform .15s,background .15s}
.slot-cta:hover{background:var(--yel-dk);transform:translateY(-1px)}

.sec-slot .slot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:56px;margin-bottom:28px}
.sec-slot .slot-card{position:relative;background:var(--ink-2);border:1px solid var(--ink-3);border-radius:18px;padding:32px 24px 28px;display:flex;flex-direction:column;align-items:flex-start;gap:20px;transition:border-color .2s;min-height:0;cursor:default;font-family:inherit;font-size:inherit;color:var(--ww);text-align:left;justify-content:flex-start}
.sec-slot .slot-card:hover{border-color:var(--grey)}
.sec-slot .slot-card.featured{background:var(--ink-2);border-color:var(--yel);border-width:1.5px}
.sec-slot .slot-card.featured:hover{border-color:var(--yel)}
.sec-slot .slot-badge{position:absolute;top:-11px;left:24px;font-family:var(--f-mono);font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;background:var(--yel);color:var(--ink);padding:4px 10px;border-radius:6px}

.sec-slot .slot-figs{display:flex;align-items:flex-end;gap:6px;height:48px;margin-bottom:4px}
.sec-slot .slot-figs .fig{width:26px;height:44px;display:block;flex-shrink:0}
.sec-slot .slot-figs .fig svg{width:100%;height:100%;stroke:var(--grey);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.sec-slot .slot-card.featured .slot-figs .fig svg{stroke:var(--ww)}

.sec-slot .slot-count{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey)}
.sec-slot .slot-price-row{display:flex;align-items:baseline;gap:6px;margin-top:auto}
.sec-slot .slot-price{font-family:var(--f-display);font-weight:700;font-size:clamp(28px,3vw,36px);letter-spacing:-.02em;color:var(--ww);line-height:1;margin-top:0}
.sec-slot .slot-card.featured .slot-price{color:var(--yel)}
.sec-slot .slot-price small{font-family:var(--f-mono);font-size:12px;font-weight:400;color:var(--grey);letter-spacing:.04em;margin-left:2px}
.sec-slot .slot-per{font-family:var(--f-mono);font-size:12px;color:var(--grey);letter-spacing:.06em}

.sec-slot .slot-foot{display:flex;align-items:flex-start;justify-content:space-between;gap:32px;padding-top:24px;border-top:1px solid var(--ink-3);flex-wrap:wrap}
.sec-slot .slot-foot p{font-size:14px;line-height:1.6;color:var(--grey);max-width:580px}
.sec-slot .slot-foot .slot-max{font-family:var(--f-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ww);white-space:nowrap;flex-shrink:0;padding-top:2px}

/* ─── responsive ─── */
@media (max-width:900px){
  .priv-grid{grid-template-columns:1fr;gap:14px}
  .priv-card{padding:32px 28px}
  .sec-slot .slot-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .sec-slot .slot-foot{flex-direction:column;gap:14px}
  .sec-slot .slot-foot .slot-max{align-self:flex-start}
  .compare-strip{grid-template-columns:1fr}
  .cmp-half + .cmp-half{border-left:none;border-top:1px solid var(--ink-3)}
}
@media (max-width:560px){
  .priv-card{padding:28px 24px;gap:20px;border-radius:18px}
  .sec-slot .slot-card{padding:28px 20px 24px;border-radius:16px}
  .slot-cta{padding:14px 24px;font-size:14px}
}

/* ═══════════════════════════════════════════════════════════════
   helyszin/sg1 — DESIGN OVERRIDE LAYER (matches Claude design v3)
   - bigger 2-line slot cards (time + price/lejárt/foglalt sub)
   - selected slot = charcoal (in-cart kept yellow for multi-select)
   - cart group label = yellow uppercase mono meta
   - aftercare reassurance strip
   - hero photo placeholders with diagonal stripe pattern
   No JS-id changes — pure visual override.
   ═══════════════════════════════════════════════════════════════ */

/* Slot cards — bigger, cleaner, 2-line */
.booking-section .slots-grid{gap:10px}
.booking-section .slot-card{
  min-height:48px;
  padding:8px 14px;
  background:#fff;
  border-color:rgba(44,44,42,.10);
  border-radius:8px;
  gap:2px;
}
.booking-section .slot-card:hover:not([disabled]):not(.booked):not(.taken){
  border-color:var(--ink);
  background:#fff;
}
.booking-section .slot-card .slot-time{
  font-family:var(--f-display);
  font-size:14px;
  font-weight:600;
  letter-spacing:-.005em;
  color:var(--ink);
}
.booking-section .slot-card .slot-price{
  font-family:var(--f-mono);
  font-size:11px;
  color:rgba(44,44,42,.55);
  letter-spacing:.04em;
  margin-top:0;
}

/* SELECTED (single-pick highlight) → charcoal — design's primary slot state.
   IN-CART stays yellow → multi-pick visual carries through. */
.booking-section .slot-card.selected:not(.in-cart){
  background:var(--ink);
  border-color:var(--ink);
  color:var(--ww);
}
.booking-section .slot-card.selected:not(.in-cart) .slot-time{color:var(--ww)}
.booking-section .slot-card.selected:not(.in-cart) .slot-price{color:rgba(245,243,239,.7)}

/* Booked / past / taken — transparent, faded, struck-through, no fill */
.booking-section .slot-card[disabled],
.booking-section .slot-card.booked,
.booking-section .slot-card.taken{
  background:transparent;
  border-color:rgba(44,44,42,.06);
  color:rgba(44,44,42,.28);
  text-decoration:none;
  opacity:1;
}
.booking-section .slot-card[disabled] .slot-time,
.booking-section .slot-card.booked .slot-time,
.booking-section .slot-card.taken .slot-time{
  color:rgba(44,44,42,.28);
  text-decoration:line-through;
  text-decoration-color:rgba(44,44,42,.22);
  font-weight:500;
}
.booking-section .slot-card[disabled] .slot-price,
.booking-section .slot-card.booked .slot-price,
.booking-section .slot-card.taken .slot-price{color:rgba(44,44,42,.32)}

/* Cart group meta line — yellow uppercase mono header above each date's slots */
#cartContent .cart-group + .cart-group{margin-top:14px}
#cartContent .cart-group-label{
  font-family:var(--f-mono);
  font-size:10px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--yel-dk);
  font-weight:600;
  padding:10px 0 8px;
  border-bottom:none;
  border-top:1px solid rgba(44,44,42,.06);
}
#cartContent .cart-group:first-child .cart-group-label{border-top:none;padding-top:2px}

/* Coupon link — quieter, sits below total */
#cartContent .promo-toggle{
  margin:14px 0 4px;
  padding:0;
  font-family:var(--f-body),'Inter',sans-serif;
  font-size:12px;
  color:rgba(44,44,42,.55);
  letter-spacing:0;
  text-align:left;
}
#cartContent .promo-toggle:hover{color:var(--ink)}
#cartContent .promo-input-row{margin-top:8px}

/* Aftercare reassurance strip — design's PIN/ügyelet/lemondás row */
.book-aftercare{
  max-width:var(--max);
  margin:48px auto 0;
  padding:28px var(--px) 0;
  border-top:1px solid rgba(44,44,42,.08);
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.book-aftercare .ba-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:13px;
  line-height:1.5;
  color:rgba(44,44,42,.75);
}
.book-aftercare .ba-item strong{
  display:block;
  margin-bottom:2px;
  font-family:var(--f-display);
  font-size:14px;
  font-weight:600;
  color:var(--ink);
}
.book-aftercare .ba-item svg{
  width:18px;
  height:18px;
  flex-shrink:0;
  margin-top:2px;
  fill:none;
  stroke:rgba(44,44,42,.45);
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.book-aftercare .ba-item a{color:var(--ink);border-bottom:1px solid rgba(44,44,42,.2)}
.book-aftercare .ba-item a:hover{border-bottom-color:var(--yel)}
@media (max-width:900px){
  .book-aftercare{grid-template-columns:1fr;gap:14px;margin-top:32px;padding-top:22px}
}

/* Hero photo placeholders — diagonal stripe pattern over a dark base
   (design's lhp-a/b/c look). Applies when .lhp has no background image. */
.loc-hero .lhp{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(245,243,239,.14);
  background:
    repeating-linear-gradient(45deg, rgba(245,241,232,.05) 0 12px, rgba(245,241,232,0) 12px 24px),
    linear-gradient(135deg, var(--ink-2, #1a1a18), var(--ink));
}
.loc-hero .lhp[data-label]::after{
  content:attr(data-label);
  position:absolute;
  bottom:10px;
  left:10px;
  font-family:var(--f-mono);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:4px 8px;
  background:rgba(0,0,0,.6);
  color:rgba(255,255,255,.85);
  border-radius:3px;
  backdrop-filter:blur(3px);
}
.loc-hero .lhp-a{border-color:rgba(245,197,24,.35)}
/* ═══════════════════════════════════════════════════════════════════
   sologym — Landing redesign (editorial)
   Strictly the v3 brand system. No invented colors. No gradients.
   Yellow is rationed (≤ 5%, action-only).
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --char: #2C2C2A;
  --char-mid: #3A3A37;
  --char-soft: #4A483F;
  --ww: #F5F3EF;
  --ww-dark: #EBE8E2;
  --grey-bg: #F2F0EA;
  --grey: #A3A095;
  --grey-dk: #7A7870;
  --yellow: #F5C518;
  --yellow-lt: #FDF3D0;

  --r-input: 8px;
  --r-card: 14px;
  --r-btn: 22px;
  --r-pan: 32px;

  --maxw: 1280px;
  --gutter: clamp(20px, 4vw, 64px);

  --t-display: clamp(40px, 4.5vw, 64px);
  --t-h1: clamp(32px, 3.5vw, 48px);
  --t-h2: clamp(28px, 3vw, 38px);
  --t-h3: clamp(20px, 1.7vw, 24px);
  --t-lede: clamp(17px, 1.3vw, 20px);
  --t-body: 16px;
  --t-mono: 12px;

  --line: rgba(44, 44, 42, 0.12);
  --line-dk: rgba(245, 243, 239, 0.14);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--ww);
  color: var(--char);
  font-family: "Inter", system-ui, sans-serif;
  font-size: var(--t-body);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

::selection { background: var(--char); color: var(--ww); }

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ───────────── Type primitives ───────────── */
.eyebrow {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--grey-dk);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: currentColor;
  opacity: 0.6;
}
.eyebrow.no-rule::before { display: none; }
.on-dark .eyebrow { color: var(--grey); }

.display, h1.display {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: var(--t-display);
  line-height: 0.96;
  letter-spacing: -0.025em;
  text-wrap: balance;
}

h2 {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: var(--t-h2);
  line-height: 1.04;
  letter-spacing: -0.02em;
  text-wrap: balance;
}

h3 {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: var(--t-h3);
  line-height: 1.18;
  letter-spacing: -0.01em;
}

.lede {
  font-size: var(--t-lede);
  line-height: 1.5;
  color: var(--char-soft);
  max-width: 56ch;
  text-wrap: pretty;
  font-weight: 400;
}
.on-dark .lede { color: rgba(245, 243, 239, 0.72); }

em { font-style: italic; font-weight: inherit; }

.mono { font-family: "JetBrains Mono", ui-monospace, monospace; font-size: 12px; letter-spacing: 0.04em; }

/* ───────────── Layout ───────────── */
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

section { padding-block: clamp(80px, 10vh, 140px); }
section.tight { padding-block: clamp(60px, 7vh, 96px); }

.section-rule {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  border-top: 1px solid var(--line);
  padding-top: 36px;
  margin-bottom: 48px;
}
.on-dark .section-rule { border-top-color: var(--line-dk); }

.section-rule .row {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 32px;
  align-items: baseline;
}
.section-rule .row .num {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey-dk);
}
.on-dark .section-rule .row .num { color: var(--grey); }

@media (max-width: 720px) {
  .section-rule .row { grid-template-columns: 1fr; gap: 12px; }
}

/* ───────────── Buttons ───────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-radius: var(--r-btn);
  font-family: "Inter", sans-serif;
  font-weight: 500;
  font-size: 15px;
  line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 160ms ease, background 160ms ease, color 160ms ease, border-color 160ms ease;
  white-space: nowrap;
}
.btn .arr {
  display: inline-block;
  transition: transform 200ms ease;
  font-family: "JetBrains Mono", monospace;
}
.btn:hover .arr { transform: translateX(4px); }

.btn-prim {
  background: var(--yellow);
  color: var(--char);
}
.btn-prim:hover { background: #ECB910; }

.btn-lg { padding: 16px 26px; font-size: 16px; }

.btn-ghost {
  background: transparent;
  color: var(--char);
  border-color: var(--line);
}
.on-dark .btn-ghost { color: var(--ww); border-color: var(--line-dk); }
.btn-ghost:hover { border-color: var(--char); }
.on-dark .btn-ghost:hover { border-color: var(--ww); }

.btn-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  font-size: 15px;
  color: inherit;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}
.btn-link .arr { font-family: "JetBrains Mono", monospace; }

/* ───────────── NAV ───────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 60;
  height: 56px;
  background: rgba(44, 44, 42, 0.78);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid rgba(245, 243, 239, 0.06);
  color: var(--ww);
}
.nav-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  height: 100%;
  padding-inline: var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.nav-logo {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: 19px;
  letter-spacing: -0.01em;
  color: var(--ww);
}
.nav-logo .gym { color: var(--yellow); }

.nav-links {
  display: flex;
  gap: 28px;
  font-size: 14px;
  color: rgba(245, 243, 239, 0.72);
}
.nav-links a { transition: color 160ms ease; }
.nav-links a:hover { color: var(--ww); }

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--yellow);
  color: var(--char);
  padding: 8px 16px;
  border-radius: 999px;
  font-weight: 500;
  font-size: 14px;
  transition: transform 160ms ease;
}
.nav-cta:hover { transform: translateY(-1px); }
.nav-cta .arr { font-family: "JetBrains Mono", monospace; }

@media (max-width: 880px) {
  .nav-links { display: none; }
}

/* ───────────── HERO ───────────── */
.hero {
  background: var(--char);
  color: var(--ww);
  padding-top: calc(56px + 32px);
  padding-bottom: 56px;
  min-height: clamp(560px, 70vh, 720px);
  position: relative;
  overflow: hidden;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  min-height: clamp(420px, 56vh, 580px);
}

.hero-eye {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--grey-lt);
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 32px;
}
.hero-eye .dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--yel);
}

.hero-h,
.hero .hero-h,
section.hero h1.hero-h {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: clamp(40px, 3.75vw, 60px);
  line-height: 1.04;
  letter-spacing: -0.022em;
  margin-bottom: 24px;
  color: var(--ww);
  opacity: 1;
  animation: none;
  text-wrap: balance;
}
.hero .hero-h em,
.hero-h em {
  font-style: italic;
  font-weight: 500;
  color: var(--yel);
}
.hero-h .yel-tick {
  display: inline-block;
  position: relative;
}
.hero-h .yel-tick::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.06em;
  height: 0.18em;
  background: var(--yellow);
  z-index: -1;
}
.hero-h.has-tick { isolation: isolate; }

.hero-sub {
  font-size: var(--t-lede);
  line-height: 1.5;
  color: rgba(245, 243, 239, 0.88);
  max-width: 38ch;
  margin-bottom: 36px;
  text-wrap: pretty;
}

.hero-cta {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.hero-cta .btn-link { color: rgba(245, 243, 239, 0.86); border-color: rgba(245, 243, 239, 0.3); }
.hero-cta .btn-link:hover { color: var(--ww); border-color: var(--ww); }

.hero-trust {
  margin-top: 28px;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: rgba(245, 243, 239, 0.75);
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
}
.hero-trust .sep { opacity: 0.55; }
.hero-trust .hero-price {
  color: var(--ww);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.hero-trust .hero-price small {
  font-weight: 400;
  opacity: 0.7;
  margin-left: 2px;
}

/* Editorial photo column */
.hero-photo {
  position: relative;
  aspect-ratio: 4 / 5;
  background: var(--char-mid);
  border: 1px solid var(--line-dk);
  overflow: hidden;
  align-self: end;
}
.hero-photo .ph-stripe {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(245, 243, 239, 0.025) 0 12px,
      rgba(245, 243, 239, 0.04) 12px 24px
    );
}
.hero-photo .ph-tag {
  position: absolute;
  left: 16px; bottom: 16px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(245, 243, 239, 0.62);
  text-transform: uppercase;
}
.hero-photo .ph-meta {
  position: absolute;
  right: 16px; top: 16px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(245, 243, 239, 0.5);
  text-align: right;
  line-height: 1.5;
}

/* hero-photos — 1 large left + 2 stacked right (loc-hero-photos pattern).
   Aspect 3:2 outer; left col spans 2 rows for the wide-angle interior shot. */
.hero-photos {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 8px;
  aspect-ratio: 3 / 2;
  align-self: center;
}
.hph {
  position: relative;
  background: var(--char-mid);
  border: 1px solid var(--line-dk);
  overflow: hidden;
  border-radius: 6px;
}
.hph::before {
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(135deg,
    rgba(245, 243, 239, 0.025) 0 12px,
    rgba(245, 243, 239, 0.04) 12px 24px);
}
.hph::after {
  content: attr(data-label);
  position: absolute;
  left: 14px; bottom: 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(245, 243, 239, 0.78);
  text-transform: uppercase;
  padding: 5px 10px;
  background: rgba(0, 0, 0, 0.42);
  border-radius: 4px;
}
.hph-a { grid-row: span 2; background: var(--ink); }
.hph-b { background: var(--char-mid); }
.hph-c { background: var(--char-mid); }

/* asymmetric variant — photo recedes, big H takes whole width */
.hero[data-variant="quiet"] .hero-grid {
  grid-template-columns: 1fr;
}
.hero[data-variant="quiet"] .hero-h {
  font-size: clamp(64px, 11vw, 168px);
}
.hero[data-variant="quiet"] .hero-photo {
  position: absolute;
  right: var(--gutter);
  top: calc(56px + 64px);
  width: clamp(220px, 26vw, 320px);
  aspect-ratio: 3 / 4;
}

@media (max-width: 880px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero[data-variant="quiet"] .hero-photo { display: none; }
}

/* ───────────── HOGYAN MŰKÖDIK ───────────── */
.steps-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: end;
  margin-bottom: 72px;
}
@media (max-width: 720px) { .steps-head { grid-template-columns: 1fr; gap: 24px; } }

.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
}
.steps::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 6%;
  right: 6%;
  height: 1px;
  background: var(--char);
  opacity: 0.18;
}
.steps::after {
  content: "";
  position: absolute;
  top: 26px;
  left: 6%;
  width: 56px;
  height: 5px;
  background: var(--yellow);
  border-radius: 3px;
}

.step {
  padding: 0 28px;
  border-left: 1px solid var(--line);
}
.step:first-child { padding-left: 0; border-left: none; }

.step-num {
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  letter-spacing: 0.18em;
  font-weight: 500;
  background: var(--ww);
  color: var(--char);
  position: relative;
  z-index: 1;
  display: inline-block;
  padding-right: 14px;
  margin-bottom: 28px;
}
.step h3 {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: 28px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
}
.step p {
  color: var(--char-soft);
  font-size: 16px;
  line-height: 1.6;
  max-width: 32ch;
}
.step .meta {
  margin-top: 24px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--grey-dk);
  text-transform: uppercase;
}

@media (max-width: 880px) {
  .steps { grid-template-columns: 1fr; gap: 32px; }
  .steps::before, .steps::after { display: none; }
  .step { padding: 24px 0 0; border-left: none; border-top: 1px solid var(--line); }
  .step:first-child { padding-top: 0; border-top: none; }
}

/* ───────────── A TÉR (feature strips) ───────────── */
.bg-soft { background: var(--grey-bg); }

.strip {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  padding-block: clamp(48px, 6vh, 80px);
  border-top: 1px solid var(--line);
}
.strip:last-child { border-bottom: 1px solid var(--line); }
.strip.reverse .strip-img { order: 2; }
.strip-img {
  aspect-ratio: 5 / 6;
  background: var(--char);
  position: relative;
  overflow: hidden;
}
.strip-img.warm { background: #6B5B48; }
.strip-img.bath { background: #C3A97E; }
.strip-img.rack { background: var(--char); }
.strip-img .ph-stripe {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255, 255, 255, 0.04) 0 14px,
      rgba(255, 255, 255, 0.07) 14px 28px
    );
}
.strip-img .ph-tag {
  position: absolute;
  left: 18px; bottom: 18px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(255, 255, 255, 0.78);
  text-transform: uppercase;
}
.strip-img.bath .ph-tag { color: rgba(44, 44, 42, 0.7); }

.strip-text { padding-block: 12px; }
.strip-text h3 {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.18;
  letter-spacing: -0.015em;
  margin-block: 16px 18px;
  text-wrap: balance;
}
.strip-text p {
  color: var(--char-soft);
  font-size: 17px;
  line-height: 1.6;
  max-width: 44ch;
}
.strip-text .specs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin-top: 20px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--grey-dk);
  text-transform: uppercase;
}
.strip-text .specs span { display: inline-flex; align-items: center; gap: 6px; }
.strip-text .specs .b { width: 4px; height: 4px; border-radius: 50%; background: currentColor; }

@media (max-width: 880px) {
  .strip { grid-template-columns: 1fr; gap: 24px; padding-block: 32px; }
  .strip.reverse .strip-img { order: 0; }
}

/* ───────────── KONTRASZT (más, mint amit ismersz) ───────────── */
.kontraszt {
  background: var(--grey-bg);
}
.kontraszt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  margin-top: 56px;
  position: relative;
}
.kontraszt-grid::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0; left: 50%;
  width: 1px; background: var(--char); opacity: 0.16;
  transform: translateX(-0.5px);
}
.k-col h3 {
  font-family: "DM Sans", sans-serif;
  font-size: 19px;
  font-weight: 600;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.k-col h3 .pill {
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 4px;
  background: var(--ww-dark);
  color: var(--grey-dk);
}
.k-col.k-us h3 .pill { background: var(--char); color: var(--ww); }

.k-col ul {
  list-style: none;
  display: grid;
  gap: 14px;
}
.k-col li {
  font-size: 16px;
  line-height: 1.5;
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.k-col li:last-child { border-bottom: none; }
.k-col li .lbl {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--grey-dk);
  text-transform: uppercase;
  min-width: 88px;
  flex-shrink: 0;
}

.k-them li .val {
  color: var(--grey-dk);
  text-decoration: line-through;
  text-decoration-color: rgba(122, 120, 112, 0.5);
  text-decoration-thickness: 1px;
}
.k-us li .val { color: var(--char); font-weight: 500; }

@media (max-width: 720px) {
  .kontraszt-grid { grid-template-columns: 1fr; gap: 24px; }
  .kontraszt-grid::before { display: none; }
  .k-col + .k-col { padding-top: 24px; border-top: 1px solid var(--line); }
}

/* ───────────── ÁRAZÁS ───────────── */
.pricing {
  background: var(--char);
  color: var(--ww);
}
.pricing.on-dark { color: var(--ww); }

.price-card {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
  padding-block: 24px;
}
.price-card .eyebrow { color: var(--grey); justify-content: center; }
.price-card .eyebrow::before { background: var(--grey); }

.price-num {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: clamp(64px, 6.5vw, 112px);
  line-height: 0.96;
  letter-spacing: -0.03em;
  margin: 24px 0 8px;
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
}
.price-num .ft {
  font-family: "JetBrains Mono", monospace;
  font-size: 0.18em;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--grey);
  margin-top: 1.4em;
  text-transform: uppercase;
}

.price-unit {
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 36px;
}

.price-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 48px;
  border-top: 1px solid var(--line-dk);
  border-bottom: 1px solid var(--line-dk);
  padding: 28px 0;
}
.price-grid > div { padding: 0 16px; border-left: 1px solid var(--line-dk); text-align: left; }
.price-grid > div:first-child { border-left: none; }
.price-grid .l {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 8px;
  display: block;
}
.price-grid .v {
  font-family: "DM Sans", sans-serif;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.2;
}

.price-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-top: 48px;
}
.price-cta .meta {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--grey);
  text-transform: uppercase;
}

@media (max-width: 720px) {
  .price-grid { grid-template-columns: 1fr 1fr; }
  .price-grid > div:nth-child(3) { border-left: none; border-top: 1px solid var(--line-dk); padding-top: 16px; margin-top: 16px; }
  .price-grid > div:nth-child(4) { border-top: 1px solid var(--line-dk); padding-top: 16px; margin-top: 16px; }
}

/* ───────────── GYIK ───────────── */
.faq-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: clamp(40px, 6vw, 96px);
  margin-top: 24px;
}
@media (max-width: 880px) { .faq-grid { grid-template-columns: 1fr; } }

.faq-list { border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  padding: 18px 0;
  font-family: "DM Sans", sans-serif;
  font-size: clamp(16px, 1.2vw, 18px);
  font-weight: 500;
  line-height: 1.4;
  color: var(--char);
  letter-spacing: -0.003em;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
}
.faq-q .plus {
  font-family: "JetBrains Mono", monospace;
  font-size: 18px;
  font-weight: 400;
  color: var(--grey-dk);
  flex-shrink: 0;
  transition: transform 200ms ease;
  width: 18px; text-align: center;
}
.faq-item[open] .plus { transform: rotate(45deg); }

.faq-a {
  padding: 0 0 24px;
  color: var(--char-soft);
  font-size: 16px;
  line-height: 1.65;
  max-width: 56ch;
}

/* ───────────── HELYSZÍN — list + Budapest map ───────────── */
.helyszin {
  background: var(--char);
  color: var(--ww);
}

.hely-layout {
  display: grid;
  grid-template-columns: minmax(0, 380px) 1fr;
  gap: clamp(32px, 4vw, 64px);
  align-items: start;
}

/* ─── LEFT: Location list ─── */
.hely-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.hely-list-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-bottom: 14px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--line-dk);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.hely-list-head .mono { color: var(--ww); }
.hely-list-count { color: var(--grey); font-size: 10px; }

.hely-item {
  position: relative;
  padding: 22px 22px 22px 26px;
  background: var(--char-mid);
  border: 1px solid var(--line-dk);
  transition: border-color 200ms ease, background 200ms ease, transform 200ms ease;
  cursor: default;
}
.hely-item::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: transparent;
  transition: background 200ms ease;
}
.hely-item.is-live::before { background: var(--yellow); }
.hely-item.is-soon { background: transparent; border-style: dashed; border-color: rgba(245,243,239,0.16); }
.hely-item.is-active,
.hely-item:hover {
  border-color: rgba(245,197,24,0.5);
  background: rgba(245,197,24,0.04);
}
.hely-item:focus-visible {
  outline: 2px solid var(--yellow);
  outline-offset: 2px;
}
.hely-item-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 12px;
}
.hely-item.is-live .hely-item-status { color: var(--yellow); }
.hi-dot {
  width: 7px; height: 7px; border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.hi-dot-live {
  background: var(--yellow);
  box-shadow: 0 0 0 2px rgba(245,197,24,0.18);
}
.hi-dot-soon {
  background: transparent;
  border: 1px dashed rgba(245,243,239,0.5);
}
.hely-item-name {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -0.012em;
  line-height: 1.12;
  color: var(--ww);
  margin: 0 0 6px;
}
.hely-item.is-soon .hely-item-name { color: rgba(245,243,239,0.55); }
.hely-item-addr {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--grey);
  margin-bottom: 10px;
}
.hely-item-desc {
  font-size: 13.5px;
  line-height: 1.55;
  color: rgba(245,243,239,0.62);
  margin: 0 0 14px;
}
.hely-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  padding: 14px 0 4px;
  border-top: 1px solid var(--line-dk);
  margin-bottom: 16px;
}
.hely-item-meta > div {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.hely-item-meta .l {
  font-family: "JetBrains Mono", monospace;
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--grey);
}
.hely-item-meta .v {
  font-family: "Inter", sans-serif;
  font-size: 13px;
  color: var(--ww);
  font-weight: 500;
}
.hely-item-cta {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.hely-item-cta .btn-prim {
  font-size: 13px;
  padding: 9px 16px;
}
.btn-link-ww {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ww);
  border-bottom: 1px solid rgba(245,243,239,0.3);
  padding-bottom: 3px;
  transition: border-color 160ms ease, color 160ms ease;
}
.btn-link-ww:hover { border-color: var(--yellow); color: var(--yellow); }
.btn-link-ww .arr { font-family: "JetBrains Mono", monospace; transition: transform 200ms ease; }
.btn-link-ww:hover .arr { transform: translateX(3px); }
.btn-link-mute { color: rgba(245,243,239,0.55); border-bottom-color: rgba(245,243,239,0.18); }

.hely-suggest {
  margin-top: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border: 1px solid var(--line-dk);
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey);
  transition: border-color 160ms ease, color 160ms ease;
}
.hely-suggest:hover { border-color: var(--yellow); color: var(--yellow); }
.hely-suggest .arr { transition: transform 200ms ease; }
.hely-suggest:hover .arr { transform: translateX(4px); }

/* ─── RIGHT: Budapest map ─── */
.hely-map {
  position: relative;
  background: var(--char-mid);
  border: 1px solid var(--line-dk);
  overflow: hidden;
  align-self: stretch;
}
.hely-map-head {
  position: absolute;
  top: 18px; left: 22px;
  display: flex;
  align-items: baseline;
  gap: 12px;
  z-index: 2;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ww);
  pointer-events: none;
}
.hely-map-coord {
  color: rgba(245,243,239,0.42);
  font-size: 10px;
  letter-spacing: 0.08em;
}
.bp-map {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 720 / 760;
}
.hely-map-legend {
  position: absolute;
  bottom: 18px; right: 22px;
  display: flex;
  gap: 18px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey);
  z-index: 2;
  pointer-events: none;
}
.hely-map-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* Pin behavior */
.bp-pin { transition: transform 220ms ease; transform-box: fill-box; transform-origin: center; }
.bp-pin-live .bp-pulse {
  transform-origin: center;
  transform-box: fill-box;
  animation: bpPulse 2.4s ease-out infinite;
}
@keyframes bpPulse {
  0% { transform: scale(0.6); opacity: 0.7; }
  100% { transform: scale(1.6); opacity: 0; }
}
.bp-pin.is-active { filter: drop-shadow(0 0 12px rgba(245,197,24,0.5)); }
.bp-pin-soon.is-active circle:first-child { fill: rgba(245,243,239,0.18); stroke: rgba(245,243,239,0.8); }
.bp-pin-soon.is-active circle:nth-child(2) { fill: rgba(245,243,239,0.85); }

/* Responsive */
@media (max-width: 1100px) {
  .hely-layout { grid-template-columns: minmax(0, 320px) 1fr; gap: 28px; }
  .hely-item { padding: 18px 18px 18px 22px; }
  .hely-item-name { font-size: 20px; }
  .hely-item-meta { gap: 10px 16px; }
}
@media (max-width: 760px) {
  .hely-layout { grid-template-columns: 1fr; gap: 32px; }
  .hely-map { order: -1; }
  .bp-map { aspect-ratio: 720 / 600; }
}
@media (max-width: 540px) {
  .hely-item { padding: 18px 18px 18px 22px; }
  .hely-item-name { font-size: 19px; }
  .hely-map-coord { display: none; }
  .hely-item-cta { gap: 12px; }
}

/* ───────────── HELYSZÍN (legacy — large card, kept for fallback) ───────────── */
.helyszin {
  background: var(--char);
  color: var(--ww);
}
.helyszin-card {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 0;
  border: 1px solid var(--line-dk);
  background: var(--char-mid);
}
.helyszin-img {
  aspect-ratio: 4 / 3;
  position: relative;
  overflow: hidden;
  background: #6B5B48;
}
.helyszin-img .ph-stripe {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(135deg, rgba(255,255,255,0.04) 0 14px, rgba(255,255,255,0.07) 14px 28px);
}
.helyszin-img .ph-tag {
  position: absolute; left: 18px; bottom: 18px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: 0.08em;
  color: rgba(255,255,255,0.78); text-transform: uppercase;
}
.helyszin-img .badge {
  position: absolute; top: 18px; left: 18px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--char);
  background: var(--ww);
  padding: 6px 10px;
  border-radius: 999px;
}
.helyszin-body {
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 32px;
}
.helyszin-name {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
}
.helyszin-name em { font-style: italic; font-weight: 400; color: rgba(245, 243, 239, 0.7); }

.helyszin-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 24px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--line-dk);
}
.helyszin-meta div .l {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey);
  display: block;
  margin-bottom: 6px;
}
.helyszin-meta div .v {
  font-family: "Inter", sans-serif;
  font-size: 15px;
  color: var(--ww);
}

.helyszin-cta {
  margin-top: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

@media (max-width: 880px) {
  .helyszin-card { grid-template-columns: 1fr; }
}

/* ───────────── FOOTER ───────────── */
.footer {
  background: var(--char);
  color: rgba(245, 243, 239, 0.72);
  padding: 80px 0 32px;
  border-top: 1px solid var(--line-dk);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--line-dk);
}
.footer-brand .logo {
  font-family: "DM Sans", sans-serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--ww);
  margin-bottom: 16px;
}
.footer-brand .logo .gym { color: var(--yellow); }
.footer-brand p {
  font-size: 14px;
  max-width: 36ch;
  line-height: 1.5;
}
.footer-col h4 {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 18px;
}
.footer-col a {
  display: block;
  padding: 4px 0;
  font-size: 14px;
  color: rgba(245, 243, 239, 0.68);
  transition: color 160ms ease;
}
.footer-col a:hover { color: var(--ww); }

.footer-bottom {
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--grey);
  flex-wrap: wrap;
  gap: 12px;
}
@media (max-width: 720px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

/* ───────────── TWEAKS PANEL — minimal floating ───────────── */
.tw-panel {
  position: fixed;
  right: 20px; bottom: 20px;
  width: 280px;
  background: var(--char);
  color: var(--ww);
  border-radius: 14px;
  padding: 18px 18px 14px;
  z-index: 100;
  font-family: "Inter", sans-serif;
  box-shadow: 0 20px 60px -20px rgba(0,0,0,0.4);
  display: none;
}
.tw-panel.open { display: block; }
.tw-panel h4 {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.tw-panel h4 button {
  background: none; border: none; color: var(--grey); cursor: pointer;
  font-family: inherit; font-size: 14px;
}
.tw-row { margin-bottom: 14px; }
.tw-row:last-child { margin-bottom: 0; }
.tw-row .l {
  display: block;
  font-size: 12px;
  color: rgba(245, 243, 239, 0.7);
  margin-bottom: 6px;
}
.tw-seg {
  display: flex;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}
.tw-seg button {
  flex: 1;
  background: none;
  border: none;
  padding: 6px 8px;
  border-radius: 6px;
  color: rgba(245, 243, 239, 0.6);
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
  transition: background 160ms, color 160ms;
}
.tw-seg button.on {
  background: var(--ww);
  color: var(--char);
}

/* ═══════════════════════════════════════════════════════════════════
   Landing redesign — overrides for legacy class collisions
   (Pre-existing .step, .step-num, .faq-* rules earlier in the file
    set display/sizing/visibility that the redesign assumes is unset.)
   ═══════════════════════════════════════════════════════════════════ */
body .steps .step { display: block; align-items: stretch; gap: 0; padding: 0 28px; border-left: 1px solid var(--line); white-space: normal; background: transparent; }
body .steps .step:first-child { padding-left: 0; border-left: none; }
body .steps .step-num {
  width: auto; height: auto; min-width: 0; min-height: 0;
  border-radius: 0;
  background: var(--ww);
  color: var(--char);
  display: inline-block;
  padding: 0 14px 0 0;
  margin: 0 0 28px;
  font-family: "JetBrains Mono", monospace;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.18em;
  line-height: 1;
  position: relative;
  z-index: 1;
}
@media (max-width: 880px) {
  body .steps .step { padding: 24px 0 0; border-left: none; border-top: 1px solid var(--line); }
  body .steps .step:first-child { padding-top: 0; border-top: none; }
}

body .faq-list .faq-q { background: none; border: none; padding: 18px 0; }
body .faq-list .faq-a { max-height: none; overflow: visible; padding: 0 0 24px; transition: none; }
body .faq-item { border-top: none; }

/* ═══════════════════════════════════════════════════════════════════
   Helyszín — one-place hero (conversion-focused)
   ═══════════════════════════════════════════════════════════════════ */
.hely-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
  background: var(--char-mid);
  border: 1px solid rgba(245, 243, 239, 0.08);
  border-radius: 14px;
  padding: clamp(20px, 2.5vw, 28px);
}

.hely-hero-img {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--char);
  border-radius: 8px;
  overflow: hidden;
}
.hely-hero-img .ph-stripe {
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(45deg, rgba(245,243,239,0.04) 0 12px, transparent 12px 24px);
}
.hely-hero-img .ph-tag {
  position: absolute; left: 16px; bottom: 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: rgba(245, 243, 239, 0.4);
  text-transform: uppercase;
}
.hely-hero-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: rgba(44, 44, 42, 0.78);
  border: 1px solid rgba(245, 243, 239, 0.12);
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245, 243, 239, 0.85);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.hely-hero-body { padding: clamp(8px, 1.5vw, 20px) clamp(8px, 1.5vw, 24px); }
.hely-hero-eye {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grey);
  margin-bottom: 14px;
}
.hely-hero-name {
  font-family: "DM Sans", sans-serif;
  font-weight: 700;
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ww);
  margin: 0 0 14px;
}
.hely-hero-desc {
  color: rgba(245, 243, 239, 0.72);
  font-size: 16px;
  line-height: 1.6;
  margin: 0 0 28px;
  max-width: 44ch;
}

.hely-hero-meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin: 0 0 32px;
  border-top: 1px solid rgba(245, 243, 239, 0.1);
}
.hely-hero-meta > div {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 16px;
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid rgba(245, 243, 239, 0.1);
}
.hely-hero-meta dt {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grey);
  margin: 0;
}
.hely-hero-meta dd {
  margin: 0;
  font-size: 16px;
  color: var(--ww);
  font-weight: 500;
}

.hely-hero-actions {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.hely-hero-actions .btn-link {
  color: rgba(245, 243, 239, 0.72);
  border-bottom: 1px solid rgba(245, 243, 239, 0.28);
  padding-bottom: 2px;
}
.hely-hero-actions .btn-link:hover {
  color: var(--ww);
  border-bottom-color: var(--ww);
}

.hely-future {
  margin: 40px 0 0;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245, 243, 239, 0.45);
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  align-items: baseline;
  border-top: 1px solid rgba(245, 243, 239, 0.1);
  padding-top: 24px;
}
.hely-future a {
  color: rgba(245, 243, 239, 0.7);
  border-bottom: 1px solid rgba(245, 243, 239, 0.22);
  padding-bottom: 1px;
  margin-left: auto;
  text-decoration: none;
  transition: color 160ms ease, border-color 160ms ease;
}
.hely-future a:hover { color: var(--yellow); border-bottom-color: var(--yellow); }
.hely-future .arr { font-family: "JetBrains Mono", monospace; }

@media (max-width: 880px) {
  .hely-hero { grid-template-columns: 1fr; gap: 24px; }
  .hely-hero-meta > div { grid-template-columns: 88px 1fr; }
  .hely-future a { margin-left: 0; }
}

/* ═══════════════════════════════════════════════════════════════════
   Helyszín — light two-card layout (revert to v6 pattern, redesign-aligned)
   ═══════════════════════════════════════════════════════════════════ */
.helyszin.helyszin-light {
  background: var(--ww);
  color: var(--char);
  padding-block: clamp(72px, 9vh, 120px);
}

.helyszin.helyszin-light .locations-head { margin-bottom: clamp(40px, 5vh, 64px); }
.helyszin.helyszin-light .locations-head .eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--grey-dk);
  display: inline-block;
  margin-bottom: 16px;
}
.helyszin.helyszin-light .locations-h {
  font-family: "DM Sans", sans-serif;
  font-weight: 700;
  font-size: clamp(30px, 2.8vw, 36px);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--char);
  margin: 0;
  text-wrap: balance;
}

.helyszin.helyszin-light .locations-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.helyszin.helyszin-light .loc-card {
  background: var(--ww);
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: inherit;
  transition: border-color 160ms ease, transform 160ms ease;
}
.helyszin.helyszin-light a.loc-card:hover { border-color: var(--grey); transform: translateY(-1px); }
.helyszin.helyszin-light .loc-card.disabled { opacity: 0.78; }
.helyszin.helyszin-light .loc-card.disabled .ph { filter: grayscale(0.3); }

.helyszin.helyszin-light .loc-card .ph {
  height: 240px;
  background: var(--char);
  display: flex;
  align-items: flex-end;
  padding: 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245, 243, 239, 0.6);
  position: relative;
}
.helyszin.helyszin-light .loc-card .ph-dark { background: var(--char); }
.helyszin.helyszin-light .loc-card .ph-mid { background: var(--char-mid); }
.helyszin.helyszin-light .loc-card .ph span {
  padding: 4px 10px;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 4px;
}

.helyszin.helyszin-light .loc-ci { padding: 28px; }
.helyszin.helyszin-light .loc-ci h3 {
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: -0.01em;
  color: var(--char);
  margin: 0 0 8px;
}
.helyszin.helyszin-light .loc-ci p {
  font-size: 14px;
  color: var(--grey-dk);
  line-height: 1.5;
  margin: 0 0 20px;
}
.helyszin.helyszin-light .loc-cm {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  margin-bottom: 24px;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  color: var(--grey-dk);
}
.helyszin.helyszin-light .loc-cm span { display: inline-flex; align-items: center; gap: 6px; }
.helyszin.helyszin-light .loc-cm svg {
  width: 14px; height: 14px;
  fill: none; stroke: currentColor;
  stroke-width: 1.6;
  stroke-linecap: round; stroke-linejoin: round;
}
.helyszin.helyszin-light .loc-cp {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.helyszin.helyszin-light .loc-cp strong {
  font-family: "DM Sans", sans-serif;
  font-weight: 700;
  font-size: 22px;
  color: var(--char);
}
.helyszin.helyszin-light .loc-cp span { font-size: 13px; color: var(--grey-dk); }

.helyszin.helyszin-light .loc-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 16px;
}
.helyszin.helyszin-light .loc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 20px;
  border-radius: 999px;
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}
.helyszin.helyszin-light .loc-btn--primary {
  background: var(--yellow);
  color: var(--char);
  border: 1px solid var(--yellow);
}
.helyszin.helyszin-light .loc-btn--primary:hover { background: #ECB910; border-color: #ECB910; }
.helyszin.helyszin-light .loc-btn--ghost {
  background: transparent;
  color: var(--char);
  border: 1px solid var(--line);
}
.helyszin.helyszin-light .loc-btn--ghost:hover { border-color: var(--char); }
.helyszin.helyszin-light .loc-card.disabled .loc-btn--ghost { cursor: default; opacity: 0.7; }
.helyszin.helyszin-light .loc-btn .arr { font-family: "JetBrains Mono", monospace; }

@media (max-width: 880px) {
  .helyszin.helyszin-light .locations-grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   sg1 (helyszín) — warm-white nav
   Brand Guideline §1.1: Warm White dominance. The location page sits
   on warm white, so the nav matches that tone. The landing page keeps
   its dark-glass nav over the charcoal hero (set above).
   ═══════════════════════════════════════════════════════════════════ */
body.page-loc .nav {
  background: rgba(245, 243, 239, 0.92);
  border-bottom: 1px solid var(--line);
  color: var(--char);
}
body.page-loc .nav-logo { color: var(--char); }
body.page-loc .nav-logo .solo { color: var(--char); }
body.page-loc .nav-logo .gym { color: var(--yel); }
body.page-loc .nav .nav-links { color: rgba(44, 44, 42, 0.72); }
body.page-loc .nav .nav-links a:hover { color: var(--char); }
body.page-loc .nav .nav-ham span { background: var(--char); }

/* ═══════════════════════════════════════════════════════════════════
   ACCESSIBILITY — prefers-reduced-motion
   Disables non-essential motion. Keeps color/border transitions for
   focus and hover feedback. Hover transforms (slot-card, helyszin-card,
   amen-img) reset; ambient pulses (ff-pulse, slot skeleton) stop.
   ═══════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  .slot-card:hover,
  .helyszin-card:hover,
  .loc-card:hover,
  .ig-grid-preview .ig-card:hover,
  .btn-primary:hover,
  .btn:hover .arr {
    transform: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   B2B SZÁMLÁZÁS — toggle + 5 mező a checkout flow Step 2-jében
   (sidebar-fields belsejében, a phone input után)
   ═══════════════════════════════════════════════════════════════════ */
.company-toggle-row{margin-top:12px;padding:10px 0;border-top:1px solid var(--line)}
.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--ink);user-select:none}
.checkbox-label input[type="checkbox"]{width:auto;min-height:auto;padding:0;margin:0;cursor:pointer}
.company-fields{flex-direction:column;gap:8px;margin-top:10px}
.company-fields input{padding:13px 14px;border:1px solid var(--line);border-radius:8px;font-family:var(--f-body);font-size:15px;background:var(--ww);outline:none;color:var(--ink);width:100%;min-height:48px;-webkit-appearance:none;transition:border-color .15s,box-shadow .15s}
.company-fields input:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(245,197,24,.25)}
.company-fields input::placeholder{color:var(--grey-dk)}
.company-address-row{display:flex;gap:8px}
.company-address-row > input:first-child{flex:0 0 100px}
.company-address-row > input:last-child{flex:1}
@media (max-width:480px){
  .company-address-row{flex-direction:column}
  .company-address-row > input{flex:1 !important}
}
@media (max-width:900px){
  .booking-sidebar .checkbox-label{color:var(--ww)}
  .booking-sidebar .company-toggle-row{border-top-color:var(--ink-3)}
  .booking-sidebar .company-fields input{background:var(--ink-2);color:var(--ww);border-color:var(--ink-3)}
  .booking-sidebar .company-fields input::placeholder{color:var(--grey)}
  .booking-sidebar .company-fields input:focus{border-color:var(--yel)}
}

/* ═══════════════════════════════════════════════════════════════
   v2 HERO + TÉR (EDZÉSTÍPUS KÁRTYÁK)
   Forrás: _tervezet/sologym_hero_es_tipusok_tervezet.html
   - .v2-hero: világos hero, 3 kép egymás mellett (nem fednek át)
   - .v2-types: sötét szekció 5 edzéstípus kártyával
   ═══════════════════════════════════════════════════════════════ */

.v2-hero{
  background:#F5F3EF;color:#2C2C2A;
  padding:88px 0 96px;
  border-bottom:1px solid rgba(44,44,42,.12);
  position:relative;
}
.v2-hero .wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.v2-hero .v2-hero-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center;
}
.v2-hero .v2-eyebrow{
  margin-bottom:28px;color:#A3A095;
  font-family:'JetBrains Mono',monospace;font-size:.78rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.v2-hero .v2-headline{
  font-family:'DM Sans',sans-serif;font-weight:700;
  font-size:clamp(3rem,7vw,6.4rem);
  line-height:.96;letter-spacing:-0.035em;
  color:#2C2C2A;margin:0;
}
.v2-hero .v2-headline span{display:block}
.v2-hero .v2-headline .accent{position:relative;display:inline-block;isolation:isolate}
.v2-hero .v2-headline .accent::after{
  content:"";position:absolute;left:-.04em;right:-.04em;bottom:.02em;height:.22em;
  background:#F5C518;z-index:-1;
}
.v2-hero .v2-meta{
  font-family:'Inter',sans-serif;
  font-size:1.05rem;line-height:1.55;color:#2C2C2A;
  max-width:480px;margin:36px 0 32px;
}

/* CTA + ár-blokk egy flex sorban — vertikálisan közéig igazítva */
.v2-hero .v2-cta-row{
  display:flex;align-items:center;gap:32px;flex-wrap:wrap;
}
.v2-hero .v2-cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;background:#2C2C2A;color:#F5F3EF;
  font-family:'DM Sans',sans-serif;font-weight:500;font-size:1rem;
  border-radius:2px;text-decoration:none;
  transition:transform .2s, background .2s;
}
.v2-hero .v2-cta:hover{background:#000;transform:translateX(2px)}
.v2-hero .v2-info{
  font-size:.85rem;color:#A3A095;line-height:1.55;
  font-family:'Inter',sans-serif;
}
.v2-hero .v2-info .v2-mono{
  display:block;margin-bottom:4px;color:#A3A095;
  font-family:'JetBrains Mono',monospace;font-size:.72rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.v2-hero .v2-info strong{
  font-family:'DM Sans',sans-serif;font-weight:600;color:#2C2C2A;
  font-size:1rem;display:block;margin-bottom:4px;
}

/* JOBB OSZLOP — 3 kép EGYMÁS MELLETT, nem fednek át */
.v2-hero .v2-images{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  width:100%;
}
.v2-hero .v2-image{
  position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:3px;
  background:linear-gradient(160deg,#ddd8cd 0%,#b8b1a4 100%);
  box-shadow:0 8px 24px rgba(44,44,42,.08), 0 2px 6px rgba(44,44,42,.04);
  transition:transform .3s ease;
}
.v2-hero .v2-image::after{
  content:"";position:absolute;inset:0;opacity:.35;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .12 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}
.v2-hero .v2-image .v2-illu{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:.32;z-index:1;
}
.v2-hero .v2-image .v2-illu svg{
  width:48%;height:48%;
  stroke:#2C2C2A;fill:none;stroke-width:1.3;
  stroke-linecap:round;stroke-linejoin:round;
}
.v2-hero .v2-image .v2-caption{
  position:absolute;left:12px;bottom:10px;z-index:2;
  font-family:'JetBrains Mono',monospace;
  font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;
  color:#2C2C2A;background:rgba(245,243,239,.92);
  padding:4px 8px;border-radius:1px;
}
.v2-hero .v2-image:hover{transform:translateY(-4px)}

@media (max-width:900px){
  .v2-hero{padding:64px 0 72px}
  .v2-hero .v2-hero-grid{grid-template-columns:1fr;gap:48px}
}
@media (max-width:520px){
  .v2-hero .v2-images{grid-template-columns:1fr;gap:10px}
}

/* ─────────── 02 — EDZÉSTÍPUS KÁRTYÁK (sötét szekció) ─────────── */
.v2-types{
  background:#2C2C2A;color:#F5F3EF;padding:96px 0;
}
.v2-types .wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.v2-types .v2-section-head{
  margin-bottom:56px;display:flex;justify-content:space-between;align-items:end;gap:48px;
}
.v2-types .v2-section-eyebrow{
  color:#A3A095;margin-bottom:18px;
  font-family:'JetBrains Mono',monospace;font-size:.78rem;
  letter-spacing:.04em;text-transform:uppercase;
}
.v2-types .v2-section-title{
  font-family:'DM Sans',sans-serif;font-weight:600;
  font-size:clamp(2rem,4vw,3.2rem);
  letter-spacing:-0.025em;max-width:620px;color:#F5F3EF;
  line-height:1.05;margin:0;
}
.v2-types .v2-section-aside{
  font-family:'Inter',sans-serif;
  font-size:.95rem;color:#A3A095;max-width:280px;line-height:1.6;
}
.v2-types .v2-types-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.v2-types .v2-card{
  aspect-ratio:3/4;position:relative;overflow:hidden;border-radius:2px;
  cursor:pointer;transition:transform .35s ease;
}
.v2-types .v2-card:hover{transform:translateY(-4px)}
.v2-types .v2-card .v2-photo-sim{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(245,197,24,.05) 0%, transparent 60%),
    linear-gradient(160deg,#3a3a37 0%,#1c1c1a 100%);
}
.v2-types .v2-card .v2-photo-sim::after{
  content:"";position:absolute;inset:0;opacity:.4;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .15 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
}
.v2-types .v2-card .v2-card-illu{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:.18;
}
.v2-types .v2-card .v2-card-illu svg{
  width:62%;height:62%;stroke:#F5F3EF;fill:none;stroke-width:1.2;
}
.v2-types .v2-card .v2-veil{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.6) 0%, rgba(0,0,0,0) 55%);
}
.v2-types .v2-card .v2-label{
  position:absolute;left:18px;right:18px;bottom:16px;
  display:flex;justify-content:space-between;align-items:end;z-index:2;
}
.v2-types .v2-card .v2-name{
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:1.15rem;color:#F5F3EF;
}
.v2-types .v2-card .v2-num{
  font-family:'JetBrains Mono',monospace;font-size:.7rem;color:#A3A095;
}
.v2-types .v2-card.featured{outline:1px solid #F5C518;outline-offset:-1px}
.v2-types .v2-card.featured .v2-name{color:#F5C518}

@media (max-width:900px){
  .v2-types{padding:72px 0}
  .v2-types .v2-section-head{flex-direction:column;align-items:flex-start;gap:24px}
  .v2-types .v2-types-row{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:520px){
  .v2-types .v2-types-row{grid-template-columns:1fr}
}
