:root {
  color-scheme: light;
  --bd-bone-40: oklch(98.4% 0.006 95);
  --bd-bone-80: oklch(97% 0.008 95);
  --bd-bone-140: oklch(94.8% 0.012 92);
  --bd-bone-260: oklch(89.5% 0.015 90);
  --bd-bone-420: oklch(78% 0.018 88);
  --bd-ink-930: oklch(24.5% 0.024 150);
  --bd-ink-780: oklch(31% 0.026 151);
  --bd-ink-610: oklch(42% 0.024 150);
  --bd-ink-450: oklch(55% 0.020 148);
  --bd-pine-120: oklch(93.5% 0.028 150);
  --bd-pine-260: oklch(83% 0.044 150);
  --bd-pine-360: oklch(69% 0.060 150);
  --bd-pine-560: oklch(52% 0.090 150);
  --bd-pine-700: oklch(39% 0.074 151);
  --bd-pine-820: oklch(30% 0.050 151);
  --bd-gold-120: oklch(93.5% 0.038 82);
  --bd-gold-520: oklch(72% 0.108 76);
  --bd-gold-670: oklch(58% 0.100 72);
  --bd-sea-180: oklch(91% 0.026 200);
  --bd-sea-420: oklch(76% 0.060 198);
  --bd-clay-110: oklch(94% 0.034 42);
  --bd-clay-560: oklch(55% 0.130 35);
  --bd-line: oklch(84% 0.014 95);
  --bd-line-soft: oklch(89.5% 0.012 95);
  --bd-focus: oklch(52% 0.100 150);
  --bd-serif: Georgia, "Iowan Old Style", "Palatino Linotype", serif;
  --bd-sans: Aptos, "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  --bd-mono: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --bd-t--2: 0.72rem;
  --bd-t--1: 0.84rem;
  --bd-t0: 1rem;
  --bd-t1: 1.25rem;
  --bd-t2: 1.56rem;
  --bd-t3: 1.95rem;
  --bd-t4: 2.44rem;
  --bd-t5: clamp(2.7rem, 6.4vw, 5.6rem);
  --bd-t6: clamp(3.2rem, 8vw, 7rem);
  --bd-s1: 0.25rem;
  --bd-s2: 0.5rem;
  --bd-s3: 0.75rem;
  --bd-s4: 1rem;
  --bd-s5: 1.5rem;
  --bd-s6: 2rem;
  --bd-s7: 3rem;
  --bd-s8: 4rem;
  --bd-s9: clamp(4.5rem, 8vw, 7.5rem);
  --bd-shell: min(100% - 1.5rem, 80rem);
  --bd-shell-wide: min(100% - 1.5rem, 88rem);
  --bd-r-sm: 0.7rem;
  --bd-r-md: 1rem;
  --bd-r-lg: 1.45rem;
  --bd-r-xl: 2rem;
  --bd-r-pill: 999px;
  --bd-shadow-sm: 0 0.7rem 1.8rem oklch(36% 0.03 150 / 0.08);
  --bd-shadow-md: 0 1.5rem 3.6rem oklch(34% 0.03 150 / 0.13);
  --bd-shadow-lg: 0 2.6rem 5.4rem oklch(30% 0.03 150 / 0.16);
  --bd-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --bd-ease-soft: cubic-bezier(0.32, 0.72, 0, 1);
  --bd-dur-fast: 160ms;
  --bd-dur-med: 240ms;
  --bd-dur-slow: 680ms;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  background: var(--bd-bone-80);
  color: var(--bd-ink-930);
}

body {
  margin: 0;
  font-family: var(--bd-sans);
  background:
    radial-gradient(circle at 22% 0%, oklch(93% 0.04 150 / 0.58), transparent 26rem),
    linear-gradient(135deg, var(--bd-bone-40), var(--bd-bone-140));
  color: var(--bd-ink-930);
  line-height: 1.6;
  min-width: 320px;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 60;
  opacity: 0.13;
  background-image:
    linear-gradient(90deg, oklch(44% 0.02 110 / 0.05) 1px, transparent 1px),
    linear-gradient(0deg, oklch(44% 0.02 110 / 0.04) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: radial-gradient(circle at 50% 18%, transparent, oklch(30% 0.02 150) 78%);
}

.sat-hero { padding: var(--bd-s8) 0 var(--bd-s6); background: radial-gradient(circle at 80% 10%, color-mix(in oklab, var(--sat-accent) 18%, transparent), transparent 26rem); }
.sat-hero-grid { display: grid; grid-template-columns: minmax(0, 1.3fr) minmax(18rem, 0.7fr); gap: var(--bd-s6); align-items: center; }
.sat-hero h1 { max-width: 13ch; margin: var(--bd-s3) 0; font-family: var(--bd-serif); font-size: var(--bd-t5); line-height: 0.96; letter-spacing: -0.055em; }
.sat-hero .lead { max-width: 58rem; font-size: var(--bd-t1); color: var(--bd-ink-610); }
.sat-microcopy { max-width: 54rem; margin-top: var(--bd-s4); }
.sat-card { border: 1px solid var(--bd-line); border-radius: var(--bd-r-xl); padding: var(--bd-s5); background: oklch(99% 0.004 95 / 0.82); box-shadow: var(--bd-shadow-sm); }
.sat-card strong { display: inline-flex; color: var(--sat-accent); text-transform: uppercase; letter-spacing: .08em; font-size: var(--bd-t--1); }
.sat-content { display: grid; gap: var(--bd-s6); padding-bottom: var(--bd-s8); }
.sat-article { max-width: 72rem; }
.sat-article h2 { margin: var(--bd-s6) 0 var(--bd-s3); font-family: var(--bd-serif); font-size: var(--bd-t3); line-height: 1.08; }
.sat-article p, .sat-article li { color: var(--bd-ink-610); }
.lead-card { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--bd-s4); padding: var(--bd-s5); border: 1px solid var(--bd-line); border-radius: var(--bd-r-xl); background: oklch(99% 0.004 95); box-shadow: var(--bd-shadow-sm); }
.lead-card h2, .lead-card p, .lead-card .full { grid-column: 1 / -1; }
.lead-card label { display: grid; gap: var(--bd-s2); font-weight: 700; color: var(--bd-ink-780); }
.lead-card input, .lead-card select, .lead-card textarea { width: 100%; border: 1px solid var(--bd-line); border-radius: var(--bd-r-sm); padding: .82rem 1rem; background: white; color: var(--bd-ink-930); }
.lead-card textarea { min-height: 8rem; resize: vertical; }
.lead-card .hp { position: absolute; left: -10000px; width: 1px; height: 1px; opacity: 0; }
.satellite .btn-primary { background: var(--sat-accent, var(--bd-pine-700)); }

@media (max-width: 760px) {
  .sat-hero-grid, .lead-card { grid-template-columns: 1fr; }
  .sat-hero h1 { max-width: none; }
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }
button { border: 0; cursor: pointer; }
:focus-visible { outline: 3px solid var(--bd-focus); outline-offset: 4px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 70;
  background: oklch(97% 0.008 95 / 0.72);
  border-bottom: 1px solid var(--bd-line-soft);
  backdrop-filter: blur(14px) saturate(1.05);
  transition: background-color var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease);
}

.site-header.is-scrolled,
body.menu-open .site-header {
  background: oklch(97% 0.008 95 / 0.94);
  border-color: oklch(82% 0.018 95 / 0.86);
  box-shadow: 0 0.7rem 1.6rem oklch(31% 0.03 150 / 0.07);
}

.nav {
  width: var(--bd-shell-wide);
  margin: 0 auto;
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.75rem, 1.4vw, var(--bd-s5));
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.68rem;
  min-height: 54px;
  flex: 0 0 auto;
}

.brand-icon { width: 38px; height: 38px; object-fit: contain; filter: drop-shadow(0 0.35rem 0.6rem oklch(28% 0.03 150 / 0.12)); }
.brand-copy { display: grid; gap: 0.08rem; line-height: 1; }
.wordmark { font-family: var(--bd-serif); font-size: 1.62rem; font-weight: 560; letter-spacing: -0.035em; color: var(--bd-ink-930); line-height: 0.92; }
.brand-copy small { font-size: 0.62rem; font-family: var(--bd-mono); letter-spacing: 0.11em; text-transform: uppercase; color: var(--bd-ink-610); white-space: nowrap; }

.nav-links { display: flex; align-items: center; gap: clamp(0.45rem, 1vw, 0.95rem); color: var(--bd-ink-780); font-size: clamp(0.78rem, 0.82vw, var(--bd-t--1)); font-weight: 680; white-space: nowrap; }
.nav-links a { min-height: 44px; min-width: 44px; padding-inline: 0.25rem; display: inline-flex; align-items: center; justify-content: center; }
.nav-links a:hover { color: var(--bd-pine-820); }
.nav-actions { display: flex; align-items: center; gap: 0.65rem; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

.menu-toggle,
.menu-close {
  min-height: 44px;
  min-width: 44px;
  border-radius: var(--bd-r-pill);
  border: 1px solid var(--bd-line);
  background: var(--bd-bone-40);
  color: var(--bd-ink-930);
}

.menu-toggle { display: none; place-items: center; gap: 0.18rem; padding: 0 0.72rem; }
.menu-toggle span:not(.sr-only) { display: block; width: 1.1rem; height: 1px; background: currentColor; transition: transform var(--bd-dur-med) var(--bd-ease), opacity var(--bd-dur-med) var(--bd-ease); }
.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(4px) rotate(42deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { transform: translateY(-3px) rotate(-42deg); }

.drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 78;
  background: oklch(24% 0.024 150 / 0.34);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--bd-dur-med) var(--bd-ease);
}

.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 80;
  width: min(25.5rem, calc(100vw - 1rem));
  height: 100dvh;
  padding: 0.75rem;
  background: var(--bd-bone-40);
  border-left: 1px solid var(--bd-line);
  box-shadow: -1.4rem 0 3.2rem oklch(24% 0.03 150 / 0.18);
  transform: translateX(0);
  display: none;
  grid-template-rows: auto 1fr auto;
  gap: var(--bd-s4);
}

body.menu-open { overflow: hidden; }
body.menu-open .drawer-backdrop { opacity: 1; pointer-events: auto; }
body.menu-open .mobile-menu { display: grid; }
.mobile-menu-head { display: flex; align-items: center; justify-content: space-between; gap: var(--bd-s3); min-height: 56px; }
.mobile-menu .brand-icon { width: 40px; height: 40px; }
.menu-close { padding: 0 0.9rem; font-weight: 780; }
.mobile-menu-links { display: grid; align-content: start; gap: 0.35rem; padding-top: var(--bd-s3); }
.mobile-menu-links a { min-height: 52px; display: flex; align-items: center; justify-content: space-between; padding: 0 0.9rem; border-radius: var(--bd-r-lg); background: var(--bd-bone-80); border: 1px solid var(--bd-line-soft); font-family: var(--bd-serif); font-size: var(--bd-t2); line-height: 1; color: var(--bd-ink-930); }
.mobile-menu-links a::after { content: "→"; font-family: var(--bd-sans); color: var(--bd-pine-700); }
.mobile-menu-actions { display: grid; gap: 0.55rem; padding-bottom: calc(0.5rem + env(safe-area-inset-bottom)); }

.btn, .chip, .tab-btn, .cluster-btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  border-radius: var(--bd-r-pill);
  transition: transform var(--bd-dur-med) var(--bd-ease), background-color var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease), color var(--bd-dur-med) var(--bd-ease), opacity var(--bd-dur-med) var(--bd-ease);
}

.btn { padding: 0.78rem 1rem; font-weight: 760; border: 1px solid transparent; }
.btn:active, .chip:active, .tab-btn:active { transform: scale(0.98); }
.btn-primary { background: var(--bd-pine-700); color: var(--bd-bone-40); box-shadow: var(--bd-shadow-sm); }
.btn-primary:hover { transform: translateY(-2px); background: var(--bd-pine-820); }
.btn-soft { background: var(--bd-bone-40); color: var(--bd-ink-930); border-color: var(--bd-line); }
.btn-soft:hover { transform: translateY(-2px); border-color: var(--bd-pine-360); }
.btn-ghost { background: transparent; color: var(--bd-ink-930); border-color: var(--bd-line); }
.btn-gold { background: var(--bd-gold-120); color: var(--bd-ink-930); border-color: oklch(76% 0.08 76); }

.icon { width: 1.05rem; height: 1.05rem; stroke: currentColor; stroke-width: 1.65; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.icon-fill { fill: currentColor; stroke: none; }
.chip-warn { background: var(--bd-clay-110); color: var(--bd-clay-560); border-color: oklch(75% 0.08 42); }

.main { overflow: clip; }
.section { padding: var(--bd-s9) 0; }
.section-tight { padding: var(--bd-s8) 0; }
.shell { width: var(--bd-shell); margin: 0 auto; }
.shell-wide { width: var(--bd-shell-wide); margin: 0 auto; }
.legal-shell { max-width: 70rem; }
.legal-hero .lead { max-width: 70ch; }
.legal-notice { display: grid; gap: .35rem; margin-bottom: var(--bd-s5); padding: var(--bd-s4); border: 1px solid oklch(75% 0.08 42); border-radius: var(--bd-r-lg); background: var(--bd-clay-110); color: var(--bd-ink-780); }
.legal-blocks { display: grid; gap: var(--bd-s5); }
.legal-block { padding: clamp(1.2rem, 3vw, 2rem); border: 1px solid var(--bd-line); border-radius: var(--bd-r-xl); background: oklch(98% 0.006 95 / .74); box-shadow: var(--bd-shadow-sm); }
.legal-block h2 { margin-top: 0; }
.legal-block p { max-width: 74ch; }
.legal-dl { display: grid; gap: .7rem; margin: var(--bd-s4) 0 0; }
.legal-dl div { display: grid; grid-template-columns: minmax(10rem, .34fr) 1fr; gap: .8rem; padding: .82rem 0; border-top: 1px solid var(--bd-line-soft); }
.legal-dl dt { font-weight: 820; color: var(--bd-ink-610); }
.legal-dl dd { margin: 0; color: var(--bd-ink-930); overflow-wrap: anywhere; }
.agency-legal-links { padding-top: 0; }

.hero {
  min-height: calc(100dvh - 72px);
  padding: clamp(2rem, 5vw, 4rem) 0 var(--bd-s7);
  display: grid;
  align-items: center;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(20rem, 1.14fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: center;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  min-height: 32px;
  padding: 0.36rem 0.68rem;
  border-radius: var(--bd-r-pill);
  background: var(--bd-pine-120);
  color: var(--bd-pine-820);
  font-family: var(--bd-mono);
  font-size: var(--bd-t--2);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border: 1px solid oklch(78% 0.04 150);
}

h1, h2, h3 { margin: 0; font-family: var(--bd-serif); color: var(--bd-ink-930); letter-spacing: -0.018em; }
h1 { font-size: var(--bd-t5); line-height: 1.01; max-width: 10.5ch; margin-top: var(--bd-s4); }
.home h1 { max-width: 11.5ch; }
h2 { font-size: clamp(2rem, 4.6vw, 3.8rem); line-height: 1.04; }
h3 { font-size: clamp(1.35rem, 2vw, 1.9rem); line-height: 1.12; }
p { margin: 0; color: var(--bd-ink-610); }
.lead { margin-top: var(--bd-s5); font-size: clamp(1.05rem, 1.4vw, 1.28rem); line-height: 1.58; max-width: 50ch; color: var(--bd-ink-780); }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--bd-s3); margin-top: var(--bd-s6); }

.proof-strip {
  margin-top: var(--bd-s6);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid var(--bd-line);
  border-radius: var(--bd-r-lg);
  overflow: hidden;
  background: var(--bd-line);
}

.proof-strip span {
  min-height: 72px;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.9rem;
  background: oklch(97.5% 0.008 95 / 0.92);
  color: var(--bd-ink-780);
  font-size: var(--bd-t--1);
  font-weight: 720;
}

.media-stage {
  position: relative;
  border-radius: var(--bd-r-xl);
  padding: 0.55rem;
  background: linear-gradient(135deg, var(--bd-bone-40), var(--bd-gold-120));
  border: 1px solid var(--bd-line);
  box-shadow: var(--bd-shadow-lg);
}

.media-frame {
  position: relative;
  min-height: clamp(24rem, 58vw, 40rem);
  overflow: hidden;
  border-radius: calc(var(--bd-r-xl) - 0.45rem);
  background: var(--bd-pine-820);
}

.media-frame img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; }
.media-frame::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, oklch(18% 0.03 150 / 0.45)); }
.media-caption { position: absolute; left: 1rem; right: 1rem; bottom: 1rem; z-index: 2; display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; color: var(--bd-bone-40); }
.media-caption strong { font-family: var(--bd-serif); font-size: clamp(1.45rem, 3vw, 2.25rem); line-height: 1; }
.seal { display: inline-flex; align-items: center; gap: 0.5rem; border-radius: var(--bd-r-pill); padding: 0.48rem 0.75rem; background: var(--bd-gold-120); color: var(--bd-ink-930); border: 1px solid var(--bd-gold-520); font-family: var(--bd-mono); font-size: var(--bd-t--2); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 760; }
.floating-card { position: absolute; z-index: 4; right: -0.6rem; top: 1.25rem; width: min(15rem, 48vw); padding: 1rem; background: var(--bd-bone-40); border: 1px solid var(--bd-line); border-radius: var(--bd-r-lg); box-shadow: var(--bd-shadow-md); }
.floating-card strong { display: block; color: var(--bd-ink-930); margin-bottom: 0.3rem; }
.floating-card small { color: var(--bd-ink-610); line-height: 1.4; }

.section-head { display: grid; grid-template-columns: minmax(0, 0.9fr) minmax(16rem, 0.55fr); gap: var(--bd-s6); align-items: end; margin-bottom: var(--bd-s7); }
.section-head p { font-size: var(--bd-t1); max-width: 42ch; }

.category-entry { padding-top: var(--bd-s8); }
.category-deck { display: grid; grid-template-columns: 1.08fr 0.92fr 0.92fr 1.08fr; gap: var(--bd-s4); align-items: stretch; }
.category-card { min-height: 17rem; display: grid; align-content: end; gap: var(--bd-s3); padding: var(--bd-s5); border-radius: var(--bd-r-xl); background: linear-gradient(145deg, oklch(98% 0.006 95 / 0.96), var(--bd-bone-140)); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); position: relative; overflow: hidden; transition: transform var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease); }
.category-card::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 78% 12%, oklch(79% 0.06 150 / 0.28), transparent 11rem); opacity: 0.85; }
.category-card:nth-child(2)::before { background: radial-gradient(circle at 72% 10%, oklch(79% 0.06 198 / 0.24), transparent 10rem); }
.category-card:nth-child(3)::before { background: radial-gradient(circle at 72% 10%, oklch(82% 0.08 76 / 0.22), transparent 10rem); }
.category-card:nth-child(4)::before { background: radial-gradient(circle at 72% 10%, oklch(79% 0.09 35 / 0.16), transparent 10rem); }
.category-card:hover { transform: translateY(-5px); border-color: var(--bd-pine-360); box-shadow: var(--bd-shadow-md); }
.category-card > * { position: relative; z-index: 1; }
.category-card span, .guide-card span { font-family: var(--bd-mono); font-size: var(--bd-t--2); letter-spacing: 0.14em; text-transform: uppercase; color: var(--bd-pine-700); }
.category-card strong { font-family: var(--bd-serif); font-size: clamp(1.45rem, 2.4vw, 2.35rem); line-height: 1.04; color: var(--bd-ink-930); max-width: 11ch; }
.category-card small { color: var(--bd-ink-610); font-size: var(--bd-t--1); line-height: 1.45; max-width: 27ch; }
.category-card:nth-child(1), .category-card:nth-child(4) { transform: translateY(1.25rem); }

.listings-section { padding-top: var(--bd-s7); }
.listings-toolbar { display: flex; justify-content: space-between; gap: var(--bd-s4); align-items: center; padding: var(--bd-s4); margin-bottom: var(--bd-s5); border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); }
.listings-toolbar strong { display: block; color: var(--bd-ink-930); font-family: var(--bd-serif); font-size: var(--bd-t2); line-height: 1.1; }
.listings-toolbar small { color: var(--bd-ink-610); }
.filter-tabs { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 0.55rem; }
.filter-tab[aria-selected="true"] { background: var(--bd-pine-700); color: var(--bd-bone-40); border-color: var(--bd-pine-700); }
.property-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--bd-s4); align-items: stretch; }
.property-card { grid-column: span 4; display: grid; grid-template-rows: auto 1fr; min-height: 100%; padding: 0.55rem; border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); transition: opacity var(--bd-dur-med) var(--bd-ease), transform var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease); }
.property-card:hover { transform: translateY(-4px); border-color: var(--bd-pine-360); box-shadow: var(--bd-shadow-md); }
.property-card.is-filtered-out { display: none; }
.property-feature { grid-column: span 8; grid-template-columns: minmax(0, 1.05fr) minmax(20rem, 0.95fr); grid-template-rows: 1fr; }
.property-media { position: relative; min-height: 17rem; overflow: hidden; border-radius: calc(var(--bd-r-xl) - 0.45rem); background: var(--bd-pine-820); }
.property-feature .property-media { min-height: 100%; }
.property-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 900ms var(--bd-ease); }
.property-card:hover .property-media img { transform: scale(1.035); }
.demo-label { position: absolute; left: 0.7rem; top: 0.7rem; min-height: 32px; display: inline-flex; align-items: center; padding: 0.28rem 0.58rem; border-radius: var(--bd-r-pill); background: oklch(98% 0.006 95 / 0.92); color: var(--bd-ink-780); border: 1px solid var(--bd-line); font-family: var(--bd-mono); font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; }
.property-body { padding: var(--bd-s4); display: grid; gap: var(--bd-s3); align-content: start; }
.property-feature .property-body { padding: var(--bd-s5); align-content: center; }
.property-type { color: var(--bd-ink-780); font-weight: 680; }
.property-card .price { margin-top: 0.1rem; }

.dossier-grid { display: grid; grid-template-columns: 0.84fr 1.16fr; gap: var(--bd-s6); align-items: start; }
.admission-standard { position: relative; }
.admission-standard::before { content: ""; position: absolute; inset: 7% 0 auto; height: 44%; background: radial-gradient(circle at 18% 20%, oklch(88% 0.05 150 / 0.32), transparent 24rem); pointer-events: none; }
.admission-grid { position: relative; }
.sticky-note { position: sticky; top: 96px; padding: var(--bd-s6); border-radius: var(--bd-r-xl); background: var(--bd-pine-820); color: var(--bd-bone-40); box-shadow: var(--bd-shadow-lg); }
.admission-note { overflow: hidden; border: 1px solid oklch(50% 0.07 150 / 0.72); background: linear-gradient(145deg, var(--bd-pine-820), oklch(25% 0.042 151)); }
.admission-note::before { content: ""; display: block; width: 4.2rem; height: 0.18rem; margin-bottom: var(--bd-s5); border-radius: var(--bd-r-pill); background: var(--bd-gold-520); box-shadow: 5rem 0 0 oklch(72% 0.108 76 / 0.24); }
.admission-note::after { content: ""; position: absolute; right: -5rem; bottom: -5rem; width: 14rem; height: 14rem; border-radius: 50%; border: 1px solid oklch(72% 0.108 76 / 0.28); background: radial-gradient(circle, oklch(72% 0.108 76 / 0.12), transparent 62%); }
.sticky-note p { color: oklch(91% 0.012 95); margin-top: var(--bd-s4); }
.sticky-note .eyebrow { background: oklch(36% 0.06 150); color: var(--bd-bone-40); border-color: oklch(48% 0.08 150); }
.admission-note h3 { position: relative; z-index: 1; max-width: 10ch; color: var(--bd-bone-40); font-size: clamp(2rem, 4vw, 3.35rem); line-height: 0.98; }

.proof-list { display: grid; gap: var(--bd-s4); }
.admission-proof-list { gap: clamp(0.8rem, 1.5vw, 1.15rem); }
.proof-item { display: grid; grid-template-columns: 3.4rem 1fr auto; gap: var(--bd-s4); align-items: center; padding: var(--bd-s5); background: oklch(98% 0.006 95 / 0.92); border: 1px solid var(--bd-line); border-radius: var(--bd-r-lg); box-shadow: var(--bd-shadow-sm); }
.admission-proof { position: relative; overflow: hidden; min-height: 9.1rem; background: linear-gradient(135deg, oklch(98.2% 0.007 95 / 0.98), oklch(94.8% 0.014 95 / 0.92)); box-shadow: 0 1.2rem 2.6rem oklch(33% 0.03 150 / 0.09); transition: transform var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease); }
.admission-proof::after { content: ""; position: absolute; left: calc(3.4rem + var(--bd-s5) + 0.5rem); right: var(--bd-s5); bottom: 0; height: 1px; background: linear-gradient(90deg, var(--bd-line), transparent); }
.admission-proof:hover { transform: translateY(-3px); border-color: oklch(77% 0.04 150); box-shadow: 0 1.7rem 3.4rem oklch(31% 0.03 150 / 0.13); }
.admission-proof h3 { font-size: clamp(1.28rem, 1.8vw, 1.72rem); }
.admission-proof p { max-width: 55ch; }
.proof-num { width: 3.4rem; height: 3.4rem; border-radius: 50%; display: grid; place-items: center; background: var(--bd-pine-120); color: var(--bd-pine-820); font-family: var(--bd-mono); font-weight: 760; }
.admission-proof .proof-num { background: var(--bd-bone-40); border: 1px solid oklch(80% 0.038 150); box-shadow: inset 0 0 0 0.35rem var(--bd-pine-120); }
.status { min-height: 34px; display: inline-flex; align-items: center; padding: 0.28rem 0.62rem; border-radius: var(--bd-r-pill); font-family: var(--bd-mono); font-size: var(--bd-t--2); text-transform: uppercase; letter-spacing: 0.12em; white-space: nowrap; }
.status-ok { color: var(--bd-pine-820); background: var(--bd-pine-120); }
.status-warn { color: oklch(36% 0.10 35); background: var(--bd-clay-110); }
.proof-illustration { margin: var(--bd-s5) 0 var(--bd-s6); overflow: hidden; border-radius: var(--bd-r-xl); border: 1px solid var(--bd-line); background: var(--bd-bone-80); box-shadow: var(--bd-shadow-sm); }
.proof-illustration img { display: block; width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; }

.route-board { position: relative; overflow: hidden; padding: var(--bd-s6); border-radius: var(--bd-r-xl); background: linear-gradient(135deg, var(--bd-bone-40), var(--bd-sea-180)); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-md); }
.diaspora-map { position: relative; min-height: 470px; border-radius: calc(var(--bd-r-xl) - 0.45rem); overflow: hidden; background: var(--bd-sea-180); border: 1px solid oklch(82% 0.026 190); box-shadow: inset 0 1px 0 oklch(99% 0.006 95 / 0.76); }
.diaspora-map img { width: 100%; height: 100%; min-height: 470px; object-fit: cover; transform: scale(1.02); }
.diaspora-scrim { position: absolute; inset: 0; background: linear-gradient(90deg, oklch(21% 0.035 150 / 0.22), transparent 34%, oklch(21% 0.035 150 / 0.15)), linear-gradient(180deg, transparent 48%, oklch(20% 0.03 150 / 0.26)); pointer-events: none; }
.diaspora-labels { position: absolute; inset: 0; pointer-events: none; }
.map-label { position: absolute; z-index: 2; left: var(--x); top: var(--y); transform: translate(-50%, -50%) translateY(0); min-height: 44px; display: inline-flex; flex-direction: column; justify-content: center; padding: 0.46rem 0.72rem; border-radius: var(--bd-r-pill); background: oklch(98% 0.006 95 / 0.90); border: 1px solid var(--bd-line); color: var(--bd-ink-930); box-shadow: 0 0.85rem 1.8rem oklch(28% 0.03 150 / 0.16); font-weight: 820; line-height: 1.02; white-space: nowrap; opacity: 1; transition: transform 620ms var(--bd-ease), opacity 620ms var(--bd-ease); }
.map-label small { margin-top: 0.18rem; color: var(--bd-ink-610); font-family: var(--bd-mono); font-size: 0.58rem; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 700; }
html.js .map-label { opacity: 0; transform: translate(-50%, -50%) translateY(12px); }
html.js .route-board.is-visible .map-label { opacity: 1; transform: translate(-50%, -50%) translateY(0); }
.map-origin { background: oklch(29% 0.04 150 / 0.88); color: var(--bd-bone-40); border-color: oklch(54% 0.05 150); }
.map-origin::after { content: ""; position: absolute; left: 50%; bottom: -1.05rem; width: 1px; height: 1.05rem; background: oklch(73.5% 0.09 78 / 0.74); box-shadow: -3.9rem 0 0 oklch(73.5% 0.09 78 / 0.42), 3.9rem 0 0 oklch(73.5% 0.09 78 / 0.42); transform: translateX(-50%); }
.map-origin small { color: oklch(88% 0.012 95); }
.label-paris { --x: 67.2%; --y: 13.6%; }
.label-tunis { --x: 55.4%; --y: 70.2%; }
.label-hammamet { --x: 61.5%; --y: 72.8%; }
.label-sousse { --x: 66.4%; --y: 68.1%; }
.label-djerba { --x: 72.1%; --y: 75%; }
.route-panels { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--bd-s4); margin-top: var(--bd-s5); }
.mini-panel { background: oklch(98% 0.006 95 / 0.82); border: 1px solid var(--bd-line); border-radius: var(--bd-r-lg); padding: var(--bd-s5); }
.mini-panel strong { display: block; color: var(--bd-ink-930); margin-bottom: 0.35rem; }

.city-mosaic { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 18rem; gap: var(--bd-s4); }
.city-tile { position: relative; overflow: hidden; border-radius: var(--bd-r-xl); padding: var(--bd-s5); display: grid; align-content: end; background: var(--bd-pine-820); box-shadow: var(--bd-shadow-sm); border: 1px solid var(--bd-line); isolation: isolate; transition: transform var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease); }
.city-tile:hover { transform: translateY(-4px); box-shadow: var(--bd-shadow-md); }
.city-tile img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; transition: transform 900ms var(--bd-ease); }
.city-tile:hover img { transform: scale(1.04); }
.city-tile::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, transparent 20%, oklch(18% 0.035 150 / 0.74)); }
.city-large { grid-column: span 2; grid-row: span 2; }
.city-wide { grid-column: span 2; }
.city-tile span { color: var(--bd-gold-120); font-family: var(--bd-mono); letter-spacing: 0.14em; text-transform: uppercase; font-size: var(--bd-t--2); }
.city-tile strong { max-width: 15ch; color: var(--bd-bone-40); font-family: var(--bd-serif); font-size: clamp(1.7rem, 3.3vw, 3.25rem); line-height: 1; }
.city-tile small { color: oklch(90% 0.012 95); font-weight: 700; }

.pro-admission, .concierge-band { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--bd-s6); align-items: center; padding: var(--bd-s7); border-radius: var(--bd-r-xl); background: var(--bd-pine-820); color: var(--bd-bone-40); box-shadow: var(--bd-shadow-lg); position: relative; overflow: hidden; }
.pro-admission { min-height: 25rem; background: linear-gradient(90deg, oklch(24% 0.044 151 / 0.96), oklch(28% 0.052 151 / 0.82)), image-set(url('/assets/og-pro.webp') type('image/webp'), url('/assets/og-pro.jpg') type('image/jpeg')) center / cover; border: 1px solid oklch(52% 0.06 150 / 0.72); }
.pro-admission::before { content: ""; position: absolute; inset: 0; opacity: 0.28; background-image: linear-gradient(90deg, oklch(96% 0.008 95 / 0.12) 1px, transparent 1px), linear-gradient(0deg, oklch(96% 0.008 95 / 0.1) 1px, transparent 1px); background-size: 72px 72px; }
.pro-admission::after, .concierge-band::after { content: ""; position: absolute; right: -8rem; top: -8rem; width: 24rem; height: 24rem; border-radius: 50%; background: oklch(73% 0.10 76 / 0.16); }
.pro-admission-side { position: relative; z-index: 1; display: grid; gap: var(--bd-s4); justify-items: end; }
.pro-admission-side span { min-height: 44px; display: inline-flex; align-items: center; padding: 0 0.82rem; border-radius: var(--bd-r-pill); border: 1px solid oklch(83% 0.038 82 / 0.68); color: var(--bd-gold-120); background: oklch(25% 0.044 151 / 0.76); font-family: var(--bd-mono); font-size: var(--bd-t--2); letter-spacing: 0.13em; text-transform: uppercase; }
.concierge-band { background: radial-gradient(circle at 88% 6%, oklch(72% 0.108 76 / 0.18), transparent 17rem), linear-gradient(135deg, oklch(26% 0.052 151), var(--bd-pine-820)); border: 1px solid oklch(52% 0.06 150 / 0.6); }
.pro-admission h2, .concierge-band h2 { color: var(--bd-bone-40); max-width: 12ch; }
.pro-admission p, .concierge-band p { margin-top: var(--bd-s4); color: oklch(90% 0.012 95); max-width: 56ch; }
.pro-admission .eyebrow, .concierge-band .eyebrow { background: oklch(36% 0.06 150); color: var(--bd-bone-40); border-color: oklch(48% 0.08 150); }
.pro-admission .btn, .concierge-band .btn { position: relative; z-index: 1; background: var(--bd-gold-120); color: var(--bd-ink-930); border-color: var(--bd-gold-520); }
.concierge-flow { display: inline-grid; grid-template-columns: auto auto auto; align-items: center; gap: 0.55rem; margin-top: var(--bd-s5); padding: 0.45rem; border: 1px solid oklch(58% 0.06 150 / 0.74); border-radius: var(--bd-r-pill); background: oklch(23% 0.042 151 / 0.58); }
.concierge-flow span, .concierge-flow strong { min-height: 44px; display: inline-flex; align-items: center; padding: 0 0.8rem; border-radius: var(--bd-r-pill); white-space: nowrap; }
.concierge-flow span { color: oklch(91% 0.014 95); background: oklch(34% 0.052 151 / 0.72); font-weight: 740; }
.concierge-flow strong { color: var(--bd-ink-930); background: var(--bd-gold-120); font-family: var(--bd-mono); font-size: var(--bd-t--2); letter-spacing: 0.12em; text-transform: uppercase; }

.guide-teasers { display: grid; grid-template-columns: 1.15fr 0.85fr 1fr; gap: var(--bd-s4); }
.guide-card { min-height: 15rem; display: grid; align-content: space-between; gap: var(--bd-s4); padding: var(--bd-s5); border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); transition: transform var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease); }
.guide-card:hover { transform: translateY(-4px); box-shadow: var(--bd-shadow-md); }
.guide-card strong { font-family: var(--bd-serif); font-size: clamp(1.35rem, 2.5vw, 2.2rem); line-height: 1.06; color: var(--bd-ink-930); max-width: 14ch; }
.guide-card small { color: var(--bd-ink-610); font-weight: 650; }
.faq-list { display: grid; gap: 0.85rem; max-width: 62rem; }
.faq-list details { border-radius: var(--bd-r-lg); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); overflow: hidden; }
.faq-list summary { min-height: 58px; display: flex; align-items: center; padding: 1rem 1.2rem; cursor: pointer; color: var(--bd-ink-930); font-weight: 820; }
.faq-list p { padding: 0 1.2rem 1.2rem; max-width: 66ch; }

.city-layout { display: grid; grid-template-columns: minmax(0, 0.58fr) minmax(0, 1.42fr); gap: var(--bd-s6); align-items: start; }
.search-strip { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0.75rem; padding: 0.75rem; background: var(--bd-bone-40); border: 1px solid var(--bd-line); border-radius: var(--bd-r-xl); box-shadow: var(--bd-shadow-sm); margin-top: var(--bd-s6); }
.field { display: grid; gap: 0.35rem; }
.field label { font-size: var(--bd-t--2); font-family: var(--bd-mono); letter-spacing: 0.1em; text-transform: uppercase; color: var(--bd-ink-610); }
.field select, .field input { min-height: 46px; border-radius: var(--bd-r-md); border: 1px solid var(--bd-line); background: var(--bd-bone-80); padding: 0 0.8rem; color: var(--bd-ink-930); }

.map-panel { padding: var(--bd-s5); border-radius: var(--bd-r-xl); background: var(--bd-pine-820); color: var(--bd-bone-40); box-shadow: var(--bd-shadow-lg); position: sticky; top: 96px; }
.map-panel h2, .map-panel h3 { color: var(--bd-bone-40); }
.cluster-list { display: grid; gap: 0.65rem; margin-top: var(--bd-s5); }
.cluster-btn { width: 100%; justify-content: space-between; padding: 0.7rem 0.9rem; color: var(--bd-bone-40); background: oklch(37% 0.052 150); border: 1px solid oklch(49% 0.06 150); text-align: left; }
.cluster-btn[aria-pressed="true"] { background: var(--bd-bone-40); color: var(--bd-ink-930); }

.listing-stack { display: grid; gap: var(--bd-s4); }
.listing-card { display: grid; grid-template-columns: minmax(11rem, 0.42fr) 1fr; gap: var(--bd-s4); padding: 0.55rem; border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-sm); transition: transform var(--bd-dur-med) var(--bd-ease), box-shadow var(--bd-dur-med) var(--bd-ease), border-color var(--bd-dur-med) var(--bd-ease); }
.listing-card:hover, .listing-card.is-active { transform: translateY(-3px); border-color: var(--bd-pine-360); box-shadow: var(--bd-shadow-md); }
.listing-card img { width: 100%; height: 100%; min-height: 13rem; object-fit: cover; border-radius: calc(var(--bd-r-xl) - 0.45rem); }
.listing-body { padding: var(--bd-s4) var(--bd-s4) var(--bd-s4) 0; display: grid; gap: var(--bd-s3); }
.meta { font-family: var(--bd-mono); font-size: var(--bd-t--2); letter-spacing: 0.11em; text-transform: uppercase; color: var(--bd-ink-450); }
.price { font-family: var(--bd-serif); font-size: clamp(1.7rem, 3vw, 2.5rem); line-height: 1; color: var(--bd-ink-930); }
.price small { display: block; margin-top: 0.25rem; font-family: var(--bd-sans); font-size: var(--bd-t--1); color: var(--bd-ink-610); }
.badges { display: flex; flex-wrap: wrap; gap: 0.45rem; }
.chip { padding: 0.35rem 0.65rem; background: var(--bd-bone-80); border: 1px solid var(--bd-line); color: var(--bd-ink-780); font-size: var(--bd-t--1); font-weight: 720; }
.chip-pine { background: var(--bd-pine-120); border-color: oklch(80% 0.042 150); color: var(--bd-pine-820); }
.chip-gold { background: var(--bd-gold-120); border-color: var(--bd-gold-520); color: var(--bd-ink-930); }
.card-actions { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 0.25rem; }

.viewer-layout { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(18rem, 0.85fr); gap: var(--bd-s6); align-items: start; }
.viewer { padding: 0.55rem; border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-lg); }
.viewer-screen { position: relative; aspect-ratio: 16 / 10; overflow: hidden; border-radius: calc(var(--bd-r-xl) - 0.45rem); background: var(--bd-pine-820); }
.viewer-screen img { width: 100%; height: 100%; object-fit: cover; }
.media-pane { display: none; height: 100%; }
.media-pane.is-active { display: block; }
.fake-pane { height: 100%; display: grid; place-items: center; padding: var(--bd-s6); text-align: center; background: linear-gradient(135deg, var(--bd-pine-820), var(--bd-ink-780)); color: var(--bd-bone-40); }
.fake-pane p { color: oklch(92% 0.012 95); margin-top: var(--bd-s3); }
.viewer-tabs { display: flex; gap: 0.55rem; flex-wrap: wrap; margin-top: var(--bd-s4); }
.tab-btn { padding: 0.55rem 0.82rem; border: 1px solid var(--bd-line); background: var(--bd-bone-80); color: var(--bd-ink-780); font-weight: 720; }
.tab-btn[aria-selected="true"] { background: var(--bd-pine-700); color: var(--bd-bone-40); border-color: var(--bd-pine-700); }
.conversion-rail { position: sticky; top: 96px; display: grid; gap: var(--bd-s4); }
.rail-card { padding: var(--bd-s5); border-radius: var(--bd-r-xl); background: var(--bd-bone-40); border: 1px solid var(--bd-line); box-shadow: var(--bd-shadow-md); }
.facts { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.65rem; margin-top: var(--bd-s4); }
.fact { padding: 0.85rem; border-radius: var(--bd-r-md); background: var(--bd-bone-80); border: 1px solid var(--bd-line-soft); }
.fact strong { display: block; color: var(--bd-ink-930); }
.fact span { color: var(--bd-ink-610); font-size: var(--bd-t--1); }
.timeline { display: grid; gap: 0.75rem; margin-top: var(--bd-s4); }
.timeline-row { display: grid; grid-template-columns: 1.65rem 1fr auto; gap: 0.7rem; align-items: center; }
.dot { width: 1.1rem; height: 1.1rem; border-radius: 50%; background: var(--bd-pine-560); box-shadow: 0 0 0 0.35rem var(--bd-pine-120); }

.agency-hero { position: relative; overflow: hidden; }
.agency-hero::before { content: ""; position: absolute; inset: 5rem 0 auto; height: 22rem; background: radial-gradient(circle at 18% 18%, oklch(84% 0.05 150 / 0.32), transparent 28rem), radial-gradient(circle at 82% 12%, oklch(82% 0.08 76 / 0.16), transparent 22rem); pointer-events: none; }
.agency-hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.44fr); gap: var(--bd-s6); align-items: stretch; }
.agency-profile h1 { max-width: 13ch; }
.agency-badges { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-top: var(--bd-s5); align-items: center; }
.agency-zones { display: flex; flex-wrap: wrap; gap: 0.55rem; margin-top: var(--bd-s6); max-width: 52rem; }
.agency-zones strong, .agency-zones span { min-height: 44px; display: inline-flex; align-items: center; border-radius: var(--bd-r-pill); padding: 0 0.82rem; }
.agency-zones strong { background: var(--bd-pine-820); color: var(--bd-bone-40); font-family: var(--bd-mono); font-size: var(--bd-t--2); text-transform: uppercase; letter-spacing: 0.12em; }
.agency-zones span { background: var(--bd-bone-40); border: 1px solid var(--bd-line); color: var(--bd-ink-780); font-weight: 740; }
.WhatsAppLeadDock { display: grid; align-content: start; gap: var(--bd-s4); padding: var(--bd-s5); border-radius: var(--bd-r-xl); background: linear-gradient(145deg, var(--bd-pine-820), oklch(25% 0.042 151)); border: 1px solid oklch(52% 0.06 150 / 0.62); box-shadow: var(--bd-shadow-lg); color: var(--bd-bone-40); }
.WhatsAppLeadDock h2 { color: var(--bd-bone-40); font-size: clamp(1.75rem, 3vw, 2.65rem); }
.WhatsAppLeadDock p, .WhatsAppLeadDock small { color: oklch(90% 0.012 95); }
.WhatsAppLeadDock .eyebrow { background: oklch(36% 0.06 150); color: var(--bd-bone-40); border-color: oklch(48% 0.08 150); }
.WhatsAppLeadDock .btn { background: var(--bd-gold-120); color: var(--bd-ink-930); border-color: var(--bd-gold-520); }
.VerifiedDossierStrip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--bd-s4); }
.VerifiedDossierStrip .proof-item { grid-template-columns: 3.4rem 1fr; align-content: start; min-height: 15rem; }
.VerifiedDossierStrip .status { grid-column: 2; width: fit-content; }
.agency-listings { display: grid; gap: var(--bd-s4); }
.ListingProofCard { position: relative; }
.ListingProofCard::after { content: "Zone masquée"; position: absolute; left: 1rem; top: 1rem; min-height: 32px; display: inline-flex; align-items: center; border-radius: var(--bd-r-pill); padding: 0 0.62rem; background: oklch(98% 0.006 95 / 0.9); border: 1px solid var(--bd-line); color: var(--bd-pine-820); font-family: var(--bd-mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 760; }

.article-layout { display: grid; grid-template-columns: minmax(13rem, 0.32fr) 1fr; gap: var(--bd-s7); align-items: start; }
.toc { position: sticky; top: 96px; padding: var(--bd-s5); border-radius: var(--bd-r-lg); background: var(--bd-bone-40); border: 1px solid var(--bd-line); }
.toc a { display: flex; min-height: 44px; align-items: center; border-bottom: 1px solid var(--bd-line-soft); color: var(--bd-ink-780); font-weight: 680; }
.article { max-width: 48rem; }
.article h2 { margin-top: var(--bd-s7); margin-bottom: var(--bd-s4); }
.article p, .article li { font-size: 1.06rem; color: var(--bd-ink-780); }
.article ul { padding-left: 1.25rem; }
.callout { padding: var(--bd-s5); border-radius: var(--bd-r-lg); background: var(--bd-clay-110); border: 1px solid oklch(80% 0.06 42); margin: var(--bd-s6) 0; }
.callout strong { color: oklch(34% 0.09 35); }
.related-links { display: flex; flex-wrap: wrap; gap: 0.55rem; align-items: center; margin: var(--bd-s5) 0 var(--bd-s6); }
.related-links strong { width: 100%; color: var(--bd-ink-930); }
.related-links a { min-height: 44px; display: inline-flex; align-items: center; padding: 0 0.9rem; border-radius: var(--bd-r-pill); background: var(--bd-bone-40); border: 1px solid var(--bd-line); color: var(--bd-ink-780); font-weight: 760; }

.footer { padding: var(--bd-s8) 0 calc(var(--bd-s7) + env(safe-area-inset-bottom)); background: var(--bd-pine-820); color: var(--bd-bone-40); }
.footer-grid { display: grid; grid-template-columns: minmax(15rem, 1.25fr) repeat(5, minmax(7rem, 0.72fr)); gap: clamp(1.25rem, 3vw, var(--bd-s6)); align-items: start; }
.footer-brand img { width: min(13rem, 70vw); height: auto; margin-bottom: var(--bd-s4); }
.footer-brand p { max-width: 28ch; }
.footer p, .footer a { color: oklch(90% 0.012 95); }
.footer a { min-height: 44px; display: flex; align-items: center; }
.footer h2, .footer h3 { color: var(--bd-bone-40); }
.footer h3 { font-family: var(--bd-sans); font-size: var(--bd-t--1); letter-spacing: 0.13em; text-transform: uppercase; margin-bottom: 0.4rem; }
.footer small { color: oklch(80% 0.012 95); }
.language-switch { display: inline-flex; gap: 1px; margin-top: 0.45rem; border: 1px solid oklch(49% 0.06 150); border-radius: var(--bd-r-pill); overflow: hidden; background: oklch(37% 0.052 150); }
.language-switch a { min-height: 44px; padding: 0 0.75rem; font-weight: 820; }
.language-switch a[aria-current="page"] { background: var(--bd-bone-40); color: var(--bd-ink-930); }
.footer-legal { margin-top: var(--bd-s7); padding-top: var(--bd-s4); border-top: 1px solid oklch(49% 0.06 150); display: flex; flex-wrap: wrap; gap: 0.7rem 1rem; color: oklch(82% 0.012 95); font-size: var(--bd-t--1); }
.footer-legal a, .footer-legal span { min-height: 44px; display: inline-flex; align-items: center; }

.mobile-whatsapp { position: fixed; left: 0.75rem; right: 0.75rem; bottom: calc(0.75rem + env(safe-area-inset-bottom)); z-index: 40; display: none; }
.mobile-whatsapp .btn { width: 100%; box-shadow: var(--bd-shadow-lg); }
.ConsentBanner[hidden] { display: none; }
.ConsentBanner { position: fixed; left: max(1rem, env(safe-area-inset-left)); right: max(1rem, env(safe-area-inset-right)); bottom: max(1rem, env(safe-area-inset-bottom)); z-index: 70; display: flex; justify-content: center; pointer-events: none; }
.ConsentBanner-inner { width: min(720px, 100%); display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.85rem; border-radius: var(--bd-r-xl); background: oklch(98% 0.006 95 / 0.96); color: var(--bd-ink-780); border: 1px solid var(--bd-line); box-shadow: 0 24px 80px oklch(20% 0.03 90 / 0.18); pointer-events: auto; }
.ConsentBanner p { margin: 0; font-size: var(--bd-t--1); line-height: 1.35; }
.ConsentBanner-actions { display: flex; gap: 0.55rem; flex-wrap: wrap; justify-content: flex-end; }
.ConsentBanner .btn { min-height: 42px; }

.reveal { opacity: 1; transform: translateY(0); transition: opacity var(--bd-dur-slow) var(--bd-ease), transform var(--bd-dur-slow) var(--bd-ease); }
html.js .reveal { opacity: 0; transform: translateY(22px); }
html.js .reveal.is-visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: 60ms; }
.delay-2 { transition-delay: 120ms; }
.delay-3 { transition-delay: 180ms; }

@media (max-width: 1120px) {
  .nav-links { display: none; }
  .menu-toggle { display: grid; }
  .search-strip { grid-template-columns: repeat(2, 1fr); }
  .search-strip .btn { grid-column: 1 / -1; }
  .category-deck { grid-template-columns: repeat(2, 1fr); }
  .category-card:nth-child(1), .category-card:nth-child(4) { transform: none; }
  .property-card, .property-feature { grid-column: span 6; }
  .property-feature { grid-template-columns: 1fr; }
  .city-mosaic { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
  .nav { min-height: 66px; }
  .brand-copy small { display: none; }
  .wordmark { font-size: 1.45rem; }
  .brand-icon { width: 36px; height: 36px; }
  .nav-actions .btn-soft { display: none; }
  .nav-actions { gap: 0.45rem; }
  .nav-actions .btn-primary { padding-inline: 0.82rem; }
  .hero { min-height: auto; padding: var(--bd-s6) 0 var(--bd-s7); }
  .hero-grid, .dossier-grid, .city-layout, .viewer-layout, .article-layout, .section-head, .agency-hero-grid { grid-template-columns: 1fr; }
  h1 { max-width: 11.5ch; font-size: clamp(2.55rem, 13vw, 4.4rem); }
  .lead { font-size: 1.05rem; max-width: 32rem; }
  .proof-strip { grid-template-columns: 1fr 1fr; }
  .floating-card { right: 0.5rem; top: 0.75rem; }
  .sticky-note, .map-panel, .conversion-rail, .toc { position: relative; top: auto; }
  .listings-toolbar { align-items: flex-start; flex-direction: column; }
  .filter-tabs { justify-content: flex-start; }
  .property-card, .property-feature { grid-column: 1 / -1; }
  .diaspora-map, .diaspora-map img { min-height: 500px; }
  .diaspora-map img { object-position: 60% center; }
  .map-label { font-size: 0.76rem; padding: 0.38rem 0.52rem; }
  .label-paris { --x: 53%; --y: 13.4%; }
  .label-tunis { --x: 36%; --y: 69.4%; }
  .label-hammamet { --x: 49%; --y: 72.4%; }
  .label-sousse { --x: 62%; --y: 67.8%; }
  .label-djerba { --x: 76%; --y: 74.8%; }
  .route-panels { grid-template-columns: 1fr; }
  .listing-card { grid-template-columns: 1fr; }
  .listing-body { padding: var(--bd-s4); }
  .listing-card img { min-height: 15rem; }
  .city-large, .city-wide { grid-column: span 1; grid-row: span 1; }
  .pro-admission, .concierge-band { grid-template-columns: 1fr; padding: var(--bd-s5); }
  .pro-admission-side { justify-items: start; }
  .concierge-flow { grid-template-columns: 1fr; border-radius: var(--bd-r-lg); width: 100%; }
  .concierge-flow span, .concierge-flow strong { width: 100%; justify-content: center; white-space: normal; text-align: center; }
  .guide-teasers { grid-template-columns: 1fr; }
  .VerifiedDossierStrip { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
  .ConsentBanner-inner { align-items: stretch; flex-direction: column; }
  .ConsentBanner-actions { justify-content: stretch; }
  .ConsentBanner-actions .btn { flex: 1 1 auto; }
  .mobile-whatsapp { display: block; }
}

@media (max-width: 520px) {
  .shell, .shell-wide { width: min(100% - 1rem, 100%); }
  .hero-actions, .card-actions { flex-direction: column; }
  .btn { width: 100%; }
  .proof-strip { grid-template-columns: 1fr; }
  .media-frame { min-height: 26rem; }
  .category-deck, .city-mosaic { grid-template-columns: 1fr; }
  .category-card { min-height: 13.5rem; }
  .property-grid { grid-template-columns: 1fr; }
  .property-media { min-height: 14rem; }
  .route-board { padding: var(--bd-s4); }
  .diaspora-map, .diaspora-map img { min-height: 540px; }
  .map-label { max-width: 8rem; white-space: normal; border-radius: var(--bd-r-lg); }
  .map-label small { display: none; }
  .search-strip, .facts { grid-template-columns: 1fr; }
  .VerifiedDossierStrip { grid-template-columns: 1fr; }
  .proof-item { grid-template-columns: 2.7rem 1fr; }
  .proof-item .status { grid-column: 2; width: fit-content; }
  .admission-proof { min-height: auto; padding: var(--bd-s4); }
  .section { padding: var(--bd-s8) 0; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-legal { display: grid; gap: 0.25rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 1ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: 1ms !important; }
  .reveal, html.js .reveal { opacity: 1; transform: none; }
  .map-label, html.js .map-label { opacity: 1; transform: translate(-50%, -50%); }
}

.lead-form {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

.lead-form input {
  min-height: 48px;
  min-width: min(18rem, 100%);
  border-radius: var(--bd-r-pill);
  border: 1px solid var(--bd-line);
  background: var(--bd-bone-40);
  color: var(--bd-ink-930);
  padding: 0 1rem;
}

.lead-form .btn { flex: 0 0 auto; }

@media (max-width: 520px) {
  .lead-form, .lead-form input, .lead-form .btn { width: 100%; }
}

.professional-offers .editorial-hero {
  padding: var(--bd-s9) 0 var(--bd-s6);
  max-width: min(100% - 1.5rem, 62rem);
}

.professional-offers .editorial-hero h1 {
  max-width: 12ch;
  margin: 0;
  font-family: var(--bd-serif);
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: 0.94;
  letter-spacing: -0.055em;
}

.professional-offers .lede {
  max-width: 64ch;
  color: var(--bd-ink-610);
  font-size: var(--bd-t1);
}

.offer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(17rem, 100%), 1fr));
  gap: var(--bd-s4);
  padding-bottom: var(--bd-s7);
}

.offer-card {
  display: grid;
  gap: var(--bd-s4);
  align-content: space-between;
  min-height: 31rem;
  padding: var(--bd-s5);
  border: 1px solid var(--bd-line);
  border-radius: var(--bd-r-xl);
  background: var(--bd-bone-40);
  box-shadow: var(--bd-shadow-sm);
}

.offer-card.is-featured {
  border-color: var(--bd-pine-560);
  background: linear-gradient(180deg, var(--bd-pine-120), var(--bd-bone-40));
}

.offer-card h2 { margin: 0; font-family: var(--bd-serif); font-size: var(--bd-t3); line-height: 1; }
.offer-card .price { margin: var(--bd-s3) 0 0; font-weight: 900; color: var(--bd-pine-820); }
.offer-card ul { margin: 0; padding-left: 1.1rem; color: var(--bd-ink-780); }
.offer-card li + li { margin-top: 0.45rem; }

.trust-panel {
  margin-bottom: var(--bd-s8);
  padding: var(--bd-s6);
  border-radius: var(--bd-r-xl);
  background: var(--bd-ink-930);
  color: var(--bd-bone-80);
}

.trust-panel h2 { margin: 0 0 var(--bd-s3); font-family: var(--bd-serif); font-size: var(--bd-t3); }
.trust-panel p { margin: 0; max-width: 70ch; color: var(--bd-bone-260); }
