/* 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;
}
*{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}
img{max-width:100%;display:block}

/* ── 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}
.hero::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 120px,rgba(245,243,239,0.015) 120px,rgba(245,243,239,0.015) 121px)}
.hero-content{position:relative;z-index:1;max-width:1400px;margin:0 auto;width:100%}
.hero-tag{font-size:11px;font-weight:500;color:var(--yel);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:32px;opacity:0;animation:fu .8s .15s forwards}
.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.45);max-width:440px;line-height:1.7;margin-bottom:48px;opacity:0;animation:fu .8s .5s forwards}
.hero-actions{display:flex;align-items:center;gap:24px;opacity:0;animation:fu .8s .65s forwards}
.hero-price{position:absolute;bottom:72px;right:var(--px);text-align:right;opacity:0;animation:fu .8s .8s forwards}
.hero-price .amount{font-family:'DM Sans',sans-serif;font-weight:600;font-size:32px;color:var(--ww);letter-spacing:-1px}
.hero-price .unit{font-size:12px;color:rgba(245,243,239,0.3);margin-top:2px}

/* ── 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:8px;text-decoration:none;transition:all .2s;display:inline-block}
.btn-p:hover{background:var(--yel-dk);transform:translateY(-1px)}
.btn-g{font-size:14px;color:rgba(245,243,239,0.4);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .2s}
.btn-g:hover{color:var(--ww)}

/* ── 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}

/* ── BENTO (3 steps) ── */
.bento{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px}
.bento-item{padding:40px 36px;background:#fff;position:relative;overflow:hidden;transition:background .3s}
.bento-item:hover{background:var(--ww-dk)}
.bento-num{font-family:'DM Sans',sans-serif;font-weight:700;font-size:64px;color:rgba(200,168,130,0.08);line-height:1;position:absolute;top:16px;right:20px}
.bento-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:18px;margin-bottom:10px;position:relative}
.bento-desc{font-size:14px;color:var(--sg);line-height:1.7;position:relative}
.bento-accent{width:28px;height:3px;background:var(--yel);margin-bottom:20px;border-radius:2px}

/* ── PRICING ── */
.pricing .sh{color:var(--ww)}
.price-row{display:flex;align-items:flex-end;gap:48px}
.price-block .amount{font-family:'DM Sans',sans-serif;font-weight:700;font-size:56px;color:var(--ww);letter-spacing:-2px;line-height:1}
.price-block .curr{font-size:18px;font-weight:400;color:rgba(245,243,239,0.4);margin-left:6px}
.price-block .label{font-size:13px;color:rgba(245,243,239,0.35);margin-top:6px}
.price-features{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:12px 40px;max-width:600px}
.price-feat{font-size:14px;color:rgba(245,243,239,0.5);display:flex;align-items:center;gap:10px}
.price-feat::before{content:'';width:6px;height:6px;background:var(--yel);border-radius:50%;flex-shrink:0}
.price-cta{margin-top:48px}

/* ── LOCATION CARDS ── */
.loc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}
.loc-card{border:1px solid var(--ww-dk);border-radius:16px;overflow:hidden;background:#fff;text-decoration:none;color:var(--ch);transition:all .2s;display:flex;flex-direction:column}
.loc-card:hover{border-color:var(--ch);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.06)}
.loc-card-photo{height:200px;background:var(--ch-mid);overflow:hidden}
.loc-card-photo img{width:100%;height:100%;object-fit:cover}
.loc-card-info{padding:28px;display:flex;flex-direction:column;gap:12px;flex:1}
.loc-card-name{font-family:'DM Sans',sans-serif;font-weight:600;font-size:20px;line-height:1.3}
.loc-card-addr{font-size:13px;color:var(--sg);line-height:1.6}
.loc-card-btns{display:flex;gap:8px;margin-top:auto;padding-top:8px}
.loc-card-book{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;background:var(--yel);color:var(--ch);padding:10px 24px;border-radius:8px;cursor:pointer;transition:background .15s;text-align:center;flex:1}
.loc-card-book:hover{background:var(--yel-dk)}
.loc-card-info-btn{font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;background:#fff;color:var(--ch);padding:10px 24px;border-radius:8px;border:1px solid var(--ww-dk);cursor:pointer;transition:all .15s;text-align:center}
.loc-card-info-btn:hover{border-color:var(--ch)}

/* ── HELYSZÍN OLDAL ── */
.photo-hero{margin-top:61px;height:50vh;min-height:300px;background:var(--ch-mid);position:relative;overflow:hidden}
.photo-hero img{width:100%;height:100%;object-fit:cover}
.photo-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(44,44,42,0.5))}
.info-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:var(--max);margin:0 auto;padding:64px var(--px) 0}
.info-col{display:flex;flex-direction:column;gap:48px}
.info-label{font-size:11px;font-weight:500;letter-spacing:2.5px;color:var(--yel-dk);text-transform:uppercase;margin-bottom:14px}
.info-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:32px;line-height:1.2;letter-spacing:-.5px;margin-bottom:12px}
.info-addr{font-size:14px;color:var(--sg);line-height:1.9}

/* Detail table */
.dtable{display:flex;flex-direction:column}
.drow{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--ww-dk);font-size:14px}
.drow:first-child{border-top:1px solid var(--ww-dk)}
.dk{color:var(--sg)}.dv{color:var(--ch);text-align:right;max-width:55%}

/* Equipment grid */
.equip{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.eq-item{padding:20px;background:#fff;border:1px solid var(--ww-dk);position:relative;transition:border-color .2s}
.eq-item:hover{border-color:var(--yel-lt)}
.eq-item strong{display:block;font-family:'DM Sans',sans-serif;font-weight:600;font-size:14px;margin-bottom:6px}
.eq-item span{font-size:13px;color:var(--sg);line-height:1.6}
.eq-item::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--yel);opacity:0;transition:opacity .2s}
.eq-item:hover::before{opacity:1}

/* Transport */
.t-list{display:flex;flex-direction:column;gap:14px}
.t-item{display:flex;gap:14px;align-items:flex-start}
.t-icon{width:40px;height:40px;flex-shrink:0;background:var(--ch);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px;color:var(--yel)}
.t-text{font-size:14px;color:var(--sg);line-height:1.7}
.t-text strong{color:var(--ch);font-weight:500;display:block}

/* Map */
.map-box{width:100%;height:300px;background:var(--ch-mid);border-radius:12px;overflow:hidden}
.map-box iframe{width:100%;height:100%;border:none}

/* Gallery */
.gallery{background:var(--ch);padding:64px var(--px)}
.gallery-i{max-width:var(--max);margin:0 auto}
.gallery .st{color:var(--yel)}
.gallery-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:4px;height:300px}
.gallery-grid div,.gallery-grid img{background:var(--ch-mid);display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(245,243,239,0.15);overflow:hidden;object-fit:cover;width:100%;height:100%}

/* ── 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;max-width:380px}
.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:40px;-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(auto-fill,minmax(150px,1fr));gap:6px}
.slot-card{padding:14px 10px;background:#fff;border:1px solid var(--ww-dk);border-radius:8px;cursor:pointer;transition:all .1s;text-align:center;-webkit-tap-highlight-color:transparent}
.slot-card:hover{border-color:var(--ch)}
.slot-card:active{border-color:var(--ch)}
.slot-card.selected{border-color:var(--yel);background:var(--yel-lt)}
.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;margin-bottom:2px}
.slot-price{font-size:11px;color:var(--sg)}

/* Sidebar */
.booking-sidebar{position:sticky;top:100px}
.sidebar-card{background:#fff;border:1px solid var(--ww-dk);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:16px}
.sidebar-title{font-family:'DM Sans',sans-serif;font-weight:600;font-size:17px}
.sidebar-row{display:flex;justify-content:space-between;font-size:13px}
.sidebar-row .label{color:var(--sg)}
.sidebar-row .value{font-weight:500}
.sidebar-divider{height:1px;background:var(--ww-dk)}
.sidebar-total{display:flex;justify-content:space-between;align-items:baseline}
.sidebar-total .label{font-size:13px;color:var(--sg)}
.sidebar-total .value{font-family:'DM Sans',sans-serif;font-weight:700;font-size:22px}
.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}

/* ── 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)}

/* ── 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}
  .hero-price{display:none}
  section{padding:72px var(--px)}
  .sh{font-size:28px}
  .bento{grid-template-columns:1fr}
  .price-features{grid-template-columns:1fr}
  .price-row{flex-direction:column;align-items:flex-start;gap:8px}
  .price-block .amount{font-size:44px}
  .loc-cards{grid-template-columns:1fr}
  .photo-strip{grid-template-columns:1fr;height:auto}
  .photo-strip div,.photo-strip img{height:200px}
  .info-layout{grid-template-columns:1fr;gap:48px;padding:48px var(--px) 0}
  .equip{grid-template-columns:1fr}
  .booking-section{padding:60px var(--px) 72px}
  .booking-layout{grid-template-columns:1fr;gap:24px}
  .booking-sidebar{position:static}
  .cal-wrap{max-width:100%}
  .slots-grid{grid-template-columns:1fr 1fr}
  .gallery{padding:48px var(--px)}
  .gallery-grid{grid-template-columns:1fr;height:auto}
  .gallery-grid div,.gallery-grid img{height:200px}
  .f-inner{grid-template-columns:1fr;gap:36px}
  .f-btm{flex-direction:column;gap:6px}
  .photo-hero{height:35vh;min-height:240px}
}

/* ── 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}
  .bento-item{padding:28px 24px}
  .bento-num{font-size:48px}
  .price-block .amount{font-size:36px}
  .btn-p{padding:12px 24px;font-size:14px;width:100%;text-align:center}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:16px}
  .hero-actions .btn-p{width:auto}
  .loc-card-btns{flex-direction:column}
  .loc-card-book,.loc-card-info-btn{text-align:center}
  .slots-grid{grid-template-columns:1fr 1fr}
  .slot-card{padding:12px 8px}
  .sidebar-card{padding:20px}
  .info-title{font-size:26px}
  .photo-hero{height:30vh;min-height:200px}
  .booking-section{padding:48px var(--px) 56px}
}
