/* =============================================================================
   Nomads With a Couch — Design System
   Warm earth tones · Fraunces serif + DM Sans · v1.0
   ============================================================================= */

/* ── Tokens ── */
:root {
  --nwac-orange:        hsl(22 85% 52%);
  --nwac-orange-light:  hsl(22 85% 95%);
  --nwac-orange-dark:   hsl(22 85% 42%);
  --nwac-teal:          hsl(185 45% 42%);
  --nwac-teal-light:    hsl(185 45% 94%);
  --nwac-teal-dark:     hsl(185 45% 32%);
  --nwac-amber:         hsl(38 90% 50%);
  --nwac-amber-light:   hsl(38 90% 94%);
  --nwac-cream:         hsl(42 33% 96%);
  --nwac-cream-2:       hsl(38 25% 91%);
  --nwac-brown:         hsl(24 18% 28%);
  --nwac-brown-light:   hsl(24 12% 42%);
  --nwac-text:          hsl(24 20% 18%);
  --nwac-muted:         hsl(24 12% 48%);
  --nwac-border:        hsl(36 18% 86%);
  --nwac-surface:       #fff;
  --nwac-dark-bg:       hsl(24 18% 14%);
  --nwac-dark-text:     hsl(38 30% 94%);
  --nwac-dark-muted:    hsl(38 18% 70%);
  --nwac-radius:        10px;
  --nwac-radius-lg:     16px;
  --nwac-shadow:        0 1px 3px rgba(0,0,0,.07), 0 4px 12px rgba(0,0,0,.06);
  --nwac-shadow-lg:     0 4px 16px rgba(0,0,0,.10), 0 16px 40px rgba(0,0,0,.08);
  --nwac-nav-width:     240px;
  --nwac-topnav-h:      64px;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--nwac-text);
  background: var(--nwac-cream);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
textarea, input, select { font: inherit; }
ul { padding-left: 1.4em; }

/* ── Accessibility ── */
.screen-reader-text { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0; }
.nwac-skip-link:focus { position:fixed;top:8px;left:8px;z-index:9999;padding:10px 18px;background:var(--nwac-orange);color:#fff;border-radius:8px; }

/* ── Typography ── */
h1, h2, h3, h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 500;
  line-height: 1.2;
  margin: 0 0 .5em;
}
p { margin: 0 0 1em; }
.nwac-h1 { font-size: clamp(2rem, 4vw, 2.75rem); }
.nwac-h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.nwac-h2--light { color: var(--nwac-dark-text); }
.nwac-h3 { font-size: 1.25rem; }
.nwac-muted { color: var(--nwac-muted); font-size: .95rem; }
.nwac-eyebrow { display:inline-block; font-size:.82rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--nwac-orange); margin-bottom:1rem; }

/* ── Layout ── */
.nwac-container { width:100%; max-width:1160px; margin:0 auto; padding:0 24px; }
.nwac-main { min-height:60vh; }
section { padding:80px 0; }

/* ── Buttons ── */
.nwac-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px; border-radius: var(--nwac-radius);
  font-size: .95rem; font-weight: 600; line-height: 1;
  transition: all .15s ease; white-space: nowrap;
  text-decoration: none;
}
.nwac-btn--primary { background:var(--nwac-orange); color:#fff; }
.nwac-btn--primary:hover { background:var(--nwac-orange-dark); transform:translateY(-1px); box-shadow:0 4px 12px rgba(0,0,0,.15); }
.nwac-btn--ghost { background:transparent; color:var(--nwac-text); border:1.5px solid var(--nwac-border); }
.nwac-btn--ghost:hover { border-color:var(--nwac-orange); color:var(--nwac-orange); }
.nwac-btn--teal { background:var(--nwac-teal); color:#fff; }
.nwac-btn--teal:hover { background:var(--nwac-teal-dark); }
.nwac-btn--amber { background:var(--nwac-amber); color:#fff; }
.nwac-btn--amber:hover { filter:brightness(.92); }
.nwac-btn--block { width:100%; justify-content:center; }
.nwac-btn--sm { padding:8px 16px; font-size:.875rem; }
.nwac-link { color:var(--nwac-orange); text-decoration:underline; text-underline-offset:2px; }
.nwac-link:hover { color:var(--nwac-orange-dark); }

/* ── Badges ── */
.nwac-badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:3px 10px; border-radius:100px;
  font-size:.78rem; font-weight:600; white-space:nowrap;
}
.nwac-badge--primary { background:var(--nwac-orange-light); color:var(--nwac-orange-dark); }
.nwac-badge--teal    { background:var(--nwac-teal-light); color:var(--nwac-teal-dark); }
.nwac-badge--amber   { background:var(--nwac-amber-light); color:hsl(32 80% 32%); }
.nwac-badge--muted   { background:var(--nwac-cream-2); color:var(--nwac-muted); }

/* ── Cost badge ── */
.nwac-cost-badge { position:absolute; top:12px; right:12px; padding:4px 10px; border-radius:100px; font-size:.78rem; font-weight:600; }
.nwac-cost-badge--green { background:#d1fae5; color:#065f46; }
.nwac-cost-badge--amber { background:#fef3c7; color:#92400e; }
.nwac-cost-badge--blue  { background:#dbeafe; color:#1e40af; }

/* ── Avatars ── */
.nwac-avatar { border-radius:50%; object-fit:cover; flex-shrink:0; }
.nwac-avatar--xs  { width:32px;  height:32px;  }
.nwac-avatar--sm  { width:48px;  height:48px;  }
.nwac-avatar--md  { width:64px;  height:64px;  display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem; }
.nwac-avatar--lg  { width:80px;  height:80px;  }
.nwac-avatar--xl  { width:120px; height:120px; }

/* ── Stars ── */
.nwac-stars { display:inline-flex; gap:2px; color:var(--nwac-amber); }
.nwac-star { font-size:16px; opacity:.25; }
.nwac-star--filled { opacity:1; }

/* ── Marketing Top Nav ── */
.nwac-topnav {
  position:sticky; top:0; z-index:200;
  height:var(--nwac-topnav-h);
  background:rgba(251,248,243,.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--nwac-border);
}
.nwac-topnav__inner { display:flex; align-items:center; gap:24px; height:100%; }
.nwac-brand { display:inline-flex; align-items:center; gap:10px; font-family:'Fraunces',serif; font-size:1.1rem; font-weight:500; color:var(--nwac-text); flex-shrink:0; }
.nwac-brand-icon { color:var(--nwac-orange); }
.nwac-topnav__links { display:flex; gap:4px; align-items:center; flex:1; }
.nwac-topnav__link { padding:8px 14px; border-radius:8px; color:var(--nwac-brown-light); font-size:.95rem; font-weight:500; transition:all .15s; }
.nwac-topnav__link:hover, .nwac-topnav__link.is-active { background:var(--nwac-cream-2); color:var(--nwac-text); }
.nwac-topnav__actions { display:flex; align-items:center; gap:10px; }
.nwac-topnav__login { display:none; }
@media(min-width:768px) { .nwac-topnav__login { display:inline-flex; } }
.nwac-hamburger { display:flex; flex-direction:column; gap:5px; padding:8px; margin-left:auto; }
.nwac-hamburger span { display:block; width:20px; height:2px; background:var(--nwac-text); border-radius:2px; transition:all .2s; }
@media(min-width:900px) { .nwac-hamburger { display:none; } .nwac-topnav__links { display:flex; } }
@media(max-width:899px) { .nwac-topnav__links, .nwac-topnav__actions { display:none; } }
.nwac-mobile-menu {
  position:fixed; top:var(--nwac-topnav-h); left:0; right:0; z-index:199;
  background:var(--nwac-cream); border-bottom:1px solid var(--nwac-border);
  padding:16px 24px; display:flex; flex-direction:column; gap:8px;
}
.nwac-mobile-menu[hidden] { display:none; }
.nwac-mobile-menu a { padding:10px 0; border-bottom:1px solid var(--nwac-border); font-weight:500; }
.nwac-mobile-menu a:last-child { border:none; }

/* ── Sidebar App Layout ── */
.nwac-app-shell { display:flex; min-height:100vh; }
.nwac-sidebar {
  width:var(--nwac-nav-width); flex-shrink:0;
  background:var(--nwac-dark-bg); color:var(--nwac-dark-text);
  display:flex; flex-direction:column;
  padding:24px 0; position:sticky; top:0; height:100vh; overflow-y:auto;
}
.nwac-sidebar .nwac-brand { padding:0 20px 24px; color:var(--nwac-dark-text); }
.nwac-sidebar .nwac-brand-icon { color:var(--nwac-orange); }
.nwac-nav { flex:1; display:flex; flex-direction:column; gap:2px; padding:0 12px; }
.nwac-nav-item { display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:8px; color:var(--nwac-dark-muted); font-size:.9rem; font-weight:500; transition:all .15s; }
.nwac-nav-item:hover { background:rgba(255,255,255,.06); color:var(--nwac-dark-text); }
.nwac-nav-item.is-active { background:rgba(255,255,255,.10); color:#fff; }
.nwac-nav-item svg { flex-shrink:0; }
.nwac-sidebar-footer { padding:12px 12px 0; border-top:1px solid rgba(255,255,255,.08); margin-top:auto; }
.nwac-app-main { flex:1; min-width:0; }
.nwac-app-content { padding:40px 48px; max-width:900px; }
@media(max-width:768px) {
  .nwac-sidebar { display:none; }
  .nwac-app-content { padding:24px 20px; }
}

/* ── Hero ── */
.nwac-hero { padding:100px 0 80px; position:relative; overflow:hidden; }
.nwac-hero__bg-pattern {
  position:absolute; inset:0; z-index:0;
  background-image:radial-gradient(circle at 70% 40%, hsla(22,85%,60%,.06) 0%, transparent 60%),
                   radial-gradient(circle at 20% 70%, hsla(185,45%,50%,.05) 0%, transparent 50%);
}
.nwac-hero__inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media(max-width:820px) { .nwac-hero__inner { grid-template-columns:1fr; } .nwac-hero__preview { display:none; } }
.nwac-hero__content { display:flex; flex-direction:column; align-items:flex-start; }
.nwac-hero__title { font-family:'Fraunces',serif; font-size:clamp(2.4rem,5vw,3.6rem); line-height:1.1; margin:.75rem 0 1rem; }
.nwac-hero__subtitle { font-size:1.15rem; color:var(--nwac-brown-light); margin-bottom:2rem; max-width:480px; }
.nwac-hero__trust { display:flex; flex-wrap:wrap; gap:16px; margin-top:1.25rem; font-size:.85rem; color:var(--nwac-muted); }
.nwac-hero__trust span { display:flex; align-items:center; gap:4px; }

/* Preview card */
.nwac-preview-card { background:#fff; border-radius:var(--nwac-radius-lg); padding:24px; box-shadow:var(--nwac-shadow-lg); border:1px solid var(--nwac-border); }
.nwac-preview-card__header { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.nwac-preview-card__header p { margin:0; font-size:.82rem; color:var(--nwac-muted); }
.nwac-preview-card__header strong { display:block; }
.nwac-preview-card__meta { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; font-size:.82rem; }

/* Waitlist form */
.nwac-waitlist-form { display:flex; gap:8px; flex-wrap:wrap; max-width:480px; }
.nwac-waitlist-form input[type="email"] { flex:1; min-width:200px; padding:12px 16px; border:1.5px solid var(--nwac-border); border-radius:var(--nwac-radius); background:#fff; font-size:.95rem; transition:border-color .15s; }
.nwac-waitlist-form input[type="email"]:focus { outline:none; border-color:var(--nwac-orange); }
.nwac-waitlist-form--footer { max-width:480px; margin:0 auto; }
.nwac-waitlist-count-label { font-size:.85rem; color:var(--nwac-muted); margin:.5rem 0 0; }
.nwac-waitlist-success { color:var(--nwac-teal); font-weight:600; margin:.5rem 0 0; }

/* ── Problem section ── */
.nwac-problem { background:#fff; }
.nwac-problem__grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media(max-width:760px) { .nwac-problem__grid { grid-template-columns:1fr; } }
.nwac-problem__text p { color:var(--nwac-brown-light); font-size:1.05rem; }
.nwac-problem__callout { font-family:'Fraunces',serif; font-size:1.3rem; color:var(--nwac-text); font-style:italic; border-left:3px solid var(--nwac-orange); padding-left:1.2rem; margin-top:1.5rem; }
.nwac-problem__stats { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.nwac-stat { background:var(--nwac-cream); border-radius:var(--nwac-radius-lg); padding:28px 24px; text-align:center; }
.nwac-stat__num { display:block; font-family:'Fraunces',serif; font-size:2.8rem; color:var(--nwac-orange); line-height:1; }
.nwac-stat__label { font-size:.88rem; color:var(--nwac-muted); margin-top:6px; display:block; }

/* ── Modes ── */
.nwac-section-header { text-align:center; max-width:680px; margin:0 auto 56px; }
.nwac-section-header--split { display:flex; justify-content:space-between; align-items:flex-end; text-align:left; max-width:none; margin-bottom:40px; }
.nwac-section-sub { color:var(--nwac-brown-light); font-size:1.05rem; margin-top:.5rem; }
.nwac-section-sub--light { color:var(--nwac-dark-muted); }
.nwac-modes { background:var(--nwac-cream); }
.nwac-modes__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px) { .nwac-modes__grid { grid-template-columns:1fr; } }
.nwac-mode-card { border-radius:var(--nwac-radius-lg); padding:36px 32px; display:flex; flex-direction:column; gap:16px; }
.nwac-mode-card--primary { background:#fff; border:1.5px solid var(--nwac-orange); }
.nwac-mode-card--teal    { background:var(--nwac-teal-light); }
.nwac-mode-card--amber   { background:var(--nwac-amber-light); }
.nwac-mode-card__icon { font-size:2rem; }
.nwac-mode-card h3 { font-family:'Fraunces',serif; font-size:1.4rem; margin:0; }
.nwac-mode-card p { color:var(--nwac-brown-light); margin:0; flex:1; }
.nwac-mode-card__list { margin:0; padding-left:1.4em; color:var(--nwac-muted); font-size:.9rem; }

/* ── Honor ── */
.nwac-honor { background:#fff; }
.nwac-honor__grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media(max-width:760px) { .nwac-honor__grid { grid-template-columns:1fr; } }
.nwac-honor__text p { color:var(--nwac-brown-light); }
.nwac-blockquote { margin:0; background:var(--nwac-cream); border-radius:var(--nwac-radius-lg); padding:32px; border-left:3px solid var(--nwac-orange); }
.nwac-blockquote p { font-family:'Fraunces',serif; font-style:italic; font-size:1.1rem; color:var(--nwac-text); margin-bottom:1rem; }
.nwac-blockquote cite { font-size:.875rem; color:var(--nwac-muted); font-style:normal; }

/* ── Features ── */
.nwac-features { background:var(--nwac-cream); }
.nwac-features__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px) { .nwac-features__grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px) { .nwac-features__grid { grid-template-columns:1fr; } }
.nwac-feature-card { background:#fff; border-radius:var(--nwac-radius-lg); padding:28px; border:1px solid var(--nwac-border); }
.nwac-feature-card__icon { font-size:1.75rem; display:block; margin-bottom:12px; }
.nwac-feature-card h3 { font-family:'Fraunces',serif; font-size:1.1rem; margin:0 0 8px; }
.nwac-feature-card p { color:var(--nwac-muted); font-size:.92rem; margin:0; }

/* ── Listings preview ── */
.nwac-listings-preview { background:#fff; }
.nwac-listing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px) { .nwac-listing-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px) { .nwac-listing-grid { grid-template-columns:1fr; } }

/* Listing card */
.nwac-listing-card { display:flex; flex-direction:column; background:#fff; border-radius:var(--nwac-radius-lg); border:1px solid var(--nwac-border); overflow:hidden; transition:box-shadow .2s, transform .2s; }
.nwac-listing-card:hover { box-shadow:var(--nwac-shadow-lg); transform:translateY(-2px); }
.nwac-listing-card__img { position:relative; aspect-ratio:3/2; background:var(--nwac-cream-2); overflow:hidden; }
.nwac-listing-card__img img { width:100%; height:100%; object-fit:cover; }
.nwac-listing-card__img-placeholder { width:100%; height:100%; background:linear-gradient(135deg, var(--nwac-cream-2) 0%, var(--nwac-border) 100%); }
.nwac-listing-card__type-badge { position:absolute; top:12px; left:12px; }
.nwac-listing-card__verified { position:absolute; bottom:12px; left:12px; display:flex; align-items:center; gap:4px; font-size:.75rem; font-weight:600; color:var(--nwac-teal); background:rgba(255,255,255,.92); border-radius:100px; padding:3px 8px; }
.nwac-verified-dot { width:6px; height:6px; border-radius:50%; background:var(--nwac-teal); display:inline-block; }
.nwac-listing-card__body { padding:18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.nwac-listing-card__city { display:flex; align-items:center; gap:4px; font-size:.8rem; color:var(--nwac-muted); }
.nwac-listing-card__title { font-weight:600; font-size:.95rem; line-height:1.35; margin:0; color:var(--nwac-text); }
.nwac-listing-card__meta { display:flex; flex-wrap:wrap; gap:12px; font-size:.8rem; color:var(--nwac-muted); }
.nwac-listing-card__meta span { display:flex; align-items:center; gap:4px; }
.nwac-listing-card__footer { display:flex; justify-content:space-between; align-items:center; margin-top:auto; padding-top:12px; border-top:1px solid var(--nwac-border); }
.nwac-listing-card__author { display:flex; align-items:center; gap:8px; font-size:.82rem; color:var(--nwac-muted); }
.nwac-listing-card__rating { display:flex; align-items:center; gap:4px; font-size:.82rem; color:var(--nwac-amber); font-weight:600; }

/* ── Elegy / "communities we loved" ── */
.nwac-elegy { background:var(--nwac-dark-bg); color:var(--nwac-dark-text); padding:100px 0; }
.nwac-elegy .nwac-section-header { color:var(--nwac-dark-text); }
.nwac-elegy__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px) { .nwac-elegy__grid { grid-template-columns:1fr; } }
.nwac-elegy-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); border-radius:var(--nwac-radius-lg); padding:32px; }
.nwac-elegy-card--highlighted { background:rgba(224,122,47,.10); border-color:rgba(224,122,47,.35); }
.nwac-elegy-card__header { display:flex; align-items:flex-start; gap:12px; margin-bottom:16px; }
.nwac-elegy-card__icon { font-size:1.75rem; flex-shrink:0; }
.nwac-elegy-card__header h3 { font-family:'Fraunces',serif; font-size:1.1rem; margin:0; color:var(--nwac-dark-text); }
.nwac-elegy-card__years { font-size:.8rem; color:var(--nwac-dark-muted); display:block; margin-top:2px; }
.nwac-elegy-status { margin-left:auto; font-size:.72rem; font-weight:700; padding:3px 8px; border-radius:100px; white-space:nowrap; flex-shrink:0; }
.nwac-elegy-status--sold  { background:rgba(239,68,68,.2); color:#fca5a5; }
.nwac-elegy-status--gated { background:rgba(251,191,36,.2); color:#fcd34d; }
.nwac-elegy-status--gone  { background:rgba(156,163,175,.2); color:#d1d5db; }
.nwac-elegy-card p { color:var(--nwac-dark-muted); font-size:.9rem; margin-bottom:.75rem; }
.nwac-elegy-card__lesson { font-style:italic; color:var(--nwac-dark-muted); font-size:.88rem; border-top:1px solid rgba(255,255,255,.08); padding-top:.75rem; margin-top:.25rem; }
.nwac-elegy-card__lesson--highlighted { color:var(--nwac-orange); }
.nwac-elegy-card__wiki { display:inline-flex; align-items:center; gap:5px; margin-top:8px; font-size:.82rem; color:var(--nwac-orange); text-decoration:underline; }

/* ── Stories preview ── */
.nwac-stories-preview { background:var(--nwac-cream); }
.nwac-story-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media(max-width:900px) { .nwac-story-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px) { .nwac-story-grid { grid-template-columns:1fr; } }
.nwac-stories-empty { text-align:center; padding:48px 24px; }

/* Story card */
.nwac-story-card { display:flex; flex-direction:column; background:#fff; border-radius:var(--nwac-radius-lg); border:1px solid var(--nwac-border); overflow:hidden; transition:box-shadow .2s, transform .2s; }
.nwac-story-card:hover { box-shadow:var(--nwac-shadow-lg); transform:translateY(-2px); }
.nwac-story-card__img { aspect-ratio:16/9; overflow:hidden; background:var(--nwac-cream-2); }
.nwac-story-card__img img { width:100%; height:100%; object-fit:cover; }
.nwac-story-card__body { padding:20px; display:flex; flex-direction:column; gap:10px; flex:1; }
.nwac-story-card__author { display:flex; align-items:center; gap:10px; }
.nwac-story-card__author-info { flex:1; }
.nwac-story-card__author-name { display:block; font-size:.88rem; font-weight:600; }
.nwac-story-card__location { display:flex; align-items:center; gap:3px; font-size:.78rem; color:var(--nwac-muted); }
.nwac-story-card__date { font-size:.78rem; color:var(--nwac-muted); margin-left:auto; flex-shrink:0; }
.nwac-story-card__title { font-family:'Fraunces',serif; font-size:1.05rem; margin:0; color:var(--nwac-text); line-height:1.3; }
.nwac-story-card__excerpt { font-size:.88rem; color:var(--nwac-muted); margin:0; line-height:1.6; flex:1; }
.nwac-story-card__footer { display:flex; align-items:center; gap:12px; padding-top:10px; border-top:1px solid var(--nwac-border); }
.nwac-story-card__read-time { display:flex; align-items:center; gap:4px; font-size:.78rem; color:var(--nwac-muted); margin-left:auto; }

/* ── Footer CTA ── */
.nwac-footer-cta { background:var(--nwac-orange); color:#fff; padding:80px 0; }
.nwac-footer-cta__inner { text-align:center; }
.nwac-footer-cta .nwac-h2 { color:#fff; }
.nwac-footer-cta p { color:rgba(255,255,255,.85); margin-bottom:2rem; }
.nwac-footer-cta .nwac-waitlist-form { justify-content:center; }
.nwac-footer-cta .nwac-btn--primary { background:#fff; color:var(--nwac-orange); }
.nwac-footer-cta .nwac-btn--primary:hover { background:rgba(255,255,255,.92); }
.nwac-footer-cta .nwac-waitlist-success { color:#fff; }

/* ── Footer ── */
.nwac-footer { background:var(--nwac-dark-bg); color:var(--nwac-dark-text); padding:64px 0 32px; }
.nwac-footer__inner { display:grid; grid-template-columns:1fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.08); }
@media(max-width:700px) { .nwac-footer__inner { grid-template-columns:1fr; } }
.nwac-footer .nwac-brand { color:var(--nwac-dark-text); }
.nwac-footer__tagline { font-size:.875rem; color:var(--nwac-dark-muted); margin-top:8px; }
.nwac-footer__links { display:flex; flex-direction:column; gap:10px; }
.nwac-footer__links a { color:var(--nwac-dark-muted); font-size:.9rem; transition:color .15s; }
.nwac-footer__links a:hover { color:var(--nwac-dark-text); }
.nwac-footer__social { display:flex; flex-direction:column; gap:10px; }
.nwac-footer__social a { color:var(--nwac-dark-muted); font-size:.9rem; }
.nwac-footer__copy { text-align:center; color:var(--nwac-dark-muted); font-size:.82rem; margin:32px 0 0; }

/* ── Browse page ── */
.nwac-browse-hero { background:#fff; padding:56px 0 48px; border-bottom:1px solid var(--nwac-border); }
.nwac-browse-hero--journal { background:var(--nwac-cream); }
.nwac-browse-hero .nwac-h1 { margin-bottom:.5rem; }
.nwac-browse-body { padding:48px 24px; }
.nwac-browse-count { font-size:.9rem; color:var(--nwac-muted); margin-bottom:24px; }
.nwac-filter-tabs { display:flex; flex-wrap:wrap; gap:8px; margin-top:28px; }
.nwac-filter-tab { padding:8px 20px; border-radius:100px; font-size:.9rem; font-weight:500; color:var(--nwac-muted); background:var(--nwac-cream); border:1.5px solid var(--nwac-border); transition:all .15s; }
.nwac-filter-tab:hover { border-color:var(--nwac-orange); color:var(--nwac-orange); }
.nwac-filter-tab.is-active { background:var(--nwac-orange); color:#fff; border-color:var(--nwac-orange); }

/* ── Listing detail page ── */
.nwac-listing-hero { height:360px; background-size:cover; background-position:center; position:relative; }
.nwac-listing-hero__overlay { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 60%); }
.nwac-listing-hero__inner { position:relative; z-index:1; height:100%; display:flex; align-items:flex-end; padding-bottom:24px; gap:8px; }
.nwac-verified-badge { display:flex; align-items:center; gap:4px; padding:3px 10px; border-radius:100px; font-size:.78rem; font-weight:600; background:rgba(255,255,255,.9); color:var(--nwac-teal); }
.nwac-listing-body { display:grid; grid-template-columns:1fr 340px; gap:48px; padding-top:40px; padding-bottom:80px; align-items:start; }
@media(max-width:900px) { .nwac-listing-body { grid-template-columns:1fr; } }
.nwac-listing-body__location { display:flex; align-items:center; gap:5px; color:var(--nwac-muted); font-size:.9rem; margin-bottom:.5rem; }
.nwac-listing-meta-row { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:32px; }
.nwac-meta-chip { display:flex; align-items:center; gap:6px; padding:6px 14px; border-radius:100px; background:var(--nwac-cream); font-size:.85rem; color:var(--nwac-muted); }
.nwac-listing-section { margin-bottom:40px; }
.nwac-listing-section h2 { font-family:'Fraunces',serif; font-size:1.3rem; border-bottom:1px solid var(--nwac-border); padding-bottom:12px; margin-bottom:16px; }
.nwac-listing-section--exchange { background:var(--nwac-orange-light); border-radius:var(--nwac-radius-lg); padding:24px; }
.nwac-listing-section--exchange h2 { border:none; margin-bottom:8px; }
.nwac-listing-exchange-meta { display:flex; gap:16px; margin-top:12px; font-size:.85rem; color:var(--nwac-muted); }
.nwac-amenities-list { display:flex; flex-wrap:wrap; gap:8px; list-style:none; padding:0; margin:0; }
.nwac-amenities-list li { padding:5px 12px; border-radius:100px; background:var(--nwac-cream); border:1px solid var(--nwac-border); font-size:.85rem; }
.nwac-listing-section--host { background:var(--nwac-cream); border-radius:var(--nwac-radius-lg); padding:24px; }
.nwac-host-bio { display:flex; gap:16px; align-items:flex-start; }
.nwac-host-bio strong { display:block; font-size:1rem; }
.nwac-host-bio .nwac-muted { font-size:.85rem; display:block; margin-bottom:4px; }

/* Contact sidebar card */
.nwac-listing-body__sidebar { position:sticky; top:calc(var(--nwac-topnav-h) + 24px); }
.nwac-contact-card { background:#fff; border:1.5px solid var(--nwac-border); border-radius:var(--nwac-radius-lg); padding:28px; display:flex; flex-direction:column; gap:16px; }
.nwac-contact-card__cost-label { font-family:'Fraunces',serif; font-size:1.5rem; display:block; }
.nwac-contact-card__cost-note { font-size:.85rem; }
.nwac-contact-card__meta { display:flex; flex-direction:column; gap:8px; font-size:.85rem; color:var(--nwac-muted); }
.nwac-contact-card__meta div { display:flex; align-items:center; gap:6px; }
.nwac-contact-card__note { text-align:center; font-size:.82rem; color:var(--nwac-muted); margin:0; }

/* ── Story detail ── */
.nwac-story-hero { height:320px; background-size:cover; background-position:center; position:relative; }
.nwac-story-hero__overlay { position:absolute; inset:0; background:rgba(0,0,0,.3); }
.nwac-story-body { max-width:740px; margin:0 auto; padding:48px 24px 80px; }
.nwac-story-header { margin-bottom:32px; }
.nwac-story__title { font-family:'Fraunces',serif; font-size:clamp(1.8rem,4vw,2.5rem); margin:.75rem 0 1.25rem; }
.nwac-story-meta { display:flex; flex-wrap:wrap; align-items:center; gap:12px; font-size:.875rem; color:var(--nwac-muted); }
.nwac-story-meta__author { display:flex; align-items:center; gap:8px; }
.nwac-story-meta a { font-weight:600; color:var(--nwac-text); }
.nwac-story-content { font-size:1.05rem; line-height:1.8; }
.nwac-story-footer { display:flex; gap:12px; margin-top:48px; padding-top:32px; border-top:1px solid var(--nwac-border); }

/* ── Auth pages ── */
.nwac-auth-page { display:flex; align-items:center; justify-content:center; min-height:calc(100vh - var(--nwac-topnav-h)); padding:40px 24px; }
.nwac-auth-card { width:100%; max-width:420px; background:#fff; border-radius:var(--nwac-radius-lg); padding:40px; box-shadow:var(--nwac-shadow-lg); }
.nwac-auth-card__brand { text-align:center; margin-bottom:24px; }
.nwac-auth-card h1 { text-align:center; margin-bottom:4px; }
.nwac-auth-card .nwac-muted { text-align:center; margin-bottom:24px; }
.nwac-auth-card__switch { text-align:center; margin-top:20px; font-size:.9rem; color:var(--nwac-muted); }

/* ── Forms ── */
.nwac-form { display:flex; flex-direction:column; gap:20px; }
.nwac-form-group { display:flex; flex-direction:column; gap:6px; }
.nwac-form-group label { font-size:.875rem; font-weight:600; color:var(--nwac-text); }
.nwac-input { padding:11px 14px; border:1.5px solid var(--nwac-border); border-radius:var(--nwac-radius); font-size:.95rem; background:#fff; transition:border-color .15s; width:100%; }
.nwac-input:focus { outline:none; border-color:var(--nwac-orange); }
textarea.nwac-input { resize:vertical; }
.nwac-form-hint { font-size:.8rem; color:var(--nwac-muted); }
.nwac-form-legal { font-size:.8rem; color:var(--nwac-muted); text-align:center; }
.nwac-form-error { color:#dc2626; font-size:.875rem; }
.nwac-form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media(max-width:560px) { .nwac-form-row { grid-template-columns:1fr; } }
.nwac-form-row--tabs { display:flex; gap:12px; flex-wrap:wrap; }
.nwac-type-tab { flex:1; min-width:140px; border:1.5px solid var(--nwac-border); border-radius:var(--nwac-radius-lg); padding:16px; cursor:pointer; display:flex; flex-direction:column; align-items:center; text-align:center; gap:4px; transition:all .15s; }
.nwac-type-tab:has(input:checked) { border-color:var(--nwac-orange); background:var(--nwac-orange-light); }
.nwac-type-tab input { position:absolute; opacity:0; }
.nwac-type-tab__emoji { font-size:1.5rem; }
.nwac-type-tab strong { font-size:.9rem; }
.nwac-form-group--inline { flex-direction:row; align-items:center; justify-content:space-between; }
.nwac-checkbox-label { display:flex; align-items:center; gap:6px; font-size:.875rem; cursor:pointer; font-weight:normal; }
.nwac-story-editor { font-family:'Fraunces',serif; font-size:1rem; line-height:1.8; }

/* ── Alerts ── */
.nwac-alert { padding:12px 16px; border-radius:var(--nwac-radius); font-size:.9rem; }
.nwac-alert--error   { background:#fef2f2; color:#991b1b; border:1px solid #fecaca; }
.nwac-alert--success { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }

/* ── App pages ── */
.nwac-page-header { margin-bottom:40px; }
.nwac-page-header .nwac-alert { margin-top:12px; }
.nwac-dashboard-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.nwac-dashboard-section { background:#fff; border-radius:var(--nwac-radius-lg); border:1px solid var(--nwac-border); padding:28px; }
.nwac-dashboard-section--full { grid-column:1 / -1; }
@media(max-width:720px) { .nwac-dashboard-grid { grid-template-columns:1fr; } }
.nwac-section-title { font-family:'Fraunces',serif; font-size:1.15rem; margin:0 0 20px; }
.nwac-quick-actions { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.nwac-quick-action { display:flex; flex-direction:column; gap:2px; padding:16px; border-radius:var(--nwac-radius); border:1.5px solid var(--nwac-border); transition:all .15s; }
.nwac-quick-action:hover { border-color:var(--nwac-orange); background:var(--nwac-orange-light); }
.nwac-quick-action__icon { font-size:1.5rem; margin-bottom:4px; }
.nwac-quick-action strong { font-size:.95rem; }
.nwac-profile-summary { display:flex; gap:16px; align-items:flex-start; }
.nwac-skill-pills { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.nwac-skill-pill { padding:3px 10px; border-radius:100px; background:var(--nwac-cream-2); font-size:.78rem; font-weight:500; }
.nwac-dashboard-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
.nwac-dashboard-list li { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.nwac-status { font-size:.75rem; font-weight:600; padding:2px 8px; border-radius:100px; }
.nwac-status--publish { background:#d1fae5; color:#065f46; }
.nwac-status--pending { background:#fef3c7; color:#92400e; }

/* Profile edit */
.nwac-profile-edit-grid { display:grid; grid-template-columns:200px 1fr; gap:40px; align-items:start; }
@media(max-width:640px) { .nwac-profile-edit-grid { grid-template-columns:1fr; } }
.nwac-profile-edit__avatar { text-align:center; }

/* Submit forms */
.nwac-submit-form { max-width:680px; }

/* ── Static pages ── */
.nwac-page-body { padding:64px 24px 80px; }
.nwac-page-body--narrow { max-width:720px; margin:0 auto; }
.nwac-page-body__header { margin-bottom:40px; }

/* ── Prose ── */
.nwac-prose { max-width:680px; }
.nwac-prose h2 { font-family:'Fraunces',serif; font-size:1.4rem; margin:2rem 0 .75rem; }
.nwac-prose p { color:var(--nwac-brown-light); margin-bottom:1rem; }
.nwac-prose ul { color:var(--nwac-brown-light); }
.nwac-prose li { margin-bottom:.4rem; }
.nwac-prose a { color:var(--nwac-orange); }

/* ── Modal ── */
.nwac-modal { position:fixed; inset:0; z-index:400; display:flex; align-items:center; justify-content:center; padding:24px; }
.nwac-modal[hidden] { display:none; }
.nwac-modal__backdrop { position:absolute; inset:0; background:rgba(0,0,0,.55); }
.nwac-modal__content { position:relative; z-index:1; background:#fff; border-radius:var(--nwac-radius-lg); padding:40px; width:100%; max-width:520px; max-height:90vh; overflow-y:auto; box-shadow:var(--nwac-shadow-lg); }
.nwac-modal__close { position:absolute; top:16px; right:16px; font-size:1.5rem; color:var(--nwac-muted); line-height:1; padding:4px 8px; border-radius:6px; }
.nwac-modal__close:hover { background:var(--nwac-cream); color:var(--nwac-text); }
.nwac-contact-form__result { font-size:.875rem; }

/* ── Empty states ── */
.nwac-empty { text-align:center; padding:64px 24px; display:flex; flex-direction:column; align-items:center; gap:16px; }
.nwac-empty p { font-size:1.1rem; color:var(--nwac-muted); }

/* ── Pagination ── */
.page-numbers { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:var(--nwac-radius); border:1.5px solid var(--nwac-border); font-size:.9rem; color:var(--nwac-text); margin:2px; }
.page-numbers.current { background:var(--nwac-orange); color:#fff; border-color:var(--nwac-orange); }
.page-numbers:hover { border-color:var(--nwac-orange); color:var(--nwac-orange); }

/* ── Utility ── */
.nwac-body--marketing { background:var(--nwac-cream); }

/* ═══════════════════════════════════════════════
   Member profile page
═══════════════════════════════════════════════ */
.nwac-avatar--xxl { width:96px; height:96px; border-radius:50%; object-fit:cover; }
.nwac-member-header { background:#fff; border-bottom:1px solid var(--nwac-border); padding:40px 0; }
.nwac-member-header__inner { display:flex; gap:28px; align-items:flex-start; flex-wrap:wrap; }
.nwac-member-header__avatar-wrap { position:relative; flex-shrink:0; }
.nwac-member-header__verified-dot { position:absolute; bottom:4px; right:4px; width:18px; height:18px; background:var(--nwac-orange); border-radius:50%; border:2px solid #fff; }
.nwac-member-header__info { flex:1; min-width:220px; display:flex; flex-direction:column; gap:10px; }
.nwac-member-header__name-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.nwac-member-header__name { margin:0; font-size:1.75rem; }
.nwac-member-header__location { display:flex; align-items:center; gap:6px; font-size:.9rem; color:var(--nwac-muted); }
.nwac-member-header__skills { margin-top:2px; }
.nwac-member-header__actions { margin-left:auto; flex-shrink:0; align-self:flex-start; }

.nwac-member-stats-bar { background:var(--nwac-cream); border-bottom:1px solid var(--nwac-border); padding:20px 0; }
.nwac-member-stats-bar__inner { display:flex; gap:0; }
.nwac-member-stat { flex:1; text-align:center; padding:0 16px; border-right:1px solid var(--nwac-border); }
.nwac-member-stat:last-child { border-right:none; }
.nwac-member-stat__num { display:block; font-family:'Fraunces',serif; font-size:1.5rem; font-weight:600; color:var(--nwac-text); line-height:1; }
.nwac-member-stat__label { display:block; font-size:.75rem; color:var(--nwac-muted); margin-top:4px; text-transform:uppercase; letter-spacing:.04em; }

.nwac-member-body { padding:48px 24px 80px; }
.nwac-member-body__grid { display:grid; grid-template-columns:260px 1fr; gap:40px; align-items:start; }
@media(max-width:860px) { .nwac-member-body__grid { grid-template-columns:1fr; } }

.nwac-member-sidebar__card { background:#fff; border:1px solid var(--nwac-border); border-radius:var(--nwac-radius-lg); padding:24px; margin-bottom:16px; }
.nwac-member-sidebar__title { font-family:'Fraunces',serif; font-size:1rem; margin:0 0 12px; }
.nwac-member-sidebar__bio { font-size:.92rem; color:var(--nwac-brown-light); line-height:1.7; margin:0; max-width:none; }

.nwac-member-section { margin-bottom:48px; }
.nwac-member-main .nwac-section-title { margin-bottom:20px; }

/* ═══════════════════════════════════════════════
   Messages page
═══════════════════════════════════════════════ */
.nwac-page-header--split { display:flex; align-items:center; gap:12px; margin-bottom:32px; }
.nwac-messages-layout { display:grid; grid-template-columns:320px 1fr; min-height:calc(100vh - var(--nwac-topnav-h) - 180px); border:1px solid var(--nwac-border); border-radius:var(--nwac-radius-lg); overflow:hidden; background:#fff; }
@media(max-width:720px) { .nwac-messages-layout { grid-template-columns:1fr; grid-template-rows:auto 1fr; } }

.nwac-messages-sidebar { border-right:1px solid var(--nwac-border); overflow-y:auto; max-height:calc(100vh - var(--nwac-topnav-h) - 220px); }
.nwac-messages-empty { padding:40px 20px; text-align:center; }
.nwac-messages-select { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; padding:60px 24px; text-align:center; }

.nwac-thread-item { display:flex; gap:12px; align-items:flex-start; padding:16px; border-bottom:1px solid var(--nwac-border); transition:background .12s; text-decoration:none; color:inherit; }
.nwac-thread-item:hover { background:var(--nwac-cream); }
.nwac-thread-item--active { background:var(--nwac-orange-light); border-left:3px solid var(--nwac-orange); }
.nwac-thread-item__body { flex:1; min-width:0; }
.nwac-thread-item__name { font-size:.9rem; font-weight:600; display:flex; align-items:center; gap:6px; }
.nwac-thread-item__context { font-size:.78rem; color:var(--nwac-muted); display:flex; align-items:center; gap:4px; margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.nwac-thread-item__preview { font-size:.82rem; color:var(--nwac-muted); margin-top:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.nwac-thread-item__date { font-size:.72rem; color:var(--nwac-muted); white-space:nowrap; flex-shrink:0; margin-top:2px; }
.nwac-thread-unread-dot { display:inline-block; width:8px; height:8px; border-radius:50%; background:var(--nwac-orange); flex-shrink:0; }

.nwac-messages-main { display:flex; flex-direction:column; }
.nwac-thread-header { display:flex; align-items:center; gap:12px; padding:16px 20px; border-bottom:1px solid var(--nwac-border); flex-shrink:0; }
.nwac-thread-header__info { display:flex; flex-direction:column; gap:2px; }
.nwac-thread-header__name { font-weight:600; font-size:.95rem; color:var(--nwac-text); }
.nwac-thread-header__listing { font-size:.8rem; color:var(--nwac-muted); display:flex; align-items:center; gap:4px; }

.nwac-thread-messages { flex:1; overflow-y:auto; padding:24px 20px; display:flex; flex-direction:column; gap:16px; max-height:calc(100vh - var(--nwac-topnav-h) - 380px); min-height:200px; }
.nwac-thread-empty { text-align:center; margin:auto; }

.nwac-msg { display:flex; align-items:flex-end; gap:8px; }
.nwac-msg--me { flex-direction:row-reverse; }
.nwac-msg__bubble { max-width:72%; padding:12px 16px; border-radius:18px; }
.nwac-msg--them .nwac-msg__bubble { background:var(--nwac-cream); border-bottom-left-radius:4px; }
.nwac-msg--me .nwac-msg__bubble { background:var(--nwac-orange); color:#fff; border-bottom-right-radius:4px; }
.nwac-msg__bubble p { margin:0; font-size:.9rem; line-height:1.5; }
.nwac-msg__time { display:block; font-size:.7rem; margin-top:4px; opacity:.65; }
.nwac-msg--me .nwac-msg__time { text-align:right; }

.nwac-reply-form { display:flex; gap:10px; padding:16px 20px; border-top:1px solid var(--nwac-border); flex-shrink:0; align-items:flex-end; }
.nwac-reply-form__input { flex:1; min-height:60px; max-height:120px; resize:none; }
.nwac-reply-form .nwac-btn { align-self:flex-end; flex-shrink:0; white-space:nowrap; }

/* ── contact form result states ── */
.nwac-contact-form__result--success { color:#166534; }
.nwac-contact-form__result--error   { color:#991b1b; }
