/* ============================================================
   P&K CONSULTING — CREDIT SITE SHARED CHROME  (app.css?v=1)
   Brand + type spec board-ratified 2026-07-04.
   Type law: Jost 300 banned; disclosures >=16px/400/>=4.5:1,
   never opacity-dimmed; font-synthesis none; hierarchy from
   size/tracking/case/gold (Marcellus has one weight).
   ============================================================ */

:root {
  --obsidian:   #0B0A08;
  --charcoal:   #14120E;
  --hairline:   #2E2818;
  --gold:       #C9A227;
  --gold-light: #E8CD79;
  --gold-deep:  #8A6E14;
  --ivory:      #F1EAD8;
  --muted:      #9C9078;
}

@font-face {
  font-family: 'PK Display';
  src: url('fonts/marcellus.woff2') format('woff2');
  font-weight: 400; font-display: swap;
}
@font-face {
  font-family: 'PK Sans';
  src: url('fonts/jost-var.woff2') format('woff2');
  font-weight: 400 600; font-display: swap; /* 300 not servable — board order */
}

* { margin: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-synthesis: none; }
body {
  background: var(--obsidian);
  color: var(--ivory);
  font-family: 'PK Sans', 'Helvetica Neue', Arial, sans-serif;
  font-weight: 400;
  font-size: 17px; line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, .display { font-family: 'PK Display', Georgia, 'Times New Roman', serif; font-weight: 400; }
h1 em, h2 em, .display em { font-style: normal; color: var(--gold-light); }

.wrap { max-width: 1160px; margin: 0 auto; padding: 0 32px; }
.eyebrow {
  color: var(--gold); font-size: 12px; font-weight: 500;
  letter-spacing: .28em; text-transform: uppercase; margin-bottom: 20px;
}
.money, .tabular { font-variant-numeric: tabular-nums; } /* counters, pricing — board condition */

/* ---------- spinning crest coin ---------- */
.coin-stage { perspective: 1400px; display: inline-block; }
.coin {
  position: relative; display: block;
  width: var(--size, 340px); height: var(--size, 340px);
  transform-style: preserve-3d;
  animation: coin-spin 14s linear infinite;
}
.coin .face {
  position: absolute; inset: 0;
  background: url('pk-crest-front-transparent.png') center/contain no-repeat;
  backface-visibility: hidden;
}
.coin .face.back  { transform: rotateY(180deg) translateZ(var(--depth, 5px)); }
.coin .face.front { transform: translateZ(var(--depth, 5px)); }
.coin .face.edge  { filter: brightness(0.3) saturate(1.3); backface-visibility: visible; }
@keyframes coin-spin { from { transform: rotateY(0); } to { transform: rotateY(360deg); } }
@media (prefers-reduced-motion: reduce) { .coin { animation: none; } }

/* ---------- buttons + links ---------- */
.btn {
  display: inline-block; text-decoration: none; cursor: pointer;
  font-family: 'PK Sans', sans-serif; font-size: 13px; font-weight: 500;
  letter-spacing: .18em; text-transform: uppercase;
  padding: 16px 34px; border: 1px solid var(--gold);
  transition: background .25s, color .25s;
}
.btn-solid { background: var(--gold); color: var(--obsidian); }
.btn-solid:hover { background: var(--gold-light); border-color: var(--gold-light); }
.btn-ghost { background: transparent; color: var(--gold); }
.btn-ghost:hover { background: rgba(201,162,39,.1); color: var(--gold-light); }
.link-gold { color: var(--gold); text-decoration: none; border-bottom: 1px solid var(--gold-deep); }
.link-gold:hover { color: var(--gold-light); }
a:focus-visible, .btn:focus-visible, button:focus-visible { outline: 1px solid var(--gold); outline-offset: 4px; }

/* ---------- NAV (sticky) ---------- */
.pk-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(11,10,8,.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--hairline);
}
.pk-nav .bar {
  max-width: 1160px; margin: 0 auto; padding: 14px 32px;
  display: flex; align-items: center; gap: 34px;
}
.pk-nav .lockup { display: flex; align-items: center; gap: 13px; margin-right: auto; text-decoration: none; color: var(--ivory); }
.pk-nav .wordmark { font-family: 'PK Display', Georgia, serif; font-size: 18px; letter-spacing: .08em; white-space: nowrap; }
.pk-nav .wordmark .amp { color: var(--gold); }
.pk-nav .links { display: flex; align-items: center; gap: 30px; }
.pk-nav .links a {
  color: var(--muted); text-decoration: none;
  font-size: 13px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase;
}
.pk-nav .links a:hover { color: var(--gold-light); }
.pk-nav .links a[aria-current="page"] { color: var(--gold); }
.pk-nav .links a.btn-solid { color: var(--obsidian); }
.pk-nav .links a.btn-solid:hover { color: var(--obsidian); }
.pk-nav .btn { padding: 12px 22px; }
.pk-nav .hamburger {
  display: none; background: none; border: 1px solid var(--hairline);
  color: var(--gold); padding: 10px 12px; cursor: pointer; font-size: 18px; line-height: 1;
}
@media (max-width: 900px) {
  .pk-nav .bar { padding: 12px 20px; gap: 16px; }
  .pk-nav .hamburger { display: block; }
  .pk-nav .links {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: flex-start; gap: 0;
    background: var(--charcoal); border-bottom: 1px solid var(--hairline);
  }
  .pk-nav .links.open { display: flex; }
  .pk-nav .links a { padding: 16px 24px; width: 100%; border-top: 1px solid var(--hairline); }
  .pk-nav .links .btn { margin: 14px 24px 18px; width: auto; border: 1px solid var(--gold); }
}

/* ---------- service cards (12-icon directory) ---------- */
.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 22px; }
.service-card {
  background: var(--charcoal); border: 1px solid var(--hairline);
  padding: 32px 28px;
  transition: transform .3s, border-color .3s;
}
.service-card:hover { transform: translateY(-4px); border-color: var(--gold-deep); }
.service-card .icon { width: 44px; height: 44px; color: var(--gold); margin-bottom: 18px; }
.service-card .icon svg { width: 100%; height: 100%; }
.service-card h3 { font-size: 21px; margin-bottom: 10px; }
.service-card p { color: var(--muted); font-size: 15.5px; margin-bottom: 16px; }

/* ---------- FOOTER ---------- */
.pk-footer { border-top: 1px solid var(--hairline); margin-top: 88px; }
.pk-footer .cols {
  max-width: 1160px; margin: 0 auto; padding: 64px 32px 48px;
  display: grid; grid-template-columns: 1.3fr 1fr 1fr; gap: 48px;
}
.pk-footer .mark { width: 68px; height: 68px; margin-bottom: 16px; }
.pk-footer .mission { color: var(--muted); font-size: 15.5px; max-width: 34ch; margin-bottom: 18px; }
.pk-footer h4 {
  font-family: 'PK Sans', sans-serif; font-weight: 500; font-size: 12px;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold); margin-bottom: 18px;
}
.pk-footer ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pk-footer ul a { color: var(--muted); text-decoration: none; font-size: 15px; }
.pk-footer ul a:hover { color: var(--gold-light); }
.pk-footer .contact-line { display: flex; align-items: center; gap: 10px; color: var(--muted); font-size: 15px; margin-bottom: 12px; }
.pk-footer .contact-line a { color: var(--muted); text-decoration: none; }
.pk-footer .contact-line a:hover { color: var(--gold-light); }
.pk-footer .contact-line svg { width: 18px; height: 18px; color: var(--gold); flex: none; }
.pk-footer .social { display: flex; gap: 12px; }
.pk-footer .social a {
  display: grid; place-items: center; width: 38px; height: 38px;
  border: 1px solid var(--hairline); color: var(--gold); transition: border-color .25s, color .25s;
}
.pk-footer .social a:hover { border-color: var(--gold); color: var(--gold-light); }
.pk-footer .social svg { width: 17px; height: 17px; }
/* board token: disclosures >=16px / 400 / never dimmed below 4.5:1 */
.pk-footer .legal {
  border-top: 1px solid var(--hairline);
}
.pk-footer .legal .inner {
  max-width: 1160px; margin: 0 auto; padding: 26px 32px;
  display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap;
  color: var(--muted); font-size: 16px; font-weight: 400;
}
.pk-footer .disclosure {
  max-width: 1160px; margin: 0 auto; padding: 8px 32px 30px;
  color: var(--muted); font-size: 16px; font-weight: 400; max-width: 90ch;
}
@media (max-width: 860px) {
  .pk-footer .cols { grid-template-columns: 1fr; gap: 40px; }
}

/* ============ WAVE 1 SECTION PATTERNS ============ */

/* offer strip + lead form */
.offer-strip {
  background:
    linear-gradient(180deg, rgba(11,10,8,.82), rgba(11,10,8,.94)),
    url('img/offer-plate.webp') center/cover no-repeat var(--charcoal);
  border-bottom: 1px solid var(--hairline);
  padding: 56px 0;
}
.offer-strip .inner { max-width: 760px; margin: 0 auto; padding: 0 32px; text-align: center; }
.offer-strip h2 { font-size: clamp(26px, 3.4vw, 34px); margin-bottom: 10px; text-wrap: balance; }
.offer-strip .sub { color: var(--muted); margin-bottom: 28px; }
.lead-form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; text-align: left; }
.lead-form .full { grid-column: 1 / -1; }
.lead-form input, .lead-form select {
  width: 100%; background: var(--obsidian); border: 1px solid var(--hairline);
  color: var(--ivory); font: inherit; padding: 14px 16px;
}
.lead-form input::placeholder { color: var(--muted); }
.lead-form input:focus, .lead-form select:focus { outline: 1px solid var(--gold); border-color: var(--gold-deep); }
.lead-form .consent { display: flex; gap: 10px; align-items: flex-start; color: var(--muted); font-size: 13.5px; }
.lead-form .consent input { width: auto; margin-top: 3px; accent-color: var(--gold); }
.lead-form .btn { width: 100%; }
@media (max-width: 560px) { .lead-form { grid-template-columns: 1fr; } .lead-form input, .lead-form select { grid-column: 1 / -1; } }

/* hero */
.hero-band { padding: 96px 0 72px; text-align: center; position: relative; }
.hero-band::before {
  content: ""; position: absolute; inset: -10% 0 0;
  background:
    radial-gradient(closest-side at center 45%, transparent 40%, var(--obsidian) 96%) center top/min(900px, 100%) no-repeat,
    url('img/hero-vignette.webp') center top/min(900px, 100%) no-repeat;
  opacity: .55; pointer-events: none; z-index: -1;
}
.hero-band .coin-stage { margin: 0 auto 40px; }
.hero-band h1 { font-size: clamp(40px, 5.6vw, 66px); line-height: 1.06; text-wrap: balance; max-width: 20ch; margin: 0 auto 22px; }
.hero-band h1 em { font-style: normal; color: var(--gold-light); }
.hero-band .lede { color: var(--muted); font-size: 19px; max-width: 56ch; margin: 0 auto 38px; }
.hero-band .cta-row { display: flex; gap: 18px; justify-content: center; flex-wrap: wrap; }

/* why us split */
.split { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; padding: 88px 0; }
.split .media {
  aspect-ratio: 4/5; background: radial-gradient(ellipse at 30% 20%, #241D0E, var(--charcoal) 70%);
  border: 1px solid var(--hairline); display: grid; place-items: center;
}
.split .media .placeholder { color: var(--gold-deep); font-size: 13px; letter-spacing: .2em; text-transform: uppercase; }
.split h2 { font-size: clamp(28px, 3.6vw, 40px); margin-bottom: 18px; text-wrap: balance; }
.split p { color: var(--muted); margin-bottom: 16px; }
@media (max-width: 860px) { .split { grid-template-columns: 1fr; } }

/* consultation card */
.consult-card {
  max-width: 620px; margin: 0 auto; text-align: center;
  background: var(--charcoal); border: 1px solid var(--gold-deep);
  padding: 52px 44px;
}
.consult-card h2 { font-size: 30px; margin-bottom: 8px; }
.consult-card .sub { color: var(--muted); margin-bottom: 26px; }
.consult-card ul { list-style: none; padding: 0; margin: 0 0 30px; text-align: left; display: flex; flex-direction: column; gap: 12px; }
.consult-card ul li { display: flex; gap: 12px; color: var(--ivory); }
.consult-card ul li svg { width: 20px; height: 20px; color: var(--gold); flex: none; margin-top: 3px; }
.consult-card .reassure { color: var(--muted); font-size: 14.5px; margin-top: 16px; }

/* cta band */
.cta-band {
  background:
    linear-gradient(120deg, rgba(20,16,6,.86), rgba(11,10,8,.92)),
    url('img/cta-texture.webp') center/cover no-repeat var(--charcoal);
  border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline);
  padding: 64px 0; text-align: center;
}
.cta-band h2 { font-size: clamp(26px, 3.4vw, 36px); margin-bottom: 22px; text-wrap: balance; }
.cta-band .secondary { display: table; margin: 18px auto 0; }

/* media / video shell + embeds */
.media-shell {
  aspect-ratio: 16/9; max-width: 860px; margin: 0 auto;
  background: radial-gradient(ellipse at center, #1C160A, var(--obsidian) 75%);
  border: 1px solid var(--hairline);
  display: grid; place-items: center; position: relative;
}
.media-shell .play {
  width: 74px; height: 74px; border-radius: 50%; border: 1px solid var(--gold);
  display: grid; place-items: center; color: var(--gold);
}
.media-shell .note { position: absolute; bottom: 16px; color: var(--gold-deep); font-size: 12px; letter-spacing: .18em; text-transform: uppercase; }
.embed-shell {
  min-height: 560px; background: var(--charcoal); border: 1px solid var(--hairline);
  display: grid; place-items: center; color: var(--gold-deep);
  font-size: 13px; letter-spacing: .2em; text-transform: uppercase;
}

/* proof strip (contact) */
.proof-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.proof-strip .tile {
  aspect-ratio: 1; background: linear-gradient(160deg, var(--charcoal), #1A1507);
  border: 1px solid var(--hairline); display: grid; place-items: center;
  color: var(--gold-deep); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; text-align: center; padding: 12px;
}
@media (max-width: 700px) { .proof-strip { grid-template-columns: repeat(2, 1fr); } }

/* NAP block */
.nap { display: flex; flex-direction: column; gap: 14px; max-width: 480px; margin: 0 auto; }
.nap .contact-line { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 16px; }
.nap .contact-line svg { width: 19px; height: 19px; color: var(--gold); flex: none; }
.nap .contact-line a { color: var(--ivory); text-decoration: none; }
.nap .contact-line a:hover { color: var(--gold-light); }

/* section rhythm + reveal */
.section { padding: 88px 0; }
.section-tight { padding: 64px 0; }
.center { text-align: center; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ============ WAVE 2 (TRUST) PATTERNS ============ */

/* category / stat tiles */
.tile-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 22px; }
.cat-card {
  background: var(--charcoal); border: 1px solid var(--hairline); padding: 34px 30px;
}
.cat-card .icon { width: 42px; height: 42px; color: var(--gold); margin-bottom: 16px; }
.cat-card .icon svg { width: 100%; height: 100%; }
.cat-card h3 { font-size: 21px; margin-bottom: 8px; }
.cat-card p { color: var(--muted); font-size: 15.5px; }
.stat-tile {
  background: var(--charcoal); border: 1px solid var(--hairline);
  padding: 34px 26px; text-align: center;
}
.stat-tile .num {
  font-family: 'PK Display', Georgia, serif; font-size: 40px; color: var(--gold-light);
  font-variant-numeric: tabular-nums; line-height: 1.1;
}
.stat-tile .lbl { color: var(--muted); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; margin-top: 8px; }
.stat-tile.pending .num { color: var(--gold-deep); font-size: 17px; letter-spacing: .16em; text-transform: uppercase; padding: 12px 0; }

/* proof teaser grid (results/testimonials shells) */
.teaser-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; }
.teaser-grid .tile {
  aspect-ratio: 1; background: linear-gradient(160deg, var(--charcoal), #1A1507);
  border: 1px solid var(--hairline); display: grid; place-items: center; text-align: center;
  color: var(--gold-deep); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; padding: 12px;
}

/* client dossier cards (redacted shells until consent) */
.dossier {
  background: var(--charcoal); border: 1px solid var(--hairline);
  display: grid; grid-template-columns: 300px 1fr; gap: 0; overflow: hidden;
}
.dossier + .dossier { margin-top: 22px; }
.dossier .gallery {
  background: repeating-linear-gradient(45deg, #17130B, #17130B 14px, #141109 14px, #141109 28px);
  border-right: 1px solid var(--hairline);
  display: grid; place-items: center; min-height: 220px;
  color: var(--gold-deep); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; text-align: center; padding: 16px;
}
.dossier .body { padding: 30px 32px; }
.dossier h3 { font-size: 20px; margin-bottom: 8px; }
.dossier p { color: var(--muted); font-size: 15.5px; }
.dossier .consent-note { color: var(--gold-deep); font-size: 12.5px; letter-spacing: .1em; text-transform: uppercase; margin-top: 14px; }
@media (max-width: 760px) { .dossier { grid-template-columns: 1fr; } .dossier .gallery { border-right: none; border-bottom: 1px solid var(--hairline); } }

/* founder hero (about) */
.founder-hero { display: grid; grid-template-columns: .9fr 1.1fr; gap: 56px; align-items: center; padding: 88px 0 64px; }
.founder-hero .portrait {
  aspect-ratio: 4/5; background: radial-gradient(ellipse at 35% 25%, #26200F, var(--charcoal) 72%);
  border: 1px solid var(--hairline); display: grid; place-items: center;
  color: var(--gold-deep); font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
}
@media (max-width: 860px) { .founder-hero { grid-template-columns: 1fr; } }

/* ============ WAVE 3 (AUTHORITY) PATTERNS ============ */

/* accordion */
.accordion { border-top: 1px solid var(--hairline); }
.accordion details { border-bottom: 1px solid var(--hairline); }
.accordion summary {
  cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 20px;
  padding: 22px 6px; font-family: 'PK Display', Georgia, serif; font-size: 19px; color: var(--ivory);
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after { content: "+"; color: var(--gold); font-family: 'PK Sans', sans-serif; font-size: 22px; flex: none; }
.accordion details[open] summary::after { content: "\2212"; }
.accordion .a-body { padding: 0 6px 24px; color: var(--muted); max-width: 74ch; }
.accordion .a-body p { margin-bottom: 12px; }
.accordion .a-body p:last-child { margin-bottom: 0; }
.accordion .nudge { color: var(--gold); font-size: 14.5px; }

/* definition grid */
.def-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 16px; }
.def-box { background: var(--charcoal); border: 1px solid var(--hairline); padding: 22px 20px; }
.def-box h3 { font-size: 17.5px; margin-bottom: 6px; color: var(--gold-light); }
.def-box p { color: var(--muted); font-size: 14.5px; }

/* callout */
.callout { background: var(--charcoal); border-left: 3px solid var(--gold); padding: 24px 28px; max-width: 78ch; }
.callout.warn { border-left-color: var(--gold-deep); }
.callout h3 { font-size: 19px; margin-bottom: 8px; }
.callout p { color: var(--muted); font-size: 15.5px; }
.counsel-banner {
  background: #1A1507; border: 1px solid var(--gold-deep); padding: 14px 20px;
  color: var(--gold-light); font-size: 14px; letter-spacing: .06em;
}

/* progression ladder */
.ladder { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--hairline); }
.ladder .step { padding: 30px 26px; border-right: 1px solid var(--hairline); background: var(--charcoal); position: relative; }
.ladder .step:last-child { border-right: none; }
.ladder .step .n { font-family: 'PK Display', Georgia, serif; color: var(--gold); font-size: 15px; letter-spacing: .2em; margin-bottom: 10px; }
.ladder .step h3 { font-size: 20px; margin-bottom: 8px; }
.ladder .step p { color: var(--muted); font-size: 14.5px; }
@media (max-width: 760px) { .ladder { grid-template-columns: 1fr; } .ladder .step { border-right: none; border-bottom: 1px solid var(--hairline); } .ladder .step:last-child { border-bottom: none; } }

/* calculators */
.calc { background: var(--charcoal); border: 1px solid var(--gold-deep); padding: 36px 34px; max-width: 640px; margin: 0 auto; }
.calc label { display: block; color: var(--muted); font-size: 13px; letter-spacing: .14em; text-transform: uppercase; margin: 18px 0 8px; }
.calc input { width: 100%; background: var(--obsidian); border: 1px solid var(--hairline); color: var(--ivory); font: inherit; padding: 13px 15px; font-variant-numeric: tabular-nums; }
.calc input:focus { outline: 1px solid var(--gold); }
.calc .result { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--hairline); }
.calc .result .big { font-family: 'PK Display', Georgia, serif; font-size: 42px; color: var(--gold-light); font-variant-numeric: tabular-nums; }
.calc .result .expl { color: var(--muted); font-size: 15px; margin-top: 6px; }

/* score-factor pie */
.pie-row { display: grid; grid-template-columns: 240px 1fr; gap: 40px; align-items: center; max-width: 760px; margin: 0 auto; }
.pie {
  width: 240px; height: 240px; border-radius: 50%;
  background: conic-gradient(#E8CD79 0 35%, #C9A227 35% 65%, #8A6E14 65% 80%, #5C4A0E 80% 90%, #3A2F0B 90% 100%);
  border: 1px solid var(--hairline);
}
.pie-legend { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.pie-legend li { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 15px; }
.pie-legend .dot { width: 14px; height: 14px; flex: none; }
.pie-legend .pct { color: var(--ivory); font-variant-numeric: tabular-nums; min-width: 42px; }
@media (max-width: 640px) { .pie-row { grid-template-columns: 1fr; justify-items: center; } }

/* simple data table */
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { text-align: left; padding: 14px 16px; border: 1px solid var(--hairline); font-size: 15px; }
.data-table th { color: var(--gold); font-family: 'PK Sans', sans-serif; font-weight: 500; font-size: 12.5px; letter-spacing: .16em; text-transform: uppercase; background: var(--charcoal); }
.data-table td { color: var(--muted); font-variant-numeric: tabular-nums; }
.table-scroll { overflow-x: auto; }
