/* ==========================================================================
   How to Rent page — editorial visual treatment
   Scoped to body.page-how-to-rent so nothing bleeds to other pages.

   Token reference:
     --cream, --linen, --charcoal, --stone, --pebble, --brass
     --font-serif, --font-sans
     --ease, --radius-card, --radius-button
   ========================================================================== */

body.page-how-to-rent {
  background: var(--cream);
}

/* ── Breadcrumbs (quiet bar above hero) ─────────────────────────────────── */

.page-how-to-rent .breadcrumbs {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--stone);
  margin: 0;
  padding: 0;
}
.page-how-to-rent .breadcrumbs a {
  color: var(--stone);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color 160ms var(--ease), border-color 160ms var(--ease);
}
.page-how-to-rent .breadcrumbs a:hover {
  color: var(--brass);
  border-bottom-color: var(--brass);
}
.page-how-to-rent .breadcrumbs .sep {
  margin: 0 7px;
  opacity: 0.5;
}

/* ── Page hero ──────────────────────────────────────────────────────────── */

.page-how-to-rent .page-intro {
  background: var(--cream);
  border-bottom: 1px solid var(--pebble);
  padding: 80px 32px 72px;
}
.page-how-to-rent .page-intro-inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* Breadcrumbs sit immediately above the eyebrow */
.page-how-to-rent .page-intro .breadcrumbs {
  margin-bottom: 20px;
}

/* Eyebrow: "RESIDENT INFO · HOW TO RENT" */
.page-how-to-rent .page-intro .eyebrow {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
  margin-bottom: 20px;
}

.page-how-to-rent .page-intro h1 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(48px, 6vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.015em;
  color: var(--charcoal);
  margin: 0 0 28px;
  max-width: 980px;
  text-wrap: pretty;
}
.page-how-to-rent .page-intro h1 em {
  font-style: italic;
  color: var(--brass);
}

.page-how-to-rent .page-intro .lede {
  font-family: var(--font-sans);
  font-size: 20px;
  line-height: 1.55;
  color: var(--stone);
  max-width: 680px;
  margin: 0;
  text-wrap: pretty;
}

/* ── Two-column doc layout: sticky TOC left, body right ─────────────────── */

.page-how-to-rent .doc {
  background: var(--cream);
  padding: 64px 32px 96px;
}
.page-how-to-rent .doc-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 72px;
  align-items: start;
}

/* ── TOC ────────────────────────────────────────────────────────────────── */

.page-how-to-rent .toc {
  position: sticky;
  top: 120px;
  font-family: var(--font-sans);
  font-size: 14px;
  padding-top: 4px;
}
.page-how-to-rent .toc-label {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
  margin: 0 0 14px;
}
.page-how-to-rent .toc ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.page-how-to-rent .toc a {
  display: block;
  padding: 8px 0 8px 12px;
  color: var(--charcoal);
  text-decoration: none;
  border-left: 2px solid var(--pebble);
  border-bottom: 0;
  line-height: 1.35;
  transition: color 160ms var(--ease), border-color 160ms var(--ease);
}
.page-how-to-rent .toc a:hover {
  color: var(--brass);
  border-left-color: var(--brass);
}
.page-how-to-rent .toc a[aria-current="true"] {
  color: var(--charcoal);
  border-left-color: var(--charcoal);
  font-weight: 500;
}

/* ── Body column ────────────────────────────────────────────────────────── */

.page-how-to-rent .body {
  max-width: 720px;
}

/* Section eyebrow above each H2 */
.page-how-to-rent .body .section-eyebrow {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
  margin-bottom: 10px;
  /* eyebrow is preceded by 56px top margin on the wrapper */
}

.page-how-to-rent .body .section-block {
  margin-top: 64px;
}
.page-how-to-rent .body .section-block:first-child {
  margin-top: 0;
}

.page-how-to-rent .body h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(32px, 3vw, 42px);
  line-height: 1.1;
  letter-spacing: -0.008em;
  color: var(--charcoal);
  margin: 0 0 20px;
  max-width: 720px;
  scroll-margin-top: 120px;
}

.page-how-to-rent .body h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.25;
  letter-spacing: -0.005em;
  color: var(--charcoal);
  margin: 28px 0 8px;
}

.page-how-to-rent .body p {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.65;
  color: var(--charcoal);
  margin: 0 0 16px;
  max-width: 68ch;
  text-wrap: pretty;
}

.page-how-to-rent .body ul,
.page-how-to-rent .body ol:not(.steps) {
  padding-left: 0;
  margin: 0 0 20px;
  list-style: none;
}
.page-how-to-rent .body ul li,
.page-how-to-rent .body ol:not(.steps) li {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.65;
  color: var(--charcoal);
  margin-bottom: 6px;
  padding-left: 20px;
  position: relative;
}
.page-how-to-rent .body ul li::before {
  content: "–";
  position: absolute;
  left: 0;
  color: var(--pebble);
  font-weight: 400;
  font-size: 14px;
}
/* Nested lists: clear indent from parent, re-apply */
.page-how-to-rent .body ul ul {
  margin: 8px 0 0;
}
.page-how-to-rent .body ul ul li::before {
  content: "–";
  color: var(--pebble);
  font-weight: 400;
  opacity: 0.55;
  font-size: 13px;
}

.page-how-to-rent .body a {
  color: var(--charcoal);
  border-bottom: 1px solid var(--pebble);
  text-decoration: none;
  transition: color 160ms var(--ease), border-color 160ms var(--ease);
}
.page-how-to-rent .body a:hover {
  color: var(--brass);
  border-bottom-color: var(--brass);
}
.page-how-to-rent .body strong {
  color: var(--charcoal);
  font-weight: 500;
}

/* ── "How it works" steps — big brass numerals ───────────────────────────── */

.page-how-to-rent .steps {
  display: block;
  grid-template-columns: none;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
}
.page-how-to-rent .steps > li {
  display: grid;
  grid-template-columns: 100px 1fr 200px;
  gap: 40px;
  padding: 40px 0;
  border-top: 1px solid var(--pebble);
  align-items: baseline;
  margin: 0;
}
.page-how-to-rent .steps > li:last-child {
  border-bottom: 1px solid var(--pebble);
}

/* Step number — large brass serif numeral */
.page-how-to-rent .steps .step-num {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 88px;
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--brass);
  font-variant-numeric: lining-nums;
  user-select: none;
}

/* Step main: title + body */
.page-how-to-rent .steps .step-main {
  /* takes 1fr */
}
.page-how-to-rent .steps h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--charcoal);
  margin: 0 0 14px;
}
.page-how-to-rent .steps p {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--stone);
  margin: 0;
  max-width: 560px;
  text-wrap: pretty;
}

/* Step aside — timing / cost note */
.page-how-to-rent .steps .step-aside {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--stone);
  line-height: 1.5;
  border-left: 1px solid var(--pebble);
  padding-left: 20px;
  align-self: start;
  padding-top: 4px;
}

/* ── Callout ────────────────────────────────────────────────────────────── */

.page-how-to-rent .callout {
  background: var(--linen);
  border: 1px solid var(--pebble);
  border-radius: var(--radius-card);
  padding: 18px 22px;
  margin: 20px 0 24px;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--charcoal);
  line-height: 1.55;
}

/* ── Denial list — clay accented ────────────────────────────────────────── */

.page-how-to-rent .denial-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  border-top: 1px solid var(--pebble);
}
.page-how-to-rent .denial-list li {
  padding: 14px 0 14px 20px;
  border-bottom: 1px solid var(--pebble);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  color: var(--charcoal);
  margin: 0;
  position: relative;
}
.page-how-to-rent .denial-list li::before {
  content: "–";
  position: absolute;
  left: 0;
  color: var(--clay);
  font-weight: 500;
}

/* ── Fees definition list ───────────────────────────────────────────────── */

.page-how-to-rent .fees {
  margin: 16px 0 8px;
  border-top: 1px solid var(--pebble);
}
.page-how-to-rent .fees > div {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1px solid var(--pebble);
  align-items: baseline;
}
.page-how-to-rent .fees dt {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.005em;
  color: var(--charcoal);
}
.page-how-to-rent .fees dd {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 16px;
  color: var(--stone);
  font-variant-numeric: tabular-nums lining-nums;
  line-height: 1.5;
}

/* ── FAQ accordion ──────────────────────────────────────────────────────── */

.page-how-to-rent .faqs {
  border-top: 1px solid var(--pebble);
  margin: 8px 0 0;
}
.page-how-to-rent .faqs details {
  border-bottom: 1px solid var(--pebble);
}
.page-how-to-rent .faqs summary {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 24px;
  padding: 24px 0;
  cursor: pointer;
  list-style: none;
  transition: color 160ms var(--ease);
}
.page-how-to-rent .faqs summary::-webkit-details-marker { display: none; }

/* Question text */
.page-how-to-rent .faqs summary > span:first-child {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  color: var(--charcoal);
  letter-spacing: -0.005em;
  line-height: 1.3;
}
.page-how-to-rent .faqs summary:hover > span:first-child {
  color: var(--brass);
}

/* Plus icon */
.page-how-to-rent .faqs summary .plus {
  flex: 0 0 auto;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 22px;
  line-height: 1;
  color: var(--stone);
  transition: transform 220ms var(--ease);
}
.page-how-to-rent .faqs details[open] summary .plus {
  transform: rotate(45deg);
  color: var(--charcoal);
}

/* Answer body */
.page-how-to-rent .faqs .faq-body {
  padding: 0 0 24px;
  font-family: var(--font-sans);
  font-size: 16px;
  color: var(--stone);
  line-height: 1.65;
  max-width: 64ch;
}

/* ── Help band — charcoal ReadyBand ─────────────────────────────────────── */

.page-how-to-rent .help-band {
  background: var(--charcoal);
  padding: 96px 32px;
}
.page-how-to-rent .help-band-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 64px;
  align-items: center;
}

/* Left column */
.page-how-to-rent .help-band .help-eyebrow {
  font-family: var(--font-sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--brass);
  font-weight: 500;
  margin-bottom: 20px;
}
.page-how-to-rent .help-band h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(36px, 3.5vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--cream);
  margin: 0 0 24px;
  max-width: 560px;
  text-wrap: pretty;
}
.page-how-to-rent .help-band > .help-band-inner > .help-left > p {
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.6;
  color: var(--pebble);
  margin: 0;
  max-width: 560px;
  text-wrap: pretty;
}

/* Right column */
.page-how-to-rent .help-band .help-right {
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: flex-start;
}

/* Primary CTA — cream bg, charcoal text */
.page-how-to-rent .help-band .btn-help-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 500;
  background: var(--cream);
  color: var(--charcoal);
  border: 1px solid var(--cream);
  border-radius: var(--radius-button);
  text-decoration: none;
  transition: background 180ms var(--ease), border-color 180ms var(--ease);
}
.page-how-to-rent .help-band .btn-help-primary:hover {
  background: var(--brass);
  border-color: var(--brass);
  color: var(--cream);
}

/* Ghost secondary CTA on charcoal */
.page-how-to-rent .help-band .btn-help-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 500;
  background: transparent;
  color: var(--cream);
  border: 1px solid var(--pebble);
  border-radius: var(--radius-button);
  text-decoration: none;
  transition: border-color 180ms var(--ease), color 180ms var(--ease);
}
.page-how-to-rent .help-band .btn-help-ghost:hover {
  border-color: var(--cream);
}

/* Office info block */
.page-how-to-rent .help-band .office {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 8px;
}
.page-how-to-rent .help-band .office-or {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
}
.page-how-to-rent .help-band .office a[href^="tel"] {
  font-family: var(--font-sans);
  font-size: 22px;
  color: var(--cream);
  font-variant-numeric: tabular-nums;
  text-decoration: none;
  border: none;
}
.page-how-to-rent .help-band .office a[href^="tel"]:hover {
  color: var(--brass);
  border: none;
}
.page-how-to-rent .help-band .office-hours {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--stone);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */

@media (max-width: 900px) {
  /* Single-column: TOC becomes static block above body */
  .page-how-to-rent .doc-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .page-how-to-rent .toc {
    position: static;
    background: var(--linen);
    border: 1px solid var(--pebble);
    border-radius: var(--radius-card);
    padding: 20px 24px;
    margin-bottom: 8px;
  }
  .page-how-to-rent .toc ol {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2px;
  }
  .page-how-to-rent .toc a {
    border-left: none;
    border-bottom: 2px solid transparent;
    padding: 6px 4px;
    white-space: nowrap;
  }
  .page-how-to-rent .toc a:hover {
    border-left: none;
    border-bottom-color: var(--brass);
  }

  /* Steps: collapse aside into 2-col */
  .page-how-to-rent .steps > li {
    grid-template-columns: 80px 1fr;
    gap: 24px;
  }
  .page-how-to-rent .steps .step-aside {
    display: none;
  }

  /* Help band: single column */
  .page-how-to-rent .help-band-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

@media (max-width: 600px) {
  .page-how-to-rent .page-intro {
    padding: 56px 20px 48px;
  }
  .page-how-to-rent .page-intro h1 {
    font-size: 42px;
  }
  .page-how-to-rent .page-intro .lede {
    font-size: 17px;
  }
  .page-how-to-rent .doc {
    padding: 40px 20px 72px;
  }
  .page-how-to-rent .body h2 {
    font-size: 30px;
  }
  .page-how-to-rent .body .section-block {
    margin-top: 48px;
  }

  /* Steps: number above title, single column */
  .page-how-to-rent .steps > li {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 32px 0;
  }
  .page-how-to-rent .steps .step-num {
    font-size: 64px;
    line-height: 1;
  }
  .page-how-to-rent .steps h3 {
    font-size: 22px;
  }

  .page-how-to-rent .fees > div {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .page-how-to-rent .help-band {
    padding: 64px 20px;
  }
  .page-how-to-rent .help-band h2 {
    font-size: 32px;
  }
}
