/* Noble Crown Cappadocia Stone House — custom CSS (Bootstrap/Tailwind YOK)
   2026 modern butik yenileme — sıcak terracotta/altın/taş paleti korunur,
   modernizasyon: yumuşak köşeler, katmanlı gölge, fluid tipografi, ferah boşluk, sakin animasyon. */

:root {
  /* Palet (korundu) */
  --stone-950: #16110D;
  --stone-900: #231B16;
  --stone-700: #45382F;
  --stone-500: #75665A;
  --stone-300: #B3A595;
  --sand-100:  #EFE6D8;
  --terracotta: #9C6238;
  --terracotta-dark: #754626;
  --gold: #C3912E;
  --gold-soft: #D9B25E;
  --gold-dark: #8A6014;
  --champagne: #E6D1A3;
  --cream-white: #FBF8F2;
  --cream-deep: #F3EADC;
  --white: #ffffff;

  /* Çizgi / yüzey tonları */
  --line: rgba(67,52,42,.10);
  --line-soft: rgba(67,52,42,.07);
  --line-gold: rgba(195,145,46,.22);
  --surface: #ffffff;
  --surface-warm: #FBF8F2;

  /* Katmanlı, yumuşak gölge sistemi */
  --shadow-xs: 0 1px 2px rgba(22,17,13,.05);
  --shadow-sm: 0 1px 2px rgba(22,17,13,.05), 0 8px 22px rgba(22,17,13,.06);
  --shadow-md: 0 2px 4px rgba(22,17,13,.05), 0 18px 44px rgba(22,17,13,.11);
  --shadow-lg: 0 4px 8px rgba(22,17,13,.06), 0 34px 80px rgba(22,17,13,.20);
  --shadow-gold: 0 14px 36px rgba(156,98,56,.22);

  /* Yumuşak köşeler — en güçlü "modernize" kaldıracı */
  --radius: 16px;
  --radius-lg: 22px;
  --radius-sm: 11px;
  --radius-pill: 999px;

  /* Boşluk ölçeği */
  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 40px);
  --section-y: clamp(64px, 9vw, 118px);

  --serif: 'Cormorant Garamond', 'Georgia', serif;
  --sans: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --ease: cubic-bezier(.22,.8,.28,1);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--stone-900);
  background: var(--cream-white);
  line-height: 1.7;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: var(--terracotta); text-decoration: none; transition: color .2s var(--ease); }
a:hover { color: var(--terracotta-dark); }

h1,h2,h3,h4 { font-family: var(--serif); font-weight: 600; line-height: 1.07; color: var(--stone-900); margin: 0 0 .5em; letter-spacing: -.005em; }
h1 { font-size: clamp(2.7rem, 1.6rem + 4.4vw, 4.4rem); }
h2 { font-size: clamp(2.05rem, 1.4rem + 2.6vw, 3rem); }
h3 { font-size: clamp(1.35rem, 1.15rem + .7vw, 1.6rem); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: var(--section-y) 0; }
.eyebrow { display:inline-block; font-family: var(--sans); font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; color: var(--terracotta); font-weight:700; margin-bottom:1.1rem; }
.section-head { text-align:center; max-width:680px; margin:0 auto clamp(40px, 5vw, 60px); }
.section-head p { color: var(--stone-500); }
.gold-line { width:54px; height:2px; background:linear-gradient(90deg, var(--gold), var(--gold-soft)); margin:20px auto 0; border:0; border-radius:2px; }

/* Focus görünür */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 2px solid var(--terracotta); outline-offset: 3px; border-radius: 4px;
}

/* ---- Buttons ---- */
.btn { position:relative; display:inline-flex; align-items:center; justify-content:center; gap:.5rem; padding:14px 30px; border-radius:var(--radius-pill); font-family:var(--sans);
  font-weight:600; font-size:.94rem; letter-spacing:.01em; cursor:pointer; border:1.5px solid transparent;
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease), box-shadow .25s var(--ease); text-align:center; isolation:isolate; }
.btn svg { width:17px; height:17px; flex:none; }
.btn-primary { background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%); color:#fff; box-shadow:var(--shadow-gold); }
.btn-primary:hover { color:#fff; transform:translateY(-2px); box-shadow:0 18px 44px rgba(156,98,56,.34); filter:brightness(1.06); }
.btn-outline { background:transparent; color:var(--stone-900); border-color:rgba(67,52,42,.28); }
.btn-outline:hover { background:var(--stone-900); color:#fff; border-color:var(--stone-900); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn-light { background:rgba(255,255,255,.92); color:var(--stone-900); border-color:rgba(255,255,255,.4); backdrop-filter:blur(6px); }
.btn-light:hover { background:#fff; color:var(--stone-900); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-wa { background:#25D366; color:#fff; }
.btn-wa:hover { background:#1da851; color:#fff; transform:translateY(-2px); box-shadow:0 14px 32px rgba(37,211,102,.32); }

/* ---- Header ---- */
.site-header { position:fixed; top:0; left:0; right:0; z-index:80; background:transparent; border:0; box-shadow:none;
  transition:background .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease), backdrop-filter .3s var(--ease); animation:headerDrop .8s var(--ease) both; }
.site-header.is-scrolled { background:rgba(251,248,242,.86); border-bottom:1px solid var(--line-gold); box-shadow:0 10px 36px rgba(22,17,13,.10); backdrop-filter:blur(20px) saturate(1.3); -webkit-backdrop-filter:blur(20px) saturate(1.3); }
.nav { display:flex; align-items:center; justify-content:space-between; height:84px; }
.brand { position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; line-height:1; min-width:0; min-height:72px; padding:6px 14px; background:transparent;
  border:0; border-radius:0; box-shadow:none; overflow:visible;
  transition:transform .26s var(--ease); }
.brand:hover { transform:translateY(-2px); }
.brand strong { font-family:var(--serif); font-size:1.45rem; letter-spacing:.01em; color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.5); }
.site-header.is-scrolled .brand strong { color:var(--stone-900); text-shadow:none; }
.brand span { font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--champagne); margin-top:4px; }
.site-header.is-scrolled .brand span { color:var(--terracotta); }
.brand-logo { position:relative; z-index:1; display:block; height:60px; width:auto; max-width:240px; object-fit:contain; filter:drop-shadow(0 4px 12px rgba(35,27,22,.28)); transition:filter .3s var(--ease); }
.site-header.is-scrolled .brand-logo { filter:drop-shadow(0 3px 7px rgba(35,27,22,.16)); }
.nav-links { display:flex; align-items:center; gap:32px; list-style:none; margin:0; padding:0; }
.nav-links > li { animation:navFade .64s var(--ease) both; }
.nav-links > li:nth-child(2) { animation-delay:.04s; }
.nav-links > li:nth-child(3) { animation-delay:.08s; }
.nav-links > li:nth-child(4) { animation-delay:.12s; }
.nav-links > li:nth-child(5) { animation-delay:.16s; }
.nav-links > li > a { position:relative; color:rgba(255,255,255,.97); font-size:.92rem; font-weight:600; letter-spacing:.01em; text-shadow:0 2px 16px rgba(0,0,0,.7); padding:6px 0; }
.site-header.is-scrolled .nav-links > li > a { color:var(--stone-900); text-shadow:none; }
.nav-links > li > a::after { content:''; position:absolute; left:0; right:0; bottom:0; height:2px; border-radius:2px; background:linear-gradient(90deg, var(--gold), var(--gold-soft)); transform:scaleX(0); transform-origin:left; transition:transform .26s var(--ease); }
.nav-links > li > a:hover, .nav-links > li > a.active { color:var(--champagne); }
.site-header.is-scrolled .nav-links > li > a:hover, .site-header.is-scrolled .nav-links > li > a.active { color:var(--gold-dark); }
.nav-links > li > a:hover::after, .nav-links > li > a.active::after { transform:scaleX(1); }
.nav-right { display:flex; align-items:center; gap:18px; animation:navFade .64s .18s var(--ease) both; }
.nav-right .btn { padding:11px 24px; }
.lang-switch { display:inline-flex; align-items:center; gap:2px; padding:5px 8px; border-radius:var(--radius-pill); background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(8px); }
.site-header.is-scrolled .lang-switch { background:rgba(67,52,42,.05); border-color:var(--line); }
.lang-switch a { font-size:.78rem; font-weight:700; color:rgba(255,255,255,.85); padding:3px 8px; border-radius:var(--radius-pill); transition:background .2s var(--ease), color .2s var(--ease); }
.site-header.is-scrolled .lang-switch a { color:var(--stone-500); }
.lang-switch a.active { color:#fff; background:var(--gold); }
.site-header.is-scrolled .lang-switch a.active { color:#fff; background:var(--gold); }
.nav-toggle { display:none; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:var(--radius-sm); cursor:pointer; padding:8px; color:#fff; backdrop-filter:blur(8px); transition:background .2s var(--ease); }
.site-header.is-scrolled .nav-toggle { color:var(--stone-900); background:rgba(67,52,42,.05); border-color:var(--line); }
.nav-toggle svg { width:24px; height:24px; }
.has-sub { position:relative; }
.has-sub::after { content:''; position:absolute; left:-18px; right:-18px; top:100%; height:24px; }
.room-menu { position:absolute; top:calc(100% + 18px); left:50%; width:min(720px, calc(100vw - 48px)); padding:24px; border-radius:var(--radius-lg);
  background:rgba(251,248,242,.97); border:1px solid var(--line-gold); box-shadow:var(--shadow-lg); backdrop-filter:blur(18px); overflow:hidden;
  transform:translate(-50%, 14px); opacity:0; visibility:hidden; pointer-events:none; transition:opacity .26s var(--ease), transform .26s var(--ease), visibility .26s; }
.room-menu::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, rgba(195,145,46,.1), var(--gold), rgba(195,145,46,.1)); }
.has-sub:hover .room-menu, .has-sub:focus-within .room-menu { opacity:1; visibility:visible; pointer-events:auto; transform:translate(-50%, 0); }
.room-menu-head { display:flex; align-items:center; justify-content:space-between; gap:16px; padding-bottom:14px; margin-bottom:14px; border-bottom:1px solid var(--line); }
.room-menu-head span { font-family:var(--serif); font-size:1.4rem; color:var(--stone-900); }
.room-menu-head a { color:var(--gold-dark) !important; font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; font-weight:700; }
.room-menu-grid { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:10px; }
.room-menu-grid a { display:block; padding:13px 15px; border-radius:var(--radius-sm); color:var(--stone-900) !important; background:rgba(255,255,255,.6); border:1px solid var(--line-soft);
  transition:background .22s var(--ease), color .22s var(--ease), border-color .22s var(--ease), transform .22s var(--ease), box-shadow .22s var(--ease); }
.room-menu-grid a:hover { background:var(--stone-950); color:#fff !important; border-color:var(--gold); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.room-menu-grid small { display:block; color:var(--gold-dark); font-size:.66rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:4px; font-weight:700; }
.room-menu-grid a:hover small { color:var(--champagne); }
.room-menu-grid strong { display:block; font-family:var(--serif); font-size:1.08rem; line-height:1.1; font-weight:600; }

@media (max-width: 900px) {
  .nav { height:74px; }
  .nav-links { position:fixed; inset:74px 0 auto 0; flex-direction:column; gap:0;
    background:rgba(251,248,242,.99); border-bottom:1px solid var(--line); padding:8px 0;
    max-height:calc(100vh - 74px); overflow-y:auto;
    transform:translateY(-130%); transition:transform .34s var(--ease); box-shadow:var(--shadow-md); }
  .nav-links.open { transform:translateY(0); }
  .nav-links li { width:100%; text-align:center; }
  .nav-links a, .site-header .nav-links a, .site-header.is-scrolled .nav-links a { display:block; padding:15px; color:var(--stone-700); text-shadow:none; }
  .nav-links > li > a::after { display:none; }
  .nav-toggle { display:flex; }
  .has-sub::after { display:none; }
  .room-menu { display:none !important; }
}
@media (max-width: 560px) {
  .brand { min-height:58px; padding:6px 10px; }
  .brand-logo { height:46px; max-width:178px; }
  .nav-right { gap:10px; }
  .nav-right .btn { display:none; }
}

/* ---- Hero ---- */
.hero { position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:center; color:#fff; overflow:hidden; padding:124px 0 72px; }
.hero::before { content:''; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(10,7,5,.30) 0%, rgba(12,8,5,.42) 45%, rgba(12,8,5,.78) 100%); }
.hero::after { content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:radial-gradient(120% 80% at 20% 30%, rgba(195,145,46,.16), transparent 55%);
  mix-blend-mode:soft-light; }
.hero-slides { position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero-slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0;
  background-color:var(--stone-700); transition:opacity 1.4s var(--ease); transform:scale(1.04); }
.hero-slide.active { opacity:1; }
.hero-inner { position:relative; z-index:2; max-width:780px; }
.hero h1 { color:#fff; text-shadow:0 4px 40px rgba(0,0,0,.4); max-width:700px; }
.hero p { font-size:clamp(1.05rem, .95rem + .5vw, 1.3rem); color:rgba(255,255,255,.92); max-width:540px; margin:0 0 34px; text-shadow:0 2px 20px rgba(0,0,0,.4); }
.hero .eyebrow { color:var(--gold-soft); text-shadow:0 2px 18px rgba(0,0,0,.5); }
.hero-cta { display:flex; gap:14px; flex-wrap:wrap; }

/* Booking arama paneli */
/* Rezervasyon arama çubuğu — 3 alan (giriş/çıkış/kişi) + buton, dengeli hizalı */
/* Rezervasyon arama çubuğu — dolgun, dengeli, özelleştirilmiş alanlar */
.booking-search { position:relative; display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:16px; align-items:end; }
.booking-search-hero { margin-top:40px; width:100%; max-width:960px; padding:26px 28px; border-radius:var(--radius-lg);
  background:rgba(251,248,242,.97); border:1px solid rgba(255,255,255,.6); box-shadow:0 30px 80px rgba(0,0,0,.32);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); animation:bookingFloat .9s .2s var(--ease) both; }
.booking-search-compact { grid-template-columns:1fr 1fr; gap:12px; margin:22px 0 14px; }
.booking-search-compact .btn { grid-column:1 / -1; width:100%; }
.booking-search p { grid-column:1 / -1; margin:4px 0 0; font-size:.78rem; color:var(--stone-500); }
.booking-field { min-width:0; }
.booking-field label { display:flex; align-items:center; gap:6px; margin:0 0 9px; color:var(--gold-dark); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; font-weight:800; }
.booking-field label svg { width:14px; height:14px; flex:none; opacity:.9; }
.booking-field input,
.booking-field select { width:100%; height:60px; border:1px solid var(--line); background:#fff; color:var(--stone-900); border-radius:var(--radius-sm); padding:0 16px; font-family:var(--sans); font-size:1rem; font-weight:600;
  transition:border-color .2s var(--ease), box-shadow .2s var(--ease); cursor:pointer; }
/* Tarih alanı: tüm alana tıklayınca takvim açılsın + altın renkli takvim ikonu */
.booking-field input[type="date"] { position:relative; }
.booking-field input[type="date"]::-webkit-calendar-picker-indicator {
  position:absolute; top:0; right:0; width:100%; height:100%; margin:0; padding:0; cursor:pointer; opacity:0; }
.booking-field input[type="date"]::-webkit-datetime-edit { padding:0; color:var(--stone-900); }
.booking-field input[type="date"]::-webkit-inner-spin-button { display:none; }
.booking-field .date-wrap { position:relative; }
.booking-field .date-wrap::after { content:''; position:absolute; right:16px; top:50%; transform:translateY(-50%); width:18px; height:18px; pointer-events:none;
  background:no-repeat center/contain url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%238A6014' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E"); }
.booking-field .date-wrap input[type="date"] { padding-right:42px; }
/* Select: özel altın ok + ferah seçenekler */
.booking-field select { appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238A6014' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:40px; }
.booking-field select option { font-weight:500; padding:10px; color:var(--stone-900); }
.booking-field input:hover,
.booking-field select:hover { border-color:rgba(195,145,46,.55); }
.booking-field input:focus,
.booking-field select:focus,
.booking-field .date-wrap:focus-within input { border-color:var(--gold); outline:none; box-shadow:0 0 0 4px rgba(195,145,46,.16); }
.booking-search .btn { height:60px; padding:0 32px; white-space:nowrap; font-size:1rem; }
.booking-search .btn svg { width:17px; height:17px; }
@media (max-width:820px) {
  .booking-search { grid-template-columns:1fr 1fr; gap:14px; }
  .booking-search .booking-field:nth-of-type(3) { grid-column:1 / -1; } /* kişi alanı tam genişlik */
  .booking-search .btn { grid-column:1 / -1; width:100%; }
}
@media (max-width:440px) {
  .booking-search { grid-template-columns:1fr; }
  .booking-search .booking-field:nth-of-type(3) { grid-column:auto; }
  .booking-search-hero { padding:20px; }
}

/* mağara kemeri silüeti — signature */
.arch { position:absolute; bottom:-1px; left:50%; transform:translateX(-50%); z-index:2; width:100%; pointer-events:none; }
.arch svg { width:100%; height:auto; display:block; }

.reveal { opacity:0; transform:translateY(30px); transition:opacity .7s var(--ease), transform .7s var(--ease); transition-delay:var(--reveal-delay, 0ms); }
.reveal.in { opacity:1; transform:none; }

/* ---- Story / Amenities ortak kart dili ---- */
.home-story { background:linear-gradient(180deg, var(--cream-white) 0%, var(--cream-deep) 100%); border-bottom:1px solid var(--line-gold); }
.home-story-grid { display:grid; grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr); gap:clamp(32px, 5vw, 56px); align-items:center; }
.home-story-copy p { max-width:560px; color:var(--stone-500); font-size:1.06rem; }
.home-story-copy .btn { margin-top:10px; }
.home-story-cards { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.home-story-card { background:var(--surface); border:1px solid var(--line-gold); border-radius:var(--radius); padding:24px 20px; box-shadow:var(--shadow-sm); min-height:212px; display:flex; flex-direction:column; gap:12px; transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease); }
.home-story-card:hover { transform:translateY(-5px); border-color:rgba(195,145,46,.42); box-shadow:var(--shadow-md); }
.home-story-card > span { width:48px; height:48px; border-radius:var(--radius-pill); color:var(--gold-dark); background:linear-gradient(135deg, rgba(195,145,46,.16), rgba(156,98,56,.08)); border:1px solid var(--line-gold); display:flex; align-items:center; justify-content:center; }
.home-story-card svg { width:22px; height:22px; }
.home-story-card strong { font-family:var(--serif); font-size:1.28rem; color:var(--stone-900); line-height:1.12; }
.home-story-card p { margin:0; color:var(--stone-500); font-size:.92rem; line-height:1.6; }
.home-story-media { margin-top:clamp(28px,4vw,44px); border-radius:var(--radius); overflow:hidden; position:relative; box-shadow:var(--shadow-md); border:1px solid var(--line-gold); aspect-ratio:16/7; }
.home-story-media img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s var(--ease); }
.home-story-media:hover img { transform:scale(1.04); }
.home-story-media figcaption { position:absolute; left:0; bottom:0; right:0; padding:18px 22px; color:#fff; font-family:var(--serif); font-size:1.05rem; background:linear-gradient(0deg, rgba(20,16,12,.62), transparent); }

/* Bölümler arası dekoratif Kapadokya bandı */
.deco-band { height:clamp(220px,32vw,380px); background-image:url(/assets/img/gallery/deco-band.webp); background-size:cover; background-position:center 60%; background-attachment:fixed; position:relative; }
.deco-band::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,16,12,.28), rgba(20,16,12,.12)); }
@media (max-width:780px){ .deco-band { background-attachment:scroll; } }

.hotel-features { background:linear-gradient(180deg, var(--surface) 0%, var(--cream-white) 100%); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-gold); }
.hotel-features .section-head p { margin:0 auto; color:var(--stone-500); font-size:1.02rem; max-width:660px; }
.hotel-feature-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:22px; }
.hotel-feature-card { background:rgba(255,255,255,.94); border:1px solid var(--line-gold); border-radius:var(--radius-lg); padding:30px; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease); }
.hotel-feature-card:hover { transform:translateY(-5px); border-color:rgba(195,145,46,.4); box-shadow:var(--shadow-md); }
.hotel-feature-top { display:grid; grid-template-columns:auto minmax(0,1fr); gap:18px; align-items:start; margin-bottom:20px; }
.hotel-feature-icon { width:56px; height:56px; border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:var(--gold-dark);
  background:linear-gradient(135deg, rgba(195,145,46,.18), rgba(156,98,56,.1)); border:1px solid var(--line-gold); flex:none; }
.hotel-feature-icon svg { width:26px; height:26px; }
.hotel-feature-card h3 { margin-bottom:6px; }
.hotel-feature-card p { margin:0; color:var(--stone-500); font-size:.92rem; line-height:1.6; }
.hotel-feature-card ul { list-style:none; padding:0; margin:0; display:grid; gap:0; }
.hotel-feature-card li { display:flex; justify-content:space-between; align-items:flex-start; gap:18px; padding:13px 0; border-top:1px solid var(--line-soft); }
.hotel-feature-card li span { color:var(--stone-500); font-size:.9rem; }
.hotel-feature-card li strong { color:var(--stone-900); font-size:.94rem; font-weight:700; line-height:1.35; text-align:right; overflow-wrap:anywhere; }

.amenities { background:var(--stone-950); color:#fff; position:relative; overflow:hidden; }
.amenities::before { content:''; position:absolute; inset:0; background:radial-gradient(80% 60% at 80% 0%, rgba(195,145,46,.14), transparent 60%); pointer-events:none; }
.amenities .container { position:relative; z-index:1; }
.amenities h2 { color:#fff; }
.amenities .section-head .eyebrow { color:var(--champagne); }
.amenity-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:18px; }
.amenity { position:relative; text-align:center; padding:32px 20px; border-radius:var(--radius); border:1px solid rgba(230,209,163,.18); background:rgba(255,255,255,.04); overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease); }
.amenity:hover { transform:translateY(-5px); border-color:rgba(230,209,163,.42); background:rgba(255,255,255,.07); box-shadow:0 20px 50px rgba(0,0,0,.22); }
.amenity .ic { width:54px; height:54px; margin:0 auto 16px; color:var(--gold-soft); display:flex; align-items:center; justify-content:center; }
.amenity .ic svg { width:32px; height:32px; }
.amenity h4 { font-family:var(--sans); font-size:1.02rem; font-weight:600; margin-bottom:5px; color:#fff; }
.amenity p { font-size:.86rem; color:rgba(255,255,255,.6); margin:0; }

/* ---- Room cards ---- */
.room-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:30px; }
.room-card { position:relative; background:var(--surface); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line-gold);
  transition:transform .36s var(--ease), box-shadow .36s var(--ease), border-color .36s var(--ease); display:flex; flex-direction:column; }
.room-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:rgba(195,145,46,.36); }
.room-card .thumb { aspect-ratio:4/3; overflow:hidden; background:var(--stone-700); position:relative; display:block; }
.room-card .thumb img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.room-card:hover .thumb img { transform:scale(1.06); }
.room-card .thumb .ph { display:flex; align-items:center; justify-content:center; height:100%; color:rgba(255,255,255,.5);
  font-family:var(--serif); font-size:2rem; }
.room-card .body { padding:26px; display:flex; flex-direction:column; flex:1; }
.room-card h3 { margin-bottom:8px; transition:color .25s var(--ease); }
.room-card:hover h3 { color:var(--gold-dark); }
.room-meta { display:flex; gap:16px; font-size:.82rem; color:var(--stone-500); margin-bottom:14px; flex-wrap:wrap; }
.room-meta span { display:inline-flex; align-items:center; gap:6px; }
.room-meta svg { width:15px; height:15px; color:var(--terracotta); }
.room-card-desc { margin:0 0 14px; color:var(--stone-500); font-size:.92rem; line-height:1.6; }
.room-category-label { margin:8px 0 2px; color:var(--gold-dark); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; font-weight:800; }
.room-card-features { display:flex; flex-wrap:wrap; gap:8px; list-style:none; padding:0; margin:14px 0 0; }
.room-card-features li { display:inline-flex; align-items:center; gap:6px; font-size:.75rem; color:var(--gold-dark); border:1px solid var(--line-gold); border-radius:var(--radius-pill); padding:6px 12px; background:rgba(195,145,46,.06); }
.room-card-features svg { width:13px; height:13px; flex:none; }
.room-card .price { font-family:var(--serif); font-size:1.45rem; color:var(--gold-dark); margin-top:auto; }
.room-card .price small { font-family:var(--sans); font-size:.72rem; color:var(--stone-500); display:block; }
.room-card-actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.room-card-actions .btn { flex:1 1 130px; justify-content:center; padding:12px 18px; }

/* ---- Room detail ---- */
.room-hero { position:relative; min-height:80vh; display:flex; align-items:flex-end; overflow:hidden; color:#fff; background:var(--stone-950); padding:170px 0 86px; }
.room-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); }
.room-hero-shade { position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,6,4,.20), rgba(8,6,4,.84)); }
.room-hero-inner { position:relative; z-index:2; max-width:900px; }
.room-hero h1 { color:#fff; max-width:820px; margin-bottom:18px; text-shadow:0 4px 36px rgba(0,0,0,.4); }
.room-hero .eyebrow { color:var(--champagne); }
.back-link { display:inline-flex; align-items:center; gap:6px; color:rgba(255,255,255,.8); margin-bottom:26px; font-size:.92rem; }
.back-link:hover { color:var(--champagne); }
.room-hero-meta { display:flex; gap:10px; flex-wrap:wrap; margin:0 0 30px; }
.room-hero-meta span { display:inline-flex; align-items:center; gap:8px; color:rgba(255,255,255,.9); border:1px solid rgba(230,209,163,.26); border-radius:var(--radius-pill); background:rgba(255,255,255,.08); padding:9px 15px; font-size:.88rem; backdrop-filter:blur(6px); }
.room-detail-section { background:linear-gradient(180deg, var(--cream-white), var(--surface) 45%, var(--cream-white)); }
.detail-gallery { display:grid; grid-template-columns:minmax(0,1.55fr) minmax(240px,.45fr); gap:16px; margin-bottom:54px; }
.detail-gallery .main { aspect-ratio:16/10; border-radius:var(--radius-lg); overflow:hidden; background:var(--stone-700); box-shadow:var(--shadow-md); border:1px solid var(--line-gold); }
.detail-gallery .main img { width:100%; height:100%; object-fit:cover; transition:opacity .22s var(--ease), transform .7s var(--ease); }
.detail-gallery .main:hover img { transform:scale(1.025); }
.detail-gallery .thumbs { display:grid; grid-template-columns:1fr; gap:12px; }
.detail-gallery .thumbs img { width:100%; aspect-ratio:16/10; height:auto; object-fit:cover; border-radius:var(--radius); cursor:pointer; border:1px solid var(--line-gold);
  transition:transform .28s var(--ease), border-color .28s var(--ease), box-shadow .28s var(--ease), opacity .28s var(--ease); }
.detail-gallery .thumbs img:hover { transform:translateY(-3px); border-color:var(--gold); box-shadow:var(--shadow-sm); }
.detail-layout { display:grid; grid-template-columns:1fr 348px; gap:clamp(32px, 4vw, 52px); }
.feature-list { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.feature-list li { display:flex; align-items:center; gap:12px; font-size:.95rem; background:var(--surface); border:1px solid var(--line-gold); border-radius:var(--radius); padding:13px 15px; box-shadow:var(--shadow-xs); transition:transform .25s var(--ease), border-color .25s var(--ease); }
.feature-list li:hover { transform:translateY(-2px); border-color:rgba(195,145,46,.4); }
.feature-icon { width:36px; height:36px; border-radius:var(--radius-pill); display:inline-flex; align-items:center; justify-content:center; color:var(--gold-dark); background:linear-gradient(135deg, rgba(195,145,46,.16), rgba(156,98,56,.08)); border:1px solid var(--line-gold); flex:none; }
.feature-icon svg { width:17px; height:17px; }
.room-note { margin-top:30px; padding:18px 20px; border-radius:var(--radius); border-left:3px solid var(--gold); background:rgba(195,145,46,.06); color:var(--stone-500); font-size:.92rem; }
.room-note strong { display:block; color:var(--gold-dark); margin-bottom:8px; text-transform:uppercase; letter-spacing:.08em; font-size:.72rem; }
.room-note p { margin:0 0 8px; }
.room-note p:last-child { margin-bottom:0; }
.book-box { background:var(--surface); border:1px solid var(--line-gold); border-radius:var(--radius-lg); padding:30px; position:sticky; top:108px; box-shadow:var(--shadow-md);
  transition:box-shadow .3s var(--ease), border-color .3s var(--ease); }
.book-box:hover { box-shadow:var(--shadow-lg); border-color:rgba(195,145,46,.4); }
.book-label { display:block; color:var(--gold-dark); text-transform:uppercase; letter-spacing:.16em; font-size:.7rem; font-weight:800; margin-bottom:4px; }
.book-box .price { font-family:var(--serif); font-size:2.15rem; color:var(--stone-900); }
.book-box .price small { font-family:var(--sans); font-size:.8rem; color:var(--stone-500); }
.book-box .btn { margin-top:12px; }
.room-photo-wall { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:64px; }
.room-photo-wall img { width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:var(--radius); border:1px solid var(--line-gold); transition:transform .36s var(--ease), border-color .36s var(--ease), box-shadow .36s var(--ease); }
.room-photo-wall img:hover { transform:translateY(-4px) scale(1.015); border-color:rgba(195,145,46,.48); box-shadow:var(--shadow-sm); }

/* ---- Gallery ---- */
.gallery-filters { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:38px; }
.gallery-filters button { background:none; border:1.5px solid var(--line); color:var(--stone-700);
  padding:9px 22px; border-radius:var(--radius-pill); cursor:pointer; font-family:var(--sans); font-size:.85rem; font-weight:600; transition:background .22s var(--ease), color .22s var(--ease), border-color .22s var(--ease); }
.gallery-filters button:hover { border-color:var(--gold); color:var(--gold-dark); }
.gallery-filters button.active { background:var(--stone-900); color:#fff; border-color:var(--stone-900); }
.masonry { columns:3; column-gap:14px; }
.masonry .g-item { break-inside:avoid; margin-bottom:14px; border-radius:var(--radius); overflow:hidden; cursor:pointer; box-shadow:var(--shadow-xs); transition:box-shadow .3s var(--ease); }
.masonry .g-item:hover { box-shadow:var(--shadow-md); }
.masonry .g-item img { transition:transform .6s var(--ease); width:100%; }
.masonry .g-item:hover img { transform:scale(1.05); }
@media(max-width:900px){ .masonry{columns:2;} }
@media(max-width:560px){ .masonry{columns:1;} }
.lightbox { position:fixed; inset:0; background:rgba(18,13,9,.92); backdrop-filter:blur(10px); z-index:100; display:flex; align-items:center; justify-content:center; padding:30px; animation:lbFade .3s var(--ease); }
.lightbox img { max-width:90vw; max-height:88vh; object-fit:contain; border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.lightbox .close { position:absolute; top:20px; right:28px; color:#fff; font-size:2.4rem; background:none; border:0; cursor:pointer; line-height:1; }

/* ---- Channels ---- */
.channels { background:var(--cream-deep); text-align:center; }
.channel-logos { display:flex; gap:18px; justify-content:center; align-items:center; flex-wrap:wrap; margin-top:26px; }
.channel-logos span { display:inline-block; font-family:var(--serif); font-size:1.2rem; color:var(--stone-700); padding:10px 20px; border-radius:var(--radius-pill); background:var(--surface); border:1px solid var(--line-gold); box-shadow:var(--shadow-xs); transition:transform .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease); }
.channel-logos a:hover span, .channel-logos span:hover { color:var(--terracotta); transform:translateY(-2px); box-shadow:var(--shadow-sm); }

/* ---- CTA band ---- */
.cta-band { background:var(--stone-950); color:#fff; text-align:center; position:relative; overflow:hidden; }
.cta-band { background-image:linear-gradient(180deg, rgba(18,14,10,.78), rgba(18,14,10,.88)), url(/assets/img/gallery/cta-band.webp); background-size:cover; background-position:center; }
.cta-band::before { content:''; position:absolute; inset:0; background:radial-gradient(70% 70% at 50% 0%, rgba(195,145,46,.18), transparent 60%); pointer-events:none; }
.cta-band .container { position:relative; z-index:1; }
.cta-band h2 { color:#fff; }
.cta-band p { color:rgba(255,255,255,.78); max-width:540px; margin:0 auto 30px; }

/* ---- Contact ---- */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px, 4vw, 48px); }
.contact-info .row { display:flex; gap:14px; margin-bottom:22px; align-items:flex-start; }
.contact-info .row .ic { width:42px; height:42px; border-radius:var(--radius); color:var(--gold-dark); background:linear-gradient(135deg, rgba(195,145,46,.16), rgba(156,98,56,.08)); border:1px solid var(--line-gold); flex:none; display:flex; align-items:center; justify-content:center; }
.contact-info .row strong { display:block; font-family:var(--sans); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--stone-500); margin-bottom:3px; }
.field { margin-bottom:18px; }
.field label { display:block; font-size:.85rem; font-weight:600; margin-bottom:7px; color:var(--stone-700); }
.field input, .field textarea { width:100%; padding:13px 15px; border:1px solid var(--line); border-radius:var(--radius-sm); font-family:var(--sans); font-size:1rem; background:var(--surface); color:var(--stone-900); transition:border-color .2s var(--ease), box-shadow .2s var(--ease); }
.field input:focus, .field textarea:focus { border-color:var(--gold); outline:none; box-shadow:0 0 0 4px rgba(195,145,46,.14); }
.map-wrap { aspect-ratio:16/9; border-radius:var(--radius-lg); overflow:hidden; margin-top:34px; border:1px solid var(--line-gold); box-shadow:var(--shadow-sm); }
.map-wrap iframe { width:100%; height:100%; border:0; display:block; }
.alert { padding:14px 18px; border-radius:var(--radius-sm); margin-bottom:20px; font-size:.92rem; }
.alert-ok { background:#e9f6ee; color:#1e6b3a; border:1px solid #bfe0cb; }
.alert-err { background:#fbe9e7; color:#a33; border:1px solid #f0c5bf; }

/* ---- Page header ---- */
.page-hero { background:var(--stone-950); color:#fff; padding:clamp(130px, 18vw, 168px) 0 clamp(60px, 8vw, 86px); text-align:center; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(80% 80% at 50% 0%, rgba(195,145,46,.16), transparent 60%);
  animation:pageSheen 10s ease-in-out infinite; }
.page-hero[style*="--hero-bg"]::before { background-image:linear-gradient(180deg, rgba(20,16,12,.58), rgba(20,16,12,.66)), var(--hero-bg);
  background-size:cover; background-position:center; animation:none; }
.page-hero::after { content:''; position:absolute; left:50%; bottom:34px; width:54px; height:2px; border-radius:2px; transform:translateX(-50%); background:linear-gradient(90deg, var(--gold), var(--gold-soft)); z-index:1; }
.page-hero .container { position:relative; z-index:1; }
.page-hero h1 { color:#fff; }
.page-hero p { color:rgba(255,255,255,.74); max-width:600px; margin:0 auto; }
.page-body { max-width:760px; margin:0 auto; font-size:1.08rem; color:var(--stone-700); }
.page-body p { margin:0 0 1.2em; }
.hotel-facts { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; margin:56px 0 0; }
.hotel-fact-card { background:var(--surface); border:1px solid var(--line-gold); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); padding:28px; transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s var(--ease); }
.hotel-fact-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(195,145,46,.38); }
.hotel-fact-card h3 { margin-bottom:18px; color:var(--stone-900); }
.hotel-fact-card dl { margin:0; display:grid; gap:10px; }
.hotel-fact-card div { display:grid; grid-template-columns:minmax(120px,.45fr) 1fr; gap:14px; padding-bottom:10px; border-bottom:1px solid var(--line-soft); }
.hotel-fact-card div:last-child { border-bottom:0; padding-bottom:0; }
.hotel-fact-card dt { color:var(--gold-dark); font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; font-weight:800; }
.hotel-fact-card dd { margin:0; color:var(--stone-700); }
.room-type-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; margin:-12px 0 40px; }
.room-type-grid a { position:relative; min-height:180px; overflow:hidden; border-radius:var(--radius-lg); color:#fff; background:var(--stone-950); border:1px solid rgba(195,145,46,.3); padding:20px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; justify-content:flex-end; isolation:isolate;
  transition:transform .36s var(--ease), border-color .36s var(--ease), box-shadow .36s var(--ease); }
.room-type-grid a::before { content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,7,5,.1), rgba(10,7,5,.82)); z-index:-1; }
.room-type-grid a::after { content:''; position:absolute; left:20px; right:20px; bottom:16px; height:2px; border-radius:2px; background:linear-gradient(90deg, var(--gold), var(--gold-soft)); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); }
.room-type-grid a:hover, .room-type-grid a.active { transform:translateY(-4px); border-color:var(--gold); box-shadow:var(--shadow-md); }
.room-type-grid a:hover::after, .room-type-grid a.active::after { transform:scaleX(1); }
.room-type-grid img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; transition:transform 1s var(--ease); }
.room-type-grid a:hover img { transform:scale(1.08); }
.room-type-grid span { display:block; color:var(--champagne); font-size:.66rem; text-transform:uppercase; letter-spacing:.14em; font-weight:700; margin-bottom:6px; text-shadow:0 2px 12px rgba(0,0,0,.8); }
.room-type-grid strong { display:block; font-family:var(--serif); font-size:1.6rem; line-height:1.04; color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.75); }
.rooms-all-link { margin:-6px 0 28px; }
.rooms-all-link a { color:var(--gold-dark); font-weight:700; }

/* ---- Noble features section ---- */
.noblefeat-section { background:var(--cream-white); border-top:1px solid var(--line-soft); }
.noblefeat-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(290px, 1fr)); gap:20px; }
.noblefeat-card { background:var(--surface); border:1px solid var(--line-gold); border-radius:var(--radius-lg); padding:2rem 1.85rem; box-shadow:var(--shadow-sm);
  transition:box-shadow .3s var(--ease), transform .3s var(--ease), border-color .3s var(--ease); }
.noblefeat-card:hover { box-shadow:var(--shadow-md); transform:translateY(-5px); border-color:rgba(195,145,46,.36); }
.noblefeat-icon { width:56px; height:56px; border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:var(--gold-dark);
  background:linear-gradient(135deg, rgba(195,145,46,.16), rgba(156,98,56,.08)); border:1px solid var(--line-gold); margin-bottom:1.3rem; flex:none; }
.noblefeat-icon svg { width:26px; height:26px; }
.noblefeat-card h3 { font-size:1.3rem; margin-bottom:.45rem; }
.noblefeat-card p { margin:0; color:var(--stone-500); font-size:.92rem; line-height:1.7; }
@media (max-width: 560px) { .noblefeat-grid { grid-template-columns: 1fr; } }

/* ---- Rooms show-all ---- */
.rooms-show-all { text-align:center; margin-top:2.6rem; }
.rooms-show-all .btn { display:inline-flex; align-items:center; gap:.5rem; }
.rooms-show-all .btn svg { width:16px; height:16px; }

/* ---- Hero scroll arrow ---- */
.hero-scroll { position:absolute; bottom:6.5rem; left:50%; transform:translateX(-50%); z-index:3; color:rgba(255,255,255,.66);
  display:flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:50%;
  border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.08); backdrop-filter:blur(6px);
  transition:color .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
  animation:heroScrollBounce 2.4s ease-in-out infinite; }
.hero-scroll svg { width:22px; height:22px; }
.hero-scroll:hover { color:var(--champagne); border-color:rgba(230,209,163,.6); background:rgba(255,255,255,.16); }
@media (max-width: 560px) { .hero-scroll { bottom:5rem; } }

/* ---- Sabit hızlı iletişim (sol alt: WhatsApp + Telefon) ---- */
.float-contact { position:fixed; bottom:24px; left:24px; z-index:60; display:flex; flex-direction:column; gap:12px; }
.fc-btn { width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-md); color:#fff; transition:transform .22s var(--ease), box-shadow .22s var(--ease); }
.fc-btn:hover { color:#fff; transform:scale(1.08); box-shadow:var(--shadow-lg); }
.fc-btn svg { width:28px; height:28px; }
.fc-wa { background:#25D366; }
.fc-tel { background:linear-gradient(135deg, var(--terracotta), var(--terracotta-dark)); }
@media (max-width:560px){ .float-contact { bottom:18px; left:18px; gap:10px; } .fc-btn { width:50px; height:50px; } .fc-btn svg { width:25px; height:25px; } }

/* ---- Footer ---- */
.site-footer { position:relative; background:var(--stone-900); color:rgba(255,255,255,.72); padding:clamp(48px, 7vw, 68px) 0 28px; font-size:.92rem; overflow:hidden; }
.site-footer::before { content:''; position:absolute; left:0; right:0; top:0; height:1px; background:linear-gradient(90deg, transparent, rgba(230,209,163,.5), transparent); }
.site-footer .container { position:relative; z-index:1; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:42px; margin-bottom:42px; }
.site-footer h4 { color:#fff; font-family:var(--sans); font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:18px; }
.site-footer a { color:rgba(255,255,255,.72); }
.site-footer a:hover { color:var(--gold-soft); }
.footer-brand strong { font-family:var(--serif); font-size:1.65rem; color:#fff; display:block; }
.footer-brand span { font-size:.64rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold-soft); }
.footer-logo { display:inline-flex; align-items:center; justify-content:center; width:190px; max-width:100%; padding:0; margin-bottom:18px; background:transparent; border:0; box-shadow:none; }
.footer-logo img { width:100%; height:auto; max-height:76px; object-fit:contain; }
.footer-list { list-style:none; padding:0; margin:0; }
.footer-list li { margin-bottom:11px; }
.footer-legal { display:flex; flex-wrap:wrap; gap:10px 22px; padding:0 0 20px; margin-bottom:6px; }
.footer-legal a { font-size:.82rem; color:rgba(255,255,255,.6); }
.footer-legal a:hover { color:var(--gold-soft); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.12); padding-top:22px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; font-size:.82rem; color:rgba(255,255,255,.5); }
.footer-bottom .powered { color:rgba(255,255,255,.5); }
.footer-bottom .powered a { color:var(--gold-soft); }

/* ---- Animations ---- */
@keyframes headerDrop { 0% { opacity:0; transform:translateY(-18px); } 100% { opacity:1; transform:translateY(0); } }
@keyframes navFade { 0% { opacity:0; transform:translateY(-8px); } 100% { opacity:1; transform:translateY(0); } }
@keyframes bookingFloat { 0% { opacity:0; transform:translateY(18px); } 100% { opacity:1; transform:translateY(0); } }
@keyframes pageSheen { 0%, 100% { opacity:.6; } 50% { opacity:1; } }
@keyframes heroScrollBounce { 0%, 100% { transform:translateX(-50%) translateY(0); } 55% { transform:translateX(-50%) translateY(8px); } }
@keyframes lbFade { from { opacity:0; } to { opacity:1; } }

/* ---- Responsive ---- */
@media(max-width:900px){
  .home-story-grid { grid-template-columns:1fr; }
  .home-story-cards { grid-template-columns:1fr 1fr 1fr; }
  .hotel-feature-grid { grid-template-columns:1fr; }
  .detail-layout, .contact-grid, .footer-grid { grid-template-columns:1fr; }
  .detail-gallery { grid-template-columns:1fr; }
  .detail-gallery .thumbs { grid-template-columns:repeat(2,1fr); }
  .feature-list { grid-template-columns:1fr; }
  .book-box { position:static; }
  .room-hero { min-height:72vh; padding:140px 0 64px; }
  .room-photo-wall { grid-template-columns:repeat(2,1fr); }
  .room-type-grid { grid-template-columns:repeat(2,1fr); }
  .hotel-facts { grid-template-columns:1fr; }
  .booking-search-compact { grid-template-columns:1fr 1fr; }
}
@media(max-width:560px){
  body { font-size:16px; }
  .hotel-feature-card { padding:24px 20px; }
  .hotel-feature-top { grid-template-columns:1fr; }
  .hotel-feature-card li { display:block; }
  .hotel-feature-card li strong { display:block; margin-top:2px; text-align:left; }
  .home-story-cards { grid-template-columns:1fr; }
  .home-story-card { min-height:auto; }
  .hero { min-height:94vh; }
  .room-grid { grid-template-columns:1fr; }
  .room-hero-meta span { width:100%; }
  .detail-gallery .thumbs { grid-template-columns:1fr; }
  .room-type-grid { grid-template-columns:1fr; }
  .room-photo-wall { grid-template-columns:1fr 1fr; }
  .booking-search-compact { grid-template-columns:1fr; }
  .booking-search-hero { padding:16px; }
  .hotel-fact-card div { grid-template-columns:1fr; gap:2px; }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slide, .room-hero-bg { transform:none; }
  .site-header, .nav-links > li, .nav-right, .booking-search-hero, .page-hero::before, .hero-scroll { animation:none; }
  .reveal { transition:none; }
}

/* Reseliva canlı fiyat rozeti */
.room-price { display:flex; align-items:baseline; gap:6px; margin:2px 0 10px; }
.room-price-label { font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; color:var(--stone-500); }
.room-price strong { font-size:1.32rem; color:var(--gold); font-weight:700; line-height:1; }
.room-price-unit { font-size:.82rem; color:var(--stone-500); }
.room-hero-price { display:inline-flex; align-items:baseline; gap:8px; margin-top:10px; }
.room-hero-price strong { font-size:1.6rem; color:var(--gold); font-weight:700; }
.room-hero-price .unit { font-size:.9rem; color:rgba(255,255,255,.7); }
.price-note { font-size:.78rem; color:var(--stone-500); margin-top:4px; }
