/* Viona — Kaila Beach · premium mobil öncelikli arayüz
   Köşe, gölge, blur ve scrim değerleri :root jetonlarından türetilir; yeni UI buraya bağlanır. */

:root {
  --bg-deep: #070a0f;
  --bg-card: rgba(18, 24, 36, 0.72);
  --stroke: rgba(255, 255, 255, 0.1);
  --text: #f2f4f8;
  --muted: rgba(242, 244, 248, 0.72);
  --gold: #d4a853;
  --gold-dim: rgba(212, 168, 83, 0.2);
  --pool: #1e8bc3;
  --pool-dim: rgba(30, 139, 195, 0.22);
  --cyan: #2eb8c7;
  --cyan-dim: rgba(46, 184, 199, 0.2);
  --shadow: 0 18px 50px rgba(0, 0, 0, 0.45);
  --shadow-tile: 0 14px 40px rgba(0, 0, 0, 0.42);
  --shadow-card-soft: 0 12px 34px rgba(0, 0, 0, 0.22);
  --shadow-hover: 0 10px 28px rgba(0, 0, 0, 0.28);
  --radius: 18px;
  --radius-sm: 14px;
  --radius-md: 16px;
  --radius-inner: 12px;
  --radius-tight: 10px;
  --radius-panel: 22px;
  --radius-pill: 999px;
  --tap: 48px;
  --font: "DM Sans", system-ui, -apple-system, sans-serif;
  --ink: #0a0e14;
  /* Native <select> seçenekleri (OS tema) */
  --surface-select: #0f1724;
  --blur-glass: 16px;
  --blur-glass-strong: 22px;
  --backdrop-scrim: rgba(5, 8, 14, 0.72);
  --stroke-chip: rgba(255, 255, 255, 0.14);
  --error-text: #f87171;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  color-scheme: dark;
}

body {
  margin: 0;
  min-height: 100dvh;
  overflow-x: hidden;
  overflow-x: clip;
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.55;
  color: var(--text);
  background: radial-gradient(120% 80% at 50% -10%, #152238 0%, var(--bg-deep) 55%);
  -webkit-font-smoothing: antialiased;
}

.hidden {
  display: none !important;
}

#app {
  min-height: 100dvh;
  overflow-x: hidden;
  overflow-x: clip;
}

/* ---------- Dil ekranı (premium açılış — her zaman 2 sütun) ---------- */

.view--lang {
  position: relative;
  min-height: 100dvh;
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: max(12px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right))
    max(max(16px, env(safe-area-inset-bottom)), 12px) max(16px, env(safe-area-inset-left));
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
}

.lang-bg {
  position: absolute;
  inset: 0;
  background-image: url("../assets/images/anasayfa1-5bb856f7-1a6f-422f-a788-b74e9a1081f8.png");
  background-size: cover;
  background-position: center;
  transform: scale(1.04);
  animation: kb 22s ease-in-out infinite alternate;
}

@keyframes kb {
  from {
    transform: scale(1.04) translate(0, 0);
  }
  to {
    transform: scale(1.08) translate(-1%, 1%);
  }
}

.lang-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.5) 0%, rgba(7, 10, 15, 0.78) 42%, rgba(5, 8, 14, 0.94) 100%),
    radial-gradient(100% 70% at 50% -5%, rgba(212, 168, 83, 0.22) 0%, transparent 52%),
    radial-gradient(90% 50% at 100% 80%, rgba(30, 139, 195, 0.12) 0%, transparent 45%),
    linear-gradient(168deg, rgba(5, 8, 14, 0.9) 0%, rgba(14, 36, 64, 0.32) 48%, rgba(5, 8, 14, 0.92) 100%);
}

.lang-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: min(520px, 100%);
  box-sizing: border-box;
  min-width: 0;
  text-align: center;
  padding: clamp(26px, 5vw, 36px) clamp(18px, 4vw, 28px) clamp(22px, 4vw, 30px);
  border-radius: clamp(22px, 4vw, 28px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(165deg, rgba(22, 32, 52, 0.97) 0%, rgba(10, 14, 24, 0.92) 45%, rgba(8, 12, 22, 0.94) 100%);
  backdrop-filter: blur(24px) saturate(1.45);
  -webkit-backdrop-filter: blur(24px) saturate(1.45);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.1) inset,
    0 0 0 1px rgba(212, 168, 83, 0.1),
    0 32px 90px rgba(0, 0, 0, 0.58),
    0 0 120px rgba(46, 184, 199, 0.08);
  animation: langPanelIn 0.75s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.lang-content-accent {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 4px;
  border-radius: clamp(22px, 4vw, 28px) clamp(22px, 4vw, 28px) 0 0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(212, 168, 83, 0.35) 20%,
    rgba(212, 168, 83, 0.95) 45%,
    rgba(46, 184, 199, 0.85) 72%,
    transparent 100%
  );
  opacity: 0.98;
}

@keyframes langPanelIn {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.lang-header {
  margin: 0 0 4px;
}

.lang-brand {
  margin: 0 0 14px;
  font-size: 0.7rem;
  letter-spacing: 0.48em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
  text-shadow: 0 0 32px rgba(212, 168, 83, 0.4);
}

.lang-title {
  margin: 0 0 10px;
  font-size: clamp(1.55rem, 4.8vw, 1.95rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.15;
  text-shadow: 0 2px 28px rgba(0, 0, 0, 0.5);
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}

.lang-sub {
  margin: 0;
  font-size: clamp(0.9rem, 2.8vw, 1.02rem);
  color: rgba(242, 244, 248, 0.78);
  line-height: 1.5;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  overflow-wrap: anywhere;
  hyphens: auto;
}

.lang-idle-notice {
  margin: 10px 0 0;
  padding: 10px 12px;
  font-size: clamp(0.82rem, 2.5vw, 0.92rem);
  font-weight: 600;
  line-height: 1.45;
  color: rgba(255, 212, 170, 0.95);
  text-align: center;
  background: rgba(212, 168, 83, 0.12);
  border: 1px solid rgba(212, 168, 83, 0.28);
  border-radius: 12px;
  overflow-wrap: anywhere;
}

.lang-idle-notice.hidden {
  display: none;
}

/* Dil butonları: her ekranda 2 sütun; dar alanda taşma yok */
.lang-grid-wrap {
  margin: 20px 0 22px;
  padding: 2px 0;
}

.lang-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 12px;
  width: 100%;
}

.lang-chip {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: max(48px, 44px);
  padding: 12px 10px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.04) 100%);
  color: var(--text);
  font: inherit;
  font-weight: 600;
  font-size: clamp(0.88rem, 2.6vw, 0.98rem);
  letter-spacing: 0.01em;
  line-height: 1.25;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
  -webkit-tap-highlight-color: rgba(212, 168, 83, 0.15);
}

.lang-chip:hover {
  border-color: rgba(212, 168, 83, 0.45);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.06) 100%);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

.lang-chip:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}

.lang-chip:active:not(.lang-chip--active) {
  transform: scale(0.98);
}

.lang-chip--active {
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.38) 0%, rgba(46, 184, 199, 0.14) 100%);
  border-color: rgba(212, 168, 83, 0.7);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.35),
    0 0 40px rgba(212, 168, 83, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.lang-cta {
  width: 100%;
  min-height: 52px;
  padding: 14px 16px;
  border-radius: var(--radius-pill);
  font-size: clamp(0.82rem, 2.8vw, 1rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.28;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
  touch-action: manipulation;
  box-shadow:
    0 4px 0 rgba(0, 0, 0, 0.12) inset,
    0 12px 36px rgba(0, 0, 0, 0.35);
}

.lang-cta:not(:disabled):hover {
  filter: brightness(1.05);
}

@media (min-width: 480px) {
  .lang-grid {
    gap: 12px 14px;
  }

  .lang-chip {
    min-height: 54px;
    padding: 14px 12px;
  }
}

/* ---------- Erişim ekranı (gizlilik + onay) ---------- */

.view--gate {
  position: relative;
  min-height: 100dvh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  padding: max(12px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right))
    max(max(20px, env(safe-area-inset-bottom)), 16px) max(16px, env(safe-area-inset-left));
  overflow-x: hidden;
  overflow-y: hidden;
  overscroll-behavior-y: contain;
  touch-action: manipulation;
  box-sizing: border-box;
}

.gate-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: min(520px, 100%);
  margin-inline: auto;
  flex: 1 1 auto;
  min-height: 0;
  max-height: calc(100dvh - max(12px, env(safe-area-inset-top)) - max(12px, env(safe-area-inset-bottom)) - 8px);
  max-height: calc(100svh - max(12px, env(safe-area-inset-top)) - max(12px, env(safe-area-inset-bottom)) - 8px);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  min-width: 0;
  overflow: hidden;
  text-align: left;
  padding: clamp(14px, 3.2vw, 22px) clamp(16px, 3.8vw, 26px) 0;
  border-radius: clamp(24px, 4.2vw, 32px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(168deg, rgba(26, 38, 58, 0.99) 0%, rgba(12, 18, 30, 0.94) 46%, rgba(8, 12, 22, 0.98) 100%);
  backdrop-filter: blur(28px) saturate(1.65);
  -webkit-backdrop-filter: blur(28px) saturate(1.65);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.12) inset,
    0 0 0 1px rgba(212, 168, 83, 0.16),
    0 44px 120px rgba(0, 0, 0, 0.68),
    0 0 160px rgba(46, 184, 199, 0.09),
    0 0 1px rgba(0, 0, 0, 0.5);
  animation: langPanelIn 0.72s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.gate-content-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  scroll-padding-bottom: max(20px, env(safe-area-inset-bottom));
  scrollbar-gutter: stable;
  padding: clamp(8px, 2vw, 12px) 0 clamp(14px, 3.5vw, 20px);
}

.gate-credentials {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 3vw, 18px);
  margin-top: 2px;
}

.gate-credentials .gate-password-fields {
  margin-bottom: 0;
}

.gate-credentials .gate-birth-panel {
  margin-top: 0;
}

.gate-identity-card {
  border: 1px solid rgba(212, 168, 83, 0.28);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.14),
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 24px 56px rgba(0, 0, 0, 0.42);
}

/* Doğum tarihi: üst oda kutusundan ayrı panel, gün / ay / yıl açılır listeler */
.gate-birth-panel {
  padding: clamp(16px, 3.8vw, 22px) clamp(16px, 3.5vw, 20px) clamp(18px, 4vw, 22px);
  border-radius: var(--radius-md);
  border: 1px solid rgba(212, 168, 83, 0.22);
  background: linear-gradient(155deg, rgba(255, 255, 255, 0.06) 0%, rgba(12, 18, 28, 0.42) 52%, rgba(8, 12, 22, 0.9) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 0 0 1px rgba(46, 184, 199, 0.1),
    0 18px 44px rgba(0, 0, 0, 0.38);
  position: relative;
}

.gate-birth-panel__title {
  display: block;
  text-align: center;
  margin-bottom: 14px;
}

.gate-birth-selects {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px 12px;
  align-items: end;
}

@media (max-width: 360px) {
  .gate-birth-selects {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

.gate-birth-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.gate-birth-sublabel {
  font-size: clamp(0.65rem, 1.8vw, 0.72rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(170, 188, 206, 0.72);
  padding-left: 2px;
}

.gate-select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-height: 50px;
  padding: 12px 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(5, 10, 18, 0.65);
  color: var(--text);
  font: inherit;
  font-size: max(1rem, 16px);
  font-weight: 500;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
  touch-action: manipulation;
  color-scheme: dark;
  appearance: auto;
}

.gate-select:focus {
  outline: none;
  border-color: rgba(120, 212, 224, 0.45);
  box-shadow: 0 0 0 3px rgba(120, 212, 224, 0.14);
}

.gate-identity-kicker {
  margin: 0 0 12px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(200, 230, 236, 0.75);
}

.gate-content-footer {
  flex: 0 0 auto;
  width: 100%;
  padding: 12px clamp(14px, 3.5vw, 22px) max(16px, calc(12px + env(safe-area-inset-bottom)));
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(10, 14, 24, 0.55) 0%, rgba(14, 20, 34, 0.98) 55%, rgba(8, 12, 22, 1) 100%);
}

.gate-content-footer .gate-back {
  display: block;
  width: 100%;
  margin-top: 10px;
  text-align: center;
}

.view--gate .gate-content {
  flex: 1 1 auto;
  min-height: 0;
}

.gate-header {
  text-align: center;
  margin-bottom: 8px;
}

.gate-header .lang-title {
  text-align: center;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: rgba(252, 252, 255, 0.98);
  text-shadow: 0 2px 28px rgba(0, 0, 0, 0.45);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .gate-header .lang-title {
    background: linear-gradient(
      120deg,
      rgba(252, 252, 255, 0.99) 0%,
      rgba(230, 214, 180, 0.95) 45%,
      rgba(200, 230, 236, 0.92) 100%
    );
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: none;
  }
}

.gate-sub {
  text-align: center;
  max-width: min(100%, 26rem);
  margin: 0 auto 4px;
  padding: 0 6px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.09);
  font-size: clamp(0.88rem, 2.55vw, 0.95rem);
  line-height: 1.55;
  color: rgba(228, 234, 242, 0.9);
  overflow-wrap: anywhere;
  hyphens: auto;
  text-wrap: balance;
}

.gate-password-stack--single:not(.hidden)::before {
  margin-bottom: 12px;
  opacity: 0.65;
}

.gate-password-fields {
  margin-bottom: 16px;
  padding: clamp(18px, 4vw, 22px) clamp(16px, 3.5vw, 20px);
  border-radius: var(--radius-md);
  border: 1px solid rgba(212, 168, 83, 0.22);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.09) 0%, rgba(255, 255, 255, 0.02) 42%, rgba(12, 18, 28, 0.35) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.08) inset,
    0 18px 48px rgba(0, 0, 0, 0.28);
}

.gate-field--single {
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.gate-field--single .gate-label {
  text-align: center;
  margin-bottom: 6px;
}

.gate-field-hint--single {
  display: block;
  text-align: center;
  font-size: clamp(0.76rem, 2.1vw, 0.85rem);
  line-height: 1.45;
  margin: 0 auto 10px;
  max-width: 100%;
  padding: 0 2px;
  color: rgba(188, 206, 222, 0.9);
  font-weight: 500;
  overflow-wrap: anywhere;
  hyphens: auto;
  text-wrap: balance;
}

.gate-field-hint--whisper {
  font-size: clamp(0.68rem, 1.85vw, 0.76rem);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(200, 218, 228, 0.52);
  margin-bottom: 12px;
}

.gate-field-hint {
  display: block;
  font-size: clamp(0.76rem, 2.1vw, 0.84rem);
  line-height: 1.42;
  margin: 0.28rem 0 0.62rem;
  color: rgba(188, 206, 222, 0.88);
  font-weight: 500;
  letter-spacing: 0.02em;
}

.gate-password-stack .gate-field {
  margin-bottom: 0;
}

.gate-password-stack .gate-field:last-of-type {
  margin-bottom: 0;
}

.gate-identity-panel {
  margin-bottom: 20px;
  padding: clamp(18px, 4vw, 22px) clamp(16px, 3.5vw, 20px);
  border-radius: var(--radius-md);
  border: 1px solid rgba(212, 168, 83, 0.22);
  background:
    linear-gradient(155deg, rgba(255, 255, 255, 0.09) 0%, rgba(255, 255, 255, 0.02) 42%, rgba(12, 18, 28, 0.35) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.08) inset,
    0 18px 48px rgba(0, 0, 0, 0.28);
}

.gate-panel-kicker {
  margin: 0 0 10px;
  font-size: clamp(0.68rem, 2vw, 0.74rem);
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(120, 212, 224, 0.88);
  text-align: center;
}

.gate-panel-title {
  margin: 0 0 12px;
  font-size: clamp(1.18rem, 3.6vw, 1.35rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.25;
  color: rgba(252, 252, 255, 0.98);
  text-align: center;
}

.gate-panel-lead {
  margin: 0 0 18px;
  font-size: clamp(0.88rem, 2.6vw, 0.95rem);
  line-height: 1.55;
  color: rgba(228, 232, 240, 0.82);
  text-align: center;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.gate-identity-fields {
  margin-top: 4px;
}

.gate-password-stack {
  width: 100%;
  min-width: 0;
  margin-bottom: 8px;
  padding-top: 4px;
}

.gate-password-stack.gate-password-stack--single {
  margin-bottom: 4px;
  padding-top: 2px;
}

.gate-password-stack:not(.hidden)::before {
  content: "";
  display: block;
  height: 1px;
  margin: 0 0 16px;
  background: linear-gradient(90deg, transparent, rgba(212, 168, 83, 0.35) 50%, transparent);
  opacity: 0.9;
}

.gate-password-lead {
  margin: 0 0 12px;
  font-size: clamp(0.78rem, 2.3vw, 0.84rem);
  line-height: 1.45;
  color: rgba(200, 206, 218, 0.72);
  text-align: center;
  overflow-wrap: anywhere;
}

.gate-password-wrap {
  width: 100%;
  min-width: 0;
  margin-bottom: 2px;
}

.gate-field-wrap {
  margin-bottom: 0;
}

.gate-field {
  margin-bottom: 18px;
}

.gate-input[type="date"] {
  color-scheme: dark;
  min-height: 48px;
}

.gate-label {
  display: block;
  font-size: clamp(0.72rem, 2.2vw, 0.78rem);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(212, 168, 83, 0.92);
  margin-bottom: 10px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.gate-label--muted {
  color: rgba(170, 182, 198, 0.72);
  letter-spacing: 0.08em;
}

.gate-input {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-height: 50px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(5, 10, 18, 0.55);
  color: var(--text);
  font: inherit;
  /* iOS: 16px altında odakta sayfa yakınlaştırır */
  font-size: max(1rem, 16px);
  font-weight: 500;
  letter-spacing: 0.04em;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
  touch-action: manipulation;
}

.gate-input::placeholder {
  color: rgba(242, 244, 248, 0.42);
  letter-spacing: 0.02em;
}

.gate-input:focus {
  outline: none;
  border-color: rgba(212, 168, 83, 0.55);
  box-shadow: 0 0 0 3px rgba(212, 168, 83, 0.18);
}

.gate-input--hero {
  border-color: rgba(120, 212, 224, 0.28);
  background: rgba(6, 14, 22, 0.62);
}

.gate-input--hero:focus {
  border-color: rgba(120, 212, 224, 0.48);
  box-shadow: 0 0 0 3px rgba(120, 212, 224, 0.16);
}

.gate-input--secondary {
  border-color: rgba(255, 255, 255, 0.1);
  background: rgba(5, 10, 18, 0.42);
  /* iOS: 16px altında odakta yakınlaştırma — kahraman alanlarla aynı eşik */
  font-size: max(1rem, 16px);
}

.gate-legal-card {
  margin-top: clamp(12px, 2.8vw, 20px);
  padding: clamp(12px, 2.6vw, 16px);
  border-radius: clamp(18px, 3.2vw, 22px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(10, 16, 26, 0.55) 0%, rgba(6, 10, 18, 0.42) 100%);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gate-legal-card .gate-privacy-card {
  margin: 0 0 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07) 0%, rgba(255, 255, 255, 0.02) 100%);
}

.gate-legal-card .gate-checks {
  margin: 0;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.07);
  gap: 10px;
}

.gate-privacy-card {
  margin: 6px 0 18px;
  padding: clamp(14px, 3vw, 18px) clamp(14px, 3vw, 18px);
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.02) 100%);
}

.gate-privacy-title {
  margin: 0 0 10px;
  font-size: clamp(0.92rem, 2.8vw, 1rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: rgba(248, 250, 252, 0.96);
  line-height: 1.3;
  overflow-wrap: anywhere;
  hyphens: auto;
  text-wrap: balance;
}

.gate-privacy-scroll {
  max-height: min(38svh, 200px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 8px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(212, 168, 83, 0.35) transparent;
}

.gate-privacy-body {
  margin: 0;
  font-size: clamp(0.84rem, 2.5vw, 0.92rem);
  line-height: 1.58;
  color: rgba(235, 238, 244, 0.82);
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}

.gate-privacy-age-line {
  margin-top: 12px;
}

.gate-checks {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 8px 0 18px;
}

.gate-check {
  display: flex;
  gap: 12px;
  align-items: center;
  cursor: pointer;
  margin: 0;
  padding: 6px 0;
  min-height: 44px;
  box-sizing: border-box;
  -webkit-tap-highlight-color: rgba(212, 168, 83, 0.12);
}

.gate-check-input {
  margin-top: 0;
  width: 1.2rem;
  height: 1.2rem;
  min-width: 1.2rem;
  min-height: 1.2rem;
  flex-shrink: 0;
  accent-color: #d4a853;
  cursor: pointer;
}

.gate-check-text {
  flex: 1;
  min-width: 0;
  font-size: clamp(0.85rem, 2.5vw, 0.93rem);
  line-height: 1.48;
  color: rgba(242, 244, 248, 0.9);
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}

.gate-error {
  margin: 4px 0 14px;
  font-size: clamp(0.82rem, 2.4vw, 0.88rem);
  font-weight: 600;
  text-align: center;
  color: #ffb4a8;
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
  overflow-wrap: anywhere;
  padding-inline: 4px;
}

.gate-error.hidden {
  display: none;
}

#btn-gate-retry-status:not(.hidden) {
  margin-top: 6px;
  margin-bottom: 12px;
}

.gate-cta {
  margin-top: 4px;
}

.view--gate .gate-cta {
  padding-inline: 14px;
}

.gate-back {
  display: block;
  width: 100%;
  margin-top: 16px;
  padding: 12px 10px;
  min-height: 44px;
  box-sizing: border-box;
  border: none;
  background: transparent;
  color: rgba(212, 168, 83, 0.82);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 4px;
  transition: color 0.2s ease;
}

.gate-back:hover {
  color: rgba(232, 197, 108, 0.98);
}

@media (prefers-reduced-motion: reduce) {
  .view--gate .lang-bg {
    animation: none;
    transform: scale(1.04);
  }

  .gate-content {
    animation: none;
  }
}

@media (max-width: 380px) {
  .lang-content,
  .gate-content {
    padding-inline: clamp(14px, 4vw, 18px);
  }

  .lang-brand {
    letter-spacing: 0.35em;
  }

  .gate-privacy-scroll {
    max-height: min(32svh, 160px);
  }
}

@media (max-height: 520px) {
  .view--lang {
    align-items: flex-start;
    padding-top: max(10px, env(safe-area-inset-top));
  }

  .gate-privacy-scroll {
    max-height: min(28svh, 120px);
  }
}

@media (min-width: 480px) {
  .gate-header .lang-brand {
    letter-spacing: 0.42em;
  }
}

.btn-primary {
  border: none;
  border-radius: var(--radius-sm);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  color: var(--ink);
  background: linear-gradient(135deg, #e8c56c, #c99a3e);
  box-shadow: var(--shadow);
  transition: transform 0.2s, filter 0.2s;
}

.btn-primary:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  filter: grayscale(0.3);
}

.btn-primary:not(:disabled):active {
  transform: scale(0.98);
}

/* ---------- Ana sayfa ---------- */

.view--home {
  padding-top: env(safe-area-inset-top, 0px);
  padding-bottom: max(20px, env(safe-area-inset-bottom));
}

.home-head {
  position: relative;
}

.carousel {
  position: relative;
  z-index: 0;
  width: 100%;
  aspect-ratio: 16 / 10;
  max-height: min(52vh, 420px);
  overflow: hidden;
  border-radius: 0 0 var(--radius) var(--radius);
  background: #0c121c;
}

.carousel-track {
  position: absolute;
  inset: 0;
}

.carousel-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(1.04);
  transition:
    opacity 1.15s cubic-bezier(0.45, 0, 0.2, 1),
    transform 1.35s cubic-bezier(0.33, 1, 0.68, 1);
  pointer-events: none;
}

.carousel-slide--active {
  opacity: 1;
  transform: scale(1);
}

.carousel-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.carousel-shine {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(5, 8, 14, 0.1) 0%,
    transparent 35%,
    rgba(5, 8, 14, 0.55) 100%
  );
}

.home-hero {
  margin-top: clamp(-28px, -5.5vw, -22px);
  margin-right: max(16px, env(safe-area-inset-right, 0px));
  margin-bottom: 0;
  margin-left: max(16px, env(safe-area-inset-left, 0px));
  position: relative;
  z-index: 2;
  isolation: isolate;
  padding: 22px max(16px, env(safe-area-inset-left, 0px)) 24px
    max(16px, env(safe-area-inset-right, 0px));
  text-align: center;
  overflow: hidden;
  border: 1px solid transparent;
  background:
    linear-gradient(rgba(16, 22, 34, 0.92), rgba(12, 16, 26, 0.94)) padding-box,
    linear-gradient(
        130deg,
        rgba(212, 168, 83, 0.5),
        rgba(46, 184, 199, 0.35),
        rgba(30, 139, 195, 0.4),
        rgba(212, 168, 83, 0.45)
      )
      border-box;
  box-shadow:
    var(--shadow),
    0 0 60px rgba(46, 184, 199, 0.07);
}

.home-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    115deg,
    transparent 0%,
    rgba(255, 255, 255, 0.045) 48%,
    transparent 52%
  );
  animation: homeHeroSheen 7s ease-in-out infinite;
  pointer-events: none;
}

@keyframes homeHeroSheen {
  0%,
  100% {
    opacity: 0.35;
    transform: translateX(-8%);
  }
  50% {
    opacity: 0.85;
    transform: translateX(8%);
  }
}

.home-hero__title {
  margin: 0;
  position: relative;
  z-index: 1;
  font-size: clamp(1.45rem, 4.5vw, 1.85rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
  text-rendering: optimizeLegibility;
  overflow-wrap: break-word;
  word-wrap: break-word;
  background: linear-gradient(100deg, #f8fafc 0%, #e8d8a8 38%, #b8e4ea 72%, #f2f4f8 100%);
  background-size: 180% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation:
    homeHeroTitleIn 0.85s cubic-bezier(0.22, 1, 0.36, 1) backwards,
    homeHeroTitleGlow 12s ease-in-out infinite alternate;
}

@keyframes homeHeroTitleIn {
  from {
    opacity: 0;
    transform: translateY(16px);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes homeHeroTitleGlow {
  0% {
    background-position: 0% 50%;
  }
  100% {
    background-position: 100% 50%;
  }
}

@supports not (background-clip: text) {
  .home-hero__title {
    color: var(--text);
    background: none;
    animation: homeHeroTitleIn 0.85s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  }
}

.home-hero__slogan {
  margin: 16px 0 0;
  padding: 16px 8px 0;
  position: relative;
  z-index: 1;
  max-width: 28rem;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(0.98rem, 3.2vw, 1.12rem);
  font-weight: 600;
  font-style: italic;
  line-height: 1.5;
  letter-spacing: 0.01em;
  color: rgba(248, 250, 252, 0.94);
  text-wrap: balance;
  overflow-wrap: break-word;
  border-top: 1px solid rgba(212, 168, 83, 0.28);
  animation: homeHeroSloganIn 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.12s backwards;
}

@keyframes homeHeroSloganIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.home-body {
  padding: 10px max(16px, env(safe-area-inset-left, 0px)) 0
    max(16px, env(safe-area-inset-right, 0px));
  max-width: 640px;
  margin: 0 auto;
}

.home-body > article {
  margin-bottom: 14px;
}

.glass-block {
  background: var(--bg-card);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  padding: 18px 18px;
  backdrop-filter: blur(var(--blur-glass));
  -webkit-backdrop-filter: blur(var(--blur-glass));
  box-shadow: var(--shadow);
}

.glass-block--accent {
  border-color: rgba(46, 184, 199, 0.28);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.1) 0%, rgba(18, 24, 36, 0.78) 55%);
  box-shadow:
    var(--shadow),
    0 0 0 1px rgba(46, 184, 199, 0.12) inset;
}

#module-inner.glass-block {
  overflow-x: hidden;
  min-width: 0;
  border-radius: calc(var(--radius) + 2px);
  border-top: 1px solid rgba(212, 168, 83, 0.28);
  background:
    linear-gradient(180deg, rgba(212, 168, 83, 0.06) 0%, transparent 22%),
    var(--bg-card);
  box-shadow:
    var(--shadow),
    0 0 0 1px rgba(46, 184, 199, 0.1) inset,
    0 1px 0 rgba(255, 255, 255, 0.04) inset;
}

#module-inner.glass-block:has(.where-module--kroki-locked) {
  padding-left: max(12px, env(safe-area-inset-left, 0px));
  padding-right: max(12px, env(safe-area-inset-right, 0px));
  padding-top: max(16px, env(safe-area-inset-top, 0px));
}

@keyframes homeReveal {
  from {
    opacity: 0;
    transform: translateY(14px);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

.home-reveal {
  animation: homeReveal 0.75s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}

.home-body > .home-reveal:nth-child(1) {
  animation-delay: 0.08s;
}
.home-body > .home-reveal:nth-child(2) {
  animation-delay: 0.16s;
}

@media (prefers-reduced-motion: reduce) {
  .home-reveal {
    animation: none;
  }
  .home-module-grid .module-card {
    animation: none !important;
  }
  .home-hero::after {
    animation: none;
  }
  .home-hero__title {
    animation: none !important;
  }
  .home-hero__slogan {
    animation: none !important;
  }
  .carousel-slide {
    transform: none;
    transition: opacity 0.35s ease;
  }
  .carousel-slide--active {
    transform: none;
  }
}

.home-app-card {
  padding: 18px 18px 17px;
  border-color: rgba(46, 184, 199, 0.32);
  background: linear-gradient(
    155deg,
    rgba(46, 184, 199, 0.12) 0%,
    rgba(18, 26, 40, 0.82) 42%,
    rgba(12, 20, 34, 0.9) 100%
  );
  box-shadow:
    var(--shadow),
    0 0 0 1px rgba(46, 184, 199, 0.14) inset;
}

/* Viona tanıtım kartı — ortalanmış, where-modülü ile uyumlu premium çerçeve */
.home-app-card--premium {
  position: relative;
  text-align: center;
  padding: 22px 22px 24px;
  border-radius: 18px;
  border: 1px solid rgba(46, 184, 199, 0.22);
  border-top: 1px solid rgba(212, 168, 83, 0.38);
  background:
    linear-gradient(180deg, rgba(212, 168, 83, 0.1) 0%, transparent 40%),
    linear-gradient(
      158deg,
      rgba(46, 184, 199, 0.13) 0%,
      rgba(18, 26, 40, 0.82) 48%,
      rgba(12, 20, 34, 0.92) 100%
    );
  box-shadow:
    var(--shadow),
    0 0 0 1px rgba(46, 184, 199, 0.12) inset,
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 16px 48px rgba(0, 0, 0, 0.22);
  isolation: isolate;
  overflow: hidden;
}

.home-app-card--premium::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(118deg, transparent 0%, rgba(255, 255, 255, 0.045) 50%, transparent 100%);
  pointer-events: none;
  opacity: 0.75;
}

.home-app-kicker {
  margin: 0 0 12px;
  font-size: clamp(0.78rem, 2.4vw, 0.88rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-align: left;
  color: rgba(46, 184, 199, 0.98);
  text-wrap: balance;
}

.home-app-card--premium .home-app-kicker {
  position: relative;
  z-index: 1;
  text-align: center;
  letter-spacing: 0.14em;
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(200, 244, 252, 0.98);
  font-size: clamp(0.8rem, 2.5vw, 0.9rem);
}

.home-app-text {
  margin: 0;
  max-width: 28rem;
  font-size: clamp(0.92rem, 2.8vw, 1.02rem);
  line-height: 1.58;
  font-weight: 500;
  letter-spacing: 0.01em;
  text-align: left;
  text-wrap: balance;
  color: rgba(245, 247, 250, 0.92);
}

.home-app-card--premium .home-app-text {
  position: relative;
  z-index: 1;
  margin-left: auto;
  margin-right: auto;
  max-width: 32rem;
  text-align: center;
  font-size: clamp(0.94rem, 2.9vw, 1.05rem);
  line-height: 1.6;
  font-weight: 500;
  color: rgba(236, 242, 250, 0.94);
}

.dual-actions {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 4px 0 20px;
}

.action-tile {
  position: relative;
  min-height: 96px;
  padding: 18px 20px;
  border-radius: calc(var(--radius-sm) + 2px);
  border: 1px solid var(--stroke);
  font: inherit;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
  text-align: left;
  cursor: pointer;
  color: var(--text);
  overflow: hidden;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  transition: transform 0.2s ease, box-shadow 0.25s ease, border-color 0.2s;
}

.action-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background: radial-gradient(80% 120% at 0% 0%, rgba(255, 255, 255, 0.22), transparent 50%);
  pointer-events: none;
}

.action-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0;
  background: linear-gradient(110deg, transparent 40%, rgba(255, 255, 255, 0.08) 50%, transparent 60%);
  transform: translateX(-100%);
  transition: opacity 0.3s, transform 0.6s ease;
  pointer-events: none;
}

.action-tile:hover::after {
  opacity: 1;
  transform: translateX(100%);
}

.action-tile:active {
  transform: scale(0.99);
}

.action-tile--gold {
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.42), rgba(16, 22, 34, 0.96));
  border-color: rgba(212, 168, 83, 0.55);
  box-shadow: var(--shadow-tile), 0 0 0 1px rgba(212, 168, 83, 0.25) inset;
}

.action-tile--cyan {
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.38), rgba(16, 22, 34, 0.96));
  border-color: rgba(46, 184, 199, 0.5);
  box-shadow: var(--shadow-tile), 0 0 0 1px rgba(46, 184, 199, 0.2) inset;
}

.action-tile--gold::before,
.action-tile--cyan::before {
  background: radial-gradient(120% 160% at 0% 0%, rgba(255, 255, 255, 0.24), transparent 48%);
  opacity: 1;
}

.action-tile--gold::after,
.action-tile--cyan::after {
  background: linear-gradient(110deg, transparent 25%, rgba(255, 255, 255, 0.16) 48%, transparent 72%);
  transform: translateX(-120%);
  transition: transform 0.75s ease;
}

.action-tile--gold:hover::after,
.action-tile--cyan:hover::after {
  transform: translateX(120%);
}

.action-tile--gold:hover {
  border-color: rgba(243, 214, 139, 0.82);
  box-shadow:
    0 18px 44px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(243, 214, 139, 0.35) inset;
}

.action-tile--cyan:hover {
  border-color: rgba(126, 231, 246, 0.82);
  box-shadow:
    0 18px 44px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(126, 231, 246, 0.3) inset;
}

.action-ico {
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.35));
}

.action-tile__text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
}

.action-tile__title {
  font-size: clamp(1rem, 3.6vw, 1.12rem);
  font-weight: 700;
  letter-spacing: -0.02em;
}

.action-tile__hint {
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(242, 244, 248, 0.72);
  line-height: 1.35;
}

.section-title {
  margin: 0 0 12px;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text);
}

.loc-block {
  margin-bottom: 14px;
}

.loc-list {
  margin: 0;
  padding-left: 1.1rem;
  color: var(--muted);
  font-size: 0.92rem;
}

.loc-list li {
  margin-bottom: 4px;
}

.loc-note {
  margin: 12px 0 0;
  font-size: 0.9rem;
  color: var(--muted);
}

.sus-block {
  margin-bottom: 20px;
}

.sus-sub {
  margin: 0 0 10px;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--gold);
}

.sus-block p:last-child {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
}

.module-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 13px;
  margin-bottom: 24px;
  min-width: 0;
}

@media (min-width: 520px) {
  .module-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.home-module-grid .module-card {
  animation: homeReveal 0.55s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}

.home-module-grid .module-card:nth-child(1) {
  animation-delay: 0.06s;
}
.home-module-grid .module-card:nth-child(2) {
  animation-delay: 0.1s;
}
.home-module-grid .module-card:nth-child(3) {
  animation-delay: 0.14s;
}
.home-module-grid .module-card:nth-child(4) {
  animation-delay: 0.18s;
}
.home-module-grid .module-card:nth-child(5) {
  animation-delay: 0.22s;
}
.home-module-grid .module-card:nth-child(6) {
  animation-delay: 0.26s;
}
.home-module-grid .module-card:nth-child(7) {
  animation-delay: 0.3s;
}
.home-module-grid .module-card:nth-child(8) {
  animation-delay: 0.34s;
}
.home-module-grid .module-card:nth-child(9) {
  animation-delay: 0.38s;
}
.home-module-grid .module-card:nth-child(10) {
  animation-delay: 0.42s;
}
.home-module-grid .module-card:nth-child(11) {
  animation-delay: 0.46s;
}
.home-module-grid .module-card:nth-child(12) {
  animation-delay: 0.5s;
}

.home-module-grid .module-card:nth-child(13) {
  animation-delay: 0.54s;
}

.home-module-grid .module-card:nth-child(14) {
  animation-delay: 0.58s;
}

.home-module-grid .module-card:nth-child(15) {
  animation-delay: 0.62s;
}

.module-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 84px;
  min-width: 0;
  padding: 16px 18px;
  border-radius: calc(var(--radius-sm) + 2px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(142deg, rgba(255, 255, 255, 0.055) 0%, rgba(14, 20, 30, 0.86) 52%, rgba(10, 16, 26, 0.9) 100%);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
  contain: layout style;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset, 0 10px 32px rgba(0, 0, 0, 0.16);
  transition:
    transform 0.22s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.25s ease,
    box-shadow 0.25s ease,
    background 0.2s ease;
}

/* Anket kartı: diğer modül kartlarıyla aynı dil; yalnızca tam genişlik */
.module-card--survey {
  grid-column: 1 / -1;
}

.module-card--survey:hover {
  border-color: rgba(46, 184, 199, 0.38);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 14px 40px rgba(0, 0, 0, 0.22);
}

.module-card:hover {
  border-color: rgba(46, 184, 199, 0.34);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 14px 40px rgba(0, 0, 0, 0.22);
}

.module-card:active {
  transform: scale(0.99);
}

.module-card:focus-visible {
  outline: 2px solid var(--pool);
  outline-offset: 2px;
}

.module-card__icon {
  width: 46px;
  height: 46px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: calc(var(--radius-sm) + 2px);
  background: linear-gradient(155deg, rgba(46, 184, 199, 0.22) 0%, rgba(46, 184, 199, 0.06) 100%);
  border: 1px solid rgba(46, 184, 199, 0.32);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.08) inset;
}

.module-card__icon svg {
  width: 24px;
  height: 24px;
  opacity: 0.95;
}

.module-card__text {
  font-size: 0.96rem;
  font-weight: 600;
  line-height: 1.3;
  min-width: 0;
  overflow-wrap: anywhere;
  hyphens: auto;
  text-wrap: balance;
  text-rendering: optimizeLegibility;
}

.site-footer {
  text-align: center;
  font-size: 0.75rem;
  color: rgba(242, 244, 248, 0.35);
  padding: 8px 0 20px;
}

/* ---------- Değerlendirme modülü ---------- */

.survey-module-root {
  margin: 0 0 18px;
}

.survey-wrap .req-intro {
  border-color: rgba(46, 184, 199, 0.22);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.08) 0%, rgba(0, 0, 0, 0.16) 100%);
}

.survey-wrap__title {
  margin: 0 0 10px;
  font-size: clamp(1.05rem, 3.6vw, 1.28rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.28;
  color: var(--text);
  overflow-wrap: break-word;
}

.survey-hub {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

@media (min-width: 480px) {
  .survey-hub {
    grid-template-columns: 1fr 1fr;
  }
}

.survey-subhub {
  margin-top: 4px;
}

.survey-subhub__sheet {
  border-radius: var(--radius-md);
  border: 1px solid rgba(46, 184, 199, 0.18);
  background: linear-gradient(180deg, rgba(18, 26, 40, 0.55) 0%, rgba(12, 18, 30, 0.72) 100%);
  padding: 12px 10px 10px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.22);
}

.survey-subhub__hint {
  margin: 0 0 10px;
  font-size: 0.9rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.82);
}

.survey-hub--sub {
  gap: 8px;
}

.req-hub__card--sub .req-hub__label {
  font-size: 0.9rem;
  line-height: 1.35;
  text-align: left;
}

@media (max-width: 520px) {
  .survey-subhub__sheet {
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    padding-bottom: max(12px, env(safe-area-inset-bottom, 0px));
  }
}

.survey-card {
  position: relative;
  margin-top: 8px;
  border: 1px solid var(--stroke);
  border-radius: var(--radius-md);
  padding: 14px 12px;
  background: linear-gradient(155deg, rgba(30, 139, 195, 0.08) 0%, rgba(18, 24, 36, 0.88) 50%, rgba(12, 18, 30, 0.94) 100%);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.1) inset,
    var(--shadow-card-soft);
}

.survey-card__title {
  margin: 0;
  font-size: clamp(1.08rem, 4vw, 1.24rem);
  line-height: 1.32;
  letter-spacing: -0.02em;
}

.survey-card__lead {
  margin: 10px 0 14px;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.8);
}

.survey-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  padding: 2px 0 6px;
}

.survey-tabs__btn {
  flex: 0 0 auto;
  min-height: 44px;
  padding: 10px 14px;
  border-radius: var(--radius-inner);
  border: 1px solid var(--stroke-chip);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: pointer;
}

.survey-tabs__btn.is-active {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.14);
  box-shadow: 0 0 0 1px rgba(30, 139, 195, 0.2) inset;
}

.survey-tabs__btn:focus-visible {
  outline: 2px solid var(--pool);
  outline-offset: 2px;
}

@media (min-width: 920px) {
  .survey-tabs {
    overflow: visible;
    flex-wrap: wrap;
  }
}

.survey-panel {
  margin-top: 10px;
  padding: 14px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.11);
  background: rgba(0, 0, 0, 0.18);
}

.survey-q-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.survey-q-row {
  padding: 10px 10px 11px;
  border-radius: var(--radius-inner);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.survey-q-row__title {
  margin: 0 0 8px;
  font-size: 0.9rem;
  line-height: 1.4;
  color: rgba(242, 244, 248, 0.92);
  overflow-wrap: break-word;
}

.survey-score {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.survey-score__btn {
  min-width: 44px;
  min-height: 44px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(0, 0, 0, 0.28);
  color: var(--text);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.survey-score__btn.is-active {
  border-color: rgba(46, 184, 199, 0.75);
  background: linear-gradient(145deg, rgba(30, 139, 195, 0.35), rgba(46, 184, 199, 0.12));
  color: var(--text);
  box-shadow: 0 0 0 1px rgba(212, 168, 83, 0.2) inset;
}

.survey-score__btn:focus-visible {
  outline: 2px solid var(--pool);
  outline-offset: 2px;
}

.survey-textarea {
  width: 100%;
  margin-top: 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(0, 0, 0, 0.24);
  color: var(--text);
  font: inherit;
  font-size: 1rem;
  line-height: 1.45;
  padding: 12px 13px;
  resize: vertical;
}

.survey-hotel-comment {
  margin-top: 12px;
}

.survey-hotel-comment__label {
  margin: 0;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.6);
}

.survey-submit {
  width: 100%;
  min-height: 50px;
  margin-top: 12px;
}

.survey-submit--main {
  margin-top: 14px;
  font-size: 1rem;
}

.survey-success {
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(52, 211, 153, 0.5);
  background: rgba(52, 211, 153, 0.12);
  color: rgba(209, 250, 229, 0.95);
  font-size: 0.92rem;
  line-height: 1.45;
}

.survey-error-msg {
  margin: 12px 0 0;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(248, 113, 113, 0.45);
  background: rgba(248, 113, 113, 0.12);
  color: rgba(254, 226, 226, 0.95);
  font-size: 0.92rem;
  line-height: 1.45;
}

.survey-success-sub {
  margin: 8px 0 0;
  padding: 0 2px;
  font-size: 0.85rem;
  line-height: 1.45;
  color: rgba(209, 250, 229, 0.75);
}

.survey-hub-hint {
  margin: 0 0 14px;
  font-size: 0.88rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.65);
}

.req-hub__card--complete {
  border-color: rgba(52, 211, 153, 0.35);
  box-shadow: 0 0 0 1px rgba(52, 211, 153, 0.15) inset;
}

/* Anket: gönder öncesi onay (sekme bazlı) */
.survey-confirm {
  position: absolute;
  inset: 0;
  z-index: 8;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: stretch;
  padding: 10px;
  border-radius: inherit;
  overflow: hidden;
}

.survey-confirm__backdrop {
  position: absolute;
  inset: 0;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: inherit;
  background: var(--backdrop-scrim);
  backdrop-filter: blur(6px);
  cursor: pointer;
}

.survey-confirm__sheet {
  position: relative;
  z-index: 1;
  padding: 16px 14px max(16px, env(safe-area-inset-bottom));
  border-radius: var(--radius-sm);
  border: 1px solid var(--stroke);
  background: rgba(18, 24, 36, 0.97);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35);
}

.survey-confirm__title {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.survey-confirm__lead {
  margin: 10px 0 0;
  font-size: 0.88rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.78);
}

.survey-confirm__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}

@media (min-width: 400px) {
  .survey-confirm__actions {
    flex-direction: row-reverse;
  }
  .survey-confirm__actions .survey-confirm__btn {
    flex: 1;
  }
}

.survey-confirm__btn {
  min-height: 48px;
  border-radius: var(--radius-inner);
  font: inherit;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: opacity 0.15s ease, transform 0.12s ease;
}

.survey-confirm__btn:active:not(:disabled) {
  transform: scale(0.99);
}

.survey-confirm__btn--secondary {
  border: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
}

/* ---------- Modül görünümü ---------- */

.view--module {
  min-height: 100dvh;
  padding: max(12px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-left, 0px))
    max(24px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-right, 0px));
  max-width: 640px;
  margin: 0 auto;
  box-sizing: border-box;
  width: 100%;
}

/* Neredeyim: geniş ekranda modül genişliği (iç kaydırma yok — sayfa tek akış) */
#view-module.view--module:has(.where-module--kroki-locked) {
  max-width: min(1040px, 100%);
}

.btn-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 14px 0 10px;
  margin-bottom: 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font: inherit;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.btn-back::before {
  content: "←";
  font-size: 1.1rem;
  opacity: 0.85;
}

.btn-back:active {
  transform: scale(0.98);
}

.module-inner {
  padding: 22px 18px;
  min-height: 200px;
  max-width: 100%;
  box-sizing: border-box;
  overflow-x: hidden;
  word-break: break-word;
}

.module-inner img,
.module-inner video {
  max-width: 100%;
  height: auto;
}

.module-inner h2 {
  margin: 0 0 12px;
  font-size: 1.2rem;
}

/* Uygulamanın eklediği modül başlığı (doğrudan ilk çocuk) — premium çizgi */
.module-inner > h2:first-child {
  margin: 0 0 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 1.22rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.25;
  color: rgba(252, 254, 255, 0.98);
  text-wrap: balance;
}

.module-inner p.placeholder {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.subgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 8px;
}

@media (max-width: 400px) {
  .subgrid {
    grid-template-columns: 1fr;
  }
}

.subbtn {
  min-height: 64px;
  padding: 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--stroke);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text);
  font: inherit;
  font-size: 0.85rem;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: transform 0.15s, border-color 0.2s, background 0.2s;
}

.subbtn:hover {
  border-color: rgba(212, 168, 83, 0.35);
}

.subbtn:active {
  transform: scale(0.98);
}

/* ---------- Modal ---------- */

.modal-root {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: env(safe-area-inset-top) 0 0;
}

@media (min-width: 520px) {
  .modal-root {
    align-items: center;
    padding: 20px;
  }
}

.modal-root.hidden {
  display: none;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: var(--backdrop-scrim);
  backdrop-filter: blur(6px);
}

.modal-sheet {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 480px;
  max-height: min(86vh, 640px);
  max-height: min(86dvh, 640px);
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  margin: 0;
  border-radius: var(--radius) var(--radius) 0 0;
  padding: 18px 16px max(22px, env(safe-area-inset-bottom));
}

@media (min-width: 520px) {
  .modal-sheet {
    border-radius: var(--radius);
  }
}

/* Değerlendirme modalı — hizalı, tek sütun liste, premium cam panel */
.modal-sheet--rate {
  width: min(100%, 520px);
  max-width: 520px;
  max-height: min(88vh, 720px);
  max-height: min(88dvh, 720px);
  margin-inline: auto;
  padding: 22px 18px max(24px, env(safe-area-inset-bottom));
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.35) inset,
    0 28px 90px -24px rgba(0, 0, 0, 0.75);
  background: linear-gradient(165deg, rgba(28, 36, 52, 0.97) 0%, rgba(14, 18, 28, 0.98) 55%, rgba(10, 14, 22, 0.99) 100%);
  backdrop-filter: blur(var(--blur-glass));
  -webkit-backdrop-filter: blur(var(--blur-glass));
}

@media (min-width: 520px) {
  .modal-sheet--rate {
    padding: 26px 24px 28px;
  }
}

#modal-rate .modal-head {
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

#modal-rate .modal-head h2 {
  font-size: clamp(1.12rem, 3.5vw, 1.28rem);
  font-weight: 600;
  letter-spacing: -0.03em;
}

#modal-rate .modal-lead {
  margin-top: 10px;
  font-size: 0.875rem;
  line-height: 1.5;
  max-width: 46ch;
  color: rgba(242, 244, 248, 0.72);
}

#modal-rate .modal-lead--rate-note {
  margin-top: 14px;
  margin-bottom: 0;
  padding: 12px 14px;
  max-width: none;
  border-radius: 12px;
  background: rgba(46, 184, 199, 0.07);
  border: 1px solid rgba(46, 184, 199, 0.16);
  font-size: 0.8125rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.78);
}

#modal-rate .btn-icon-close:hover {
  background: rgba(255, 255, 255, 0.12);
}

#modal-rate .btn-icon-close:focus-visible {
  outline: 2px solid rgba(46, 184, 199, 0.75);
  outline-offset: 2px;
}

.modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.modal-head-text {
  min-width: 0;
  flex: 1;
}

.modal-head h2 {
  margin: 0;
  font-size: 1.18rem;
  line-height: 1.28;
  letter-spacing: -0.02em;
}

.modal-lead {
  margin: 8px 0 0;
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--muted);
}

.btn-icon-close {
  border: none;
  background: rgba(255, 255, 255, 0.08);
  color: var(--text);
  width: 40px;
  height: 40px;
  border-radius: var(--radius-inner);
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
}

.rate-modal-body {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.rate-section {
  display: flex;
  flex-direction: column;
  gap: 11px;
  animation: rateFadeIn 0.55s ease-out both;
}

@keyframes rateFadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.rate-section__title {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.48);
}

.rate-section--reviews {
  gap: 14px;
}

.rate-section--reviews .rate-section__title {
  padding-bottom: 12px;
  margin-bottom: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.09);
  letter-spacing: 0.13em;
  color: rgba(242, 244, 248, 0.55);
}

.rate-section:not(.rate-section--reviews) .rate-section__title {
  padding-bottom: 8px;
  margin-bottom: 2px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Tek sütun: dar modallarda hizayı bozmayan, okunaklı liste */
.rate-link-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.rate-link {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) 22px;
  grid-template-rows: auto;
  align-items: start;
  gap: 0 14px;
  padding: 14px 14px 14px 15px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text);
  font: inherit;
  text-decoration: none;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.25s ease,
    transform 0.18s ease,
    background 0.2s ease;
  animation: rateFadeIn 0.5s ease-out both;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset;
}

.rate-link:focus-visible {
  outline: 2px solid rgba(46, 184, 199, 0.75);
  outline-offset: 2px;
}

.rate-link:hover {
  border-color: rgba(212, 168, 83, 0.42);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.12) inset,
    0 18px 40px -22px rgba(0, 0, 0, 0.55);
  transform: translateY(-1px);
}

.rate-link--social:hover {
  border-color: rgba(244, 114, 182, 0.48);
  box-shadow:
    0 0 0 1px rgba(244, 114, 182, 0.14) inset,
    0 18px 40px -22px rgba(0, 0, 0, 0.55);
}

.rate-link--booking:hover {
  border-color: rgba(46, 184, 199, 0.55);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.15) inset,
    0 18px 40px -22px rgba(0, 0, 0, 0.55);
}

.rate-link:active {
  transform: translateY(0);
}

.rate-link--review {
  border-color: rgba(212, 168, 83, 0.2);
  background: linear-gradient(152deg, rgba(212, 168, 83, 0.09) 0%, rgba(16, 22, 34, 0.92) 48%, rgba(10, 14, 22, 0.95) 100%);
}

.rate-link--social {
  border-color: rgba(236, 72, 153, 0.32);
  background: linear-gradient(152deg, rgba(236, 72, 153, 0.1) 0%, rgba(16, 22, 34, 0.92) 50%, rgba(10, 14, 22, 0.96) 100%);
}

.rate-link--booking {
  border-color: rgba(46, 184, 199, 0.38);
  background: linear-gradient(152deg, rgba(46, 184, 199, 0.12) 0%, rgba(16, 22, 34, 0.92) 50%, rgba(10, 14, 22, 0.96) 100%);
}

.rate-link--featured.rate-link--review {
  grid-template-columns: 54px minmax(0, 1fr) 24px;
  padding: 17px 16px 17px 17px;
  border-radius: calc(var(--radius-md) + 2px);
  border-color: rgba(66, 133, 244, 0.42);
  background: linear-gradient(
    155deg,
    rgba(66, 133, 244, 0.16) 0%,
    rgba(212, 168, 83, 0.08) 38%,
    rgba(12, 18, 30, 0.96) 100%
  );
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 20px 48px -24px rgba(0, 0, 0, 0.6);
}

.rate-link--featured.rate-link--review:hover {
  border-color: rgba(120, 175, 255, 0.55);
}

.rate-link--featured .rate-link__icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(0, 0, 0, 0.32);
  border-color: rgba(255, 255, 255, 0.1);
}

.rate-link--featured .rate-link__title {
  font-size: 1.02rem;
  font-weight: 700;
  letter-spacing: -0.025em;
}

.rate-link--featured .rate-link__svg {
  width: 28px;
  height: 28px;
}

.rate-link__icon {
  grid-column: 1;
  grid-row: 1;
  width: 48px;
  height: 48px;
  margin-top: 2px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-inner);
  background: rgba(0, 0, 0, 0.26);
  border: 1px solid rgba(255, 255, 255, 0.09);
}

.rate-link__svg {
  width: 26px;
  height: 26px;
  display: block;
}

.rate-link__svg--ig {
  width: 28px;
  height: 28px;
}

.rate-link__body {
  grid-column: 2;
  grid-row: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 1px;
}

.rate-link__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 12px;
  align-items: start;
}

.rate-link__title {
  margin: 0;
  font-size: 0.93rem;
  font-weight: 700;
  line-height: 1.28;
  overflow-wrap: anywhere;
  hyphens: auto;
}

.rate-link__badge {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  align-self: start;
  margin-top: 1px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 5px 9px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.28);
  color: rgba(242, 244, 248, 0.78);
  white-space: nowrap;
}

@media (max-width: 340px) {
  .rate-link__row {
    grid-template-columns: 1fr;
  }

  .rate-link__badge {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
    margin-top: 0;
  }
}

.rate-link--review .rate-link__badge {
  border-color: rgba(212, 168, 83, 0.38);
  color: rgba(255, 224, 170, 0.96);
}

.rate-link--social .rate-link__badge {
  border-color: rgba(244, 114, 182, 0.45);
  color: #fbcfe8;
}

.rate-link--booking .rate-link__badge {
  border-color: rgba(46, 184, 199, 0.45);
  color: #a5f3fc;
}

.rate-link__hint {
  font-size: 0.8rem;
  letter-spacing: 0.01em;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.58);
  max-width: 100%;
}

.rate-link__arrow {
  grid-column: 3;
  grid-row: 1;
  margin-top: 14px;
  justify-self: end;
  opacity: 0.45;
  font-size: 1.1rem;
  line-height: 1;
}

.rate-link--featured .rate-link__arrow {
  margin-top: 18px;
}

.viona-blurb {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* —— Viona sohbet modal —— */

.modal-sheet--viona {
  display: flex;
  flex-direction: column;
  max-height: min(92dvh, 720px);
  overflow: hidden;
  padding-bottom: max(16px, env(safe-area-inset-bottom));
}

.modal-head--viona {
  flex-shrink: 0;
  align-items: flex-start;
}

.viona-chat {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  gap: 0;
}

/* Sesli mod: üstte boş sohbet alanı olmasın — mesaj listesi + kısayollar + yazı alanı gizli; sadece bar + avatar */
.viona-chat--voice-drawer-open .viona-chat__welcome,
.viona-chat--voice-drawer-open .viona-chat__quick,
.viona-chat--voice-drawer-open .viona-chat__scroll,
.viona-chat--voice-drawer-open .viona-chat__composer {
  display: none !important;
}

.viona-chat--voice-drawer-open .viona-chat__bar-btn--clear {
  display: none !important;
}

.viona-chat-primary--voice-mode {
  gap: 12px;
}

/* Sesli çekmece tüm yüksekliği doldurur, avatar ortada */
.viona-chat--voice-drawer-open .viona-voice-drawer:not([hidden]) {
  flex: 1 1 auto;
  min-height: min(300px, 52vh);
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-panel);
  border: 1px solid rgba(46, 184, 199, 0.22);
  background:
    radial-gradient(ellipse 85% 65% at 50% 18%, rgba(46, 184, 199, 0.14) 0%, transparent 58%),
    radial-gradient(ellipse 70% 50% at 80% 88%, rgba(212, 168, 83, 0.08) 0%, transparent 45%),
    linear-gradient(165deg, rgba(16, 28, 48, 0.92) 0%, rgba(6, 10, 20, 0.96) 55%, rgba(4, 7, 14, 0.98) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    inset 0 -1px 0 rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(0, 0, 0, 0.2),
    0 20px 48px rgba(0, 0, 0, 0.42);
  padding: 28px 22px 32px;
}

/* Kapalı / metin modunda: idle iken durum satırı yok */
.viona-voice-drawer[data-voice-state="idle"] .viona-voice__status {
  display: none;
}

/* Sesli mod açık + boşta: kısa ipucu (keşfedilebilirlik) */
.viona-chat--voice-drawer-open .viona-voice-drawer[data-voice-state="idle"]:not([hidden]) .viona-voice__status {
  display: block;
  margin-top: 4px;
  max-width: 260px;
  padding: 8px 16px;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(242, 244, 248, 0.62);
  border-color: rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.2);
  box-shadow: none;
}

.viona-chat--voice-drawer-open .viona-voice-drawer .viona-voice__stage {
  width: min(204px, 58vw);
  height: min(204px, 58vw);
}

.viona-chat-primary {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  gap: 14px;
  min-height: 200px;
}

/* Sol geri + sağda araçlar */
.viona-chat__topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  padding: 4px 0 4px;
  min-height: 48px;
}

.viona-chat__nav-back {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: linear-gradient(165deg, rgba(22, 32, 52, 0.9) 0%, rgba(8, 12, 22, 0.95) 100%);
  color: rgba(242, 244, 248, 0.94);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.28);
  cursor: pointer;
  transition:
    border-color 0.2s,
    background 0.2s,
    box-shadow 0.2s,
    opacity 0.2s;
}

.viona-chat__nav-back:hover:not(:disabled) {
  border-color: rgba(46, 184, 199, 0.4);
  background: linear-gradient(165deg, rgba(28, 48, 78, 0.95) 0%, rgba(12, 20, 36, 0.98) 100%);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.32);
}

.viona-chat__nav-back:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
}

.viona-chat__nav-back:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.viona-chat__nav-back-ico {
  width: 22px;
  height: 22px;
}

/* Sohbet üst çubuğu — lacivert cam, sohbet odaklı */
.viona-chat__bar {
  display: flex;
  flex: 1;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-shrink: 0;
  min-width: 0;
}

.viona-chat__bar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 18px;
  border-radius: var(--radius-pill);
  font-size: 0.84rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: linear-gradient(165deg, #172a48 0%, #0c162c 48%, #080f1f 100%);
  color: rgba(242, 244, 248, 0.94);
  box-shadow:
    0 4px 18px rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  cursor: pointer;
  transition:
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.15s ease,
    background 0.2s;
}

.viona-chat__bar-btn:hover {
  border-color: rgba(212, 168, 83, 0.32);
  box-shadow:
    0 6px 22px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.viona-chat__bar-btn:active {
  transform: scale(0.98);
}

.viona-chat__bar-btn:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
}

.viona-chat__bar-btn--clear {
  min-height: 40px;
  padding: 0 14px;
  border-color: rgba(255, 255, 255, 0.08);
  background: linear-gradient(165deg, rgba(18, 26, 40, 0.88) 0%, rgba(8, 12, 20, 0.94) 100%);
  color: rgba(242, 244, 248, 0.72);
  font-size: 0.8rem;
  font-weight: 500;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.22);
}

.viona-chat__bar-btn--clear:hover {
  border-color: rgba(255, 255, 255, 0.16);
  color: rgba(242, 244, 248, 0.9);
}

/* Sesli mod kapalıyken: bar altı kısa yönergeler (i18n: voiceSectionTap*) */
.viona-chat__voice-hints {
  margin: 0;
  padding: 2px 6px 12px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: center;
  text-align: center;
}

.viona-chat__voice-hints p {
  margin: 0;
  max-width: 320px;
  font-size: 0.76rem;
  font-weight: 500;
  line-height: 1.38;
  letter-spacing: 0.01em;
  color: rgba(242, 244, 248, 0.55);
}

.viona-chat__voice-info-only {
  font-size: 0.74rem;
  font-weight: 500;
  color: rgba(200, 230, 245, 0.72);
  max-width: 340px !important;
}

.viona-chat__voice-avatar-hint {
  font-size: 0.72rem;
  font-weight: 400;
  color: rgba(242, 244, 248, 0.45);
}

.viona-chat--voice-drawer-open .viona-chat__voice-hints {
  display: none !important;
}

.viona-chat__bar-btn--voice {
  border-color: rgba(46, 184, 199, 0.35);
  background: linear-gradient(165deg, #1a3354 0%, #0e1e38 50%, #0a1428 100%);
}

.viona-chat__bar-btn--voice:hover {
  border-color: rgba(46, 184, 199, 0.5);
}

.viona-chat__bar-btn--voice.viona-chat__bar-btn--on {
  border-color: rgba(46, 184, 199, 0.62);
  background: linear-gradient(165deg, #1f3d62 0%, #122542 100%);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.15),
    0 0 28px rgba(46, 184, 199, 0.12),
    0 6px 24px rgba(0, 0, 0, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.viona-chat__bar-ico {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.92;
}

/* Sesli panel — yalnızca avatar/videolar + altta durum (metin modunda önizleme) */
.viona-voice-drawer {
  flex-shrink: 0;
  border-radius: var(--radius-md);
  border: 1px solid rgba(46, 184, 199, 0.2);
  background:
    linear-gradient(155deg, rgba(20, 34, 58, 0.55) 0%, rgba(8, 12, 22, 0.72) 100%),
    rgba(5, 8, 14, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.055),
    0 10px 32px rgba(0, 0, 0, 0.32);
  padding: 18px 16px 20px;
}

.viona-voice-drawer[hidden] {
  display: none !important;
}

/* Sesli alan içi avatar */
.viona-voice {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  padding: 0;
}

.viona-voice--stack {
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

.viona-voice__hit {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  color: inherit;
  font: inherit;
  line-height: 0;
  transition: transform 0.22s cubic-bezier(0.34, 1.2, 0.64, 1), filter 0.2s ease;
}

/* Dekoratif halka — duruma göre renk / nabız */
.viona-voice__hit::before,
.viona-voice__hit::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  box-sizing: border-box;
  opacity: 0;
  transition: opacity 0.35s ease, border-color 0.3s ease;
}

.viona-voice__hit::before {
  width: calc(100% + 18px);
  height: calc(100% + 18px);
  border: 2px solid rgba(46, 184, 199, 0.28);
}

.viona-voice__hit::after {
  width: calc(100% + 8px);
  height: calc(100% + 8px);
  border: 1px solid rgba(255, 255, 255, 0.14);
  opacity: 0.55;
}

.viona-voice-drawer[data-voice-state="idle"] .viona-voice__hit::before {
  opacity: 0.35;
  border-color: rgba(212, 168, 83, 0.22);
}

.viona-voice-drawer[data-voice-state="listening"] .viona-voice__hit::before {
  opacity: 0.95;
  border-color: rgba(46, 184, 199, 0.55);
  animation: viona-voice-halo-pulse 1.85s ease-in-out infinite;
}

.viona-voice-drawer[data-voice-state="thinking"] .viona-voice__hit::before {
  opacity: 0.75;
  border-color: rgba(212, 168, 83, 0.45);
  animation: viona-voice-halo-soft 2.2s ease-in-out infinite;
}

.viona-voice-drawer[data-voice-state="speaking"] .viona-voice__hit::before {
  opacity: 0.88;
  border-color: rgba(46, 184, 199, 0.5);
  animation: viona-voice-halo-pulse 2.4s ease-in-out infinite;
}

.viona-voice__hit:not(:disabled):hover {
  transform: scale(1.025);
  filter: brightness(1.04);
}

.viona-voice__hit:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 6px;
  border-radius: 50%;
}

.viona-voice__hit:disabled,
.viona-voice__hit--locked {
  cursor: not-allowed;
  opacity: 0.88;
  filter: grayscale(0.08);
}

.viona-voice__hit:disabled::before,
.viona-voice__hit--locked::before,
.viona-voice__hit:disabled::after,
.viona-voice__hit--locked::after {
  animation: none;
  opacity: 0.25;
}

@keyframes viona-voice-halo-pulse {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.65;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.055);
    opacity: 1;
  }
}

@keyframes viona-voice-halo-soft {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.5;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.04);
    opacity: 0.85;
  }
}

@media (prefers-reduced-motion: reduce) {
  .viona-voice__hit::before {
    animation: none !important;
  }

  .viona-voice-drawer[data-voice-state="listening"] .viona-voice__hit::before,
  .viona-voice-drawer[data-voice-state="thinking"] .viona-voice__hit::before,
  .viona-voice-drawer[data-voice-state="speaking"] .viona-voice__hit::before {
    opacity: 0.75;
  }
}

.viona-voice-drawer .viona-voice__stage {
  width: min(176px, 46vw);
  height: min(176px, 46vw);
}

.viona-voice__stage {
  position: relative;
  z-index: 1;
  width: min(200px, 52vw);
  height: min(200px, 52vw);
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background:
    radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.08) 0%, transparent 42%),
    rgba(0, 0, 0, 0.32);
  border: 2px solid rgba(255, 255, 255, 0.14);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.08),
    0 16px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.viona-voice-drawer[data-voice-state="listening"] .viona-voice__stage {
  border-color: rgba(46, 184, 199, 0.35);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.12),
    0 0 32px rgba(46, 184, 199, 0.14),
    0 16px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.viona-voice-drawer[data-voice-state="thinking"] .viona-voice__stage {
  border-color: rgba(212, 168, 83, 0.32);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.1),
    0 0 28px rgba(212, 168, 83, 0.1),
    0 16px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.viona-voice-drawer[data-voice-state="speaking"] .viona-voice__stage {
  border-color: rgba(46, 184, 199, 0.38);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.14),
    0 0 36px rgba(46, 184, 199, 0.16),
    0 16px 48px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.viona-voice__asset {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.viona-voice__asset.hidden {
  display: none;
}

.viona-voice__video {
  pointer-events: none;
  background: #1a1d24;
}

.viona-voice__status {
  margin: 0;
  width: 100%;
  max-width: 300px;
  padding: 11px 20px;
  border-radius: var(--radius-pill);
  font-size: 0.89rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  text-align: center;
  line-height: 1.4;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(0, 0, 0, 0.22) 100%);
  color: rgba(242, 244, 248, 0.9);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 4px 20px rgba(0, 0, 0, 0.2);
  transition:
    border-color 0.28s ease,
    color 0.28s ease,
    box-shadow 0.28s ease;
}

.viona-voice-drawer[data-voice-state="idle"] .viona-voice__status {
  border-color: rgba(212, 168, 83, 0.22);
  color: rgba(242, 244, 248, 0.78);
}

.viona-voice-drawer[data-voice-state="listening"] .viona-voice__status {
  border-color: rgba(46, 184, 199, 0.45);
  color: var(--cyan);
  box-shadow: 0 0 20px rgba(46, 184, 199, 0.12);
}

.viona-voice-drawer[data-voice-state="thinking"] .viona-voice__status {
  border-color: rgba(212, 168, 83, 0.4);
  color: var(--gold);
}

.viona-voice-drawer[data-voice-state="speaking"] .viona-voice__status {
  border-color: rgba(46, 184, 199, 0.5);
  color: rgba(230, 248, 252, 0.95);
  box-shadow: 0 0 24px rgba(46, 184, 199, 0.15);
}

.viona-chat__scroll {
  flex: 1;
  min-height: 180px;
  max-height: min(48vh, 360px);
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 4px 2px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.22);
  scroll-behavior: smooth;
}

.viona-chat__welcome {
  text-align: center;
  padding: 16px 12px 8px;
}

.viona-chat__welcome.hidden {
  display: none;
}

.viona-chat__welcome-ico {
  width: 48px;
  height: 48px;
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.2), rgba(46, 184, 199, 0.12));
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--cyan);
}

.viona-chat__welcome-ico svg {
  width: 28px;
  height: 28px;
}

.viona-chat__welcome-title {
  margin: 0 0 8px;
  font-size: clamp(1.02rem, 3.8vw, 1.14rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.35;
  color: var(--text);
}

.viona-chat__welcome-brand {
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--gold);
  text-shadow: 0 0 24px rgba(212, 168, 83, 0.22);
}

.viona-chat__welcome-lead,
.viona-chat__welcome-hint {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
  color: var(--muted);
}

.viona-chat__welcome-hint {
  margin-top: 10px;
  font-size: 0.82rem;
  opacity: 0.92;
}

.viona-chat__messages {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0 6px 4px;
}

.viona-chat__msg {
  display: flex;
  flex-direction: column;
  max-width: 100%;
}

.viona-chat__msg--user {
  align-items: flex-end;
}

.viona-chat__msg--assistant {
  align-items: flex-start;
}

.viona-chat__bubble {
  max-width: min(100%, 340px);
  padding: 10px 14px;
  border-radius: var(--radius-md);
  font-size: 0.92rem;
  line-height: 1.5;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

.viona-chat__msg--user .viona-chat__bubble {
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.35), rgba(30, 139, 195, 0.22));
  border: 1px solid rgba(46, 184, 199, 0.35);
  color: var(--text);
  border-bottom-right-radius: 6px;
}

.viona-chat__msg--assistant .viona-chat__bubble {
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.09) 0%, rgba(255, 255, 255, 0.04) 100%);
  border: 1px solid rgba(212, 168, 83, 0.18);
  border-left: 3px solid rgba(212, 168, 83, 0.55);
  border-bottom-left-radius: 6px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.viona-chat__msg--error .viona-chat__bubble {
  border-color: rgba(248, 113, 113, 0.45);
  background: rgba(248, 113, 113, 0.1);
}

.viona-chat__options {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
  max-width: min(100%, 340px);
}

/* Sohbet CTA düğmeleri — belirgin; ikon metinle aynı satırda */
.viona-chat__option-btn--cta-guest,
.viona-chat__option-btn--cta-discover,
.viona-chat__option-btn--cta-complaint,
.viona-chat__option-btn--cta-spa,
.viona-chat__option-btn--cta-transfer,
.viona-chat__option-btn--cta-restaurant {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px 8px 10px;
  min-height: 0;
  text-align: left;
  border-radius: var(--radius-md);
  border: 1px solid rgba(212, 168, 83, 0.42);
  background:
    linear-gradient(145deg, rgba(212, 168, 83, 0.18) 0%, rgba(30, 139, 195, 0.14) 48%, rgba(18, 24, 36, 0.65) 100%);
  box-shadow:
    0 10px 32px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 1px 0 rgba(255, 255, 255, 0.1) inset;
  position: relative;
  overflow: hidden;
}

.viona-chat__option-btn--cta-guest::before,
.viona-chat__option-btn--cta-discover::before,
.viona-chat__option-btn--cta-complaint::before,
.viona-chat__option-btn--cta-spa::before,
.viona-chat__option-btn--cta-transfer::before,
.viona-chat__option-btn--cta-restaurant::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255, 255, 255, 0.07) 42%,
    transparent 64%
  );
  opacity: 0.85;
  pointer-events: none;
  animation: vionaCtaSheen 5.5s ease-in-out infinite;
}

@keyframes vionaCtaSheen {
  0%,
  100% {
    transform: translateX(-18%);
    opacity: 0.35;
  }
  50% {
    transform: translateX(18%);
    opacity: 0.65;
  }
}

.viona-chat__option-btn-res-ico {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  line-height: 0;
}

.viona-chat__option-btn-res-ico svg {
  display: block;
  width: 16px;
  height: 16px;
}

.viona-chat__option-btn-res-label {
  flex: 0 1 auto;
  font-weight: 600;
  font-size: 0.8rem;
  line-height: 1.3;
  letter-spacing: 0.01em;
  color: var(--text);
}

.viona-chat__option-btn--cta-guest:hover,
.viona-chat__option-btn--cta-discover:hover,
.viona-chat__option-btn--cta-complaint:hover,
.viona-chat__option-btn--cta-spa:hover,
.viona-chat__option-btn--cta-transfer:hover,
.viona-chat__option-btn--cta-restaurant:hover {
  border-color: rgba(212, 168, 83, 0.62);
  background:
    linear-gradient(145deg, rgba(212, 168, 83, 0.26) 0%, rgba(30, 139, 195, 0.2) 48%, rgba(18, 24, 36, 0.55) 100%);
  box-shadow:
    0 14px 40px rgba(0, 0, 0, 0.42),
    0 0 24px rgba(212, 168, 83, 0.12),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  transform: translateY(-2px);
}

.viona-chat__option-btn--cta-guest:hover .viona-chat__option-btn-res-ico,
.viona-chat__option-btn--cta-discover:hover .viona-chat__option-btn-res-ico,
.viona-chat__option-btn--cta-complaint:hover .viona-chat__option-btn-res-ico,
.viona-chat__option-btn--cta-spa:hover .viona-chat__option-btn-res-ico,
.viona-chat__option-btn--cta-transfer:hover .viona-chat__option-btn-res-ico,
.viona-chat__option-btn--cta-restaurant:hover .viona-chat__option-btn-res-ico {
  color: #e8c878;
}

.viona-chat__option-btn--cta-guest:focus-visible,
.viona-chat__option-btn--cta-discover:focus-visible,
.viona-chat__option-btn--cta-complaint:focus-visible,
.viona-chat__option-btn--cta-spa:focus-visible,
.viona-chat__option-btn--cta-transfer:focus-visible,
.viona-chat__option-btn--cta-restaurant:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-color: rgba(212, 168, 83, 0.75);
}

@media (hover: none) {
  .viona-chat__option-btn--cta-guest:active,
  .viona-chat__option-btn--cta-discover:active,
  .viona-chat__option-btn--cta-complaint:active,
  .viona-chat__option-btn--cta-spa:active,
  .viona-chat__option-btn--cta-transfer:active,
  .viona-chat__option-btn--cta-restaurant:active {
    transform: translateY(0) scale(0.99);
  }
}

@media (prefers-reduced-motion: reduce) {
  .viona-chat__option-btn--cta-guest::before,
  .viona-chat__option-btn--cta-discover::before,
  .viona-chat__option-btn--cta-complaint::before,
  .viona-chat__option-btn--cta-spa::before,
  .viona-chat__option-btn--cta-transfer::before,
  .viona-chat__option-btn--cta-restaurant::before {
    animation: none;
    opacity: 0.4;
  }
}

.viona-chat__option-btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--stroke-chip);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  font: inherit;
  font-size: 0.9rem;
  cursor: pointer;
  transition:
    background 0.16s ease,
    transform 0.08s ease,
    box-shadow 0.16s ease,
    border-color 0.16s ease;
}

.viona-chat__option-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(212, 168, 83, 0.45);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.32);
  transform: translateY(-1px);
}

.viona-chat__option-btn:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-color: rgba(212, 168, 83, 0.7);
}

@media (hover: none) {
  .viona-chat__option-btn:active {
    transform: translateY(1px) scale(0.99);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
  }
}

/* Genel .viona-chat__option-btn üzerine — CTA satır içi kompakt */
.viona-chat__option-btn.viona-chat__option-btn--cta-guest,
.viona-chat__option-btn.viona-chat__option-btn--cta-discover,
.viona-chat__option-btn.viona-chat__option-btn--cta-complaint,
.viona-chat__option-btn.viona-chat__option-btn--cta-spa,
.viona-chat__option-btn.viona-chat__option-btn--cta-transfer,
.viona-chat__option-btn.viona-chat__option-btn--cta-restaurant {
  display: inline-flex;
  width: auto;
  max-width: 100%;
  align-self: flex-start;
}

.viona-chat__err-actions {
  margin-top: 6px;
  padding-left: 2px;
}

.viona-chat__linkbtn {
  font: inherit;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--cyan);
  background: none;
  border: none;
  padding: 4px 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.viona-chat__linkbtn:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: 4px;
}

.viona-chat__typing {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 8px 10px;
  font-size: 0.82rem;
  color: var(--muted);
}

.viona-chat__typing.hidden {
  display: none;
}

.viona-chat__typing-inner {
  display: inline-flex;
  gap: 4px;
  align-items: center;
}

.viona-chat__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  opacity: 0.35;
  animation: vionaChatDot 1.2s ease-in-out infinite;
}

.viona-chat__dot:nth-child(2) {
  animation-delay: 0.15s;
}

.viona-chat__dot:nth-child(3) {
  animation-delay: 0.3s;
}

@keyframes vionaChatDot {
  0%,
  80%,
  100% {
    opacity: 0.25;
    transform: translateY(0);
  }
  40% {
    opacity: 1;
    transform: translateY(-3px);
  }
}

.viona-chat__quick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex-shrink: 0;
}

.viona-chat__chip {
  font: inherit;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text);
  background: rgba(212, 168, 83, 0.12);
  border: 1px solid rgba(212, 168, 83, 0.35);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, transform 0.15s;
}

.viona-chat__chip:hover {
  background: rgba(212, 168, 83, 0.2);
  border-color: rgba(212, 168, 83, 0.55);
}

.viona-chat__chip:active {
  transform: scale(0.98);
}

.viona-chat__chip:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
}

.viona-chat__composer {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-shrink: 0;
  padding-top: 4px;
}

.viona-chat__input {
  flex: 1;
  min-height: 48px;
  max-height: 120px;
  resize: none;
  font: inherit;
  font-size: 0.95rem;
  line-height: 1.45;
  color: var(--text);
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.viona-chat__input::placeholder {
  color: rgba(242, 244, 248, 0.45);
}

.viona-chat__input:focus {
  outline: none;
  border-color: rgba(46, 184, 199, 0.55);
  box-shadow: 0 0 0 3px rgba(46, 184, 199, 0.15);
}

.viona-chat__send {
  flex-shrink: 0;
  min-height: 48px;
  padding-left: 18px;
  padding-right: 18px;
  font-size: 0.92rem;
  font-weight: 600;
}

.viona-chat__fineprint {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.45);
}

@media (min-width: 520px) {
  .viona-chat__scroll {
    max-height: min(52vh, 400px);
  }
}

/* —— Neredeyim — premium konum rehberi (liste) —— */
.where-module--premium {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 10px;
}

/* Kroki: iç içe kaydırma yok; bloklar doğal akış, harita tam genişlik tam yükseklik (sayfa kayar) */
.where-module--premium.where-module--kroki-locked {
  gap: 14px;
  padding-bottom: 12px;
}

.where-module--premium.where-module--kroki-locked .where-kroki-layout {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.where-module--premium.where-module--kroki-locked .where-kroki-controls {
  flex: 0 0 auto;
  overflow: visible;
}

.where-module--premium.where-module--kroki-locked .where-kroki {
  flex: 0 0 auto;
  overflow: visible;
  margin: 0;
  gap: 12px;
}

.where-module--premium.where-module--kroki-locked .where-kroki-detail:not(.where-kroki-detail--hidden) {
  overflow: visible;
  max-height: none;
}

.where-module--premium.where-module--kroki-locked .where-kroki__stage {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

.where-module--premium.where-module--kroki-locked .where-kroki__frame {
  position: relative;
  width: 100%;
  max-width: 100%;
  line-height: 0;
}

.where-module--premium.where-module--kroki-locked .where-kroki__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin: 0;
  vertical-align: top;
  user-select: none;
  -webkit-user-drag: none;
}

.where-kroki-layout {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.where-kroki-controls {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
}

@media (orientation: landscape) {
  .where-module--premium.where-module--kroki-locked .where-kroki-layout {
    flex-direction: row;
    align-items: stretch;
    gap: 14px;
  }

  .where-module--premium.where-module--kroki-locked .where-kroki-controls {
    flex: 0 0 min(46vw, 360px);
    max-height: none;
    overflow: visible;
  }

  .where-module--premium.where-module--kroki-locked .where-kroki {
  display: flex;
  flex-direction: column;
    flex: 1 1 auto;
    min-width: 0;
    max-height: none;
    overflow: visible;
    margin: 0;
  }

  .where-module--premium.where-module--kroki-locked .where-kroki__map-region {
    flex: 0 0 auto;
    display: block;
    overflow: visible;
  }

  .where-module--premium.where-module--kroki-locked .where-kroki__stage {
    flex: 0 0 auto;
    max-width: none;
    width: 100%;
    margin: 0 auto;
  }

  .where-module--premium.where-module--kroki-locked .where-kroki-detail {
    flex: 0 0 auto;
    max-height: none;
    overflow: visible;
  }
}

.where-premium-page-title {
  margin: 0 0 4px;
  font-size: 1.22rem;
  font-weight: 700;
  line-height: 1.28;
  letter-spacing: 0.02em;
  color: rgba(252, 254, 255, 0.98);
  text-wrap: balance;
}

/* Neredeyim — blok özeti kartı (premium hub) */
.where-kroki-block-legend--hub {
  margin: 0 0 14px;
  padding: 16px 18px 17px;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background:
    linear-gradient(145deg, rgba(46, 184, 199, 0.12) 0%, transparent 42%),
    linear-gradient(168deg, rgba(10, 16, 26, 0.94) 0%, rgba(6, 10, 18, 0.98) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 18px 44px rgba(0, 0, 0, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.where-kroki-block-legend__title {
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(212, 168, 83, 0.28);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  line-height: 1.35;
  color: rgba(212, 210, 200, 0.92);
}

.where-kroki-block-legend__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 0 0 12px;
}

.where-kroki-block-legend__para {
  margin: 0;
  font-size: clamp(0.84rem, 2.4vw, 0.93rem);
  font-weight: 500;
  line-height: 1.52;
  letter-spacing: 0.01em;
  color: rgba(236, 242, 250, 0.94);
  text-wrap: balance;
}

/* Kroki özet: satır satır blok — numara eşlemesi */
.where-kroki-block-legend__matrix {
  margin: 0;
}

.where-kroki-legend-matrix__caption {
  margin: 0 0 10px;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  line-height: 1.35;
  color: rgba(120, 210, 218, 0.88);
}

.where-kroki-legend-matrix__grid {
  display: grid;
  gap: 7px;
}

.where-kroki-legend-row {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 34%) minmax(0, 1fr);
  gap: 8px 12px;
  align-items: center;
  margin: 0;
  padding: 10px 12px 10px 15px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(100deg, rgba(46, 184, 199, 0.1) 0%, transparent 55%),
    rgba(0, 0, 0, 0.22);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset;
  overflow: hidden;
}

.where-kroki-legend-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(
    180deg,
    rgba(212, 168, 83, 0.95) 0%,
    rgba(46, 184, 199, 0.55) 100%
  );
  border-radius: 12px 0 0 12px;
}

.where-kroki-legend-row__label {
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.3;
  color: rgba(238, 230, 212, 0.96);
}

.where-kroki-legend-row__values {
  font-size: clamp(0.7rem, 2.05vw, 0.8rem);
  font-weight: 500;
  line-height: 1.42;
  letter-spacing: 0.02em;
  color: rgba(218, 230, 246, 0.9);
  font-variant-numeric: tabular-nums;
  text-wrap: balance;
}

@media (max-width: 380px) {
  .where-kroki-legend-row {
    grid-template-columns: 1fr;
    gap: 5px;
    align-items: start;
  }

  .where-kroki-legend-row__values {
    padding-left: 0;
  }
}

.where-kroki-select-wrap {
  margin: 0 0 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.where-kroki-select-label {
  font-size: clamp(0.8rem, 2.4vw, 0.85rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(200, 210, 224, 0.82);
}

.where-kroki-select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  min-height: 52px;
  padding: 14px 44px 14px 18px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(4, 10, 18, 0.92);
  color: rgba(236, 242, 250, 0.96);
  font-size: clamp(1rem, 3.2vw, 1.06rem);
  font-weight: 600;
  line-height: 1.35;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(46, 184, 199, 0.65) 50%),
    linear-gradient(135deg, rgba(46, 184, 199, 0.65) 50%, transparent 50%);
  background-position: calc(100% - 20px) calc(50% - 3px), calc(100% - 14px) calc(50% - 3px);
  background-size: 7px 7px, 7px 7px;
  background-repeat: no-repeat;
}

.where-kroki-select:focus-visible {
  outline: none;
  border-color: rgba(46, 184, 199, 0.55);
  box-shadow: 0 0 0 3px rgba(46, 184, 199, 0.25);
}

.where-kroki-detail {
  margin: 0 0 12px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: rgba(2, 8, 14, 0.88);
}

.where-kroki-detail--hidden {
  display: none;
}

.where-kroki-detail__title {
  margin: 0 0 10px;
  font-size: clamp(1.02rem, 3vw, 1.12rem);
  font-weight: 700;
  line-height: 1.35;
  color: rgba(248, 250, 252, 0.98);
}

.where-kroki-detail__loc {
  margin: 0;
  font-size: clamp(0.95rem, 2.9vw, 1.02rem);
  font-weight: 500;
  line-height: 1.55;
  color: rgba(46, 200, 210, 0.95);
}

/* Neredeyim — dik kroki + sabit işaretler */
.where-kroki {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin: 0 0 6px;
}

.where-kroki__map-region {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(4, 8, 14, 0.55);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
  width: 100%;
}

/* Kroki modülü: iç kaydırma yok, görsel kesilmesin (genel .where-kroki__map-region overflow:hidden üstüne) */
.where-module--premium.where-module--kroki-locked .where-kroki__map-region {
  display: block;
  width: 100%;
  overflow: visible;
}

/* Eskiden 520px tavandı — mobilde %100 genişlik, geniş ekranda modül genişliğine kadar */
.where-kroki__stage {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

@media (min-width: 720px) {
  .where-kroki__stage {
    max-width: min(100%, 920px);
  }
}

.where-kroki__frame {
  position: relative;
  width: 100%;
  line-height: 0;
}

.where-kroki__img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
  user-select: none;
  -webkit-user-drag: none;
}

.where-kroki__pins {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

/* Pin: yatay kapsül — masaüstü rahat; dar ekranda daha küçük (haritada üst üste binme azalır) */
.where-kroki-pin {
  position: absolute;
  z-index: 4;
  box-sizing: border-box;
  width: auto;
  min-width: 44px;
  height: 40px;
  min-height: 40px;
  padding: 0 12px;
  margin: 0;
  border: 2px solid rgba(255, 255, 255, 0.95);
  border-radius: 999px;
  background: linear-gradient(145deg, #ff2d6a 0%, #d41450 100%);
  color: #fff;
  font-size: clamp(0.82rem, 2.4vw, 0.95rem);
  font-weight: 800;
  line-height: 40px;
  white-space: nowrap;
  cursor: pointer;
  touch-action: manipulation;
  pointer-events: auto;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.35),
    0 4px 14px rgba(0, 0, 0, 0.45);
  transform: translate(-50%, -50%);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    border-color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}

/* Telefon: mümkün olduğunca küçük kapsül (liste ile seçim de var) */
@media (max-width: 767.98px) {
  .where-kroki-pin {
    min-width: 26px;
    height: 22px;
    min-height: 22px;
    padding: 0 3px;
    line-height: 22px;
    border-width: 1px;
    font-size: clamp(0.58rem, 2.2vw, 0.68rem);
    box-shadow:
      0 0 0 1px rgba(0, 0, 0, 0.28),
      0 1px 5px rgba(0, 0, 0, 0.38);
  }

  .where-kroki-pin--selected {
    transform: translate(-50%, -50%) scale(1.02);
    box-shadow:
      0 0 0 1px rgba(0, 0, 0, 0.4),
      0 0 0 2px rgba(255, 200, 80, 0.55),
      0 2px 8px rgba(0, 0, 0, 0.48);
  }
}

/* Tablet / geniş dokunmatik: biraz daha geniş hedef (dar telefona uygulanmaz) */
@media (pointer: coarse) and (min-width: 768px) {
  .where-kroki-pin {
    min-width: 48px;
    min-height: 44px;
    height: 44px;
    line-height: 44px;
    padding: 0 14px;
    font-size: clamp(0.88rem, 2.2vw, 0.98rem);
  }
}

.where-kroki-pin:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px rgba(46, 184, 199, 0.65),
    0 4px 14px rgba(0, 0, 0, 0.45);
  z-index: 8;
}

.where-kroki-pin--selected {
  z-index: 12;
  border-color: rgba(255, 214, 120, 0.98);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.45),
    0 0 0 4px rgba(255, 200, 80, 0.55),
    0 6px 22px rgba(0, 0, 0, 0.55);
  background: linear-gradient(145deg, #ff4a7a 0%, #ff9a3d 100%);
  transform: translate(-50%, -50%) scale(1.08);
}

@media (pointer: coarse) and (min-width: 768px) {
  .where-kroki-pin--selected {
    transform: translate(-50%, -50%) scale(1.06);
  }
}

.where-kroki-table-outer {
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.28);
  overflow: hidden;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.where-kroki-table-title {
  margin: 0;
  padding: 12px 14px 8px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.88);
}

.where-kroki-table {
  width: 100%;
  min-width: 280px;
  border-collapse: collapse;
  font-size: 0.8rem;
}

.where-kroki-table td:nth-child(2) {
  max-width: 46vw;
  word-break: break-word;
  font-weight: 500;
  color: rgba(236, 242, 250, 0.92);
}

.where-kroki-table th,
.where-kroki-table td {
  padding: 8px 10px;
  text-align: left;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  vertical-align: top;
}

.where-kroki-table thead th {
  border-top: none;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(200, 210, 224, 0.85);
  background: rgba(0, 0, 0, 0.25);
}

.where-kroki-table__num {
  width: 2.25rem;
  font-weight: 800;
  color: rgba(255, 77, 122, 0.95);
  white-space: nowrap;
}

.where-kroki-table__mono {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: rgba(232, 240, 248, 0.95);
  white-space: nowrap;
}

@media (max-width: 420px) {
  .where-kroki-table th,
  .where-kroki-table td {
    padding: 7px 8px;
    font-size: 0.74rem;
  }

  /* Dar ekranda da pin küçültme — dokunma alanı korunur */
  .where-kroki-select {
    min-height: 50px;
    padding-top: 13px;
    padding-bottom: 13px;
  }
}

.where-premium-hero-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 0;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 1px 0 0 rgba(212, 168, 83, 0.1);
}

@media (min-width: 640px) {
  .where-premium-hero-row {
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
  }
}

.where-premium-subhead {
  margin: 0 0 14px;
  padding-top: 2px;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.82);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 12px;
  row-gap: 8px;
}

.where-premium-subhead::after {
  content: "";
  flex: 1 1 48px;
  height: 1px;
  background: linear-gradient(90deg, rgba(46, 184, 199, 0.35), transparent);
  min-width: 32px;
}

.where-premium-grid {
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.where-place-card {
  display: flex;
  gap: 15px;
  align-items: flex-start;
  padding: 15px 17px 17px;
  border-radius: 17px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(168deg, rgba(255, 255, 255, 0.045) 0%, rgba(14, 20, 30, 0.68) 55%, rgba(8, 12, 20, 0.76) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.04) inset,
    0 10px 32px rgba(0, 0, 0, 0.2);
  transition: border-color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
}

.where-place-card--hero {
  flex-direction: column;
  align-items: stretch;
  padding: 20px 19px 22px;
  border-color: rgba(212, 168, 83, 0.32);
  background: linear-gradient(
    158deg,
    rgba(212, 168, 83, 0.14) 0%,
    rgba(46, 184, 199, 0.06) 38%,
    rgba(8, 14, 22, 0.8) 52%,
    rgba(10, 18, 28, 0.88) 100%
  );
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.08),
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 16px 44px rgba(0, 0, 0, 0.28);
}

@media (min-width: 640px) {
  .where-place-card--hero {
    min-height: 100%;
  }
}

.where-place-card--standard:hover {
  border-color: rgba(46, 184, 199, 0.32);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 14px 40px rgba(0, 0, 0, 0.26);
  transform: translateY(-1px);
}

.where-place-card__icon-wrap {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(155deg, rgba(46, 184, 199, 0.22) 0%, rgba(46, 184, 199, 0.05) 100%);
  border: 1px solid rgba(46, 184, 199, 0.32);
  color: rgba(186, 240, 248, 0.98);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.1) inset;
}

.where-place-card--hero .where-place-card__icon-wrap {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(155deg, rgba(212, 168, 83, 0.28) 0%, rgba(46, 184, 199, 0.1) 100%);
  border-color: rgba(212, 168, 83, 0.38);
  color: rgba(255, 244, 220, 0.98);
}

.where-place-card__ico {
  width: 26px;
  height: 26px;
  display: block;
}

.where-place-card--hero .where-place-card__ico {
  width: 30px;
  height: 30px;
}

.where-place-card__body {
  flex: 1;
  min-width: 0;
}

.where-place-card--hero .where-place-card__body {
  padding-top: 2px;
}

.where-place-card__title {
  margin: 0 0 12px;
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.32;
  letter-spacing: 0.015em;
  color: rgba(250, 252, 255, 0.98);
  text-wrap: balance;
}

.where-place-card--hero .where-place-card__title {
  font-size: 1.09rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.where-place-card__block {
  margin-bottom: 10px;
}

.where-place-card__block:last-child {
  margin-bottom: 0;
}

.where-place-card__block--desc {
  margin-top: 4px;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.where-place-card__label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.75);
  margin-bottom: 5px;
}

.where-place-card--hero .where-place-card__label {
  color: rgba(232, 210, 160, 0.88);
}

.where-place-card__text {
  margin: 0;
  font-size: 0.865rem;
  line-height: 1.52;
  color: rgba(236, 242, 250, 0.9);
  font-weight: 400;
}

@media (prefers-reduced-motion: reduce) {
  .where-place-card--standard:hover {
    transform: none;
  }
}

/* İçerik modülleri — kart yığını */
.venue-stack {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 10px;
}

.rest-zone {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 14px 20px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  box-shadow: 0 14px 42px rgba(0, 0, 0, 0.2);
}

.rest-zone--dining {
  background: linear-gradient(158deg, rgba(46, 184, 199, 0.09) 0%, rgba(8, 14, 22, 0.52) 40%, rgba(10, 18, 28, 0.78) 100%);
  border-color: rgba(46, 184, 199, 0.24);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.1),
    0 18px 48px rgba(0, 0, 0, 0.22);
}

.rest-zone--bars {
  background: linear-gradient(162deg, rgba(212, 168, 83, 0.11) 0%, rgba(8, 14, 22, 0.52) 42%, rgba(12, 18, 28, 0.78) 100%);
  border-color: rgba(212, 168, 83, 0.26);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.12),
    0 18px 48px rgba(0, 0, 0, 0.24);
}

.rest-zone__title {
  margin: 0 0 2px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  line-height: 1.35;
  text-wrap: balance;
  color: rgba(244, 252, 253, 0.96);
}

.rest-zone--dining .rest-zone__title {
  color: rgba(186, 238, 243, 0.98);
  border-bottom-color: rgba(46, 184, 199, 0.32);
}

.rest-zone--bars .rest-zone__title {
  color: rgba(245, 228, 188, 0.98);
  border-bottom-color: rgba(212, 168, 83, 0.38);
}

.rest-zone--dining .rest-section-title {
  margin-top: 8px;
  margin-bottom: 6px;
  color: rgba(120, 220, 230, 0.95);
}

.rest-zone--dining .venue-card:first-of-type {
  margin-top: 2px;
}

.rest-zone--bars .rest-bar-extras--import-prices {
  margin-top: 2px;
  margin-bottom: 2px;
  border-top-width: 1px;
  border-top-color: rgba(212, 168, 83, 0.35);
  padding-top: 16px;
}

.rest-zone--bars .venue-card {
  border-color: rgba(212, 168, 83, 0.14);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.rest-zone--dining .venue-card {
  border-color: rgba(46, 184, 199, 0.14);
}

.viona-mod--rest .rest-rules {
  margin-top: 2px;
}

.viona-mod--rest .viona-mod-lead {
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(230, 238, 245, 0.88);
  padding: 12px 14px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.06) 0%, rgba(8, 12, 20, 0.35) 100%);
}

.venue-card {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.22);
}

.venue-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.35);
}

.venue-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* A La Carte — La Terrace: iki görsel, ~2 sn otomatik crossfade (4 sn döngü), kontrol yok */
.venue-card__media--crossfade {
  position: relative;
}

.venue-card__media--crossfade img {
  position: absolute;
  inset: 0;
}

@keyframes viona-alacarte-xfade-a {
  0%,
  48% {
    opacity: 1;
  }

  50%,
  100% {
    opacity: 0;
  }
}

@keyframes viona-alacarte-xfade-b {
  0%,
  48% {
    opacity: 0;
  }

  50%,
  100% {
    opacity: 1;
  }
}

.venue-card__media--crossfade img:nth-child(1) {
  animation: viona-alacarte-xfade-a 4s ease-in-out infinite;
}

.venue-card__media--crossfade img:nth-child(2) {
  animation: viona-alacarte-xfade-b 4s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
  .venue-card__media--crossfade img {
    animation: none !important;
  }

  .venue-card__media--crossfade img:nth-child(1) {
    opacity: 1;
  }

  .venue-card__media--crossfade img:nth-child(2) {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }
}

.venue-card__body {
  padding: 14px 16px 16px;
  min-width: 0;
}

.venue-card__title {
  margin: 0 0 4px;
  font-size: 1.05rem;
  font-weight: 600;
  text-wrap: balance;
  overflow-wrap: break-word;
}

.venue-card__sub {
  margin: 0 0 8px;
  font-size: 0.82rem;
  color: rgba(242, 244, 248, 0.65);
}

.venue-card__text {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.88);
}

.rest-section-title {
  margin: 12px 0 8px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.92);
}

.viona-mod > .rest-section-title:first-child {
  margin-top: 4px;
}

.viona-mod-lead + .rest-section-title {
  margin-top: 10px;
}

.viona-mod--rest .venue-card__loc {
  margin: 0 0 10px;
  font-size: 0.82rem;
  line-height: 1.4;
  color: rgba(242, 244, 248, 0.62);
}

.venue-slots {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.venue-slot {
  padding: 12px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.venue-slots .venue-slot:first-child {
  border-top: 0;
  padding-top: 2px;
}

.venue-slot__head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

.venue-slot__name {
  font-weight: 700;
  font-size: 0.92rem;
  color: rgba(242, 244, 248, 0.95);
}

.venue-slot__time {
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(212, 168, 83, 0.95);
  white-space: nowrap;
}

.venue-slot__meta {
  font-size: 0.84rem;
  color: rgba(242, 244, 248, 0.72);
  margin-bottom: 8px;
}

.venue-slot__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.venue-slot__badge {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 8px;
  background: rgba(46, 184, 199, 0.12);
  border: 1px solid rgba(46, 184, 199, 0.28);
  color: rgba(200, 240, 245, 0.95);
}

.venue-slot__detail {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.82);
}

.venue-card__actions {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.venue-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: rgba(241, 251, 253, 0.96);
  border: 1px solid rgba(46, 184, 199, 0.45);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.2) 0%, rgba(46, 184, 199, 0.1) 100%);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.venue-card__cta:hover {
  transform: translateY(-1px);
  border-color: rgba(46, 184, 199, 0.75);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.28);
}

.venue-card__cta:active {
  transform: translateY(0);
}

.venue-card__cta--icon {
  gap: 10px;
}

.venue-card__cta-icon {
  flex-shrink: 0;
  opacity: 0.92;
}

.venue-card__cta-label {
  line-height: 1.25;
  text-align: left;
}

.rest-bar-extras {
  margin: 2px 0 16px;
  padding: 14px 16px 16px;
  border-radius: 16px;
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: linear-gradient(155deg, rgba(46, 184, 199, 0.1) 0%, rgba(8, 14, 24, 0.92) 55%, rgba(12, 18, 28, 0.88) 100%);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.rest-bar-extras--import-prices {
  margin-top: 22px;
  padding-top: 18px;
  border: 1px solid rgba(212, 168, 83, 0.32);
  border-top-width: 2px;
  border-top-color: rgba(212, 168, 83, 0.42);
  background: linear-gradient(165deg, rgba(212, 168, 83, 0.12) 0%, rgba(8, 14, 24, 0.94) 48%, rgba(12, 18, 28, 0.9) 100%);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.26);
}

.rest-bar-extras__block-title {
  margin: 0 0 10px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.35;
  color: rgba(232, 210, 160, 0.95);
}

.rest-bar-extras__intro {
  margin: 0 0 12px;
  font-size: 0.82rem;
  line-height: 1.5;
  color: rgba(220, 232, 240, 0.88);
  letter-spacing: 0.02em;
}

.rest-bar-extras__pdf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  max-width: 100%;
  min-height: 44px;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration: none;
  font-size: 0.87rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: rgba(248, 252, 253, 0.98);
  border: 1px solid rgba(212, 168, 83, 0.42);
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.22) 0%, rgba(46, 184, 199, 0.14) 100%);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.rest-bar-extras__pdf-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(212, 168, 83, 0.65);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.3);
}

.rest-bar-extras__pdf-btn:active {
  transform: translateY(0);
}

.rest-bar-extras__pdf-btn .venue-card__cta-icon {
  opacity: 1;
  color: rgba(255, 248, 230, 0.95);
}

.venue-card--rest .venue-card__media {
  aspect-ratio: 16 / 10;
}

.rest-rules {
  margin-top: 4px;
  padding: 16px 16px 14px;
  border-radius: 16px;
  border: 1px solid rgba(212, 168, 83, 0.22);
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.08) 0%, rgba(12, 18, 28, 0.85) 100%);
}

.rest-rules__title {
  margin: 0 0 12px;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.35;
  color: rgba(248, 246, 238, 0.95);
}

.rest-rules__list {
  margin: 0;
  padding-left: 1.15rem;
  font-size: 0.84rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.82);
}

.rest-rules__list li {
  margin-bottom: 10px;
}

.rest-rules__list li:last-child {
  margin-bottom: 0;
}

.rest-rules__list li::marker {
  color: rgba(212, 168, 83, 0.7);
}

/* Plaj & havuz — can kurtaran uyarısı (öncelikli) */
.beach-lifeguard-alert {
  margin: 0 0 16px;
  padding: 14px 16px 15px 17px;
  border-radius: 14px;
  border: 1px solid rgba(255, 150, 72, 0.42);
  border-left: 4px solid rgba(255, 130, 58, 0.98);
  background:
    linear-gradient(115deg, rgba(255, 140, 60, 0.12) 0%, transparent 48%),
    linear-gradient(168deg, rgba(28, 12, 6, 0.92) 0%, rgba(8, 12, 20, 0.96) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.05) inset,
    0 12px 32px rgba(0, 0, 0, 0.32);
}

.beach-lifeguard-alert__kicker {
  margin: 0 0 8px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.35;
  color: rgba(255, 210, 170, 0.98);
}

.beach-lifeguard-alert__text {
  margin: 0;
  font-size: clamp(0.88rem, 2.6vw, 0.96rem);
  font-weight: 600;
  line-height: 1.52;
  letter-spacing: 0.01em;
  color: rgba(252, 248, 242, 0.96);
  text-wrap: balance;
}

/* Plaj & havuz — restaurant modülü ile uyumlu */
.viona-mod--beach .beach-intro {
  margin-bottom: 14px;
  padding: 16px 16px 14px;
  border-radius: 16px;
  border: 1px solid rgba(30, 139, 195, 0.28);
  background: linear-gradient(155deg, rgba(30, 139, 195, 0.12) 0%, rgba(12, 20, 34, 0.88) 100%);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

.beach-intro__p {
  margin: 0 0 12px;
  font-size: 0.9rem;
  line-height: 1.58;
  color: rgba(242, 244, 248, 0.88);
}

.beach-intro__p:last-child {
  margin-bottom: 0;
}

.beach-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 4px 0 14px;
}

.beach-stat {
  flex: 1 1 calc(33.33% - 8px);
  min-width: 96px;
  padding: 12px 10px;
  text-align: center;
  border-radius: 14px;
  border: 1px solid rgba(46, 184, 199, 0.28);
  background: linear-gradient(180deg, rgba(46, 184, 199, 0.1) 0%, rgba(10, 14, 22, 0.65) 100%);
}

.beach-stat__v {
  display: block;
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: rgba(212, 168, 83, 0.98);
  line-height: 1.2;
}

.beach-stat__k {
  display: block;
  margin-top: 4px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.62);
  line-height: 1.3;
}

.beach-kv {
  display: grid;
  grid-template-columns: minmax(0, 42%) 1fr;
  gap: 8px 12px;
  font-size: 0.84rem;
  margin: 0;
}

.beach-kv dt {
  margin: 0;
  color: rgba(242, 244, 248, 0.48);
  font-weight: 600;
}

.beach-kv dd {
  margin: 0;
  color: rgba(242, 244, 248, 0.9);
  line-height: 1.45;
}

@media (max-width: 380px) {
  .beach-kv {
    grid-template-columns: 1fr;
  }
  .beach-kv dt {
    padding-top: 6px;
  }
  .beach-kv dt:first-child {
    padding-top: 0;
  }
}

.venue-card--beach .venue-card__media {
  aspect-ratio: 16 / 10;
}

.rest-rules.beach-support {
  border-color: rgba(46, 184, 199, 0.28);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.1) 0%, rgba(12, 18, 28, 0.88) 100%);
}

.beach-support__line {
  margin: 0 0 10px;
  font-size: 0.84rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.82);
}

.beach-support__line:last-child {
  margin-bottom: 0;
}

/* Spa & wellness — ayırıcı başlıklar, lavanta tonları */
.viona-mod--spa .spa-intro {
  margin-bottom: 14px;
  padding: 16px 16px 14px;
  border-radius: 16px;
  border: 1px solid rgba(167, 139, 250, 0.28);
  background: linear-gradient(
    155deg,
    rgba(139, 92, 246, 0.1) 0%,
    rgba(30, 27, 75, 0.45) 45%,
    rgba(12, 18, 28, 0.92) 100%
  );
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

.spa-intro__p {
  margin: 0 0 12px;
  font-size: 0.9rem;
  line-height: 1.58;
  color: rgba(242, 244, 248, 0.88);
}

.spa-intro__p:last-child {
  margin-bottom: 0;
}

.rest-section-title--spa {
  margin-top: 8px;
  color: rgba(196, 181, 253, 0.95);
  border-bottom: 1px solid rgba(167, 139, 250, 0.2);
  padding-bottom: 6px;
}

.venue-card--spa .venue-card__media {
  aspect-ratio: 16 / 10;
}

.venue-card--spa-hero {
  border-color: rgba(167, 139, 250, 0.35);
  box-shadow: 0 8px 32px rgba(91, 33, 182, 0.12);
}

/* Ücretli masaj kartı: soğuk turkuaz / lacivert ton (VIP altın-mor ile karışmasın) */
.venue-card--spa-paid {
  border-color: rgba(56, 189, 199, 0.42);
  background: linear-gradient(
    175deg,
    rgba(30, 90, 110, 0.35) 0%,
    rgba(18, 42, 58, 0.55) 42%,
    rgba(0, 0, 0, 0.32) 100%
  );
  box-shadow: 0 8px 26px rgba(46, 184, 199, 0.08);
}

.venue-card--spa-paid .venue-card__loc {
  color: rgba(186, 230, 240, 0.75);
}

.venue-card__text--spa-note {
  margin-top: 10px !important;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.86rem !important;
  color: rgba(242, 244, 248, 0.78) !important;
}

.spa-kv dt {
  color: rgba(216, 201, 255, 0.55);
}

.spa-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 6px;
}

@media (max-width: 480px) {
  .spa-split {
    grid-template-columns: 1fr;
  }
}

.spa-split__col {
  padding: 14px 14px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.spa-split__col--free {
  background: linear-gradient(160deg, rgba(46, 184, 199, 0.1) 0%, rgba(12, 18, 28, 0.85) 100%);
  border-color: rgba(46, 184, 199, 0.28);
}

.spa-split__col--paid {
  background: linear-gradient(160deg, rgba(212, 168, 83, 0.12) 0%, rgba(12, 18, 28, 0.85) 100%);
  border-color: rgba(212, 168, 83, 0.25);
}

.spa-split__title {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.88);
}

.spa-split__list {
  margin: 0;
  padding-left: 1.1rem;
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.82);
}

.spa-split__list li {
  margin-bottom: 6px;
}

.spa-split__list li::marker {
  color: rgba(167, 139, 250, 0.65);
}

.spa-split__col--paid .spa-split__list li::marker {
  color: rgba(212, 168, 83, 0.75);
}

.spa-split--compact .spa-split__col {
  padding: 10px 12px 8px;
}

.spa-split--compact .spa-split__title {
  margin-bottom: 6px;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
}

.spa-split--compact .spa-split__list {
  font-size: 0.78rem;
  line-height: 1.42;
}

.spa-split--compact .spa-split__list li {
  margin-bottom: 3px;
}

/* Spa — PDF şeridi: mor paketlerden ayrı okyanus / derin teal paleti */
.spa-intro + .spa-pdf-strip {
  margin-top: 4px;
}

.spa-pdf-strip {
  margin: 0 0 16px;
  padding: 15px 16px 17px;
  border-radius: 16px;
  border: 1px solid rgba(45, 212, 191, 0.38);
  background: linear-gradient(
    152deg,
    rgba(13, 148, 136, 0.28) 0%,
    rgba(15, 118, 110, 0.2) 38%,
    rgba(8, 47, 52, 0.75) 72%,
    rgba(10, 20, 28, 0.96) 100%
  );
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.spa-pdf-strip__intro {
  margin: 0 0 12px;
  font-size: 0.83rem;
  line-height: 1.52;
  color: rgba(204, 251, 241, 0.94);
  letter-spacing: 0.02em;
}

.spa-pdf-strip__btn {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  min-height: 44px;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration: none;
  font-size: 0.87rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: rgba(6, 28, 32, 0.96);
  border: 1px solid rgba(153, 246, 228, 0.55);
  background: linear-gradient(145deg, rgba(204, 251, 241, 0.98) 0%, rgba(45, 212, 191, 0.88) 48%, rgba(20, 184, 166, 0.92) 100%);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.22);
  transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.spa-pdf-strip__btn:hover {
  transform: translateY(-1px);
  border-color: rgba(236, 253, 245, 0.85);
  box-shadow: 0 10px 26px rgba(45, 212, 191, 0.25);
}

.spa-pdf-strip__btn:active {
  transform: translateY(0);
}

.spa-pdf-strip__icon {
  flex-shrink: 0;
  opacity: 0.92;
  color: rgba(15, 80, 85, 0.92);
}

/* Spa — menü: kategorili accordion (ad · süre · fiyat) */
.spa-menu-accordion {
  margin: 0 0 20px;
}

.spa-menu-accordion__h {
  margin-bottom: 12px;
}

.spa-menu-accordion__fallback {
  margin: 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.2);
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.78);
}

.spa-menu-accordion__cat {
  margin: 0 0 8px;
  border-radius: 14px;
  border: 1px solid rgba(45, 212, 191, 0.22);
  background: linear-gradient(
    165deg,
    rgba(13, 148, 136, 0.12) 0%,
    rgba(8, 47, 52, 0.35) 55%,
    rgba(10, 18, 26, 0.88) 100%
  );
  overflow: hidden;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.2);
}

.spa-menu-accordion__cat:last-child {
  margin-bottom: 0;
}

.spa-menu-accordion__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px 12px 16px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: rgba(204, 251, 241, 0.95);
  cursor: pointer;
  list-style: none;
  transition: background 0.15s ease;
}

.spa-menu-accordion__summary::-webkit-details-marker {
  display: none;
}

.spa-menu-accordion__summary::after {
  content: "";
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(153, 246, 228, 0.75);
  border-bottom: 2px solid rgba(153, 246, 228, 0.75);
  transform: rotate(45deg);
  margin-top: -4px;
  transition: transform 0.2s ease;
}

.spa-menu-accordion__cat[open] .spa-menu-accordion__summary {
  background: rgba(0, 0, 0, 0.18);
}

.spa-menu-accordion__cat[open] .spa-menu-accordion__summary::after {
  transform: rotate(-135deg);
  margin-top: 2px;
}

.spa-menu-accordion__list {
  margin: 0;
  padding: 0 14px 12px 18px;
  list-style: none;
}

.spa-menu-accordion__item {
  position: relative;
  padding: 7px 0 7px 14px;
  font-size: 0.86rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.9);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.spa-menu-accordion__item:last-child {
  border-bottom: 0;
  padding-bottom: 4px;
}

.spa-menu-accordion__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.95em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(45, 212, 191, 0.65);
}

.spa-menu-accordion__item-name {
  display: block;
  font-weight: 600;
}

.spa-menu-accordion__item-dur {
  display: block;
  margin-top: 3px;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: rgba(153, 246, 228, 0.72);
}

.spa-menu-accordion__item-price {
  display: block;
  margin-top: 4px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: rgba(212, 168, 83, 0.95);
}

/* Spa — program paketleri (kart ızgarası) */
.spa-program-section {
  margin: 0 0 28px;
}

.spa-program-section__h {
  margin-bottom: 14px;
}

.spa-program-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

@media (min-width: 640px) {
  .spa-program-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .spa-program-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.spa-program-card {
  border-radius: 16px;
  border: 1px solid rgba(167, 139, 250, 0.24);
  background: linear-gradient(
    168deg,
    rgba(88, 28, 135, 0.16) 0%,
    rgba(49, 27, 88, 0.22) 42%,
    rgba(12, 18, 28, 0.96) 100%
  );
  padding: 16px 16px 14px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.24);
  min-width: 0;
}

.spa-program-card__title {
  margin: 0 0 12px;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  line-height: 1.4;
  color: rgba(245, 240, 255, 0.98);
}

.spa-program-card__list {
  margin: 0;
  padding: 0 0 0 1.05rem;
  font-size: 0.81rem;
  line-height: 1.48;
  color: rgba(242, 244, 248, 0.88);
}

.spa-program-card__li {
  margin-bottom: 6px;
}

.spa-program-card__li::marker {
  color: rgba(196, 181, 253, 0.8);
}

.spa-program-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.84rem;
  font-weight: 700;
}

.spa-program-card__dur {
  color: rgba(204, 251, 241, 0.88);
  letter-spacing: 0.03em;
}

.spa-program-card__dot {
  color: rgba(255, 255, 255, 0.28);
  font-weight: 400;
}

.spa-program-card__price {
  color: rgba(212, 168, 83, 0.98);
  letter-spacing: 0.04em;
}

.spa-packages {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 8px 0 18px;
}

@media (min-width: 640px) {
  .spa-packages {
    grid-template-columns: 1fr 1fr;
  }

  .spa-packages .spa-package-card--vip {
    grid-column: 1 / -1;
  }
}

.spa-package-card {
  padding: 14px 14px 12px;
  border-radius: 14px;
  border: 1px solid rgba(167, 139, 250, 0.24);
  background: linear-gradient(168deg, rgba(139, 92, 246, 0.08) 0%, rgba(12, 18, 28, 0.93) 100%);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
}

/* VIP: derin mor / mücevher tonu — ücretli kartın turkuazından net ayrışır */
.spa-package-card--vip {
  border-color: rgba(167, 139, 250, 0.5);
  background: linear-gradient(
    168deg,
    rgba(88, 28, 135, 0.32) 0%,
    rgba(49, 27, 88, 0.55) 38%,
    rgba(12, 18, 28, 0.95) 100%
  );
  box-shadow: 0 10px 30px rgba(91, 33, 182, 0.18);
}

.spa-package-card--vip .spa-package-card__title {
  color: rgba(245, 240, 255, 0.98);
}

.spa-package-card__headrow {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 8px;
}

.spa-package-card__sparkle {
  flex-shrink: 0;
  margin-top: 2px;
  color: rgba(196, 181, 253, 0.95);
}

.spa-package-card--vip .spa-package-card__sparkle {
  color: rgba(233, 213, 255, 0.98);
}

.spa-package-card__title {
  margin: 0;
  flex: 1;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  line-height: 1.35;
  text-transform: uppercase;
  color: rgba(237, 233, 254, 0.96);
}

.spa-package-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.spa-package-card__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 10px;
  font-size: 0.76rem;
  font-weight: 600;
  color: rgba(224, 231, 255, 0.92);
  border: 1px solid rgba(167, 139, 250, 0.28);
  background: rgba(0, 0, 0, 0.2);
}

.spa-package-card__chip--price {
  border-color: rgba(212, 168, 83, 0.35);
  color: rgba(254, 240, 200, 0.96);
  background: rgba(212, 168, 83, 0.1);
}

.spa-package-card__glyph {
  flex-shrink: 0;
  color: rgba(167, 211, 232, 0.9);
}

.spa-package-card__chip--price .spa-package-card__price-value {
  font-weight: 700;
  letter-spacing: 0.04em;
}

.spa-package-card__bullets {
  margin: 0;
  padding-left: 1.05rem;
  font-size: 0.8rem;
  line-height: 1.48;
  color: rgba(242, 244, 248, 0.86);
}

.spa-package-card__bullets li {
  margin-bottom: 5px;
}

.spa-package-card__bullets li::marker {
  color: rgba(167, 139, 250, 0.55);
}

.spa-package-card--vip .spa-package-card__bullets li::marker {
  color: rgba(196, 181, 253, 0.75);
}

.spa-package-card--vip .spa-package-card__chip--price {
  border-color: rgba(196, 181, 253, 0.45);
  color: rgba(250, 245, 255, 0.98);
  background: rgba(124, 58, 237, 0.2);
}

.rest-section-title--spa-packages {
  margin-top: 18px;
  padding-top: 4px;
}

.rest-section-title--spa-summary {
  margin-top: 10px;
  font-size: 0.92rem;
  opacity: 0.9;
}

/* Ücretli bakım başlığı ile kart arası nefes */
.viona-mod--spa .rest-section-title--spa-paid-lead {
  margin-top: 12px;
  margin-bottom: 4px;
}

.venue-article {
  padding: 16px 18px;
  margin-bottom: 12px;
}

.venue-article__title {
  margin: 0 0 8px;
  font-size: 1rem;
}

.venue-article__body {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.88);
}

/* Talepler formu */
.req-wrap {
  margin-top: 8px;
  min-width: 0;
}

.req-intro {
  margin: 0 0 14px;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.08) 0%, rgba(0, 0, 0, 0.15) 100%);
  font-size: 0.88rem;
  line-height: 1.52;
  color: rgba(242, 244, 248, 0.9);
}

.req-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.req-request-bundle {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.req-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.req-field-hint {
  margin: 0;
  font-size: 0.8rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.55);
}

.req-label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.55);
}

.req-input,
.req-textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border-radius: var(--radius-tight);
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.25);
  color: var(--text);
  padding: 10px 12px;
  font: inherit;
  font-size: 0.95rem;
}

.req-input:focus,
.req-textarea:focus {
  outline: none;
  border-color: rgba(46, 184, 199, 0.62);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.3),
    0 0 0 4px rgba(46, 184, 199, 0.12);
}

.req-input.req-input--locked,
.req-input.req-input--locked:focus {
  cursor: default;
  color: rgba(232, 236, 244, 0.88);
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(6, 12, 20, 0.45);
  box-shadow: none;
  user-select: text;
}

select.req-input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 42px;
  background-color: rgba(8, 14, 24, 0.82);
  border-color: rgba(255, 255, 255, 0.18);
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(212, 168, 83, 0.95) 50%),
    linear-gradient(135deg, rgba(212, 168, 83, 0.95) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    background-color 0.2s ease;
}

select.req-input:hover {
  border-color: rgba(212, 168, 83, 0.45);
  background-color: rgba(10, 18, 30, 0.92);
}

select.req-input:required:invalid {
  color: rgba(242, 244, 248, 0.62);
}

select.req-input option {
  color: var(--text);
  background: var(--surface-select);
}

/* iOS: 16px altında odakta sayfa yakınlaştırmasını önler */
@media (max-width: 540px) {
  .req-input,
  .req-textarea {
    font-size: 1rem;
  }
}

.req-textarea {
  resize: vertical;
  min-height: 96px;
}

.req-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.req-tab {
  flex: 1;
  min-width: 120px;
  padding: 8px 12px;
  border-radius: var(--radius-inner);
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.2);
  color: var(--text);
  font: inherit;
  cursor: pointer;
}

@media (max-width: 480px) {
  .req-tab {
    min-height: 44px;
  }
}

.req-tab--active {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.12);
}

.req-subform {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.req-err {
  margin: 0;
  color: var(--error-text);
  font-size: 0.88rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.req-submit {
  margin-top: 4px;
  align-self: flex-start;
}

.req-success {
  padding: 16px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(46, 184, 199, 0.45);
  background: rgba(46, 184, 199, 0.1);
}

.req-success__title {
  margin: 0 0 8px;
  font-size: 1.05rem;
}

.req-success__body {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.45;
}

.req-form-title {
  margin-bottom: 6px;
}

.req-back-hub {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  padding: 9px 14px;
  border: 1px solid rgba(46, 184, 199, 0.35);
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.14), rgba(12, 18, 30, 0.72));
  color: rgba(230, 248, 250, 0.96);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  text-decoration: none;
  box-shadow:
    0 6px 18px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(46, 184, 199, 0.12) inset;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease,
    box-shadow 0.18s ease;
}

.req-back-hub::before {
  content: "←";
  font-size: 0.95rem;
  line-height: 1;
  color: rgba(46, 184, 199, 0.95);
}

.req-back-hub:hover {
  border-color: rgba(46, 184, 199, 0.6);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.2), rgba(12, 18, 30, 0.84));
  box-shadow:
    var(--shadow-hover),
    0 0 0 1px rgba(46, 184, 199, 0.2) inset;
}

.req-back-hub:focus-visible {
  outline: 2px solid rgba(46, 184, 199, 0.7);
  outline-offset: 2px;
}

.req-hub {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}

.req-hub__card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  width: 100%;
  padding: 16px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.22);
  color: var(--text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  min-height: 56px;
  transition: border-color 0.15s ease, background 0.15s ease;
}

.req-hub__card:hover,
.req-hub__card:focus-visible {
  border-color: rgba(46, 184, 199, 0.45);
  background: rgba(46, 184, 199, 0.08);
  outline: none;
}

.req-hub__icon {
  display: flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-inner);
  background: rgba(46, 184, 199, 0.12);
  color: rgba(46, 184, 199, 0.95);
  flex-shrink: 0;
  margin-top: 2px;
}

.req-hub__body {
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
  min-width: 0;
}

.req-hub__hint {
  display: block;
  font-size: 0.82rem;
  font-weight: 500;
  line-height: 1.42;
  letter-spacing: 0.01em;
  color: rgba(242, 244, 248, 0.66);
  overflow-wrap: break-word;
}

.req-hub__icon svg {
  width: 22px;
  height: 22px;
}

.req-hub__label {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  min-width: 0;
  overflow-wrap: break-word;
}

/* Misafir bildirimleri — gruplu radyo kategorileri */
.req-notif-group {
  margin-bottom: 16px;
}
.req-notif-group:last-child {
  margin-bottom: 0;
}
.req-notif-group__title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.5);
  margin: 0 0 10px;
}
.req-notif-note-hint {
  margin: 0 0 8px;
  font-size: 0.82rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.72);
}

/* Misafir bildirimleri — modül başlığı + geri (hub) */
.req-wrap--guest-notif {
  margin-top: 4px;
}
.req-gn-module-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 12px 18px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(46, 184, 199, 0.18);
}
.req-wrap--guest-notif .req-gn-module-head .req-back-hub {
  margin-bottom: 0;
  flex-shrink: 0;
}
.req-gn-module-head__text {
  flex: 1 1 220px;
  min-width: 0;
}
.req-wrap--guest-notif .req-gn-module-head .req-form-title {
  margin-bottom: 6px;
  font-size: clamp(1.2rem, 4.2vw, 1.45rem);
  letter-spacing: 0.03em;
}
.req-gn-module-head__sub {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.42;
  color: rgba(242, 244, 248, 0.62);
  font-weight: 500;
  letter-spacing: 0.02em;
}

.req-gn-unified {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Geç çıkış — öne çıkan kart */
.req-gn-late-card {
  position: relative;
  margin-bottom: 20px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(46, 184, 199, 0.28);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.11) 0%, rgba(0, 0, 0, 0.34) 52%, rgba(0, 0, 0, 0.22) 100%);
  box-shadow:
    0 14px 36px rgba(0, 0, 0, 0.22),
    0 0 0 1px rgba(46, 184, 199, 0.08) inset;
  overflow: hidden;
}
.req-gn-late-card__accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(46, 184, 199, 0.95), rgba(212, 168, 83, 0.55));
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
}
.req-gn-late-card__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px 18px;
  padding: 18px 18px 18px 22px;
}
.req-gn-late-card__icon {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(46, 184, 199, 0.16);
  color: rgba(46, 184, 199, 0.98);
  box-shadow: 0 0 0 1px rgba(46, 184, 199, 0.2) inset;
}
.req-gn-late-card__icon svg {
  width: 26px;
  height: 26px;
}
.req-gn-late-card__body {
  flex: 1 1 200px;
  min-width: 0;
}
.req-gn-late-card__title {
  margin: 0 0 6px;
  font-size: 1.14rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--text);
}
.req-gn-late-card__lead {
  margin: 0;
  font-size: 0.89rem;
  line-height: 1.48;
  color: rgba(242, 244, 248, 0.78);
}
.req-gn-late-card__cta {
  flex-shrink: 0;
  width: 100%;
  display: flex;
  justify-content: stretch;
}
.req-gn-late-card__cta .req-gn-late-open {
  width: 100%;
  min-height: 46px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
@media (min-width: 540px) {
  .req-gn-late-card__cta {
    width: auto;
    margin-left: auto;
    justify-content: flex-end;
  }
  .req-gn-late-card__cta .req-gn-late-open {
    width: auto;
    min-width: 148px;
    padding-left: 22px;
    padding-right: 22px;
  }
}

.req-gn-late-panel {
  margin: 0 0 22px;
  padding: 16px 16px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: rgba(6, 12, 22, 0.55);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.2);
}
.req-gn-late-panel[hidden] {
  display: none !important;
}
.req-gn-late-panel__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 12px 14px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.req-gn-late-panel__head .req-back-hub {
  margin-bottom: 0;
  flex-shrink: 0;
}
.req-gn-late-panel__head-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1 1 200px;
  min-width: 0;
}
.req-gn-late-panel__title {
  font-size: 1.08rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--text);
}
.req-gn-late-panel__hint {
  font-size: 0.78rem;
  line-height: 1.38;
  color: rgba(242, 244, 248, 0.52);
  font-weight: 500;
}
.req-gn-late-panel__body .req-form--late-checkout {
  margin-top: 0;
}
.req-gn-main-block[hidden] {
  display: none !important;
}
.req-gn-main-card {
  padding-top: 2px;
}
.req-gn-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(46, 184, 199, 0.25), transparent);
  margin: 2px 0 20px;
  border: none;
  opacity: 1;
}
.req-gn-main-heading {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.75);
}
.req-intro--tight {
  margin-top: 0;
  margin-bottom: 14px;
}
.req-wrap--guest-notif .req-gn-main-card .req-intro {
  border-color: rgba(46, 184, 199, 0.18);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.06) 0%, rgba(0, 0, 0, 0.12) 100%);
}
.req-intro--inline {
  margin-top: 0;
  margin-bottom: 12px;
}
.req-form--late-checkout .req-res-section:first-of-type {
  margin-top: 0;
}
.req-input--time {
  min-height: 44px;
  color-scheme: dark;
}

/* Geç çıkış — saat: açılır panel */
.req-time-dropdown {
  position: relative;
  width: 100%;
  max-width: 300px;
}
.req-time-dropdown__trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: var(--radius-tight);
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.28);
  color: var(--text);
  font: inherit;
  font-size: 1.06rem;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-align: left;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease;
}
.req-time-dropdown__trigger:hover,
.req-time-dropdown--open .req-time-dropdown__trigger {
  border-color: rgba(46, 184, 199, 0.52);
  box-shadow: 0 0 0 1px rgba(46, 184, 199, 0.15);
}
.req-time-dropdown__trigger:focus-visible {
  outline: 2px solid rgba(46, 184, 199, 0.65);
  outline-offset: 2px;
}
.req-time-dropdown__chev {
  display: flex;
  flex-shrink: 0;
  color: rgba(46, 184, 199, 0.88);
  transition: transform 0.22s ease;
}
.req-time-dropdown--open .req-time-dropdown__chev {
  transform: rotate(180deg);
}
.req-time-dropdown__panel {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 50;
  padding: 12px 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(46, 184, 199, 0.32);
  background: rgba(10, 16, 26, 0.97);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.5);
  max-height: min(300px, 55vh);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.req-time-dropdown__panel[hidden] {
  display: none !important;
}
.req-time-dropdown__hint {
  margin: 0 0 10px;
  font-size: 0.8rem;
  line-height: 1.42;
  color: rgba(242, 244, 248, 0.64);
}
.req-time-dropdown__columns {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  justify-content: center;
  gap: 8px 10px;
  flex: 1;
  min-height: 0;
}
.req-time-dropdown__block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.req-time-dropdown__caption {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.48);
}
.req-time-dropdown__col {
  max-height: 200px;
  width: 76px;
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: var(--radius-tight);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.35);
  scrollbar-width: thin;
  scrollbar-color: rgba(46, 184, 199, 0.45) transparent;
}
.req-time-dropdown__col::-webkit-scrollbar {
  width: 6px;
}
.req-time-dropdown__col::-webkit-scrollbar-thumb {
  background: rgba(46, 184, 199, 0.4);
  border-radius: 4px;
}
.req-time-dropdown__col-inner {
  display: flex;
  flex-direction: column;
  padding: 6px 4px;
  gap: 2px;
}
.req-time-dropdown__opt {
  display: block;
  width: 100%;
  margin: 0;
  padding: 10px 6px;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--text);
  font: inherit;
  font-size: 1.05rem;
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  transition: background 0.12s ease;
}
.req-time-dropdown__opt:hover,
.req-time-dropdown__opt:focus-visible {
  background: rgba(46, 184, 199, 0.14);
  outline: none;
}
.req-time-dropdown__opt--active {
  background: rgba(46, 184, 199, 0.24);
  box-shadow: inset 0 0 0 1px rgba(46, 184, 199, 0.38);
  font-weight: 700;
}
.req-time-dropdown__colon {
  align-self: center;
  font-size: 1.3rem;
  font-weight: 700;
  color: rgba(242, 244, 248, 0.5);
  padding-top: 1.25rem;
}
.req-field--time-dropdown .req-label {
  margin-bottom: 6px;
}

.req-wrap--guest-notif .req-chip {
  border-color: rgba(255, 255, 255, 0.12);
  transition: border-color 0.15s ease, background 0.15s ease;
}
.req-wrap--guest-notif .req-chip:has(input:checked) {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.12);
}

.req-request-picker-hint {
  margin: 0 0 12px;
  font-size: 0.8rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.64);
}

.req-request-picker {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
}

.req-request-picker__group {
  padding: 14px 14px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.04) 0%, rgba(0, 0, 0, 0.12) 100%);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.req-request-picker__group-title {
  margin: 0 0 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.85);
  user-select: none;
  pointer-events: none;
}

.req-chips--request-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

@media (min-width: 480px) {
  .req-chips--request-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.req-chip--tile {
  min-height: 48px;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  padding: 10px 12px;
  line-height: 1.35;
  border-radius: 12px;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.req-request-picker__group .req-chip--tile:hover {
  border-color: rgba(46, 184, 199, 0.35);
  background: rgba(46, 184, 199, 0.06);
}

.req-request-picker__group .req-chip--tile:has(input:checked) {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.12);
  box-shadow: 0 0 0 1px rgba(46, 184, 199, 0.2);
}

.req-request-details:empty {
  display: none;
}

.req-request-details:not(:empty) {
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.req-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.req-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.2);
  font-size: 0.88rem;
  cursor: pointer;
  user-select: none;
}

.req-chip input {
  width: 18px;
  height: 18px;
  accent-color: rgba(46, 184, 199, 0.9);
}

.req-chip:has(input:checked) {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.1);
}

.req-lost-property-split {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px dashed rgba(255, 255, 255, 0.14);
}
.req-lost-property-hint {
  margin: 0 0 10px;
  font-size: 0.82rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.78);
}
.req-label--sub {
  display: block;
  margin-bottom: 8px;
  font-size: 0.86rem;
  font-weight: 600;
  color: rgba(242, 244, 248, 0.92);
}
.req-chips--lost-property {
  margin-top: 4px;
}
.req-chip--lost-property {
  border-color: rgba(232, 196, 120, 0.45);
  background: rgba(232, 196, 120, 0.08);
}
.req-chip--lost-property:has(input:checked) {
  border-color: rgba(232, 196, 120, 0.75);
  background: rgba(232, 196, 120, 0.16);
}

.req-other-detail.hidden {
  display: none;
}

.req-stay-hint {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.82);
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
}

.req-stay-hint--warn {
  color: #fbbf24;
  background: rgba(251, 191, 36, 0.08);
}

.req-tabs--large {
  margin-bottom: 12px;
}

.req-tabs--large .req-tab {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 52px;
  font-weight: 600;
}

.req-tab__icon {
  display: flex;
  color: rgba(46, 184, 199, 0.9);
}

.req-tab__icon svg {
  width: 20px;
  height: 20px;
}

.req-tab__txt {
  font-size: 0.95rem;
}

/* Talep modülü — öne çıkan blok */
.req-res-prestige {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 4px;
  max-width: 100%;
  overflow-x: hidden;
}

.req-res-lead {
  margin: 0 0 6px;
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.78);
}

.req-res-pick-label {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.45);
}

.req-res-segmented {
  display: flex;
  gap: 0;
  padding: 5px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.28);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  margin-bottom: 18px;
}

.req-res-seg__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 52px;
  padding: 10px 12px;
  border: none;
  border-radius: 12px;
  background: transparent;
  color: rgba(242, 244, 248, 0.65);
  font: inherit;
  font-size: 0.94rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    box-shadow 0.2s ease;
}

.req-res-seg__btn:hover {
  color: rgba(242, 244, 248, 0.92);
  background: rgba(255, 255, 255, 0.04);
}

.req-res-seg__btn:focus-visible {
  outline: 2px solid rgba(46, 184, 199, 0.65);
  outline-offset: 2px;
}

.req-res-seg__btn--active {
  color: #f8fafc;
  background: linear-gradient(165deg, rgba(46, 184, 199, 0.22) 0%, rgba(46, 184, 199, 0.08) 100%);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.45),
    0 8px 24px rgba(0, 0, 0, 0.25);
}

.req-res-seg__ico {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(46, 184, 199, 0.95);
}

.req-res-seg__ico svg {
  width: 22px;
  height: 22px;
}

.req-res-form-mount {
  min-height: 80px;
}

.req-res-active {
  animation: reqPanelIn 0.28s ease both;
}

@keyframes reqPanelIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}

.req-res-section {
  margin-bottom: 14px;
  padding: 16px 16px 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 255, 255, 0.07);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05) 0%, rgba(0, 0, 0, 0.14) 100%);
  box-shadow: var(--shadow-card-soft);
}

.req-res-section__title {
  margin: 0 0 14px;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(242, 244, 248, 0.48);
}

.req-res-section__inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.req-form--res .req-field {
  gap: 8px;
}

.req-form--res .req-input,
.req-form--res .req-textarea {
  padding: 14px 14px;
  border-radius: var(--radius-inner);
  font-size: 1rem;
}

.req-submit--res {
  width: 100%;
  margin-top: 6px;
  padding: 15px 20px;
  border-radius: var(--radius-inner);
  font-size: 1.02rem;
  font-weight: 600;
}

.req-success--res {
  margin-top: 14px;
}

.req-res-rest-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.req-res-info-note {
  margin: 2px 0 0;
  padding: 10px 12px;
  border-radius: var(--radius-tight);
  border: 1px solid rgba(212, 168, 83, 0.26);
  background: rgba(212, 168, 83, 0.08);
  font-size: 0.82rem;
  line-height: 1.45;
  color: rgba(248, 230, 190, 0.95);
}

.req-res-rest-card {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 0;
  padding: 14px 16px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.2);
  cursor: pointer;
  transition:
    border-color 0.18s ease,
    background 0.18s ease,
    box-shadow 0.18s ease;
}

.req-res-rest-card:hover {
  border-color: rgba(46, 184, 199, 0.35);
  background: rgba(46, 184, 199, 0.06);
}

.req-res-rest-card:has(input:checked) {
  border-color: rgba(46, 184, 199, 0.55);
  background: rgba(46, 184, 199, 0.12);
  box-shadow: 0 0 0 1px rgba(46, 184, 199, 0.2);
}

.req-res-rest-card input[type="radio"] {
  margin-top: 3px;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  accent-color: rgba(46, 184, 199, 0.95);
  cursor: pointer;
}

.req-res-rest-card__text {
  flex: 1;
  font-size: 0.96rem;
  font-weight: 600;
  line-height: 1.4;
  color: rgba(242, 244, 248, 0.95);
}

.req-spa-service-mount {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.req-spa-cat-title {
  margin: 4px 0 2px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(45, 212, 191, 0.78);
}

.req-res-rest-grid--spa {
  gap: 8px;
}

.req-res-rest-card--spa-line {
  padding: 11px 14px;
}

.req-res-rest-card--spa-line .req-res-rest-card__text {
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.38;
}

.req-res-cal {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  width: 100%;
}

.req-res-cal__row {
  margin-top: 4px;
  padding: 10px 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(0, 0, 0, 0.18);
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.req-res-cal__picked {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 10px;
  margin-top: 10px;
  font-size: 0.84rem;
  min-width: 0;
}

.req-res-cal__picked-label {
  color: rgba(242, 244, 248, 0.48);
}

.req-res-cal__picked-val {
  font-family: ui-monospace, "Cascadia Code", monospace;
  font-size: 0.9rem;
  font-weight: 600;
  color: rgba(46, 184, 199, 0.98);
  letter-spacing: 0.03em;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.req-res-cal .cal-picker {
  margin-top: 0;
}

.req-res-slot-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(76px, 1fr));
  gap: 8px;
  margin-top: 4px;
}

.req-res-slot {
  min-height: 46px;
  padding: 8px 6px;
  border-radius: 11px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.22);
  color: var(--text);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    color 0.15s ease;
}

.req-res-slot:hover {
  border-color: rgba(46, 184, 199, 0.4);
  background: rgba(46, 184, 199, 0.08);
}

.req-res-slot--active {
  border-color: rgba(46, 184, 199, 0.65);
  background: rgba(46, 184, 199, 0.18);
  color: #f8fafc;
  box-shadow: 0 0 0 1px rgba(46, 184, 199, 0.25);
}

.req-res-slots-empty {
  margin: 0;
  padding: 12px;
  font-size: 0.86rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.55);
  border-radius: 12px;
  border: 1px dashed rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.15);
}

.req-res-stay-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
  width: 100%;
  min-width: 0;
  align-items: start;
}

@media (min-width: 520px) {
  .req-res-stay-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 16px;
    align-items: start;
  }
}

.req-res-stay-grid .req-res-cal {
  min-width: 0;
  max-width: 100%;
}

.req-res-stay-grid .cal-picker {
  width: 100%;
  max-width: none;
}

.req-res-stay-grid .cal-picker__grid {
  width: 100%;
}

.req-res-stay-grid .cal-picker__cell {
  min-width: 0;
  box-sizing: border-box;
}

.req-res-slot-wrap--scroll {
  max-height: min(42vh, 320px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 4px;
  -webkit-overflow-scrolling: touch;
}

.req-res-slot-wrap--scroll::-webkit-scrollbar {
  width: 6px;
}

.req-res-slot-wrap--scroll::-webkit-scrollbar-thumb {
  background: rgba(46, 184, 199, 0.35);
  border-radius: 6px;
}

.req-stay-banner {
  margin-top: 4px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.12);
}

.req-stay-banner--promo {
  border-color: rgba(46, 184, 199, 0.42);
  background: rgba(46, 184, 199, 0.09);
}

.req-stay-banner--paid {
  border-color: rgba(251, 191, 36, 0.28);
  background: rgba(251, 191, 36, 0.07);
}

.req-stay-banner--warn {
  border-color: rgba(248, 113, 113, 0.35);
  background: rgba(248, 113, 113, 0.08);
}

.req-stay-banner__main {
  margin: 0 0 6px;
  font-size: 0.93rem;
  line-height: 1.5;
  font-weight: 600;
  color: rgba(242, 244, 248, 0.95);
}

.req-stay-banner__nights {
  margin: 0;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(242, 244, 248, 0.72);
}

/* Takvim seçici */
.cal-picker {
  margin-top: 6px;
}

.cal-picker__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

.cal-picker__title {
  font-size: 0.9rem;
  font-weight: 600;
}

.cal-picker__nav {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.25);
  color: var(--text);
  cursor: pointer;
  font: inherit;
}

.cal-picker__nav:disabled,
.cal-picker__nav.cal-picker__nav--disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

@media (pointer: coarse) {
  .cal-picker__nav {
    min-width: 44px;
    min-height: 44px;
  }
}

.cal-picker__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.cal-picker__cell {
  aspect-ratio: 1;
  min-height: 36px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: rgba(0, 0, 0, 0.2);
  color: var(--text);
  font: inherit;
  font-size: 0.82rem;
  cursor: pointer;
}

.cal-picker__cell--selected {
  border-color: rgba(46, 184, 199, 0.7);
  background: rgba(46, 184, 199, 0.2);
}

.cal-picker__cell--disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.cal-picker__cell--empty {
  visibility: hidden;
  pointer-events: none;
}

/* —— Modül içerikleri: akordeon & indirim —— */
.viona-mod {
  margin-top: 4px;
  max-width: 100%;
  min-width: 0;
}

.viona-mod-lead {
  margin: 0 0 14px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(46, 184, 199, 0.28);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.12) 0%, rgba(0, 0, 0, 0.2) 100%);
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.9);
}

.viona-mod-lead--tight {
  margin-bottom: 12px;
  padding: 12px 14px;
  font-size: 0.88rem;
  line-height: 1.5;
  letter-spacing: 0.01em;
}

.viona-mod--activities .rest-section-title {
  margin-bottom: 6px;
}

/* Haftalık akşam programı — animasyon modülü */
.activities-evening {
  margin: 0 0 16px;
  padding: 20px 20px 18px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(155deg, rgba(46, 184, 199, 0.14) 0%, transparent 42%),
    linear-gradient(215deg, rgba(212, 175, 88, 0.07) 0%, transparent 48%),
    linear-gradient(210deg, rgba(120, 86, 200, 0.06) 0%, transparent 45%),
    rgba(6, 12, 20, 0.72);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.08) inset,
    0 20px 56px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(46, 184, 199, 0.06);
  min-width: 0;
}

.activities-evening__head {
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.activities-evening__title {
  margin: 0;
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: rgba(248, 246, 238, 0.98);
}

.activities-evening__list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Gün kartı — başlık + alt alta saat / etkinlik */
.activities-evening-day {
  margin: 0;
  padding: 14px 14px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(165deg, rgba(255, 255, 255, 0.045) 0%, transparent 55%),
    rgba(8, 14, 22, 0.55);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.06),
    0 8px 28px rgba(0, 0, 0, 0.22);
  min-width: 0;
}

.activities-evening-day__title {
  margin: 0 0 12px;
  padding: 0 2px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: rgba(245, 238, 224, 0.96);
  position: relative;
}

.activities-evening-day__title::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 44px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(212, 175, 88, 0.95), rgba(46, 184, 199, 0.65));
}

.activities-evening-day__slots {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.activities-evening-slot {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 12px 14px;
  padding: 10px 11px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.035);
  transition: border-color 0.2s ease, background 0.2s ease;
  min-width: 0;
}

.activities-evening-slot:hover {
  border-color: rgba(46, 184, 199, 0.2);
  background: rgba(46, 184, 199, 0.07);
}

.activities-evening-slot__time {
  flex-shrink: 0;
  min-width: 4.25rem;
  padding: 7px 11px;
  border-radius: 10px;
  font-size: 0.78rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.03em;
  text-align: center;
  white-space: nowrap;
  color: rgba(12, 18, 24, 0.94);
  background: linear-gradient(145deg, rgba(230, 200, 120, 0.98), rgba(210, 168, 88, 0.9));
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  line-height: 1.2;
}

.activities-evening-slot__event {
  font-size: 0.86rem;
  line-height: 1.45;
  color: rgba(232, 236, 242, 0.94);
  min-width: 0;
  overflow-wrap: anywhere;
  padding-top: 1px;
}

.activities-evening-slot__event--off-note {
  color: rgba(210, 218, 228, 0.9);
  font-weight: 500;
  font-size: 0.84rem;
  line-height: 1.48;
}

.activities-evening-slot--empty,
.activities-evening-slot--off {
  position: relative;
  padding-left: 13px;
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(255, 255, 255, 0.05);
}

.activities-evening-slot--empty::before,
.activities-evening-slot--off::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 52%;
  border-radius: 0 4px 4px 0;
  opacity: 0.85;
}

.activities-evening-slot--empty::before {
  background: linear-gradient(180deg, rgba(46, 184, 199, 0.55), rgba(46, 184, 199, 0.12));
}

.activities-evening-slot--off::before {
  background: linear-gradient(180deg, rgba(148, 156, 170, 0.45), rgba(148, 156, 170, 0.1));
}

.activities-evening-slot--empty .activities-evening-slot__time,
.activities-evening-slot--off .activities-evening-slot__time {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(218, 224, 232, 0.65);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
  font-weight: 600;
}

.activities-evening-slot__event--silent {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-height: 1.2rem;
  pointer-events: none;
}

.activities-evening-slot__event--silent::after {
  content: "";
  display: block;
  width: min(100%, 72px);
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(46, 184, 199, 0.35) 22%,
    rgba(255, 255, 255, 0.12) 50%,
    rgba(46, 184, 199, 0.25) 78%,
    transparent 100%
  );
  opacity: 0.9;
}

.activities-evening-slot--off .activities-evening-slot__event--silent::after {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(148, 156, 170, 0.35) 30%,
    rgba(255, 255, 255, 0.08) 50%,
    rgba(148, 156, 170, 0.22) 70%,
    transparent 100%
  );
}

@media (prefers-reduced-motion: no-preference) {
  .activities-evening-slot__event--silent::after {
    animation: activities-evening-silent-shimmer 5s ease-in-out infinite;
  }
}

@keyframes activities-evening-silent-shimmer {
  0%,
  100% {
    opacity: 0.55;
    transform: scaleX(0.92);
  }
  50% {
    opacity: 1;
    transform: scaleX(1);
  }
}

@media (max-width: 520px) {
  .activities-evening {
    padding: 16px 14px 14px;
    border-radius: 18px;
  }

  .activities-evening__head {
    margin-bottom: 10px;
    padding-bottom: 10px;
  }

  .activities-evening__title {
    font-size: 0.92rem;
    line-height: 1.35;
  }

  .activities-evening__list {
    gap: 12px;
  }

  .activities-evening-day {
    padding: 13px 12px 11px;
    border-radius: 14px;
  }

  .activities-evening-day__title {
    font-size: 0.88rem;
    margin-bottom: 10px;
    padding-bottom: 9px;
  }

  .activities-evening-day__slots {
    gap: 9px;
  }

  .activities-evening-slot {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 11px 11px;
  }

  .activities-evening-slot__time {
    justify-self: start;
    min-width: unset;
    padding: 8px 14px;
    font-size: 0.8rem;
  }

  .activities-evening-slot__event {
    font-size: 0.82rem;
    padding-top: 0;
  }

  .activities-evening-slot__event--off-note {
    font-size: 0.8rem;
  }
}

@media (max-width: 360px) {
  .activities-evening {
    padding: 14px 12px 12px;
  }

  .activities-evening-slot__event {
    font-size: 0.8rem;
  }
}

.activities-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 760px) {
  .activities-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .activities-cards .venue-card:last-child {
    grid-column: 1 / -1;
  }
}

.activities-legacy {
  margin-top: 14px;
  display: grid;
  gap: 12px;
}

.activities-legacy__stack {
  display: grid;
  gap: 12px;
}

.activities-legacy-card {
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(145deg, rgba(18, 29, 45, 0.88) 0%, rgba(10, 17, 28, 0.94) 100%);
  padding: 13px;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
}

.activities-legacy-card--highlight {
  border-color: rgba(46, 184, 199, 0.4);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.16) 0%, rgba(10, 17, 28, 0.95) 85%);
  padding: 14px;
}

.activities-legacy-card__kicker {
  margin: 0 0 7px;
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
  color: rgba(171, 239, 246, 0.95);
}

.activities-legacy-card__title {
  margin: 0 0 8px;
  font-size: 0.94rem;
  font-weight: 700;
  color: rgba(242, 244, 248, 0.95);
}

.activities-legacy-card__text {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.5;
  color: rgba(242, 244, 248, 0.84);
}

.activities-legacy-card__gallery {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.activities-showcase {
  margin-top: 12px;
  display: block;
}

.activities-showcase__viewport {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.28);
  background: rgba(0, 0, 0, 0.3);
}

.activities-showcase__track {
  display: flex;
  transition: transform 0.35s ease;
  will-change: transform;
}

.activities-showcase__slide {
  min-width: 100%;
  margin: 0;
  aspect-ratio: 16 / 9;
}

.activities-showcase__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.activities-legacy-card__figure {
  margin: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(0, 0, 0, 0.25);
}

.activities-legacy-card__figure img {
  width: 100%;
  height: 100%;
  max-height: 180px;
  object-fit: cover;
  display: block;
}

@media (min-width: 760px) {
  .activities-legacy-card--highlight .activities-legacy-card__gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Toplantı — özet + görseller + metin */
.viona-mod--meeting .meet-summary {
  margin: 0 0 16px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.22);
}

.meet-summary__line {
  margin: 0 0 10px;
  font-size: 0.86rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.86);
}

.meet-summary__line:last-child {
  margin-bottom: 0;
}

.meet-prose {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.meet-prose__h {
  margin: 18px 0 8px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: rgba(46, 184, 199, 0.95);
}

.meet-prose__h:first-child {
  margin-top: 0;
}

.meet-prose__p {
  margin: 0 0 12px;
  font-size: 0.88rem;
  line-height: 1.58;
  color: rgba(242, 244, 248, 0.85);
}

.meet-prose__p:last-child {
  margin-bottom: 0;
}

.meet-figure {
  margin: 0 0 14px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--stroke);
  background: rgba(0, 0, 0, 0.25);
  aspect-ratio: 16 / 10;
}

.meet-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.meet-business {
  margin-top: 20px;
  padding-top: 4px;
}

.meet-business .meet-figure {
  margin-bottom: 10px;
}

.meet-business__cap {
  margin: 0;
  font-size: 0.84rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.78);
}

/* Mini Club — giriş + kartlar */
.viona-mod--miniclub .miniclub-intro {
  margin-bottom: 14px;
  padding: 16px 16px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255, 150, 150, 0.22);
  background: linear-gradient(
    155deg,
    rgba(255, 130, 150, 0.11) 0%,
    rgba(46, 184, 199, 0.09) 42%,
    rgba(12, 18, 30, 0.92) 100%
  );
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
}

.miniclub-intro__p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.58;
  color: rgba(242, 244, 248, 0.9);
}

/* A La Carte — premium giriş + indirim rozeti */
.viona-mod--alacarte .alacarte-intro {
  margin-bottom: 16px;
  padding: 16px 18px 15px;
  border-radius: 16px;
  border: 1px solid rgba(212, 168, 83, 0.32);
  background: linear-gradient(
    145deg,
    rgba(212, 168, 83, 0.1) 0%,
    rgba(46, 184, 199, 0.06) 38%,
    rgba(12, 18, 28, 0.94) 100%
  );
  box-shadow: 0 10px 36px rgba(0, 0, 0, 0.22);
}

.alacarte-intro__p {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.58;
  color: rgba(248, 246, 238, 0.92);
}

.viona-mod--alacarte .alacarte-card {
  border-color: rgba(212, 168, 83, 0.18);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}

/* Sinton BBQ — menü indir */
.alacarte-menu-cta {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.alacarte-menu-cta__btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 13px 16px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  color: rgba(12, 10, 8, 0.94);
  background: linear-gradient(
    135deg,
    rgba(255, 248, 235, 0.99) 0%,
    rgba(212, 168, 83, 0.55) 42%,
    rgba(180, 130, 60, 0.75) 100%
  );
  border: 1px solid rgba(255, 255, 255, 0.38);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.2),
    0 8px 26px rgba(0, 0, 0, 0.28);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}

@media (hover: hover) {
  .alacarte-menu-cta__btn:hover {
    transform: translateY(-2px);
    box-shadow:
      0 0 0 1px rgba(212, 168, 83, 0.35),
      0 12px 32px rgba(0, 0, 0, 0.32);
  }
}

.alacarte-menu-cta__btn:active {
  transform: translateY(0);
}

.alacarte-menu-cta__btn:focus-visible {
  outline: 2px solid rgba(212, 168, 83, 0.9);
  outline-offset: 3px;
}

.alacarte-menu-cta__ico {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.92;
}

.alacarte-menu-cta__ico svg {
  width: 22px;
  height: 22px;
}

.alacarte-menu-cta__label {
  flex: 1;
  min-width: 0;
  text-align: left;
}

/* La Terrace — çift PDF (TR arayüz: TR PDF; diğer diller: EN PDF) */
.alacarte-terrace-pdfs {
  margin-top: 20px;
  padding-top: 2px;
}

.alacarte-terrace-pdfs__panel {
  padding: 16px 16px 17px;
  border-radius: 16px;
  border: 1px solid rgba(130, 220, 228, 0.35);
  background: linear-gradient(
    155deg,
    rgba(255, 255, 255, 0.07) 0%,
    rgba(46, 184, 199, 0.12) 40%,
    rgba(8, 28, 36, 0.55) 100%
  );
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 12px 40px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.alacarte-terrace-pdfs__title {
  margin: 0 0 14px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(210, 248, 252, 0.9);
}

.alacarte-terrace-pdfs__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 420px) {
  .alacarte-terrace-pdfs__grid {
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }
}

.alacarte-terrace-pdfs__btn {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  box-sizing: border-box;
  min-height: 48px;
  padding: 13px 15px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.84rem;
  letter-spacing: 0.018em;
  color: rgba(6, 26, 34, 0.96);
  background: linear-gradient(
    160deg,
    rgba(240, 254, 255, 0.99) 0%,
    rgba(120, 216, 220, 0.5) 42%,
    rgba(18, 132, 148, 0.82) 100%
  );
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow:
    0 0 0 1px rgba(72, 196, 204, 0.25),
    0 10px 28px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.35);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  -webkit-tap-highlight-color: transparent;
}

@media (hover: hover) {
  .alacarte-terrace-pdfs__btn:hover {
    transform: translateY(-2px);
    box-shadow:
      0 0 0 1px rgba(72, 196, 204, 0.45),
      0 16px 40px rgba(0, 0, 0, 0.3),
      inset 0 1px 0 rgba(255, 255, 255, 0.45);
  }
}

.alacarte-terrace-pdfs__btn:active {
  transform: translateY(0);
}

.alacarte-terrace-pdfs__btn:focus-visible {
  outline: 2px solid rgba(164, 240, 245, 0.98);
  outline-offset: 3px;
}

.alacarte-terrace-pdfs__ico {
  flex-shrink: 0;
  width: 21px;
  height: 21px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.92;
}

.alacarte-terrace-pdfs__ico svg {
  width: 21px;
  height: 21px;
}

.alacarte-terrace-pdfs__label {
  flex: 1;
  min-width: 0;
  text-align: left;
  line-height: 1.35;
}

.venue-slot__badge--accent {
  background: rgba(212, 168, 83, 0.14);
  border-color: rgba(212, 168, 83, 0.38);
  color: rgba(248, 230, 190, 0.98);
}

.viona-acc {
  margin-bottom: 10px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.08) 0%, rgba(0, 0, 0, 0.2) 55%);
  overflow: hidden;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.viona-acc[open] {
  border-color: rgba(46, 184, 199, 0.35);
}

.viona-acc summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
  user-select: none;
}

.viona-acc summary::-webkit-details-marker {
  display: none;
}

.viona-acc summary::after {
  content: "";
  margin-left: auto;
  width: 10px;
  height: 10px;
  border-right: 2px solid rgba(46, 184, 199, 0.8);
  border-bottom: 2px solid rgba(46, 184, 199, 0.8);
  transform: rotate(45deg);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.viona-mod--general .viona-acc summary::after {
  transition: none;
}

.viona-acc[open] summary::after {
  transform: rotate(-135deg);
}

.viona-acc__title {
  flex: 1;
  min-width: 0;
  text-align: left;
  line-height: 1.35;
}

.viona-acc__icon {
  display: flex;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(46, 184, 199, 0.15);
  color: rgba(46, 184, 199, 0.95);
  flex-shrink: 0;
}

.viona-acc__icon svg {
  width: 20px;
  height: 20px;
}

.viona-acc__body {
  padding: 0 16px 16px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.88);
}

.viona-acc__body p {
  margin: 0 0 10px;
}

.viona-acc__body p:last-child {
  margin-bottom: 0;
}

.viona-kv {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 12px;
  font-size: 0.86rem;
  margin-top: 8px;
}

.viona-kv dt {
  color: rgba(242, 244, 248, 0.5);
  font-weight: 600;
}

.viona-kv dd {
  margin: 0;
}

@media (max-width: 380px) {
  .viona-kv {
    grid-template-columns: 1fr;
  }
  .viona-kv dt {
    padding-top: 6px;
  }
  .viona-kv dt:first-of-type {
    padding-top: 0;
  }
}

.viona-list {
  margin: 0 0 10px;
  padding-left: 1.15rem;
  list-style: disc;
  color: rgba(242, 244, 248, 0.88);
}

.viona-list:last-child {
  margin-bottom: 0;
}

.viona-list li {
  margin-bottom: 6px;
  padding-left: 2px;
}

.viona-list li::marker {
  color: rgba(46, 184, 199, 0.65);
}

.viona-mod--general .viona-acc {
  margin-bottom: 11px;
}

.viona-mod--general .viona-acc__body {
  padding-top: 2px;
}

.discount-hero {
  position: relative;
  padding: 18px 18px 20px;
  margin-bottom: 16px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(212, 168, 83, 0.35);
  background: linear-gradient(125deg, rgba(212, 168, 83, 0.18) 0%, rgba(46, 184, 199, 0.12) 45%, rgba(5, 12, 22, 0.85) 100%);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

.discount-hero--premium {
  padding: 20px 20px 22px;
  border-width: 1px;
  box-shadow:
    0 12px 48px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(212, 168, 83, 0.12) inset;
}

.discount-hero__kicker {
  position: relative;
  margin: 0 0 8px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(212, 168, 83, 0.98);
}

.discount-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 100% 0%, rgba(46, 184, 199, 0.25), transparent 55%);
  pointer-events: none;
}

.discount-hero__title {
  position: relative;
  margin: 0 0 6px;
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.discount-hero__lead {
  position: relative;
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.45;
  color: rgba(242, 244, 248, 0.82);
}

.discount-grid {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.discount-card {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.28);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.discount-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.35);
}

.discount-card__media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.4);
}

.discount-carousel {
  position: absolute;
  inset: 0;
}

.discount-carousel-track {
  position: absolute;
  inset: 0;
}

.discount-carousel-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.45, 0, 0.2, 1);
  pointer-events: none;
}

.discount-carousel-slide--active {
  opacity: 1;
}

.discount-carousel-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.discount-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 4;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: #0a1018;
  background: linear-gradient(135deg, #f4d58d 0%, #d4a853 50%, #b8862f 100%);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
}

.discount-card__body {
  position: relative;
  padding: 16px 16px 18px;
}

.discount-card__title {
  margin: 0 0 8px;
  font-size: 1.08rem;
  font-weight: 700;
}

.discount-card__highlight {
  margin: 0 0 10px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.4;
  color: rgba(46, 224, 208, 0.98);
  background: rgba(46, 184, 199, 0.12);
  border: 1px solid rgba(46, 184, 199, 0.28);
}

.discount-card__text {
  margin: 0 0 12px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.88);
}

.discount-card__text:last-child {
  margin-bottom: 0;
}

/* ----- Transfer fiyat listesi (modül) ----- */
.transfer-mod {
  max-width: 42rem;
  margin: 0 auto;
}

.transfer-mod__hero {
  text-align: center;
  margin-bottom: 1.25rem;
}

.transfer-mod__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.15rem, 4vw, 1.45rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(245, 247, 250, 0.98);
  line-height: 1.25;
}

.transfer-mod__subtitle {
  margin: 0;
  font-size: clamp(0.82rem, 2.6vw, 0.92rem);
  font-weight: 500;
  color: rgba(126, 231, 246, 0.92);
  letter-spacing: 0.02em;
  line-height: 1.45;
}

.transfer-mod__pdf-ico {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 1.35rem;
  height: 1.35rem;
  opacity: 0.95;
}

.transfer-mod__pdf-svg {
  width: 100%;
  height: 100%;
}

.btn-transfer-pdf {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  width: 100%;
  max-width: 22rem;
  margin: 0 auto 1.35rem;
  padding: 0.75rem 1.1rem;
  border-radius: var(--radius-tight);
  border: 1px solid rgba(46, 184, 199, 0.45);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.22), rgba(12, 18, 30, 0.95));
  color: rgba(245, 247, 250, 0.96);
  font: inherit;
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

.btn-transfer-pdf:hover {
  border-color: rgba(126, 231, 246, 0.65);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
}

.btn-transfer-pdf:active {
  transform: scale(0.99);
}

.transfer-mod__tablewrap {
  border-radius: 12px;
  border: 1px solid rgba(46, 184, 199, 0.28);
  overflow: auto;
  margin-bottom: 1.5rem;
  background: rgba(8, 12, 22, 0.65);
  -webkit-overflow-scrolling: touch;
}

.transfer-mod__table {
  width: 100%;
  min-width: 17rem;
  border-collapse: collapse;
  font-size: clamp(0.78rem, 2.4vw, 0.88rem);
}

.transfer-mod__table thead th {
  padding: 0.72rem 0.65rem;
  text-align: left;
  font-weight: 700;
  color: rgba(10, 14, 22, 0.95);
  background: linear-gradient(180deg, rgba(72, 210, 224, 0.95), rgba(46, 184, 199, 0.88));
  border-bottom: 1px solid rgba(10, 20, 32, 0.2);
  white-space: nowrap;
}

.transfer-mod__table thead th:first-child {
  border-radius: 11px 0 0 0;
}

.transfer-mod__table thead th:nth-child(4) {
  border-radius: 0 11px 0 0;
}

.transfer-mod__th-num {
  text-align: center;
}

.transfer-mod__table tbody td {
  padding: 0.68rem 0.65rem;
  color: rgba(245, 247, 250, 0.94);
  border-bottom: 1px solid rgba(46, 184, 199, 0.12);
  vertical-align: middle;
  line-height: 1.4;
}

.transfer-mod__table tbody tr:last-child td {
  border-bottom: none;
}

.transfer-mod__table tbody tr:nth-child(even) td {
  background: rgba(255, 255, 255, 0.02);
}

.transfer-mod__cell-price {
  text-align: center;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  color: rgba(126, 231, 246, 0.98);
}

.transfer-mod__section-title {
  margin: 1.35rem 0 0.65rem;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(72, 210, 224, 0.98);
}

.transfer-mod__section-title:first-of-type {
  margin-top: 0.25rem;
}

.transfer-mod__list {
  margin: 0 0 0.5rem;
  padding-left: 1.2rem;
  color: rgba(235, 238, 245, 0.9);
  font-size: 0.88rem;
  line-height: 1.55;
}

.transfer-mod__list--vehicles {
  list-style: disc;
}

/* ----- Oda servisi (modül) — menü: sade yüzey, net hiyerarşi, az süs ----- */
.room-service-mod {
  max-width: 44rem;
  margin: 0 auto;
}

.room-service-mod__inner {
  padding: 1.25rem 1.1rem 1.35rem;
  text-align: start;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(10, 14, 22, 0.92);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

.room-service-mod__banner {
  margin: 0 0 1.15rem;
  padding: 0.9rem 1rem 0.95rem;
  border-radius: 12px;
  border: 1px solid rgba(212, 168, 83, 0.32);
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.1) 0%, rgba(46, 184, 199, 0.07) 55%, rgba(8, 12, 20, 0.55) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 4px 20px rgba(0, 0, 0, 0.12);
}

.room-service-mod__banner-kicker {
  display: block;
  margin: 0 0 0.5rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(212, 168, 83, 0.96);
}

.room-service-mod__banner-line {
  margin: 0 0 0.45rem;
  padding: 0;
  font-size: 0.8rem;
  font-weight: 400;
  line-height: 1.55;
  color: rgba(228, 234, 242, 0.91);
  text-wrap: balance;
}

.room-service-mod__banner-line:last-child {
  margin-bottom: 0;
}

.room-service-mod__header {
  text-align: center;
  margin: 0 0 1.25rem;
  padding: 0 0 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.room-service-mod__brand {
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(212, 168, 83, 0.9);
  margin: 0 0 0.4rem;
}

.room-service-mod__menu-title {
  margin: 0;
  font-family: Georgia, "Times New Roman", ui-serif, serif;
  font-size: clamp(1.1rem, 3.6vw, 1.42rem);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(252, 252, 255, 0.98);
  line-height: 1.25;
  text-wrap: balance;
}

.room-service-mod__section-title {
  margin: 1.5rem 0 0.75rem;
  padding: 0 0 0.35rem;
  border-bottom: 1px solid rgba(46, 184, 199, 0.35);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(72, 210, 224, 0.95);
  line-height: 1.35;
}

.room-service-mod__section-title:first-of-type {
  margin-top: 0.25rem;
}

.room-service-mod__dish {
  margin: 0;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.room-service-mod__dish:last-of-type {
  border-bottom: none;
  padding-bottom: 0.25rem;
}

.room-service-mod__dish-head {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.room-service-mod__ref {
  flex-shrink: 0;
  min-width: 1.4rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: rgba(212, 168, 83, 0.92);
}

.room-service-mod__name {
  flex: 1 1 11rem;
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: rgba(248, 250, 255, 0.98);
  line-height: 1.4;
}

.room-service-mod__price {
  flex-shrink: 0;
  margin-left: auto;
  min-width: 4.25rem;
  text-align: end;
  font-size: 0.84rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: rgba(212, 168, 83, 0.96);
  white-space: nowrap;
}

.room-service-mod__desc {
  margin: 0.35rem 0 0;
  padding: 0;
  max-width: none;
  font-size: 0.8rem;
  font-weight: 400;
  line-height: 1.55;
  color: rgba(210, 218, 228, 0.82);
}

.room-service-mod__desc--sub {
  margin-top: 0.2rem;
  font-size: 0.76rem;
  color: rgba(190, 200, 212, 0.78);
}

.room-service-mod__opts {
  margin: 0.4rem 0 0;
  padding-left: 1.1rem;
  font-size: 0.8rem;
  line-height: 1.55;
  color: rgba(224, 230, 238, 0.88);
}

.room-service-mod__opts li {
  margin: 0.1rem 0;
}

.room-service-mod__opts li::marker {
  color: rgba(255, 255, 255, 0.35);
}

.room-service-mod__subs {
  margin-top: 0.55rem;
  padding: 0.25rem 0 0 0.85rem;
  border-left: 1px solid rgba(46, 184, 199, 0.28);
}

.room-service-mod__sub {
  margin-bottom: 0.65rem;
}

.room-service-mod__sub:last-child {
  margin-bottom: 0;
}

.room-service-mod__sub-head {
  display: flex;
  align-items: baseline;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.room-service-mod__sub-name {
  flex: 1 1 9rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: rgba(242, 246, 252, 0.94);
}

.room-service-mod__note {
  margin: 0.5rem 0 0.75rem;
  padding: 0.45rem 0 0.45rem 0.65rem;
  font-size: 0.78rem;
  font-style: italic;
  line-height: 1.5;
  color: rgba(180, 192, 204, 0.88);
  border-left: 2px solid rgba(255, 255, 255, 0.12);
}

.room-service-mod__foot {
  margin-top: 1.35rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.room-service-mod__foot-line {
  margin: 0 0 0.4rem;
  font-size: 0.78rem;
  line-height: 1.5;
  font-weight: 400;
  color: rgba(218, 224, 232, 0.88);
  text-wrap: balance;
}

.room-service-mod__foot-line:last-child {
  margin-bottom: 0;
}

.room-service-mod__foot-line--order {
  font-weight: 600;
  color: rgba(248, 250, 252, 0.96);
  margin-top: 0.15rem;
}

.room-service-mod__foot-line--brand {
  margin-top: 0.85rem;
  padding-top: 0.65rem;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-align: center;
  color: rgba(212, 168, 83, 0.88);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

@media print {
  .btn-back,
  .btn-transfer-pdf {
    display: none !important;
  }

  .transfer-mod__tablewrap {
    border-color: #333;
  }

  .transfer-mod__table thead th {
    background: #2a9aa8 !important;
    color: #0a0e14 !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .room-service-mod__inner {
    box-shadow: none !important;
    border-color: #444 !important;
  }
}

.venue-card--lift {
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.venue-card--lift:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.3);
}

@media (prefers-reduced-motion: reduce) {
  .req-res-active {
    animation: none;
  }
  .carousel-slide {
    transition: none;
  }
  .activities-carousel-slide {
    transition: none;
  }
  .discount-carousel-slide {
    transition: none;
  }
  .lang-bg {
    animation: none;
  }
  .lang-content {
    animation: none;
  }
  .rate-section,
  .rate-link {
    animation: none;
  }
  .rate-link:hover {
    transform: none;
  }
  .action-tile::after {
    display: none;
  }
}

/* Sürdürülebilirlik — broşür akışı; görseller tam genişlik, kesintisiz sıra (web + mobil) */
.viona-mod--sustainability .sustainability-intro {
  margin-bottom: 18px;
}

.sustainability-doc {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(6, 10, 16, 0.65);
  box-shadow:
    0 0 0 1px rgba(45, 212, 191, 0.08),
    0 20px 50px rgba(0, 0, 0, 0.45);
  max-width: 100%;
}

.sustain-slide--link {
  display: block;
  margin: 0;
  padding: 0;
  line-height: 0;
  text-decoration: none;
  color: inherit;
  outline: none;
  -webkit-tap-highlight-color: rgba(45, 212, 191, 0.15);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  transition: opacity 0.2s ease, filter 0.2s ease;
}

.sustain-slide--link:last-child {
  border-bottom: none;
}

@media (hover: hover) {
  .sustain-slide--link:hover {
    filter: brightness(1.04);
  }
}

.sustain-slide--link:active {
  opacity: 0.92;
}

.sustain-slide--link:focus-visible {
  box-shadow: inset 0 0 0 3px rgba(45, 212, 191, 0.55);
  z-index: 1;
  position: relative;
}

.sustain-slide__media {
  margin: 0;
  line-height: 0;
  background: rgba(0, 0, 0, 0.25);
}

.sustain-slide__media img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  vertical-align: middle;
  user-select: none;
  pointer-events: none;
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* Yakında Ne Var? */
.viona-mod--coming-soon .coming-soon-card {
  margin-top: 8px;
  padding: 28px 22px 26px;
  text-align: center;
  border-radius: 18px;
  border: 1px solid rgba(147, 197, 253, 0.22);
  background: linear-gradient(
    155deg,
    rgba(96, 165, 250, 0.1) 0%,
    rgba(46, 184, 199, 0.07) 50%,
    rgba(12, 18, 28, 0.94) 100%
  );
  box-shadow: 0 14px 44px rgba(0, 0, 0, 0.26);
}

.coming-soon-card__ico {
  margin: 0 auto 16px;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(147, 197, 253, 0.95);
  opacity: 0.95;
}

.coming-soon-card__ico svg {
  width: 44px;
  height: 44px;
}

.coming-soon-card__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(242, 244, 248, 0.88);
  max-width: 26rem;
  margin-left: auto;
  margin-right: auto;
}

/* Çevrede Keşfet — kategori → liste + harita */
.viona-mod--near-explore {
  margin-top: 0;
}

.viona-mod--near-explore .near-explore-shell--home {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.viona-mod--near-explore .near-explore-lead {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(242, 244, 248, 0.88);
}

.viona-mod--near-explore .near-explore-tagline {
  margin: 0;
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.85);
  font-weight: 600;
}

.near-explore-mapwrap {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.28);
  background: rgba(0, 0, 0, 0.25);
}

.near-explore-mapwrap--home {
  height: min(42vw, 180px);
  min-height: 140px;
}

.near-explore-mapwrap--category {
  height: min(48vw, 240px);
  min-height: 200px;
}

.near-explore-map {
  width: 100%;
  height: 100%;
  min-height: inherit;
  line-height: 0;
}

.near-explore-gmaps-frame {
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  border: 0;
  border-radius: inherit;
  background: rgba(10, 14, 22, 0.85);
}

.near-explore-map-fallback {
  margin: 0;
  padding: 16px 14px;
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(200, 208, 220, 0.92);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: inherit;
  box-sizing: border-box;
}

.near-explore-empty {
  margin: 0 0 8px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1px dashed rgba(255, 255, 255, 0.14);
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(220, 224, 232, 0.88);
  background: rgba(0, 0, 0, 0.18);
}

.module-inner .near-explore-config-error {
  margin-top: 8px;
}

.near-explore-cats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

@media (min-width: 420px) {
  .near-explore-cats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.near-explore-cat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  min-height: 72px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(155deg, rgba(18, 24, 36, 0.95) 0%, rgba(8, 12, 20, 0.92) 100%);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
  color: rgba(248, 246, 238, 0.96);
  font: inherit;
  font-weight: 600;
  font-size: 0.88rem;
  text-align: left;
  cursor: pointer;
  transition:
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.15s;
}

.near-explore-cat:active {
  transform: scale(0.99);
}

.near-explore-cat:hover,
.near-explore-cat:focus-visible {
  border-color: rgba(46, 184, 199, 0.45);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.2),
    0 12px 32px rgba(0, 0, 0, 0.28);
  outline: none;
}

.near-explore-cat__ico {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: rgba(46, 184, 199, 0.12);
  font-size: 1.15rem;
  line-height: 1;
}

.near-explore-cat[data-category="market"] .near-explore-cat__ico::before {
  content: "🛒";
}
.near-explore-cat[data-category="pharmacy"] .near-explore-cat__ico::before {
  content: "💊";
}
.near-explore-cat[data-category="atm"] .near-explore-cat__ico::before {
  content: "🏧";
}
.near-explore-cat[data-category="beach"] .near-explore-cat__ico::before {
  content: "🏖";
}
.near-explore-cat[data-category="sight"] .near-explore-cat__ico::before {
  content: "🗺";
}
.near-explore-cat[data-category="food"] .near-explore-cat__ico::before {
  content: "🍽";
}
/* Semt pazarı / bazaar — altın vurgu (Market süpermarketten ayrı sekme) */
.near-explore-cat[data-category="bazaar"] .near-explore-cat__ico {
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.28) 0%, rgba(120, 90, 40, 0.14) 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 232, 196, 0.12);
}
.near-explore-cat[data-category="bazaar"] .near-explore-cat__ico::before {
  content: "🧺";
}
.near-explore-cat[data-category="bazaar"]:hover,
.near-explore-cat[data-category="bazaar"]:focus-visible {
  border-color: rgba(212, 168, 83, 0.55);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.22),
    0 12px 36px rgba(0, 0, 0, 0.32);
}

.near-explore-cat__label {
  line-height: 1.25;
}

.near-explore-shell--category {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
}

.near-explore-cat-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

.near-explore-back {
  min-height: 44px;
  padding: 0 14px;
  border-radius: var(--radius-pill, 999px);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(248, 246, 238, 0.92);
  font: inherit;
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.near-explore-back:hover,
.near-explore-back:focus-visible {
  background: rgba(46, 184, 199, 0.15);
  border-color: rgba(46, 184, 199, 0.35);
  outline: none;
}

.near-explore-cat-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: rgba(252, 254, 255, 0.98);
}

.near-explore-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  min-height: 120px;
  max-height: min(52vh, 520px);
  overflow-y: auto;
  padding-bottom: 8px;
  -webkit-overflow-scrolling: touch;
}

.near-explore-card {
  margin: 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: rgba(0, 0, 0, 0.22);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  transition:
    border-color 0.2s,
    box-shadow 0.2s,
    transform 0.12s;
  text-align: left;
}

.near-explore-card:hover,
.near-explore-card:focus-visible {
  border-color: rgba(46, 184, 199, 0.35);
  outline: none;
}

.near-explore-card--active {
  border-color: rgba(212, 168, 83, 0.55);
  box-shadow:
    0 0 0 1px rgba(212, 168, 83, 0.25),
    0 12px 32px rgba(0, 0, 0, 0.28);
}

.near-explore-card--featured {
  border-color: rgba(46, 184, 199, 0.28);
  background: linear-gradient(135deg, rgba(46, 184, 199, 0.1) 0%, rgba(0, 0, 0, 0.22) 100%);
}

.near-explore-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.near-explore-card__title {
  margin: 0;
  font-size: 0.98rem;
  font-weight: 700;
  color: rgba(252, 254, 255, 0.98);
  line-height: 1.3;
}

.near-explore-card__badge {
  flex-shrink: 0;
  padding: 4px 8px;
  border-radius: 8px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.95);
  background: rgba(46, 184, 199, 0.12);
}

.near-explore-card__desc {
  margin: 0 0 8px;
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(220, 224, 232, 0.88);
}

.near-explore-card__addr {
  margin: 0 0 10px;
  font-size: 0.8rem;
  line-height: 1.45;
  color: rgba(180, 188, 200, 0.88);
}

.near-explore-card__schedule {
  margin: -4px 0 10px;
  font-size: 0.74rem;
  line-height: 1.4;
  font-style: italic;
  color: rgba(160, 168, 182, 0.82);
}

.near-explore-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(212, 168, 83, 0.95);
}

.near-explore-detail {
  position: fixed;
  inset: 0;
  z-index: 12000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: max(12px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right))
    max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
  background: rgba(4, 8, 14, 0.55);
  backdrop-filter: blur(6px);
}

.near-explore-detail.hidden {
  display: none;
}

.near-explore-detail__panel {
  position: relative;
  width: 100%;
  max-width: 520px;
  max-height: min(78vh, 640px);
  overflow-y: auto;
  margin: 0;
  padding: 20px 18px 22px;
  border-radius: 20px 20px 18px 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.45);
}

.near-explore-detail__title {
  margin: 0 0 6px;
  padding-right: 36px;
  font-size: 1.08rem;
  font-weight: 700;
  color: rgba(252, 254, 255, 0.98);
}

.near-explore-detail__cat {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(46, 184, 199, 0.9);
}

.near-explore-detail__desc {
  margin: 0 0 10px;
  font-size: 0.9rem;
  line-height: 1.55;
  color: rgba(232, 236, 242, 0.9);
}

.near-explore-detail__addr {
  margin: 0 0 12px;
  font-size: 0.84rem;
  line-height: 1.5;
  color: rgba(180, 188, 200, 0.9);
}

.near-explore-detail__schedule {
  margin: -6px 0 12px;
  font-size: 0.78rem;
  line-height: 1.45;
  font-style: italic;
  color: rgba(160, 168, 182, 0.88);
}

.near-explore-detail__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 12px;
  font-size: 0.82rem;
  font-weight: 600;
  color: rgba(212, 168, 83, 0.95);
}

.near-explore-detail__route {
  margin: 0 0 14px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(46, 184, 199, 0.22);
  background: rgba(46, 184, 199, 0.08);
  font-size: 0.84rem;
  font-weight: 600;
  line-height: 1.45;
  color: rgba(232, 244, 248, 0.95);
  word-break: break-word;
}

.near-explore-detail__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.near-explore-detail__no-dir {
  margin: 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(0, 0, 0, 0.2);
  font-size: 0.86rem;
  line-height: 1.5;
  color: rgba(200, 208, 220, 0.9);
  text-align: center;
}

.near-explore-detail__btn {
  width: 100%;
  justify-content: center;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
}

.near-explore-btn--ghost.near-explore-detail__btn {
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(248, 246, 238, 0.95);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.near-explore-btn--ghost.near-explore-detail__btn:hover,
.near-explore-btn--ghost.near-explore-detail__btn:focus-visible {
  border-color: rgba(46, 184, 199, 0.4);
  background: rgba(46, 184, 199, 0.12);
  outline: none;
}

.near-explore-detail__close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(0, 0, 0, 0.35);
  color: rgba(248, 246, 238, 0.95);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.near-explore-detail__close:hover,
.near-explore-detail__close:focus-visible {
  background: rgba(46, 184, 199, 0.2);
  outline: none;
}

.near-explore-marker--hotel .near-explore-marker__dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 3px solid rgba(212, 168, 83, 0.95);
  background: rgba(18, 24, 36, 0.95);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
}

.near-explore-marker--place .near-explore-marker__pin {
  width: 14px;
  height: 14px;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  background: linear-gradient(145deg, rgba(46, 184, 199, 0.95), rgba(30, 120, 140, 0.98));
  border: 2px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.35);
}

.near-explore-marker--place.is-active .near-explore-marker__pin {
  background: linear-gradient(145deg, rgba(212, 168, 83, 0.98), rgba(160, 120, 50, 0.98));
  transform: rotate(-45deg) scale(1.15);
}

/* Alanya — keşif rehberi kartı (premium) */
.viona-mod--alanya .alanya-guide-card--premium {
  position: relative;
  margin-bottom: 22px;
  padding: 0;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background:
    radial-gradient(120% 80% at 100% 0%, rgba(46, 184, 199, 0.18) 0%, transparent 55%),
    radial-gradient(90% 60% at 0% 100%, rgba(212, 168, 83, 0.14) 0%, transparent 50%),
    linear-gradient(165deg, rgba(18, 24, 36, 0.97) 0%, rgba(8, 12, 20, 0.99) 100%);
  box-shadow:
    0 0 0 1px rgba(46, 184, 199, 0.12),
    0 18px 48px rgba(0, 0, 0, 0.35);
}

.alanya-guide-card__deco {
  position: absolute;
  top: 12px;
  right: 14px;
  width: 56px;
  height: 56px;
  color: rgba(45, 212, 191, 0.35);
  pointer-events: none;
}

.alanya-guide-card__mark {
  width: 100%;
  height: 100%;
  display: block;
}

.alanya-guide-card__inner {
  position: relative;
  padding: 22px 20px 20px;
  padding-right: 4.25rem;
}

@media (min-width: 420px) {
  .alanya-guide-card__inner {
    padding: 26px 24px 22px;
    padding-right: 5rem;
  }
}

.alanya-guide-card__eyebrow {
  display: block;
  margin: 0 0 10px;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(45, 212, 191, 0.88);
}

.alanya-guide-card__title {
  margin: 0 0 12px;
  font-size: clamp(1.2rem, 4.2vw, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: rgba(252, 252, 253, 0.98);
}

.alanya-guide-card__lead {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.62;
  color: rgba(203, 213, 225, 0.9);
  max-width: 36rem;
}

.alanya-guide-card__cta {
  margin-top: 20px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 14px 18px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  color: rgba(10, 14, 20, 0.95);
  background: linear-gradient(135deg, rgba(224, 251, 243, 0.98) 0%, rgba(45, 212, 191, 0.92) 48%, rgba(20, 184, 166, 0.9) 100%);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.28);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}

@media (hover: hover) {
  .alanya-guide-card__cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.32);
  }
}

.alanya-guide-card__cta:active {
  transform: translateY(0);
}

.alanya-guide-card__cta:focus-visible {
  outline: 2px solid rgba(45, 212, 191, 0.85);
  outline-offset: 3px;
}

.alanya-guide-card__cta-ico {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.alanya-guide-card__cta-ico svg {
  width: 22px;
  height: 22px;
}

.alanya-guide-card__cta-label {
  flex: 1;
  min-width: 0;
  text-align: left;
}

.alanya-guide-card__cta-chev {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  opacity: 0.65;
  display: flex;
  align-items: center;
  justify-content: center;
}

.alanya-guide-card__cta-chev svg {
  width: 18px;
  height: 18px;
}
