:root {
  --cream: #f4efe4;
  --ink: #20231e;
  --terracotta: #bd4e35;
  --sun: #f3b51b;
  --cobalt: #174e77;
  --sage: #788a72;
  --line: rgba(32, 35, 30, .18);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
}
body.dialog-open { overflow: hidden; }
img {
  display: block;
  width: 100%;
  background: #ddd4c3;
  opacity: 1;
  filter: none;
  transform: none;
}
img.image-loaded {
  opacity: 1;
  filter: none;
  transform: none;
}
.brand-logo {
  background: transparent;
}
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }

.site-header {
  position: fixed;
  z-index: 10;
  top: 0;
  left: 0;
  right: 0;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 30px;
  padding: 8px clamp(24px, 5vw, 72px);
  color: white;
  background: rgba(24, 29, 25, .72);
  border-bottom: 1px solid rgba(255, 255, 255, .12);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: background .25s ease, padding .25s ease;
}
.wordmark {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  border: 0;
  outline: 0;
  background: transparent;
  box-shadow: none;
  font-family: "Fraunces", Georgia, serif;
  /*font-family: Cormorant Garamond;*/
  font-size: 34px;
  font-weight: 600;
  font-optical-sizing: auto;
  letter-spacing: -.035em;
}
.brand-logo { width: 64px; height: 64px; border: 0; outline: 0; background: transparent; box-shadow: none; object-fit: contain; filter: drop-shadow(0 1px 1px rgba(0,0,0,.2)); }
.site-header .brand-logo {
  width: 85px;
  height: 85px;
  filter:
    drop-shadow(1px 0 0 rgba(238, 190, 73, .48))
    drop-shadow(-1px 0 0 rgba(238, 190, 73, .48))
    drop-shadow(0 1px 0 rgba(238, 190, 73, .48))
    drop-shadow(0 -1px 0 rgba(238, 190, 73, .48))
    drop-shadow(0 6px 8px rgba(0, 0, 0, .9));
}
nav {
  display: flex;
  gap: 34px;
  font-family: "Fraunces", Georgia, serif;
  font-size: 17px;
  font-weight: 600;
  font-optical-sizing: auto;
  letter-spacing: -.02em;
}
nav a { opacity: .86; }
nav a:hover { opacity: 1; }
.header-book { justify-self: end; }
.menu-button { display: none; border: 0; background: none; padding: 8px; }
.menu-button span { display: block; width: 24px; height: 2px; margin: 5px; background: white; }

.button {
  border: 0;
  border-radius: 0;
  padding: 15px 21px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
}
.button-dark { background: var(--ink); color: white; }
.button-sun { display: flex; justify-content: space-between; align-items: center; gap: 28px; background: var(--sun); color: var(--ink); }
.button-outline { display: inline-block; border: 1px solid rgba(255,255,255,.5); color: white; }

.hero { position: relative; min-height: 92vh; display: flex; align-items: flex-end; overflow: hidden; color: white; }
.hero-image { position: absolute; inset: 0; height: 100%; object-fit: cover; object-position: center; transform: scale(1.015); }
.hero-wash { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(17,25,21,.75), rgba(17,25,21,.18) 68%), linear-gradient(0deg, rgba(17,25,21,.48), transparent 45%); }
.hero-copy { position: relative; z-index: 1; width: min(780px, 80%); margin: 0 0 12vh clamp(24px, 8vw, 125px); }
.kicker { margin: 0 0 22px; color: var(--terracotta); font-size: 10px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.kicker.light { color: #f6c95b; }
h1, h2, h3, blockquote { font-family: Georgia, "Times New Roman", serif; font-weight: 400; }
h1 { margin: 0; font-size: clamp(62px, 9vw, 126px); line-height: .85; letter-spacing: -.065em; }
h1 em { color: #ffd15b; font-weight: 400; }
.hero-intro { max-width: 560px; margin: 32px 0 0 8px; font-size: clamp(16px, 1.5vw, 21px); line-height: 1.55; }
.quick-facts {
  position: absolute;
  right: clamp(24px, 5vw, 72px);
  bottom: 10vh;
  display: grid;
  grid-template-columns: repeat(2, 120px);
  background: rgba(21,29,25,.8);
  backdrop-filter: blur(12px);
}
.quick-facts div { padding: 18px 20px; border: 1px solid rgba(255,255,255,.18); }
.quick-facts strong, .quick-facts span { display: block; }
.quick-facts strong { font: 400 24px Georgia, serif; }
.quick-facts span { margin-top: 4px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; opacity: .68; }
.scroll-cue { position: absolute; left: 18px; bottom: 70px; border: 0; background: none; color: white; writing-mode: vertical-rl; transform: rotate(180deg); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; cursor: pointer; }
.scroll-cue span { margin-top: 12px; }

.booking-ribbon {
  position: relative;
  z-index: 3;
  width: min(1050px, calc(100% - 48px));
  margin: -42px auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr) auto;
  background: white;
  box-shadow: 0 24px 60px rgba(28,35,29,.16);
}
.booking-field { padding: 17px 22px; border-right: 1px solid var(--line); }
.booking-field label { display: block; margin-bottom: 5px; color: #77786f; font-size: 9px; letter-spacing: .15em; text-transform: uppercase; }
.booking-field input, .booking-field select { width: 100%; border: 0; outline: 0; background: transparent; color: var(--ink); }
.booking-ribbon .button { margin: 8px; min-width: 215px; }

.section { padding: clamp(80px, 10vw, 145px) clamp(24px, 8vw, 125px); }
.story { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 12vw; align-items: start; overflow: hidden; }
.story-heading, .story-copy { position: relative; z-index: 1; }
.story-watermark { position: absolute; right: 5vw; bottom: 10px; width: min(280px, 24vw); height: auto; border: 0; background: transparent; box-shadow: none; opacity: .045; pointer-events: none; transform: rotate(-6deg); }
h2 { margin: 0; font-size: clamp(44px, 5.4vw, 78px); line-height: .96; letter-spacing: -.045em; }
.story-copy { max-width: 570px; padding-top: 35px; }
.story-copy p { color: #555b53; line-height: 1.75; }
.story-copy .lead { margin-top: 0; color: var(--ink); font: 400 clamp(21px, 2vw, 29px)/1.45 Georgia, serif; }
.text-link { display: inline-flex; align-items: center; gap: 24px; margin-top: 18px; padding-bottom: 7px; border-bottom: 1px solid currentColor; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }

.feature-grid { padding-top: 0; display: grid; grid-template-columns: 1fr 1fr; }
.feature-grid > * { min-height: 590px; }
.feature-image { margin: 0; overflow: hidden; }
.feature-image img { height: 100%; object-fit: cover; transition: transform .8s ease; }
.feature-image:hover img { transform: scale(1.03); }
.feature-copy { display: flex; justify-content: space-between; flex-direction: column; padding: clamp(35px, 5vw, 70px); color: white; }
.feature-copy.terracotta { background: var(--terracotta); }
.feature-copy.cobalt { background: var(--cobalt); }
.feature-number { font: 18px Georgia, serif; opacity: .7; }
.feature-copy h3 { max-width: 560px; margin: 0 0 24px; font-size: clamp(37px, 4vw, 58px); line-height: 1.02; letter-spacing: -.035em; }
.feature-copy p:last-child { max-width: 460px; margin: 0; line-height: 1.65; opacity: .78; }

.amenities { display: grid; grid-template-columns: .8fr 1.2fr; gap: 10vw; background: #ece5d7; }
.amenity-list { border-top: 1px solid var(--line); }
.amenity-list div { display: grid; grid-template-columns: 50px 1fr; gap: 20px; padding: 22px 0; border-bottom: 1px solid var(--line); }
.amenity-list span { color: var(--terracotta); font: 13px Georgia, serif; }
.amenity-list strong { font-size: 14px; }

.terrace-story { display: grid; grid-template-columns: minmax(0, 1.03fr) minmax(0, .97fr); align-items: start; gap: 0; padding: 0; background: #dfe4dc; }
.terrace-main { position: sticky; top: 76px; width: 100%; height: calc(100vh - 76px); min-height: 720px; max-height: 920px; margin: 0; overflow: hidden; }
.terrace-main img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.terrace-main figcaption, .terrace-pair figcaption { position: absolute; left: 15px; bottom: 14px; padding: 8px 10px; background: rgba(31,36,31,.82); color: white; font-size: 9px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }
.terrace-content { min-width: 0; padding: clamp(65px, 7vw, 110px); }
.terrace-content h2 { margin: 20px 0 32px; }
.terrace-lead { max-width: 610px; font: 400 clamp(20px, 1.8vw, 27px)/1.5 Georgia, serif; }
.terrace-content > p:not(.kicker):not(.terrace-lead) { max-width: 590px; color: #555b53; line-height: 1.75; }
.terrace-details { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); margin: 38px 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.terrace-details div { min-height: 115px; padding: 18px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.terrace-details strong, .terrace-details span { display: block; }
.terrace-details strong { margin-bottom: 20px; color: var(--terracotta); font: 600 18px "Fraunces", Georgia, serif; }
.terrace-details span { color: #62675f; font-size: 11px; line-height: 1.5; }
.terrace-pair { display: grid; grid-template-columns: 1fr 1.3fr; gap: 12px; }
.terrace-pair figure { position: relative; min-height: 260px; margin: 0; overflow: hidden; }
.terrace-pair img { height: 100%; object-fit: cover; }
.terrace-pair figure:first-child img { object-position: center; }
.terrace-pair figure:last-child img { object-position: center 60%; }
.terrace-level { margin-top: 52px; }
.terrace-level-heading { display: grid; grid-template-columns: 90px 1fr; gap: 8px 20px; margin-bottom: 20px; }
.terrace-level-heading span { grid-row: 1 / span 2; padding-top: 8px; color: var(--terracotta); font-size: 10px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.terrace-level-heading h3 { margin: 0; font: 600 clamp(24px, 2vw, 34px)/1.1 "Fraunces", Georgia, serif; }
.terrace-level-heading p { max-width: 520px; margin: 0; color: #62675f; font-size: 13px; line-height: 1.65; }
.terrace-level-gallery { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); grid-auto-rows: 190px; gap: 10px; }
.terrace-level-gallery figure, .terrace-upper-image { position: relative; min-width: 0; margin: 0; overflow: hidden; }
.terrace-level-gallery .terrace-level-feature { grid-column: 1 / -1; grid-row: span 2; }
.terrace-level-gallery img, .terrace-upper-image img { width: 100%; height: 100%; object-fit: cover; }
.terrace-level-gallery figure:nth-child(2) img { object-position: center 60%; }
.terrace-level-upper { padding-top: 40px; border-top: 1px solid var(--line); }
.terrace-upper-image { min-height: 390px; }
.terrace-upper-image figcaption { position: absolute; left: 15px; bottom: 14px; padding: 8px 10px; background: rgba(31,36,31,.82); color: #fff; font-size: 9px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }

.experience-story {
  position: relative;
  overflow: hidden;
  background: #25342d;
  color: white;
}
.experience-story::after {
  content: "CT";
  position: absolute;
  right: -20px;
  top: 10px;
  color: rgba(255, 255, 255, .025);
  font: 600 clamp(220px, 35vw, 520px)/1 "Fraunces", Georgia, serif;
  letter-spacing: -.12em;
  pointer-events: none;
}
.experience-intro { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 8vw; align-items: end; }
.experience-lead { max-width: 570px; margin: 0 0 4px; color: #cbd3cc; font: 400 clamp(20px, 2vw, 28px)/1.5 Georgia, serif; }
.experience-columns { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 6vw; margin-top: 90px; }
.experience-columns article { padding-top: 25px; border-top: 1px solid rgba(255,255,255,.25); }
.experience-index { color: #f6c95b; font: 16px Georgia, serif; }
.experience-columns h3 { max-width: 500px; margin: 25px 0; font-size: clamp(32px, 3.5vw, 48px); line-height: 1.05; }
.experience-columns p { max-width: 570px; color: #b9c3bb; line-height: 1.75; }
.experience-moments { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 80px; border-top: 1px solid rgba(255,255,255,.2); border-left: 1px solid rgba(255,255,255,.2); }
.experience-moments div { min-height: 150px; padding: 25px; border-right: 1px solid rgba(255,255,255,.2); border-bottom: 1px solid rgba(255,255,255,.2); }
.experience-moments strong, .experience-moments span { display: block; }
.experience-moments strong { margin-bottom: 26px; color: #f6c95b; font: 600 22px "Fraunces", Georgia, serif; }
.experience-moments span { color: #b9c3bb; font-size: 13px; line-height: 1.5; }

.gallery { padding-right: 0; overflow: hidden; }
.section-heading.inline { display: flex; justify-content: space-between; align-items: end; padding-right: clamp(24px, 8vw, 125px); margin-bottom: 45px; }
.gallery-next { border: 0; background: transparent; cursor: pointer; }
.gallery-track { display: flex; gap: 18px; overflow-x: auto; padding: 0 clamp(24px, 8vw, 125px) 20px 0; scrollbar-width: none; scroll-snap-type: x mandatory; }
.gallery-track::-webkit-scrollbar { display: none; }
.gallery-card { flex: 0 0 min(33vw, 410px); margin: 0; scroll-snap-align: start; }
.gallery-card.large { flex-basis: min(45vw, 610px); }
.gallery-card.portrait { flex-basis: min(28vw, 350px); }
.gallery-card.low-res { flex-basis: min(25vw, 320px); }
.gallery-card img { height: 470px; object-fit: cover; }
.gallery-card.low-res img { height: 390px; margin-top: 40px; }
.gallery-card figcaption { display: flex; justify-content: space-between; gap: 20px; padding-top: 12px; color: #686d65; font-size: 11px; letter-spacing: .11em; text-transform: uppercase; }
.gallery-card figcaption b { color: var(--terracotta); font-weight: 700; }

.coast-story { background: #e8e1d3; overflow: hidden; }
.coast-heading { display: grid; grid-template-columns: 1.15fr .85fr; gap: 8vw; align-items: end; margin-bottom: 65px; }
.coast-heading h2 { margin-bottom: 0; }
.coast-intro { max-width: 540px; }
.coast-intro p { margin: 0 0 16px; color: #555b53; font: 400 clamp(17px, 1.55vw, 21px)/1.65 Georgia, serif; }
.coast-intro span { display: inline-block; margin-top: 12px; padding: 10px 14px; background: var(--sun); font-size: 11px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; }
.coast-collage { display: grid; grid-template-columns: 1.35fr .65fr; grid-template-rows: 390px 330px; gap: 18px; }
.coast-image { position: relative; min-width: 0; margin: 0; overflow: hidden; background: #c8c9bf; }
.coast-image img { height: 100%; object-fit: cover; transition: transform .7s ease; }
.coast-image:hover img { transform: scale(1.025); }
.coast-image figcaption { position: absolute; left: 18px; bottom: 18px; padding: 9px 12px; background: rgba(32,35,30,.82); color: white; font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.coast-main { grid-row: 1 / 3; }
.coast-main img { object-position: center 58%; }
.coast-wide { grid-row: 1 / 3; }
.coast-wide img { object-position: center 46%; }
.photo-credit { margin: 14px 0 0; color: #73776f; font-size: 10px; letter-spacing: .04em; }
.photo-credit a { border-bottom: 1px solid currentColor; }

.calpe-character { background: var(--ink); color: white; }
.character-heading { display: grid; grid-template-columns: .65fr 1.35fr 1fr; gap: 5vw; align-items: end; margin-bottom: 65px; }
.character-heading .kicker { align-self: start; }
.character-heading h2 { margin: 0; }
.character-heading > p:last-child { max-width: 440px; margin: 0 0 8px; color: #b9c3bb; font: 400 clamp(17px, 1.5vw, 21px)/1.65 Georgia, serif; }
.character-grid { display: grid; grid-template-columns: 1.05fr .72fr 1.05fr; grid-template-rows: 360px 390px; gap: 18px; }
.character-card { position: relative; min-width: 0; margin: 0; overflow: hidden; }
.character-card img { height: 100%; object-fit: cover; transition: transform .75s ease; }
.character-card:hover img { transform: scale(1.025); }
.character-card:after { content: ""; position: absolute; inset: 35% 0 0; background: linear-gradient(transparent, rgba(16,20,17,.88)); pointer-events: none; }
.character-card figcaption { position: absolute; z-index: 1; left: 22px; right: 22px; bottom: 20px; display: grid; grid-template-columns: 35px 1fr; color: white; }
.character-card figcaption span { grid-row: 1 / 3; color: #f6c95b; font: 18px Georgia, serif; }
.character-card figcaption strong { font: 600 clamp(19px, 1.7vw, 25px)/1.15 "Fraunces", Georgia, serif; }
.character-card figcaption small { margin-top: 5px; color: #ccd2cc; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; }
.character-old-town { grid-row: 1 / 3; }
.character-old-town img { object-position: center; }
.character-architecture { grid-column: 3; grid-row: 1 / 3; }
.character-architecture img { object-position: 54% center; }
.character-note { grid-row: 1 / 3; align-self: stretch; display: flex; flex-direction: column; justify-content: center; width: 100%; height: 100%; padding: clamp(28px, 4vw, 55px); background: var(--terracotta); }
.character-note span { color: #ffd46c; font-size: 10px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.character-note h3 { margin: 25px 0 20px; font-size: clamp(31px, 3vw, 45px); line-height: 1.03; }
.character-note p { margin: 0; color: #f3d8d1; font-size: 13px; line-height: 1.7; }
.character-lane, .character-ifach { display: none; }

.ifach-hike { display: grid; grid-template-columns: 1.05fr .95fr; gap: 0; padding: 0; background: var(--sun); }
.hike-visual { position: relative; min-height: 860px; overflow: hidden; }
.hike-visual:after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(18,25,22,.35), transparent 55%); pointer-events: none; }
.hike-visual img { height: 100%; object-fit: cover; object-position: 55% center; }
.hike-height { position: absolute; z-index: 1; left: clamp(24px, 5vw, 70px); bottom: clamp(28px, 5vw, 70px); display: flex; align-items: end; gap: 16px; color: white; }
.hike-height strong { font: 600 clamp(74px, 9vw, 130px)/.72 "Fraunces", Georgia, serif; letter-spacing: -.07em; }
.hike-height span { padding-bottom: 2px; font-size: 10px; font-weight: 700; line-height: 1.4; letter-spacing: .11em; text-transform: uppercase; }
.hike-content { padding: clamp(65px, 7vw, 110px); }
.hike-content h2 { margin: 20px 0 35px; font-size: clamp(54px, 6vw, 88px); }
.hike-lead { max-width: 610px; margin: 0 0 48px; font: 400 clamp(19px, 1.7vw, 24px)/1.55 Georgia, serif; }
.hike-stages { border-top: 1px solid rgba(32,35,30,.32); }
.hike-stages article { display: grid; grid-template-columns: 48px 1fr; gap: 15px; padding: 23px 0; border-bottom: 1px solid rgba(32,35,30,.32); }
.hike-stages article > span { color: var(--terracotta); font: 18px Georgia, serif; }
.hike-stages h3 { margin: 0 0 8px; font-size: 24px; }
.hike-stages p { max-width: 540px; margin: 0; color: #4e514b; font-size: 13px; line-height: 1.65; }
.hike-actions { display: flex; align-items: center; gap: 24px; margin-top: 38px; }
.hike-actions p { max-width: 280px; margin: 0; color: #55584f; font-size: 10px; line-height: 1.5; }

.ifach-cats { display: grid; grid-template-columns: .9fr 1.1fr; padding: 0; background: var(--terracotta); color: white; }
.cats-copy { padding: clamp(65px, 8vw, 125px); }
.cats-number { display: inline-block; margin: 25px 0 18px; padding: 9px 13px; border: 1px solid rgba(255,255,255,.4); color: #ffd46c; font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.cats-copy h2 { margin: 0 0 35px; font-size: clamp(55px, 6.5vw, 92px); }
.cats-lead { max-width: 620px; font: 400 clamp(21px, 1.9vw, 28px)/1.5 Georgia, serif; }
.cats-copy > p:not(.kicker):not(.cats-lead) { max-width: 580px; color: #f1d5ce; line-height: 1.75; }
.cats-note { display: grid; grid-template-columns: 150px 1fr; gap: 24px; max-width: 620px; margin: 42px 0 32px; padding: 22px 0; border-top: 1px solid rgba(255,255,255,.3); border-bottom: 1px solid rgba(255,255,255,.3); }
.cats-note strong { color: #ffd46c; font: 600 18px "Fraunces", Georgia, serif; }
.cats-note span { color: #f1d5ce; font-size: 12px; line-height: 1.6; }
.cats-source { color: white; }
.cats-gallery { position: relative; display: grid; grid-template-rows: 1.35fr .65fr; min-height: 800px; gap: 12px; padding: 12px; background: #1c211c; overflow: hidden; }
.cats-photo { position: relative; min-height: 0; margin: 0; overflow: hidden; }
.cats-photo img { height: 100%; object-fit: cover; transition: transform .75s ease; }
.cats-photo:hover img { transform: scale(1.025); }
.cats-photo-main img { object-position: center 52%; }
.cats-photo-detail img { object-position: center 58%; }
.cats-photo figcaption { position: absolute; left: 14px; bottom: 13px; padding: 8px 10px; background: rgba(28,33,28,.82); color: white; font-size: 9px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; }
.cats-gallery > p { position: absolute; z-index: 2; right: clamp(25px, 4vw, 55px); top: 44%; margin: 0; text-align: right; color: white; text-shadow: 0 2px 18px rgba(0,0,0,.75); font: 600 clamp(25px, 2.8vw, 42px)/1.1 "Fraunces", Georgia, serif; }

.location { display: grid; grid-template-columns: 1.15fr .85fr; padding: 0; background: var(--cobalt); color: white; }
.location-photo { position: relative; min-height: 720px; }
.location-photo img { height: 100%; object-fit: cover; }
.map-pin { position: absolute; left: 54%; top: 45%; padding: 9px 12px; background: var(--sun); color: var(--ink); font-size: 11px; font-weight: 700; }
.map-pin:after { content: ""; position: absolute; bottom: -7px; left: 15px; border: 7px solid transparent; border-top-color: var(--sun); border-bottom: 0; }
.location-copy { padding: clamp(55px, 8vw, 115px); }
.location-copy > p:not(.kicker) { max-width: 470px; line-height: 1.7; opacity: .77; }
.distances { padding: 0; margin: 42px 0; list-style: none; border-top: 1px solid rgba(255,255,255,.25); }
.distances li { display: grid; grid-template-columns: 90px 1fr; padding: 17px 0; border-bottom: 1px solid rgba(255,255,255,.25); font-size: 13px; }
.distances strong { color: #ffd15b; font: 400 18px Georgia, serif; }
.distances span { align-self: center; }

.quote { text-align: center; }
.quote-mark { display: block; color: var(--terracotta); font: 80px/.7 Georgia, serif; }
blockquote { max-width: 950px; margin: 25px auto 42px; font-size: clamp(38px, 5vw, 70px); line-height: 1.08; letter-spacing: -.04em; }

footer { position: relative; display: grid; grid-template-columns: 1.35fr .65fr .9fr 1fr; gap: clamp(35px, 5vw, 85px); padding: 80px clamp(24px, 8vw, 125px) 105px; background: var(--ink); color: white; }
.footer-brand p { max-width: 300px; color: #aeb5ac; line-height: 1.6; }
.light-mark { margin-bottom: 18px; font-size: 34px; font-family: Cormorant Garamond; font-size: 34px;}
.footer-logo {
  width: 88px;
  height: 88px;
  filter:
    drop-shadow(1px 0 0 rgba(238, 190, 73, .48))
    drop-shadow(-1px 0 0 rgba(238, 190, 73, .48))
    drop-shadow(0 1px 0 rgba(238, 190, 73, .48))
    drop-shadow(0 -1px 0 rgba(238, 190, 73, .48))
    drop-shadow(0 6px 8px rgba(0, 0, 0, .92));
}
footer > div:not(.footer-brand) { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; font-size: 15px; color: #b7bdb4; }
.footer-label { margin: 0 0 10px; color: #f3ca67; font-size: 9px; font-weight: 700; letter-spacing: .17em; text-transform: uppercase; }
.footer-social { width: 100%; }
.footer-social a { display: grid; grid-template-columns: 28px 1fr auto; align-items: center; gap: 10px; width: 100%; padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.13); transition: color .2s ease, border-color .2s ease; }
.footer-social a:hover { color: white; border-color: rgba(255,255,255,.4); }
.social-mark { display: grid; place-items: center; width: 25px; height: 25px; border: 1px solid #f3ca67; border-radius: 50%; color: #f3ca67; font: 700 11px Arial, sans-serif; }
.social-mark-wide { font-size: 9px; }
.social-arrow { color: #f3ca67; font-size: 13px; }
.copyright { position: absolute; left: clamp(24px, 8vw, 125px); bottom: 30px; color: #727970; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; }

.mobile-book { display: none; }
.booking-dialog { width: min(620px, calc(100% - 28px)); max-height: calc(100vh - 30px); padding: 48px; border: 0; background: var(--cream); color: var(--ink); box-shadow: 0 30px 100px rgba(0,0,0,.35); }
.booking-dialog::backdrop { background: rgba(16,24,20,.75); backdrop-filter: blur(4px); }
.booking-dialog h2 { margin-bottom: 14px; font-size: 46px; }
.booking-dialog > p:not(.kicker) { color: #62675f; line-height: 1.6; }
.dialog-close { position: absolute; top: 18px; right: 20px; border: 0; background: none; font-size: 30px; cursor: pointer; }
.booking-dialog form { display: grid; gap: 15px; margin-top: 28px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.booking-dialog label { display: grid; gap: 7px; color: #555b53; font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.booking-dialog input, .booking-dialog select, .booking-dialog textarea { width: 100%; border: 1px solid var(--line); background: white; padding: 13px; color: var(--ink); text-transform: none; }
.submit-enquiry { width: 100%; justify-content: center; margin-top: 4px; }
.form-note { margin: 0; text-align: center; color: #868a83; font-size: 10px; }
.form-success { padding: 35px 0 15px; text-align: center; }
.form-success span { display: grid; place-items: center; width: 60px; height: 60px; margin: auto; border-radius: 50%; background: var(--sun); font-size: 25px; }
.form-success h3 { margin-bottom: 8px; font-size: 34px; }
.form-success p { color: #62675f; line-height: 1.6; }

@media (min-width: 1400px) {
  .ifach-hike { grid-template-columns: 1.08fr .92fr; min-height: 820px; max-height: 900px; }
  .hike-visual { min-height: 0; height: 100%; }
  .hike-content { display: flex; flex-direction: column; justify-content: center; padding: 60px clamp(65px, 5vw, 95px); }
  .hike-content h2 { margin: 14px 0 24px; font-size: clamp(58px, 4.5vw, 78px); line-height: .94; }
  .hike-lead { margin-bottom: 30px; font-size: 21px; }
  .hike-stages article { padding: 16px 0; }
  .hike-stages h3 { font-size: 21px; }
  .hike-actions { margin-top: 28px; }

  .ifach-cats { grid-template-columns: .82fr 1.18fr; min-height: 1080px; }
  .cats-copy { display: flex; flex-direction: column; justify-content: center; padding: 60px clamp(65px, 5vw, 95px); overflow: hidden; }
  .cats-number { margin: 18px 0 13px; }
  .cats-copy h2 { margin-bottom: 24px; font-size: clamp(58px, 4.5vw, 78px); line-height: .94; }
  .cats-lead { font-size: 21px; }
  .cats-copy > p:not(.kicker):not(.cats-lead) { line-height: 1.6; }
  .cats-note { margin: 28px 0 24px; padding: 17px 0; }
  .cats-gallery { min-height: 1080px; height: 100%; grid-template-columns: 1fr; grid-template-rows: 1.08fr .92fr; }
  .cats-photo-main, .cats-photo-detail { min-height: 0; }
  .cats-photo-main img { object-position: 58% center; }
  .cats-photo-detail img { object-position: center 58%; }
  .cats-gallery > p { top: 43%; right: 45px; bottom: auto; }
}

@media (max-width: 900px) {
  .site-header { grid-template-columns: 1fr auto; }
  .site-header nav, .header-book { display: none; }
  .site-header.menu-open nav { position: absolute; top: 100%; left: 18px; right: 18px; display: flex; flex-direction: column; gap: 0; padding: 12px 20px; background: var(--ink); }
  .site-header.menu-open nav a { padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.15); }
  .menu-button { display: block; justify-self: end; }
  .quick-facts { display: none; }
  .hero-copy { width: calc(100% - 48px); margin-bottom: 13vh; }
  .booking-ribbon { grid-template-columns: repeat(3, 1fr); }
  .booking-ribbon .button { grid-column: 1 / -1; margin: 0; }
  .story, .amenities { grid-template-columns: 1fr; gap: 45px; }
  .terrace-story { grid-template-columns: 1fr; }
  .terrace-main { position: relative; top: auto; height: auto; min-height: 0; max-height: none; aspect-ratio: 16 / 10; }
  .experience-intro { grid-template-columns: 1fr; gap: 35px; }
  .experience-moments { grid-template-columns: repeat(2, 1fr); }
  .feature-grid > * { min-height: 480px; }
  .coast-heading { grid-template-columns: 1fr; gap: 35px; }
  .coast-collage { grid-template-rows: 340px 300px; }
  .character-heading { grid-template-columns: 1fr 1fr; }
  .character-heading .kicker { grid-column: 1 / -1; }
  .character-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 400px 310px 340px; }
  .character-old-town { grid-row: 1 / 3; }
  .character-architecture { grid-column: 2; grid-row: 2 / 4; }
  .character-lane { display: block; grid-column: 1; }
  .character-note { grid-column: 2; grid-row: 1; }
  .ifach-hike { grid-template-columns: 1fr; }
  .hike-visual { min-height: 620px; }
  .ifach-cats { grid-template-columns: 1fr; }
  .cats-gallery { min-height: 760px; }
  .location { grid-template-columns: 1fr; }
  .location-photo { min-height: 520px; }
  footer { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}

@media (max-width: 620px) {
  .site-header { padding: 8px 20px; }
  .wordmark { font-size: 22px; }
  .hero { min-height: 92svh; }
  .hero-wash { background: linear-gradient(0deg, rgba(17,25,21,.8), rgba(17,25,21,.1) 80%); }
  .hero-copy { margin: 0 24px 105px; }
  h1 { font-size: clamp(57px, 19vw, 78px); }
  .hero-intro { font-size: 16px; }
  .scroll-cue { display: none; }
  .booking-ribbon { display: none; }
  .section { padding: 80px 24px; }
  .story { gap: 15px; }
  .story-watermark { right: -35px; bottom: 20px; width: 200px; opacity: .04; }
  .story-copy { padding-top: 15px; }
  .feature-grid { grid-template-columns: 1fr; padding-left: 0; padding-right: 0; }
  .feature-grid > * { min-height: 430px; }
  .feature-grid .cobalt { order: 4; }
  .amenities { padding: 80px 24px; }
  .terrace-story { padding: 0; }
  .terrace-main { height: auto; min-height: 0; aspect-ratio: 4 / 5; }
  .terrace-content { padding: 70px 24px 80px; }
  .terrace-details { grid-template-columns: 1fr; }
  .terrace-details div { min-height: 95px; }
  .terrace-pair { grid-template-columns: 1fr; }
  .terrace-pair figure { min-height: 330px; }
  .terrace-level-heading { grid-template-columns: 1fr; }
  .terrace-level-heading span { grid-row: auto; }
  .terrace-level-gallery { display: block; }
  .terrace-level-gallery figure { width: 100%; height: auto; aspect-ratio: 3 / 2; margin-bottom: 10px; }
  .terrace-level-gallery figure:nth-child(2) { aspect-ratio: 1 / 1; }
  .terrace-level-gallery .terrace-level-feature { grid-column: auto; grid-row: auto; }
  .terrace-upper-image { width: 100%; height: auto; min-height: 0; aspect-ratio: 3 / 2; }
  .experience-columns { grid-template-columns: 1fr; margin-top: 60px; gap: 55px; }
  .experience-moments { grid-template-columns: 1fr; margin-top: 60px; }
  .experience-moments div { min-height: 125px; }
  .section-heading.inline { align-items: flex-start; flex-direction: column; gap: 24px; padding-right: 24px; }
  .gallery-card, .gallery-card.large, .gallery-card.portrait, .gallery-card.low-res { flex-basis: 83vw; }
  .gallery-card.low-res img { height: 360px; margin-top: 25px; }
  .gallery-card img { height: 410px; }
  .coast-heading { margin-bottom: 40px; }
  .coast-collage { grid-template-columns: 1fr; grid-template-rows: 430px 320px; gap: 12px; }
  .coast-main, .coast-wide { grid-row: auto; }
  .coast-image figcaption { left: 12px; bottom: 12px; }
  .character-heading { grid-template-columns: 1fr; gap: 25px; margin-bottom: 40px; }
  .character-heading .kicker { grid-column: auto; }
  .character-grid { display: flex; flex-direction: column; gap: 12px; }
  .character-card, .character-old-town, .character-architecture, .character-lane, .character-ifach { display: block; min-height: 390px; }
  .character-note { min-height: 320px; }
  .character-architecture img { object-position: center; }
  .hike-visual { min-height: 520px; }
  .hike-content { padding: 70px 24px 80px; }
  .hike-content h2 { font-size: clamp(54px, 17vw, 75px); }
  .hike-actions { align-items: flex-start; flex-direction: column; }
  .cats-copy { padding: 70px 24px 80px; }
  .cats-copy h2 { font-size: clamp(52px, 16vw, 72px); }
  .cats-note { grid-template-columns: 1fr; gap: 10px; }
  .cats-gallery { min-height: 650px; grid-template-rows: 1fr 1fr; }
  .location-copy { padding: 70px 24px 90px; }
  blockquote { font-size: 40px; }
  footer { grid-template-columns: 1fr; padding-bottom: 140px; }
  .footer-brand { grid-column: auto; }
  .mobile-book { position: fixed; z-index: 20; left: 12px; right: 12px; bottom: 12px; display: flex; align-items: center; justify-content: space-between; gap: 15px; padding: 10px 10px 10px 17px; background: var(--ink); color: white; box-shadow: 0 15px 40px rgba(0,0,0,.3); }
  .mobile-book small, .mobile-book strong { display: block; }
  .mobile-book small { margin-bottom: 2px; color: #b8beb7; font-size: 9px; letter-spacing: .12em; text-transform: uppercase; }
  .mobile-book strong { font: 18px Georgia, serif; }
  .booking-dialog { padding: 43px 22px 25px; }
  .form-row { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  img {
    transition: none;
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
