/* ═══════════════════════════════════════════
   CSS CUSTOM PROPERTIES — Variable Font
═══════════════════════════════════════════ */
@property --fw {
  syntax: '<number>';
  initial-value: 700;
  inherits: true;
}

/* ═══════════════════════════════════════════
   LANGUAGE DROPDOWN
═══════════════════════════════════════════ */
.lang-dropdown {
  position: relative;
  z-index: 30;
}

.lang-drop-trigger {
  display: flex;
  align-items: center;
  gap: 4px;
  background: rgba(255,255,255,0.70);
  border: 1px solid rgba(22,57,66,0.08);
  border-radius: 20px;
  padding: 6px 10px 6px 8px;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s;
  user-select: none;
  box-shadow: 0 8px 24px rgba(31,55,61,0.08);
}

.lang-drop-trigger:active { background: rgba(255,255,255,0.90); }

.flag-icon {
  display: inline-block;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  box-shadow: inset 0 0 0 1px rgba(15, 37, 44, 0.08);
}

.flag-icon--gb {
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2060%2040'%3E%3Crect%20width='60'%20height='40'%20fill='%23012169'/%3E%3Cpath%20d='M0%200l60%2040M60%200L0%2040'%20stroke='%23fff'%20stroke-width='10'/%3E%3Cpath%20d='M0%200l60%2040M60%200L0%2040'%20stroke='%23C8102E'%20stroke-width='6'/%3E%3Cpath%20d='M30%200v40M0%2020h60'%20stroke='%23fff'%20stroke-width='16'/%3E%3Cpath%20d='M30%200v40M0%2020h60'%20stroke='%23C8102E'%20stroke-width='10'/%3E%3C/svg%3E");
}

.flag-icon--tr {
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2060%2040'%3E%3Crect%20width='60'%20height='40'%20fill='%23E30A17'/%3E%3Ccircle%20cx='24'%20cy='20'%20r='10'%20fill='%23fff'/%3E%3Ccircle%20cx='27'%20cy='20'%20r='8'%20fill='%23E30A17'/%3E%3Cpath%20d='M35%2020l8.09-2.63-5%206.88v-8.5l5%206.88z'%20fill='%23fff'/%3E%3C/svg%3E");
}

.flag-icon--ru {
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2060%2040'%3E%3Crect%20width='60'%20height='40'%20fill='%23fff'/%3E%3Crect%20y='13.33'%20width='60'%20height='13.34'%20fill='%230039A6'/%3E%3Crect%20y='26.67'%20width='60'%20height='13.33'%20fill='%23D52B1E'/%3E%3C/svg%3E");
}

.lang-drop-flag {
  width: 17px;
  height: 12px;
  border-radius: 3px;
  flex-shrink: 0;
}

.lang-drop-code {
  font-size: 11px;
  font-weight: 600;
  color: #1b434c;
  letter-spacing: 0.5px;
  min-width: 18px;
}

.lang-drop-chevron {
  color: #888;
  transition: transform 0.2s ease;
  margin-left: 1px;
}

.lang-dropdown.open .lang-drop-chevron {
  transform: rotate(180deg);
}

.lang-drop-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 152px;
  background: #FFFFFF;
  border-radius: 16px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.14);
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px) scale(0.97);
  transform-origin: top right;
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 50;
}

.lang-dropdown.open .lang-drop-menu {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: all;
}

.lang-drop-opt {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 14px;
  font-size: 13px;
  font-weight: 500;
  color: #1A1A1A;
  border: none;
  background: transparent;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: background 0.1s;
}

.lang-drop-opt:hover  { background: #F8F8FA; }
.lang-drop-opt:active { background: #F2F2F6; }
.lang-drop-opt:not(:last-child) { border-bottom: 1px solid rgba(0, 0, 0, 0.05); }
.lang-drop-opt.active { background: #F5F2FD; }

.opt-flag  {
  width: 17px;
  height: 12px;
  border-radius: 3px;
  flex-shrink: 0;
}
.opt-name  { flex: 1; }
.opt-check { opacity: 0; transition: opacity 0.15s; flex-shrink: 0; }
.lang-drop-opt.active .opt-check { opacity: 1; }

/* ═══════════════════════════════════════════
   CARD BASE
═══════════════════════════════════════════ */
.card {
  border-radius: 20px;
  cursor: pointer;
  display: block;
  position: relative;
  overflow: hidden;
  /* Variable font weight inherited by children via --fw */
  --fw: 700;
  transition:
    transform 0.12s ease,
    opacity   0.12s ease,
    --fw      0.38s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Noise / grain texture overlay */
.card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  opacity: 0.045;
  mix-blend-mode: overlay;
  pointer-events: none;
}

.card:hover { --fw: 900; }
.card:active {
  transform: scale(0.975);
  opacity: 0.88;
  --fw: 820;
}

/* Card color variants */
.card-orange { background: #FF8040; }

/* ═══════════════════════════════════════════
   HERO CARD  (Card 1 — full width, tall)
═══════════════════════════════════════════ */
.card-hero {
  padding: 16px 18px 18px;
}

.card-hero-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 8px;
}

.card-desc {
  font-size: 13px;
  font-weight: 400;
  color: rgba(0, 0, 0, 0.45);
  line-height: 1.45;
  margin-top: 2px;
  margin-bottom: 14px;
}

.card-desc-light {
  color: rgba(255, 255, 255, 0.65);
}

/* ═══════════════════════════════════════════
   SMALL GRID CARDS  (Cards 2 & 3)
═══════════════════════════════════════════ */
.card-sm {
  padding: 14px 14px 16px;
  display: flex;
  flex-direction: column;
  min-height: 162px;
}

.card-sm-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1.5px solid rgba(0, 0, 0, 0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
  flex-shrink: 0;
}

/* light icon border for dark cards */
.card-sm-icon-light {
  border-color: rgba(255, 255, 255, 0.35);
}

.card-title-sm {
  font-size: 17px;
  font-weight: 700;
  font-variation-settings: 'wght' var(--fw);
  line-height: 1.2;
  letter-spacing: -0.2px;
  margin-bottom: 6px;
  margin-top: 2px;
}

.card-desc-sm {
  font-size: 11px;
  font-weight: 400;
  color: rgba(0, 0, 0, 0.4);
  line-height: 1.5;
  margin-top: auto;
}

.card-desc-sm-light {
  color: rgba(255, 255, 255, 0.55);
}

/* ═══════════════════════════════════════════
   WIDE CARD  (Card 4 — horizontal)
═══════════════════════════════════════════ */
.card-wide {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px;
  gap: 10px;
}

.card-wide-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.card-wide-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 255, 255, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.card-wide-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* Red discount pill inside wide card */
.discount-home-pill {
  background: rgba(255, 255, 255, 0.25);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 11px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: 0.2px;
}

/* ═══════════════════════════════════════════
   SHARED TEXT HELPERS
═══════════════════════════════════════════ */
.card-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1.5px;
  margin-bottom: 2px;
}

.label-dark  { color: rgba(0, 0, 0, 0.4); }
.label-light { color: rgba(255, 255, 255, 0.55); }

.card-title {
  font-size: 22px;
  font-weight: 700;
  font-variation-settings: 'wght' var(--fw);
  line-height: 1.15;
  letter-spacing: -0.3px;
  margin-bottom: 4px;
}

.title-dark  { color: #1A1A1A; }
.title-light { color: #FFFFFF; }

/* ═══════════════════════════════════════════
   PILLS
═══════════════════════════════════════════ */
.pills-row {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  align-items: center;
}

.pill {
  display: inline-block;
  padding: 5px 11px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}

.pill-dark  { border: 1.5px solid rgba(0,0,0,0.22);   color: rgba(0,0,0,0.6);     background: transparent; }
.pill-light { border: 1.5px solid rgba(255,255,255,0.4); color: rgba(255,255,255,0.9); background: transparent; }

/* ═══════════════════════════════════════════
   ARROW BUTTONS
═══════════════════════════════════════════ */
.arrow-btn {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.1s ease;
  flex-shrink: 0;
}

.arrow-btn:active { transform: scale(0.9); }

.arrow-dark  { background: #1A1A1A; }
.arrow-light { background: rgba(255, 255, 255, 0.25); }

/* ═══════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════ */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.anim-1 { animation: slideUp 0.4s ease 0.05s both; }
.anim-2 { animation: slideUp 0.4s ease 0.12s both; }
.anim-3 { animation: slideUp 0.4s ease 0.20s both; }
.anim-4 { animation: slideUp 0.4s ease 0.28s both; }

.cards-grid .card:nth-child(1) { animation: slideUp 0.4s ease 0.12s both; }
.cards-grid .card:nth-child(2) { animation: slideUp 0.4s ease 0.17s both; }

@media (prefers-reduced-motion: reduce) {
  .anim-1, .anim-2, .anim-3, .anim-4,
  .cards-grid .card { animation: none; }
}

/* ═══════════════════════════════════════════
   SUB-PAGE: CTA BUTTONS (contact)
═══════════════════════════════════════════ */
.cta-btn {
  width: 100%;
  padding: 16px 20px;
  border-radius: 16px;
  font-size: 15px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  border: none;
  transition: transform 0.12s ease, opacity 0.12s ease;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.cta-btn:active { transform: scale(0.975); opacity: 0.88; }

.cta-whatsapp { background: #25D366; color: #fff; }
.cta-phone    { background: #1A1A1A; color: #fff; }
.cta-sms      { background: #F5F5F5; color: #1A1A1A; border: 1px solid rgba(0,0,0,0.08); }

.cta-stack { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }

.contact-hero {
  background: linear-gradient(140deg, #0F172A 0%, #213A8F 48%, #FF7C45 100%);
  border-radius: 24px;
  padding: 20px 18px;
  margin-bottom: 14px;
  position: relative;
  overflow: hidden;
}

.contact-hero::after {
  content: '';
  position: absolute;
  right: -28px;
  top: -40px;
  width: 142px;
  height: 142px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.11);
}

.contact-hero-badge {
  position: relative;
  z-index: 1;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.9px;
  color: rgba(255, 255, 255, 0.62);
  margin-bottom: 8px;
}

.contact-hero-title {
  position: relative;
  z-index: 1;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -0.8px;
  color: #FFFFFF;
  font-weight: 800;
  max-width: 240px;
}

.contact-hero-sub {
  position: relative;
  z-index: 1;
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  max-width: 300px;
}

.contact-meta-row {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.contact-meta-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.15);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.2px;
}

.contact-form {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 24px;
  padding: 18px 16px 16px;
  box-shadow: 0 16px 36px rgba(12, 20, 42, 0.05);
}

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

.contact-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contact-field-full {
  grid-column: 1 / -1;
}

.contact-label-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.contact-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.4px;
  color: #8A93A5;
  text-transform: uppercase;
}

.contact-optional {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 20px;
  padding: 0 8px;
  border-radius: 999px;
  background: #F1F3F8;
  color: #98A2B3;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.contact-input {
  width: 100%;
  min-height: 48px;
  padding: 14px 15px;
  border-radius: 16px;
  background: #F6F7FB;
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 500;
  color: #1A1A1A;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.contact-input::placeholder {
  color: #B7BFCD;
}

.contact-input:focus {
  background: #FFFFFF;
  border-color: rgba(61, 82, 196, 0.38);
  box-shadow: 0 0 0 4px rgba(61, 82, 196, 0.08);
}

.contact-field.is-error .contact-input {
  background: #FFF6F3;
  border-color: rgba(232, 78, 56, 0.35);
  box-shadow: 0 0 0 4px rgba(232, 78, 56, 0.08);
}

.contact-form .section-label {
  margin-top: 18px;
}

.contact-form .message-box {
  margin-bottom: 0;
  padding: 0;
  background: #F6F7FB;
  border-color: transparent;
  overflow: hidden;
}

.contact-form .message-box textarea {
  min-height: 132px;
  padding: 15px;
}

.contact-help {
  margin-top: 12px;
  font-size: 12px;
  line-height: 1.55;
  color: #8B94A4;
}

.contact-status {
  min-height: 18px;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.4;
  color: #7C8595;
}

.contact-status.is-success {
  color: #237A52;
}

.contact-status.is-error {
  color: #C45141;
}

.send-btn.is-loading {
  opacity: 0.9;
  pointer-events: none;
}

/* ═══════════════════════════════════════════
   SUB-PAGE: SECTION LABEL
═══════════════════════════════════════════ */
.section-label {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1.5px;
  color: #AAAAAA;
  margin-bottom: 10px;
  margin-top: 20px;
}

/* ═══════════════════════════════════════════
   SUB-PAGE: MESSAGE BOX & SEND
═══════════════════════════════════════════ */
.message-box {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  padding: 14px 16px;
  margin-bottom: 10px;
}

.message-box textarea {
  width: 100%;
  min-height: 110px;
  font-size: 14px;
  color: #1A1A1A;
  background: transparent;
  caret-color: #3D52C4;
}

.message-box textarea::placeholder { color: #BBBBBB; }
.message-box.is-error {
  border-color: rgba(232, 78, 56, 0.35);
  background: #FFF6F3;
}

.message-box.is-error textarea {
  background: #FFF6F3;
}

.send-btn {
  width: 100%;
  margin-top: 16px;
  padding: 16px;
  border-radius: 16px;
  font-size: 15px;
  font-weight: 600;
  background: #1A1A1A;
  color: #FFFFFF;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  transition: transform 0.12s ease, opacity 0.12s ease;
}

.send-btn:active { transform: scale(0.975); opacity: 0.88; }

/* ── Verification loading screen ─────────────────────────── */
.vl-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 32px 24px 40px;
  gap: 20px;
  text-align: center;
}

.vl-badge {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(20,58,69,0.45);
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(22,57,66,0.10);
  border-radius: 99px;
  padding: 5px 14px;
}

/* SVG halka */
.vl-circle-wrap {
  position: relative;
  width: 180px;
  height: 180px;
}
.vl-ring {
  width: 180px;
  height: 180px;
  transform: rotate(-90deg);
}
.vl-ring-bg {
  fill: none;
  stroke: rgba(33,126,136,0.10);
  stroke-width: 2;
}
.vl-ring-progress {
  fill: none;
  stroke: #217e88;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-dasharray: 377;   /* 2π × 60 ≈ 377 */
  stroke-dashoffset: 377;
  animation: vl-ring-sweep 2.2s cubic-bezier(0.4,0,0.2,1) infinite;
}
@keyframes vl-ring-sweep {
  0%   { stroke-dashoffset: 377; opacity: 0.4; }
  50%  { stroke-dashoffset: 75;  opacity: 1;   }
  100% { stroke-dashoffset: 377; opacity: 0.4; }
}

.vl-circle-inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
}
.vl-room-label {
  font-family: 'Inter', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(20,58,69,0.38);
}
.vl-room-num {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 52px;
  font-weight: 600;
  color: #143a45;
  line-height: 1.05;
  letter-spacing: -1px;
  animation: vl-num-pulse 2.2s ease-in-out infinite;
}
@keyframes vl-num-pulse {
  0%, 100% { opacity: 0.65; }
  50%      { opacity: 1;    }
}

/* Durum metni */
.vl-status {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: rgba(21,58,66,0.50);
  font-weight: 400;
  margin-top: -4px;
}

/* Adım göstergesi */
.vl-steps {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 220px;
  margin-top: 4px;
}
.vl-step {
  display: flex;
  align-items: center;
  gap: 10px;
}
.vl-step-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: background 0.4s;
}
.vl-step--active .vl-step-dot {
  background: #217e88;
  animation: vl-step-blink 1.2s ease-in-out infinite;
}
.vl-step--done .vl-step-dot {
  background: #217e88;
  animation: none;
}
.vl-step--wait .vl-step-dot {
  background: rgba(33,126,136,0.18);
}
@keyframes vl-step-blink {
  0%, 100% { opacity: 0.4; transform: scale(0.8); }
  50%      { opacity: 1;   transform: scale(1.2); }
}
.vl-step-text {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: rgba(21,58,66,0.45);
  transition: color 0.4s;
}
.vl-step--active .vl-step-text { color: #1b434c; }
.vl-step--done   .vl-step-text { color: rgba(21,58,66,0.55); }

/* ═══════════════════════════════════════════
   SUB-PAGE: REQUEST SUCCESS SCREEN
═══════════════════════════════════════════ */
.rs-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 32px 24px 40px;
  gap: 20px;
  text-align: center;
}

.rs-badge {
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: rgba(20,58,69,0.45);
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(22,57,66,0.10);
  border-radius: 99px;
  padding: 5px 14px;
  opacity: 0;
  animation: rs-fade-up 0.4s ease 0.05s forwards;
}

.rs-circle-wrap {
  position: relative;
  width: 160px;
  height: 160px;
}

.rs-ring {
  width: 160px;
  height: 160px;
  transform: rotate(-90deg);
}

.rs-ring-track {
  fill: none;
  stroke: rgba(33,126,136,0.10);
  stroke-width: 2;
}

.rs-ring-fill {
  fill: none;
  stroke: #217e88;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-dasharray: 302;
  stroke-dashoffset: 302;
  animation: rs-ring-draw 0.85s cubic-bezier(0.25, 1, 0.5, 1) 0.15s forwards;
}

@keyframes rs-ring-draw {
  to { stroke-dashoffset: 0; }
}

.rs-check-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rs-check-path {
  fill: none;
  stroke: #217e88;
  stroke-width: 3.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 56;
  stroke-dashoffset: 56;
  animation: rs-check-draw 0.35s ease 0.9s forwards;
}

@keyframes rs-check-draw {
  to { stroke-dashoffset: 0; }
}

.rs-title {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 32px;
  font-weight: 600;
  color: #143a45;
  line-height: 1.1;
  margin: 0;
  opacity: 0;
  animation: rs-fade-up 0.45s ease 1.1s forwards;
}

.rs-message {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: rgba(21,58,66,0.52);
  font-weight: 400;
  line-height: 1.65;
  max-width: 270px;
  margin: -6px 0 0;
  opacity: 0;
  animation: rs-fade-up 0.45s ease 1.3s forwards;
}

.rs-home-btn {
  display: inline-block;
  text-decoration: none;
  opacity: 0;
  animation: rs-fade-up 0.45s ease 1.55s forwards;
}

@keyframes rs-fade-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════
   SUB-PAGE: QUICK REQUEST GRID
═══════════════════════════════════════════ */
.quick-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 6px;
}

.quick-btn {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 16px;
  padding: 16px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  color: #1A1A1A;
  cursor: pointer;
  transition: background 0.15s, transform 0.12s, border-color 0.15s;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  text-align: center;
  line-height: 1.3;
}

.quick-btn:active { background: #F0F0F5; transform: scale(0.97); }
.quick-btn.selected { background: #C8B4F5; border-color: transparent; }
.quick-btn .emoji { font-size: 22px; line-height: 1; }

/* ═══════════════════════════════════════════
   SUB-PAGE: INFO CARDS (hotel-info)
═══════════════════════════════════════════ */
.info-section-title {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 1.5px;
  color: #AAAAAA;
  margin: 20px 0 8px;
}

.info-card {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 16px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  gap: 12px;
}

.info-card-left { flex: 1; }
.info-card-label { font-size: 10px; font-weight: 500; letter-spacing: 1px; color: #AAAAAA; margin-bottom: 3px; }
.info-card-value { font-size: 16px; font-weight: 600; color: #1A1A1A; line-height: 1.2; }
.info-card-sub   { font-size: 11px; color: #BBBBBB; margin-top: 2px; }
.info-card-right { flex-shrink: 0; }

.info-copy-btn {
  padding: 6px 14px;
  background: #1A1A1A;
  color: #fff;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  transition: opacity 0.15s;
}

.info-copy-btn:active { opacity: 0.75; }

.info-card-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: #EFEFF4;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.info-card.info-emergency { background: #FFF0EE; border-color: rgba(232,78,56,0.2); }
.info-card.info-emergency .info-card-label { color: #E84E38; }
.info-card.info-emergency .info-card-value { color: #E84E38; }

.hours-grid { display: flex; flex-direction: column; gap: 4px; margin-top: 4px; }
.hours-row  { display: flex; justify-content: space-between; align-items: center; }
.hours-label { font-size: 12px; color: #777; font-weight: 400; }
.hours-value { font-size: 12px; font-weight: 600; color: #1A1A1A; }

.info-hero {
  background: linear-gradient(135deg, #1A1A1A 0%, #3D52C4 100%);
  border-radius: 24px;
  padding: 20px 18px;
  margin-bottom: 18px;
  position: relative;
  overflow: hidden;
}

.info-hero::after {
  content: '';
  position: absolute;
  top: -36px;
  right: -24px;
  width: 132px;
  height: 132px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
}

.info-hero-eyebrow {
  position: relative;
  z-index: 1;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.8px;
  color: rgba(255, 255, 255, 0.62);
  margin-bottom: 8px;
}

.info-hero-title {
  position: relative;
  z-index: 1;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.6px;
  line-height: 1.08;
  color: #FFFFFF;
}

.info-hero-text {
  position: relative;
  z-index: 1;
  font-size: 13px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.78);
  margin-top: 10px;
  max-width: 310px;
}

.info-stat-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
}

.info-stat-card {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  padding: 12px 13px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.info-stat-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.2px;
  color: rgba(255, 255, 255, 0.66);
}

.info-stat-value {
  font-size: 19px;
  font-weight: 800;
  color: #FFFFFF;
  margin-top: 4px;
}

.info-card-stack {
  align-items: stretch;
  flex-direction: column;
}

.info-card-head {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.info-card-stack .info-card-right {
  align-self: flex-start;
}

.info-card-stack .hours-grid {
  width: 100%;
  gap: 0;
  margin-top: 12px;
}

.info-card-stack .hours-row {
  align-items: flex-start;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.info-card-stack .hours-row:first-child {
  padding-top: 0;
  border-top: none;
}

.info-card-stack .hours-label {
  flex: 1;
  line-height: 1.5;
}

.info-card-stack .hours-value {
  max-width: 132px;
  text-align: right;
  line-height: 1.45;
}

.info-note {
  width: 100%;
  margin-top: 12px;
  padding: 11px 12px;
  border-radius: 14px;
  background: #F6F7FB;
  font-size: 12px;
  line-height: 1.55;
  color: #666A74;
}

.info-bullet-list {
  list-style: none;
  width: 100%;
  margin: 12px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
}

.info-bullet-list li {
  position: relative;
  padding-left: 16px;
  font-size: 12px;
  line-height: 1.6;
  color: #5F5F66;
}

.info-bullet-list li::before {
  content: '';
  position: absolute;
  top: 0.55em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #3D52C4;
}

.info-link-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
}

.info-link-list a {
  color: #3D52C4;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
}

.info-link-list a:active {
  opacity: 0.72;
}

.info-card.info-emergency .info-bullet-list li {
  color: #7A4F49;
}

.info-card.info-emergency .info-bullet-list li::before {
  background: #E84E38;
}

/* Hotel guide redesign */
.hotel-guide {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.guide-hero {
  position: relative;
  overflow: hidden;
  padding: 24px 20px 20px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.22), transparent 34%),
    linear-gradient(160deg, #133943 0%, #1d5160 48%, #ecb56f 100%);
  color: #fff;
  box-shadow: 0 20px 44px rgba(19, 57, 67, 0.18);
}

.guide-hero::before,
.guide-hero::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.guide-hero::before {
  width: 180px;
  height: 180px;
  top: -92px;
  right: -64px;
  background: rgba(255,255,255,0.1);
}

.guide-hero::after {
  width: 128px;
  height: 128px;
  left: -46px;
  bottom: -62px;
  background: rgba(255,255,255,0.08);
}

.guide-hero-eyebrow {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.86);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
}

.guide-hero-eyebrow::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #7DFFB2;
  box-shadow: 0 0 0 6px rgba(125,255,178,0.16);
}

.guide-hero-title {
  position: relative;
  z-index: 1;
  margin-top: 16px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 38px;
  line-height: 1.02;
  letter-spacing: -0.9px;
}

.guide-hero-text {
  position: relative;
  z-index: 1;
  margin-top: 12px;
  max-width: 310px;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(255,255,255,0.88);
}

.guide-hero-metrics {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 18px;
}

.guide-stat {
  padding: 14px 14px 13px;
  border-radius: 18px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.guide-stat-label {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: rgba(255,255,255,0.74);
  text-transform: uppercase;
}

.guide-stat-value {
  margin-top: 5px;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.1;
  color: #fff;
}

.guide-jump-nav {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 2px 0 1px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.guide-jump-nav::-webkit-scrollbar {
  display: none;
}

.guide-jump-link {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(17, 55, 64, 0.08);
  background: rgba(255,255,255,0.72);
  box-shadow: 0 10px 24px rgba(20, 57, 66, 0.06);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.4px;
  color: #163942;
  white-space: nowrap;
}

.guide-jump-link:active {
  transform: scale(0.98);
}

.guide-section {
  --guide-accent: #173c45;
  --guide-soft: #eef5f6;
  --guide-accent-cloud: rgba(23, 60, 69, 0.1);
  --guide-accent-label: #35535b;
  --guide-accent-icon-bg: #e8f0f1;
  --guide-accent-icon-ring: rgba(23, 60, 69, 0.08);
  --guide-accent-surface: #f6f9f9;
  position: relative;
  padding: 18px;
  border-radius: 28px;
  border: 1px solid rgba(16, 54, 63, 0.08);
  background: linear-gradient(180deg, var(--guide-soft) 0%, #fff 100%);
  box-shadow: 0 14px 34px rgba(21, 58, 66, 0.06);
  scroll-margin-top: 88px;
}

.guide-section--essentials {
  --guide-accent: #163b44;
  --guide-soft: #eef4f5;
  --guide-accent-cloud: rgba(22, 59, 68, 0.1);
  --guide-accent-label: #3f5d64;
  --guide-accent-icon-bg: #e5eef0;
  --guide-accent-icon-ring: rgba(22, 59, 68, 0.08);
  --guide-accent-surface: #f4f8f8;
}

.guide-section--dining {
  --guide-accent: #b87933;
  --guide-soft: #fcf4e8;
  --guide-accent-cloud: rgba(184, 121, 51, 0.11);
  --guide-accent-label: #8f6c44;
  --guide-accent-icon-bg: #f7ead7;
  --guide-accent-icon-ring: rgba(184, 121, 51, 0.1);
  --guide-accent-surface: #fbf4ea;
}

.guide-section--wellness {
  --guide-accent: #1c7d80;
  --guide-soft: #eef9f7;
  --guide-accent-cloud: rgba(28, 125, 128, 0.1);
  --guide-accent-label: #3f7072;
  --guide-accent-icon-bg: #e4f2f1;
  --guide-accent-icon-ring: rgba(28, 125, 128, 0.1);
  --guide-accent-surface: #eef8f7;
}

.guide-section--services {
  --guide-accent: #5567c6;
  --guide-soft: #eff1ff;
  --guide-accent-cloud: rgba(85, 103, 198, 0.1);
  --guide-accent-label: #59659d;
  --guide-accent-icon-bg: #e7ebff;
  --guide-accent-icon-ring: rgba(85, 103, 198, 0.09);
  --guide-accent-surface: #f1f3ff;
}

.guide-section--rules {
  --guide-accent: #d55d42;
  --guide-soft: #fff0ea;
  --guide-accent-cloud: rgba(213, 93, 66, 0.11);
  --guide-accent-label: #9c5d4f;
  --guide-accent-icon-bg: #fde5dd;
  --guide-accent-icon-ring: rgba(213, 93, 66, 0.1);
  --guide-accent-surface: #fff2ed;
}

.guide-section--departure {
  --guide-accent: #276a5d;
  --guide-soft: #eef8f4;
  --guide-accent-cloud: rgba(39, 106, 93, 0.1);
  --guide-accent-label: #4e736a;
  --guide-accent-icon-bg: #e4f1ec;
  --guide-accent-icon-ring: rgba(39, 106, 93, 0.09);
  --guide-accent-surface: #f1f8f5;
}

.guide-section-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.guide-section-texts {
  flex: 1;
  min-width: 0;
}

.guide-section-kicker {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--guide-accent-label);
  text-transform: uppercase;
}

.guide-section-title {
  margin-top: 7px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 30px;
  line-height: 1.04;
  letter-spacing: -0.7px;
  color: #173942;
}

.guide-section-sub {
  margin-top: 9px;
  max-width: 295px;
  font-size: 14px;
  line-height: 1.65;
  color: #66777c;
}

.guide-section-icon {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--guide-accent-icon-bg);
  color: var(--guide-accent);
  box-shadow: inset 0 0 0 1px var(--guide-accent-icon-ring);
  flex-shrink: 0;
}

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

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

.guide-surface {
  padding: 15px 15px 14px;
  border-radius: 22px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(19, 58, 67, 0.06);
  box-shadow: 0 10px 24px rgba(21, 58, 66, 0.04);
}

.guide-surface--accent {
  background: linear-gradient(180deg, var(--guide-accent-surface) 0%, rgba(255,255,255,0.98) 100%);
}

.guide-surface-kicker {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: var(--guide-accent-label);
}

.guide-surface-title {
  margin-top: 6px;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.2px;
  color: #173942;
}

.guide-surface-text {
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.65;
  color: #5e6f74;
}

.guide-data-list {
  display: flex;
  flex-direction: column;
}

.guide-data-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 14px 0;
  border-top: 1px solid rgba(17, 55, 64, 0.07);
}

.guide-data-row:first-child {
  padding-top: 0;
  border-top: none;
}

.guide-data-label {
  font-size: 14.5px;
  line-height: 1.5;
  color: #4f5e63;
}

.guide-data-value {
  max-width: 180px;
  text-align: right;
  font-size: 14.5px;
  font-weight: 700;
  line-height: 1.5;
  color: #173942;
  white-space: pre-line;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

.guide-note {
  margin-top: 12px;
  padding: 14px 14px;
  border-radius: 16px;
  background: #f5f7fb;
  font-size: 13.5px;
  line-height: 1.65;
  color: #5b676d;
}

.guide-bullet-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0;
  padding: 0;
}

.guide-bullet-list li {
  position: relative;
  padding-left: 18px;
  font-size: 14.5px;
  line-height: 1.65;
  color: #4f5e63;
}

.guide-bullet-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--guide-accent);
}

.guide-warning-card {
  background: linear-gradient(180deg, var(--guide-accent-surface) 0%, rgba(255,255,255,0.98) 100%);
}

.guide-link-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
}

.guide-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 15px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(20, 58, 66, 0.07);
  font-size: 14.5px;
  font-weight: 700;
  color: var(--guide-accent);
}

.guide-link:active {
  transform: scale(0.985);
}

.guide-link svg {
  flex-shrink: 0;
}

/* ── Mobile (most phones up to iPhone Pro Max 430px) ─────────────────────── */
@media (max-width: 430px) {
  .guide-hero {
    padding: 22px 18px 20px;
  }

  .guide-hero-title {
    font-size: 32px;
    letter-spacing: -0.6px;
  }

  .guide-section {
    padding: 18px 16px;
    border-radius: 24px;
  }

  .guide-section-title {
    font-size: 26px;
    letter-spacing: -0.5px;
  }

  .guide-section-icon {
    width: 42px;
    height: 42px;
  }

  .guide-surface {
    padding: 16px 14px 14px;
  }
}

/* ── Small phones (≤375px: SE, mini, etc.) ───────────────────────────────── */
@media (max-width: 375px) {
  .guide-hero-title {
    font-size: 30px;
  }

  .guide-section-title {
    font-size: 24px;
  }

  .guide-section-head {
    flex-direction: column;
  }

  .guide-section-icon {
    width: 40px;
    height: 40px;
  }

  .guide-data-row {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }

  .guide-data-value {
    max-width: none;
    text-align: left;
    font-size: 14px;
  }

  .guide-data-label {
    font-size: 13.5px;
  }

  .guide-bullet-list li {
    font-size: 14px;
  }
}

/* ═══════════════════════════════════════════
   SUB-PAGE: BOOK DIRECT
═══════════════════════════════════════════ */
.hero-banner {
  background: #E84E38;
  border-radius: 20px;
  padding: 22px 20px;
  margin-bottom: 14px;
  position: relative;
  overflow: hidden;
}

.hero-banner::before {
  content: '';
  position: absolute;
  right: -20px; top: -20px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
}

.hero-eyebrow { font-size: 10px; font-weight: 500; letter-spacing: 1.5px; color: rgba(255,255,255,0.65); margin-bottom: 6px; }
.hero-title   { font-size: 28px; font-weight: 800; color: #FFFFFF; letter-spacing: -0.5px; line-height: 1.1; }
.hero-sub     { font-size: 13px; color: rgba(255,255,255,0.75); margin-top: 6px; }

.discount-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,0.2);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  color: #FFFFFF;
  margin-top: 10px;
}

.form-card { background: #FFFFFF; border: 1px solid rgba(0,0,0,0.07); border-radius: 20px; padding: 16px; margin-bottom: 10px; }
.form-row  { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid rgba(0,0,0,0.06); }
.form-row:last-child { border-bottom: none; }
.form-row-label  { font-size: 12px; font-weight: 500; color: #AAAAAA; }
.form-row-input  { font-size: 14px; font-weight: 600; color: #1A1A1A; background: transparent; text-align: right; width: 140px; }
.form-row-select { font-size: 14px; font-weight: 600; color: #1A1A1A; background: transparent; text-align: right; appearance: none; -webkit-appearance: none; border: none; cursor: pointer; }

.book-cta {
  width: 100%;
  padding: 18px;
  border-radius: 18px;
  font-size: 16px;
  font-weight: 700;
  background: #E84E38;
  color: #FFFFFF;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  transition: transform 0.12s ease, opacity 0.12s ease;
}

.book-cta:active { transform: scale(0.975); opacity: 0.9; }

.book-flow {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.booking-hero {
  position: relative;
  overflow: hidden;
  padding: 24px 20px 20px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.22), transparent 34%),
    linear-gradient(155deg, #133943 0%, #1d4f5b 44%, #efb360 100%);
  color: #fff;
  box-shadow: 0 18px 42px rgba(18, 56, 65, 0.2);
}

.booking-hero::before,
.booking-hero::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.booking-hero::before {
  width: 188px;
  height: 188px;
  top: -96px;
  right: -72px;
  background: rgba(255,255,255,0.1);
}

.booking-hero::after {
  width: 134px;
  height: 134px;
  bottom: -70px;
  left: -44px;
  background: rgba(255,255,255,0.08);
}

.booking-hero-badge {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.86);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.booking-hero-badge::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #7CFFB3;
  box-shadow: 0 0 0 6px rgba(124,255,179,0.16);
}

.booking-hero-title {
  position: relative;
  z-index: 1;
  margin-top: 16px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 40px;
  line-height: 0.98;
  letter-spacing: -1px;
}

.booking-hero-sub {
  position: relative;
  z-index: 1;
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.84);
  max-width: 300px;
}

.booking-hero-pills {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.booking-hero-pill {
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.12);
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.92);
}

.booking-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.booking-card {
  position: relative;
  padding: 18px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, #fff 100%);
  border: 1px solid rgba(17, 55, 64, 0.08);
  box-shadow: 0 14px 34px rgba(18, 56, 65, 0.06);
}

.booking-card--form {
  background: linear-gradient(180deg, #f6faf9 0%, #fff 100%);
}

.booking-card--summary {
  background: linear-gradient(180deg, #eef4f7 0%, #fff 100%);
}

.booking-card-kicker {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #6f8186;
}

.booking-card-title {
  margin-top: 8px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 31px;
  line-height: 1.04;
  letter-spacing: -0.7px;
  color: #163942;
}

.booking-card-text {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.6;
  color: #67787d;
}

.booking-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 16px;
}

.booking-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.booking-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.booking-step-panel {
  display: none;
  opacity: 0;
  transform: translateY(10px);
}

.booking-step-panel.is-visible {
  display: block;
  opacity: 1;
  transform: translateY(0);
  animation: booking-step-in 0.28s ease;
}

.booking-room-groups {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.booking-room-card {
  padding: 14px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(20, 58, 66, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
  animation: booking-step-in 0.28s ease;
}

.booking-room-title {
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.3px;
  color: #143942;
}

.booking-field-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: #6c7e82;
}

.booking-input,
.booking-select {
  width: 100%;
  min-height: 50px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(20, 58, 66, 0.1);
  background: rgba(255,255,255,0.86);
  font-size: 15px;
  font-weight: 700;
  color: #163942;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.7);
}

.booking-input:focus,
.booking-select:focus {
  border-color: rgba(29, 109, 89, 0.35);
  box-shadow: 0 0 0 4px rgba(29, 109, 89, 0.08);
}

.booking-select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #6b7d82 50%),
    linear-gradient(135deg, #6b7d82 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 34px;
}

.booking-child-ages {
  display: none;
  flex-direction: column;
  gap: 10px;
  margin-top: 2px;
}

.booking-child-ages.is-visible {
  display: flex;
}

.booking-child-age-row {
  display: flex;
  flex-direction: column;
  gap: 7px;
  animation: booking-child-in 0.26s ease;
}

@keyframes booking-child-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes booking-step-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.booking-phone-card {
  margin-top: 16px;
  padding: 14px 15px;
  border-radius: 20px;
  background: rgba(255,255,255,0.9);
  border: 1px solid rgba(18, 56, 65, 0.07);
}

.booking-phone-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.7px;
  text-transform: uppercase;
  color: #7c8d92;
}

.booking-phone-value {
  margin-top: 6px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: #143943;
}

.booking-summary-note {
  margin-top: 12px;
  padding: 12px 13px;
  border-radius: 16px;
  background: #f5f8fa;
  font-size: 12px;
  line-height: 1.6;
  color: #64757a;
}

.booking-submit {
  width: 100%;
  min-height: 56px;
  padding: 0 18px;
  border-radius: 20px;
  background: linear-gradient(135deg, #1a6d59 0%, #0f8a57 100%);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.2px;
  box-shadow: 0 16px 34px rgba(15, 138, 87, 0.24);
  transition: transform 0.14s ease, opacity 0.14s ease, box-shadow 0.14s ease;
}

.booking-submit:active {
  transform: scale(0.985);
  opacity: 0.94;
}

.booking-submit.is-loading {
  opacity: 0.9;
  box-shadow: 0 12px 26px rgba(15, 138, 87, 0.2);
}

.booking-submit:disabled {
  cursor: wait;
}

.booking-redirect {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(16, 37, 43, 0.34);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}

.booking-redirect.is-active {
  opacity: 1;
  visibility: visible;
}

.booking-redirect-card {
  width: min(100%, 340px);
  padding: 24px 20px 20px;
  border-radius: 28px;
  background: linear-gradient(160deg, #133943 0%, #1c5563 55%, #eab56b 100%);
  color: #fff;
  box-shadow: 0 24px 46px rgba(19, 57, 67, 0.22);
  transform: translateY(16px) scale(0.96);
  transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1);
}

.booking-redirect.is-active .booking-redirect-card {
  transform: translateY(0) scale(1);
}

.booking-redirect-ring {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.22);
  border-top-color: #fff;
  animation: booking-spin 1s linear infinite;
}

@keyframes booking-spin {
  to {
    transform: rotate(360deg);
  }
}

.booking-redirect-title {
  margin-top: 18px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 31px;
  line-height: 1.04;
  letter-spacing: -0.7px;
}

.booking-redirect-text {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255,255,255,0.84);
}

.booking-redirect-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
}

.booking-redirect-pill::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #7dffb2;
}

/* ═══════════════════════════════════════════
   SUB-PAGE: LANGUAGE
═══════════════════════════════════════════ */
.lang-option-list { display: flex; flex-direction: column; gap: 8px; }

.lang-option {
  background: #FFFFFF;
  border: 1.5px solid rgba(0,0,0,0.07);
  border-radius: 16px;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, transform 0.12s;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.lang-option:active { transform: scale(0.975); }
.lang-option.selected { border-color: #C8B4F5; background: #FAF7FF; }

.lang-option-left { display: flex; align-items: center; gap: 14px; }
.lang-flag   {
  width: 27px;
  height: 19px;
  border-radius: 4px;
  flex-shrink: 0;
}
.lang-name   { font-size: 16px; font-weight: 600; color: #1A1A1A; }
.lang-native { font-size: 12px; color: #AAAAAA; margin-top: 1px; }

.lang-check {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid rgba(0,0,0,0.15);
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s, border-color 0.15s;
}

.lang-option.selected .lang-check { background: #C8B4F5; border-color: #C8B4F5; }

/* ═══════════════════════════════════════════
   SUB-PAGE: ENTERTAINMENT SCHEDULE
═══════════════════════════════════════════ */
.schedule-card {
  background: #FFFFFF;
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 8px;
}

.schedule-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 16px;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.schedule-row:last-child { border-bottom: none; }

.schedule-time {
  font-size: 13px;
  font-weight: 700;
  color: #1A1A1A;
  min-width: 46px;
  flex-shrink: 0;
  letter-spacing: -0.2px;
}

.schedule-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #FF8040;
  flex-shrink: 0;
}

.schedule-dot-eve { background: #3D52C4; }
.schedule-dot-morn { background: #CCDC3E; }

.schedule-activity {
  font-size: 13px;
  font-weight: 500;
  color: #1A1A1A;
  flex: 1;
}

.ent-page-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ent-hero-card {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  padding: 22px 20px 20px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,0.22), transparent 35%),
    linear-gradient(145deg, #123a45 0%, #1d5662 45%, #efb667 100%);
  color: #fff;
  box-shadow: 0 18px 38px rgba(18, 58, 69, 0.22);
}

.ent-hero-card::before,
.ent-hero-card::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.ent-hero-card::before {
  width: 180px;
  height: 180px;
  right: -80px;
  top: -88px;
  background: rgba(255,255,255,0.1);
}

.ent-hero-card::after {
  width: 130px;
  height: 130px;
  left: -54px;
  bottom: -62px;
  background: rgba(255,255,255,0.08);
}

.ent-hero-badge,
.ent-section-kicker,
.ent-period-badge,
.ent-channel-label {
  font-size: 10px;
  letter-spacing: 2.2px;
  font-weight: 700;
  text-transform: uppercase;
}

.ent-hero-badge {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.88);
}

.ent-hero-badge::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #7BFFB1;
  box-shadow: 0 0 0 6px rgba(123,255,177,0.16);
}

.ent-hero-title {
  position: relative;
  z-index: 1;
  margin-top: 16px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 34px;
  line-height: 1.04;
  letter-spacing: -0.8px;
}

.ent-hero-text {
  position: relative;
  z-index: 1;
  margin-top: 12px;
  max-width: 300px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.82);
}

.ent-pill-row {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.ent-pill {
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.14);
  border: 1px solid rgba(255,255,255,0.12);
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.92);
}

.ent-channel-card {
  display: block;
  position: relative;
  overflow: hidden;
  padding: 18px 18px 16px;
  border-radius: 24px;
  background: #ffffff;
  border: 1px solid rgba(15, 54, 63, 0.08);
  box-shadow: 0 14px 32px rgba(20, 58, 66, 0.08);
  color: inherit;
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.ent-channel-card:active {
  transform: scale(0.985);
}

.ent-channel-card:hover {
  border-color: rgba(37, 129, 86, 0.26);
  box-shadow: 0 18px 40px rgba(20, 58, 66, 0.11);
}

.ent-channel-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.ent-channel-label {
  color: #7A8B90;
}

.ent-channel-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 10px;
  border-radius: 999px;
  background: #ECF9F0;
  color: #16814D;
  font-size: 11px;
  font-weight: 700;
}

.ent-channel-badge svg {
  flex-shrink: 0;
}

.ent-channel-title {
  margin-top: 14px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.4px;
  color: #153942;
}

.ent-channel-text {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.6;
  color: #5C6C70;
}

.ent-channel-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(15, 54, 63, 0.08);
}

.ent-channel-note {
  font-size: 11px;
  color: #93A0A4;
}

.ent-channel-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: #16814D;
}

.ent-channel-cta svg {
  flex-shrink: 0;
}

.ent-board-card {
  padding: 20px 16px 16px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, #fff 100%);
  border: 1px solid rgba(0,0,0,0.06);
}

.ent-section-kicker {
  color: #86959A;
}

.ent-section-title {
  margin-top: 8px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 31px;
  line-height: 1.05;
  letter-spacing: -0.7px;
  color: #163942;
}

.ent-section-sub {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.55;
  color: #6A7A7F;
}

.ent-period-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}

.ent-period-card {
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(0,0,0,0.05);
}

.ent-period-card--morning {
  background: linear-gradient(180deg, #FFF6D9 0%, #FFFFFF 100%);
}

.ent-period-card--afternoon {
  background: linear-gradient(180deg, #EAF8F4 0%, #FFFFFF 100%);
}

.ent-period-card--evening {
  background: linear-gradient(180deg, #163A46 0%, #204E5E 100%);
  color: #fff;
  border-color: rgba(255,255,255,0.06);
}

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

.ent-period-badge {
  color: #50656B;
}

.ent-period-card--evening .ent-period-badge {
  color: rgba(255,255,255,0.7);
}

.ent-period-note {
  max-width: 140px;
  text-align: right;
  font-size: 11px;
  line-height: 1.45;
  color: #7A8B90;
}

.ent-period-card--evening .ent-period-note {
  color: rgba(255,255,255,0.72);
}

.ent-period-list {
  display: flex;
  flex-direction: column;
}

.ent-period-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}

.ent-period-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.ent-period-card--evening .ent-period-row {
  border-bottom-color: rgba(255,255,255,0.1);
}

.ent-period-time {
  min-width: 48px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.2px;
  color: #163942;
}

.ent-period-card--evening .ent-period-time {
  color: #fff;
}

.ent-period-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

.ent-period-dot--sun { background: #F2B24B; }
.ent-period-dot--sea { background: #38B89A; }
.ent-period-dot--night { background: #F7D586; }

.ent-period-activity {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  color: #183B44;
}

.ent-period-card--evening .ent-period-activity {
  color: rgba(255,255,255,0.92);
}

.ent-footnote {
  margin-top: 14px;
  font-size: 12px;
  line-height: 1.55;
  color: #7F8E93;
}

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast {
  position: fixed;
  bottom: 90px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #1A1A1A;
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  padding: 10px 20px;
  border-radius: 20px;
  opacity: 0;
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 100;
  white-space: nowrap;
}

.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media (max-width: 375px) {
  .card-title    { font-size: 20px; }
  .card-title-sm { font-size: 15px; }
  .header-title  { font-size: 27px; }
  .cta-btn       { font-size: 14px; }
  .contact-grid  { grid-template-columns: 1fr; }
  .contact-hero-title { font-size: 25px; }
  .ent-hero-title { font-size: 30px; }
  .ent-section-title { font-size: 28px; }
  .ent-channel-footer,
  .ent-period-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .ent-period-note {
    max-width: none;
    text-align: left;
  }
}

/* Home experience */
.home-main-legacy {
  padding-top: 8px;
}

.home-card-hero {
  min-height: 214px;
  padding: 18px 18px 20px;
}

.home-card-head {
  position: relative;
  z-index: 2;
  margin-bottom: 28px;
}

.home-card-arrow {
  box-shadow: 0 14px 26px rgba(21, 59, 69, 0.16);
}

.home-card-hero .card-title,
.home-card-hero .card-desc,
.home-card-hero .pills-row {
  position: relative;
  z-index: 2;
  max-width: 232px;
}

.home-card-orb {
  position: absolute;
  right: 16px;
  bottom: 16px;
  transform: scale(0.9);
  z-index: 1;
}

.home-card-orb::after {
  content: '24/7';
  font-size: 18px;
}

.home-card-sm {
  min-height: 184px;
}

.home-card-sm .card-desc-sm {
  max-width: 130px;
}

.home-card-mini-arrow {
  margin-top: auto;
}

.home-card-mini-arrow-dark {
  background: rgba(21, 59, 69, 0.09);
}

.home-card-mini-arrow-light {
  background: rgba(255, 255, 255, 0.16);
}

.home-card-hero-warm::before {
  content: '';
  position: absolute;
  right: -48px;
  top: -42px;
  width: 184px;
  height: 184px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 246, 229, 0.32), rgba(255, 246, 229, 0) 70%);
}

.pill-soft-warm {
  background: rgba(255, 255, 255, 0.34);
  border-color: rgba(124, 56, 19, 0.14);
  color: #7a320f;
}

.home-hero-panel {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 22px 18px 18px;
  background: linear-gradient(135deg, #103a46 0%, #1f5f67 40%, #2d8278 68%, #efb477 100%);
  box-shadow:
    0 24px 48px rgba(15, 49, 58, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.home-hero-panel::before {
  content: '';
  position: absolute;
  inset: auto -44px -62px auto;
  width: 182px;
  height: 182px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.28), rgba(255, 255, 255, 0) 68%);
}

.home-hero-panel::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.14), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0));
  pointer-events: none;
}

.home-hero-top,
.home-hero-text,
.home-hero-stats,
.home-hero-pills {
  position: relative;
  z-index: 1;
}

.home-hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.home-hero-copy {
  min-width: 0;
}

.home-hero-eyebrow {
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.65);
}

.home-hero-title {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 40px;
  font-weight: 600;
  line-height: 0.86;
  letter-spacing: -1.2px;
  color: #FFFFFF;
}

.home-hero-title em {
  font-style: italic;
  font-weight: 600;
  color: #ffe4c2;
}

.home-hero-medallion {
  width: 88px;
  min-width: 88px;
  height: 88px;
  padding: 12px;
  border-radius: 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2px;
  background: rgba(255, 255, 255, 0.13);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.home-hero-medallion-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.6px;
  color: rgba(255, 255, 255, 0.68);
}

.home-hero-medallion-value {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.4px;
  color: #FFFFFF;
}

.home-hero-text {
  margin-top: 14px;
  max-width: 290px;
  font-size: 13px;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.82);
}

.home-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 18px;
}

.home-stat-card {
  min-height: 76px;
  padding: 12px 10px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.home-stat-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.66);
}

.home-stat-value {
  display: block;
  margin-top: 12px;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.4px;
  color: #FFFFFF;
}

.home-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.home-hero-pill {
  display: inline-flex;
  align-items: center;
  min-height: 29px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.14);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.2px;
}

.home-section-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  padding: 4px 2px 0;
}

.home-section-kicker {
  margin-bottom: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.8px;
  color: #87918f;
}

.home-section-title {
  max-width: 240px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.5px;
  color: #163942;
}

.home-section-badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(20, 57, 66, 0.08);
  color: #45616a;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  box-shadow: 0 12px 24px rgba(33, 48, 52, 0.06);
}

.card-lux {
  border: 1px solid rgba(255, 255, 255, 0.76);
  box-shadow: 0 18px 36px rgba(69, 55, 34, 0.08);
}

.card-contact-lux {
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0) 24%),
    linear-gradient(145deg, #0f2d4a 0%, #1a4a6e 38%, #2e6fa0 70%, #d8a56f 100%);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow:
    0 24px 42px rgba(10, 28, 50, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

.card-contact-lux.home-card-hero {
  min-height: 193px;
  padding: 17px 18px 18px;
}

.card-contact-lux::before {
  content: '';
  position: absolute;
  inset: auto -54px -74px auto;
  width: 212px;
  height: 212px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 228, 192, 0.34), rgba(255, 228, 192, 0) 68%);
}

.card-contact-lux::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0) 48%),
    radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0) 24%);
  pointer-events: none;
}

.card-contact-lux .label-soft {
  color: rgba(255, 255, 255, 0.72);
}

.card-contact-lux .title-ink {
  color: #fff8ee;
}

.card-contact-lux .card-desc-ink {
  color: rgba(255, 248, 238, 0.82);
}

.card-contact-lux .pill-soft {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.card-contact-lux .home-card-arrow {
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 16px 28px rgba(14, 44, 52, 0.18);
}

.card-contact-lux .card-title,
.card-contact-lux .card-desc,
.card-contact-lux .pills-row {
  max-width: 258px;
}

.card-lux-head {
  position: relative;
  z-index: 1;
  margin-bottom: 14px;
}

.label-soft {
  color: rgba(21, 58, 66, 0.56);
}

.label-light-soft {
  color: rgba(255, 255, 255, 0.62);
}

.title-ink {
  color: #163942;
}

.card-desc-ink {
  color: rgba(22, 57, 66, 0.7);
}

.card-desc-light-strong,
.card-desc-sm-light-strong {
  color: rgba(255, 255, 255, 0.8);
}

.card-contact-body {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.card-contact-copy {
  min-width: 0;
}

.card-footnote {
  margin: 2px 0 14px;
  max-width: 225px;
  font-size: 12px;
  line-height: 1.55;
  color: #527079;
}

.home-pill-row {
  gap: 6px;
}

.pill-soft {
  border: 1px solid rgba(21, 58, 66, 0.12);
  background: rgba(255, 255, 255, 0.54);
  color: #355b64;
  font-weight: 600;
}

.card-contact-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hero-orb {
  position: relative;
  width: 84px;
  height: 84px;
  border-radius: 28px;
  background: linear-gradient(145deg, rgba(22, 88, 101, 0.14), rgba(255, 255, 255, 0.82));
  border: 1px solid rgba(255, 255, 255, 0.82);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.85),
    0 16px 28px rgba(28, 63, 71, 0.1);
}

.hero-orb::before {
  content: '';
  position: absolute;
  inset: 13px;
  border-radius: 22px;
  border: 1px solid rgba(22, 58, 66, 0.12);
}

.hero-orb::after {
  content: '';
  position: absolute;
  inset: 20px;
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.76), rgba(255, 255, 255, 0.08));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.58);
}

.arrow-lux {
  background: #153b45;
  box-shadow: 0 14px 26px rgba(21, 59, 69, 0.18);
}

.cards-grid-home {
  gap: 10px;
}

.card-sand-lux {
  background: linear-gradient(160deg, #fff9ef 0%, #f0e4d2 100%);
}

.card-sea-lux {
  background: linear-gradient(155deg, #123a45 0%, #215d68 58%, #3b837d 100%);
}

.card-sm.card-lux {
  min-height: 192px;
  padding: 18px 16px 16px;
}

.card-sm-icon-soft {
  background: rgba(19, 56, 65, 0.08);
  border-color: rgba(19, 56, 65, 0.14);
}

.card-sm-icon-foam {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.24);
}

.card-inline-link {
  display: inline-flex;
  margin-top: auto;
  padding-top: 14px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: #173a42;
}

.card-inline-link-light {
  color: #f6e4c3;
}

.card-wide-lux {
  min-height: 126px;
  border: 1px solid rgba(255, 255, 255, 0.72);
}

.card-wide-icon-soft {
  background: rgba(255, 255, 255, 0.24);
  border-color: rgba(255, 255, 255, 0.26);
}

.card-wide-right-stack {
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  min-height: 72px;
}

.card-sunset-lux {
  background: linear-gradient(130deg, #fbe0c3 0%, #efb37b 46%, #d97a52 100%);
  box-shadow: 0 18px 36px rgba(132, 74, 42, 0.16);
}

.card-book-lux {
  background:
    radial-gradient(circle at 14% 22%, rgba(255, 210, 170, 0.22), transparent 40%),
    linear-gradient(135deg, #b83418 0%, #d85028 50%, #e87840 100%);
  border: 1px solid rgba(255, 150, 100, 0.28);
  box-shadow:
    0 18px 40px rgba(180, 50, 20, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

.card-status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(21, 58, 66, 0.08);
  border: 1px solid rgba(21, 58, 66, 0.08);
  color: #1f5560;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}

.card-status-pill-dark {
  background: rgba(255, 255, 255, 0.24);
  border-color: rgba(255, 255, 255, 0.26);
  color: #7a320f;
}

.card-tag-soft {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.75);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.7px;
  text-transform: uppercase;
}

.card-book-lux .discount-home-pill {
  background: linear-gradient(135deg, #f4ce92 0%, #ffe3b1 100%);
  color: #5e300f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.home-pulse-card {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  padding: 20px 18px 18px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.68) 0%, rgba(237, 241, 240, 0.9) 54%, rgba(231, 236, 241, 0.98) 100%);
  border: 1px solid rgba(255, 255, 255, 0.84);
  box-shadow: 0 20px 42px rgba(42, 52, 58, 0.08);
}

.home-pulse-card::before {
  content: '';
  position: absolute;
  right: -16px;
  bottom: -24px;
  width: 138px;
  height: 138px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(47, 139, 127, 0.16), rgba(47, 139, 127, 0) 70%);
}

.home-pulse-label,
.home-pulse-title,
.home-pulse-text,
.home-pulse-pills {
  position: relative;
  z-index: 1;
}

.home-pulse-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.9px;
  color: #738582;
}

.home-pulse-title {
  margin-top: 8px;
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 28px;
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: -0.8px;
  color: #173942;
}

.home-pulse-text {
  margin-top: 9px;
  max-width: 280px;
  font-size: 13px;
  line-height: 1.6;
  color: #5b6a6f;
}

.home-pulse-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.home-pulse-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(21, 58, 66, 0.08);
  color: #35565f;
  font-size: 11px;
  font-weight: 600;
}

@media (max-width: 375px) {
  .home-hero-title {
    font-size: 34px;
  }

  .home-hero-top {
    align-items: stretch;
  }

  .home-hero-medallion {
    width: 78px;
    min-width: 78px;
    height: 78px;
    border-radius: 24px;
  }

  .home-section-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .card-contact-body {
    grid-template-columns: 1fr;
  }

  .card-contact-actions {
    justify-content: space-between;
  }
}
