:root {
  /* Ember family (primary) */
  --ember1: #2a1612;
  --ember2: #3d1d18;
  --ember5: #c43d22;
  --ember7: #e85a35;
  --ember8: #ff7a45;
  --emberD: #f5d4c4;

  /* Warm neutrals */
  --cream:  #faf3eb;
  --cream2: #f3e8d9;
  --paper:  #fffaf3;

  /* Warm greys */
  --warm1: #1d1816;
  --warm3: #3e342e;
  --warm5: #6e5c54;
  --warm7: #8b7a72;
  --warmA: #b6a89f;
  --warmC: #d8ccc1;
  --warmE: #ece2d6;

  /* Carried over from DN */
  --brown1: #29101a;
  --brown3: #5b4045;
  --brownA: #ccaea3;
  --brownC: #edddd2;
  --amber:  #e89c2a;
  --green:  #4fa86b;
}

html { font-size: 62.5%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Montserrat', system-ui, sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  color: var(--ember2);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
* { box-sizing: border-box; }
img { max-width: 100%; display: block; }
a { color: var(--ember7); text-decoration: none; }
a:hover { color: var(--ember5); }

/* ===== Monogram (D + C, multiply blend) ===== */
.ds-mono {
  display: inline-flex;
  align-items: baseline;
  font-family: 'Montserrat', sans-serif;
  font-weight: 900;
  letter-spacing: -0.06em;
  line-height: 0.85;
  isolation: isolate;
  user-select: none;
  white-space: nowrap;
}
.ds-mono > span { display: inline-block; mix-blend-mode: multiply; }
.ds-mono .ink-a { margin-right: -0.16em; position: relative; z-index: 1; color: var(--warm5); }
.ds-mono .ink-b { position: relative; z-index: 2; color: var(--ember7); }
.ds-mono.on-dark > span { mix-blend-mode: screen; }
.ds-mono.on-dark .ink-a { color: var(--brownA); }
.ds-mono.on-dark .ink-b { color: var(--ember8); }
.ds-mono.on-tile > span { mix-blend-mode: normal; }
.ds-mono.on-tile .ink-a { color: rgba(255, 250, 243, 0.55); }
.ds-mono.on-tile .ink-b { color: rgba(255, 250, 243, 0.96); }

.ds-lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  line-height: 1;
  font-weight: 700;
}
.ds-lockup .mark-slot { display: inline-flex; align-items: center; font-size: 1.5em; line-height: 0.85; margin-right: 0.12em; }
.ds-lockup .word { display: inline-flex; letter-spacing: 0; align-items: baseline; font-size: 1em; }
.ds-lockup .word .dudes { font-weight: 300; color: var(--ember2); margin-right: 0.04em; }
.ds-lockup .word .chat  { font-weight: 700; color: var(--ember7); }
.on-dark .ds-lockup .word .dudes { color: var(--cream); }
.on-dark .ds-lockup .word .chat  { color: var(--ember8); }

/* ===== Nav — dark, matching the Cover-photo-competition banner ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: var(--ember2);
  background-image:
    radial-gradient(70% 240% at 88% 0%, rgba(232, 156, 42, 0.20), transparent 60%),
    radial-gradient(60% 240% at 8% 100%, rgba(232, 90, 53, 0.30), transparent 60%);
  border-bottom: 0.1rem solid rgba(245, 212, 196, 0.16);
}
.nav .inner {
  max-width: 128rem; margin: 0 auto;
  padding: 1.6rem 2.4rem;
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
}
.nav .ds-lockup { font-size: 3rem; gap: 0.4em; }
/* on-dark lockup so it reads on the dark bar */
.nav .ds-lockup .word .dudes { color: var(--cream); }
.nav .ds-lockup .word .chat { color: var(--ember8); }
/* rotating app-icon tile as the nav mark (sized to set the wordmark height) */
.nav .nav-mark {
  width: 4rem; height: 4rem; border-radius: 26%; flex-shrink: 0;
  background: linear-gradient(140deg, #ff8a55 0%, var(--ember7) 50%, var(--ember5) 100%);
  display: inline-flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  box-shadow: 0 0.3rem 0.9rem rgba(196, 61, 34, 0.32), inset 0 0.12rem 0 rgba(255, 255, 255, 0.2);
}
.nav .nav-mark svg { width: 60%; height: 60%; transition: opacity 0.4s ease; }
.nav .nav-mark.swapping svg { opacity: 0; }
.nav .links { display: none; gap: 2.8rem; }
.nav .links a { color: var(--brownA); font-size: 1.3rem; font-weight: 500; }
.nav .links a:hover { color: var(--ember8); }
.nav .cta { font-size: 1.25rem; font-weight: 700; padding: 0.9rem 1.6rem; border-radius: 0.4rem; background: var(--ember7); color: #fff; letter-spacing: 0.04em; text-transform: uppercase; }
.nav .cta:hover { background: var(--ember5); color: #fff; }
@media (min-width: 900px) { .nav .links { display: flex; } }

/* ===== Buttons ===== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  height: 4.8rem; padding: 0 2.4rem; border-radius: 0.4rem;
  font-family: inherit; font-size: 1.3rem; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
  border: 0.1rem solid transparent; cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.btn.primary { background: var(--ember7); color: #fff; }
.btn.primary:hover { background: var(--ember5); color: #fff; }
.btn.ghost { background: transparent; color: var(--ember2); border-color: var(--warmC); }
.btn.ghost:hover { border-color: var(--ember7); color: var(--ember7); }
.btn.dark { background: var(--ember2); color: var(--cream); }
.btn.dark:hover { background: var(--warm1); color: var(--cream); }
.btn.lg { height: 5.6rem; padding: 0 3rem; font-size: 1.4rem; }

/* ===== Section scaffolding ===== */
.section { padding: 9rem 2.4rem; }
.section .inner { max-width: 128rem; margin: 0 auto; }
.section-head { display: grid; grid-template-columns: 1fr; gap: 1.2rem; margin-bottom: 4rem; }
.section-head .num { font-size: 1.1rem; font-weight: 700; color: var(--ember7); letter-spacing: 0.18em; text-transform: uppercase; margin: 0; }
.section-head h2 { font-size: 3.6rem; font-weight: 300; color: var(--ember2); margin: 0; line-height: 1.05; letter-spacing: -0.01em; }
.section-head .desc { font-size: 1.4rem; color: var(--warm3); line-height: 1.6; max-width: 56rem; margin: 0; }
@media (min-width: 1024px) {
  .section-head { grid-template-columns: 22rem 1fr; gap: 4rem; align-items: baseline; }
}
.section.alt { background: var(--paper); border-top: 0.1rem solid var(--warmE); border-bottom: 0.1rem solid var(--warmE); }
.section.dark { background: var(--ember2); color: var(--cream); border: 0; }
.section.dark .section-head h2 { color: var(--cream); }
.section.dark .section-head .desc { color: var(--brownA); }
.section.dark .section-head .num { color: var(--ember8); }

/* ===== Hero ===== */
.hero { padding: 4rem 2.4rem 6rem; }
.hero .inner { max-width: 128rem; margin: 0 auto; }
.hero-grid {
  display: grid; grid-template-columns: 1fr; gap: 4rem; align-items: center;
}
@media (min-width: 1000px) {
  .hero-grid { grid-template-columns: 1.15fr 1fr; gap: 6rem; }
}
.hero .top-meta {
  display: flex; align-items: center; gap: 1.2rem; margin-bottom: 2.4rem;
  font-size: 1.05rem; font-weight: 600; color: var(--warm7);
  letter-spacing: 0.14em; text-transform: uppercase;
}
.hero .top-meta .dot { width: 0.6rem; height: 0.6rem; border-radius: 50%; background: var(--ember7); }
.hero h1 {
  margin: 0 0 2.4rem;
  font-size: clamp(5.6rem, 10vw, 9.6rem);
  font-weight: 300;
  letter-spacing: -0.025em;
  line-height: 0.95;
  color: var(--ember2);
}
.hero h1 .accent { color: var(--ember7); font-weight: 700; }
.hero .lede { font-size: 2rem; line-height: 1.45; font-weight: 300; max-width: 52rem; color: var(--warm3); margin: 0 0 3.2rem; }
.hero .lede strong { color: var(--ember2); font-weight: 600; }

/* Waitlist form */
.waitlist-form {
  display: flex; gap: 0.8rem; flex-wrap: wrap;
  background: var(--paper);
  padding: 0.8rem;
  border: 0.1rem solid var(--warmE);
  border-radius: 0.6rem;
  max-width: 52rem;
  box-shadow: 0 0.4rem 1.2rem rgba(42,22,18,0.06);
}
.waitlist-form input[type="email"] {
  flex: 1; min-width: 22rem;
  height: 4.8rem; padding: 0 1.4rem;
  border: 0; outline: 0;
  background: transparent;
  font-family: inherit; font-size: 1.5rem; color: var(--ember2);
}
.waitlist-form input::placeholder { color: var(--warmA); }
.waitlist-form .submit { height: 4.8rem; padding: 0 2.4rem; }
.waitlist-form .fine { width: 100%; font-size: 1.05rem; color: var(--warm7); padding: 0.4rem 0.6rem 0; }
.waitlist-form .fine a { color: var(--ember7); text-decoration: underline; text-underline-offset: 0.2em; }
.waitlist-form .fine a:hover { color: var(--ember5); }
/* Honeypot — visually removed, off-screen, not a tab stop */
.hp-field { position: absolute; left: -9999px; top: 0; width: 1px; height: 1px; opacity: 0; pointer-events: none; }

/* Hero left column — flex column; on desktop it stretches to the photo's
   height and space-between spreads the text so the waitlist box bottom-aligns
   with the cover photo. */
.hero-copy { display: flex; flex-direction: column; gap: 2.8rem; }
.hero-copy .top-meta, .hero-copy h1, .hero-copy .lede { margin: 0; }
.hero-grid > .coverboy-stage { align-self: center; }
@media (min-width: 1000px) {
  .hero-grid { align-items: stretch; }
  .hero-copy { justify-content: space-between; }
}

/* Cover-boy hero card */
.coverboy-stage {
  position: relative;
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.8rem;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  box-shadow: 0 1.6rem 4rem rgba(42,22,18,0.12);
}
.coverboy-stage .photo {
  position: absolute; inset: 0;
  /* Placeholder treatment — replace background-image with: url('/img/coverboys/cover-01.jpg') */
  background-color: #c9856a;
  background-image:
    radial-gradient(80% 60% at 35% 30%, rgba(255,235,210,0.35), transparent 60%),
    repeating-linear-gradient(45deg, rgba(42,22,18,0.06) 0 0.8rem, transparent 0.8rem 1.6rem);
  background-size: cover; background-position: center;
}
.coverboy-stage::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(42,22,18,0) 40%, rgba(42,22,18,0.65) 100%);
  pointer-events: none;
}
.coverboy-stage .caption {
  position: absolute; top: 1.6rem; left: 2rem;
  font-size: 0.95rem; font-weight: 700; color: rgba(255, 250, 243, 0.85);
  letter-spacing: 0.18em; text-transform: uppercase;
}
.coverboy-stage .credit {
  position: absolute; bottom: 2rem; left: 2rem; right: 2rem;
  color: var(--cream); z-index: 2;
}
.coverboy-stage .credit .who { font-size: 1.4rem; font-weight: 700; letter-spacing: 0.02em; }
.coverboy-stage .credit .from { font-size: 1.05rem; font-weight: 500; color: rgba(255, 250, 243, 0.72); margin-top: 0.4rem; letter-spacing: 0.06em; text-transform: uppercase; }
.coverboy-stage .badge {
  position: absolute; top: 1.6rem; right: 1.6rem; z-index: 2;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 1rem;
  background: rgba(255, 250, 243, 0.92);
  border-radius: 999px;
  font-size: 0.95rem; font-weight: 700;
  color: var(--ember2); letter-spacing: 0.08em; text-transform: uppercase;
}
.coverboy-stage .badge .dot { width: 0.6rem; height: 0.6rem; border-radius: 50%; background: var(--ember7); }

/* ===== Big idea — three cards ===== */
.idea-grid { display: grid; grid-template-columns: 1fr; gap: 2.4rem; }
@media (min-width: 900px) { .idea-grid { grid-template-columns: repeat(3, 1fr); } }
.idea-card {
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.6rem;
  padding: 3rem 2.6rem;
  display: flex; flex-direction: column; gap: 1.4rem;
}
.idea-card .pill {
  display: inline-flex; align-items: center; align-self: flex-start; gap: 0.6rem;
  padding: 0.4rem 1rem; border-radius: 999px;
  background: var(--cream2); color: var(--ember5);
  font-size: 1.0rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
}
.idea-card .pill .dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--ember7); }
.idea-card h3 { font-size: 2rem; font-weight: 600; margin: 0; color: var(--ember2); letter-spacing: -0.005em; }
.idea-card p { margin: 0; font-size: 1.35rem; color: var(--warm3); line-height: 1.6; }

/* ===== Feature rows (alternating) ===== */
.feature-row {
  display: grid; grid-template-columns: 1fr; gap: 4rem; align-items: center;
  padding: 4rem 0;
  border-top: 0.1rem dashed var(--warmE);
}
.feature-row:first-of-type { border-top: 0; padding-top: 0; }
@media (min-width: 900px) {
  .feature-row { grid-template-columns: 1fr 1fr; gap: 6rem; }
  .feature-row.reverse .feature-text { order: 2; }
}
.feature-row .eyebrow { font-size: 1.1rem; font-weight: 700; color: var(--ember7); letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 1rem; }
.feature-row h3 { font-size: 3rem; font-weight: 300; color: var(--ember2); margin: 0 0 1.6rem; letter-spacing: -0.01em; line-height: 1.1; }
.feature-row h3 strong { font-weight: 700; }
.feature-row p { font-size: 1.5rem; color: var(--warm3); line-height: 1.6; margin: 0 0 1.2rem; max-width: 48rem; }
.feature-row ul { margin: 1.6rem 0 0; padding: 0; list-style: none; display: grid; gap: 0.8rem; }
.feature-row ul li { font-size: 1.3rem; color: var(--ember2); display: flex; align-items: flex-start; gap: 1rem; }
.feature-row ul li .ms { color: var(--ember7); flex-shrink: 0; }
.feature-visual {
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.8rem;
  padding: 3rem;
  min-height: 32rem;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}

/* Landscape cover-photo banner inside Features — half-width photo + text next to it */
.feature-banner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
  margin: 0 0 5rem;
}
@media (min-width: 800px) {
  .feature-banner { grid-template-columns: 1fr 1fr; gap: 5rem; }
}
.feature-banner .banner-photo {
  margin: 0;
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.8rem;
  overflow: hidden;
  box-shadow: 0 1.2rem 3rem rgba(42, 22, 18, 0.10);
}
.feature-banner .banner-photo .photo {
  position: absolute; inset: 0;
  /* Placeholder — replace background-image with: url('/img/coverboys/cover-02-landscape.jpg') */
  background-color: #b6957e;
  background-image:
    radial-gradient(70% 80% at 20% 40%, rgba(255, 235, 210, 0.4), transparent 60%),
    radial-gradient(60% 90% at 80% 60%, rgba(196, 61, 34, 0.25), transparent 60%),
    repeating-linear-gradient(45deg, rgba(42, 22, 18, 0.06) 0 0.8rem, transparent 0.8rem 1.6rem);
  background-size: cover; background-position: center;
}
.feature-banner .banner-photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(42, 22, 18, 0) 50%, rgba(42, 22, 18, 0.65) 100%);
  pointer-events: none;
}
.feature-banner .banner-photo .caption {
  position: absolute; top: 1.4rem; left: 1.8rem; z-index: 2;
  font-size: 0.9rem; font-weight: 700; color: rgba(255, 250, 243, 0.85);
  letter-spacing: 0.18em; text-transform: uppercase;
}
.feature-banner .banner-photo .badge {
  position: absolute; top: 1.4rem; right: 1.4rem; z-index: 2;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.4rem 0.9rem;
  background: rgba(255, 250, 243, 0.92);
  border-radius: 999px;
  font-size: 0.9rem; font-weight: 700;
  color: var(--ember2); letter-spacing: 0.08em; text-transform: uppercase;
}
.feature-banner .banner-photo .badge .dot { width: 0.5rem; height: 0.5rem; border-radius: 50%; background: var(--ember7); }
.feature-banner .banner-photo .credit {
  position: absolute; bottom: 1.6rem; left: 1.8rem; right: 1.8rem; z-index: 2;
  color: var(--cream);
}
.feature-banner .banner-photo .credit .who { font-size: 1.4rem; font-weight: 700; letter-spacing: 0.02em; }
.feature-banner .banner-photo .credit .from { font-size: 1.0rem; font-weight: 500; color: rgba(255, 250, 243, 0.72); margin-top: 0.3rem; letter-spacing: 0.08em; text-transform: uppercase; }

.feature-banner .banner-text { display: flex; flex-direction: column; gap: 1.4rem; }
.feature-banner .banner-text .eyebrow { font-size: 1.1rem; font-weight: 700; color: var(--ember7); letter-spacing: 0.18em; text-transform: uppercase; margin: 0; }
.feature-banner .banner-text h3 { font-size: clamp(2.4rem, 3.2vw, 3.2rem); font-weight: 300; color: var(--ember2); margin: 0; line-height: 1.1; letter-spacing: -0.01em; }
.feature-banner .banner-text h3 strong { font-weight: 700; }
.feature-banner .banner-text p { font-size: 1.4rem; color: var(--warm3); line-height: 1.6; margin: 0; max-width: 44rem; }
.feature-banner .banner-text a.inline-link { font-size: 1.2rem; font-weight: 700; color: var(--ember7); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 0.4rem; display: inline-flex; align-items: center; gap: 0.4rem; }
.feature-banner .banner-text a.inline-link:hover { color: var(--ember5); }

/* Phone mock — mirrors the real DudesNetwork app shell (prototype/index.html) */
.phone {
  width: 28rem; height: 56rem;
  background: var(--paper);
  border-radius: 3.2rem;
  padding: 0.6rem;
  border: 0.4rem solid var(--warm1);
  box-shadow: 0 1.6rem 3rem rgba(42, 22, 18, 0.18);
  position: relative; overflow: hidden;
}
.phone .screen {
  width: 100%; height: 100%; background: var(--cream);
  border-radius: 2.8rem;
  display: grid; grid-template-rows: 4.4rem 3.4rem 3.2rem 1fr 4.8rem;
  overflow: hidden;
}

/* Topbar */
.phone .topbar {
  background: var(--ember1); color: var(--paper);
  display: flex; align-items: center; justify-content: space-between; padding: 0 1.4rem;
}
.phone .topbar .title { font-size: 1.25rem; font-weight: 700; letter-spacing: 0.02em; }
.phone .topbar .title .accent { color: var(--ember8); }
.phone .topbar .topbar-icons { display: flex; gap: 1.2rem; }
.phone .topbar .topbar-icons .ms { color: #fff; font-size: 1.4rem; opacity: 0.55; }
.phone .topbar .topbar-icons .ms.is-active { opacity: 1; }

/* Filter chips */
.phone .filter-row {
  display: flex; gap: 0.5rem; padding: 0 1.2rem;
  background: var(--paper); border-bottom: 0.1rem solid var(--warmE);
  overflow: hidden; align-items: center;
}
.phone .filter-row .chip {
  flex-shrink: 0; padding: 0.35rem 0.85rem; border-radius: 1.2rem;
  border: 0.1rem solid var(--warmC); background: var(--paper);
  color: var(--warm5); font-size: 0.95rem; font-weight: 500; white-space: nowrap; line-height: 1;
}
.phone .filter-row .chip.active { background: var(--ember1); color: var(--paper); border-color: var(--ember1); }

/* Sort pills */
.phone .sort-row {
  display: flex; align-items: center; gap: 0.35rem; padding: 0 1.2rem;
  background: var(--paper); border-bottom: 0.1rem solid var(--warmE);
}
.phone .sort-row .pill {
  padding: 0.3rem 0.65rem; border-radius: 1rem; border: 0.1rem solid var(--warmE);
  background: transparent; color: var(--warm7); font-size: 0.9rem; font-weight: 500;
  display: inline-flex; align-items: center; gap: 0.25rem; line-height: 1;
}
.phone .sort-row .pill .ms { font-size: 1rem; }
.phone .sort-row .pill.active { background: var(--ember7); color: #fff; border-color: var(--ember7); }
.phone .sort-row .count { margin-left: auto; font-size: 0.85rem; color: var(--warmA); font-weight: 300; }

/* Member grid */
.phone .grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.1rem;
  background: var(--warmE);
  overflow: hidden;
  align-content: start;
}
.phone .tile { background: var(--paper); position: relative; }
.phone .tile .photo { width: 100%; aspect-ratio: 1; position: relative; overflow: hidden; }
.phone .tile.a .photo { background: linear-gradient(135deg, #d8a78e, #c9856a); }
.phone .tile.b .photo { background: linear-gradient(135deg, #b6957e, #a48b7d); }
.phone .tile.c .photo { background: linear-gradient(135deg, #c9856a, #b88c75); }
.phone .tile.d .photo { background: linear-gradient(135deg, #a48b7d, #8d7268); }
.phone .tile.e .photo { background: linear-gradient(135deg, #b88c75, #c69a82); }
.phone .tile.f .photo { background: linear-gradient(135deg, #c69a82, #d8a78e); }
.phone .tile .online {
  position: absolute; top: 0.4rem; right: 0.4rem;
  width: 0.7rem; height: 0.7rem; border-radius: 50%; background: var(--green);
  border: 0.15rem solid #fff;
}
.phone .tile .verified {
  position: absolute; top: 0.4rem; left: 0.4rem;
  background: rgba(232, 90, 53, 0.92); color: #fff;
  width: 1.25rem; height: 1.25rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.phone .tile .verified .ms { font-size: 0.85rem; }
.phone .tile .score {
  position: absolute; left: 0; right: 0; bottom: 0;
  background: linear-gradient(transparent, rgba(42, 22, 18, 0.85));
  color: #fff; font-size: 1.0rem; font-weight: 700;
  padding: 1rem 0.7rem 0.35rem; text-align: left;
}
.phone .tile .info { padding: 0.4rem 0.6rem 0.6rem; background: var(--paper); }
.phone .tile .info .name {
  font-size: 0.9rem; font-weight: 600; color: var(--ember2);
  display: flex; align-items: center; gap: 0.2rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.phone .tile .info .name .ms { color: var(--ember7); font-size: 0.8rem; }
.phone .tile .info .meta { font-size: 0.8rem; color: var(--warm7); margin-top: 0.1rem; font-weight: 300; }

/* Bottom tabbar */
.phone .tabbar {
  background: var(--paper); border-top: 0.1rem solid var(--warmE);
  display: flex; align-items: center; justify-content: space-around;
}
.phone .tab {
  display: flex; flex-direction: column; align-items: center; gap: 0.15rem;
  color: var(--warm7); font-size: 0.8rem; font-weight: 500; position: relative;
}
.phone .tab .ms { font-size: 1.4rem; }
.phone .tab.active { color: var(--ember2); }
.phone .tab.active .ms { color: var(--ember7); }
.phone .tab .badge-count {
  position: absolute; top: -0.2rem; right: 0.8rem;
  background: var(--ember5); color: #fff;
  font-size: 0.7rem; font-weight: 700;
  min-width: 1.2rem; height: 1.2rem; border-radius: 0.6rem;
  display: flex; align-items: center; justify-content: center; padding: 0 0.3rem;
}

/* Chat bubble preview (for conversations feature) */
.chat-preview { display: flex; flex-direction: column; gap: 1rem; width: 100%; max-width: 36rem; }
.bubble { padding: 1.2rem 1.6rem; border-radius: 1.6rem; max-width: 80%; font-size: 1.35rem; line-height: 1.4; }
.bubble.them { background: var(--cream2); color: var(--ember2); align-self: flex-start; border-bottom-left-radius: 0.4rem; }
.bubble.you  { background: var(--ember7); color: #fff; align-self: flex-end; border-bottom-right-radius: 0.4rem; }
.bubble.meta { background: transparent; color: var(--warm7); font-size: 1.05rem; align-self: center; text-transform: uppercase; letter-spacing: 0.12em; }

/* Community tag chips (for communities feature) */
.tag-cloud { display: flex; flex-wrap: wrap; gap: 0.8rem; max-width: 40rem; }
.tag-cloud .chip {
  font-size: 1.15rem; font-weight: 600; padding: 0.6rem 1.2rem; border-radius: 999px;
  background: var(--paper); border: 0.1rem solid var(--warmE); color: var(--ember2);
}
.tag-cloud .chip.match { background: var(--ember7); border-color: var(--ember7); color: #fff; }
.tag-cloud .chip.match::before { content: "✓ "; }

/* Map mock (for location feature) */
.map-mock {
  width: 100%; max-width: 36rem; aspect-ratio: 4/3;
  background:
    radial-gradient(circle at 50% 50%, rgba(232,90,53,0.18) 0, transparent 38%),
    radial-gradient(circle at 50% 50%, rgba(232,90,53,0.32) 0, transparent 14%),
    repeating-linear-gradient(0deg, var(--warmE) 0 0.1rem, transparent 0.1rem 4rem),
    repeating-linear-gradient(90deg, var(--warmE) 0 0.1rem, transparent 0.1rem 4rem),
    var(--cream2);
  border-radius: 0.6rem; position: relative; border: 0.1rem solid var(--warmE);
}
.map-mock .pin { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 1.6rem; height: 1.6rem; border-radius: 50%; background: var(--ember7); border: 0.3rem solid #fff; box-shadow: 0 0.2rem 0.6rem rgba(0,0,0,0.25); }
.map-mock .ring { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); border: 0.15rem dashed var(--ember7); border-radius: 50%; }
.map-mock .ring.r1 { width: 35%; height: 47%; }
.map-mock .ring.r2 { width: 70%; height: 93%; opacity: 0.5; }

/* ===== Tagline pull ===== */
.tagline-wrap {
  padding: 6rem 4rem; background: var(--ember2); color: var(--cream);
  border-radius: 0.8rem;
  display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: center;
}
@media (min-width: 900px) { .tagline-wrap { grid-template-columns: 1fr auto; padding: 7rem; } }
.tagline-wrap blockquote { margin: 0; font-size: clamp(2.8rem, 4vw, 4.4rem); line-height: 1.05; font-weight: 300; letter-spacing: -0.015em; }
.tagline-wrap blockquote strong { color: var(--ember8); font-weight: 700; }
.tagline-wrap .who { font-size: 1.05rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--brownA); font-weight: 600; text-align: right; }

/* ===== Founder presale tiers ===== */
.tier-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 800px) { .tier-grid { grid-template-columns: repeat(3, 1fr); } }
.tier-card {
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.8rem;
  padding: 3rem 2.6rem;
  display: flex; flex-direction: column; gap: 1.4rem;
  position: relative;
}
.tier-card.feature {
  background: var(--ember2);
  border-color: var(--ember2);
  color: var(--cream);
  transform: scale(1.02);
}
.tier-card.feature h3 { color: var(--cream); }
.tier-card.feature .price { color: var(--ember8); }
.tier-card.feature ul li { color: var(--cream); }
.tier-card.feature ul li .ms { color: var(--ember8); }
.tier-card.feature .desc { color: var(--brownA); }
.tier-card .label { font-size: 1.0rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ember7); margin: 0; }
.tier-card.feature .label { color: var(--ember8); }
.tier-card h3 { font-size: 2.4rem; font-weight: 600; margin: 0; color: var(--ember2); }
.tier-card .price { font-size: 4rem; font-weight: 300; color: var(--ember2); letter-spacing: -0.02em; line-height: 1; margin: 0; }
.tier-card .price .unit { font-size: 1.4rem; font-weight: 500; color: var(--warm7); }
.tier-card.feature .price .unit { color: var(--brownA); }
.tier-card .desc { font-size: 1.3rem; color: var(--warm3); margin: 0; }
.tier-card ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 0.8rem; }
.tier-card ul li { font-size: 1.3rem; color: var(--ember2); display: flex; align-items: flex-start; gap: 0.8rem; }
.tier-card ul li .ms { color: var(--ember7); flex-shrink: 0; font-size: 1.6rem; }
.tier-card .btn { margin-top: auto; }
.tier-card .ribbon {
  position: absolute; top: -1rem; right: 2rem;
  background: var(--amber); color: #fff;
  font-size: 0.95rem; font-weight: 700; padding: 0.4rem 1rem;
  border-radius: 0.4rem; letter-spacing: 0.12em; text-transform: uppercase;
}

/* ===== Competition CTA banner ===== */
.competition {
  background: var(--ember2); color: var(--cream);
  border-radius: 0.8rem;
  padding: 5rem 4rem;
  display: grid; grid-template-columns: 1fr; gap: 3rem;
  align-items: center;
  background-image:
    radial-gradient(60% 80% at 90% 10%, rgba(232,156,42,0.22), transparent 60%),
    radial-gradient(50% 60% at 10% 100%, rgba(232,90,53,0.32), transparent 60%);
}
@media (min-width: 900px) { .competition { grid-template-columns: 1.4fr 1fr; padding: 6rem; } }
.competition .num { font-size: 1.1rem; font-weight: 700; color: var(--ember8); letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 1.2rem; }
.competition h2 { margin: 0 0 1.6rem; font-size: clamp(3.2rem, 5vw, 5.2rem); font-weight: 300; color: var(--cream); line-height: 1.05; letter-spacing: -0.015em; }
.competition h2 strong { color: var(--ember8); font-weight: 700; }
.competition p { color: var(--brownA); font-size: 1.5rem; max-width: 52rem; margin: 0 0 2.4rem; }
.competition .actions { display: flex; gap: 1.2rem; flex-wrap: wrap; }
.competition .actions .btn.primary { background: var(--ember8); color: var(--ember1); }
.competition .actions .btn.primary:hover { background: #fff; color: var(--ember1); }
.competition .actions .btn.ghost { color: var(--cream); border-color: rgba(245, 212, 196, 0.4); }
.competition .actions .btn.ghost:hover { border-color: var(--ember8); color: var(--ember8); }
.competition .visual { display: flex; align-items: center; justify-content: center; }
.competition .visual .ds-mono { font-size: clamp(8rem, 18vw, 16rem); }

/* ===== News grid ===== */
.news-grid { display: grid; grid-template-columns: 1fr; gap: 2.4rem; }
@media (min-width: 800px) { .news-grid { grid-template-columns: repeat(3, 1fr); } }
.news-card {
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.6rem;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform 0.2s, box-shadow 0.2s;
}
.news-card:hover { transform: translateY(-0.4rem); box-shadow: 0 1.6rem 3rem rgba(42,22,18,0.10); }
.news-card .photo {
  aspect-ratio: 16/10;
  background-color: #c9856a;
  background-image:
    radial-gradient(80% 60% at 30% 30%, rgba(255,235,210,0.4), transparent 60%),
    repeating-linear-gradient(45deg, rgba(42,22,18,0.06) 0 0.6rem, transparent 0.6rem 1.2rem);
}
.news-card .body { padding: 2rem 2.2rem 2.4rem; display: flex; flex-direction: column; gap: 0.8rem; }
.news-card .stamp { font-size: 1.0rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ember7); }
.news-card h3 { font-size: 1.8rem; font-weight: 600; color: var(--ember2); margin: 0; line-height: 1.25; }
.news-card p { font-size: 1.25rem; color: var(--warm3); margin: 0; }
.news-card .read { margin-top: 0.6rem; font-size: 1.15rem; font-weight: 700; color: var(--ember7); letter-spacing: 0.08em; text-transform: uppercase; }

/* ===== FAQ ===== */
.faq { display: grid; gap: 0; max-width: 88rem; margin: 0 auto; }
.faq details {
  border-top: 0.1rem solid var(--warmE);
  padding: 2.4rem 0;
}
.faq details:last-of-type { border-bottom: 0.1rem solid var(--warmE); }
.faq summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
  font-size: 1.7rem; font-weight: 600; color: var(--ember2);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .ms { color: var(--ember7); transition: transform 0.2s; }
.faq details[open] summary .ms { transform: rotate(45deg); }
.faq details p { margin-top: 1.4rem; max-width: 72rem; color: var(--warm3); font-size: 1.4rem; line-height: 1.6; }

/* ===== Footer ===== */
footer.site {
  background: var(--ember1); color: var(--brownA);
  padding: 6rem 2.4rem 3rem;
}
footer.site .inner { max-width: 128rem; margin: 0 auto; }
footer.site .cols {
  display: grid; grid-template-columns: 1fr; gap: 3.2rem;
  padding-bottom: 4rem;
  border-bottom: 0.1rem solid rgba(245, 212, 196, 0.14);
}
@media (min-width: 700px) { footer.site .cols { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 4rem; } }
footer.site h4 { font-size: 1.1rem; font-weight: 700; color: var(--ember8); letter-spacing: 0.16em; text-transform: uppercase; margin: 0 0 1.6rem; }
footer.site ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.8rem; }
footer.site ul a { color: var(--brownA); font-size: 1.3rem; }
footer.site ul a:hover { color: var(--ember8); }
footer.site .brand { display: flex; flex-direction: column; gap: 1.6rem; }
footer.site .brand .ds-lockup { font-size: 2.4rem; }
footer.site .brand p { font-size: 1.25rem; color: var(--brownA); max-width: 36rem; margin: 0; }
footer.site .stores { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1.2rem; }
footer.site .store-badge {
  display: inline-flex; align-items: center; gap: 0.8rem;
  padding: 1rem 1.4rem; border-radius: 0.6rem;
  background: rgba(245, 212, 196, 0.08);
  border: 0.1rem solid rgba(245, 212, 196, 0.18);
  color: var(--cream); font-size: 1.1rem; line-height: 1.2;
}
footer.site .store-badge .ms { color: var(--ember8); font-size: 2.4rem; }
footer.site .store-badge strong { display: block; font-size: 1.25rem; font-weight: 700; }
footer.site .imprint {
  padding-top: 3rem;
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1.6rem;
  font-size: 1.05rem; color: rgba(204, 174, 163, 0.7); letter-spacing: 0.04em;
}
footer.site .imprint .legal { display: flex; gap: 2rem; flex-wrap: wrap; }
footer.site .imprint a { color: rgba(204, 174, 163, 0.85); }
footer.site .imprint a:hover { color: var(--ember8); }

/* ===== Helpers ===== */
.ms { font-family: 'Material Symbols Outlined'; font-weight: 400; font-style: normal; font-size: 1.8rem; line-height: 1; vertical-align: middle; }
.ms.sm { font-size: 1.4rem; }
.ms.md { font-size: 1.6rem; }
.ms.lg { font-size: 2.4rem; }
.eyebrow { font-size: 1.1rem; font-weight: 700; color: var(--ember7); text-transform: uppercase; letter-spacing: 0.16em; margin: 0; }
.center { text-align: center; }
.skip-link { position: absolute; left: -999rem; top: 0; padding: 1rem; background: var(--ember2); color: var(--cream); }
.skip-link:focus { left: 1rem; top: 1rem; z-index: 1000; }

/* ===== Moving ember gradient — bold accents + primary buttons ===== */
@keyframes ember-flow {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Bold accent text: gradient clipped to glyphs */
.hero h1 .accent,
.competition h2 strong,
.tagline-wrap blockquote strong,
.section-head h2 strong {
  background-image: linear-gradient(90deg, var(--ember5) 0%, var(--ember7) 35%, var(--ember8) 50%, var(--ember7) 65%, var(--ember5) 100%);
  background-size: 300% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  animation: ember-flow 7s ease-in-out infinite;
}

/* Primary buttons — moving gradient fill */
.btn.primary {
  background: linear-gradient(90deg, var(--ember5) 0%, var(--ember7) 50%, var(--ember8) 100%);
  background-size: 200% 100%;
  animation: ember-flow 6s ease-in-out infinite;
  border-color: transparent;
  color: #fff;
}
.btn.primary:hover {
  animation-duration: 2.5s;
  background-position: 100% 50%;
  color: #fff;
}

.nav .cta {
  background: linear-gradient(90deg, var(--ember5) 0%, var(--ember7) 50%, var(--ember8) 100%);
  background-size: 200% 100%;
  animation: ember-flow 6s ease-in-out infinite;
  color: #fff;
}
.nav .cta:hover {
  animation-duration: 2.5s;
  background-position: 100% 50%;
  color: #fff;
}

/* Competition section primary button — same gradient (overrides the solid ember8 special-case) */
.competition .actions .btn.primary {
  background: linear-gradient(90deg, var(--ember5) 0%, var(--ember7) 50%, var(--ember8) 100%);
  background-size: 200% 100%;
  color: #fff;
}
.competition .actions .btn.primary:hover {
  background-position: 100% 50%;
  color: #fff;
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero h1 .accent,
  .competition h2 strong,
  .tagline-wrap blockquote strong,
  .section-head h2 strong,
  .btn.primary,
  .nav .cta,
  .competition .actions .btn.primary {
    animation: none;
  }
}

/* ===== Brand icons (from the DudesChat icon-system design) ===== */
.idea-icon { width: 5rem; height: 5rem; display: block; margin-bottom: 0.6rem; }

@keyframes icon-heartbeat {
  0%, 55%, 100% { transform: scale(1); }
  8%  { transform: scale(1.12); }
  16% { transform: scale(0.98); }
  24% { transform: scale(1.08); }
  34% { transform: scale(1.00); }
}

/* Rotating app-icon tile (competition section) — big tile pulses; the small nav mark only rotates */
.icon-tile {
  width: clamp(11rem, 22vw, 17rem);
  aspect-ratio: 1;
  border-radius: 22%;
  background: linear-gradient(140deg, #ff8a55 0%, var(--ember7) 50%, var(--ember5) 100%);
  box-shadow: 0 1.6rem 3.2rem rgba(196, 61, 34, 0.34), inset 0 0.2rem 0 rgba(255, 255, 255, 0.18);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.icon-tile::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 30% 18%, rgba(255, 255, 255, 0.22), transparent 60%);
  pointer-events: none;
}
.icon-tile svg {
  width: 62%; height: 62%;
  transform-origin: 50% 50%; transform-box: fill-box;
  animation: icon-heartbeat 2.6s ease-in-out infinite;
  transition: opacity 0.4s ease;
}
.icon-tile.swapping svg { opacity: 0; }
@media (prefers-reduced-motion: reduce) {
  .icon-tile svg { animation: none; }
}

/* ===== Feed mock (status feed) — phone variant ===== */
.phone.feed-phone .screen { grid-template-rows: 4.4rem 1fr 4.8rem; }
.phone .feed {
  background: var(--cream2);
  padding: 0.7rem; display: flex; flex-direction: column; gap: 0.7rem;
  overflow: hidden; align-content: start;
}
.phone .feed-card {
  background: var(--paper); border: 0.1rem solid var(--warmE); border-radius: 0.8rem;
  padding: 0.7rem 0.8rem; display: flex; flex-direction: column; gap: 0.45rem;
}
.phone .feed-head { display: flex; align-items: center; gap: 0.55rem; }
.phone .feed-avatar { width: 2.4rem; height: 2.4rem; border-radius: 50%; flex-shrink: 0; }
.phone .feed-avatar.you { background: linear-gradient(135deg, var(--ember8), var(--ember5)); }
.phone .feed-avatar.a { background: linear-gradient(135deg, #d8a78e, #c9856a); }
.phone .feed-avatar.b { background: linear-gradient(135deg, #b6957e, #a48b7d); }
.phone .feed-avatar.c { background: linear-gradient(135deg, #c69a82, #b88c75); }
.phone .feed-id { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 0.05rem; }
.phone .feed-name { font-size: 0.95rem; font-weight: 700; color: var(--ember2); display: flex; align-items: center; gap: 0.2rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.phone .feed-name .ms { font-size: 0.8rem; color: var(--ember7); }
.phone .feed-name .crown { color: var(--amber); }
.phone .feed-meta { font-size: 0.78rem; color: var(--warm7); font-weight: 300; }
.phone .mood {
  display: inline-flex; align-items: center; gap: 0.2rem; flex-shrink: 0;
  padding: 0.2rem 0.5rem; border-radius: 0.3rem;
  background: var(--ember7); color: #fff;
  font-size: 0.8rem; font-weight: 800; letter-spacing: 0.04em;
}
.phone .mood .ms { font-size: 0.9rem; }
.phone .feed-text { font-size: 0.95rem; color: var(--ember2); line-height: 1.35; }

/* ===== Legal / policy pages (from policy.css) ===== */
/* ===== Policy page hero ===== */
.policy-hero {
  padding: 6rem 2.4rem 4rem;
  border-bottom: 0.1rem solid var(--warmE);
}
.policy-hero .inner { max-width: 88rem; margin: 0 auto; }
.policy-hero .num {
  font-size: 1.1rem; font-weight: 700; color: var(--ember7);
  letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 1.2rem;
}
.policy-hero h1 {
  margin: 0 0 1.6rem;
  font-size: clamp(3.6rem, 6vw, 5.6rem);
  font-weight: 300; line-height: 1.05; letter-spacing: -0.015em;
  color: var(--ember2);
}
.policy-hero h1 strong { font-weight: 700; }
.policy-hero .lede {
  font-size: 1.8rem; line-height: 1.45; font-weight: 300;
  color: var(--warm3); max-width: 64rem; margin: 0;
}
.policy-hero .meta {
  margin-top: 3.2rem; padding-top: 2rem;
  border-top: 0.1rem solid var(--warmE);
  display: flex; flex-wrap: wrap; gap: 2.4rem 4rem;
  font-size: 1.1rem; color: var(--warm7);
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600;
}
.policy-hero .meta strong { color: var(--ember2); font-weight: 700; }

/* ===== Policy prose ===== */
.policy-body {
  padding: 5rem 2.4rem 8rem;
  background: var(--cream);
}
.policy-body .inner {
  max-width: 76rem;
  margin: 0 auto;
  background: var(--paper);
  border: 0.1rem solid var(--warmE);
  border-radius: 0.8rem;
  padding: 5rem clamp(2.4rem, 5vw, 5rem);
}

.policy-body h2 {
  font-size: 2.2rem; font-weight: 700;
  color: var(--ember2);
  margin: 4rem 0 1.6rem;
  letter-spacing: 0.04em; text-transform: uppercase;
  border-top: 0.1rem solid var(--warmE);
  padding-top: 3.2rem;
}
.policy-body h2:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.policy-body h3 {
  font-size: 1.6rem; font-weight: 700;
  color: var(--ember5);
  margin: 3rem 0 1rem;
  letter-spacing: 0.06em; text-transform: uppercase;
}

.policy-body p {
  font-size: 1.5rem;
  line-height: 1.7;
  color: var(--ember2);
  margin: 0 0 1.4rem;
  max-width: 64rem;
}
.policy-body p.intro {
  font-size: 1.7rem; font-weight: 400; color: var(--warm3); line-height: 1.55;
}
.policy-body p.fine-print { font-size: 1.25rem; color: var(--warm5); font-style: italic; }

.policy-body ul, .policy-body ol {
  margin: 0 0 1.8rem; padding-left: 2.2rem;
  font-size: 1.5rem; line-height: 1.7; color: var(--ember2);
}
.policy-body ul li, .policy-body ol li { margin-bottom: 0.8rem; }
.policy-body ul li::marker { color: var(--ember7); }

.policy-body strong { font-weight: 700; color: var(--ember2); }
.policy-body em { font-style: italic; color: var(--warm3); }

.policy-body .tl-dr {
  background: var(--cream2);
  border-left: 0.4rem solid var(--ember7);
  border-radius: 0.4rem;
  padding: 2.4rem 2.6rem;
  margin: 0 0 4rem;
}
.policy-body .tl-dr h2 { margin: 0 0 1.2rem; border: 0; padding: 0; font-size: 1.2rem; color: var(--ember7); letter-spacing: 0.16em; }
.policy-body .tl-dr p { margin: 0 0 0.8rem; font-size: 1.4rem; color: var(--ember2); }
.policy-body .tl-dr ul { margin: 0; padding-left: 2rem; font-size: 1.4rem; }
.policy-body .tl-dr ul li { margin-bottom: 0.6rem; }

.policy-body .last-revised {
  margin-top: 5rem; padding-top: 2.4rem;
  border-top: 0.1rem solid var(--warmE);
  font-size: 1.1rem; color: var(--warm7);
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
}

.policy-body .upper-case { font-size: 1.3rem; text-transform: uppercase; letter-spacing: 0.04em; line-height: 1.6; color: var(--warm3); }

/* ===== Other policies — list at bottom ===== */
.other-policies {
  padding: 5rem 2.4rem 7rem;
  background: var(--paper);
  border-top: 0.1rem solid var(--warmE);
}
.other-policies .inner { max-width: 88rem; margin: 0 auto; }
.other-policies h3 {
  font-size: 1.1rem; font-weight: 700; color: var(--ember7);
  letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 2rem;
}
.other-policies ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr; gap: 1rem;
}
@media (min-width: 700px) { .other-policies ul { grid-template-columns: repeat(2, 1fr); } }
.other-policies li a {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.6rem 1.8rem;
  border: 0.1rem solid var(--warmE);
  border-radius: 0.6rem;
  background: var(--cream);
  color: var(--ember2);
  font-size: 1.4rem; font-weight: 600;
  text-decoration: none;
  transition: border-color 0.2s, transform 0.2s;
}
.other-policies li a:hover { border-color: var(--ember7); color: var(--ember7); transform: translateY(-0.2rem); }
.other-policies li a::after { content: "→"; color: var(--ember7); font-weight: 700; }
