/* ─────────────────────────────────────────────────────────────
   Piandré · content pages (about, contact, catalog, updates, posts)
   Minimalist white canvas, single red accent. Reuses styles.css tokens.
   ───────────────────────────────────────────────────────────── */

/* Doc hero — shared with salon.css .sln-hero spacing. Top padding clears the
   fixed header (~82px at rest) so the "← back" link isn't clipped on mobile. */
.doc-hero { padding: clamp(92px, 8vw, 108px) 0 clamp(26px, 4vw, 44px); border-bottom: 1px solid var(--line); }
.doc-hero .eyebrow { margin: 0; }
.doc-back { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); margin-bottom: clamp(22px, 4vw, 40px); transition: color .25s var(--ease); }
.doc-back:hover { color: var(--red); }
.doc-hero h1 { font-family: var(--font-display); font-weight: 300; font-size: clamp(46px, 7.4vw, 104px); line-height: .98; letter-spacing: -.015em; margin: 12px 0 0; max-width: 16ch; }
.doc-hero h1 .it { font-style: italic; color: var(--red); }
/* Keep a short hero headline on one line (never orphan the last word) */
.doc-hero h1.oneline { white-space: nowrap; max-width: none; font-size: min(8.4vw, 88px); }
/* The founder's belief, as a full-sentence quote: real scale for presence,
   a tight measure so it stacks into a deliberate block, left-aligned, with
   the attribution snugged beneath. (Own class so it never collides with the
   homepage .statement component, which is centered + heavily padded.) */
.doc-hero h1.belief { font-size: clamp(28px, 4vw, 52px); line-height: 1.1; letter-spacing: -.012em; text-align: left; max-width: 19ch; margin-top: 16px; }
.doc-attr { margin: clamp(18px, 2.2vw, 24px) 0 0; font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }

/* About hero: the founder's belief on the left, the team on the right —
   so the empty space becomes a picture of the people the quote is about. */
.about-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 56%); gap: clamp(34px, 5vw, 72px); align-items: center; margin-top: clamp(4px, 1vw, 10px); }
.about-hero-copy .eyebrow { margin: 0; }
.about-hero-copy .belief { margin-top: 14px; }
.about-hero-figure { margin: 0; }
.about-hero-figure img { width: 100%; height: auto; display: block; border-radius: 6px; aspect-ratio: 4 / 3; object-fit: cover; background: var(--paper-2); }
.about-hero-figure figcaption { margin-top: 12px; font-size: 12px; font-weight: 600; letter-spacing: .02em; color: var(--muted); line-height: 1.5; }
@media (max-width: 820px) {
  .about-hero-grid { grid-template-columns: 1fr; gap: clamp(22px, 5vw, 32px); margin-top: clamp(20px, 5vw, 34px); align-items: start; }
}
.doc-lede { font-size: clamp(17px, 2.1vw, 22px); color: var(--ink-soft); margin: 22px 0 0; max-width: 50ch; line-height: 1.55; }

/* Contact form (Netlify Forms) */
.ct-form-card { max-width: 680px; margin: 0 0 clamp(44px, 6vw, 72px); }
.ct-form-title { font-family: var(--font-display); font-weight: 400; font-size: clamp(26px, 3.4vw, 38px); line-height: 1.08; margin: 0 0 8px; }
.ct-form-sub { color: var(--ink-soft); line-height: 1.6; margin: 0 0 26px; max-width: 54ch; }
.ct-field-row { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 14px; }
.ct-field { display: block; margin-bottom: 16px; }
.ct-field > span:first-child { display: block; font-size: 11.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: 8px; }
.ct-field input, .ct-field select, .ct-field textarea { width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 6px; font-family: var(--font-sans); font-size: 16px; font-weight: 500; color: var(--ink); background: var(--white); appearance: none; -webkit-appearance: none; transition: border-color .18s var(--ease), box-shadow .18s var(--ease); }
.ct-field textarea { resize: vertical; min-height: 128px; line-height: 1.55; }
.ct-field input:focus, .ct-field select:focus, .ct-field textarea:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 3px rgba(192, 45, 47, .08); }
.ct-select-wrap { position: relative; display: block; }
.ct-select-wrap::after { content: ''; position: absolute; right: 15px; top: 50%; width: 12px; height: 12px; transform: translateY(-50%); pointer-events: none; background: center / contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23837a72' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); }
.ct-submit { margin-top: 6px; padding: 14px 32px; background: var(--red); color: #fff; border: none; border-radius: 6px; font-family: var(--font-sans); font-size: 12.5px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; transition: background .2s var(--ease), transform .1s var(--ease); }
.ct-submit:hover:not(:disabled) { background: var(--red-deep); transform: translateY(-1px); }
.ct-submit:disabled { opacity: .55; cursor: default; }
.ct-success { padding: 22px 0 6px; }
.ct-success h3 { font-family: var(--font-display); font-weight: 400; font-style: italic; font-size: clamp(22px, 2.6vw, 30px); line-height: 1.2; margin: 0 0 18px; }
.ct-submit-ghost { background: none; border: 1px solid var(--line-2); color: var(--ink); padding: 11px 22px; border-radius: 6px; font-family: var(--font-sans); font-weight: 700; font-size: 11.5px; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: border-color .2s var(--ease), color .2s var(--ease); }
.ct-submit-ghost:hover { border-color: var(--red); color: var(--red); }
.ct-form-card [hidden] { display: none !important; }
@media (max-width: 560px) { .ct-field-row { grid-template-columns: 1fr; gap: 0; } }

/* Prose */
.prose { max-width: 72ch; }
.prose h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(28px, 4vw, 44px); line-height: 1.1; letter-spacing: -.01em; margin: clamp(44px, 6vw, 76px) 0 18px; }
.prose h2:first-child { margin-top: 0; }
.prose h2 .it { font-style: italic; color: var(--red); }
.prose h3 { font-size: 13px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--red); margin: clamp(30px, 4vw, 46px) 0 14px; }
.prose p { font-size: clamp(16px, 1.85vw, 18.5px); line-height: 1.72; color: var(--ink-soft); margin: 0 0 18px; }
.prose p strong { color: var(--ink); font-weight: 600; }
.prose a { color: var(--red); text-decoration: none; border-bottom: 1px solid var(--line-2); }
.prose a:hover { border-color: var(--red); }

.pull { font-family: var(--font-display); font-weight: 300; font-style: italic; font-size: clamp(24px, 3.6vw, 40px); line-height: 1.28; color: var(--ink); letter-spacing: -.01em; margin: clamp(36px, 5vw, 64px) 0; padding-left: clamp(20px, 3vw, 34px); border-left: 2px solid var(--red); max-width: 30ch; }
.pull .by { display: block; font-family: var(--font-sans); font-style: normal; font-size: 12.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-top: 18px; }

/* About — FAQ paired with the flagship building (sticky alongside) */
.faq-layout { display: grid; grid-template-columns: minmax(0, 360px) minmax(0, 1fr); gap: clamp(34px, 5vw, 72px); align-items: start; }
.faq-figure { position: sticky; top: 104px; margin: 0; }
.faq-figure img { width: 100%; height: auto; display: block; aspect-ratio: 4 / 5; object-fit: cover; object-position: center 36%; border-radius: 5px; background: var(--paper-2); filter: grayscale(1) contrast(1.04); }
.faq-figure figcaption { margin-top: 12px; font-size: 12px; font-weight: 600; letter-spacing: .03em; color: var(--muted); line-height: 1.5; }
.faq-layout .section-head { max-width: none; margin: 0; }
.faq-layout .faq-list { max-width: none; margin: clamp(24px, 3vw, 38px) 0 0; }
@media (max-width: 820px) {
  .faq-layout { grid-template-columns: 1fr; gap: clamp(22px, 5vw, 32px); }
  .faq-figure { position: static; }
  .faq-figure img { aspect-ratio: 4 / 3; }
}

/* Founder — portrait sitting beside her story (the History blurb) */
.founder-layout { display: grid; grid-template-columns: minmax(0, 230px) minmax(0, 1fr); gap: clamp(34px, 5vw, 76px); align-items: start; }
.founder-aside { position: sticky; top: 104px; }
.founder-aside .founder-photo { width: clamp(150px, 16vw, 184px); height: auto; border-radius: 50%; display: block; background: var(--paper-2); }
.founder-name { font-family: var(--font-display); font-weight: 500; font-size: clamp(19px, 2vw, 23px); line-height: 1.2; color: var(--ink); margin: 18px 0 0; }
.founder-role { font-size: 11.5px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; color: var(--muted); margin: 7px 0 0; }
@media (max-width: 820px) {
  .founder-layout { grid-template-columns: 1fr; gap: clamp(20px, 5vw, 30px); }
  .founder-aside { position: static; }
  .founder-aside .founder-photo { width: 132px; }
}

/* Editorial section: a pinned title rail beside scannable entries.
   Shares the founder-layout grid so Story / Spirituality / Financial all
   carry the same left-rail rhythm down the page. */
.about-sec { display: grid; grid-template-columns: minmax(0, 230px) minmax(0, 1fr); gap: clamp(34px, 5vw, 76px); align-items: start; margin-top: clamp(50px, 7vw, 96px); }
.about-sec .sec-title { position: sticky; top: 104px; }
.about-sec .sec-title h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(28px, 3.4vw, 40px); line-height: 1.05; letter-spacing: -.01em; margin: 0; }
.sec-items { display: flex; flex-direction: column; }
.sec-item { padding: clamp(20px, 2.6vw, 28px) 0; border-top: 1px solid var(--line); }
.sec-item:first-child { padding-top: 0; border-top: 0; }
.sec-item h3 { font-size: 13px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--red); margin: 0 0 12px; }
.sec-item p { font-size: clamp(16px, 1.85vw, 18px); line-height: 1.72; color: var(--ink-soft); margin: 0; }
.sec-item p strong { color: var(--ink); font-weight: 600; }
@media (max-width: 820px) {
  .about-sec { grid-template-columns: 1fr; gap: clamp(16px, 4vw, 24px); margin-top: clamp(42px, 9vw, 60px); }
  .about-sec .sec-title { position: static; }
  .sec-item:first-child { padding-top: clamp(18px, 4vw, 24px); border-top: 1px solid var(--line); }
}

/* Mission / vision two-up */
.mv-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); margin: clamp(40px, 5vw, 68px) 0; }
.mv-cell { background: var(--paper); padding: clamp(28px, 3.4vw, 46px); }
.mv-cell h3 { margin-top: 0; }
.mv-cell p { font-size: clamp(16px, 1.8vw, 18px); line-height: 1.72; color: var(--ink-soft); margin-bottom: 0; }
.mv-cell p strong { color: var(--ink); font-weight: 600; }

/* Quote list */
.quotes { list-style: none; padding: 0; margin: clamp(24px, 3vw, 40px) 0 0; display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.quotes li { background: var(--paper); padding: clamp(22px, 2.6vw, 32px); font-family: var(--font-display); font-style: italic; font-size: clamp(19px, 2.3vw, 26px); line-height: 1.32; color: var(--ink); }

/* Book pill (shared button used on content pages) */
.book-dot.lg { font-size: 15px; padding: 14px 26px; border: 1px solid var(--red); border-radius: 999px; color: var(--red); display: inline-flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: .04em; transition: background .3s var(--ease), color .3s var(--ease); }
.book-dot.lg .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--red); transition: background .3s var(--ease); }
.book-dot.lg:hover { background: var(--red); color: #fff; }
.book-dot.lg:hover .dot { background: #fff; }

/* Contact */
.ct-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(34px, 5vw, 72px); align-items: start; }
.ct-block { padding-bottom: clamp(24px, 3vw, 34px); border-bottom: 1px solid var(--line); margin-bottom: clamp(24px, 3vw, 34px); }
.ct-block:last-child { border-bottom: 0; margin-bottom: 0; }
.ct-block h3 { font-size: 11.5px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin: 0 0 14px; }
.ct-block a, .ct-block p { font-size: clamp(16px, 1.9vw, 19px); color: var(--ink); line-height: 1.6; display: block; margin: 0 0 6px; }
.ct-block a { transition: color .25s var(--ease); }
.ct-block a:hover { color: var(--red); }
.ct-big { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 400; }

/* Catalog menu */
.cat-cat { margin-top: clamp(40px, 5vw, 64px); }
.cat-cat:first-of-type { margin-top: clamp(20px, 3vw, 32px); }
.cat-cat-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; padding-bottom: 14px; border-bottom: 1px solid var(--line-2); margin-bottom: 4px; }
.cat-cat-head h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(26px, 3.6vw, 42px); letter-spacing: -.01em; }
.cat-cat-head .n { font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.cat-items { display: flex; flex-wrap: wrap; gap: 8px 0; padding: 18px 0 4px; }
.cat-item { font-size: clamp(15px, 1.7vw, 17px); color: var(--ink-soft); line-height: 1.5; }
.cat-item::after { content: "·"; color: var(--line-2); margin: 0 12px; }
.cat-item:last-child::after { content: ""; margin: 0; }
.cat-note { font-size: 14px; color: var(--muted); margin-top: 14px; }

/* Updates — blog card gallery */
.up-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: clamp(28px, 3.2vw, 46px) clamp(22px, 2.6vw, 36px); margin-top: clamp(26px, 3.4vw, 44px); }
.up-item { display: flex; flex-direction: column; }
.up-thumb { display: block; overflow: hidden; border-radius: 6px; margin-bottom: 15px; }
.up-thumb img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; display: block; background: var(--paper-2); transition: transform .55s var(--ease); }
.up-item:hover .up-thumb img { transform: scale(1.04); }
.up-meta { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: 9px; }
.up-meta .by { color: var(--red); }
.up-item h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(20px, 1.7vw, 24px); line-height: 1.18; letter-spacing: -.01em; margin: 0 0 8px; color: var(--ink); transition: color .2s var(--ease); }
.up-item:hover h2 { color: var(--red); }
.up-item p { font-size: 15px; color: var(--ink-soft); line-height: 1.55; margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.up-item .more { display: inline-block; margin-top: 12px; font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--red); }
@media (max-width: 900px) { .up-list { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .up-list { grid-template-columns: 1fr; gap: 32px; } }

/* Post hero photo (below the title). Shares the article's reading column
   (68ch) and a consistent 3:2 crop — matching the /updates index
   thumbnails — so it frames the post instead of filling the whole desktop
   width. */
.post-hero { margin: clamp(22px, 4vw, 44px) 0 0; max-width: 68ch; }
.post-hero img { width: 100%; aspect-ratio: 3 / 2; object-fit: cover; border-radius: 5px; display: block; background: var(--paper-2); }

/* Migrated YouTube videos — responsive 16:9, in the reading column. */
.post-videos { max-width: 68ch; margin: clamp(22px, 4vw, 44px) 0 0; }
.post-video { margin: 26px 0; border-radius: 5px; overflow: hidden; background: #000; }
.post-videos .post-video:first-child { margin-top: 0; }
.post-video iframe { display: block; width: 100%; aspect-ratio: 16 / 9; border: 0; }

/* Post page */
.post-body { max-width: 68ch; overflow-wrap: break-word; }   /* wrap long inline URLs so they can't overflow on mobile */
.post-body p { font-size: clamp(16.5px, 1.9vw, 19px); line-height: 1.75; color: var(--ink-soft); margin: 0 0 22px; }
.post-body a { color: var(--red); text-decoration: underline; text-underline-offset: 2px; transition: opacity .2s var(--ease); }
.post-body a:hover { opacity: .7; }
.post-body strong { font-weight: 700; color: var(--ink); }
.post-body em { font-style: italic; }
.post-foot { max-width: 68ch; margin-top: clamp(40px, 5vw, 70px); padding-top: clamp(26px, 3vw, 40px); border-top: 1px solid var(--line); }

@media (max-width: 820px) {
  .ct-grid { grid-template-columns: 1fr; gap: clamp(26px, 6vw, 40px); }
  .mv-grid { grid-template-columns: 1fr; }
}
