/* ============================================================
   PARCELS TO WATERSHEDS — V2 / "Operator's Brief"
   Confident, deck-like, scannable. CEO voice explicit via
   sidebar callouts. White base + Rainplan blue, big Sora type.
   Page-scoped under .ptw2-* to avoid colliding with v1 and site.
   ============================================================ */

.ptw2 {
  --paper:       #FFFFFF;
  --canvas:     #FAFBFD;
  --gray-50:    #F5F6F8;
  --gray-100:   #ECEEF1;
  --gray-200:   #DDE1E6;
  --rule:       #E5E7EB;
  --ink:        #0B1F3A;
  --ink-soft:   #2C3E5C;
  --ink-mute:   #5B6B7F;
  --crossed:    #98A1AE;
  --water:      #1570EF;
  --water-deep: #0E4FA8;
  --water-soft: #E7F0FF;
  --water-tint: #F4F8FF;
  --moss:       #137D5E;
  --warn:       #C4632B;
  --greg-bg:    #FFF8E6;
  --greg-edge:  #E8B931;
  --display:    'Sora', system-ui, sans-serif;
  --body:       'DM Sans', system-ui, sans-serif;

  background: var(--paper);
  color: var(--ink);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

/* Default anchors carry no decoration — buttons, tiles and cards manage their own.
   Body-prose links opt into the underline via the .ptw2-link helper or by living
   inside a paragraph that explicitly enables it. */
.ptw2 a { color: var(--water-deep); text-decoration: none; }
.ptw2 a:hover { color: var(--water); }
.ptw2 .ptw2-link,
.ptw2 .ptw2-lede a,
.ptw2 .ptw2-problem__copy a,
.ptw2 .ptw2-answer__body a {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.ptw2 .site-header { background: var(--paper); border-bottom: 1px solid var(--gray-100); }

/* ----- Frame ----- */
.ptw2-section {
  padding: 6rem 2rem;
  position: relative;
}
.ptw2-wrap {
  max-width: 1180px;
  margin: 0 auto;
}

.ptw2-eyebrow {
  font-family: var(--body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--water);
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.ptw2-eyebrow::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 2px;
  background: var(--water);
}

.ptw2-h1 {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 1.25rem 0 1.5rem;
  text-wrap: balance;
}
.ptw2-h2 {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.6vw, 2.8rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 1rem 0 1rem;
  text-wrap: balance;
}
.ptw2-h2 .accent { color: var(--water); }
.ptw2-h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.2;
  color: var(--ink);
  margin: 0 0 0.75rem;
}

.ptw2-lede {
  font-family: var(--body);
  font-size: 1.18rem;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 38em;
}

.ptw2-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.7rem;
  border-radius: 6px;
  font-family: var(--body);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all 180ms ease;
  text-decoration: none !important;
}
.ptw2-btn--primary { background: var(--water); color: var(--paper); }
.ptw2-btn--primary:hover { background: var(--water-deep); color: var(--paper); text-decoration: none; }
.ptw2-btn--ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.ptw2-btn--ghost:hover { background: var(--ink); color: var(--paper); text-decoration: none; }

/* ============================================================
   HERO — Section 1
   ============================================================ */
.ptw2-hero {
  padding: 7rem 2rem 5rem;
  background:
    linear-gradient(180deg, var(--paper) 0%, var(--canvas) 100%);
  position: relative;
  overflow: hidden;
}
.ptw2-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.5;
  pointer-events: none;
}
.ptw2-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 4rem;
  align-items: center;
}
.ptw2-hero__ctas {
  display: flex;
  gap: 0.75rem;
  margin: 1.75rem 0 1.5rem;
  flex-wrap: wrap;
}
.ptw2-hero__byline {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-100);
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  font-size: 0.85rem;
  color: var(--ink-mute);
}

/* Hero diagram: 4-up reframing strip */
.ptw2-hero__art {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  position: relative;
}
.ptw2-tile {
  background: var(--paper);
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  padding: 1.25rem;
  position: relative;
  transition: all 200ms ease;
}
.ptw2-tile__num {
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  font-size: 0.95rem;
  margin-bottom: 0.5rem;
  letter-spacing: 0.05em;
}
.ptw2-tile__topic {
  font-family: var(--display);
  font-weight: 700;
  color: var(--ink);
  font-size: 1.05rem;
  margin-bottom: 0.5rem;
}
.ptw2-tile__hint {
  font-size: 0.85rem;
  color: var(--ink-mute);
  line-height: 1.4;
}
.ptw2-tile:hover { border-color: var(--water); transform: translateY(-2px); }

@media (max-width: 880px) {
  .ptw2-hero { padding: 4.5rem 1.5rem 3rem; }
  .ptw2-hero__inner { grid-template-columns: 1fr; gap: 2.5rem; }
}
@media (max-width: 480px) {
  .ptw2-hero__art { grid-template-columns: 1fr; }
}

/* ============================================================
   CEO MARGINALIA — used throughout
   ============================================================ */
.ptw2-greg {
  background: var(--greg-bg);
  border-left: 3px solid var(--greg-edge);
  border-radius: 4px;
  padding: 1.5rem 1.5rem 1.25rem;
  position: relative;
}
.ptw2-greg__label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 0.6rem;
}
.ptw2-greg__label::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--greg-bg);
  font-size: 0.7rem;
  font-weight: 800;
  text-align: center;
  line-height: 20px;
  font-family: var(--display);
  flex-shrink: 0;
}
.ptw2-greg__body {
  font-family: var(--body);
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--ink);
}
.ptw2-greg__body em { font-style: italic; color: var(--ink); font-weight: 600; }
.ptw2-greg__attr {
  margin-top: 0.75rem;
  font-family: var(--body);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  color: var(--ink-mute);
}
.ptw2-greg__attr strong { color: var(--ink); font-weight: 700; }

/* Inline Greg variant — for hero (uses initial inside the marker) */
.ptw2-greg--hero .ptw2-greg__label::before { content: 'GC'; line-height: 20px; }
.ptw2-greg--reframe .ptw2-greg__label::before { content: 'GC'; line-height: 20px; }

/* ============================================================
   STRUCTURAL PROBLEM — Section 2
   ============================================================ */
.ptw2-problem { background: var(--canvas); border-top: 1px solid var(--gray-100); border-bottom: 1px solid var(--gray-100); }
.ptw2-problem__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 4rem;
  align-items: start;
  margin-top: 3rem;
}
.ptw2-problem__copy p {
  color: var(--ink-soft);
  font-size: 1.02rem;
  line-height: 1.65;
  margin-bottom: 1.1rem;
}
.ptw2-problem__copy strong { color: var(--ink); font-weight: 700; }
.ptw2-comparison {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
.ptw2-comp {
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  padding: 1.5rem 1.5rem;
  background: var(--paper);
}
.ptw2-comp__label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 0.5rem;
}
.ptw2-comp--current { border-left: 3px solid var(--crossed); background: var(--gray-50); }
.ptw2-comp--current .ptw2-comp__title { color: var(--ink-mute); }
.ptw2-comp--future { border-left: 3px solid var(--water); background: var(--water-tint); }
.ptw2-comp--future .ptw2-comp__title { color: var(--water-deep); }
.ptw2-comp__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}
.ptw2-comp__body { font-size: 0.95rem; color: var(--ink-soft); line-height: 1.5; }

@media (max-width: 880px) {
  .ptw2-problem { padding: 4rem 1.5rem; }
  .ptw2-problem__grid { grid-template-columns: 1fr; gap: 2.5rem; }
}

/* ============================================================
   REFRAMINGS — Sections 3–6 (deck-style)
   The signature: muted "assumed barriers" card grid on the left,
   single highlighted "real answer" card on the right, big tagline
   below, Greg marginalia on the side.
   ============================================================ */
.ptw2-reframe {
  border-top: 1px solid var(--gray-100);
  padding: 6rem 2rem;
  background: var(--paper);
}
.ptw2-reframe--shaded { background: var(--canvas); }
.ptw2-reframe__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem 3rem;
  align-items: end;
  margin-bottom: 2.5rem;
}
.ptw2-reframe__chapter {
  font-family: var(--display);
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--water);
  margin-bottom: 0.5rem;
}
.ptw2-reframe__num {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(3.5rem, 8vw, 6rem);
  line-height: 0.9;
  color: var(--ink);
  letter-spacing: -0.05em;
  opacity: 0.92;
}
.ptw2-reframe__num span {
  color: var(--water);
}
.ptw2-reframe__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
  text-align: left;
  text-wrap: balance;
  padding-bottom: 0.5rem;
}

.ptw2-reframe__body {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 2.5rem;
  align-items: stretch;
}

/* LEFT — assumed barriers card grid */
.ptw2-assumed {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ptw2-assumed__label {
  font-family: var(--body);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 1rem;
}
.ptw2-assumed__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  flex: 1;
}
.ptw2-card {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  padding: 1.2rem 1.25rem;
  position: relative;
  transition: opacity 300ms ease;
}
.ptw2-card__heading {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--ink);
  margin-bottom: 0.4rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.ptw2-card__heading::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--crossed);
  display: inline-block;
}
.ptw2-card__copy {
  font-size: 0.88rem;
  color: var(--ink-mute);
  line-height: 1.5;
}
.ptw2-card--crossed .ptw2-card__heading {
  color: var(--crossed);
  text-decoration: line-through;
  text-decoration-color: var(--crossed);
  text-decoration-thickness: 0;
  text-underline-offset: 0;
  animation: ptw2-strike 500ms forwards;
}
.ptw2-card--crossed:nth-child(1) .ptw2-card__heading { animation-delay: 0.05s; }
.ptw2-card--crossed:nth-child(2) .ptw2-card__heading { animation-delay: 0.25s; }
.ptw2-card--crossed:nth-child(3) .ptw2-card__heading { animation-delay: 0.45s; }
.ptw2-card--crossed:nth-child(4) .ptw2-card__heading { animation-delay: 0.65s; }
@keyframes ptw2-strike { to { text-decoration-thickness: 2px; } }

/* RIGHT — real answer */
.ptw2-answer {
  background: linear-gradient(165deg, var(--water-tint) 0%, var(--water-soft) 100%);
  border: 1px solid var(--water);
  border-radius: 12px;
  padding: 2.25rem 2rem 2rem;
  display: flex;
  flex-direction: column;
  position: relative;
}
.ptw2-answer__label {
  font-family: var(--body);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--water);
  margin-bottom: 1rem;
}
.ptw2-answer__heading {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 1rem;
  letter-spacing: -0.02em;
}
.ptw2-answer__body {
  font-size: 1rem;
  line-height: 1.55;
  color: var(--ink-soft);
}
.ptw2-answer__body strong { color: var(--ink); font-weight: 700; }

/* Tagline under the reframing */
.ptw2-reframe__tagline {
  margin-top: 2.5rem;
  padding: 1.75rem 2rem;
  background: var(--ink);
  color: var(--paper);
  border-radius: 8px;
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(1.1rem, 1.8vw, 1.45rem);
  line-height: 1.25;
  letter-spacing: -0.005em;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.ptw2-reframe__tagline::before {
  content: '→';
  color: var(--water);
  font-weight: 800;
  font-size: 1.5em;
  flex-shrink: 0;
}

/* Greg marginalia inside the reframing */
.ptw2-reframe__greg {
  margin-top: 1.75rem;
  max-width: 720px;
}

@media (max-width: 880px) {
  .ptw2-reframe { padding: 4rem 1.5rem; }
  .ptw2-reframe__body { grid-template-columns: 1fr; gap: 1.5rem; }
  .ptw2-assumed__cards { grid-template-columns: 1fr 1fr; }
  .ptw2-reframe__head { grid-template-columns: 1fr; }
  .ptw2-reframe__title { text-align: left; padding-bottom: 0; }
}
@media (max-width: 480px) {
  .ptw2-assumed__cards { grid-template-columns: 1fr; }
}

/* ============================================================
   ENGINES — Section 7
   ============================================================ */
.ptw2-engines {
  background: var(--ink);
  color: var(--paper);
  padding: 6rem 2rem;
  position: relative;
  overflow: hidden;
}
.ptw2-engines__head { max-width: 760px; margin: 0 auto 3rem; text-align: center; }
.ptw2-engines__head .ptw2-eyebrow { color: rgba(125, 182, 255, 0.95); }
.ptw2-engines__head .ptw2-eyebrow::before { background: rgba(125, 182, 255, 0.95); }
.ptw2-engines__head .ptw2-h2 { color: var(--paper); margin-top: 1rem; }
.ptw2-engines__head .ptw2-h2 .accent { color: #7DB6FF; }
.ptw2-engines__head p { color: rgba(250, 250, 250, 0.78); font-size: 1.05rem; max-width: 38em; margin: 0 auto; }

.ptw2-engines__pair {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0;
  align-items: stretch;
  max-width: 1080px;
  margin: 0 auto;
}
.ptw2-engine {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  padding: 2.25rem;
}
.ptw2-engine__tag {
  display: inline-block;
  font-family: var(--body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(250, 250, 250, 0.6);
  margin-bottom: 0.7rem;
}
.ptw2-engine__name {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.7rem;
  margin-bottom: 0.4rem;
  letter-spacing: -0.015em;
}
.ptw2-engine--pipe .ptw2-engine__name { color: #7DB6FF; }
.ptw2-engine--exec .ptw2-engine__name { color: var(--paper); }
.ptw2-engine__owner {
  font-size: 0.85rem;
  color: rgba(250, 250, 250, 0.62);
  margin-bottom: 1.75rem;
}
.ptw2-engine__steps { list-style: none; padding: 0; margin: 0; }
.ptw2-engine__steps li {
  padding: 0.85rem 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.1);
  font-size: 0.95rem;
  color: rgba(250, 250, 250, 0.92);
  display: flex;
  gap: 0.85rem;
}
.ptw2-engine__steps li:last-child { border-bottom: none; }
.ptw2-engine__steps strong {
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  min-width: 1.25em;
}
.ptw2-engine--exec .ptw2-engine__steps strong { color: #7DD8A7; }

.ptw2-engines__bridge {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1.25rem;
}
.ptw2-engines__bridge-icon {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: var(--paper);
  color: var(--ink);
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.4rem;
}

.ptw2-engines__statbands {
  margin-top: 3rem;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  gap: 2rem;
}
.ptw2-statband__label {
  font-family: var(--body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(250, 250, 250, 0.55);
  margin-bottom: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding-top: 1rem;
}
.ptw2-statband__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.ptw2-stat {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.03);
  padding: 1.25rem 1.25rem;
  border-radius: 6px;
}
.ptw2-stat__num {
  font-family: var(--display);
  font-weight: 800;
  font-size: 2.2rem;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--paper);
  margin-bottom: 0.4rem;
}
.ptw2-stat--pipe .ptw2-stat__num { color: #7DB6FF; }
.ptw2-stat__label { font-size: 0.78rem; color: rgba(250, 250, 250, 0.65); line-height: 1.35; }

.ptw2-engines__source {
  margin-top: 1.5rem;
  text-align: center;
  font-size: 0.78rem;
  color: rgba(250, 250, 250, 0.45);
  letter-spacing: 0.05em;
}
.ptw2-engines__close {
  margin-top: 3rem;
  text-align: center;
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.3rem;
  color: var(--paper);
  max-width: 40em;
  margin-left: auto;
  margin-right: auto;
  letter-spacing: -0.005em;
  line-height: 1.3;
}

@media (max-width: 880px) {
  .ptw2-engines { padding: 4rem 1.5rem; }
  .ptw2-engines__pair { grid-template-columns: 1fr; }
  .ptw2-engines__bridge { padding: 0.5rem 0; transform: rotate(90deg); }
  .ptw2-statband__row { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   CASCADE — Section 8
   ============================================================ */
.ptw2-cascade { background: var(--paper); padding: 6rem 2rem; border-top: 1px solid var(--gray-100); }
.ptw2-cascade__head { max-width: 760px; margin: 0 auto 3rem; }
.ptw2-cascade__head .ptw2-h2 { margin-top: 1rem; }
.ptw2-cascade__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: 1180px;
  margin: 0 auto;
}
.ptw2-cstep {
  background: var(--canvas);
  border: 1px solid var(--gray-200);
  border-radius: 10px;
  padding: 2rem 1.75rem 1.75rem;
  position: relative;
}
.ptw2-cstep__num {
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  margin-bottom: 1.25rem;
}
.ptw2-cstep__art {
  width: 84px;
  height: 84px;
  margin-bottom: 1.25rem;
}
.ptw2-cstep__art svg { width: 100%; height: 100%; }
.ptw2-cstep__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--ink);
  margin-bottom: 0.6rem;
  letter-spacing: -0.015em;
}
.ptw2-cstep__body { color: var(--ink-soft); font-size: 0.95rem; line-height: 1.55; }
.ptw2-cstep__stat {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--gray-200);
  display: flex;
  gap: 0.6rem;
  align-items: baseline;
}
.ptw2-cstep__stat-num {
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  font-size: 1.4rem;
  letter-spacing: -0.01em;
}
.ptw2-cstep__stat-label { font-size: 0.82rem; color: var(--ink-mute); }

@media (max-width: 768px) {
  .ptw2-cascade { padding: 4rem 1.5rem; }
  .ptw2-cascade__steps { grid-template-columns: 1fr; }
}

/* ============================================================
   WHY NOW — Section 9
   ============================================================ */
.ptw2-now { background: var(--canvas); padding: 6rem 2rem; border-top: 1px solid var(--gray-100); }
.ptw2-now__head { max-width: 760px; margin: 0 auto 3rem; }
.ptw2-now__head .ptw2-h2 { margin-top: 1rem; }
.ptw2-forces {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
.ptw2-force {
  background: var(--paper);
  border: 1px solid var(--gray-200);
  border-left: 4px solid var(--water);
  border-radius: 8px;
  padding: 1.75rem;
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 1.25rem;
  align-items: start;
}
.ptw2-force__chip {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: var(--water-tint);
  color: var(--water);
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
}
.ptw2-force__chip--pair {
  font-size: 0.95rem;
  letter-spacing: 0.04em;
}
.ptw2-force__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--ink);
  margin-bottom: 0.5rem;
  letter-spacing: -0.015em;
}
.ptw2-force__body { font-size: 0.92rem; color: var(--ink-soft); line-height: 1.5; }

@media (max-width: 768px) {
  .ptw2-now { padding: 4rem 1.5rem; }
  .ptw2-forces { grid-template-columns: 1fr; }
}

/* ============================================================
   LOCAL / EQUITY BEAT — Section 8.5
   ============================================================ */
.ptw2-local {
  background: var(--paper);
  padding: 6rem 2rem;
  border-top: 1px solid var(--gray-100);
}
.ptw2-local__head { max-width: 760px; margin: 0 auto 3rem; }
.ptw2-local__head .ptw2-h2 { margin-top: 1rem; }
.ptw2-local__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  max-width: 1080px;
  margin: 0 auto;
}
.ptw2-local-card {
  background: var(--canvas);
  border: 1px solid var(--gray-200);
  border-left: 4px solid var(--moss);
  border-radius: 8px;
  padding: 1.75rem;
}
.ptw2-local-card__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--ink);
  margin-bottom: 0.6rem;
  letter-spacing: -0.01em;
}
.ptw2-local-card__body {
  font-size: 0.95rem;
  color: var(--ink-soft);
  line-height: 1.55;
}
@media (max-width: 768px) {
  .ptw2-local { padding: 4rem 1.5rem; }
  .ptw2-local__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   CLOSING POSITION — Section 10 (company voice)
   ============================================================ */
.ptw2-close {
  background: var(--canvas);
  padding: 6rem 2rem;
  border-top: 1px solid var(--gray-100);
}
.ptw2-close__inner {
  max-width: 820px;
  margin: 0 auto;
}
.ptw2-close__inner .ptw2-h2 {
  margin: 1rem 0 2rem;
}
.ptw2-close__list {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: grid;
  gap: 0;
  counter-reset: close-item;
}
.ptw2-close__list li {
  counter-increment: close-item;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 1rem;
  align-items: baseline;
  padding: 1.25rem 0;
  border-bottom: 1px solid var(--gray-200);
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.ptw2-close__list li:last-child { border-bottom: none; }
.ptw2-close__list li::before {
  content: counter(close-item, decimal-leading-zero);
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  font-size: 1.4rem;
}
.ptw2-close__body {
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 2.5rem;
}
.ptw2-close__statement {
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(1.3rem, 2.6vw, 1.7rem);
  line-height: 1.25;
  color: var(--ink);
  padding: 1.75rem 0 0;
  border-top: 2px solid var(--ink);
  letter-spacing: -0.015em;
  margin-bottom: 3rem;
}
.ptw2-close__cta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media (max-width: 768px) {
  .ptw2-close { padding: 4rem 1.5rem; }
  .ptw2-close__cta { grid-template-columns: 1fr; }
  .ptw2-close__list li { grid-template-columns: 44px 1fr; font-size: 1.05rem; }
}

/* ============================================================
   CEO LETTER — Section 10 (closing)
   Direct CEO address, then CTAs.
   ============================================================ */
.ptw2-letter { background: var(--paper); padding: 6rem 2rem; border-top: 1px solid var(--gray-100); }
.ptw2-letter__inner {
  max-width: 820px;
  margin: 0 auto;
}
.ptw2-letter__head {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.ptw2-letter__avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  display: grid;
  place-items: center;
  font-family: var(--display);
  font-weight: 800;
  font-size: 1.4rem;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}
.ptw2-letter__meta {
  display: flex;
  flex-direction: column;
}
.ptw2-letter__meta-name {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--ink);
}
.ptw2-letter__meta-context {
  font-family: var(--body);
  font-size: 0.85rem;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
}
.ptw2-letter__body {
  font-size: 1.08rem;
  line-height: 1.6;
  color: var(--ink);
}
.ptw2-letter__body p { margin-bottom: 1.15rem; }
.ptw2-letter__body p:last-child { margin-bottom: 0; }
.ptw2-letter__body strong { font-weight: 700; }
.ptw2-letter__body em { font-style: italic; }
.ptw2-letter__list {
  list-style: none;
  padding: 0;
  margin: 1.25rem 0 1.5rem;
  display: grid;
  gap: 0.85rem;
}
.ptw2-letter__list li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 0.85rem;
  align-items: baseline;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--gray-100);
  font-size: 1.02rem;
}
.ptw2-letter__list li::before {
  content: counter(letter-item, decimal-leading-zero);
  counter-increment: letter-item;
  font-family: var(--display);
  font-weight: 800;
  color: var(--water);
  font-size: 1.1rem;
}
.ptw2-letter__list { counter-reset: letter-item; }
.ptw2-letter__signoff {
  margin-top: 1.5rem;
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--ink);
}

.ptw2-letter__cta {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.ptw2-path {
  padding: 1.5rem 1.5rem;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  text-decoration: none;
  display: block;
  background: var(--paper);
  transition: all 180ms ease;
  cursor: pointer;
}
.ptw2-path:hover {
  border-color: var(--water);
  text-decoration: none;
  background: var(--water-tint);
  transform: translateY(-2px);
}
.ptw2-path__label {
  font-family: var(--body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--water);
  margin-bottom: 0.6rem;
}
.ptw2-path__title {
  font-family: var(--display);
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--ink);
  margin-bottom: 0.35rem;
}
.ptw2-path__body { font-size: 0.88rem; color: var(--ink-soft); line-height: 1.5; }

@media (max-width: 760px) {
  .ptw2-letter { padding: 4rem 1.25rem; }
  .ptw2-letter__cta { grid-template-columns: 1fr; }
}

/* Scroll progress bar */
.ptw2-thread {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: var(--water);
  z-index: 100;
  transition: width 80ms linear;
}
