/* =========================================================
   Don & Maria Suites — Design 5: "Immersive"
   Cinematic full-screen panels · dot nav · rooms slider
   ========================================================= */

:root {
  --ink:    #0e0e10;
  --solid:  #141416;
  --paper:  #f4f1ea;
  --muted:  rgba(255,255,255,0.72);
  --coral:  #e88153;
  --coral-d:#cf6a3c;
  --sage:   #9cb79f;
  --line:   rgba(255,255,255,0.16);
  --display:'Bodoni Moda', Georgia, serif;
  --body:   'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--body); font-weight: 300; color: #fff; background: var(--ink); line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; }
h1, h2, h3 { font-family: var(--display); font-weight: 400; line-height: 1.05; }

.kick { text-transform: uppercase; letter-spacing: 0.34em; font-size: 0.68rem; font-weight: 500; color: var(--coral); margin-bottom: 1.4rem; }
.kick.center { text-align: center; }
.center { text-align: center; }

.btn { display: inline-block; background: var(--coral); color: #1a0f06; font-family: var(--body); font-weight: 600; font-size: 0.76rem; letter-spacing: 0.18em; text-transform: uppercase; padding: 1.05rem 2.3rem; text-decoration: none; border: 0; cursor: pointer; transition: background 0.25s, transform 0.2s; }
.btn:hover { background: var(--coral-d); transform: translateY(-2px); }
.btn-block { width: 100%; text-align: center; }
.btn-line { display: inline-block; border: 1px solid rgba(255,255,255,0.55); color: #fff; font-size: 0.76rem; letter-spacing: 0.18em; text-transform: uppercase; padding: 1.05rem 2.3rem; text-decoration: none; transition: background 0.25s, color 0.25s; }
.btn-line:hover { background: #fff; color: var(--ink); }

/* ---------- Progress + header ---------- */
.progress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--coral); z-index: 120; }
.hdr { position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: 26px clamp(22px, 5vw, 56px); mix-blend-mode: difference; }
.logo { text-decoration: none; font-family: var(--display); font-size: 1.3rem; color: #fff; }
.logo em { font-style: italic; }
.menu-btn { display: flex; align-items: center; gap: 10px; background: none; border: 0; color: #fff; cursor: pointer; font-family: var(--body); font-size: 0.74rem; letter-spacing: 0.2em; text-transform: uppercase; }
.menu-btn i { width: 22px; height: 8px; position: relative; }
.menu-btn i::before, .menu-btn i::after { content: ''; position: absolute; left: 0; width: 22px; height: 1.5px; background: #fff; transition: 0.3s; }
.menu-btn i::before { top: 0; } .menu-btn i::after { bottom: 0; }
.menu-btn.open i::before { top: 3px; transform: rotate(45deg); }
.menu-btn.open i::after { bottom: 3px; transform: rotate(-45deg); }

/* ---------- Overlay menu ---------- */
.overlay { position: fixed; inset: 0; z-index: 95; background: rgba(14,14,16,0.97); display: flex; flex-direction: column; justify-content: center; padding: 0 clamp(28px, 8vw, 140px); opacity: 0; visibility: hidden; transition: opacity 0.4s ease, visibility 0.4s; }
.overlay.open { opacity: 1; visibility: visible; }
.overlay-nav { display: flex; flex-direction: column; gap: 0.4rem; }
.overlay-nav a { text-decoration: none; font-family: var(--display); font-size: clamp(2rem, 6vw, 4.4rem); color: #fff; display: flex; align-items: baseline; gap: 1.2rem; transition: color 0.25s, padding-left 0.3s; }
.overlay-nav a i { font-family: var(--body); font-style: normal; font-size: 0.8rem; color: var(--coral); letter-spacing: 0.1em; }
.overlay-nav a:hover { color: var(--coral); padding-left: 14px; }
.overlay-foot { display: flex; gap: 2.4rem; flex-wrap: wrap; margin-top: 3rem; color: var(--muted); font-size: 0.82rem; letter-spacing: 0.04em; }

/* ---------- Dot nav ---------- */
.dots { position: fixed; right: 28px; top: 50%; transform: translateY(-50%); z-index: 90; display: flex; flex-direction: column; gap: 16px; }
.dots a { width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.6); position: relative; transition: background 0.25s, transform 0.25s; }
.dots a.is-active { background: var(--coral); border-color: var(--coral); transform: scale(1.25); }
.dots a::after { content: attr(data-label); position: absolute; right: 22px; top: 50%; transform: translateY(-50%); white-space: nowrap; font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; opacity: 0; pointer-events: none; transition: opacity 0.25s; }
.dots a:hover::after { opacity: 1; }

/* ---------- Panels ---------- */
.panel { position: relative; min-height: 100vh; min-height: 100svh; display: flex; align-items: center; overflow: hidden; }
.panel.solid { background: var(--solid); }
.panel-bg { position: absolute; top: -10%; bottom: -10%; left: 0; right: 0; z-index: 0; background-size: cover; background-position: center; background-color: var(--ink); will-change: transform; }
.panel-veil { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(8,8,10,0.45), rgba(8,8,10,0.35)); }
.panel-veil.dark { background: linear-gradient(90deg, rgba(8,8,10,0.86) 0%, rgba(8,8,10,0.5) 55%, rgba(8,8,10,0.2) 100%); }
.panel-mid { position: relative; z-index: 2; width: 100%; max-width: 1180px; margin: 0 auto; padding: 120px clamp(22px, 5vw, 56px); }
.panel-mid.center { text-align: center; display: flex; flex-direction: column; align-items: center; }
.panel-mid.full { max-width: 1180px; }
.panel h1 { font-size: clamp(3rem, 9vw, 7.5rem); font-weight: 400; }
.panel h1 em, .panel h2 em { font-style: italic; color: var(--coral); }
.panel h2 { font-size: clamp(2.4rem, 6vw, 5rem); }
.sub { font-weight: 300; font-size: 1.12rem; max-width: 48ch; margin: 1.8rem 0 2.4rem; color: var(--muted); }
.panel-mid.center .sub { margin-left: auto; margin-right: auto; }
.cue { position: absolute; left: 50%; bottom: 34px; transform: translateX(-50%); z-index: 2; text-decoration: none; text-transform: uppercase; letter-spacing: 0.24em; font-size: 0.64rem; color: #fff; opacity: 0.85; }
.cue::after { content: ''; display: block; width: 1px; height: 38px; background: #fff; margin: 10px auto 0; animation: cue 1.8s ease-in-out infinite; transform-origin: top; }
@keyframes cue { 0%,100% { transform: scaleY(0.3); opacity: 0.4; } 50% { transform: scaleY(1); opacity: 1; } }

/* Story stats */
.stats { display: flex; gap: 2.8rem; flex-wrap: wrap; margin-top: 2.6rem; }
.stats strong { display: block; font-family: var(--display); font-size: 2.6rem; color: #fff; }
.stats span { font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); }

/* ---------- Rooms slider ---------- */
.rslides { position: absolute; inset: 0; z-index: 0; }
.rslide { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transform: scale(1.05); transition: opacity 0.9s ease, transform 1.4s ease; }
.rslide.is-active { opacity: 1; transform: scale(1); }
.rmeta { letter-spacing: 0.04em; color: var(--muted); margin-bottom: 1rem; }
.rprice { font-family: var(--display); font-size: 2.4rem; margin-bottom: 2rem; }
.rprice small { font-family: var(--body); font-size: 0.9rem; font-weight: 300; color: var(--muted); }
.rnav { position: absolute; right: clamp(22px, 5vw, 56px); bottom: 60px; z-index: 3; display: flex; gap: 12px; }
.rnav button { width: 56px; height: 56px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.5); background: rgba(0,0,0,0.2); color: #fff; font-size: 1.2rem; cursor: pointer; transition: background 0.25s, color 0.25s; }
.rnav button:hover { background: var(--coral); border-color: var(--coral); color: var(--ink); }

/* ---------- Amenities ---------- */
.amenities h2 { margin-bottom: 3rem; }
.amen-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.amen { background: var(--solid); padding: 38px 22px; display: flex; flex-direction: column; align-items: center; gap: 1rem; text-align: center; transition: background 0.25s; }
.amen:hover { background: #1d1d20; }
.amen svg { width: 30px; height: 30px; color: var(--coral); }
.amen span { font-size: 0.84rem; letter-spacing: 0.02em; color: var(--muted); }

/* ---------- Gallery filmstrip ---------- */
.gallery h2 { margin-bottom: 2.6rem; }
.film { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 16px; scrollbar-width: thin; scrollbar-color: var(--coral) transparent; }
.film::-webkit-scrollbar { height: 6px; }
.film::-webkit-scrollbar-thumb { background: var(--coral); border-radius: 6px; }
.film img { flex: 0 0 clamp(280px, 40vw, 480px); height: 360px; object-fit: cover; transition: filter 0.3s; }
.film img:hover { filter: brightness(1.1); }

/* ---------- Reserve ---------- */
.reserve-mid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(36px, 5vw, 80px); align-items: start; }
.reserve-form h2 { font-size: clamp(2rem, 4vw, 3.2rem); margin: 0.6rem 0; }
.form { margin-top: 1.8rem; display: grid; gap: 1.3rem; }
.f-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.3rem; }
.f { display: flex; flex-direction: column; }
.f label { text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.62rem; color: var(--muted); margin-bottom: 0.5rem; }
.f input, .f select { font-family: var(--body); font-size: 0.96rem; font-weight: 300; color: #fff; background: transparent; border: 0; border-bottom: 1px solid var(--line); border-radius: 0; padding: 0.7rem 0; transition: border-color 0.25s; }
.f input::placeholder { color: rgba(255,255,255,0.4); }
.f input:focus, .f select:focus { outline: none; border-bottom-color: var(--coral); }
.f select option { background: var(--solid); }
.form-status { min-height: 1.2rem; font-size: 0.9rem; font-weight: 400; }
.form-status.ok { color: var(--sage); } .form-status.err { color: var(--coral); }
.reserve-info h3 { font-size: 1.7rem; margin-bottom: 1rem; }
.addr { color: var(--muted); margin-bottom: 1.4rem; }
.ilist { list-style: none; display: grid; gap: 1rem; border-top: 1px solid var(--line); padding-top: 1.3rem; }
.ilist li { display: flex; flex-direction: column; }
.ilist li span { text-transform: uppercase; letter-spacing: 0.16em; font-size: 0.6rem; color: var(--coral); margin-bottom: 0.2rem; }
.ilist li a { text-decoration: none; }
.ilist li a:hover { color: var(--coral); }
.map { margin-top: 1.4rem; }
.map iframe { width: 100%; height: 180px; border: 0; display: block; filter: grayscale(0.4) brightness(0.85); }
.copy { margin-top: 1.6rem; font-size: 0.72rem; letter-spacing: 0.1em; color: rgba(255,255,255,0.4); }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.8s cubic-bezier(0.22,1,0.36,1), transform 0.8s cubic-bezier(0.22,1,0.36,1); }
.reveal.in-view { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .dots { display: none; }
  .amen-grid { grid-template-columns: repeat(2, 1fr); }
  .reserve-mid { grid-template-columns: 1fr; }
  .rnav { bottom: 30px; }
}
@media (max-width: 540px) {
  .amen-grid { grid-template-columns: 1fr 1fr; }
  .f-row { grid-template-columns: 1fr; }
  .panel-mid { padding-top: 100px; padding-bottom: 80px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, .reveal, .rslide, .cue::after { transition: none !important; animation: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
}
