:root {
  --cream: #f7f3ee;
  --soft-cream: #fbfaf7;
  --beige: #d8c7b6;
  --warm-beige: #bfa88f;
  --moka: #342821;
  --black: #111111;
  --grey: #77716b;
  --white: #ffffff;
  --line: rgba(17, 17, 17, 0.12);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', sans-serif; background: var(--cream); color: var(--black); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.nav { position: sticky; top: 0; left: 0; width: 100%; z-index: 50; padding: 22px 6vw; display: flex; align-items: center; justify-content: space-between; color: #2a211b; background: rgba(247, 243, 238, 0); border-bottom: 1px solid transparent; transition: 0.35s ease; }
.nav.is-scrolled { padding-block: 14px; background: rgba(251, 250, 247, 0.78); border-bottom-color: rgba(52, 40, 33, 0.10); box-shadow: 0 18px 50px rgba(52, 40, 33, 0.08); backdrop-filter: blur(18px) saturate(1.18); -webkit-backdrop-filter: blur(18px) saturate(1.18); }
.logo-wrap { display: flex; align-items: center; gap: 14px; letter-spacing: 0.18em; text-transform: uppercase; }
.monogram { font-family: 'Cormorant Garamond', serif; width: 44px; height: 44px; border: 1px solid currentColor; display: grid; place-items: center; border-radius: 50%; font-size: 20px; font-weight: 600; }
.logo-text { font-size: 12px; line-height: 1.5; font-weight: 500; }
.nav-links { display: flex; align-items: center; gap: 28px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.12em; }
.nav-links a { opacity: 0.86; transition: 0.25s; }
.nav-links a:hover { opacity: 1; }
.nav-cta { border: 1px solid currentColor; padding: 12px 20px; border-radius: 999px; }
.mobile-menu-button { display: none; width: 46px; height: 46px; border: 1px solid rgba(42,33,27,0.28); border-radius: 50%; background: rgba(255,255,255,0.28); color: #2a211b; place-items: center; cursor: pointer; transition: 0.25s ease; }
.mobile-menu-button span { display: block; width: 18px; height: 1px; background: currentColor; margin: 3px 0; transition: 0.25s ease; }
.mobile-menu-button[aria-expanded="true"] span:nth-child(1) { transform: translateY(4px) rotate(45deg); }
.mobile-menu-button[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.mobile-menu-button[aria-expanded="true"] span:nth-child(3) { transform: translateY(-4px) rotate(-45deg); }
.mobile-menu { position: fixed; inset: 0 0 0 auto; width: min(420px, 100vw); min-height: 100vh; z-index: 80; background: rgba(251,250,247,0.94); color: #2a211b; border-left: 1px solid rgba(52,40,33,0.10); box-shadow: -28px 0 80px rgba(52,40,33,0.14); backdrop-filter: blur(22px) saturate(1.12); -webkit-backdrop-filter: blur(22px) saturate(1.12); transform: translateX(100%); transition: transform 0.32s ease; padding: 28px 28px 34px; display: flex; flex-direction: column; justify-content: space-between; pointer-events: none; }
.mobile-menu.is-open { transform: translateX(0); pointer-events: auto; }
body.menu-open { overflow: hidden; }
.mobile-menu-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 52px; }
.mobile-menu-logo { font-family: 'Cormorant Garamond', serif; width: 48px; height: 48px; border: 1px solid currentColor; border-radius: 50%; display: grid; place-items: center; font-size: 21px; font-weight: 600; }
.mobile-menu-close { width: 44px; height: 44px; border: 1px solid rgba(42,33,27,0.22); border-radius: 50%; background: transparent; color: inherit; font-size: 24px; line-height: 1; cursor: pointer; }
.mobile-menu-links { display: grid; gap: 18px; }
.mobile-menu-links a { font-family: 'Cormorant Garamond', serif; font-size: clamp(34px, 10vw, 52px); line-height: 0.95; letter-spacing: -0.04em; }
.mobile-menu-contact { border-top: 1px solid var(--line); padding-top: 24px; display: grid; gap: 10px; color: var(--grey); font-size: 14px; line-height: 1.7; }
.mobile-menu-contact strong { color: #2a211b; font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; }
.section-kicker { text-transform: uppercase; letter-spacing: 0.18em; color: var(--warm-beige); font-size: 12px; margin-bottom: 16px; font-weight: 600; }
.catalog-hero { padding: 118px 6vw 58px; display: grid; grid-template-columns: minmax(0, 1fr) 220px; gap: 48px; align-items: end; background: var(--soft-cream); }
.catalog-hero h1, .detail-hero h1, .related-section h2 { font-family: 'Cormorant Garamond', serif; font-weight: 500; line-height: .96; letter-spacing: -0.04em; }
.catalog-hero h1 { font-size: clamp(46px, 6vw, 86px); max-width: 820px; margin-bottom: 24px; }
.catalog-hero p { max-width: 720px; color: var(--grey); line-height: 1.75; font-size: 17px; }
.catalog-note { background: var(--moka); color: var(--white); padding: 28px; min-height: 180px; display: flex; flex-direction: column; justify-content: flex-end; }
.catalog-note strong { font-family: 'Cormorant Garamond', serif; font-size: 72px; font-weight: 500; line-height: .8; }
.catalog-note span { margin-top: 14px; color: rgba(255,255,255,.68); font-size: 12px; text-transform: uppercase; letter-spacing: .14em; }
.catalog-section, .detail-body, .related-section { padding: 86px 6vw; }
.catalog-toolbar { display: flex; justify-content: space-between; align-items: end; gap: 28px; margin-bottom: 22px; }
.filter-row { display: flex; flex-wrap: wrap; gap: 8px; }
.filter-button { border: 1px solid var(--line); background: rgba(255,255,255,.65); color: var(--grey); padding: 11px 16px; border-radius: 999px; font: inherit; font-size: 13px; cursor: pointer; transition: .24s ease; }
.filter-button:hover, .filter-button.is-active { color: var(--white); background: var(--moka); border-color: var(--moka); }
.search-field { min-width: min(320px, 100%); display: grid; gap: 8px; color: var(--grey); font-size: 12px; text-transform: uppercase; letter-spacing: .12em; }
.search-field input { width: 100%; border: 1px solid var(--line); background: var(--white); padding: 13px 14px; font: inherit; font-size: 14px; color: var(--black); outline: none; }
.search-field input:focus { border-color: var(--moka); }
.result-count { color: var(--grey); margin-bottom: 26px; font-size: 14px; }
.catalog-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.catalog-card { position: relative; min-height: 420px; overflow: hidden; background: var(--moka); display: flex; align-items: flex-end; isolation: isolate; }
.catalog-card[hidden] { display: none; }
.catalog-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.82), rgba(0,0,0,.14)); z-index: 1; }
.catalog-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: .65s ease; }
.catalog-card:hover img { transform: scale(1.06); }
.catalog-card__status { position: absolute; top: 18px; left: 18px; z-index: 2; padding: 8px 11px; border: 1px solid rgba(255,255,255,.28); background: rgba(255,255,255,.13); color: var(--white); backdrop-filter: blur(12px); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.catalog-card__content { position: relative; z-index: 2; padding: 28px; color: var(--white); width: 100%; }
.catalog-card__destination { display: block; color: var(--beige); font-size: 11px; text-transform: uppercase; letter-spacing: .16em; margin-bottom: 10px; }
.catalog-card h2 { font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 500; line-height: 1.02; margin-bottom: 12px; }
.catalog-card p { color: rgba(255,255,255,.68); line-height: 1.5; font-size: 14px; margin-bottom: 20px; }
.catalog-card__meta { display: flex; justify-content: space-between; gap: 14px; align-items: end; color: rgba(255,255,255,.64); font-size: 13px; }
.catalog-card__meta strong { color: var(--beige); font-weight: 600; text-align: right; }
.source-note { color: var(--grey); font-size: 12px; line-height: 1.7; margin-top: 34px; max-width: 760px; }
.source-note a { border-bottom: 1px solid currentColor; }
.detail-hero { min-height: 72vh; position: relative; display: flex; align-items: flex-end; overflow: hidden; color: var(--white); }
.detail-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.detail-hero__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.82), rgba(0,0,0,.12)), linear-gradient(to right, rgba(0,0,0,.52), transparent 70%); }
.detail-hero__content { position: relative; z-index: 2; padding: 0 6vw 72px; max-width: 980px; }
.back-link { display: inline-flex; margin-bottom: 28px; color: rgba(255,255,255,.78); font-size: 13px; text-transform: uppercase; letter-spacing: .12em; }
.project-pill { display: inline-flex; padding: 9px 12px; border: 1px solid rgba(255,255,255,.3); background: rgba(255,255,255,.12); backdrop-filter: blur(12px); font-size: 11px; text-transform: uppercase; letter-spacing: .14em; margin-bottom: 16px; }
.detail-hero h1 { font-size: clamp(46px, 7vw, 96px); margin-bottom: 18px; }
.detail-hero p { color: rgba(255,255,255,.72); font-size: 18px; }
.detail-body { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 7vw; background: var(--soft-cream); align-items: start; }
.detail-lead { color: var(--grey); font-size: 19px; line-height: 1.8; max-width: 840px; }
.detail-list-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; margin-top: 56px; }
.detail-list-grid h2 { font-family: 'Cormorant Garamond', serif; font-size: 38px; font-weight: 500; margin-bottom: 20px; }
.detail-list-grid ul { list-style: none; display: grid; gap: 14px; }
.detail-list-grid li { color: var(--grey); line-height: 1.6; border-left: 2px solid var(--beige); padding-left: 14px; }
.detail-panel { position: sticky; top: 110px; background: var(--moka); color: var(--white); padding: 30px; display: grid; gap: 22px; }
.detail-panel div { display: grid; gap: 6px; padding-bottom: 18px; border-bottom: 1px solid rgba(255,255,255,.12); }
.detail-panel span { color: rgba(255,255,255,.5); font-size: 11px; text-transform: uppercase; letter-spacing: .14em; }
.detail-panel strong { font-size: 16px; font-weight: 500; }
.detail-panel p { color: rgba(255,255,255,.55); font-size: 12px; line-height: 1.65; }
.btn-panel { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 0 22px; border-radius: 999px; background: var(--white); color: var(--moka); text-transform: uppercase; letter-spacing: .1em; font-size: 12px; }
.project-inquiry { padding: 86px 6vw; background: var(--moka); color: var(--white); display: grid; grid-template-columns: minmax(0, .78fr) minmax(0, 1fr); gap: 7vw; align-items: start; }
.project-inquiry h2 { font-family: 'Cormorant Garamond', serif; font-size: clamp(38px, 5vw, 72px); font-weight: 500; line-height: .96; letter-spacing: -0.04em; margin-bottom: 20px; }
.project-inquiry p { color: rgba(255,255,255,.65); line-height: 1.8; max-width: 520px; }
.project-lead-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.project-lead-form label { display: grid; gap: 8px; color: rgba(255,255,255,.72); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; }
.project-lead-form input, .project-lead-form textarea { width: 100%; border: 1px solid rgba(255,255,255,.22); border-radius: 8px; padding: 13px 14px; background: rgba(255,255,255,.08); color: var(--white); font: inherit; outline: none; }
.project-lead-form textarea { min-height: 130px; resize: vertical; }
.project-lead-form .span-2 { grid-column: span 2; }
.project-lead-form .honeypot { position: absolute; left: -9999px; }
.project-lead-form .consent { display: flex; align-items: center; gap: 10px; text-transform: none; letter-spacing: 0; font-size: 13px; }
.project-lead-form .consent input { width: auto; }
.project-lead-form .form-status { min-height: 22px; color: rgba(255,255,255,.72); }
.related-section { background: var(--cream); }
.related-section h2 { font-size: clamp(34px, 4vw, 58px); max-width: 780px; margin-bottom: 44px; }
.catalog-grid--small .catalog-card { min-height: 360px; }
.footer { background: #0b0b0b; color: var(--white); padding: 58px 6vw; display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 40px; align-items: start; }
.footer-logo { color: var(--white); margin-bottom: 18px; }
.footer p, .footer a { color: rgba(255,255,255,0.62); font-size: 14px; line-height: 1.9; }
.footer h4 { font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--beige); margin-bottom: 18px; }
@media (max-width: 1050px) {
  .nav-links { display: none; }
  .mobile-menu-button { display: grid; }
  .catalog-hero, .detail-body, .project-inquiry { grid-template-columns: 1fr; }
  .catalog-note { min-height: auto; }
  .catalog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .detail-panel { position: static; }
}
@media (max-width: 700px) {
  .logo-text { display: none; }
  .catalog-hero, .catalog-section, .detail-body, .related-section { padding-left: 6vw; padding-right: 6vw; }
  .catalog-toolbar { display: grid; }
  .catalog-grid, .detail-list-grid, .footer, .project-lead-form { grid-template-columns: 1fr; }
  .project-lead-form .span-2 { grid-column: auto; }
  .catalog-card { min-height: 390px; }
}
