/* =========================================
   LUCID PLATFORM — Design Token System
   ========================================= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600&display=swap');

:root{
  --ink:#241F3D;
  --ink-soft:#4A4468;
  --paper:#FBF7EF;
  --paper-soft:#F3ECDF;

  --indigo:#332B7A;
  --indigo-deep:#221A52;
  --indigo-light:#5A4FCF;

  --coral:#FF6B4A;
  --coral-deep:#E24F2E;
  --coral-soft:#FFD9CB;

  --amber:#F4B740;
  --amber-deep:#D6941D;
  --amber-soft:#FCE7B8;

  --teal:#1F8A7A;
  --teal-deep:#166257;
  --teal-soft:#CDEDE6;

  --blush:#F7E1DA;
  --blush-deep:#EFC4B6;

  --cream:#FBF6EC;

  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:24px;
  --radius-xl:32px;
  --radius-pill:999px;

  --shadow-sm:0 1px 2px rgba(36,31,61,.08), 0 1px 1px rgba(36,31,61,.06);
  --shadow-md:0 4px 8px rgba(36,31,61,.10), 0 14px 26px rgba(36,31,61,.12);
  --shadow-lg:0 10px 18px rgba(36,31,61,.16), 0 28px 52px rgba(36,31,61,.20);

  --space-section: clamp(4rem, 8vw, 8rem);
  --space-section-tight: clamp(2.5rem, 5vw, 5rem);

  --ff-head:'Playfair Display', serif;
  --ff-body:'Plus Jakarta Sans', sans-serif;

  --transition-fast:.2s cubic-bezier(.4,0,.2,1);
  --transition-med:.35s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body.canvas{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--ff-head); margin:0 0 .5em; line-height:1.15; font-weight:700; color:var(--ink); }
p{ margin:0 0 1em; }
button{ font-family:var(--ff-body); cursor:pointer; }

h1{ font-size:clamp(2.6rem, 5vw + 1rem, 5rem); }
h2{ font-size:clamp(2rem, 3vw + 1rem, 3.1rem); }
h3{ font-size:clamp(1.25rem, 1vw + 1rem, 1.6rem); }

.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s ease; }
.reveal.visible{ opacity:1; transform:translateY(0); }

/* =========================================
   BUTTONS
   ========================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding-block:.9rem; padding-inline:1.8rem;
  border-radius:var(--radius-pill);
  font-weight:600; font-size:.98rem;
  border:2px solid transparent;
  transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast), color var(--transition-fast);
  min-height:44px;
}
.btn--coral{ background:var(--coral); color:#fff; box-shadow:var(--shadow-md); }
.btn--coral:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); background:var(--coral-deep); }
.btn--amber{ background:var(--amber); color:var(--ink); box-shadow:var(--shadow-md); }
.btn--amber:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); background:var(--amber-deep); color:#fff; }
.btn--indigo{ background:var(--indigo); color:#fff; box-shadow:var(--shadow-md); }
.btn--indigo:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); background:var(--indigo-deep); }
.btn--outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.btn--outline-light:hover{ background:rgba(255,255,255,.15); border-color:#fff; transform:translateY(-3px); }

/* =========================================
   NAV — .bridge (glassmorphism)
   ========================================= */
.bridge{
  position:fixed; inset-inline:0; top:0; z-index:200;
  transition:background var(--transition-med), backdrop-filter var(--transition-med), border-color var(--transition-med), box-shadow var(--transition-med);
  border-bottom:1px solid transparent;
}
.bridge-inner{
  max-width:1280px; margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between;
  padding-block:1.1rem; padding-inline:clamp(1.2rem,4vw,2.5rem);
}
.bridge-logo{ display:flex; align-items:center; gap:.6rem; font-family:var(--ff-head); font-weight:700; font-size:1.2rem; color:var(--ink); }
.bridge--scrolled{
  background:rgba(251,247,239,.72);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border-bottom:1px solid rgba(36,31,61,.08);
  box-shadow:0 4px 24px rgba(36,31,61,.06);
}
.bridge-nav{ display:flex; gap:clamp(1rem,2vw,2.2rem); }
.bridge-nav a{
  font-weight:500; font-size:.96rem; position:relative; padding-block:.3rem;
  transition:color var(--transition-fast);
}
.bridge-nav a::after{
  content:''; position:absolute; left:0; bottom:-2px; height:2px; width:0;
  background:var(--coral); transition:width var(--transition-fast);
}
.bridge-nav a:hover::after, .bridge-nav a.is-active::after{ width:100%; }
.bridge-nav a.is-active{ color:var(--coral-deep); }
.bridge-cta{
  background:var(--indigo); color:#fff; padding:.65rem 1.4rem; border-radius:var(--radius-pill);
  font-weight:600; font-size:.92rem; box-shadow:var(--shadow-sm);
  transition:transform var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
}
.bridge-cta:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); background:var(--indigo-deep); }
.bridge-toggle{
  display:none; flex-direction:column; gap:5px; background:none; border:none; padding:.5rem;
}
.bridge-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:transform var(--transition-fast), opacity var(--transition-fast); }

/* =========================================
   MOBILE DRAWER — bottom tab bar
   ========================================= */
.drawer{
  position:fixed; inset-inline:0; bottom:0; z-index:300;
  display:none;
  background:rgba(251,247,239,.92);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-top:1px solid rgba(36,31,61,.08);
  box-shadow:0 -6px 24px rgba(36,31,61,.12);
  transform:translateY(120%);
  transition:transform var(--transition-med);
  padding-block:.5rem;
  padding-bottom:calc(.5rem + env(safe-area-inset-bottom));
}
.drawer.is-open{ transform:translateY(0); }
.drawer-tab{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:.25rem;
  padding-block:.4rem; font-size:.7rem; font-weight:600; color:var(--ink-soft);
  min-height:44px; justify-content:center;
  transition:color var(--transition-fast);
}
.drawer-tab i{ font-size:1.05rem; }
.drawer-tab.is-active{ color:var(--coral-deep); }

/* =========================================
   STAGE / HERO
   ========================================= */
.stage{
  position:relative; padding-block:calc(var(--space-section) + 4rem) var(--space-section);
  padding-inline:clamp(1.2rem,6vw,5rem);
  background:linear-gradient(135deg, var(--indigo-deep) 0%, var(--indigo) 42%, var(--coral) 78%, var(--amber) 100%);
  color:#fff; overflow:hidden;
}
.stage::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 85% 15%, rgba(255,255,255,.12), transparent 55%);
  pointer-events:none;
}
.stage-inner{ max-width:760px; position:relative; z-index:1; }
.stage-eyebrow{
  text-transform:uppercase; letter-spacing:.14em; font-size:.8rem; font-weight:600;
  color:rgba(255,255,255,.85); margin-bottom:1.2rem;
}
.stage-heading{ color:#fff; margin-bottom:1.2rem; }
.stage-sub{ font-size:1.15rem; color:rgba(255,255,255,.92); max-width:620px; margin-bottom:2.2rem; }
.stage-actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }

.stage-path{ display:flex; gap:1.5rem; flex-wrap:wrap; position:relative; z-index:1; }
.stage-path-step{
  display:flex; flex-direction:column; align-items:flex-start; gap:.5rem;
  position:relative; padding-inline-end:1.5rem; cursor:default;
}
.stage-path-step:not(:last-child)::after{
  content:''; position:absolute; top:18px; right:-.75rem; width:2rem; height:2px;
  background:rgba(255,255,255,.35);
}
.stage-path-dot{
  width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.4);
  font-family:var(--ff-head); font-weight:700; color:#fff;
  transition:background var(--transition-fast), transform var(--transition-fast);
}
.stage-path-step:hover .stage-path-dot, .stage-path-step:focus .stage-path-dot{
  background:var(--coral); transform:scale(1.08);
}
.stage-path-label{ font-weight:600; font-size:.95rem; color:#fff; }
.stage-path-tip{
  font-size:.8rem; color:rgba(255,255,255,.75); max-width:170px;
}

.stage--sub{ padding-block:calc(var(--space-section-tight) + 4rem) var(--space-section-tight); }
.stage--teal{ background:linear-gradient(135deg, var(--teal-deep), var(--teal) 60%, var(--amber) 130%); }
.stage--coral{ background:linear-gradient(135deg, var(--coral-deep), var(--coral) 55%, var(--amber) 120%); }
.stage--amber{ background:linear-gradient(135deg, var(--amber-deep), var(--amber) 55%, var(--coral) 130%); }
.stage--indigo{ background:linear-gradient(135deg, var(--indigo-deep), var(--indigo) 60%, var(--teal) 130%); }
.stage--thanks{ background:linear-gradient(135deg, var(--coral-deep), var(--indigo) 55%, var(--teal) 120%); padding-block:calc(var(--space-section) + 3rem) var(--space-section); }

/* =========================================
   SEAM — decorative strip
   ========================================= */
.seam{ height:10px; width:100%; }
.seam--coral{ background:repeating-linear-gradient(90deg, var(--coral) 0 24px, var(--coral-soft) 24px 48px); }
.seam--amber{ background:repeating-linear-gradient(90deg, var(--amber) 0 24px, var(--amber-soft) 24px 48px); }
.seam--teal{ background:repeating-linear-gradient(90deg, var(--teal) 0 24px, var(--teal-soft) 24px 48px); }
.seam--indigo{ background:repeating-linear-gradient(90deg, var(--indigo) 0 24px, var(--indigo-light) 24px 48px); }

/* =========================================
   ALCOVE — editorial off-center rows
   ========================================= */
.alcove{ padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem); }
.alcove--blush{ background:var(--blush); }
.alcove--amber{ background:var(--amber-soft); }
.alcove--paper{ background:var(--paper); }
.alcove-row{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem);
  align-items:center; max-width:1280px; margin-inline:auto;
}
.alcove-row + .alcove-row{ margin-top:var(--space-section-tight); }
.alcove-row--reverse .alcove-media{ order:2; }
.alcove-row--reverse .alcove-text{ order:1; }
.alcove-eyebrow{
  text-transform:uppercase; letter-spacing:.12em; font-size:.78rem; font-weight:600;
  color:var(--coral-deep); margin-bottom:.8rem;
}
.terrain-eyebrow{ color:#fff; opacity:.85; }
.alcove-text h2{ margin-bottom:1rem; }
.alcove-text p{ color:var(--ink-soft); max-width:520px; }
.checklist li{ display:flex; gap:.6rem; align-items:flex-start; margin-bottom:.6rem; color:var(--ink-soft); }
.checklist i{ color:var(--teal); margin-top:.25rem; }

.frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-lg);
  padding:10px;
  background:linear-gradient(155deg, rgba(255,255,255,.6), rgba(255,255,255,.1));
}
.frame img{ border-radius:calc(var(--radius-lg) - 8px); width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.frame--card{ padding:6px; margin-bottom:1rem; }
.frame--card img{ aspect-ratio:16/10; }

/* =========================================
   GALLERY / SHELF / SPOTLIGHT
   ========================================= */
.gallery{ padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem); }
.gallery--cream{ background:var(--cream); }
.gallery--blush{ background:var(--blush); padding-block:0 var(--space-section); }
.gallery-head{ max-width:680px; margin-inline:auto; text-align:center; margin-bottom:3.5rem; }
.gallery-lede{ color:var(--ink-soft); font-size:1.05rem; }

.shelf{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(250px,1fr));
  gap:1.8rem; max-width:1280px; margin-inline:auto;
}
.shelf--two{ grid-template-columns:repeat(auto-fit, minmax(320px,1fr)); }

.spotlight{
  background:#fff; border-radius:var(--radius-lg); padding:2.2rem;
  box-shadow:var(--shadow-sm);
  border-top:5px solid transparent;
  transition:transform var(--transition-med), box-shadow var(--transition-med), border-color var(--transition-med);
}
.spotlight:hover{ transform:translateY(-8px) scale(1.02); box-shadow:var(--shadow-lg); }
.spotlight--coral{ border-color:var(--coral); }
.spotlight--amber{ border-color:var(--amber); }
.spotlight--teal{ border-color:var(--teal); }
.spotlight--indigo{ border-color:var(--indigo); }
.spotlight-icon{
  width:52px; height:52px; border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center;
  background:color-mix(in srgb, var(--coral) 12%, white); color:var(--coral-deep); font-size:1.3rem; margin-bottom:1.2rem;
}
.spotlight--amber .spotlight-icon{ background:color-mix(in srgb, var(--amber) 18%, white); color:var(--amber-deep); }
.spotlight--teal .spotlight-icon{ background:color-mix(in srgb, var(--teal) 15%, white); color:var(--teal-deep); }
.spotlight--indigo .spotlight-icon{ background:color-mix(in srgb, var(--indigo) 12%, white); color:var(--indigo); }
.spotlight p{ color:var(--ink-soft); font-size:.96rem; margin-bottom:0; }
.spotlight h3{ margin-bottom:.7rem; }

/* =========================================
   TERRAIN — map / service areas section
   ========================================= */
.terrain{
  background:linear-gradient(160deg, var(--teal-deep), var(--teal));
  padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem);
  color:#fff;
}
.terrain-head{ max-width:680px; margin-inline:auto; text-align:center; margin-bottom:3rem; }
.terrain-head h2{ color:#fff; }
.terrain-lede{ color:rgba(255,255,255,.85); }
.terrain-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.5rem;
  max-width:1280px; margin-inline:auto;
}
.terrain-card{
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius-lg); padding:1.8rem;
  transition:transform var(--transition-med), background var(--transition-med), box-shadow var(--transition-med);
}
.terrain-card:hover{ transform:translateY(-6px) scale(1.02); background:rgba(255,255,255,.14); box-shadow:var(--shadow-md); }
.terrain-card i{ color:var(--amber); font-size:1.4rem; margin-bottom:.8rem; }
.terrain-card h3{ color:#fff; margin-bottom:.6rem; font-size:1.15rem; }
.terrain-card p{ color:rgba(255,255,255,.82); font-size:.92rem; margin-bottom:0; }
.terrain--map{ background:linear-gradient(160deg, var(--teal-deep), var(--indigo)); }
.terrain-map-frame{
  max-width:1000px; margin-inline:auto; border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:var(--shadow-lg); border:6px solid rgba(255,255,255,.15);
}

/* =========================================
   SPOTLIGHT CTA
   ========================================= */
.spotlight-cta{
  padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem);
  background:linear-gradient(120deg, var(--indigo-deep), var(--indigo) 60%, var(--coral) 130%);
  color:#fff; text-align:center;
}
.spotlight-cta--teal{ background:linear-gradient(120deg, var(--teal-deep), var(--teal) 60%, var(--indigo) 130%); }
.spotlight-cta--amber{ background:linear-gradient(120deg, var(--amber-deep), var(--amber) 55%, var(--coral) 130%); }
.spotlight-cta-inner{ max-width:680px; margin-inline:auto; }
.spotlight-cta h2{ color:#fff; margin-bottom:1rem; }
.spotlight-cta p{ color:rgba(255,255,255,.9); margin-bottom:2rem; }
.spotlight-cta .stage-actions{ justify-content:center; margin-bottom:0; }

/* =========================================
   DESK — contact form
   ========================================= */
.desk-section{ padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem); background:var(--paper); }
.desk-grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2rem,5vw,4rem);
  max-width:1280px; margin-inline:auto; align-items:start;
}
.desk-form{ background:#fff; border-radius:var(--radius-xl); padding:clamp(1.8rem,4vw,3rem); box-shadow:var(--shadow-md); }
.desk-form-lede{ color:var(--ink-soft); margin-bottom:1.8rem; }
.desk-field{ margin-bottom:1.3rem; display:flex; flex-direction:column; gap:.4rem; }
.desk-field label{ font-weight:600; font-size:.9rem; }
.desk-field input[type=text], .desk-field input[type=email], .desk-field input[type=tel], .desk-field textarea{
  padding:.85rem 1rem; border-radius:var(--radius-sm); border:1.5px solid rgba(36,31,61,.15);
  font-family:var(--ff-body); font-size:.98rem; background:var(--paper); min-height:44px;
  transition:border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.desk-field input:focus, .desk-field textarea:focus{
  outline:none; border-color:var(--coral); box-shadow:0 0 0 4px color-mix(in srgb, var(--coral) 18%, transparent);
}
.desk-field--check{ flex-direction:row; align-items:flex-start; gap:.7rem; }
.desk-field--check input{ margin-top:.3rem; width:20px; height:20px; accent-color:var(--coral); }
.desk-field--check label{ font-weight:400; font-size:.88rem; color:var(--ink-soft); }
.desk-submit{ width:100%; margin-top:.5rem; }

.desk-info{ display:flex; flex-direction:column; gap:1.5rem; }
.desk-info-card{ background:var(--blush); border-radius:var(--radius-lg); padding:1.8rem; box-shadow:var(--shadow-sm); }
.desk-info-card h3{ margin-bottom:1rem; }
.desk-info-card ul li{ display:flex; gap:.7rem; align-items:center; margin-bottom:.7rem; color:var(--ink-soft); }
.desk-info-card ul li i{ color:var(--coral-deep); width:18px; }
.desk-hours{ width:100%; border-collapse:collapse; margin-bottom:1rem; }
.desk-hours td{ padding:.5rem 0; border-bottom:1px solid rgba(36,31,61,.08); font-size:.92rem; color:var(--ink-soft); }
.desk-hours-note{ font-size:.85rem; color:var(--ink-soft); margin-bottom:0; }

/* =========================================
   THANKS PAGE NEXT STEPS
   ========================================= */
.thanks-next{ padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem); background:var(--paper); }
.thanks-next-inner{ max-width:640px; margin-inline:auto; text-align:center; }
.thanks-next-inner p{ color:var(--ink-soft); margin-bottom:2rem; }

/* =========================================
   LEGAL PAGES
   ========================================= */
.legal-stage{
  padding-block:calc(var(--space-section-tight) + 3.5rem) var(--space-section-tight);
  padding-inline:clamp(1.2rem,6vw,5rem);
  background:linear-gradient(135deg, var(--indigo-deep), var(--indigo));
  color:#fff;
}
.legal-stage--terms{ background:linear-gradient(135deg, var(--teal-deep), var(--teal)); }
.legal-stage--cookies{ background:linear-gradient(135deg, var(--coral-deep), var(--coral)); }
.legal-stage--impressum{ background:linear-gradient(135deg, var(--amber-deep), var(--amber)); }
.legal-stage-inner{ max-width:800px; }
.legal-stage h1{ color:#fff; margin-bottom:.6rem; }
.legal-stage p{ color:rgba(255,255,255,.85); margin-bottom:0; }

.legal-body{ padding-block:var(--space-section); padding-inline:clamp(1.2rem,6vw,5rem); background:var(--paper); }
.legal-body-inner{ max-width:820px; margin-inline:auto; }
.legal-sec{ margin-bottom:2.4rem; }
.legal-sec h2{ font-size:1.35rem; margin-bottom:.8rem; }
.legal-sec p{ color:var(--ink-soft); }
.legal-list{ margin-top:.8rem; padding-inline-start:1.2rem; }
.legal-list li{ list-style:disc; color:var(--ink-soft); margin-bottom:.5rem; }
.legal-table{ width:100%; border-collapse:collapse; margin-block:1rem; }
.legal-table td{ padding:.7rem .5rem; border-bottom:1px solid rgba(36,31,61,.1); font-size:.92rem; color:var(--ink-soft); vertical-align:top; }
.legal-table td:first-child{ font-weight:600; color:var(--ink); width:40%; }

/* =========================================
   FOOTER — .harbor
   ========================================= */
.harbor{ background:var(--indigo-deep); color:rgba(255,255,255,.85); padding-block:var(--space-section-tight) 0; }
.harbor-inner{
  max-width:1280px; margin-inline:auto; padding-inline:clamp(1.2rem,6vw,5rem);
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2.5rem;
  padding-bottom:2.5rem; border-bottom:1px solid rgba(255,255,255,.1);
}
.harbor-col h3{ color:#fff; font-size:1.05rem; margin-bottom:1rem; }
.harbor-about p{ font-size:.92rem; color:rgba(255,255,255,.7); margin-top:1rem; }
.harbor-about .bridge-logo span{ color:#fff; }
.harbor-col ul li{ margin-bottom:.6rem; }
.harbor-col ul li a{ font-size:.92rem; color:rgba(255,255,255,.75); transition:color var(--transition-fast); }
.harbor-col ul li a:hover{ color:var(--amber); }
.harbor-contact ul li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.9rem; color:rgba(255,255,255,.8); }
.harbor-contact ul li i{ margin-top:.2rem; color:var(--amber); }
.harbor-newsletter{
  max-width:1280px; margin-inline:auto; padding-inline:clamp(1.2rem,6vw,5rem);
  padding-block:2rem; display:flex; flex-direction:column; gap:.8rem;
}
.harbor-newsletter label{ font-size:.9rem; color:rgba(255,255,255,.8); }
.harbor-newsletter-row{ display:flex; gap:.8rem; max-width:460px; flex-wrap:wrap; }
.harbor-newsletter-row input{
  flex:1; min-width:200px; padding:.8rem 1rem; border-radius:var(--radius-pill); border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.06); color:#fff; min-height:44px;
}
.harbor-newsletter-row input::placeholder{ color:rgba(255,255,255,.5); }
.harbor-newsletter-row button{
  background:var(--coral); color:#fff; border:none; padding-inline:1.6rem; border-radius:var(--radius-pill); font-weight:600;
  transition:background var(--transition-fast), transform var(--transition-fast); min-height:44px;
}
.harbor-newsletter-row button:hover{ background:var(--coral-deep); transform:translateY(-2px); }
.harbor-bottom{
  max-width:1280px; margin-inline:auto; padding-inline:clamp(1.2rem,6vw,5rem);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem;
  padding-block:1.5rem; font-size:.82rem; color:rgba(255,255,255,.55);
}

/* =========================================
   COOKIE CONSENT — .capsule
   ========================================= */
.capsule{ position:fixed; inset-inline:0; bottom:1.5rem; z-index:500; display:flex; justify-content:center; padding-inline:1rem; }
.capsule-pill{
  display:none; align-items:center; gap:1rem; flex-wrap:wrap; justify-content:center;
  background:rgba(36,31,61,.94); color:#fff; padding:.8rem 1.4rem;
  border-radius:var(--radius-pill); box-shadow:var(--shadow-lg);
  backdrop-filter:blur(10px);
  max-width:640px;
  transition:opacity var(--transition-med), transform var(--transition-med);
}
.capsule.is-visible .capsule-pill{ display:flex; }
.capsule-pill p{ margin:0; font-size:.85rem; }
.capsule-pill button#capsuleCustomize{
  background:none; border:none; color:var(--amber); font-weight:600; text-decoration:underline; padding:0; font-size:.85rem;
}
.capsule-pill-actions{ display:flex; gap:.6rem; }
.capsule-btn{
  border:1px solid rgba(255,255,255,.3); background:transparent; color:#fff;
  padding:.5rem 1rem; border-radius:var(--radius-pill); font-size:.82rem; font-weight:600;
  transition:background var(--transition-fast), transform var(--transition-fast);
  min-height:38px;
}
.capsule-btn:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }
.capsule-btn--accent{ background:var(--coral); border-color:var(--coral); }
.capsule-btn--accent:hover{ background:var(--coral-deep); }

.capsule-modal{
  display:none; background:#fff; color:var(--ink); border-radius:var(--radius-xl);
  padding:2rem; max-width:520px; width:100%; box-shadow:var(--shadow-lg);
  max-height:80vh; overflow-y:auto;
}
.capsule.is-expanded .capsule-modal{ display:block; }
.capsule.is-expanded .capsule-pill{ display:none; }
.capsule-modal h3{ margin-bottom:.6rem; }
.capsule-modal > p{ color:var(--ink-soft); font-size:.9rem; margin-bottom:1.3rem; }
.capsule-cat{ padding-block:.9rem; border-top:1px solid rgba(36,31,61,.08); }
.capsule-cat-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:.4rem; }
.capsule-cat-head input{ width:20px; height:20px; accent-color:var(--coral); }
.capsule-cat p{ font-size:.85rem; color:var(--ink-soft); margin-bottom:0; }
.capsule-modal-actions{ display:flex; gap:.8rem; margin-top:1.4rem; flex-wrap:wrap; }
.capsule-modal-actions .capsule-btn{ color:var(--ink); border-color:rgba(36,31,61,.2); }
.capsule-modal-actions .capsule-btn:hover{ background:rgba(36,31,61,.06); }
.capsule-modal-actions .capsule-btn--accent{ color:#fff; }

/* =========================================
   RESPONSIVE
   ========================================= */
@media (max-width: 980px){
  .bridge-nav, .bridge-cta{ display:none; }
  .bridge-toggle{ display:flex; }
  .drawer{ display:flex; }
  .alcove-row{ grid-template-columns:1fr; }
  .alcove-row--reverse .alcove-media{ order:1; }
  .alcove-row--reverse .alcove-text{ order:2; }
  .desk-grid{ grid-template-columns:1fr; }
  .harbor-inner{ grid-template-columns:1fr 1fr; }
}

@media (max-width: 640px){
  .harbor-inner{ grid-template-columns:1fr; }
  .stage-path{ flex-direction:column; gap:1.2rem; }
  .stage-path-step:not(:last-child)::after{ display:none; }
  .capsule{ bottom:1rem; }
  .capsule-pill{ flex-direction:column; align-items:stretch; text-align:center; }
  .capsule-pill-actions{ justify-content:center; }
  main{ padding-top:0; }
}

@media (max-width: 400px){
  .stage-heading{ font-size:2.1rem; }
}