/* ============================================================
   HAZEL'S VACATION RENTALS — Interior page components
   Loaded after theme.css on all sub-pages.
   ============================================================ */

/* Interior hero */
.page-hero { position:relative; color:#fff; padding: 150px 0 70px; margin-top:-82px; overflow:hidden; }
.page-hero::before { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(16,37,55,.62), rgba(16,37,55,.80)); z-index:1; }
.page-hero .ph-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.page-hero .container { position:relative; z-index:2; }
.page-hero h1 { color:#fff; font-size: clamp(2.3rem, 5vw, 3.6rem); max-width: 820px; }
.page-hero p { color: rgba(255,255,255,.9); max-width: 640px; font-size:1.1rem; margin-bottom:0; }
.page-hero .script { display:block; margin-bottom:2px; }
.crumbs { font-family:var(--display); font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; color: rgba(255,255,255,.72); margin-bottom:18px; }
.crumbs a:hover { color: var(--gold-soft); }
.crumbs span { color: var(--gold-soft); }

/* Listing intro bar */
.listing-meta { display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:40px; }
.listing-meta .count { font-family:var(--display); color:var(--slate); font-size:.95rem; }

/* Property detail gallery */
.pdp-gallery { display:grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap:12px; }
.pdp-gallery a { display:block; overflow:hidden; border-radius:var(--radius); position:relative; }
.pdp-gallery a:first-child { grid-row: 1 / 3; grid-column: 1; }
.pdp-gallery img { width:100%; height:100%; object-fit:cover; transition: transform .8s var(--ease); }
.pdp-gallery a:hover img { transform: scale(1.05); }
.pdp-gallery .more-photos { position:absolute; inset:0; background:rgba(16,37,55,.55); color:#fff; display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:500; letter-spacing:.04em; }

.pdp-layout { display:grid; grid-template-columns: 1.7fr 1fr; gap: clamp(32px,5vw,64px); align-items:start; margin-top: 56px; }
.pdp-main h2 { font-size:1.7rem; margin-top:42px; }
.pdp-main h2:first-child { margin-top:0; }
.pdp-title { display:flex; flex-direction:column; gap:6px; margin-bottom:8px; }
.pdp-title h1 { font-size: clamp(1.9rem,3.6vw,2.7rem); margin:0; }
.pdp-title .loc { color:var(--teal-deep); font-family:var(--display); letter-spacing:.04em; text-transform:uppercase; font-size:.9rem; }

.amenities { list-style:none; padding:0; margin:18px 0 0; display:grid; grid-template-columns: repeat(2,1fr); gap:14px 26px; }
.amenities li { display:flex; gap:12px; align-items:center; font-size:.98rem; color:var(--ink); }
.amenities svg { width:22px; height:22px; color:var(--teal); flex:0 0 auto; }

.quick-specs { display:flex; gap:28px; flex-wrap:wrap; padding:20px 0; border-block:1px solid var(--line); margin:6px 0 26px; }
.quick-specs .qs b { font-family:var(--display); font-size:1.5rem; color:var(--navy); display:block; line-height:1; }
.quick-specs .qs span { font-size:.8rem; text-transform:uppercase; letter-spacing:.05em; color:var(--slate); }

/* Booking sidebar */
.book-card { position:sticky; top:100px; background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:28px; }
.book-card .bc-from { display:flex; align-items:baseline; gap:8px; margin-bottom:4px; }
.book-card .bc-from b { font-family:var(--display); font-size:1.6rem; color:var(--navy); }
.book-card .bc-from span { color:var(--slate); font-size:.9rem; }
.book-card .bc-rating { color:var(--gold); font-size:.92rem; margin-bottom:18px; }
.book-card .btn { width:100%; justify-content:center; margin-bottom:12px; }
.book-card .bc-note { font-size:.82rem; color:var(--slate); text-align:center; margin:8px 0 0; }
.book-card hr { border:0; border-top:1px solid var(--line); margin:22px 0; }
.book-card .bc-host { display:flex; gap:14px; align-items:center; }
.book-card .bc-host img { width:48px; height:48px; }
.book-card .bc-host small { color:var(--slate); font-size:.84rem; }

/* Availability */
.avail-note { background:var(--sand); border-radius:var(--radius); padding:22px 24px; display:flex; gap:16px; align-items:flex-start; }
.avail-note svg { width:26px; height:26px; color:var(--teal); flex:0 0 auto; margin-top:2px; }
.avail-note p { margin:0; font-size:.96rem; color:#3f464d; }
.cal-wrap { display:grid; grid-template-columns: repeat(2,1fr); gap:28px; margin-top:22px; }
.cal { border:1px solid var(--line); border-radius:var(--radius); padding:16px; }
.cal h4 { font-size:1rem; text-align:center; margin-bottom:12px; color:var(--navy); }
.cal table { width:100%; border-collapse:collapse; }
.cal th { font-size:.7rem; color:var(--slate); font-weight:600; padding:4px 0; font-family:var(--display); }
.cal td { text-align:center; padding:6px 0; font-size:.84rem; color:var(--ink); }
.cal td.out { color:#c9cdd2; }
.cal td.booked { color:#c9cdd2; text-decoration:line-through; }
.cal td.today { box-shadow: inset 0 0 0 1.5px var(--teal); border-radius:50%; }
.cal-legend { display:flex; gap:20px; justify-content:center; margin-top:18px; font-size:.82rem; color:var(--slate); }
.cal-legend i { display:inline-block; width:11px; height:11px; border-radius:50%; margin-right:6px; vertical-align:middle; }
.cal-legend .i-open{ background:#fff; box-shadow:inset 0 0 0 1.5px var(--teal); } .cal-legend .i-booked{ background:#c9cdd2; }

/* Feature rows (service pages) */
.feature-row { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,68px); align-items:center; margin-bottom: clamp(48px,7vw,88px); }
.feature-row:last-child { margin-bottom:0; }
.feature-row.flip .fr-media { order:2; }
.fr-media img { border-radius:var(--radius); box-shadow:var(--shadow); aspect-ratio:4/3; object-fit:cover; width:100%; }
.fr-copy h3 { font-size: clamp(1.5rem,2.8vw,2rem); }
.fr-copy ul { list-style:none; padding:0; margin:18px 0 0; }
.fr-copy li { display:flex; gap:12px; margin-bottom:12px; color:var(--ink); }
.fr-copy li svg { width:22px; height:22px; color:var(--teal); flex:0 0 auto; margin-top:3px; }

/* Steps */
.steps { display:grid; grid-template-columns: repeat(4,1fr); gap:24px; }
.step .n { font-family:var(--display); font-weight:600; font-size:1rem; color:var(--navy-900); background:var(--gold); width:42px; height:42px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.step h4 { font-size:1.15rem; margin-bottom:.3em; }
.step p { color:var(--slate); font-size:.94rem; }
.section.navy .step p { color:rgba(255,255,255,.76); }
.section.navy .step h4 { color:#fff; }

/* Plans */
.plans { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start; }
.plan { background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:34px 30px; }
.plan.feature { border-color:var(--gold); box-shadow:var(--shadow); position:relative; }
.plan.feature::before { content:"Most popular"; position:absolute; top:-12px; left:30px; background:var(--gold); color:var(--navy-900); font-family:var(--display); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:5px 12px; border-radius:2px; }
.plan h3 { font-size:1.3rem; }
.plan .price { font-family:var(--display); font-size:2.2rem; color:var(--teal-deep); margin:6px 0 4px; }
.plan .price span { font-size:.95rem; color:var(--slate); }
.plan ul { list-style:none; padding:0; margin:18px 0 0; }
.plan li { padding:9px 0; border-top:1px solid var(--line); font-size:.94rem; color:var(--ink); display:flex; gap:10px; }
.plan li svg { width:18px; height:18px; color:var(--teal); flex:0 0 auto; margin-top:3px; }

/* FAQ */
.faq { max-width:820px; margin-inline:auto; }
.faq details { border-bottom:1px solid var(--line); padding:18px 0; }
.faq summary { font-family:var(--display); font-weight:500; font-size:1.1rem; color:var(--navy); cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:16px; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after { content:"+"; color:var(--teal); font-size:1.5rem; transition:transform .3s var(--ease); }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq details p { margin:14px 0 0; color:var(--slate); }

/* Forms */
.form-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(32px,5vw,64px); align-items:start; }
.form { background:#fff; border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-sm); padding: clamp(26px,4vw,40px); }
.field { margin-bottom:18px; }
.field.row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field label { display:block; font-family:var(--display); font-weight:500; font-size:.86rem; letter-spacing:.02em; color:var(--navy); margin-bottom:7px; }
.field input, .field select, .field textarea {
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:var(--radius);
  font-family:var(--body); font-size:1rem; color:var(--ink); background:#fff; transition:border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(0,167,158,.12); }
.field textarea { resize:vertical; min-height:130px; }
.form .btn { width:100%; justify-content:center; margin-top:6px; }
.form-aside h3 { font-size:1.4rem; }
.contact-lines { list-style:none; padding:0; margin:22px 0 0; }
.contact-lines li { display:flex; gap:14px; align-items:flex-start; margin-bottom:18px; }
.contact-lines svg { width:24px; height:24px; color:var(--teal); flex:0 0 auto; margin-top:2px; }
.contact-lines b { display:block; font-family:var(--display); color:var(--navy); }
.contact-lines a:hover { color:var(--teal-deep); }
.form-success { display:none; background:#eaf7f5; border:1px solid var(--teal); border-radius:var(--radius); padding:16px 18px; color:var(--teal-deep); margin-bottom:20px; }
.form-success.show { display:block; }

/* Legal prose */
.prose { max-width:820px; }
.prose h2 { font-size:1.5rem; margin-top:42px; }
.prose h3 { font-size:1.15rem; margin-top:28px; }
.prose p, .prose li { color:#3f464d; }
.prose ul { padding-left:20px; }
.prose li { margin-bottom:8px; }
.prose .updated { color:var(--slate); font-size:.92rem; font-style:italic; }
.prose a { color:var(--teal-deep); text-decoration:underline; }

/* Lightbox */
.lb { position:fixed; inset:0; background:rgba(16,37,55,.94); z-index:200; display:none; align-items:center; justify-content:center; padding:30px; }
.lb.open { display:flex; }
.lb img { max-width:92vw; max-height:88vh; border-radius:var(--radius); box-shadow:var(--shadow-lg); }
.lb button { position:absolute; background:none; border:0; color:#fff; cursor:pointer; font-size:2rem; line-height:1; padding:14px; }
.lb .lb-close { top:14px; right:20px; }
.lb .lb-prev { left:10px; top:50%; transform:translateY(-50%); }
.lb .lb-next { right:10px; top:50%; transform:translateY(-50%); }
.lb .lb-count { position:absolute; bottom:20px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.8); font-family:var(--display); font-size:.9rem; letter-spacing:.05em; }

@media (max-width: 980px){
  .pdp-layout { grid-template-columns:1fr; }
  .book-card { position:static; }
  .feature-row, .feature-row.flip .fr-media { grid-template-columns:1fr; order:0; }
  .steps { grid-template-columns:repeat(2,1fr); }
  .plans { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .cal-wrap { grid-template-columns:1fr; }
  .pdp-gallery { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .pdp-gallery a:first-child { grid-row:auto; grid-column: 1 / 3; }
}
@media (max-width:760px){
  .steps { grid-template-columns:1fr; }
  .amenities { grid-template-columns:1fr; }
  .field.row { grid-template-columns:1fr; }
}
