/* ==========================================================================
   components.css
   Brand mark, nav, footer, signage chrome, primitives reused across pages.
   ========================================================================== */


/* ==========================================================================
   § 01 — Brand mark (flower)
   PNG mask repainted by --flower-ink (the monogram is the only branded mark).
   ========================================================================== */
.flower{
  display: inline-block;
  width: 32px; height: 32px;
  vertical-align: middle;
  background-color: var(--flower-ink);
  -webkit-mask: url('/static/img/logo-alpha.png') center / contain no-repeat;
          mask: url('/static/img/logo-alpha.png') center / contain no-repeat;
}
.flower.sm { width: 18px; height: 18px; }
.flower.md { width: 26px; height: 26px; }
.flower.lg { width: 56px; height: 56px; }
.flower.xl { width: 96px; height: 96px; }
.flower.ornament,
.flower.divider{ background-color: var(--flower-divider-ink); }


/* ==========================================================================
   § 02 — Nav (header.site)
   Wide, low, hairline edge, monogram + wordmark left, links right.
   ========================================================================== */
header.site{
  position: sticky; top: 0; z-index: 50;
  background: var(--topbar);
  border-bottom: 1px solid var(--rule);
}
header.site .inner{
  max-width: var(--max);
  margin: 0 auto;
  height: 72px;
  padding: 0 var(--gutter);
  display: flex; align-items: center; gap: 36px;
}

header.site .brand{
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--ink-deep);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.35rem;
  letter-spacing: -0.012em;
  text-transform: lowercase;
  border-bottom: 0;
}
header.site .brand:hover{ color: var(--ink-deep); border-bottom: 0; }
header.site .brand .flower{ background-color: var(--ink-deep); }

header.site nav.primary{
  display: flex; align-items: center; gap: 4px;
  margin-left: auto;
}
header.site nav.primary > a{
  position: relative;
  padding: 8px 14px;
  color: var(--ink-dim);
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.86rem;
  letter-spacing: 0;
  border-bottom: 0;
}
header.site nav.primary > a::after{
  content: ""; position: absolute;
  left: 14px; right: 14px; bottom: 4px; height: 1px;
  background: currentColor;
  transform: scaleX(0); transform-origin: left;
  transition: transform .22s cubic-bezier(.22,1,.36,1);
}
header.site nav.primary > a:hover{ color: var(--ink-deep); }
header.site nav.primary > a:hover::after{ transform: scaleX(1); }
header.site nav.primary > a.active{ color: var(--ink-deep); }
header.site nav.primary > a.active::after{ transform: scaleX(1); background: var(--signal); }

header.site .nav-cta-wrap{
  display: inline-flex; align-items: center; gap: 12px;
  padding-left: 20px; margin-left: 4px;
  border-left: 1px solid var(--rule);
}

/* Burger / mobile */
header.site .nav-toggle{ display: none; }
header.site .nav-burger{
  display: none;
  margin-left: auto;
  width: 44px; height: 44px;
  color: var(--ink-deep);
  border: 1px solid var(--ink-deep);
  align-items: center; justify-content: center;
  background: var(--paper);
  cursor: pointer;
}
header.site .nav-toggle:focus-visible ~ .nav-burger{
  outline: 2px solid var(--signal);
  outline-offset: 3px;
}
header.site .nav-burger .bars,
header.site .nav-burger .close{ width: 20px; height: 20px; }
header.site .nav-burger .close{ display: none; }
header.site .mobile-cta-wrap{ display: none; }

@media (max-width: 920px){
  header.site .inner{ height: 64px; }
  header.site nav.primary{
    position: fixed; inset: 64px 0 0 0;
    z-index: 70;
    background: var(--paper);
    border-top: 1px solid var(--rule);
    flex-direction: column; align-items: stretch; gap: 0;
    padding: 24px var(--gutter) calc(24px + var(--safe-bottom));
    overflow-y: auto;
    overscroll-behavior: contain;
    transform: translateX(100%);
    transition: transform .26s cubic-bezier(.22,1,.36,1);
  }
  header.site nav.primary > a{
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 500;
    color: var(--ink-deep);
    padding: 16px 0;
    border-bottom: 1px solid var(--rule);
  }
  header.site nav.primary > a::after{ display: none; }
  header.site .nav-burger{ display: inline-flex; }
  header.site .nav-cta-wrap{ display: none; }
  header.site .mobile-cta-wrap{ display: block; margin-top: 32px; }
  header.site .mobile-cta-wrap .btn{ width: 100%; height: 56px; }
  header.site .nav-toggle:checked ~ nav.primary{ transform: translateX(0); }
  header.site .nav-toggle:checked ~ .nav-burger .bars{ display: none; }
  header.site .nav-toggle:checked ~ .nav-burger .close{ display: block; }
}


/* ==========================================================================
   § 03 — Footer
   Asymmetric masthead block. Oversized colophon. Hairline rules.
   ========================================================================== */
footer.site{
  background: var(--paper);
  border-top: 1px solid var(--ink-deep);
  margin-top: 0;
}
footer.site .inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 80px var(--gutter) 56px;
}
footer.site .footer-grid{
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 48px;
  padding-bottom: 64px;
  border-bottom: 1px solid var(--rule);
}
@media (max-width: 1080px){
  footer.site .footer-grid{ grid-template-columns: repeat(3, 1fr); gap: 36px; }
  footer.site .footer-brand{ grid-column: 1 / -1; }
}
@media (max-width: 680px){
  footer.site .footer-grid{ grid-template-columns: 1fr 1fr; gap: 28px; }
}

footer.site .footer-brand .brand{
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: -0.012em;
  color: var(--ink-deep);
  text-transform: lowercase;
  border-bottom: 0;
}
footer.site .footer-brand .brand .flower{ background-color: var(--ink-deep); }
footer.site .footer-brand p{
  margin-top: 18px; max-width: 28ch;
  color: var(--ink-dim);
  font-size: 0.92rem; line-height: 1.55;
}

footer.site .footer-col h4{
  color: var(--ink-faint);
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin: 0 0 18px;
}
footer.site .footer-col ul{ list-style: none; padding: 0; margin: 0; }
footer.site .footer-col li{ margin: 0; }
footer.site .footer-col a{
  display: inline-block; padding: 6px 0;
  color: var(--ink); font-size: 0.92rem; font-weight: 500;
  border-bottom: 0;
  transition: color .18s, transform .18s;
}
footer.site .footer-col a:hover{
  color: var(--signal);
  transform: translateX(3px);
}

footer.site .footer-ornament{ display: none; }

footer.site .footer-bottom{
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 16px; flex-wrap: wrap;
  padding-top: 36px;
  color: var(--ink-faint);
  font-size: 0.8rem; letter-spacing: 0.04em;
}


/* ==========================================================================
   § 04 — Sticky mobile CTA
   ========================================================================== */
.sticky-mobile-cta{
  position: fixed;
  left:   calc(16px + var(--safe-left));
  right:  calc(16px + var(--safe-right));
  bottom: calc(16px + var(--safe-bottom));
  z-index: 60;
  background: var(--ink-deep);
  border: 0;
  box-shadow: var(--shadow-lg);
  transform: translateY(calc(140% + var(--safe-bottom)));
  transition: transform .26s cubic-bezier(.22,1,.36,1);
  display: none;
}
.sticky-mobile-cta.visible{ transform: translateY(0); }
/* Yield to the open mobile menu — the panel is z:70, the sticky is z:60,
   but the panel doesn't paint over the sticky in iOS Safari reliably. */
body.nav-open .sticky-mobile-cta{
  transform: translateY(calc(140% + var(--safe-bottom)));
}
.sticky-mobile-cta .btn{ width: 100%; height: 56px; background: var(--ink-deep); color: var(--paper); }
.sticky-mobile-cta .btn:hover{ background: var(--signal); }
@media (max-width: 720px){ .sticky-mobile-cta{ display: block; } }
/* Reserve room at the bottom of the page so the sticky CTA doesn't
   eclipse footer / form-card content. Only applied when the CTA is showing. */
@media (max-width: 720px){
  body.has-sticky-cta{
    padding-bottom: calc(72px + var(--safe-bottom));
  }
}


/* ==========================================================================
   § 05 — Section primitives
   Numerals + label + hairline = section signpost.
   ========================================================================== */
.section{
  position: relative;
  padding: var(--section-y) 0;
  border-top: 1px solid var(--ink-deep);
}
.section:first-of-type,
.hero + .section{ border-top: 0; }
.section.soft{ background: var(--paper-2); }
.section.chapter{ /* spacing marker, kept for compat */ }

/* Section flip — was the cream/dark contrast in v1; in the signage register
   it inverts to a black block for occasional emphasis. Kept for compat only. */
.section-flip{
  background: var(--ink-deep);
  color: var(--paper);
  border-top: 0;
}
.section-flip h1, .section-flip h2, .section-flip h3, .section-flip h4{ color: var(--paper); }
.section-flip p, .section-flip li{ color: oklch(0.78 0.010 70); }
.section-flip strong{ color: var(--paper); }
.section-flip .section-rule{ color: oklch(0.62 0.010 70); border-color: oklch(0.30 0.010 70); }
.section-flip .section-num{ color: var(--paper); -webkit-text-stroke-color: oklch(0.32 0.010 70); }

/* The signage signpost — section number + label that anchors a section.
   Numeric stripe lives in the left rail; label sits beside it on a hairline. */
.signpost{
  display: grid;
  grid-template-columns: var(--rail) 1fr;
  align-items: baseline;
  gap: 32px;
  margin-bottom: clamp(40px, 5vw, 80px);
}
@media (max-width: 720px){
  .signpost{ grid-template-columns: 1fr; gap: 8px; }
}
.signpost .num{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  letter-spacing: -0.04em;
  color: var(--signal);
  line-height: 0.85;
  font-variant-numeric: tabular-nums;
}
@media (max-width: 720px){
  .signpost .num{ font-size: clamp(2rem, 8vw, 2.6rem); }
}
.signpost .label{
  font-family: var(--font-sans);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-deep);
  padding-bottom: 14px;
  /* The 1px underline is drawn by the .signpost .label::after rule in
     base.css so it can animate from scaleX(0) on scroll-reveal. */
}

/* Legacy alias kept so we don't break the inner pages.
   Re-styled as the same signpost language without the numeric. */
.section-rule{
  display: block;
  font-family: var(--font-sans);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-deep);
  padding-bottom: 16px;
  margin-bottom: 36px;
  border-bottom: 1px solid var(--ink-deep);
}

/* Section head (eyebrow + h2 + sub) — left-aligned, this register doesn't center */
.section-head{ max-width: 56rem; margin: 0 0 48px; }
.section-head.left{ text-align: left; margin: 0 0 48px; }
.section-head h2{ margin-bottom: 18px; }
.section-head p{
  font-size: 1.1rem; line-height: 1.5; color: var(--ink-dim);
  max-width: 56ch; margin: 0;
}


/* ==========================================================================
   § 06 — Hero terminal: live activity feed
   Light card on paper. Ink-deep border, hairline rules, outlined chips.
   Static body height; the feed anchors to the bottom and the oldest row
   clips off the top through an overflow-hidden viewport, never resizing
   the card itself.
   ========================================================================== */
.console-log{
  background: var(--paper);
  color: var(--ink-deep);
  border: 1px solid var(--ink-deep);
  font-family: var(--font-mono);
  overflow: hidden;
  position: relative;
}

/* Chrome bar — kept minimal: signal-red live dot + label + LIVE flag.
   The traffic-light dots from the old dark version are hidden via the
   .console-log .chrome .dot rule below; the markup stays for compat. */
.console-log .chrome{
  display: flex; align-items: center;
  gap: 12px;
  padding: 12px 18px;
  background: var(--paper-2);
  border-bottom: 1px solid var(--ink-deep);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  color: var(--ink-dim);
  text-transform: uppercase;
}
.console-log .chrome .dot{ display: none; }
.console-log .chrome .title{
  color: var(--ink-deep);
  letter-spacing: 0.08em;
}
.console-log .chrome .title::before{
  content: "";
  display: inline-block;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--signal);
  margin-right: 10px;
  vertical-align: 1px;
  box-shadow: 0 0 0 3px oklch(0.52 0.155 28 / 0.18);
  animation: pulse-dot 1.6s ease-in-out infinite;
}
.console-log .chrome .live{
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--signal);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  font-weight: 500;
}

/* Body is hard-fixed-height — the card never resizes regardless of feed
   activity. The feed clips at the top so retiring rows fade off-edge. */
.console-log .body{
  padding: 0;
  font-size: 0.86rem;
  position: relative;
  height: 360px;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.console-log .feed{
  display: flex; flex-direction: column;
  padding: 0;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  /* Soft fade at the top edge so retiring rows dissolve into the chrome */
  -webkit-mask-image: linear-gradient(to bottom,
                                      transparent 0,
                                      #000 28px,
                                      #000 100%);
          mask-image: linear-gradient(to bottom,
                                      transparent 0,
                                      #000 28px,
                                      #000 100%);
}
/* Rows animate their own height. Enter grows max-height 0→full and exit
   shrinks it back to 0. The two cancel exactly, so the total feed height
   is constant and the visible rows scroll up at the easing rate. */
.console-log .row{
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 0 20px;
  border-top: 1px solid var(--rule);
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  animation: feed-in .55s cubic-bezier(.22,1,.36,1) forwards;
  will-change: max-height, opacity, padding;
  flex: none;
}
.console-log .row:first-child{ border-top: 0; }
.console-log .row.is-leaving{
  animation: feed-out .32s cubic-bezier(.22,1,.36,1) forwards;
  pointer-events: none;
}
.console-log .row .time{
  color: var(--ink-faint);
  font-size: 0.78rem;
  font-variant-numeric: tabular-nums;
}
.console-log .row .app {
  color: var(--ink-deep);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.console-log .row .verdict{
  display: inline-flex; align-items: center;
  padding: 3px 9px;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid currentColor;
  white-space: nowrap;
  background: var(--paper);
}
.console-log .row .verdict.approved{ color: var(--good); }
.console-log .row .verdict.blocked { color: var(--signal); background: var(--signal-soft); }
.console-log .row .verdict.recalled{ color: var(--ink-faint); }
.console-log .row .verdict.review  { color: var(--warn); }

/* Sticky tail: prompt + cursor live below the feed, in the same paper. */
.console-log .feed-tail{
  display: flex; align-items: center;
  gap: 12px;
  padding: 12px 20px;
  color: var(--ink-dim);
  font-size: 0.78rem;
  border-top: 1px solid var(--ink-deep);
  background: var(--paper-2);
  flex: none;
}
.console-log .feed-tail .prompt{
  color: var(--signal); font-family: var(--font-mono); font-weight: 500;
}
.console-log .feed-tail .cursor{
  display: inline-block;
  width: 8px; height: 12px;
  background: var(--ink-deep);
  vertical-align: middle;
  animation: cursor-blink 1.1s steps(1) infinite;
}

/* Shared chrome dot styles for the OTHER terminals (runtime-event-card +
   shell-chrome) keep the dark traffic-light look. */
.runtime-event-card .chrome,
.shell-chrome{
  display: flex; align-items: center; gap: 8px;
  padding: 12px 18px;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
}
.shell-chrome{
  background: oklch(0.14 0.012 70);
  border-bottom: 1px solid oklch(0.28 0.010 70);
  color: oklch(0.72 0.010 70);
}
.runtime-event-card .chrome .dot,
.shell-chrome .dot{
  width: 8px; height: 8px;
  background: oklch(0.32 0.010 70);
  border-radius: 50%;
  flex: none;
}
.runtime-event-card .chrome .dot.r,
.shell-chrome .dot.r{ background: var(--signal); }
.runtime-event-card .chrome .dot.y,
.shell-chrome .dot.y{ background: var(--warn); }
.runtime-event-card .chrome .dot.g,
.shell-chrome .dot.g{ background: var(--good); }
.runtime-event-card .chrome .title{ margin-left: 10px; color: var(--ink-deep); }
.shell-chrome .title{ margin-left: 10px; color: var(--paper); }
.shell-chrome .session{
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 8px;
  color: oklch(0.62 0.010 70);
  font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
}
.console-log .feed-tail .prompt{ color: var(--signal-bright); font-family: var(--font-mono); }
.console-log .feed-tail .cursor{
  display: inline-block;
  width: 8px; height: 14px;
  background: var(--paper);
  vertical-align: middle;
  animation: cursor-blink 1.1s steps(1) infinite;
}

@keyframes feed-in{
  0%   { max-height: 0;    opacity: 0; padding-top: 0;     padding-bottom: 0;     border-top-color: transparent; }
  50%  { opacity: 1; }
  100% { max-height: 56px; opacity: 1; padding-top: 14px;  padding-bottom: 14px;  border-top-color: var(--rule); }
}
@keyframes feed-out{
  0%   { max-height: 56px; opacity: 1; padding-top: 14px;  padding-bottom: 14px;  border-top-color: var(--rule); }
  50%  { opacity: 0; }
  100% { max-height: 0;    opacity: 0; padding-top: 0;     padding-bottom: 0;     border-top-color: transparent; }
}

/* Seeded rows skip the entrance animation and sit in their final state. */
.console-log .row.is-seeded{
  animation: none;
  max-height: 56px;
  opacity: 1;
  padding: 14px 20px;
  border-top-color: var(--rule);
}
.console-log .row.is-seeded:first-child{ border-top-color: transparent; }

/* When a Blocked or Recalled event lands, briefly tint the row. */
.console-log .row.is-alert{
  animation: feed-in .55s cubic-bezier(.22,1,.36,1) forwards,
             alert-flash 1.6s cubic-bezier(.22,1,.36,1) .55s 1;
}
@keyframes alert-flash{
  0%   { background-color: var(--signal-soft); }
  100% { background-color: transparent; }
}
/* is-leaving must win, even on alert rows. Exit duration matches enter
   exactly so the height delta cancels and the box stays static. */
.console-log .row.is-leaving,
.console-log .row.is-alert.is-leaving{
  animation: feed-out .55s cubic-bezier(.22,1,.36,1) forwards;
}


/* ==========================================================================
   § 07 — Runtime event card (one event, big)
   Light surface, signage discipline, signal-color "Blocked" hero.
   ========================================================================== */
.runtime-event-card{
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink-deep);
  font-family: var(--font-mono);
  max-width: 580px; width: 100%;
  overflow: hidden;
}
.runtime-event-card .chrome{
  background: var(--paper);
  color: var(--ink-dim);
  border-bottom: 1px solid var(--ink-deep);
}
.runtime-event-card .chrome .title{ color: var(--ink-deep); }
.runtime-event-card .body{ padding: 28px 30px 28px; }
.runtime-event-card dl{
  display: grid; grid-template-columns: auto 1fr;
  column-gap: 20px; row-gap: 6px;
  margin: 0 0 22px;
  font-size: 0.86rem;
}
.runtime-event-card dt{
  color: var(--ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.7rem; padding-top: 4px;
}
.runtime-event-card dd{ margin: 0; color: var(--ink-deep); }
.runtime-event-card dd.reason{ color: var(--signal); }
.runtime-event-card .blocked-big{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.8rem, 5vw, 4.4rem);
  letter-spacing: -0.04em;
  line-height: 0.9;
  color: var(--signal);
  padding: 20px 0;
  border-top: 1px solid var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
  margin: 18px 0;
  text-transform: uppercase;
}
.runtime-event-card .action-row{
  display: flex; flex-wrap: wrap; gap: 8px;
  padding-top: 6px;
}
.runtime-event-card .action-row .pill{
  padding: 7px 12px;
  font-size: 0.72rem;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-deep);
  background: transparent;
  border: 1px solid var(--ink-deep);
}


/* ==========================================================================
   § 08 — Console shell (multi-pane product surface)
   ========================================================================== */
.console-shell{
  background: var(--ink-deep);
  color: var(--paper);
  font-family: var(--font-mono);
  overflow: hidden;
}
.shell-tabs{
  display: flex; flex-wrap: nowrap;
  background: oklch(0.14 0.012 70);
  border-bottom: 1px solid oklch(0.28 0.010 70);
  padding: 0 8px;
  overflow-x: auto;
  scrollbar-width: none;
}
.shell-tabs::-webkit-scrollbar{ display: none; }
.shell-tabs .tab{ flex: none; white-space: nowrap; }
.shell-tabs .tab{
  padding: 12px 14px;
  font-size: 0.76rem;
  color: oklch(0.62 0.010 70);
  letter-spacing: 0.04em;
  border-bottom: 1px solid transparent;
  margin-bottom: -1px;
}
.shell-tabs .tab.active{ color: var(--paper); border-bottom-color: var(--signal); }

.shell-panes{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: var(--ink-deep);
}
.shell-panes .pane{
  padding: 22px 24px;
  border-right: 1px solid oklch(0.24 0.010 70);
  border-bottom: 1px solid oklch(0.24 0.010 70);
  min-height: 220px;
}
.shell-panes .pane:nth-child(3n){ border-right: 0; }
.shell-panes .pane:nth-last-child(-n+3){ border-bottom: 0; }
@media (max-width: 880px){
  .shell-panes{ grid-template-columns: 1fr; }
  .shell-panes .pane{ border-right: 0; }
}

.shell-panes .pane-head{
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 12px;
  margin-bottom: 14px;
  border-bottom: 1px solid oklch(0.24 0.010 70);
}
.shell-panes .pane-head .ptitle{
  color: var(--paper);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  font-weight: 500;
}
.shell-panes .pane-head .live{
  margin-left: auto;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--good);
  animation: pulse-dot 1.6s ease-in-out infinite;
}

.shell-panes .pane .code{
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: oklch(0.84 0.010 70);
  white-space: pre-wrap;
  margin: 0;
  line-height: 1.65;
}
.shell-panes .pane .line{
  display: grid; grid-template-columns: 1fr auto auto;
  align-items: center; gap: 10px;
  padding: 8px 0;
  font-size: 0.78rem;
  color: oklch(0.82 0.010 70);
  border-top: 1px solid oklch(0.22 0.010 70);
}
.shell-panes .pane .line:first-of-type{ border-top: 0; }
.shell-panes .pane .line .meta{ color: oklch(0.58 0.010 70); font-size: 0.72rem; }

.shell-panes .pane .chip{
  display: inline-flex; align-items: center;
  padding: 2px 8px;
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid currentColor;
}
.shell-panes .pane .chip.approved{ color: var(--good); }
.shell-panes .pane .chip.blocked { color: var(--signal-bright); }
.shell-panes .pane .chip.recalled{ color: oklch(0.62 0.010 70); }
.shell-panes .pane .chip.live    { color: var(--good); }
.shell-panes .pane .chip.review  { color: var(--warn); }
.shell-panes .pane .chip.owned   { color: var(--paper); }

.shell-panes .pane .pane-note{
  color: oklch(0.72 0.010 70);
  font-size: 0.8rem; line-height: 1.5;
  margin: 12px 0 16px;
}
.shell-panes .pane .recall-btn{
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px 14px;
  font-size: 0.74rem;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--signal-bright);
  background: transparent;
  border: 1px solid var(--signal-bright);
}
.shell-panes .pane .actions{
  display: flex; gap: 8px; margin-top: 14px;
}
.shell-panes .pane .actions .pill{
  padding: 6px 11px;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: oklch(0.82 0.010 70);
  background: transparent;
  border: 1px solid oklch(0.32 0.010 70);
}
.shell-panes .pane .actions .pill.primary{
  background: var(--paper); color: var(--ink-deep); border-color: var(--paper);
}


/* ==========================================================================
   § 09 — Diagram card (architectural illustration on platform.html)
   ========================================================================== */
.diagram-card{
  background: var(--paper);
  border: 1px solid var(--ink-deep);
  position: relative;
}
.diagram-card .chrome{
  background: var(--paper);
  border-bottom: 1px solid var(--ink-deep);
  color: var(--ink-deep);
}
.diagram-card svg{
  width: 100%; height: auto; display: block;
  padding: clamp(12px, 3vw, 32px);
}
.diagram-card .caption{
  display: block;
  padding: 12px 18px;
  border-top: 1px solid var(--ink-deep);
  font-family: var(--font-sans);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-faint);
}


/* ==========================================================================
   § 10 — Capability grid (platform.html: six features in one install)
   ========================================================================== */
.capability-grid-6,
.capability-grid-4{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
}
.capability-grid-4{ grid-template-columns: repeat(2, 1fr); }
@media (max-width: 880px){
  .capability-grid-6, .capability-grid-4{ grid-template-columns: 1fr; }
}

.capability-card{
  background: var(--paper);
  padding: 40px 32px 36px;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 14px;
  transition: background-color .2s, color .2s;
}
.capability-card:hover{ background: var(--ink-deep); color: var(--paper); }
.capability-card:hover h3{ color: var(--paper); }
.capability-card:hover p { color: oklch(0.78 0.010 70); }
.capability-card:hover .icon{ color: var(--paper); }
.capability-card .icon{
  width: 28px; height: 28px;
  color: var(--signal);
  margin-bottom: 8px;
}
.capability-card .icon svg{ width: 28px; height: 28px; }
.capability-card h3{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: -0.012em;
  color: var(--ink-deep);
  margin: 0;
}
.capability-card p{
  font-size: 0.95rem; line-height: 1.5;
  color: var(--ink-dim); margin: 0;
}


/* ==========================================================================
   § 11 — Persona blocks (teams.html — five executives)
   ========================================================================== */
.persona-block{
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px;
  padding: 72px 0;
  border-top: 1px solid var(--rule);
}
.persona-block:first-of-type{ border-top: 0; padding-top: 0; }
.persona-block.flip .persona-text{ order: 2; }
@media (max-width: 880px){
  .persona-block{ grid-template-columns: 1fr; gap: 32px; padding: 48px 0; }
  .persona-block.flip .persona-text{ order: 0; }
}
.persona-block .persona-text h3{
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--ink-deep);
  font-size: clamp(2rem, 6vw + 0.4rem, 3rem);
  letter-spacing: -0.02em;
  line-height: 0.94;
  margin: 0 0 24px;
  text-transform: uppercase;
  text-wrap: balance;
}
.persona-block .persona-text .fear{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.4rem, 1.6vw + 0.6rem, 2rem);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--ink-deep);
  margin: 0 0 32px;
  max-width: 24ch;
}
.persona-block .persona-text .fear::before{ content: "“"; color: var(--signal); margin-right: 2px; }
.persona-block .persona-text .fear::after { content: "”"; color: var(--signal); }
.persona-block .gets-title{
  color: var(--ink-faint);
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.persona-block .gets-list{
  list-style: none; padding: 0; margin: 0;
}
.persona-block .gets-list li{
  position: relative;
  padding: 14px 0 14px 36px;
  border-top: 1px solid var(--rule);
  color: var(--ink-deep);
  font-size: 0.98rem;
  line-height: 1.45;
}
.persona-block .gets-list li:first-child{ border-top: 0; }
.persona-block .gets-list li::before{
  content: counter(persona-counter, decimal-leading-zero);
  counter-increment: persona-counter;
  position: absolute; left: 0; top: 14px;
  color: var(--signal);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.04em;
}
.persona-block .gets-list{ counter-reset: persona-counter; }

.persona-block .persona-side{ display: flex; align-items: flex-start; }
.persona-block .scenario{
  background: var(--paper-2);
  padding: 32px 32px 36px;
  border-top: 4px solid var(--signal);
}
.persona-block .scenario .when{
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-deep);
  margin: 0 0 16px;
}
.persona-block .scenario p:not(.when){
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.3rem;
  line-height: 1.2;
  color: var(--ink-deep);
  letter-spacing: -0.012em;
}


/* ==========================================================================
   § 12 — Persona tile (smaller, used on home if needed)
   ========================================================================== */
.persona-tile{
  background: var(--paper);
  border-top: 1px solid var(--rule);
  padding: 28px 0;
}
.persona-tile h3{ font-size: 1.2rem; color: var(--ink-deep); margin: 0 0 8px; }
.persona-tile .outcome{ color: var(--ink-dim); margin: 0; }


/* ==========================================================================
   § 13 — Pullquote
   ========================================================================== */
.pullquote{
  margin: 0;
  padding: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 3vw + 0.6rem, 3.4rem);
  line-height: 1.04;
  letter-spacing: -0.022em;
  color: var(--ink-deep);
  max-width: 22ch;
}
.pullquote::before{ content: "“"; color: var(--signal); }
.pullquote::after { content: "”"; color: var(--signal); }
.pullquote cite{
  display: block;
  margin-top: 24px;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-style: normal;
  color: var(--ink-dim);
}


/* ==========================================================================
   § 14 — Spec rows (key/value pairs separated by hairlines)
   ========================================================================== */
.spec-rows{
  border-top: 1px solid var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
}
.spec-row{
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 48px;
  padding: 24px 0;
  border-top: 1px solid var(--rule);
}
.spec-row:first-child{ border-top: 0; }
.spec-row .k{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: -0.01em;
  color: var(--ink-deep);
}
.spec-row .v{
  font-size: 1rem;
  color: var(--ink);
  line-height: 1.6;
}
@media (max-width: 720px){
  .spec-row{ grid-template-columns: 1fr; gap: 8px; }
}


/* ==========================================================================
   § 15 — Logo wall / trust bar
   ========================================================================== */
.logo-wall{
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 32px 56px;
  padding: 40px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.logo-wall .logo{
  font-family: var(--font-sans);
  font-size: 0.86rem;
  letter-spacing: 0.06em;
  color: var(--ink-faint);
}

.trust-bar{
  padding: 28px var(--gutter);
  border-top: 1px solid var(--ink-deep);
  background: var(--paper);
}
.trust-bar .group{
  max-width: var(--inner); margin: 0 auto;
  display: flex; align-items: center; justify-content: center;
  gap: 18px; flex-wrap: wrap;
  font-family: var(--font-sans);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-deep);
}
.trust-bar .group > span{ display: inline-flex; align-items: center; gap: 18px; }
.trust-bar .group > span:not(:last-child)::after{
  content: "·";
  color: var(--signal);
  font-weight: 400;
}


/* ==========================================================================
   § 16 — Principles (security page numbered list)
   ========================================================================== */
.principle{
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 40px;
  padding: 40px 0;
  border-bottom: 1px solid var(--rule);
}
.principle:last-child{ border-bottom: 0; }
.principle .num{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 3.6rem;
  letter-spacing: -0.04em;
  line-height: 0.85;
  color: var(--signal);
  font-variant-numeric: tabular-nums;
}
.principle h3{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 2rem;
  letter-spacing: -0.018em;
  line-height: 1;
  color: var(--ink-deep);
  margin: 0 0 12px;
}
.principle p{
  color: var(--ink); font-size: 1.02rem; line-height: 1.55;
  margin: 0; max-width: 56ch;
}
@media (max-width: 920px){
  .principle{ grid-template-columns: 1fr; gap: 12px; padding: 28px 0; }
}


/* ==========================================================================
   § 17 — Comparison table
   ========================================================================== */
.comparison-table{
  width: 100%;
  border-collapse: collapse;
  border-top: 1px solid var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
}
.comparison-table thead th{
  text-align: left;
  padding: 18px 20px;
  color: var(--ink-deep);
  font-family: var(--font-sans);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--ink-deep);
}
.comparison-table thead th.with{ color: var(--signal); }
.comparison-table tbody td{
  padding: 16px 20px;
  font-size: 0.96rem;
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
}
.comparison-table tbody tr:last-child td{ border-bottom: 0; }
.comparison-table tbody td.without{ color: var(--ink-dim); }
.comparison-table tbody td.with   { color: var(--ink-deep); font-weight: 500; }


/* ==========================================================================
   § 18 — Status chips
   ========================================================================== */
.status-chip{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid var(--ink-deep);
  color: var(--ink-deep);
  background: var(--paper);
}
.status-chip.--approved,
.status-chip.--governed { color: var(--good); border-color: var(--good); }
.status-chip.--blocked  { color: var(--signal); border-color: var(--signal); background: var(--signal-soft); }
.status-chip.--logged   { color: var(--ink-deep); border-color: var(--ink-deep); }
.status-chip.--owned    { color: var(--ink-deep); }
.status-chip.--recalled { color: var(--ink-faint); border-color: var(--ink-faint); }
.status-chip.--review-required { color: var(--warn); border-color: var(--warn); }


/* ==========================================================================
   § 19 — Hard-line display
   ========================================================================== */
.hard-line, .hard-line-display{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2rem, 3vw + 0.5rem, 3.6rem);
  letter-spacing: -0.022em;
  line-height: 0.98;
  color: var(--ink-deep);
  margin: 0;
}
.accent{ color: var(--signal); }


/* ==========================================================================
   § 20 — Pricing tier cards
   ========================================================================== */
.pricing-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--ink-deep);
  border-bottom: 1px solid var(--ink-deep);
}
@media (max-width: 980px){
  .pricing-grid{ grid-template-columns: 1fr; }
}
.tier-card{
  background: var(--paper);
  padding: 40px 32px 36px;
  border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 20px;
}
.tier-card:last-child{ border-right: 0; }
@media (max-width: 880px){
  .tier-card{ border-right: 0; border-bottom: 1px solid var(--rule); }
  .tier-card:last-child{ border-bottom: 0; }
}
.tier-card h3{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 2.4rem;
  color: var(--ink-deep);
  letter-spacing: -0.022em;
  line-height: 0.9;
  text-transform: uppercase;
}
.tier-card .pitch{
  color: var(--ink); font-size: 0.96rem; line-height: 1.5; margin: 0;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--rule);
}
.tier-card ul.includes{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
  flex: 1;
}
.tier-card ul.includes li{
  position: relative; padding-left: 22px;
  color: var(--ink); font-size: 0.94rem; line-height: 1.45;
}
.tier-card ul.includes li::before{
  content: "+"; position: absolute; left: 0;
  color: var(--signal); font-weight: 600;
}
.tier-card .tier-cta{ margin-top: 8px; }


/* ==========================================================================
   § 21 — Forms
   ========================================================================== */
.form-card{
  background: var(--paper);
  border: 1px solid var(--ink-deep);
  padding: clamp(20px, 5vw, 36px);
}
.form-row{ display: flex; flex-direction: column; gap: 8px; margin-bottom: 22px; }
.form-row.split{ display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 560px){
  .form-row.split{ grid-template-columns: 1fr; gap: 22px; }
}
.form-row.split > div{ display: flex; flex-direction: column; gap: 8px; }
.form-row label{
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-deep);
}
.form-row label .req{ color: var(--signal); margin-left: 4px; }

.form-row input,
.form-row select,
.form-row textarea{
  background: var(--paper-2);
  border: 1px solid var(--rule-strong);
  border-radius: 0;
  color: var(--ink-deep);
  padding: 13px 14px;
  font: 1rem/1.4 var(--font-sans);
  width: 100%;
  transition: border-color .18s, background-color .18s;
}
.form-row input::placeholder,
.form-row textarea::placeholder{ color: var(--ink-faint); }
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{
  outline: none;
  border-color: var(--signal);
  background: var(--paper);
  box-shadow: 0 0 0 1px var(--signal);
}
.form-row textarea{ min-height: 140px; resize: vertical; }
.form-row select{ appearance: none; padding-right: 36px;
  background-image: linear-gradient(45deg, transparent 50%, var(--ink-dim) 50%),
                    linear-gradient(135deg, var(--ink-dim) 50%, transparent 50%);
  background-position: calc(100% - 18px) 22px, calc(100% - 12px) 22px;
  background-size: 6px 6px, 6px 6px; background-repeat: no-repeat;
}

.form-help{
  font-size: 0.84rem; color: var(--ink-faint); margin: 8px 0 0;
}
.form-error{
  padding: 14px 18px;
  background: var(--signal-soft);
  border: 1px solid var(--signal);
  color: var(--signal-deep);
  font-size: 0.92rem;
  margin: 0 0 22px;
}

.form-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 48px;
  max-width: var(--inner);
  margin: 0 auto;
}
.form-wrap{ max-width: var(--inner); margin: 0 auto; }
@media (max-width: 880px){
  .form-grid{ grid-template-columns: 1fr; gap: 28px; }
}
.form-aside{
  padding: 32px;
  border-top: 4px solid var(--signal);
  background: var(--paper-2);
}
.form-aside h4{
  color: var(--ink-deep);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin: 0 0 16px;
}
.form-aside ul{ list-style: none; padding: 0; margin: 0; }
.form-aside li{
  position: relative; padding: 10px 0 10px 24px;
  border-top: 1px solid var(--rule);
  color: var(--ink); font-size: 0.94rem;
}
.form-aside li:first-child{ border-top: 0; }
.form-aside li::before{
  content: "→"; position: absolute; left: 0; top: 10px;
  color: var(--signal);
}


/* ==========================================================================
   § 22 — 404 / Thanks
   ========================================================================== */
.notfound,
.thanks-card{
  max-width: 720px; margin: 0 auto;
  padding: 80px 0;
}
.notfound .flower,
.thanks-card .flower{ background-color: var(--signal); margin-bottom: 32px; }
.notfound .code{
  font-family: var(--font-sans);
  color: var(--signal);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.notfound h1, .thanks-card h1{ margin: 0 0 20px; font-size: clamp(2.4rem, 3vw + 1rem, 3.8rem); }
.notfound p, .thanks-card p{ color: var(--ink); font-size: 1.06rem; margin-bottom: 18px; max-width: 56ch; }
.notfound .cta-row{ display: flex; gap: 12px; flex-wrap: wrap; margin-top: 32px; }
.thanks-card .btn{ margin-top: 28px; }


/* ==========================================================================
   § 23 — Stamp (DRAFT) and misc
   ========================================================================== */
.stamp{
  display: inline-block;
  padding: 5px 12px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--signal);
  border: 1px solid var(--signal);
  margin-bottom: 20px;
  transform: rotate(-2deg);
}
.full{ width: 100%; }


/* ==========================================================================
   § 24 — Field story (testimonial)
   ========================================================================== */
.field-story{
  border-top: 1px solid var(--rule);
  padding: 28px 0;
}
.field-story .who{
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--signal);
  margin: 0 0 12px;
}
.field-story p{ color: var(--ink-deep); font-size: 1.04rem; margin: 0; }


/* ==========================================================================
   § 25 — Compliance / deployment card (legacy, simplified)
   ========================================================================== */
.compliance-card,
.deployment-card{
  padding: 28px 0;
  border-top: 1px solid var(--rule);
}
.compliance-card h3,
.deployment-card h3{ font-size: 1.2rem; color: var(--ink-deep); margin: 0 0 8px; }
.compliance-card p,
.deployment-card p{ font-size: 0.96rem; color: var(--ink-dim); margin: 0; }
