/* ============================================================
   Inner-page components — page hero, prose, grids, lists, forms
   ============================================================ */

/* Page hero (compact cinematic, framed top) */
.phero {
  position: relative; isolation: isolate; color: var(--cream);
  min-height: clamp(46vh, 58svh, 620px);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 8rem var(--gutter) clamp(2.4rem, 5vw, 4rem);
  border-top-left-radius: var(--frame-radius); border-top-right-radius: var(--frame-radius);
  overflow: hidden; background: var(--ink);
}
.phero__media { position: absolute; inset: 0; z-index: -2; }
.phero__media img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); }
.phero::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(13,12,10,0.55) 0%, rgba(13,12,10,0.2) 40%, rgba(13,12,10,0.82) 100%); }
.phero__crumb { font-family: var(--mono); text-transform: uppercase; letter-spacing: .2em; font-size: .68rem; color: var(--on-dark-soft); margin-bottom: 1rem; display: flex; gap: .6em; align-items: center; }
.phero__crumb a:hover { color: var(--accent-2); }
.phero__crumb .sep { color: var(--accent-2); }
.phero h1 { font-size: clamp(2.4rem, 1.4rem + 3.6vw, 4.6rem); line-height: 1; max-width: 18ch; letter-spacing: -.02em; }
.phero h1 em { color: var(--cream); }
.phero h1 .mark { color: var(--accent-2); transform: skewX(-12deg); display: inline-block; font-style: normal; letter-spacing: -.08em; }
.phero__sub { margin-top: 1.2rem; max-width: 52ch; color: var(--on-dark-soft); font-size: var(--step-1); }

/* Generic light section wrappers reuse .section .lite / .standard */
.prose { max-width: 70ch; }
.prose p { color: var(--on-light-soft); margin-bottom: 1.1rem; font-size: var(--step-1); line-height: 1.6; }
.prose p:first-of-type { color: var(--on-light); font-size: var(--step-2); font-family: var(--serif); line-height: 1.3; letter-spacing: -.01em; }
.prose h2, .prose h3 { margin: 2rem 0 .8rem; }
.prose h3 { font-size: var(--step-2); }

/* Two-column intro (text + image) */
.split { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split--flip .split__media { order: -1; }
.split__media { position: relative; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3.4; background: var(--ink-2); }
.split__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.split__text .eyebrow { margin-bottom: 1rem; }
.split__text h2 { font-size: var(--step-3); margin-bottom: 1.2rem; }
.split__text h2 em { color: var(--accent); }
.split__text p { color: var(--on-light-soft); margin-bottom: 1rem; }
@media (max-width: 820px){ .split { grid-template-columns: 1fr; } .split--flip .split__media { order: 0; } }

/* Values / feature cards grid */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 1.2rem; }
.card {
  background: var(--paper); border: 1px solid var(--line-light); border-radius: var(--radius-lg);
  padding: 1.8rem; display: flex; flex-direction: column; gap: .7rem;
  transition: transform .4s var(--ease), border-color .4s, box-shadow .4s;
}
.card:hover { transform: translateY(-4px); border-color: var(--accent); box-shadow: 0 24px 50px -30px rgba(13,12,10,.4); }
.card__n { font-family: var(--mono); font-size: .7rem; letter-spacing: .14em; color: var(--accent); }
.card h3 { font-size: var(--step-2); }
.card p { color: var(--on-light-soft); font-size: var(--step--1); }
.card--ink { background: var(--ink-2); border-color: var(--line-dark); color: var(--cream); }
.card--ink h3 { color: var(--cream); } .card--ink p { color: var(--on-dark-soft); }

/* List rows (communities / typical listings) */
.rows { border-top: 1px solid var(--line-light); }
.row {
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.5rem; align-items: center;
  padding: 1.8rem 0; border-bottom: 1px solid var(--line-light);
  transition: padding-left .4s var(--ease);
}
.row:hover { padding-left: .8rem; }
.row__k { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; color: var(--accent); width: 9ch; }
.row__main h3 { font-size: var(--step-2); }
.row__main h3 em { color: var(--accent); }
.row__main p { color: var(--on-light-soft); font-size: var(--step--1); max-width: 60ch; margin-top: .3rem; }
.row__go { width: 44px; height: 44px; border-radius: 50%; border: 1px solid var(--line-light); display: grid; place-items: center; transition: background .3s, color .3s, transform .3s; flex: 0 0 auto; }
.row:hover .row__go { background: var(--accent); color: #fff; transform: rotate(-45deg); }
@media (max-width: 700px){ .row { grid-template-columns: 1fr auto; } .row__k { display: none; } }

/* Service list (numbered, with bullets) */
.svcblock { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.svcblock .card ul { margin-top: .4rem; display: flex; flex-direction: column; gap: .5rem; }
.svcblock .card li { color: var(--on-light-soft); font-size: var(--step--1); padding-left: 1.2em; position: relative; }
.svcblock .card li::before { content: ""; position: absolute; left: 0; top: .55em; width: 6px; height: 6px; background: var(--accent); transform: skewX(-12deg); }
@media (max-width: 760px){ .svcblock { grid-template-columns: 1fr; } }

/* FAQ accordion */
.faq { max-width: 820px; margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--line-light); }
.faq__q { width: 100%; text-align: left; display: flex; justify-content: space-between; gap: 1rem; align-items: center;
  padding: 1.5rem 0; font-family: var(--serif); font-size: var(--step-1); color: var(--on-light); }
.faq__q .ic { flex: 0 0 auto; width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--line-light); display: grid; place-items: center; transition: transform .4s var(--ease), background .3s, color .3s; }
.faq__item.open .faq__q .ic { transform: rotate(45deg); background: var(--accent); color: #fff; border-color: var(--accent); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height .5s var(--ease); }
.faq__a p { color: var(--on-light-soft); padding-bottom: 1.5rem; max-width: 70ch; }

/* Form */
.formwrap { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
.form { background: var(--paper); border: 1px solid var(--line-light); border-radius: var(--radius-lg); padding: clamp(1.6rem,3vw,2.6rem); }
.form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.field { display: flex; flex-direction: column; gap: .4rem; }
.field.full { grid-column: 1 / -1; }
.field label { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; font-size: .64rem; color: var(--on-light-soft); }
.field input, .field select, .field textarea {
  font: inherit; font-size: var(--step-0); color: var(--on-light);
  background: var(--cream); border: 1px solid var(--line-light); border-radius: 12px;
  padding: .8em .9em; width: 100%; transition: border-color .3s, box-shadow .3s;
}
.field textarea { min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(209,44,26,.12); }
.form .btn { margin-top: 1.2rem; width: 100%; justify-content: center; }
.form__consent { display: flex; gap: .6rem; align-items: flex-start; margin-top: 1rem; font-size: var(--step--1); color: var(--on-light-soft); }
.form__consent input { width: auto; }
.form__aside .eyebrow { margin-bottom: 1rem; }
.form__aside h2 { font-size: var(--step-3); margin-bottom: 1.2rem; }
.form__aside h2 em { color: var(--accent); }
.contact-line { display: flex; gap: .9rem; align-items: flex-start; padding: 1rem 0; border-bottom: 1px solid var(--line-light); }
.contact-line svg { width: 20px; height: 20px; color: var(--accent); flex: 0 0 auto; margin-top: .15rem; }
.contact-line b { display: block; font-weight: 600; }
.contact-line span, .contact-line a { color: var(--on-light-soft); font-size: var(--step--1); }
.contact-line a:hover { color: var(--accent); }
@media (max-width: 860px){ .formwrap { grid-template-columns: 1fr; } .form__grid { grid-template-columns: 1fr; } }

/* Legal / prose pages */
.legal-body { max-width: 820px; margin-inline: auto; }
.legal-body h2 { font-size: var(--step-2); margin: 2.2rem 0 .8rem; }
.legal-body p, .legal-body li { color: var(--on-light-soft); margin-bottom: 1rem; line-height: 1.7; }
.legal-body ul { padding-left: 1.2rem; list-style: disc; }

/* Properties placeholder */
.empty { text-align: center; max-width: 60ch; margin-inline: auto; }
.empty .eyebrow { justify-content: center; margin-bottom: 1rem; }
.empty h2 { font-size: var(--step-4); margin-bottom: 1rem; }
.empty h2 em { color: var(--accent); }
.empty p { color: var(--on-light-soft); margin-bottom: 1.6rem; }
