@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');
/* ---------- Reset ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

:root{
  /* Typography */
  --font-sans: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-display: ui-serif, Georgia, "Times New Roman", serif;

  /* Base colors */
  --bg: #f4f2ee;
  --surface: rgba(255,255,255,.92);
  --text: #101217;
  --muted: rgba(16,18,23,.66);
  --border: rgba(16,18,23,.10);

  /* Elevation */
  --shadow-sm: 0 10px 30px rgba(2,6,23,.08);
  --shadow: 0 20px 60px rgba(2,6,23,.10);

  /* Shape */
  --radius: 20px;
  --radius-sm: 14px;

  /* Brand (Logo Colors) */
  --brand-green: #253c18;   /* koyu yeşil */
  --brand-green-2: #4e6a41; /* orta yeşil */
  --brand-sand: #d1a663;    /* altın/kum */
  --brand-tan: #94856f;     /* açık kahve */
}

html{ scroll-behavior: smooth; }

body{
  font-family: var(--font-sans);
  color: var(--text);
  background:
    radial-gradient(900px 520px at 20% -10%, rgba(209,166,99,.16), rgba(255,255,255,0) 65%),
    radial-gradient(900px 520px at 90% 0%, rgba(37,60,24,.10), rgba(255,255,255,0) 60%),
    var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1,h2,h3{
  font-family: var(--font-display);
  letter-spacing: .2px;
}

:focus-visible{
  outline: 3px solid rgba(209,166,99,.55);
  outline-offset: 2px;
}

.container{
  width: min(1120px, 92%);
  margin: 0 auto;
}

/* ---------- Header ---------- */
.header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.header-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 0;
}

.header-inner .btn-primary{
  box-shadow: 0 14px 35px rgba(0,0,0,.18);
}

.nav-link{
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.nav-link:hover{
  transform: translateY(-1px);
}


.brand{
  font-weight: 800;
  letter-spacing: .6px;
}

.nav{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}

.nav-link{
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 650;
  color: rgba(0,0,0,.70);
}

.nav-link:hover,
.nav-link.active{
  background: rgba(0,0,0,.06);
  color: rgba(0,0,0,.92);
}

/* ---------- Buttons ---------- */
.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 750;
  border: 1px solid transparent;
  white-space: nowrap;
}

.btn-primary{
  background: var(--brand-green) !important;
  border-color: var(--brand-green) !important;
  color: #fff !important;
  box-shadow: 0 18px 45px rgba(37,60,24,.18);
  transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;
}

.btn-ghost{
  background: transparent;
  border-color: rgba(37,60,24,.28);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}

.btn-primary:hover{
  filter: brightness(.98);
  transform: translateY(-1px);
  box-shadow: 0 22px 60px rgba(37,60,24,.22);
}

.btn-ghost:hover{
  background: rgba(209,166,99,.14);
  border-color: rgba(209,166,99,.28);
  transform: translateY(-1px);
}

/* ---------- Hero ---------- */
.hero{
  position: relative;
  min-height: 78vh;
  display: block;
  overflow: hidden;
  padding-bottom: 120px; /* altta booking kartına yer bırak */
}

/* Hero içindeki tüm üst katmanlar (topbar, header, navbar, başlık) */
.hero-shell{
  position: relative;
  z-index: 2;
}

/* Ana sayfada hero normal konumda kalsın */
.home .hero{
  margin-top: 0;
}

.hero-bg{
  position: absolute;
  inset: 0;
  background-image: url("../img/hero.jpg");
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  filter: saturate(1.05) contrast(1.05);
}


.hero-overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 360px at 50% 50%, rgba(0,0,0,.55), rgba(0,0,0,0) 65%),
    linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.20) 55%, rgba(255,255,255,0));
}


.hero-content{
  position: relative;
  text-align: center;
  color: #fff;
  padding: 72px 0;
}

.hero-content{
  max-width: 900px;
  padding: 72px 18px;
}

.hero-content::before{
  content: "";
  position: absolute;
  inset: auto 0 auto 0;
  left: 50%;
  transform: translateX(-50%);
  top: 50%;
  translate: 0 -50%;
  width: min(820px, 94%);
  height: 240px;
  border-radius: 26px;

  /* 🔑 ASIL DEĞİŞİKLİK */
  background: linear-gradient(
    180deg,
    rgba(0,0,0,.38),
    rgba(0,0,0,.22)
  );

  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  z-index: -1;
}


.hero-title{
  text-shadow: 0 18px 50px rgba(0,0,0,.65);
}

.hero-sub{
  color: rgba(255,255,255,.85);
  text-shadow: 0 10px 30px rgba(0,0,0,.6);
}

.hero-kicker{
  margin: 0 0 8px;
  letter-spacing: .24em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.75);
}

.hero-title{
  margin: 0 0 12px;
  font-size: clamp(34px, 5vw, 64px);
  line-height: 1.05;
}

.hero-sub{
  margin: 0 auto 22px;
  max-width: 62ch;
  color: rgba(255,255,255,.80);
  font-size: clamp(16px, 2vw, 20px);
}

.hero-actions{
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.hero-bottom-fade{
  position: absolute;
  inset: auto 0 0 0;
  height: 120px;
  background: linear-gradient(
  180deg,
  rgba(0,0,0,.32),
  rgba(0,0,0,.18)
);

}

/* ---------- Sections ---------- */
.section{
  padding: 64px 0;
}

.section-head{
  display: grid;
  gap: 6px;
  margin-bottom: 18px;
}

.section-head h2{
  margin: 0;
  font-size: 30px;
}

.section-head p{
  margin: 0;
  color: var(--muted);
}

/* Cards */
.cards{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
}

.card h3{ margin: 0 0 8px; }
.card p{ margin: 0; color: var(--muted); }

/* Banner */
.banner{
  background: #0c0f14;
  color: #fff;
  padding: 44px 0;
}

.banner-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.banner h2{ margin: 0 0 6px; }
.banner p{ margin: 0; color: rgba(255,255,255,.75); }

/* Footer */
.footer{
  border-top: 1px solid rgba(0,0,0,.06);
  padding: 28px 0;
}

.footer-inner{
  display: grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap: 16px;
  align-items: start;
}

.brand-footer{
  font-weight: 900;
  margin-bottom: 6px;
}

.footer-links{
  display: grid;
  gap: 8px;
}

.muted{ color: var(--muted); }

/* Responsive */
@media (max-width: 900px){
  .cards{ grid-template-columns: 1fr; }
  .banner-inner{ flex-direction: column; align-items: flex-start; }
  .footer-inner{ grid-template-columns: 1fr; }
}

/* ---------- Rooms Page ---------- */
.page-hero{
  position: relative;
  min-height: 42vh;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.page-hero-bg{
  position: absolute;
  inset: 0;
  background-image: url("../img/hero-rooms.JPG");
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  filter: saturate(1.05) contrast(1.05);
}

.page-hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.60), rgba(0,0,0,.25));
}

.page-hero-content{
  position: relative;
  color: #fff;
  text-align: center;
  padding: 40px 0;
}

.page-hero-content h1{
  margin: 0 0 8px;
  font-size: clamp(28px, 4vw, 46px);
  color: #fff;
  text-shadow: 0 12px 30px rgba(0,0,0,.6);
}

.page-hero-content p{
  margin: 0;
  color: rgba(255,255,255,.80);
  text-shadow: 0 8px 24px rgba(0,0,0,.55);
}

.page-hero-content .hero-kicker{
  color: rgba(255,255,255,.85);
  text-shadow: 0 8px 24px rgba(0,0,0,.55);
}

.room-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.room-card{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 22px 70px rgba(0,0,0,.08);
  background: #fff;
}

.room-img{
  height: 210px;
  background-size: cover;
  background-position: center;
}

.room-body{
  padding: 16px;
}

.room-body h3{
  margin: 0 0 6px;
}

.room-actions{
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}

@media (max-width: 900px){
  .room-grid{ grid-template-columns: 1fr; }
}

/* ---------- Gallery ---------- */
.gallery-toolbar{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.chips{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.chip{
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.9);
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
}

.chip.active,
.chip:hover{
  background: rgba(0,0,0,.06);
}

/* ---------- Gallery (Masonry / No gaps) ---------- */
.gallery-grid{
  column-count: 3;
  column-gap: 14px;
}

.g-item{
  break-inside: avoid;
  margin: 0 0 14px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 60px rgba(0,0,0,.08);
  background: #fff;
}

.g-btn{
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: zoom-in;
  display: block;
}

.g-btn img{
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  transition: transform .25s ease;
}

.g-btn:hover img{
  transform: scale(1.04);
}

@media (max-width: 1000px){
  .gallery-grid{ column-count: 2; }
}
@media (max-width: 640px){
  .gallery-grid{ column-count: 1; }
}


/* Lightbox */
.lightbox{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 200;
}

.lightbox.open{
  display: block;
}

.lb-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.72);
}

.lb-panel{
  position: relative;
  width: min(1050px, 92%);
  margin: 5vh auto;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 40px 120px rgba(0,0,0,.45);
  background: rgba(10,12,16,.85);
  backdrop-filter: blur(10px);
}

.lb-img{
  width: 100%;
  max-height: 78vh;
  object-fit: contain;
  display: block;
  background: rgba(0,0,0,.35);
}

.lb-close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
}

.lb-actions{
  position: absolute;
  inset: auto 0 18px 0;
  display: flex;
  justify-content: space-between;
  padding: 0 14px;
  
}

.lb-nav{
  pointer-events: auto;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.35);
  color: #fff;
  font-size: 28px;
  cursor: pointer;
}

@media (max-width: 900px){
  .gallery-grid{ grid-template-columns: 1fr; }
  .g-item:nth-child(1),
  .g-item:nth-child(8),
  .g-item:nth-child(n){
    grid-column: auto;
  }
  .g-btn img{ height: 210px; }
  .lb-panel{ margin: 10vh auto; }
}
/* ---------- Hero Video ---------- */
.hero-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* Video üstündeki her şey videonun üstünde olsun */
.hero-overlay,
.hero-content{
  position: relative;
  z-index: 1;
}

/* Mobilde videoyu kapat, foto göster */
@media (max-width: 768px){
  .hero-video{ display: none; }

  .hero{
    background-image: url("../img/hero-mobile.jpg");
    background-size: cover;
    background-position: center;
  }
}

/* ---------- Hero Text (videonun üstünde) ---------- */
.hero-content{
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
  padding: 96px 18px 40px;
}

.hero-content .container{
  max-width: 900px;
}

.hero-title{
  margin: 0 0 12px;
  font-size: clamp(34px, 5vw, 64px);
  line-height: 1.05;
  text-shadow: 0 18px 50px rgba(0,0,0,.65);
}

.hero-sub{
  margin: 0 auto 22px;
  max-width: 62ch;
  color: rgba(255,255,255,.80);
  font-size: clamp(16px, 2vw, 20px);
  text-shadow: 0 10px 30px rgba(0,0,0,.6);
}

.hero-kicker{
  margin: 0 0 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.75);
}

.hero-actions{
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 22px;
}

/* ---------- Öne Çıkanlar Section ---------- */
.section{
  padding: 72px 0 80px;
}

.section-head{
  display: grid;
  gap: 8px;
  margin-bottom: 26px;
  text-align: center;
}

.section-head h2{
  font-size: 32px;
}

.section-head p{
  font-size: 14px;
  color: var(--muted);
}


/* ---------- Contact Page ---------- */
.contact-grid{
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 18px;
  margin-top: 10px;
}

.contact-cards{
  display: grid;
  gap: 14px;
}

.c-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 16px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.06);
}

.c-card h3{ margin: 0 0 6px; }
.c-link{
  display: inline-block;
  font-weight: 800;
  margin-top: 6px;
}

.contact-right{
  display: grid;
  gap: 14px;
}

.contact-form,
.contact-map{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 16px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.06);
}

.contact-form h2,
.contact-map h2{
  margin: 0 0 8px;
}

.form-row{
  display: grid;
  gap: 8px;
  margin: 12px 0;
}

label{
  font-weight: 700;
  color: rgba(0,0,0,.75);
}

input, textarea{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.14);
  outline: none;
  font: inherit;
  background: #fff;
}

input:focus, textarea:focus{
  border-color: rgba(0,0,0,.35);
}

.map-frame{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.10);
  height: 320px;
}

.map-frame iframe{
  width: 100%;
  height: 100%;
  border: 0;
}

@media (max-width: 900px){
  .contact-grid{ grid-template-columns: 1fr; }
  .map-frame{ height: 280px; }
}

/* ---------- Page Hero Backgrounds ---------- */
.page-hero{
  position: relative;
  min-height: 42vh;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.page-hero-bg{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
}

.page-hero-overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,.55),
    rgba(0,0,0,.35)
  );
}

/* SAYFAYA ÖZEL */
.page-rooms .page-hero-bg{
  background-image: url("../img/hero-rooms.JPG");
}

.page-gallery .page-hero-bg{
  background-image: url("../img/hero-gallery.JPG");
}

.page-contact .page-hero-bg{
  background-image: url("../img/hero-contact.jpg");
}

.page-factsheet .page-hero-bg{
  background-image: url("../img/hero-factsheet.jpg");
}

/* ---------- Header Social Icons ---------- */
.header-social{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-right: 10px;
}

.header-social a{
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(0,0,0,.06);
  transition: background .2s ease, transform .2s ease;
}

.header-social a:hover{
  background: rgba(0,0,0,.14);
  transform: translateY(-1px);
}

.header-social svg{
  width: 18px;
  height: 18px;
  fill: #111;
}

/* Mobilde biraz küçült */
@media (max-width: 768px){
  .header-social a{
    width: 30px;
    height: 30px;
  }
  .header-social svg{
    width: 16px;
    height: 16px;
  }
}

/* =========================
   Brand Palette (Logo Colors)
   ========================= */
:root{
  --brand-green: #253c18;   /* koyu yeşil */
  --brand-green-2: #4e6a41; /* orta yeşil */
  --brand-sand: #d1a663;    /* altın/kum */
  --brand-tan: #94856f;     /* açık kahve */
}

/* Header brand logo */
.brand{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.brand-mark{
  width: 34px;
  height: 34px;
  object-fit: contain;
}

.brand-text{
  font-weight: 900;
  letter-spacing: .3px;
}

/* Buttons: artık marka rengi */
.btn-primary{
  background: var(--brand-green) !important;
  border-color: var(--brand-green) !important;
  color: #fff !important;
}

.btn-ghost{
  border-color: rgba(37,60,24,.35) !important;
}

/* Menü aktif/hover ufak marka dokunuşu */
.nav-link.active,
.nav-link:hover{
  background: rgba(209,166,99,.18) !important; /* kum tonu */
  color: rgba(0,0,0,.92) !important;
}

/* Header social icons */
.header-social{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-right: 10px;
}

.header-social a{
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(209,166,99,.18); /* kum tonu */
  border: 1px solid rgba(37,60,24,.12);
  transition: background .2s ease, transform .2s ease;
}

.header-social a:hover{
  background: rgba(209,166,99,.30);
  transform: translateY(-1px);
}

.header-social svg{
  width: 18px;
  height: 18px;
  fill: var(--brand-green);
}

/* Galeri filtre chipleri marka rengi */
.chip.active{
  background: rgba(37,60,24,.10) !important;
  border-color: rgba(37,60,24,.25) !important;
}

/* Banner alanı daha premium */
.banner{
  background: linear-gradient(120deg, var(--brand-green), #0c0f14) !important;
}

/* ---------- Topbar + Main Header (Voyage style) ---------- */
.topbar{
  background: #0f1410;
  color: rgba(255,255,255,.86);
  font-size: 12px;
}

.topbar-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
}

.topbar-left{
  display: flex;
  align-items: center;
  gap: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.burger{
  width: 40px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  color: #fff;
  cursor: pointer;
}

.topbar-right{
  display: flex;
  align-items: center;
  gap: 10px;
}

.pill{
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  white-space: nowrap;
}

/* Main header */
.header{
  position: relative;
  z-index: 3;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,.08);
}

/* Ana sayfada header ve menü videonun üstünde, daha şeffaf görünsün */
.home .header{
  background: transparent;
  border-bottom: 0;
}

.home .navbar{
  background: transparent;
  border-bottom: 0;
  position: relative;
  z-index: 3;
}

.header-inner.voyage{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
}

.header-left{
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-center{
  display: grid;
  place-items: center;
}

.brand.big{
  gap: 12px;
}

.brand-mark.big{
  width: 52px;
  height: 52px;
}

.header-right{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.header-social{
  margin-right: 0;
}

/* Menü (2. satır gibi) */
.navbar{
  background: #fff;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.navbar-inner{
  display: flex;
  justify-content: center;
  gap: 14px;
  padding: 12px 0;
  flex-wrap: wrap;
}

/* Ana sayfada menü şeridi videonun üstünde, şeffaf dursun */
.home .navbar{
  background: transparent;
  border-bottom: 0;
}

.home .nav-link{
  color: rgba(255,255,255,.92);
}

.home .nav-link:hover,
.home .nav-link.active{
  background: rgba(255,255,255,.14) !important;
  color: #fff !important;
}

.nav-link{
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
}

/* Mobil */
@media (max-width: 900px){
  .header-inner.voyage{ grid-template-columns: 1fr auto; }
  .header-right{ display: none; }
  .brand-mark.big{ width: 44px; height: 44px; }
}
/* ---------- Rating Bar (sticky) ---------- */
.rating-bar{
  position: fixed;
  left: 0;
  right: 0;

  /* bottom: 0; yerine: */
    bottom: calc(14px + env(safe-area-inset-bottom));

  background: #0f1410;
  color: rgba(255,255,255,.9);
  border-top: 1px solid rgba(255,255,255,.10);
  z-index: 300;

  /* köşeleri yumuşat */
  border-radius: 16px;
  width: min(1120px, 94%);
  margin: 0 auto;

  box-shadow: 0 18px 60px rgba(0,0,0,.25);
}


.rating-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 0;
}

.rating-left{
  display: flex;
  align-items: center;
  gap: 10px;
}

.rating-score{
  width: 56px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  font-weight: 900;
  font-size: 18px;
}

.rating-title{ font-weight: 900; line-height: 1.1; }
.rating-sub{ font-size: 12px; color: rgba(255,255,255,.70); }

.rating-items{
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.r-item{
  display: grid;
  gap: 2px;
  min-width: 120px;
  padding-left: 14px;
  border-left: 1px solid rgba(255,255,255,.12);
  font-size: 12px;
  text-decoration: none;
  color: inherit;
  border-radius: 10px;
}

.r-item:hover{
  background: rgba(255,255,255,.08);
}


.r-item span{ color: rgba(255,255,255,.70); }
.r-item b{ color: #fff; }

@media (max-width: 900px){
  .rating-items{ display: none; } /* mobilde sade kalsın */
}

/* Rating bar sayfanın altını kapatmasın */
body{ padding-bottom: 120px; }

/* ---------- Category Slider (Voyage style) ---------- */
.cat-slider{
  position: relative;
}

.cat-track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(240px, 1fr);
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 10px 6px;
  scrollbar-width: none;
}
.cat-track::-webkit-scrollbar{ display: none; }

.cat-card{
  position: relative;
  height: 360px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 22px 70px rgba(0,0,0,.10);

  /* kartın inline background-image'ını düzgün göster */
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;

  scroll-snap-align: start;
  text-decoration: none;
  transform: translateZ(0);
}



.cat-shade{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.55) 100%);
}

.cat-title{
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 16px;
  color: #fff;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 22px;
  text-shadow: 0 18px 50px rgba(0,0,0,.65);
}

.cat-card:hover{
  outline: 2px solid rgba(209,166,99,.45);
}

/* ok butonları */
.cat-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-size: 26px;
  z-index: 2;
}

.cat-nav.prev{ left: -4px; }
.cat-nav.next{ right: -4px; }

@media (max-width: 900px){
  .cat-card{ height: 300px; }
  .cat-nav{ display: none; } /* mobilde swipe yeterli */
}

/* Badge */
.cat-badge{
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(0,0,0,.10);
  color: rgba(0,0,0,.85);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  box-shadow: 0 16px 50px rgba(0,0,0,.18);
}
/* Kurumsal kapak */
.page-corporate .page-hero-bg{
  background-image: url("../img/hero-corporate.jpg");
}
/* ---------- Corporate Page ---------- */
.corp-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 10px;
}

.corp-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 18px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.06);
}

.corp-card h2{
  margin: 0 0 10px;
}

.corp-list{
  margin: 0;
  padding-left: 18px;
  color: rgba(16,18,23,.78);
}

.corp-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.corp-cta{
  grid-column: auto; 
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(120deg, var(--brand-green), #0c0f14);
  color: #fff;
  box-shadow: 0 24px 90px rgba(0,0,0,.10);
}

.corp-cta-inner{
  padding: 22px;
}

.corp-cta .muted{
  color: rgba(255,255,255,.78);
}

@media (max-width: 900px){
  .corp-grid{ grid-template-columns: 1fr; }
}
/* ---------- Fact Sheet (Web) ---------- */
.page-factsheet .page-hero-bg{
  background-image: url("../img/hero-factsheet.jpg"); /* istersen hero-factsheet.jpg */
}

.facts-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 10px;
}

.facts-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 18px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.06);
}

.facts-card h2{
  margin: 0 0 10px;
}

.facts-table{
  display: grid;
  gap: 10px;
}

.facts-table .row{
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 10px;
  border-bottom: 1px dashed rgba(0,0,0,.12);
}

.facts-table .row span{
  color: rgba(16,18,23,.65);
  font-weight: 700;
}

.facts-table .row b{
  color: rgba(16,18,23,.92);
  text-align: right;
}

.facts-list{
  margin: 0;
  padding-left: 18px;
  color: rgba(16,18,23,.78);
  display: grid;
  gap: 8px;
}

.facts-cta{
  grid-column: auto; 
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(120deg, var(--brand-green), #0c0f14);
  color: #fff;
  box-shadow: 0 24px 90px rgba(0,0,0,.10);
}

.facts-cta-inner{ padding: 22px; }
.facts-cta .muted{ color: rgba(255,255,255,.78); }

@media (max-width: 900px){
  .facts-grid{ grid-template-columns: 1fr; }
}
/* ---------- Factsheet (Hotel Information) ---------- */
.facts-header{
  margin-top: 8px;
  margin-bottom: 12px;
}

.facts-grid-2{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  align-items: start;
}

.facts-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 18px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 60px rgba(0,0,0,.06);
}

.facts-card h3{
  margin: 0 0 12px;
}

.facts-table{
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
}

.facts-table .row{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed rgba(0,0,0,.12);
}

.facts-table .row span{
  font-weight: 800;
  color: rgba(16,18,23,.78);
}

.facts-table .row b{
  font-weight: 900;
  color: rgba(16,18,23,.92);
  text-align: right;
}

.facts-table .row em{
  grid-column: auto; 
  font-style: normal;
  color: rgba(16,18,23,.62);
  font-size: 13px;
}

.facts-split{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 10px;
}

.pill-card{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 12px;
  background: rgba(246,245,242,.9);
}

.pill-card h4{
  margin: 0 0 8px;
  font-size: 14px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgba(16,18,23,.8);
}

.facts-list{
  margin: 0;
  padding-left: 18px;
  color: rgba(16,18,23,.78);
  display: grid;
  gap: 6px;
}

.facts-list.big{ gap: 10px; }

.facts-kv{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 10px 0;
}

.kv{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 12px;
  background: rgba(246,245,242,.9);
}

.kv span{
  display: block;
  color: rgba(16,18,23,.62);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.kv b{
  font-weight: 900;
  color: rgba(16,18,23,.92);
}

.note{
  margin-top: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(209,166,99,.10);
  color: rgba(16,18,23,.78);
}

.note b{ color: rgba(16,18,23,.92); }

.facts-cta{
  margin-top: 12px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(120deg, var(--brand-green), #0c0f14);
  color: #fff;
}

.facts-cta-inner{ padding: 18px; }
.facts-cta .muted{ color: rgba(255,255,255,.75); }

@media (max-width: 1000px){
  .facts-grid-2{ grid-template-columns: 1fr; }
  .facts-kv{ grid-template-columns: 1fr; }
}
.booking-wrap{
  max-width:1100px;
  margin:0 auto;
  padding:18px 16px;
}
.booking-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:18px;
  box-shadow:0 12px 40px rgba(2,6,23,.10);
  padding:14px 14px 12px;
}
.booking-title{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  padding:4px 6px 10px;
}
.booking-title b{font-size:16px;color:#0f172a}
.booking-title span{font-size:12px;color:#64748b}

.booking-field{
  border:1px solid #e2e8f0;
  border-radius:14px;
  padding:10px 12px;
  background:#fff;
}
.booking-field label{
  display:block;
  font-size:12px;
  color:#64748b;
  margin-bottom:6px;
}
.booking-field input{
  width:100%;
  border:0;
  outline:0;
  font-size:14px;
}
.booking-btn{
  border:0;
  border-radius:14px;
  padding:12px 14px;
  font-weight:800;
  cursor:pointer;
  background:#2f3aa5;
  color:#fff;
  height:100%;
}
.booking-btn:hover{filter:brightness(.96)}

.booking-guests{position:relative}
#homeGuestsBtn{
  width:100%;
  border:0;
  background:transparent;
  text-align:left;
  font-size:14px;
  cursor:pointer;
  padding:0;
  color:#0f172a;
}

.booking-panel{
  position:absolute;
  left:0; right:0;
  top:76px;
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:14px;
  box-shadow:0 20px 55px rgba(2,6,23,.16);
  padding:10px;
  display:none;
  z-index:2000;
}
.booking-panel.open{display:block}
.booking-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 6px;
  border-radius:10px;
}
.booking-row:hover{background:#f8fafc}
.booking-row b{font-size:14px}
.booking-row small{display:block;color:#64748b;font-size:12px}
.booking-step{display:flex;align-items:center;gap:10px}
.booking-step button{
  width:34px;height:34px;
  border-radius:10px;
  border:1px solid #e2e8f0;
  background:#fff;
  cursor:pointer;
  font-size:18px;
  line-height:0;
}
.booking-step span{min-width:18px;text-align:center;font-weight:800}
.booking-note{display:block;color:#64748b;font-size:12px;padding:6px 6px 2px}
.booking-wrap{ position: relative; z-index: 9999; }
.booking-card{ position: relative; z-index: 9999; }
/* Üst bar her şeyin üstünde kalsın ve tıklanabilsin */
.topbar, .header-top, .header-upper, .header {
  position: relative;
  z-index: 9999;
}

/* TR + hamburger sol grubu */
.topbar-left {
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Tıklanabilirliği garanti et */
.topbar-left * {
  pointer-events: auto;
}
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 18px;
  position:relative;
  z-index:9999;
}

/* Sol: sadece menü + TR */
.topbar-left{
  display:flex;
  align-items:center;
  gap:12px;
}

/* Sağ: telefon + rezervasyon */
.topbar-right{
  display:flex;
  align-items:center;
  gap:12px;
  margin-left:auto;
}
.topbar-left, .topbar-left *{ pointer-events:auto; }
/* Üst siyah bar: sağ sol tam yaslansın */
.topbar{
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  padding-left:16px !important;
  padding-right:16px !important;
}

/* Sağ grup kesin sağa gitsin */
.topbar-right{
  margin-left:auto !important;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
  gap:12px !important;
}
/* Menü/TR tıklansın diye en üste al */
.topbar, .topbar *{
  position: relative;
  z-index: 99999 !important;
  pointer-events: auto !important;
}
/* Üste binen şeffaf katmanlar tıklamayı engellemesin */
.overlay, .hero-overlay, .header-overlay, .bg-overlay{
  pointer-events:none !important;
}
/* Üst siyah bar: sol (menü+TR) / sağ (telefon+rezervasyon) */
.topbar {
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  width:100% !important;
  padding:12px 20px !important;
  position:relative !important;
  z-index:99999 !important;
}

/* Sol grup */
.topbar-left{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
}

/* Sağ grup TAM SAĞ */
.topbar-right{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  margin-left:auto !important;
  justify-content:flex-end !important;
}

/* Eğer üst bar bir container içindeyse tam genişlik */
.topbar-container{
  width:100% !important;
  max-width:none !important;
}
.topbar.topbar-container { max-width: none !important; width: 100% !important; }
.social { 
  width: 42px; height: 42px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: #f4ead8;
}
.social i { font-size: 18px; color: #25D366; } /* whatsapp yeşili */
/* TOPBAR HER SAYFADA AYNI HİZADA OLSUN */
.topbar {
  width: 100%;
  margin: 0;
  padding: 0;
}

/* İçerik sola ve sağa düzgün yaslansın */
.topbar-container {
  max-width: 100%;
  padding: 10px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* SOL TARAF (☰ + TR) */
.topbar-left {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: 0;
}

/* SAĞ TARAF (telefon + rezervasyon) */
.topbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-right: 0;
}
/* TR ve Menü butonu biraz aşağı insin */
.topbar-left {
  margin-top: 28px; /* 1 cm civarı */
}
.offcanvas-backdrop.show{
  opacity: 0.6;
}
/* OFFCANVAS MENÜ TASARIMI */
#mainMenu.offcanvas {
  width: 320px;
  background: linear-gradient(180deg, #0b0f0c 0%, #121a14 100%);
  color: #fff;
  border-right: 1px solid rgba(255,255,255,.08);
}

.menu-header {
  padding: 16px 16px 10px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.menu-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.menu-logo {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  object-fit: contain;
  padding: 6px;
}

.menu-title { font-weight: 700; font-size: 14px; }
.menu-sub   { font-size: 12px; opacity: .75; }

.menu-body { padding: 14px 14px 18px 14px; }

.menu-nav { display: grid; gap: 8px; }

.menu-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  color: rgba(255,255,255,.9);
  text-decoration: none;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.06);
}

.menu-link:hover {
  background: rgba(46, 204, 113, .15);
  border-color: rgba(46, 204, 113, .25);
  color: #fff;
}

.menu-link i { width: 18px; opacity: .9; }

.menu-divider {
  height: 1px;
  background: rgba(255,255,255,.08);
  margin: 14px 0;
}

.menu-actions { display: grid; gap: 10px; }

.menu-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  color: #fff;
  text-decoration: none;
  background: rgba(255,255,255,.08);
}

.menu-cta {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 12px 14px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  color: #fff;
  background: #198754;
}

.menu-social {
  display: flex;
  gap: 10px;
  margin-top: 16px;
}

.menu-social a {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.08);
  color: #fff;
  text-decoration: none;
}
/* Offcanvas her zaman üstte dursun */
#mainMenu.offcanvas {
  z-index: 2000 !important;
}

/* Bootstrap backdrop da üstte kalsın */
.offcanvas-backdrop {
  z-index: 1999 !important;
}

/* Header/Topbar offcanvas’ın altında kalsın */
.topbar, header, .header {
  position: relative;
  z-index: 10 !important;
}
#mainMenu.offcanvas { z-index: 2000 !important; }
.offcanvas-backdrop { z-index: 1999 !important; }
/* OFFCANVAS GÖRÜNMÜYOR SORUNU - KESİN ÇÖZÜM */
#mainMenu.offcanvas {
  position: fixed !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  visibility: visible !important;
  z-index: 2000 !important;
}

.offcanvas-backdrop {
  z-index: 1999 !important;
}
/* MENÜ AÇILIYOR AMA İÇERİK GÖRÜNMÜYORSA - KESİN ÇÖZÜM */
#mainMenu,
#mainMenu .offcanvas-header,
#mainMenu .offcanvas-body {
  color: #fff !important;
}

#mainMenu a,
#mainMenu a:visited {
  color: rgba(255,255,255,.92) !important;
  text-decoration: none !important;
}

#mainMenu a:hover {
  color: #fff !important;
}

/* Menü içindeki ikonlar */
#mainMenu i, 
#mainMenu svg {
  color: rgba(255,255,255,.92) !important;
  fill: rgba(255,255,255,.92) !important;
}

/* Menü öğeleri (buton gibi kutu görünüm) */
#mainMenu .menu-link {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}
#mainMenu .offcanvas-body {
  overflow-y: auto !important;
  padding-top: 16px !important;
}
/* Tarih alanı - booking tasarımını bozmadan */
.booking-field.date-field{
  position: relative;
}
/* Tarih alanı: tasarım bozulmadan, takvim kesin açılsın */
.booking-field.date-field{
  position: relative;
}
/* Grid bozulmasın: sadece date inputu text'in üstüne bindiriyoruz */
.booking-field.date-field{
  position: relative;
}

/* Görünen text input: mevcut booking-field input stilini kullansın */
.booking-field.date-field .date-display{
  width: 100%;
}

/* Gerçek date input: sadece input alanını kaplasın, label'a binmesin */
.booking-field.date-field .date-real{
  position: absolute;
  left: 0;
  right: 0;
  top: 34px;        /* label altına gelsin (gerekirse 30-38 arası oynat) */
  height: 44px;     /* senin input yüksekliğin */
  opacity: 0;
  cursor: pointer;
  z-index: 10;
}
/* Hızlı Rezervasyon: 4 kolon (Giriş / Çıkış / Kişi / Ara) */
.booking-grid{
  display: grid !important;
  grid-template-columns: 260px 260px 1fr 180px !important;
  gap: 16px !important;
  align-items: stretch !important;
}



/* TEK TEK ZORLA YERLEŞTİR (diğer CSS'ler ezemesin) */
#homeCheckinBox{  grid-column: 1 !important; }
#homeCheckoutBox{ grid-column: 2 !important; }
#homeGuestsBox{   grid-column: 3 !important; }
#homeSearchBox{   grid-column: 4 !important; }

/* Ara butonu kutu yüksekliğini doldursun */
#homeSearchBox .booking-btn,
#homeSearchBox button{
  height: 100% !important;
}


/* Ara butonu kutuyu doldursun */
#homeSearchBox .booking-btn--full{
  width:100%;
  height:100%;
  min-height:64px; /* eski buton yüksekliği gibi */
  border-radius:14px; /* sende neyse uyar */
}
/* Kişi paneli açılınca grid düzenini bozmasın */
#homeGuestsBox{ position: relative; }
#homeGuestsPanel{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 50;
}
/* Kişi paneli açılınca satırı bozmasın */
#homeGuestsBox { position: relative; }
#homeGuestsPanel{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 50;
}
/* Sayfa ana genişliği sıkıştıysa düzelt */
body, html { width: 100%; }

.container,
.header .container,
.main .container,
.section .container {
  max-width: 1200px;   /* sende eskiden kaçsa onu yazabiliriz */
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
/* Booking bölümü kendi içinde kalsın ama siteyi sıkıştırmasın */
.booking-wrap{
  width: 100%;
}

.booking-card{
  width: min(1200px, 100%);
  margin: 0 auto;
}
/* === HIZLI REZERVASYON GRID (eski gibi yan yana) === */
.booking-grid{
  display: grid !important;
  grid-template-columns: 1.05fr 1.05fr 1.3fr .7fr !important; /* giriş / çıkış / kişi / ara */
  gap: 10px !important;
  align-items: end !important;
}

/* Grid içindekiler taşma yapmasın */
.booking-grid > *{ min-width: 0; }

/* Mobilde alt alta */
@media (max-width: 900px){
  .booking-grid{ grid-template-columns: 1fr !important; }
}

/* === Kişi paneli açılınca satırı bozmasın (overlap açılır) === */
#homeGuestsBox{ position: relative; }

#homeGuestsPanel{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 999;
}

/* Panel görünümü (opsiyonel ama güzel durur) */
#homeGuestsPanel{
  background: #fff;
  border: 1px solid #e6e6e6;
  border-radius: 12px;
  box-shadow: 0 12px 30px rgba(0,0,0,.12);
  padding: 12px;
}
/* Site genelini tam genişlikte tut (sıkışmayı engelle) */
body{ width:100%; }
main, header, footer, section{ max-width: none; }

/* Booking sadece kendi kartında sınırlı kalsın */
.booking-wrap{
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 18px 16px;
}

.booking-card{
  max-width: 1100px;
  margin: 0 auto;
}
/* booking-wrap SADECE rezervasyon alanı olsun */
.booking-wrap{
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

/* kart görünümü booking-card'da kalsın */
.booking-card{
  max-width: 1100px;
  margin: 0 auto;
  padding: 18px 16px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 20px 40px rgba(0,0,0,.08);
}
.booking-wrap{
  max-width: none !important;
  margin: 0 !important;
  padding: 18px 16px !important;
  background: transparent !important;
}

.booking-card{
  max-width: 1100px;
  margin: 0 auto;
}
.date-field { position: relative; }
.date-display { width: 100%; cursor: pointer; background: #fff; }
.date-real { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
/* Index'teki tarih mantığı: yazı görünür, gerçek date gizli */
.date-field { position: relative; }
.date-display {
  width: 100%;
  cursor: pointer;
  background: #fff;
}
.date-real{
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
.hero{
  position: relative;
  width: 100%;
  height: 70vh; /* videonun yüksekliği - istersen 80vh yap */
  overflow: hidden;
}

.heroVideo{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 1) En üst siyah şerit yok: header şeffaf ve video üstünde */
.siteHeader{
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

.headerInner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
}

/* 2) Logo + sosyal ikonlar kısmındaki saydam/blur şerit kalksın */
.topOverlay{
  position: absolute;
  top: 90px;           /* header’ın altına gelsin */
  left: 0;
  right: 0;
  z-index: 40;

  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  border: none !important;

  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 10px 16px;
}

/* 3) "Keyifli Anılar İçin" videonun altına ortalı ve küçük */
.heroTitleBelow{
  text-align: center;
  padding: 26px 16px;
}

.heroTitleBelow h1{
  margin: 0;
  font-size: clamp(22px, 3vw, 38px);
  font-weight: 700;
  line-height: 1.1;
}
header, nav, .navbar, .topbar, .header {
  background: transparent !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}
/* Üst menü linkleri */
header nav a,
.header nav a,
.siteHeader nav a {
  color: #000 !important;   /* istediğin renk */
  font-weight: 600;
}
header nav,
.header nav,
.siteHeader nav {
  position: relative;
  top: 100px;   /* arttırırsan daha yukarı çıkar */
}
/* Hamburger ikon */
.menuBtn,
.hamburger,
.header .menu {
  color: #000000 !important;
  font-size: 22px;
}

/* TR yazısı */
.lang,
.language,
.header .lang {
  color: #000000 !important;
  font-weight: 600;
}
.headerInner{
  align-items: flex-start !important;
  padding-top: 10px !important;
}
header * {
  color: white !important;
}
/* ÜST MENÜDEKİ TÜM YAZILAR - ZORLA */
header, header * ,
.siteHeader, .siteHeader *,
.navbar, .navbar *,
.topbar, .topbar * {
  color: #000000 !important; /* burayı değiştir */
}
/* SVG ikonlar için */
header svg, header svg * {
  fill: #000000 !important;
  stroke: #000000 !important;
}
/* Header’ın genel yüksekliğini/paddingini azalt */
header, .siteHeader, .navbar, .topbar {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

/* Menü satırını yukarı çek */
header nav,
.siteHeader nav,
.navbar nav {
  transform: translateY(-18px) !important; /* -12 / -24 deneyebilirsin */
}
/* Menü satırını yukarı çek */
.navbar-inner{
  position: relative;
  top: -20px;  /* daha yukarı için -25 / -30 */
}
.navbar-inner{
  transform: translateY(-20px) !important;
}


/* 1) Logo + sosyal ikonlar bloğu: yukarı al + üstte tut */
.header-inner.voyage{
  position: relative;
  z-index: 9999 !important;
  transform: translateY(-75px) !important; /* -15 / -35 deneyebilirsin */
}

/* Logo biraz yukarı */
.header-inner.voyage .brand{
  display: inline-block;
  transform: translateY(-6px) !important;
}

/* 2) Menü linkleri (Ana Sayfa/Odalar...): yukarı al + tıklanabilir */
.navbar-inner{
  position: relative;
  z-index: 9999 !important;
  transform: translateY(-75px) !important;
}

.navbar-inner .nav-link{
  position: relative;
  z-index: 10000 !important;
  pointer-events: auto !important;

  color: #000000 !important;   /* MENÜ RENK */
  font-weight: 700;
}

/* 3) Sosyal ikonların rengi (SVG + fontawesome whatsapp) */
.header-social a svg{
  width: 22px;
  height: 22px;
}

.header-social a svg,
.header-social a svg *{
  fill: #000000 !important;    /* İKON RENK */
  stroke: #000000 !important;
}

.header-social a,
.header-social a i{
  color: #000000 !important;   /* WhatsApp icon */
}

/* 4) Menü hover rengi */
.navbar-inner .nav-link:hover{
  color: #1f8f5f !important;
}


/* 3) Üste çıksın ve kesin tıklansın */
.header-inner.voyage,
.navbar-inner{
  position: relative !important;
  z-index: 999999 !important;
}
/* HERO YAZI ALANI */
.hero-content{
  position: absolute !important;
  left: 50%;
  top: 265%;                /* 50 = tam orta | 60–65 = biraz daha alt */
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 10;
  max-width: 90%;
}

/* BAŞLIK */
.hero-content h1{
  font-size: clamp(28px, 4vw, 44px); /* ufaltıldı */
  line-height: 1.1;
  margin-bottom: 12px;
}

/* ALT AÇIKLAMA */
.hero-content p{
  font-size: 16px;
  max-width: 700px;
  margin: 0 auto 18px;
}

/* BUTONLAR ORTALI */
.hero-content .buttons,
.hero-content .hero-buttons{
  display: flex;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}
@media (max-width: 768px){
  .hero-content{
    top: 65%;
  }

  .hero-content h1{
    font-size: 26px;
  }
}


/* 2) Yazı bloğu + içindeki butonlar TIKLANABİLİR olsun */
.hero-content,
.hero-content *{
  pointer-events: auto !important;
}

/* 3) Eğer hâlâ tıklanmıyorsa: yazı bloğunu en üste al */
.hero-content{
  position: absolute !important;
  z-index: 99999 !important;
}
/* 1) ÜSTTE OKUNURLUK ŞERİDİ (video üstünde) */
.header-inner.voyage,
.navbar-inner{
  position: relative;
  z-index: 999999 !important;
}


/* 2) MENÜ YAZILARI (Ana Sayfa, Odalar...) - belirgin */
.navbar-inner .nav-link{
  color: #fff !important;
  font-weight: 800 !important;
  letter-spacing: .5px;
  
  text-shadow: 0 2px 10px rgba(0,0,0,.85);
}

/* 3) LOGO + SOSYAL İKONLAR daha belirgin */
.header-inner.voyage .brand-mark{
  filter: drop-shadow(0 6px 14px rgba(0,0,0,.65));
}

.header-social a svg,
.header-social a svg *{
  fill: #fff !important;
  stroke: #fff !important;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.8));
}

.header-social a,
.header-social a i{
  color:#fff !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.85);
}

/* 4) TELEFON + REZERVASYON BUTONU (class'ları farklı olabilir diye geniş tuttum) */
.header-right a,
.header-right .phone,
.header-right .cta,
.header-right button,
.header-right .btn{
  color:#fff !important;
  font-weight: 800 !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.85);
}
/* ACİL: Menü ve üst bar tekrar tıklansın */
.header-inner.voyage,
.navbar-inner{
  position: relative !important;
  z-index: 999999 !important;
  pointer-events: auto !important;
}

.header-inner.voyage *,
.navbar-inner *{
  pointer-events: auto !important;
}

/* 3) Menü (☰) ve TR daha belirgin */
.topbar-left button.btn{
  color: #fff !important;
  border-color: rgba(255,255,255,.55) !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.9);
}
.topbar-left span{
  color:#fff !important;
  font-weight: 800 !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.9);
}

/* 4) Telefon + Rezervasyon Yap (üstteki) belirgin */
.topbar-right a{
  color:#fff !important;
  font-weight: 800 !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.9);
}

/* Üstteki Rezervasyon butonu */
.topbar-right a.btn-success{
  background: rgba(31,143,95,.95) !important;
  border: 2px solid rgba(255,255,255,.35) !important;
  color:#fff !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.9);
}

/* 5) Offcanvas içindeki Rezervasyon Yap da belirgin */
a.menu-cta{
  background: rgba(31,143,95,.95) !important;
  color:#fff !important;
  font-weight: 800 !important;
  border-radius: 999px !important;
}

/* 6) Video / video katmanları click yemesin (genel güvenlik) */
video{
  pointer-events: none !important;
  /* 1) Topbar her şeyin üstünde ve tıklanabilir */
.topbar{
  position: absolute !important;   /* videonun üstüne binsin */
  top: 0; left: 0; right: 0;
  z-index: 999999 !important;
  pointer-events: auto !important;
}}
/* === NAVBAR LINK TIKLAMA KESİN FIX === */

/* Menü linkleri her şeyin üstünde */
.navbar-inner{
  position: relative;
  z-index: 10001;
}

/* Linkler açıkça tıklanabilir */
.navbar-inner .nav-link{
  position: relative;
  z-index: 10002;
  pointer-events: auto;
}

/* Hero / video katmanları click yemesin */
.hero video,
.heroVideo,
.hero::before,
.hero::after{
  pointer-events: none;
}
/* === NAVBAR TIKLAMA KESİN FIX (pseudo-element dahil) === */

/* Navbar alanı tıklanabilir */
.navbar-inner{
  position: relative !important;
  z-index: 999999 !important;
  pointer-events: auto !important;
}

/* Navbar'ın üstüne binen ::before/::after varsa click yemesin */
.navbar-inner::before,
.navbar-inner::after{
  pointer-events: none !important;
  z-index: -1 !important;   /* linklerin altına it */
  content: "" !important;   /* varsa aktif kalsın ama alta gitsin */
}

/* Linkler: kesin tıklanabilir + üstte */
.navbar-inner .nav-link{
  position: relative !important;
  z-index: 1000000 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
}

/* Çok nadir: container üst katman yapıyorsa onu da pasifleştir */
.navbar-inner .container::before,
.navbar-inner .container::after{
  pointer-events: none !important;
  z-index: -1 !important;
}
/* ===== FINAL FIX: Layout bozulmadan tıklamalar düzelsin ===== */

/* Header görünür kalsın ama "boş alanı" tıklama yemesin */
header.header{
  position: relative !important;    /* SAYFA AKIŞI BOZULMASIN */
  z-index: 50 !important;
  pointer-events: none !important;  /* header kutusu click yemesin */
}

/* Header içindeki gerçek içerikler (logo + sosyal ikonlar) tıklanabilir olsun */
header.header .header-inner,
header.header .header-inner *{
  pointer-events: auto !important;
}

/* Menü satırı normal akışta kalsın ama üstte olsun ve tıklansın */
div.navbar{
  position: relative !important;    /* ABSOLUTE DEĞİL */
  z-index: 60 !important;           /* header’dan biraz üstte */
  pointer-events: auto !important;
}
div.navbar *{
  pointer-events: auto !important;
}

/* Daha önce verdiğimiz translate/negatif margin vs. kaldıysa sıfırla (click kaymasını bitirir) */
div.navbar,
.navbar-inner,
.navbar-inner .nav-link{
  transform: none !important;
  margin-top: 0 !important;
  top: auto !important;
}
/* Menü satırını az yukarı al (transform yok, click kaydırmaz) */
div.navbar{
  position: relative !important;
  top: -100px !important;     /* -4 / -6 / -10 deneyebilirsin */
  margin-top: 0 !important; /* margin ile çakışmasın */
}
.navbar-inner{
  position: relative !important;
  top: -8px !important;
}
.room-modal{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 999999;
}
.room-modal.is-open{ display: block; }

.room-modal__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.6);
}

.room-modal__panel{
  position:absolute;
  top:50%;
  left:50%;
  transform: translate(-50%, -50%);
  width: min(900px, 90%);
  max-height: 85vh;
  overflow:auto;
  background:#fff;
  padding:20px;
  border-radius:16px;
}

.room-modal__close{
  position:absolute;
  top:10px;
  right:15px;
  font-size:28px;
  background:none;
  border:none;
  cursor:pointer;
}
.room-modal{ position:fixed; inset:0; display:none; z-index:999999; }
.room-modal.is-open{ display:block; }

.room-modal__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.58);
  backdrop-filter: blur(4px);
}

.room-modal__panel{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:min(980px,92vw);
  max-height:86vh;
  overflow:auto;
  background:#fff;
  border-radius:18px;
  padding:22px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.room-modal__close{
  position:absolute;
  top:10px; right:14px;
  font-size:28px;
  background:none; border:none;
  cursor:pointer;
}

.room-modal__header h2{ margin:0; font-size:28px; }
.room-modal__header p{ margin:6px 0 0; color:#555; }

.room-modal__section{
  margin-top:16px;
  background:#fafafa;
  border:1px solid #eee;
  border-radius:14px;
  padding:16px;
}

.room-modal__section h3{ margin:0 0 10px; font-size:18px; }
.room-modal__section h4{ margin:14px 0 8px; font-size:15px; }
.room-modal__section ul{ margin:0; padding-left:18px; }
.room-modal__section li{ margin:6px 0; }

.room-modal__cols{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }

.room-modal__footer{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  padding-top:14px;
}

@media (max-width:820px){
  .room-modal__cols{ grid-template-columns:1fr; }
  .room-modal__panel{ padding:18px; }
}
.room-modal{ position:fixed; inset:0; display:none; z-index:999999; }
.room-modal.is-open{ display:block; }

.room-modal__backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.58);
  backdrop-filter: blur(4px);
}

.room-modal__panel{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:min(980px,92vw);
  max-height:86vh;
  overflow:auto;
  background:#fff;
  border-radius:18px;
  padding:22px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}

.room-modal__close{
  position:absolute;
  top:10px; right:14px;
  font-size:28px;
  background:none; border:none;
  cursor:pointer;
}

.room-modal__header h2{ margin:0; font-size:28px; }
.room-modal__header p{ margin:6px 0 0; color:#555; }

.room-modal__section{
  margin-top:16px;
  background:#fafafa;
  border:1px solid #eee;
  border-radius:14px;
  padding:16px;
}

.room-modal__section h3{ margin:0 0 10px; font-size:18px; }
.room-modal__section h4{ margin:14px 0 8px; font-size:15px; }
.room-modal__section ul{ margin:0; padding-left:18px; }
.room-modal__section li{ margin:6px 0; }

.room-modal__cols{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }

.room-modal__footer{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  padding-top:14px;
}

@media (max-width:820px){
  .room-modal__cols{ grid-template-columns:1fr; }
  .room-modal__panel{ padding:18px; }
}
.room-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}

.room-card{
  background:#fff;
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.08);
}

.room-img{
  height: 200px;
  background-size: cover;
  background-position: center;
}

.room-body{
  padding: 18px 18px 20px;
}

.room-body h3{
  margin: 0 0 6px;
  font-size: 28px;
}

.room-actions{
  display:flex;
  gap: 12px;
  margin-top: 14px;
  align-items:center;
}

@media (max-width: 980px){
  .room-grid{ grid-template-columns: 1fr; }
  .room-img{ height: 220px; }
}
/* ===== ODALAR SAYFASI HERO ARKA PLAN ===== */
.page-hero{
  position: relative;
  min-height: 420px;
  display: flex;
  align-items: center;
  justify-content: center;

  background-image: url('/img/hero-.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Yazıların okunması için koyu overlay */
.page-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45); /* koyuluk */
}

/* Yazılar overlay'in üstünde kalsın */
.page-hero .container{
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
}

/* Başlık stilleri */
.page-hero h1{
  font-size: 56px;
  margin: 10px 0;
}

.page-hero p{
  font-size: 18px;
  opacity: 0.95;
}

/* Mobil uyum */
@media (max-width: 768px){
  .page-hero{
    min-height: 300px;
  }
  .page-hero h1{
    font-size: 36px;
  }
}
.page-rooms .page-hero-bg{
  background-image: url('/img/hero-rooms.JPG');
}
.page-factsheet .page-hero-bg{
  background-image: url('/img/hero-factsheet.jpg');
}
/* Hero container referans olsun */
.page-hero{
  position: relative;
  overflow: hidden;
}

/* Arka plan katmanı */
.page-hero-bg{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}

/* Yazılar önde kalsın */
.page-hero .container,
.page-hero-content{
  position: relative;
  z-index: 2;
}

/* Okunurluk için koyu overlay */
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.35);
  z-index: 1;
}

/* Iletisim hero metni Kurumsal ile ayni gorunsun */
.page-contact .page-hero-content h1{
  color: #fff !important;
  font-family: var(--font-display);
  text-shadow: 0 12px 30px rgba(0,0,0,.55);
}

.page-contact .page-hero-content p,
.page-contact .page-hero-content .hero-kicker{
  color: rgba(255,255,255,.88) !important;
  text-shadow: 0 8px 24px rgba(0,0,0,.5);
}

/* ===== 2026 Visual Refresh ===== */
:root{
  --bg: #f6f5f1;
  --text: #1f2520;
  --muted: rgba(31,37,32,.68);
  --surface: rgba(255,255,255,.86);
  --surface-strong: rgba(255,255,255,.94);
  --brand-green: #1f5a41;
  --brand-green-2: #2f7a59;
  --brand-sand: #d8ad67;
  --radius: 22px;
  --radius-sm: 14px;
}

html, body{
  background:
    radial-gradient(1100px 500px at 0% -10%, rgba(216,173,103,.20), transparent 70%),
    radial-gradient(1000px 520px at 100% 0%, rgba(31,90,65,.14), transparent 68%),
    #f6f5f1 !important;
  color: var(--text);
}

body{
  font-family: "Manrope", "Avenir Next", "Segoe UI", sans-serif;
}

h1,h2,h3{
  font-family: "Cormorant Garamond", "Times New Roman", serif;
  letter-spacing: .02em;
}

/* Reset legacy header shift hacks */
header nav,
.header nav,
.siteHeader nav,
.navbar nav,
.header-inner.voyage,
.header-inner.voyage .brand,
.navbar-inner,
div.navbar,
.hero-content{
  top: auto !important;
  transform: none !important;
  margin-top: 0 !important;
}

/* Top bars */
.topbar{
  position: relative !important;
  z-index: 200 !important;
  background: linear-gradient(120deg, rgba(17,33,28,.88), rgba(24,47,39,.80)) !important;
  border-bottom: 1px solid rgba(255,255,255,.08) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 8px 24px rgba(0,0,0,.15) !important;
}

.header{
  position: relative !important;
  z-index: 190 !important;
  background: rgba(255,255,255,.75) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(31,37,32,.08) !important;
}

.navbar{
  position: relative !important;
  z-index: 180 !important;
  background: linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.82)) !important;
  border-bottom: 1px solid rgba(31,37,32,.08);
}

.header-inner.voyage{
  min-height: 86px;
  padding-block: 10px !important;
}

.navbar-inner{
  min-height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(14px, 2vw, 34px);
  flex-wrap: wrap;
  padding: 10px 0;
}

.navbar-inner .nav-link{
  color: #284234 !important;
  font-weight: 800 !important;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-radius: 999px;
  padding: 8px 12px;
  text-shadow: none !important;
}

.navbar-inner .nav-link:hover{
  color: #113327 !important;
  background: rgba(47,122,89,.10);
}

.header-social a{
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
}

.header-social a svg,
.header-social a svg *,
.header-social a i{
  color: #2a4637 !important;
  fill: #2a4637 !important;
  stroke: #2a4637 !important;
}

/* Hero */
.hero,
.page-hero{
  border-bottom-left-radius: 28px;
  border-bottom-right-radius: 28px;
  overflow: hidden;
}

.hero::before{
  background: linear-gradient(180deg, rgba(0,0,0,.52), rgba(0,0,0,.24)) !important;
}

.page-hero::before{
  background: linear-gradient(180deg, rgba(0,0,0,.48), rgba(0,0,0,.26)) !important;
}

.hero-content{
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 42px 16px;
  z-index: 5 !important;
}

.hero-glass{
  background: linear-gradient(135deg, rgba(255,255,255,.30), rgba(255,255,255,.16));
  border: 1px solid rgba(255,255,255,.34);
  box-shadow: 0 24px 70px rgba(0,0,0,.24);
  border-radius: 26px;
}

.hero-title{
  text-shadow: 0 16px 52px rgba(0,0,0,.58);
}

.hero-sub{
  color: rgba(255,255,255,.92);
}

/* Sections */
.section{
  padding: clamp(58px, 7vw, 96px) 0;
}

.section:nth-of-type(odd){
  background: linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,0));
}

.section-head h2{
  color: #17231d;
  font-size: clamp(36px, 5vw, 54px);
}

.section-head p{
  color: var(--muted);
  font-size: clamp(15px, 1.6vw, 18px);
}

/* Cards and surfaces */
.card,
.room-card,
.facts-card,
.corp-card,
.contact-card,
.c-card{
  background: var(--surface-strong) !important;
  border: 1px solid rgba(17,35,28,.08) !important;
  box-shadow: 0 18px 55px rgba(19,37,29,.10) !important;
  border-radius: 22px;
}

.card:hover,
.room-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 28px 70px rgba(19,37,29,.16) !important;
}

/* Booking */
.booking-card{
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.88)) !important;
  border: 1px solid rgba(31,90,65,.12) !important;
  box-shadow: 0 20px 60px rgba(25,43,34,.13) !important;
  border-radius: 20px !important;
}

.booking-field{
  background: rgba(248,250,247,.92);
}

.booking-btn{
  background: linear-gradient(120deg, #194f38, #2b7a58) !important;
  border: none !important;
  color: #fff !important;
}

/* Buttons */
.btn{
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: .02em;
}

.btn-primary,
.btn-success{
  background: linear-gradient(120deg, #1b513a, #2d7d5c) !important;
  border-color: rgba(255,255,255,.22) !important;
  color: #fff !important;
  box-shadow: 0 10px 28px rgba(21,68,49,.34);
}

.btn-primary:hover,
.btn-success:hover{
  filter: brightness(1.06);
}

.btn-ghost{
  background: rgba(255,255,255,.72);
  border-color: rgba(31,37,32,.14);
}

/* Gallery */
.chips{
  gap: 10px;
}

.chip{
  border-radius: 999px;
  border: 1px solid rgba(31,37,32,.16);
  background: rgba(255,255,255,.74);
}

.chip.active{
  background: linear-gradient(120deg, #1b513a, #2d7d5c);
  color: #fff;
  border-color: transparent;
}

.g-item{
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 34px rgba(0,0,0,.14);
}

/* Footer / rating */
.rating-bar{
  background: linear-gradient(120deg, rgba(8,23,19,.95), rgba(13,35,28,.92)) !important;
  border-radius: 24px 24px 0 0;
}

.footer{
  background: linear-gradient(120deg, #14261f, #0d1d17);
  color: rgba(255,255,255,.9);
}

.footer .muted,
.footer a{
  color: rgba(255,255,255,.78);
}

/* Mobile */
@media (max-width: 900px){
  .header-inner.voyage{
    min-height: 78px;
  }

  .navbar-inner{
    justify-content: center;
    gap: 10px;
    padding: 8px 0 10px;
  }

  .navbar-inner .nav-link{
    font-size: 11px;
    padding: 6px 9px;
  }

  .hero,
  .page-hero{
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
  }
}

/* ===== Post-Feedback Fine Tune ===== */
html, body{
  background:
    radial-gradient(1200px 560px at 0% -10%, rgba(168,126,71,.16), transparent 70%),
    radial-gradient(1100px 580px at 100% 0%, rgba(20,56,42,.18), transparent 68%),
    #ecebe6 !important;
}

.section:nth-of-type(odd){
  background: linear-gradient(180deg, rgba(242,240,233,.74), rgba(242,240,233,.30));
}

.topbar{
  background: linear-gradient(120deg, rgba(12,24,20,.90), rgba(18,36,30,.86)) !important;
}

.header{
  background: rgba(236,234,227,.70) !important;
}

.navbar{
  background: linear-gradient(180deg, rgba(233,231,224,.82), rgba(233,231,224,.72)) !important;
}

.header-inner.voyage{
  min-height: 70px;
  padding-block: 8px !important;
}

.navbar-inner{
  min-height: 52px;
  padding: 7px 0;
}

.home .hero-content{
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: center !important;
  text-align: center;
  padding: 0 16px 64px !important;
  z-index: 10 !important;
}

.home .hero-content .container{
  max-width: min(900px, 92vw);
}

/* Hard lock: hero metni videonun alt-orta kısmında kalsın */
.home .hero{
  position: relative !important;
}

.home .hero .hero-content{
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  left: 50% !important;
  bottom: -46px !important;
  transform: translateX(-50%) !important;
  width: min(940px, 92vw) !important;
  padding: 0 !important;
  display: block !important;
  text-align: center !important;
}

.home .hero .hero-content .container{
  width: 100% !important;
  margin: 0 auto !important;
}

.home .hero-kicker,
.home .hero-title,
.home .hero-sub{
  text-shadow: 0 10px 26px rgba(0,0,0,.62);
}

.home .hero::before{
  background: linear-gradient(180deg, rgba(0,0,0,.58), rgba(0,0,0,.34)) !important;
}

.booking-card{
  background: linear-gradient(180deg, rgba(236,235,228,.95), rgba(228,226,217,.88)) !important;
  border: 1px solid rgba(32,62,49,.16) !important;
}

/* ===== Final Header + Hero Alignment Fix ===== */
.topbar{
  background: #12261f !important;
  backdrop-filter: none !important;
}

.header{
  background: #ece8de !important;
  backdrop-filter: none !important;
}

.navbar{
  background: #e6e1d5 !important;
  backdrop-filter: none !important;
}

.header-inner.voyage{
  min-height: 58px !important;
  padding-block: 2px !important;
  transform: translateY(-8px);
}

.navbar-inner{
  min-height: 44px !important;
  padding: 2px 0 !important;
  transform: translateY(-8px);
}

/* Hero metnini tekrar videonun alt-orta k�sm�na al */
.home .hero .hero-content{
  left: 50% !important;
  bottom: 42px !important;
  transform: translateX(-50%) !important;
  width: min(940px, 92vw) !important;
}

/* ===== Emergency Clean Header + Hero Text Restore ===== */
/* Home hero �st�ndeki �effaf bantlar� tamamen kald�r */
.home .hero .topbar,
.home .hero .header,
.home .hero .navbar{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Video �zerindeki ek sis/overlay katman�n� kapat */
.home .hero .hero-overlay,
.home .hero::before{
  display: none !important;
  background: transparent !important;
}

/* Logo, sosyal ikonlar ve men�y� biraz daha �ste al */
.home .hero .topbar{ padding: 8px 18px !important; }
.home .hero .header-inner.voyage{
  min-height: 50px !important;
  padding-block: 0 !important;
  transform: translateY(-14px) !important;
}
.home .hero .navbar-inner{
  min-height: 38px !important;
  padding: 0 !important;
  transform: translateY(-14px) !important;
}

/* Kayan/bolan hero metnini geri getir */
.home .hero .hero-content{
  position: absolute !important;
  inset: auto !important;
  left: 50% !important;
  bottom: 56px !important;
  transform: translateX(-50%) !important;
  width: min(940px, 92vw) !important;
  z-index: 120 !important;
  text-align: center !important;
  display: block !important;
  padding: 0 !important;
}

.home .hero-kicker,
.home .hero-title,
.home .hero-sub{
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #fff !important;
}

/* ===== Final Hero Bottom Control ===== */
:root{
  --home-hero-bottom: 46px;
  --home-hero-shift-y: 595px; /* buyutdukce yazi asagi iner */
}

.home .hero .hero-content{
  bottom: var(--home-hero-bottom) !important;
  transform: translate(-50%, var(--home-hero-shift-y)) !important;
}

/* ===== Home Nav Readability Boost ===== */
.home .hero .navbar-inner{
  background: rgba(255,255,255,.62) !important;
  border: 1px solid rgba(19,46,36,.14) !important;
  border-radius: 999px !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.18) !important;
  padding: 6px 16px !important;
}

.home .hero .navbar-inner .nav-link{
  color: #173a2d !important;
  font-weight: 900 !important;
  letter-spacing: .09em !important;
  text-transform: uppercase;
  text-shadow: 0 1px 0 rgba(255,255,255,.8), 0 3px 10px rgba(0,0,0,.28) !important;
  -webkit-text-stroke: .25px rgba(8,24,18,.35);
  padding: 8px 14px !important;
  border-radius: 999px;
}

.home .hero .navbar-inner .nav-link:hover,
.home .hero .navbar-inner .nav-link.active{
  background: rgba(23,58,45,.14) !important;
  color: #0e2c21 !important;
}

/* ===== Flatpickr Modern Theme ===== */
.flatpickr-calendar{
  border: 1px solid rgba(21,57,43,.14) !important;
  box-shadow: 0 18px 42px rgba(12,25,20,.22) !important;
  border-radius: 14px !important;
  overflow: hidden;
}

.flatpickr-months{
  background: linear-gradient(120deg, #183d2f, #225640) !important;
}

.flatpickr-month,
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year,
.flatpickr-weekday{
  color: #fff !important;
}

.flatpickr-weekdaycontainer{
  background: #f4f7f3;
}

.flatpickr-day{
  border-radius: 10px !important;
}

.flatpickr-day:hover{
  background: rgba(34,86,64,.12) !important;
  border-color: rgba(34,86,64,.24) !important;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange{
  background: #1f5a41 !important;
  border-color: #1f5a41 !important;
}

.home .booking-field.date-field .date-real{
  pointer-events: none !important;
}

#homeChildBirthdays{
  grid-column: 1 / 4 !important;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(29,68,52,.14);
  border-radius: 12px;
  padding: 10px 12px;
}

.home-child-birthday-fields{
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 10px;
}

.home-child-bday-item label{
  display: block;
  font-size: 12px;
  color: #516174;
  margin-bottom: 6px;
}

.home-child-bday-item input{
  width: 100%;
  border: 1px solid #d8e0ea;
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
}

@media (max-width: 900px){
  #homeChildBirthdays{
    grid-column: auto !important;
  }
  .home-child-birthday-fields{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px){
  .flatpickr-calendar{
    font-size: 15px;
  }

  .flatpickr-day{
    max-width: 42px;
    height: 42px;
    line-height: 42px;
  }
}

/* Contact WhatsApp button click safety */
.contact-wa-btn{ position: relative; z-index: 5; pointer-events: auto !important; }

/* ===== Mobile Stability Patch 2026 ===== */
@media (max-width: 991.98px){
  html, body{ overflow-x: hidden !important; }

  .container{ width: min(100%, 94vw) !important; }

  .topbar,
  .topbar-container{ padding: 8px 12px !important; }

  .topbar-right{ gap: 8px !important; }
  .topbar-right .btn{
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .header-inner.voyage{
    min-height: auto !important;
    padding: 6px 0 !important;
    transform: none !important;
    grid-template-columns: 1fr auto 1fr !important;
  }

  .header-right{ display: none !important; }

  .navbar-inner{
    justify-content: flex-start !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 8px !important;
    padding: 8px 4px !important;
    transform: none !important;
  }

  .navbar-inner::-webkit-scrollbar{ display: none; }

  .navbar-inner .nav-link{
    white-space: nowrap !important;
    font-size: 11px !important;
    padding: 7px 10px !important;
  }

  .home .hero,
  .page-hero{
    min-height: 42vh !important;
    border-bottom-left-radius: 18px !important;
    border-bottom-right-radius: 18px !important;
  }

  .home .hero .hero-content{
    left: 50% !important;
    bottom: 18px !important;
    transform: translate(-50%, 0) !important;
    width: min(94vw, 640px) !important;
    padding: 0 8px !important;
  }

  .home .hero-title{
    font-size: clamp(30px, 9vw, 44px) !important;
    line-height: 1.05 !important;
  }

  .home .hero-sub{
    font-size: 14px !important;
    line-height: 1.4 !important;
  }

  .hero-actions{
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .booking-wrap{ padding: 12px !important; }
  .booking-card{
    padding: 12px !important;
    border-radius: 14px !important;
  }

  .booking-grid{
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  #homeChildBirthdays{ grid-column: auto !important; }

  .section{ padding: 36px 0 !important; }
  .section-head h2{ font-size: clamp(28px, 8vw, 38px) !important; }

  .room-grid,
  .corp-grid,
  .facts-grid,
  .facts-grid-2,
  .contact-grid{
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .room-actions{ flex-wrap: wrap !important; }
  .room-actions .btn{
    flex: 1 1 calc(50% - 6px);
    min-width: 140px;
  }

  .gallery-toolbar{ display: grid !important; gap: 10px !important; }

  .chips{
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    gap: 8px !important;
    padding-bottom: 4px;
    scrollbar-width: none;
  }

  .chips::-webkit-scrollbar{ display: none; }
  .chip{ white-space: nowrap !important; }

  .cat-track{ grid-auto-columns: minmax(78vw, 1fr) !important; }
  .cat-card{ height: 230px !important; }

  .room-modal__panel{
    width: min(96vw, 760px) !important;
    max-height: 88vh !important;
  }

  .rating-bar{
    width: min(96%, 560px) !important;
    bottom: 10px !important;
  }

  body{ padding-bottom: 108px !important; }
}

@media (max-width: 575.98px){
  .topbar-right .btn-outline-light{ display: none !important; }

  .topbar-right .btn-success{
    font-size: 11px !important;
    padding: 7px 10px !important;
  }

  .home .hero .hero-content{ bottom: 10px !important; }

  .home .hero-kicker{
    font-size: 11px !important;
    letter-spacing: .16em !important;
  }

  .home .hero-title{ font-size: clamp(26px, 10.4vw, 38px) !important; }
  .home .hero-sub{ display: none !important; }

  .booking-title{
    display: flex;
    flex-direction: column;
    gap: 2px;
  }

  .booking-title b{ font-size: 20px !important; }
  .booking-field label{ font-size: 12px !important; }

  .room-actions .btn{ flex: 1 1 100%; }

  .facts-header h2{ font-size: 28px !important; }
}

/* ===== Mobile Hotfix 2026-02 ===== */
@media (max-width: 767.98px){
  /* Hero text should not sit on top of menu links */
  .home .hero{
    min-height: auto !important;
    padding-bottom: 14px !important;
  }

  .home .hero .hero-content{
    position: relative !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: min(94vw, 640px) !important;
    margin: 14px auto 0 !important;
    padding: 12px !important;
    border-radius: 14px;
    background: rgba(11, 30, 24, .46) !important;
    border: 1px solid rgba(255,255,255,.2);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  }

  .home .hero .hero-title{
    margin: 0 0 10px !important;
    font-size: clamp(34px, 10vw, 46px) !important;
  }

  .home .hero .hero-actions{
    margin-top: 6px !important;
  }

  /* Quick booking spacing/tap areas */
  .booking-wrap{
    padding: 10px 12px !important;
    margin-top: 0 !important;
  }

  .booking-card{
    padding: 12px !important;
    border-radius: 14px !important;
  }

  .booking-grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .booking-field{
    width: 100% !important;
    min-height: 68px !important;
    padding: 10px 12px !important;
  }

  #homeSearchBox{
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    min-height: auto !important;
  }

  #homeSearchBox .booking-btn--full{
    min-height: 54px !important;
    width: 100% !important;
  }

  #homeGuestsPanel{
    top: calc(100% + 6px) !important;
    z-index: 9999 !important;
  }

  /* Featured categories: make swipe + arrows clear */
  .cat-slider{
    position: relative;
    overflow: visible;
  }

  .cat-track{
    grid-auto-columns: minmax(84vw, 1fr) !important;
    gap: 10px !important;
    padding: 8px 24px !important;
    scroll-snap-type: x mandatory;
  }

  .cat-card{
    height: 220px !important;
    scroll-snap-align: center !important;
  }

  .cat-nav{
    display: grid !important;
    place-items: center;
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: rgba(11,30,24,.62);
    color: #fff;
    border: 1px solid rgba(255,255,255,.35);
    top: 50%;
    transform: translateY(-50%);
    z-index: 4;
  }

  .cat-nav.prev{ left: 0 !important; }
  .cat-nav.next{ right: 0 !important; }

  .navbar-inner{
    scroll-snap-type: x proximity;
  }

  .navbar-inner .nav-link{
    scroll-snap-align: center;
  }

  .home-quick-links{ display: none !important; }
}

/* ===== Mobile Booking Final Fix ===== */
@media (max-width: 767.98px){
  .home .booking-wrap{
    width: 100% !important;
    max-width: none !important;
    padding: 10px 12px !important;
  }

  .home .booking-card{
    width: 100% !important;
    max-width: none !important;
    padding: 14px !important;
    border-radius: 16px !important;
  }

  .home .booking-grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

  .home .booking-grid > *{
    grid-column: auto !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .home .booking-field{
    min-height: 72px !important;
    padding: 10px 12px !important;
  }

  .home .booking-field .date-display{
    display: block !important;
    width: 100% !important;
    min-height: 42px !important;
    border: 1px solid #e4e8ef !important;
    border-radius: 12px !important;
    padding: 10px 12px !important;
    background: #fff !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
  }

  .home .booking-field .date-real{
    display: none !important;
  }

  .home #homeGuestsBtn{
    display: block !important;
    width: 100% !important;
    min-height: 42px !important;
    border: 1px solid #e4e8ef !important;
    border-radius: 12px !important;
    padding: 10px 12px !important;
    background: #fff !important;
    font-size: 15px !important;
  }

  .home #homeSearchBox{
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    min-height: auto !important;
  }

  .home #homeSearchBox .booking-btn--full{
    width: 100% !important;
    min-height: 52px !important;
    border-radius: 12px !important;
    font-size: 20px !important;
  }
}

/* ===== Mobile Emergency Booking Override ===== */
@media (max-width: 900px){
  .home .booking-wrap .booking-grid{
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

  .home .booking-wrap #homeCheckinBox,
  .home .booking-wrap #homeCheckoutBox{
    grid-column: span 1 !important;
  }

  .home .booking-wrap #homeGuestsBox{
    grid-column: 1 / -1 !important;
  }

  .home .booking-wrap #homeSearchBox{
    grid-column: 1 / -1 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  .home .booking-wrap #homeSearchBox .booking-btn--full{
    width: 100% !important;
    min-height: 52px !important;
    height: 52px !important;
    font-size: 20px !important;
  }

  .home .booking-wrap .booking-field{
    min-height: auto !important;
    padding: 10px 12px !important;
  }

  .home .booking-wrap .booking-field .date-display{
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 12px !important;
    border: 1px solid #e4e8ef !important;
    border-radius: 12px !important;
    background: #fff !important;
    font-size: 15px !important;
    line-height: 1.2 !important;
  }

  .home .booking-wrap .booking-field .date-real{
    display: none !important;
  }

  .home .booking-wrap #homeGuestsBtn{
    width: 100% !important;
    min-height: 42px !important;
    border: 1px solid #e4e8ef !important;
    border-radius: 12px !important;
    padding: 10px 12px !important;
    background: #fff !important;
    font-size: 15px !important;
    line-height: 1.25 !important;
  }
}

/* Desktop: make guest box same visual height as date boxes */
@media (min-width: 901px){
  .home #homeCheckinBox,
  .home #homeCheckoutBox,
  .home #homeGuestsBox{
    min-height: 78px;
  }

  .home #homeGuestsBtn{
    display: block;
    width: 100%;
    min-height: 44px;
    line-height: 1.25;
  }
}

/* Social icons: stronger contrast */
.header-social a{
  background: rgba(255,255,255,.95) !important;
  border: 2px solid rgba(19,71,52,.45) !important;
  box-shadow: 0 8px 20px rgba(0,0,0,.28) !important;
}

.header-social a svg,
.header-social a svg *,
.header-social a i{
  color: #1b4f3a !important;
  fill: #1b4f3a !important;
  stroke: #1b4f3a !important;
}

.header-social a:hover{
  background: #1b4f3a !important;
  border-color: #ffffff !important;
}

.header-social a:hover svg,
.header-social a:hover svg *,
.header-social a:hover i{
  color: #ffffff !important;
  fill: #ffffff !important;
  stroke: #ffffff !important;
}

/* Desktop hard lock: all social icons same as WhatsApp style */
@media (min-width: 901px){
  .header .header-social a{
    background: #1b4f3a !important;
    border: 2px solid rgba(255,255,255,.7) !important;
    box-shadow: 0 8px 20px rgba(0,0,0,.28) !important;
  }

  .header .header-social a svg,
  .header .header-social a svg *,
  .header .header-social a i{
    color: #ffffff !important;
    fill: #ffffff !important;
    stroke: #ffffff !important;
  }

  .header .header-social a:hover{
    background: #143f2f !important;
    border-color: #ffffff !important;
  }
}
