/* =========================================================================
   ROVN · facilities.css  ·  facility-track specific sections
   (reuses base.css + home.css components: tier-chip, receipt, spine,
    ladder, workers-grid, coverage, cta-band, doctrine, sec-head)
   ========================================================================= */

/* ---------- sub-nav active state ---------- */
.nav a[aria-current="page"] { color: var(--ink); background: rgba(28,24,18,0.05); }

/* ============================================================
   PAGE HERO  ·  readiness console
   ============================================================ */
.fhero { padding-top: clamp(40px, 6vw, 80px); padding-bottom: clamp(56px, 6vw, 100px); }
.fhero-grid { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr); gap: clamp(28px, 4vw, 60px); align-items: center; }
.fhero h1 { font-size: var(--t-h1); margin: 22px 0 22px; }
.fhero h1 em { font-style: italic; color: var(--teal-ink); }
.fhero .lead { max-width: 42ch; margin-bottom: 30px; }
.fhero-ctas { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.fhero-foot { margin-top: 26px; display: flex; flex-wrap: wrap; gap: 8px 20px; font-size: var(--t-xs); color: var(--ink-3); }
.fhero-foot .mono { letter-spacing: 0.02em; }

/* the console panel */
.console {
  background:
    radial-gradient(120% 80% at 85% 0%, rgba(40,198,198,0.12), transparent 55%),
    var(--night);
  border: 1px solid var(--night-line); border-radius: var(--r-4);
  box-shadow: var(--shadow-night); overflow: hidden; color: var(--on-night);
}
.console-top { display: flex; align-items: center; gap: 14px; padding: 16px 20px; border-bottom: 1px solid var(--night-line); }
.console-top .ct-live { display: inline-flex; align-items: center; gap: 0.55em; font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-bright); }
.console-top .ct-live .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--teal-bright); box-shadow: 0 0 10px var(--teal-bright); }
.console-top .ct-fac { font-size: var(--t-sm); color: var(--on-night-2); }
.console-top .ct-fac b { color: var(--on-night); font-weight: 600; }
.console-top .ct-illus { margin-left: auto; font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--on-night-3); }

.console-filters { display: flex; gap: 8px; padding: 14px 20px; border-bottom: 1px solid var(--night-line-soft); flex-wrap: wrap; }
.cf-chip { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.04em; padding: 0.4em 0.75em; border-radius: var(--r-pill); border: 1px solid var(--night-line); color: var(--on-night-2); }
.cf-chip.active { background: var(--teal); border-color: var(--teal); color: #fff; }
.cf-chip .n { opacity: 0.7; }

.console-table { padding: 6px 8px 12px; }
.crow { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr) auto; gap: 10px; align-items: center; padding: 12px; border-radius: var(--r-2); transition: background .25s; }
.crow:hover { background: rgba(244,238,225,0.03); }
.crow + .crow { border-top: 1px solid var(--night-line-soft); }
.crow-head { font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-night-3); padding: 8px 12px 10px; }
.crow .cw { display: flex; align-items: center; gap: 10px; }
.crow .cw .av { width: 28px; height: 28px; border-radius: 50%; flex: none; background: linear-gradient(135deg, var(--night-2), var(--tier-attested)); }
.crow .cw .nm { display: block; font-size: var(--t-sm); color: var(--on-night); font-weight: 500; line-height: 1.15; }
.crow .cw .ro { display: block; font-family: var(--mono); font-size: 0.6rem; color: var(--on-night-3); margin-top: 1px; }
.cstat { display: inline-flex; align-items: center; gap: 0.4em; font-family: var(--mono); font-size: 0.64rem; }
.cstat .ic { width: 13px; height: 13px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 8px; flex: none; }
.cstat.ok { color: var(--teal-bright); } .cstat.ok .ic { background: rgba(40,198,198,0.18); color: var(--teal-bright); }
.cstat.warn { color: #C9A24B; } .cstat.warn .ic { background: rgba(201,162,75,0.18); color: #C9A24B; }
.cstat.wait { color: var(--on-night-3); } .cstat.wait .ic { background: rgba(244,238,225,0.08); }
.crow .cgo { font-family: var(--mono); font-size: 0.6rem; color: var(--on-night-3); text-align: right; }
.crow .cgo.decide { color: var(--teal-bright); }
@media (max-width: 600px) {
  .crow { grid-template-columns: 1.4fr 1fr; }
  .crow .cstat:nth-child(n+3), .crow .cgo, .crow-head { display: none; }
}
@media (max-width: 980px) { .fhero-grid { grid-template-columns: 1fr; } .console { order: 2; } }

/* ============================================================
   INPUTS  ·  bring your world
   ============================================================ */
.inputs-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-top: 44px; }
.input-card { border: 1px solid var(--line); border-radius: var(--r-3); background: var(--paper-0); padding: 22px 18px; display: flex; flex-direction: column; gap: 10px; transition: border-color .3s, transform .35s var(--ease-quint); }
.input-card:hover { border-color: var(--teal-line); transform: translateY(-3px); }
.input-card .ic-k { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal-ink); }
.input-card .ic-t { font-family: var(--serif); font-size: 1.18rem; letter-spacing: -0.01em; line-height: 1.1; }
.input-card .ic-d { font-size: var(--t-xs); color: var(--ink-3); line-height: 1.45; }
.inputs-arrow { display: flex; align-items: center; justify-content: center; gap: 12px; margin-top: 26px; font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.inputs-arrow .ln { height: 1px; width: 40px; background: var(--line-strong); }
@media (max-width: 880px) { .inputs-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .inputs-grid { grid-template-columns: 1fr; } }

/* ============================================================
   SIX QUESTIONS  ·  full treatment
   ============================================================ */
.sixq { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 48px; }
.sixq-card { border: 1px solid var(--line); border-radius: var(--r-3); background: var(--paper-0); padding: 26px 24px; position: relative; overflow: hidden; }
.sixq-card .sq-n { font-family: var(--mono); font-size: 0.66rem; color: var(--teal-ink); letter-spacing: 0.08em; margin-bottom: 14px; }
.sixq-card .sq-t { font-family: var(--serif); font-size: 1.5rem; letter-spacing: -0.012em; line-height: 1.04; margin-bottom: 10px; }
.sixq-card .sq-d { font-size: var(--t-sm); color: var(--ink-3); line-height: 1.5; }
.sixq-card .sq-chip { margin-top: 16px; }
@media (max-width: 860px) { .sixq { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .sixq { grid-template-columns: 1fr; } }

/* ============================================================
   ROLES  ·  who we serve
   ============================================================ */
.roles-wrap { margin-top: 44px; display: flex; flex-wrap: wrap; gap: 9px; }
.role-chip { font-size: var(--t-sm); color: var(--ink-2); border: 1px solid var(--line); background: var(--paper-0); border-radius: var(--r-pill); padding: 0.5em 0.95em; }
.role-chip .more { color: var(--teal-ink); font-weight: 600; }

/* ============================================================
   DECISION GATE  ·  humans decide
   ============================================================ */
.gate { background: var(--night); color: var(--on-night); border-block: 1px solid var(--night-line); position: relative; overflow: hidden; }
.gate .kicker { color: var(--on-night-3); } .gate .kicker::before { background: var(--on-night-3); }
.gate h2 { color: var(--on-night); } .gate .lead { color: var(--on-night-2); }
.gate-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 72px); align-items: center; }
.gate-flow { display: flex; flex-direction: column; gap: 0; }
.gate-step { display: grid; grid-template-columns: auto 1fr; gap: 16px; padding: 18px 0; align-items: start; }
.gate-step + .gate-step { border-top: 1px solid var(--night-line-soft); }
.gate-step .gs-tag { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.35em 0.6em; border-radius: var(--r-1); white-space: nowrap; align-self: start; }
.gate-step.ai .gs-tag { background: rgba(40,198,198,0.12); color: var(--teal-bright); border: 1px solid var(--teal-line); }
.gate-step.human .gs-tag { background: var(--on-night); color: var(--night); }
.gate-step .gs-t { font-size: var(--t-sm); color: var(--on-night); line-height: 1.4; }
.gate-step .gs-t b { font-weight: 600; }
.gate-step .gs-t span { color: var(--on-night-3); display: block; margin-top: 3px; font-size: var(--t-xs); }

/* ============================================================
   DESIGN PARTNER PROGRAM
   ============================================================ */
.dpp { }
.dpp-card { border: 1px solid var(--line); border-radius: var(--r-4); background: var(--paper-0); overflow: hidden; display: grid; grid-template-columns: 1fr 0.85fr; }
.dpp-main { padding: clamp(34px, 4vw, 56px); }
.dpp-main .dpp-price { font-family: var(--serif); font-size: clamp(2.4rem, 1.6rem + 2.4vw, 3.4rem); letter-spacing: -0.02em; line-height: 1; }
.dpp-main .dpp-price .term { color: var(--ink-3); }
.dpp-main .dpp-sub { margin-top: 14px; color: var(--ink-2); max-width: 38ch; }
.dpp-main .dpp-ctas { margin-top: 28px; display: flex; gap: 12px; flex-wrap: wrap; }
.dpp-list { background: var(--night); color: var(--on-night-2); padding: clamp(30px, 3vw, 48px); }
.dpp-list .dl-h { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--on-night-3); margin-bottom: 18px; }
.dpp-list ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.dpp-list li { display: grid; grid-template-columns: auto 1fr; gap: 11px; font-size: var(--t-sm); line-height: 1.4; }
.dpp-list li .ck { color: var(--teal-bright); }
.dpp-list li b { color: var(--on-night); font-weight: 600; }
.dpp-note { margin-top: 22px; font-size: var(--t-xs); color: var(--ink-4); }
@media (max-width: 820px) { .dpp-card { grid-template-columns: 1fr; } }

/* ============================================================
   COST OF WAITING  ·  facility economics (the bleeding money)
   ============================================================ */
.costwall { background: var(--paper-2); border-block: 1px solid var(--line); }
.cost-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--r-3); overflow: hidden; margin-top: 44px; }
.cost-item { background: var(--paper-0); padding: clamp(26px, 3vw, 36px) clamp(22px, 2.4vw, 30px); display: flex; flex-direction: column; gap: 14px; }
.cost-item .cost-n { font-family: var(--serif); font-weight: 400; font-size: clamp(2.1rem, 1.5rem + 1.9vw, 3rem); letter-spacing: -0.022em; line-height: 0.95; color: var(--ink); font-variant-numeric: tabular-nums; }
.cost-item .cost-n .u { font-size: 0.4em; color: var(--ink-3); letter-spacing: 0; font-variant-numeric: normal; }
.cost-item .cost-l { font-size: var(--t-sm); color: var(--ink-3); line-height: 1.5; }
.cost-item .cost-src { display: block; margin-top: 9px; font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-4); }
.cost-foot { margin-top: 32px; max-width: 72ch; font-family: var(--serif); font-size: var(--t-h4); line-height: 1.4; letter-spacing: -0.01em; color: var(--ink-2); }
.cost-foot b { color: var(--teal-ink); font-weight: 400; font-style: italic; }
.cost-foot .illus { display: block; margin-top: 16px; font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-4); }
@media (max-width: 880px) { .cost-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .cost-grid { grid-template-columns: 1fr; } }

/* ============================================================
   PRICING LADDER  ·  transparent
   ============================================================ */
.price-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; align-items: stretch; }
.price-card { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--r-4); background: var(--paper-0); padding: clamp(26px, 3vw, 34px) clamp(22px, 2.4vw, 28px); display: flex; flex-direction: column; position: relative; transition: border-color .3s, transform .35s var(--ease-quint); }
.price-card:hover { transform: translateY(-3px); border-color: var(--teal-line); }
.price-card.feature { border-color: var(--teal); box-shadow: 0 0 0 1px var(--teal), var(--shadow-2); }
.price-card .pc-badge { position: absolute; top: -11px; left: 26px; background: var(--teal); color: #fff; font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.4em 0.7em; border-radius: var(--r-pill); }
.price-card .pc-name { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-ink); margin-bottom: 16px; }
.price-card .pc-price { font-family: var(--serif); font-weight: 400; font-size: clamp(1.9rem, 1.4rem + 1.2vw, 2.5rem); letter-spacing: -0.022em; line-height: 1; color: var(--ink); }
.price-card .pc-price .per { font-size: 0.36em; color: var(--ink-3); letter-spacing: 0; }
.price-card .pc-sub { margin-top: 14px; font-size: var(--t-sm); color: var(--ink-3); line-height: 1.5; flex: 1; }
.price-card .pc-foot { margin-top: 22px; padding-top: 16px; border-top: 1px solid var(--line); font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.04em; color: var(--ink-4); }
@media (max-width: 940px) { .price-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .price-grid { grid-template-columns: 1fr; } }

/* transparent-pricing wedge */
.pwedge { margin-top: 36px; border: 1px solid var(--teal-line); background: var(--teal-wash); border-radius: var(--r-3); padding: clamp(22px, 2.6vw, 30px) clamp(24px, 2.8vw, 34px); display: flex; gap: 10px 26px; align-items: baseline; flex-wrap: wrap; }
.pwedge .pw-k { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal-ink); white-space: nowrap; }
.pwedge .pw-t { font-family: var(--serif); font-size: var(--t-h4); line-height: 1.4; letter-spacing: -0.01em; color: var(--ink); flex: 1; min-width: 280px; }
.pwedge .pw-t em { font-style: italic; color: var(--teal-ink); }

/* per-card pricing CTA */
.price-card .pc-cta { margin-top: 16px; display: inline-flex; align-items: center; gap: 0.45em; font-family: var(--sans); font-weight: 600; font-size: var(--t-sm); color: var(--teal-ink); transition: gap .3s var(--ease-quint); align-self: flex-start; }
.price-card .pc-cta:hover { gap: 0.78em; }
.price-card.feature .pc-cta { margin-top: 18px; background: var(--teal); color: #fff; padding: 0.62em 1.05em; border-radius: var(--r-pill); transition: background .25s, gap .3s var(--ease-quint); }
.price-card.feature .pc-cta:hover { background: var(--teal-deep); }

.price-card .pc-cta { margin-top: auto; }
.price-card .pc-foot { margin-top: 22px; }
