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

body{
  font-family:'Inter',sans-serif;
  background:#f5f5f5;
  color:#333;
}

/* =========================
   HEADER
========================= */

.header{
  background:white;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  position:sticky;
  top:0;
  width:100%;
  z-index:1000;
  transition:all 0.3s ease;
}

.header.scrolled{
  padding:5px 0;
  box-shadow:0 5px 20px rgba(0,0,0,0.1);
}

.topbar{
  display:flex;
  justify-content:center;
  align-items:center;
  position:relative;
  padding:20px;
  transition:all 0.3s ease;
}

.header.scrolled .topbar{
  padding:10px 20px;
}

/* LOGO */

.logo{
  text-align:center;
}

.logo img{
  height:90px;
  transition:all 0.3s ease;
}

.header.scrolled .logo img{
  height:60px;
}

/* LANG */

.lang{
  position:absolute;
  right:30px;
}

.lang a{
  color:black;
  text-decoration:none;
}

.lang a:hover{
  color:black;
}

/* HAMBURGER */

.hamburger{
  display:none;
  position:absolute;
  left:20px;
  font-size:26px;
  cursor:pointer;
}

/* =========================
   MENU
========================= */

.menu{
  position:relative;
  z-index:9999;
}

.menu ul{
  list-style:none;
  display:flex;
  justify-content:center;
  gap:30px;
  padding:15px;
}

.menu li{
  position:relative;
}

.menu a{
  text-decoration:none;
  color:#444;
  padding:10px;
  display:block;
}

/* TOP MENU HOVER */

.menu > ul > li > a{
  border-radius:6px;
  transition:all 0.25s ease;
}

.menu > ul > li > a:hover{
  background:#c8a96a;
  color:white;
  transform:translateY(-3px);
  box-shadow:0 6px 15px rgba(0,0,0,0.1);
}

/* DROPDOWN */

.menu ul ul{
  position:absolute;
  top:100%;
  left:0;
  background:rgba(255,255,255,0.95);
  display:none;
  flex-direction:column;
  min-width:220px;
  border-radius:12px;
  padding:10px 0;
  box-shadow:0 15px 40px rgba(0,0,0,0.15);
  backdrop-filter:blur(10px);
  z-index:9999;

  transform:translateY(10px);
  opacity:0;
  transition:all 0.25s ease;
}

.menu li:hover > ul{
  display:flex;
  transform:translateY(0);
  opacity:1;
}

.menu ul ul ul{
  left:100%;
  top:0;
}

.menu ul ul li a{
  padding:12px 20px;
  transition:all 0.25s ease;
}

.menu ul ul li a:hover{
  background:#c8a96a;
  color:white;
  padding-left:25px;
}

.menu ul ul li:not(:last-child){
  border-bottom:1px solid rgba(0,0,0,0.05);
}

/* =========================
   HERO
========================= */

.hero{
  height:500px;
  background:url("../images/hero.jpg") center/cover no-repeat;
  position:relative;
  display:flex;
  align-items:flex-end;
  justify-content:center;
}

.hero::before{
  content:"";
  position:absolute;
  width:100%;
  height:100%;
  background:rgba(0,0,0,0.35);
}

/* =========================
   BOOKING BAR
========================= */

.booking-bar{
  position:relative;
  background:rgba(255,255,255,0.95);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  padding:15px 20px;
  border-radius:6px;
  box-shadow:0 5px 25px rgba(0,0,0,0.2);
  margin-bottom:40px;
}

.field{
  display:flex;
  flex-direction:column;
  padding:0 15px;
}

.field label{
  font-size:12px;
  color:#777;
  margin-bottom:5px;
  letter-spacing:1px;
}

.field input{
  border:none;
  font-size:16px;
  background:transparent;
  outline:none;
}

.divider{
  width:1px;
  height:40px;
  background:#ddd;
}

/* BUTTONS */

.booking-btn{
  background:linear-gradient(135deg,#c8a96a,#b89658);
  color:white;
  padding:18px 35px;
  text-decoration:none;
  font-weight:500;
  letter-spacing:1px;
  border-radius:4px;
  transition:all 0.3s ease;
  display:flex;
  align-items:center;
}

.booking-btn:hover{
  background:linear-gradient(135deg,#b89658,#a8854a);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,0.2);
}

.header-booking-btn{
  background:linear-gradient(135deg,#c8a96a,#b89658);
  color:white !important;
  padding:10px 18px;
  border-radius:4px;
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  letter-spacing:1px;
  transition:all 0.3s ease;
}

.header-booking-btn:hover{
  background:linear-gradient(135deg,#b89658,#a8854a);
  transform:translateY(-1px);
  box-shadow:0 5px 15px rgba(0,0,0,0.2);
}

/* =========================
   SECTION
========================= */

.section{
  padding:60px;
  text-align:center;
}

/* =========================
   INTRO
========================= */

.intro{
  padding:80px 20px;
  background:white;
}

.intro-container{
  max-width:1200px;
  margin:auto;
  display:flex;
  align-items:center;
  gap:50px;
}

.intro-image{
  flex:1;
}

.intro-image img{
  width:100%;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,0.15);
  transition:0.3s;
}

.intro-image img:hover{
  transform:scale(1.03);
}

.intro-text{
  flex:1;
  text-align:left;
}

.intro-text h2{
  font-family:'Playfair Display', serif;
  font-size:32px;
  margin-bottom:20px;
}

.intro-text p{
  line-height:1.8;
  margin-bottom:15px;
  color:#555;
}

/* =========================
   ROOMS
========================= */

.rooms{
  display:flex;
  gap:30px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:30px;
}

.room{
  width:300px;
  background:white;
  box-shadow:0 5px 20px rgba(0,0,0,0.1);
  border-radius:10px;
  overflow:hidden;
}

.room img{
  width:100%;
  height:200px;
  object-fit:cover;
}

.room-info{
  padding:15px;
  text-align:left;
}

/* APARTMENT CARD */

.apartment-card{
  position:relative;
  overflow:hidden;
  border-radius:12px;
  transition:all 0.3s ease;
  box-shadow:0 5px 20px rgba(0,0,0,0.1);
}

.apartment-card img{
  width:100%;
  display:block;
}

.apartment-card:hover{
  transform:translateY(-10px) scale(1.03);
  box-shadow:0 15px 40px rgba(0,0,0,0.25);
  outline:2px solid #c8a96a;
}

/* =========================
   SLIDER
========================= */
.slider{
  position:relative;
  max-width:900px;
  margin:40px auto;
  overflow:hidden;
}

.slides{
  display:flex;
  width:100%;
  transition:transform 0.5s ease;
}

.slides img{
  width:100%;
  flex:0 0 100%;
  height:400px;
  object-fit:cover;
  display:block;
}
.prev, .next{
position:absolute;
top:50%;
transform:translateY(-50%);
background:rgba(0,0,0,0.5);
color:white;
border:none;
padding:10px;
cursor:pointer;
}

.prev{left:10px;}
.next{right:10px;}

.dots{
text-align:center;
margin-top:10px;
}

.dots span{
height:10px;
width:10px;
margin:5px;
background:#ccc;
display:inline-block;
border-radius:50%;
cursor:pointer;
}

.dots .active{
background:#c8a96a;
}

/* =========================
   CONTACT
========================= */

.contact-container{
  display:flex;
  gap:40px;
  align-items:flex-start;
  max-width:1200px;
  margin:auto;
}

.contact-left{
  flex:1;
}

.contact-right{
  flex:1;
  text-align:left;
}

/* =========================
   FOOTER
========================= */

footer{
  background:#1f1f1f;
  color:white;
  padding:50px 40px;
  margin-top:80px;
  text-align:center;
  font-size:12px;
  line-height:2;
}

.footer-container{
  display:flex;
  justify-content:space-between;
  gap:40px;
  max-width:1200px;
  margin:auto;
}

.footer-col{
  flex:1;
}

footer a{
  color:white;
  text-decoration:none;
  transition:0.3s;
}

footer a:hover{
  color:#c8a96a;
}

.footer-logo img{
  max-width:120px;
}

.social p{
  cursor:pointer;
  transition:0.2s;
}

.social p:hover{
  color:#c8a96a;
}

/* =========================
   POPUP
========================= */

#promoPopup{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,0.6);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:0.4s;
  z-index:9999;
}

#promoPopup.active{
  opacity:1;
  pointer-events:auto;
}

.popup-content{
  position:relative;
  transform:scale(0.3);
  transition:0.5s ease;
}

#promoPopup.active .popup-content{
  transform:scale(1);
}

.popup-content img{
  max-width:90vw;
  max-height:80vh;
  border-radius:12px;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}

.close-btn{
  position:absolute;
  top:-10px;
  right:-10px;
  background:#c8a96a;
  color:white;
  width:30px;
  height:30px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  font-size:18px;
}

/* =========================
   SCROLL TOP
========================= */

.scroll-top{
  position:fixed;
  bottom:20px;
  right:20px;
  width:55px;
  height:55px;
  background:#c8a96a;
  color:white;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  font-weight:bold;
  cursor:pointer;
  box-shadow:0 5px 20px rgba(0,0,0,0.3);
  transition:0.3s;
}

.scroll-top:hover{
  transform:translateY(-3px);
}

/* =========================
   MOBILE
========================= */

@media(max-width:900px){

  .hamburger{
    display:block;
  }

  .menu{
    display:none;
    flex-direction:column;
  }

  .menu.active{
    display:flex;
  }

  .menu ul{
    flex-direction:column;
    gap:0;
  }

  .menu ul ul{
    position:relative;
    display:none;
    box-shadow:none;
    transform:none;
    opacity:1;
  }

  .menu ul ul.active{
    display:block;
  }

  .footer-container,
  .contact-container{
    flex-direction:column;
  }

}

@media(max-width:768px){

  .booking-bar{
    flex-direction:column;
    align-items:stretch;
  }

  .divider{
    display:none;
  }

  .booking-btn{
    justify-content:center;
  }

  .intro-container{
    flex-direction:column;
  }

  .scroll-top{
    width:45px;
    height:45px;
    font-size:18px;
  }

  .logo img{
    height:60px;
  }

  .header.scrolled .logo img{
    height:50px;
  }

  .topbar{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }

  .topbar > .hamburger,
  .topbar > .lang{
    width:100%;
  }

  .topbar > .lang{
    display:flex;
    justify-content:flex-end;
    align-items:center;
    gap:8px;
  }

  .logo{
    text-align:center;
  }

  .logo img{
    height:50px;
  }

  .lang{
    position:static;
  }

}

.slider .slides{
  display:flex !important;
  flex-wrap:nowrap !important;
  transition:transform 0.5s ease;
}

.slider .slides img{
  flex:0 0 100% !important;
  width:100% !important;
  height:400px;
  object-fit:cover;
  display:block;
}


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

body{
    background:#f5f5f5;
    font-family:Arial,sans-serif;
}

/* SZEKCIÓ */
.rooms-section{
    width:100%;
    max-width:1400px;
    margin:100px auto;
    overflow:hidden;
}

/* SWIPER */
.swiper{
    width:100%;
    padding-bottom:60px;
}

/* SLIDE */
.room-slide{
    display:flex;
    align-items:center;

    width:100%;
}

/* BAL OLDAL */
.left{
    width:40%;
    z-index:5;

    display:flex;
    justify-content:flex-end;
}

/* JOBB OLDAL */
.right{
    width:60%;
}

.right img{
    width:100%;
    height:520px;
    object-fit:cover;
    display:block;
}

/* FEHÉR DOBOZ */
.card{

    width:420px;

    background:white;

    padding:45px;

    box-shadow:0 20px 50px rgba(0,0,0,0.15);

    position:relative;

    z-index:10;

    transform:translateX(180px);
}

/* CÍM */
.card h1{
    font-size:42px;
    margin-bottom:25px;
}

/* SZÖVEG */
.card p{
    line-height:1.8;
    color:#444;
    margin-bottom:25px;
}

/* LISTA */
.card ul{
    padding-left:20px;
    margin-bottom:30px;
}

.card li{
    margin-bottom:10px;
}

/* GOMB */
.book-btn{

    display:inline-block;

    background:#c8a46b;

    color:white;

    text-decoration:none;

    padding:14px 28px;

    letter-spacing:1px;

    transition:0.3s;
}

.book-btn:hover{
    opacity:0.85;
}

/* SWIPER PONTOK */
.swiper-pagination-bullet{
    width:12px;
    height:12px;
}

.swiper-pagination-bullet-active{
    background:#c8a46b;
}

/* MOBIL */
@media(max-width:900px){

    .room-slide{
        flex-direction:column;
    }

    .left{
        width:100%;
        justify-content:center;

        order:2;
    }

    .right{
        width:100%;

        order:1;
    }

    .right img{
        height:320px;
    }

    .card{

        width:90%;

        transform:none;

        margin-top:-50px;

        padding:30px;
    }

    .card h1{
        font-size:30px;
    }

}

/* ROOM CARD */

.room-card{
width:320px;
border-radius:12px;
overflow:hidden;
box-shadow:0 8px 25px rgba(0,0,0,0.15);
transition:0.3s;
}

/* kép konténer */
.room-image{
position:relative;
}

.room-image img{
width:100%;
height:240px;
object-fit:cover;
display:block;
}

/* ===== FELSŐ CÍMKÉK ===== */

.label{
    position:absolute;
    top:12px;

    display:inline-flex;
    align-items:center;

    width:auto;
    max-width:max-content;

    background:linear-gradient(135deg,#c8a96a,#b89658);
    color:white;

    padding:6px 14px;
    font-size:12px;
    font-weight:500;
    letter-spacing:1px;

    border-radius:6px;
    box-shadow:0 4px 10px rgba(0,0,0,0.2);
    z-index:2;
}

.label.left{
    left:12px;
    right:auto;
}

.label.right{
    right:12px;
    left:auto;
}


/* ===== ALSÓ SÁV ===== */

.room-bottom{
position:absolute;
bottom:45px; /* hagyunk helyet a gombnak */
left:0;
width:100%;

padding:12px 15px;

/* SÖTÉTEBB lett */
background:linear-gradient(to top, rgba(0,0,0,0.9), rgba(0,0,0,0.2));

color:white;
font-size:13px;

display:flex;
justify-content:space-between;
flex-wrap:wrap;
}

/* elemek */
.room-bottom span{
display:flex;
align-items:center;
gap:4px;
opacity:0.95;
}

.details-btn{
position:absolute;
bottom:10px;
left:50%;
transform:translateX(-50%);

color:white;
font-size:13px;
letter-spacing:1px;
font-weight:400;

text-decoration:none;

/* 🔥 FEHÉR KERET */
border:1px solid rgba(255,255,255,0.8);
padding:8px 18px;
border-radius:4px;

/* áttetsző háttér */
background:rgba(255,255,255,0.05);

/* finom blur */
backdrop-filter:blur(3px);

transition:all 0.3s ease;
}

/* hover */

.details-btn:hover{
background:white;
color:#333;

border-color:white;

transform:translateX(-50%) translateY(-2px);
}

/* ===== HOVER (luxus effekt) ===== */

.room-card:hover{
transform:translateY(-8px) scale(1.02);
box-shadow:0 20px 40px rgba(0,0,0,0.25);
}

.room-card:hover .label{
transform:translateY(-2px);
}

.room-card:hover .room-bottom{
background:linear-gradient(to top, rgba(0,0,0,0.9), transparent);
}

/* OVERLAY */

.room-overlay{
position:absolute;
bottom:0;
width:100%;
padding:20px;
background:linear-gradient(to top, rgba(0,0,0,0.8), transparent);
color:white;
text-align:left;
}

/* TEXT */

.room-overlay h2{
margin-bottom:8px;
}

.room-overlay p{
font-size:14px;
line-height:1.6;
}

/* HOVER EFFECT */

.room-card:hover{
transform:translateY(-10px) scale(1.03);
box-shadow:0 15px 40px rgba(0,0,0,0.25);
outline:2px solid #c8a96a;
}


/* ===== V6: restore original category-card overlay layout ===== */
.room-image{
  position:relative;
  overflow:hidden;
}
.room-bottom{
  position:absolute !important;
  bottom:45px !important;
  left:0 !important;
  width:100% !important;
  padding:12px 15px !important;
  background:linear-gradient(to top, rgba(0,0,0,0.9), rgba(0,0,0,0.2)) !important;
  color:white !important;
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  gap:6px 8px !important;
  font-size:13px !important;
}
.room-bottom span{
  display:flex !important;
  align-items:center !important;
  gap:4px !important;
  opacity:.95 !important;
  white-space:nowrap !important;
}
.room-bottom svg{
  flex:0 0 18px !important;
}
.details-btn{
  position:absolute !important;
  bottom:10px !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  display:inline-block !important;
  width:auto !important;
  min-width:150px !important;
  max-width:80% !important;
  text-align:center !important;
  color:white !important;
  border:1px solid rgba(255,255,255,0.8) !important;
  background:rgba(255,255,255,0.05) !important;
  border-radius:4px !important;
  padding:8px 18px !important;
}
.details-btn:hover{
  transform:translateX(-50%) translateY(-2px) !important;
}
@media(max-width:600px){
  .room-card{width:90%;}
  .room-image img{height:240px; object-fit:cover;}
  .room-bottom{font-size:12px !important; padding:10px 12px !important; gap:5px 6px !important;}
  .room-bottom span{gap:3px !important;}
  .details-btn{font-size:13px !important; padding:7px 16px !important;}
}
@media(max-width:380px){
  .room-bottom{font-size:11px !important;}
  .room-bottom svg{width:16px !important; height:16px !important; flex-basis:16px !important;}
}


/* === Mariposa v17 verified hard fixes === */

/* Header tényleges osztályai */
.header,
.header .topbar,
.header .menu,
.topbar,
.menu{
  background-color:#f4eddf !important;
  background-image:
    url("data:image/svg+xml,%3Csvg width='180' height='130' viewBox='0 0 180 130' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23c8a96a' stroke-width='1.1' opacity='.20'%3E%3Cpath d='M90 65 C68 28 28 28 32 65 C36 102 70 88 90 65Z'/%3E%3Cpath d='M90 65 C112 28 152 28 148 65 C144 102 110 88 90 65Z'/%3E%3Cpath d='M90 48 L90 92'/%3E%3C/g%3E%3C/svg%3E") !important;
  background-size:300px 215px !important;
}

/* A konkrét HU | EN + Foglalás blokk */
.lang{
  position:absolute !important;
  right:110px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  white-space:nowrap !important;
  z-index:10001 !important;
}

.lang a{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.header-booking-btn{
  margin-left:8px !important;
  padding:10px 16px !important;
  max-width:170px !important;
  white-space:nowrap !important;
}

/* Robot Tündi valódi konténere + felfelé nyíl valódi azonosítók */
#mariposa-ai-chat-root{
  right:42px !important;
  left:auto !important;
  bottom:92px !important;
}

#scrollTopBtn,
.scroll-top,
.back-to-top,
.to-top,
#backToTop{
  right:42px !important;
  left:auto !important;
}

/* Az oldal háttérmintája ténylegesen látszódjon */
html, body{
  background-color:#f4eddf !important;
  background-image:
    url("data:image/svg+xml,%3Csvg width='220' height='160' viewBox='0 0 220 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23b99757' stroke-width='1.25' opacity='.24'%3E%3Cpath d='M110 78 C82 35 32 30 36 76 C40 122 86 102 110 78Z'/%3E%3Cpath d='M110 78 C138 35 188 30 184 76 C180 122 134 102 110 78Z'/%3E%3Cpath d='M110 78 C86 110 62 144 102 136 C122 132 119 98 110 78Z'/%3E%3Cpath d='M110 78 C134 110 158 144 118 136 C98 132 101 98 110 78Z'/%3E%3Cpath d='M110 58 L110 110'/%3E%3C/g%3E%3C/svg%3E") !important;
  background-size:360px 260px !important;
  background-repeat:repeat !important;
  overflow-x:hidden !important;
}

/* Fehér szakaszok krémesítése */
.intro,
.about,
.welcome-section,
.content-section,
.white-section,
.gallery,
.rooms-section,
.all-rooms-section,
.attractions-two-col,
.room-category-section{
  background-color:transparent !important;
}

/* Footerben ne jelenjen meg duplikált nyíl/szöveg */
.footer-col.social p,
.social p,
.social-icons{
  font-size:0 !important;
}

.footer-col.social a,
.social a,
.social-icons a{
  font-size:0 !important;
  color:transparent !important;
  text-decoration:none !important;
}

.footer-col.social svg,
.social svg,
.social-icons svg{
  width:26px !important;
  height:26px !important;
  margin:0 8px !important;
}

@media(max-width:900px){
  .lang{
    right:18px !important;
    gap:7px !important;
  }

  .header-booking-btn{
    padding:8px 11px !important;
    font-size:12px !important;
  }

  #mariposa-ai-chat-root,
  #scrollTopBtn,
  .scroll-top,
  .back-to-top,
  .to-top,
  #backToTop{
    right:18px !important;
  }
}


/* === Mariposa v20 room labels, 2x2 feature strip, transparent logo support === */
.all-room-card{position:relative!important;}
.all-room-badge{
  position:absolute;
  top:16px;
  left:16px;
  z-index:4;
  background:#c8a96a;
  color:white;
  padding:10px 18px;
  border-radius:8px;
  font-weight:700;
  font-size:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
}
.all-room-number-badge{
  position:absolute;
  top:16px;
  right:16px;
  z-index:4;
  background:#c8a96a;
  color:white;
  padding:10px 18px;
  border-radius:8px;
  font-weight:700;
  font-size:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
}

/* szoba kategória oldalak: alsó sáv ikonok 2 sor / 2 oszlop */
.room-features,
.card-features,
.room-card-features,
.features,
.room-info,
.room-meta{
  display:grid!important;
  grid-template-columns:repeat(2, minmax(0,1fr))!important;
  gap:10px 16px!important;
  align-items:center!important;
}
.room-features li,
.card-features li,
.room-card-features li,
.features li,
.room-info li,
.room-meta li,
.room-features span,
.card-features span,
.room-card-features span{
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  white-space:nowrap!important;
  min-width:0!important;
}

/* ha overlay sávban van, ne 3+1 legyen */
.room-card .features,
.room-card .room-features,
.room-slide .features,
.room-slide .room-features,
.category-card .features,
.category-card .room-features{
  grid-template-columns:repeat(2, 1fr)!important;
}

/* logo ne fehér négyzetként hasson */
.logo img,
.header .logo img,
.site-logo img{
  background:transparent!important;
  mix-blend-mode:multiply;
}

/* logó átlátszó PNG támogatás */
.logo img[src*="logo"],
.header .logo img[src*="logo"]{
  background-color:transparent!important;
}

@media(max-width:600px){
  .all-room-badge,
  .all-room-number-badge{
    font-size:14px;
    padding:8px 14px;
  }
}
