/* ============================================================
   michaelurquidi.com - Page layout system (Option 2)
   The spec-sheet treatment shared across every page.
   Depends on tokens.css (palette, type, scale) and site.css
   (nav, buttons, cards, footer, reveal). This file only adds
   page structure: the document-meta strip, mastheads, numbered
   section scaffold, and the page-specific blocks.
   Palette discipline: olive does the work, gold marks the one
   paid thing, purple appears once as the writing panel.
   ============================================================ */

/* ---- Skip link + visible keyboard focus ---- */
.skip {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--ink); color: var(--bg);
  padding: 10px 16px; border-radius: var(--radius-s);
  font-family: var(--mono); font-size: 13px;
}
.skip:focus { left: 12px; top: 12px; color: var(--bg); }
a:focus-visible, .btn:focus-visible, button:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px;
}

/* ---- Document meta strip (under the nav) ---- */
.docmeta { border-bottom: 1px solid var(--border); }
.docmeta .wrap {
  display: flex; justify-content: space-between; gap: 12px 30px; flex-wrap: wrap;
  padding-top: 10px; padding-bottom: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted);
}

/* ---- Masthead: home title block ---- */
.masthead { padding: clamp(54px, 9vw, 104px) 0 clamp(40px, 6vw, 70px); }
.masthead .grid {
  display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: clamp(34px, 5vw, 70px); align-items: end;
}
.masthead .eyebrow { margin-bottom: 22px; }
.masthead h1 { font-size: var(--fs-display); line-height: 0.98; letter-spacing: -0.03em; margin-bottom: 26px; }
.masthead .intro { max-width: 46ch; font-size: clamp(17px, 1.9vw, 20px); color: var(--muted); line-height: 1.6; margin-bottom: 32px; }
.masthead .cta-row { display: flex; flex-wrap: wrap; gap: 13px; }
@media (max-width: 860px) {
  .masthead .grid { grid-template-columns: 1fr; align-items: start; gap: 34px; }
  .masthead .console { max-width: 520px; }
}

/* ---- Pagehead: interior pages ---- */
.pagehead { padding: clamp(48px, 7vw, 84px) 0 clamp(30px, 4vw, 48px); }
.pagehead .eyebrow { margin-bottom: 20px; }
.pagehead h1 { font-size: var(--fs-h1); line-height: 1.02; letter-spacing: -0.025em; margin-bottom: 22px; max-width: 18ch; }
.pagehead .lead { max-width: 56ch; }
.pagehead .actions { margin-top: 26px; display: flex; flex-wrap: wrap; gap: 13px; }

/* ---- Hero artifact: UTM Builder output console ---- */
.console {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden; font-family: var(--mono); box-shadow: 0 1px 0 var(--border);
}
.console .bar {
  display: flex; align-items: center; gap: 8px; padding: 11px 16px;
  border-bottom: 1px solid var(--border);
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted);
}
.console .bar .dots { display: inline-flex; gap: 6px; margin-right: 6px; }
.console .bar .dots i { width: 9px; height: 9px; border-radius: 50%; background: var(--border-s); display: inline-block; }
.console .body { padding: 20px 18px; font-size: 13px; line-height: 1.95; }
.console .body .row { white-space: nowrap; overflow-x: auto; }
.console .base { color: var(--muted); }
.console .key { color: var(--link); }
.console .val { color: var(--ink); }
.console .op { color: var(--muted); }
.console .caret { display: inline-block; width: 8px; height: 15px; background: var(--primary); vertical-align: -2px; margin-left: 2px; animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .console .caret { animation: none; } }
.console .note { border-top: 1px solid var(--border); padding: 11px 18px; font-size: 11px; letter-spacing: 0.06em; color: var(--muted); display: flex; justify-content: space-between; gap: 12px; }

/* ---- Past lives band (home) ---- */
.pastlives { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.pastlives .wrap { display: flex; align-items: baseline; flex-wrap: wrap; gap: 12px 30px; padding-top: 18px; padding-bottom: 18px; }
.pastlives .lbl { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.pastlives .who { font-family: var(--serif); font-size: clamp(17px, 2vw, 21px); color: var(--ink); }

/* ---- Numbered section scaffold ---- */
.sec { padding: clamp(58px, 9vw, 100px) 0; }
.sec-tight { padding: clamp(40px, 6vw, 64px) 0; }
.sec-head { display: grid; grid-template-columns: auto 1fr auto; gap: 18px 26px; align-items: baseline; margin-bottom: 44px; }
.sec-num { font-family: var(--mono); font-weight: 500; font-size: clamp(30px, 5vw, 52px); line-height: 0.8; color: var(--border-s); letter-spacing: 0.02em; }
.sec-head h2 { max-width: 24ch; }
.sec-head .meta { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); text-align: right; white-space: nowrap; align-self: center; }
.sec-head .meta a { color: var(--accent); }
@media (max-width: 720px) {
  .sec-head { grid-template-columns: auto 1fr; }
  .sec-head .meta { grid-column: 1 / -1; text-align: left; }
}

/* ---- Prose block ---- */
.prose { max-width: 64ch; }
.prose p { margin-bottom: 20px; color: var(--ink); }
.prose p:last-child { margin-bottom: 0; }
.prose .first { font-size: clamp(18px, 2vw, 21px); color: var(--ink); line-height: 1.55; }

/* ---- 01 Capabilities ledger (home) ---- */
.ledger { border-top: 1px solid var(--border); }
.ledger .item { display: grid; grid-template-columns: 42px minmax(0, 1fr) minmax(0, 0.7fr); gap: 16px 30px; padding: 26px 0; border-bottom: 1px solid var(--border); align-items: start; }
.ledger .ix { font-family: var(--mono); font-size: 12px; color: var(--link); padding-top: 5px; }
.ledger h3 { margin-bottom: 9px; }
.ledger p { font-size: 15.5px; color: var(--muted); line-height: 1.58; max-width: 52ch; }
.ledger .stat { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--ink); text-align: right; padding-top: 4px; }
@media (max-width: 720px) {
  .ledger .item { grid-template-columns: 30px 1fr; }
  .ledger .stat { grid-column: 2; text-align: left; color: var(--muted); }
}

/* ---- Product cards (home grid) ---- */
.prodgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 880px) { .prodgrid { grid-template-columns: 1fr; } }
.prod { display: flex; flex-direction: column; position: relative; }
.prod.is-paid { border-top: 2px solid var(--primary); }
.prod .ptag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.prod h3 { margin-bottom: 10px; }
.prod h3 a { color: var(--ink); }
.prod h3 a:hover { color: var(--link); }
.prod p { font-size: 14.5px; color: var(--muted); line-height: 1.58; flex: 1; margin-bottom: 22px; }
.prod .foot-row { display: flex; align-items: center; justify-content: space-between; padding-top: 15px; border-top: 1px solid var(--border); font-family: var(--mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; }
.prod .free { color: var(--link); }
.prod .paid { color: var(--gold-d); font-weight: 500; font-size: 14px; }

/* ---- Product detail blocks (products page) ---- */
.prodfull { border-top: 1px solid var(--border); }
.prodfull .block { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr); gap: clamp(26px, 4vw, 60px); padding: clamp(40px, 6vw, 64px) 0; border-bottom: 1px solid var(--border); align-items: start; }
.prodfull .ix { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; color: var(--link); margin-bottom: 14px; }
.prodfull .ptag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.prodfull h2 { margin-bottom: 16px; }
.prodfull .desc { color: var(--muted); max-width: 54ch; }
.prodfull .specs { display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px; }
.prodfull .specs.is-paid { border-top: 2px solid var(--gold); }
.prodfull .feat { list-style: none; margin: 0 0 20px; padding: 0; }
.prodfull .feat li { font-family: var(--mono); font-size: 12.5px; letter-spacing: 0.03em; color: var(--ink); padding: 7px 0; border-bottom: 1px solid var(--border); display: flex; gap: 10px; }
.prodfull .feat li::before { content: "+"; color: var(--link); }
.prodfull .priceline { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin: 4px 0 18px; }
.prodfull .price { font-family: var(--serif); font-size: 30px; color: var(--ink); }
.prodfull .price.paid { color: var(--gold-d); }
.prodfull .fmt { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
@media (max-width: 820px) { .prodfull .block { grid-template-columns: 1fr; } }

/* ---- Stat grid (about, writing) ---- */
.statgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.statgrid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.statgrid .cell { background: var(--bg); padding: 28px 22px; }
.statgrid .n { font-family: var(--serif); font-size: clamp(28px, 3.4vw, 40px); line-height: 1; color: var(--ink); letter-spacing: -0.02em; }
.statgrid .k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-top: 12px; max-width: 24ch; }
@media (max-width: 720px) { .statgrid, .statgrid.cols-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 440px) { .statgrid, .statgrid.cols-3 { grid-template-columns: 1fr; } }

/* ---- Lives grid (about) ---- */
.lives { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 820px) { .lives { grid-template-columns: 1fr; } }
.lives .ptag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.lives h3 { margin-bottom: 10px; }
.lives p { color: var(--muted); font-size: 14.5px; line-height: 1.56; }

/* ---- Chips (toolbox) ---- */
.chips { display: flex; flex-wrap: wrap; gap: 9px; }
.chips span { font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink); background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: 7px 14px; }

/* ---- Writing panel + side (home, writing) ---- */
.writing { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: clamp(28px, 4vw, 56px); align-items: stretch; }
@media (max-width: 820px) { .writing { grid-template-columns: 1fr; } }
.writing .panel { background: var(--accent-surface); color: var(--on-accent-surface); border-radius: var(--radius); padding: clamp(30px, 4vw, 46px); display: flex; flex-direction: column; }
.writing .panel .lbl { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: color-mix(in srgb, var(--on-accent-surface) 72%, transparent); }
.writing .panel h2 { color: var(--on-accent-surface); margin: 14px 0 14px; }
.writing .panel p { color: color-mix(in srgb, var(--on-accent-surface) 88%, transparent); font-size: 15.5px; flex: 1; }
.writing .panel .lnk { color: var(--gold); margin-top: 24px; }
.writing .panel .lnk:hover { color: color-mix(in srgb, var(--gold) 80%, white); }
.writing .side { padding-top: 4px; }
.writing .side .lbl { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 16px; }
.writing .side p { color: var(--muted); font-size: 15.5px; margin-bottom: 14px; max-width: 42ch; }

/* ---- Case study feature (writing) ---- */
.casestudy { display: grid; grid-template-columns: auto 1fr; gap: 18px 26px; }
.casestudy .ix { font-family: var(--mono); font-size: clamp(30px, 5vw, 52px); line-height: 0.8; color: var(--border-s); }
.casestudy .ptag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.casestudy h2 { max-width: 18ch; margin-bottom: 18px; }
.casestudy .desc { color: var(--muted); max-width: 60ch; margin-bottom: 30px; }
.casestudy .cta-row { margin-top: 30px; display: flex; gap: 13px; flex-wrap: wrap; }
@media (max-width: 620px) { .casestudy { grid-template-columns: 1fr; } }

/* ---- Contact methods ---- */
.methods { border-top: 1px solid var(--border); max-width: 720px; }
.methods a { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 8px 20px; padding: 24px 4px; border-bottom: 1px solid var(--border); color: var(--ink); }
.methods a:hover { color: var(--link); }
.methods .k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.methods .v { font-family: var(--serif); font-size: clamp(20px, 2.6vw, 27px); letter-spacing: -0.01em; }
.methods .arrow { color: var(--link); font-family: var(--mono); }

/* ---- Note block ---- */
.note-block { border-left: 2px solid var(--border-s); padding: 4px 0 4px 20px; max-width: 60ch; color: var(--muted); font-size: 15.5px; }

/* ---- Closer (home, contact) ---- */
.closer .wrap { display: grid; grid-template-columns: auto 1fr auto; gap: 18px 26px; align-items: center; }
.closer .sub { color: var(--muted); font-size: 15.5px; max-width: 40ch; }
.closer .cta-row { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 720px) {
  .closer .wrap { grid-template-columns: auto 1fr; }
  .closer .cta-row { grid-column: 1 / -1; justify-content: flex-start; }
}

/* ---- References index (references page) ---- */
.refindex { border-top: 1px solid var(--border); }
.refindex .row { display: grid; grid-template-columns: 42px minmax(0, 1fr) auto; gap: 16px 30px; padding: 26px 0; border-bottom: 1px solid var(--border); align-items: start; color: var(--ink); }
.refindex .row:hover { color: var(--ink); }
.refindex .row:hover h3 { color: var(--link); }
.refindex .row:hover .open { color: var(--accent); }
.refindex .ix { font-family: var(--mono); font-size: 12px; color: var(--link); padding-top: 5px; }
.refindex .rtag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.refindex h3 { margin-bottom: 8px; transition: color .18s var(--ease); }
.refindex p { font-size: 15px; color: var(--muted); line-height: 1.56; max-width: 62ch; }
.refindex .open { font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; color: var(--link); white-space: nowrap; padding-top: 5px; display: inline-flex; gap: 7px; align-items: center; transition: color .18s var(--ease); }
.refindex .open .arrow { transition: transform .18s var(--ease); }
.refindex .row:hover .open .arrow { transform: translateX(3px); }
@media (max-width: 720px) {
  .refindex .row { grid-template-columns: 30px 1fr; }
  .refindex .open { grid-column: 2; padding-top: 12px; }
}

/* ---- Legal document (privacy page) ---- */
.legaldoc { max-width: 72ch; }
.legaldoc .h { display: grid; grid-template-columns: 42px 1fr; gap: 14px; align-items: baseline; margin: 44px 0 14px; }
.legaldoc section:first-child .h { margin-top: 0; }
.legaldoc .hn { font-family: var(--mono); font-size: 12px; color: var(--border-s); }
.legaldoc .hl { font-family: var(--mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.legaldoc .body { padding-left: 56px; }
.legaldoc p { font-size: 16.5px; color: var(--ink); margin-bottom: 16px; line-height: 1.62; }
.legaldoc p:last-child { margin-bottom: 0; }
.legaldoc a { color: var(--link); border-bottom: 1px solid var(--border); }
.legaldoc a:hover { color: var(--accent); border-color: var(--accent); }
.legaldoc .updated { font-family: var(--mono); font-size: 12px; color: var(--muted); letter-spacing: 0.04em; margin-top: 44px; padding-top: 20px; border-top: 1px solid var(--border); padding-left: 56px; }
@media (max-width: 720px) {
  .legaldoc .h { grid-template-columns: 30px 1fr; }
  .legaldoc .body, .legaldoc .updated { padding-left: 0; }
}
