/* =========================================================================
   ROVN · workers.css  ·  worker-track specific sections
   (reuses base.css + home.css components: tier-chip, sec-head, cta-band)
   Dignified, warm, worker-owned. The firewall is made visible.
   ========================================================================= */

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

/* ============================================================
   HERO  ·  the Worker Passport
   ============================================================ */
.whero { padding-top: clamp(40px, 6vw, 80px); padding-bottom: clamp(56px, 6vw, 100px); }
.whero-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr); gap: clamp(28px, 4vw, 64px); align-items: center; }
.whero h1 { font-size: var(--t-mega); margin: 22px 0 22px; }
.whero h1 em { font-style: italic; color: var(--teal-ink); }
.whero .lead { max-width: 40ch; margin-bottom: 16px; }
.whero-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 30px; }
.whero-tags .wt { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--teal-ink); border: 1px solid var(--teal-line); border-radius: var(--r-pill); padding: 0.4em 0.8em; }
.whero-ctas { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.whero-foot { margin-top: 24px; font-size: var(--t-xs); color: var(--ink-3); font-family: var(--mono); }

/* passport card (rich) */
.wpass { background: var(--paper-0); border: 1px solid var(--line); border-radius: var(--r-4); box-shadow: var(--shadow-lift); overflow: hidden; }
.wpass-head { display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: center; padding: 22px 24px; border-bottom: 1px solid var(--line); background: linear-gradient(180deg, var(--paper-0), var(--paper)); }
.wpass-portrait { width: 56px; height: 56px; border-radius: var(--r-3); background: linear-gradient(140deg, var(--paper-3), var(--tier-attested)); position: relative; flex: none; }
.wpass-id .nm { font-family: var(--serif); font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1; }
.wpass-id .meta { font-family: var(--mono); font-size: 0.66rem; color: var(--ink-4); margin-top: 5px; letter-spacing: 0.02em; }
.wpass-seal { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.wpass-seal .ring { width: 40px; height: 40px; border-radius: 50%; border: 1.5px solid var(--teal); display: flex; align-items: center; justify-content: center; color: var(--teal); position: relative; }
.wpass-seal .ring::after { content: ""; position: absolute; inset: -5px; border-radius: 50%; border: 1px solid var(--teal-line); }
.wpass-seal .lab { font-family: var(--mono); font-size: 0.54rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--teal-ink); }

.wpass-owned { display: flex; align-items: center; gap: 8px; padding: 11px 24px; background: var(--teal-wash); border-bottom: 1px solid var(--line); font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--teal-ink); }
.wpass-owned .k { width: 6px; height: 6px; border-radius: 50%; background: var(--teal); }

.wpass-row { display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: center; padding: 14px 24px; border-bottom: 1px solid var(--line-soft); }
.wpass-row:last-child { border-bottom: 0; }
.wpass-row .wr-name { font-size: var(--t-sm); color: var(--ink); font-weight: 500; }
.wpass-row .wr-name .src { display: block; font-family: var(--mono); font-size: 0.62rem; color: var(--ink-4); font-weight: 400; margin-top: 2px; }
.wpass-row .wr-meta { font-family: var(--mono); font-size: 0.64rem; color: var(--ink-4); text-align: right; }
.wpass-foot { display: flex; align-items: center; justify-content: space-between; padding: 14px 24px; background: var(--paper); border-top: 1px solid var(--line); font-family: var(--mono); font-size: 0.64rem; color: var(--ink-4); }
.wpass-foot .ch { color: var(--teal-ink); }
@media (max-width: 980px) { .whero-grid { grid-template-columns: 1fr; } .wpass { order: 2; } }
@media (max-width: 420px) { .wpass-row { grid-template-columns: 1fr auto; } .wpass-row .wr-meta { display: none; } }

/* ============================================================
   CONSENT  ·  you control what travels
   ============================================================ */
.consent { background: var(--paper-2); border-block: 1px solid var(--line); }
.consent-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 80px); align-items: center; }
.consent-panel { border: 1px solid var(--line); border-radius: var(--r-4); background: var(--paper-0); overflow: hidden; }
.consent-panel .cp-head { padding: 16px 22px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; }
.consent-panel .cp-head .t { font-weight: 600; font-size: var(--t-sm); }
.consent-panel .cp-head .who { font-family: var(--mono); font-size: 0.64rem; color: var(--ink-4); }
.consent-row { display: flex; align-items: center; gap: 14px; padding: 15px 22px; border-bottom: 1px solid var(--line-soft); }
.consent-row:last-child { border-bottom: 0; }
.consent-row .cr-t { font-size: var(--t-sm); color: var(--ink-2); }
.consent-row .cr-t .s { display: block; font-size: var(--t-xs); color: var(--ink-4); margin-top: 2px; }
.consent-row .tog { margin-left: auto; width: 40px; height: 23px; border-radius: var(--r-pill); background: var(--paper-3); position: relative; transition: background .3s var(--ease-quint); flex: none; }
.consent-row .tog::after { content: ""; position: absolute; top: 2px; left: 2px; width: 19px; height: 19px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-1); transition: transform .3s var(--ease-spring); }
.consent-row.on .tog { background: var(--teal); }
.consent-row.on .tog::after { transform: translateX(17px); }

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.steps { margin-top: 48px; 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; }
.step { background: var(--paper-0); padding: 30px 26px; display: flex; flex-direction: column; }
.step .st-n { font-family: var(--mono); font-size: 0.7rem; color: var(--teal-ink); letter-spacing: 0.08em; margin-bottom: 18px; }
.step .st-t { font-family: var(--serif); font-size: 1.35rem; letter-spacing: -0.012em; line-height: 1.05; margin-bottom: 10px; }
.step .st-d { font-size: var(--t-sm); color: var(--ink-3); line-height: 1.5; margin-top: auto; }
@media (max-width: 880px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .steps { grid-template-columns: 1fr; } }

/* ============================================================
   THE FIREWALL  ·  what your record is / is not
   ============================================================ */
.firewall { background: var(--night); color: var(--on-night); border-block: 1px solid var(--night-line); position: relative; overflow: hidden; }
.firewall .kicker { color: var(--on-night-3); } .firewall .kicker::before { background: var(--on-night-3); }
.firewall h2 { color: var(--on-night); } .firewall .lead { color: var(--on-night-2); }
.fw-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 48px; }
.fw-card { border-radius: var(--r-4); padding: clamp(26px, 3vw, 40px); border: 1px solid var(--night-line); }
.fw-card .fw-tag { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 18px; display: inline-flex; align-items: center; gap: 0.5em; }
.fw-card .fw-tag .m { width: 14px; height: 14px; border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; }
.fw-card ul { list-style: none; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.fw-card li { display: grid; grid-template-columns: auto 1fr; gap: 11px; font-size: var(--t-body); line-height: 1.4; }
.fw-card li .mk { font-family: var(--mono); }
.fw-card.is { background: rgba(40,198,198,0.06); }
.fw-card.is .fw-tag { color: var(--teal-bright); } .fw-card.is .fw-tag .m { background: var(--teal); color: #fff; }
.fw-card.is li .mk { color: var(--teal-bright); }
.fw-card.is li b { color: var(--on-night); font-weight: 600; }
.fw-card.is li { color: var(--on-night); }
.fw-card.isnot { background: rgba(244,238,225,0.02); }
.fw-card.isnot .fw-tag { color: var(--on-night-3); } .fw-card.isnot .fw-tag .m { background: var(--night-2); color: var(--on-night-3); border: 1px solid var(--night-line); }
.fw-card.isnot li { color: var(--on-night-2); }
.fw-card.isnot li .mk { color: var(--on-night-3); }
.fw-legal { margin-top: 26px; padding: 18px 22px; border: 1px solid var(--night-line); border-radius: var(--r-3); background: rgba(244,238,225,0.02); font-size: var(--t-sm); color: var(--on-night-2); line-height: 1.5; display: flex; gap: 14px; align-items: flex-start; }
.fw-legal .lbl { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--on-night-3); white-space: nowrap; padding-top: 2px; }
@media (max-width: 760px) { .fw-cols { grid-template-columns: 1fr; } }

/* ============================================================
   FREE  ·  banner
   ============================================================ */
.free-band { text-align: center; }
.free-band .fb-big { font-family: var(--serif); font-size: var(--t-h1); letter-spacing: -0.02em; line-height: 1.04; max-width: 24ch; margin: 0 auto 20px; text-wrap: balance; }
.free-band .fb-big em { font-style: italic; color: var(--teal-ink); }
.free-band .fb-sub { max-width: 48ch; margin: 0 auto 30px; color: var(--ink-3); }
.free-band .fb-points { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 12px; }
.free-band .fb-chip { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-2); border: 1px solid var(--line); border-radius: var(--r-pill); padding: 0.5em 0.9em; background: var(--paper-0); }
.free-band .fb-chip .k { color: var(--teal-ink); }
