/* ──────────────────────────────────────────────────────────────────────
   The Piercing Parlour — v4 Editorial · shared stylesheet
   Italiana display + Cormorant Garamond body, cream paper, brass trim.
   Imported by every v4 page. Each page may add small inline overrides.
   ────────────────────────────────────────────────────────────────────── */

:root{
  /* Dark, layered surfaces — the page is a slow gradient #141414 → #0a0a0a
     with a soft Tiffany glow over the top portion (set on <body>).        */
  --paper:        #0f0f0f;                /* legacy alias — solid surface  */
  --paper-dim:    #16161a;
  --paper-edge:   #1c1c20;

  /* Text — high-contrast Tiffany on dark, with cream fallback rhythm.    */
  --ink:          #9CE9F2;                /* primary text — Tiffany light */
  --ink-dim:      rgba(247,241,230,.84);  /* body copy in cream           */
  --ink-mute:     rgba(247,241,230,.62);
  --ink-faint:    rgba(247,241,230,.38);
  --ink-deep:     #F5EFE3;                /* sharpest headlines           */

  /* Ink for content sitting on the inverted cream card (Webster HQ).     */
  --ink-on-paper:       #088a86;
  --ink-on-paper-dim:   rgba(8,138,134,.74);
  --ink-on-paper-mute:  rgba(8,138,134,.52);
  --ink-on-paper-deep:  #16110D;

  --line:         rgba(247,241,230,.12);
  --line-strong:  rgba(247,241,230,.24);
  --line-gold:    rgba(217,191,118,.50);
  --line-aqua:    rgba(35,200,233,.45);
  --line-paper:   rgba(26,20,16,.16);

  --brass:        #D9BF76;
  --brass-soft:   rgba(217,191,118,.30);
  --tiffany:      #23C8E9;
  --tiffany-deep: #088a86;
  --tiffany-soft: rgba(35,200,233,.14);
  --aqua:         #23C8E9;

  --rev-bg:       #F5EFE3;                /* the one cream moment         */
  --rev-ink:      #16110D;
  --rev-mute:     rgba(22,17,13,.62);

  --display:  "Italiana", "Bodoni Moda", "Didot", serif;
  --serif:    "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sc:       "Cormorant SC", "Cormorant Garamond", serif;
}

*{ box-sizing: border-box; margin: 0; padding: 0; }
html, body{ color: var(--ink-dim); font-family: var(--serif); font-weight: 400; }
html{ background: linear-gradient(180deg, #141414, #0f0f0f 60%, #0a0a0a) fixed; min-height: 100%; }
body{ overflow-x: hidden; min-height: 100vh; background:
    linear-gradient(180deg, rgba(35,200,233,0.18), rgba(10,10,10,0) 55%),
    transparent; background-repeat: no-repeat; }

/* Subtle paper grain — visible only up close. */
body::before{
  content: ""; position: fixed; inset: 0; pointer-events: none;
  z-index: 1000; opacity: .065; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

a{ color: inherit; text-decoration: none; border-bottom: 1px solid var(--rule-strong); transition: border-color .2s ease, color .2s ease; padding-bottom: 1px; }
a:hover{ color: var(--brass); border-color: var(--brass); }
a.unstyled{ border-bottom: none; }
button{ font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
em, i{ font-style: italic; }

::selection{ background: var(--tiffany); color: #0a0a0a; }

.skip{ position: absolute; left: -9999px; top: 0; }
.skip:focus{ left: 16px; top: 16px; background: var(--ink); color: var(--paper); padding: 8px 14px; z-index: 9999; }

/* ── Type utilities ─────────────────────────────────────────── */
.display{ font-family: var(--display); font-weight: 400; letter-spacing: -0.01em; line-height: .92; }
.sc{ font-family: var(--sc); font-weight: 500; letter-spacing: 0.22em; text-transform: uppercase; }
.italic{ font-style: italic; font-family: var(--serif); }
.figure{ font-feature-settings: "lnum" 1; }

/* ── Masthead (top bar + section nav) ───────────────────────── */
.masthead{ position: sticky; top: 0; z-index: 50; background: rgba(15,15,15,.86); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid var(--rule-strong); }
.masthead-inner{ display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; padding: 10px 32px; }
.masthead .vol{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); }
.masthead .mid{ text-align: center; font-family: var(--display); font-size: 28px; line-height: 1; color: var(--ink); white-space: nowrap; }
.masthead .mid a{ border: none; color: inherit; padding: 0; }
.masthead .mid em{ font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--ink-mute); margin-right: 4px; vertical-align: 2px; font-weight: 400; }
.masthead .right{ text-align: right; font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); }

.section-nav{ border-top: 1px solid var(--rule); }
.section-nav-inner{ display: flex; align-items: center; justify-content: center; flex-wrap: wrap; padding: 9px 32px; gap: 0; }
.section-nav a{ font-family: var(--sc); font-size: 11px; letter-spacing: 0.26em; color: var(--ink-mute); border: none; padding: 4px 22px; position: relative; transition: color .15s; }
.section-nav a + a::before{ content: "·"; position: absolute; left: -2px; top: 50%; transform: translateY(-50%); color: var(--brass); opacity: .7; }
.section-nav a:hover{ color: var(--tiffany); }
.section-nav a.active{ color: var(--tiffany); }
.section-nav a.active::after{ content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: -10px; width: 18px; height: 2px; background: var(--brass); }
.section-nav .cta{ color: var(--ink-deep); border: 1px solid var(--ink-deep); padding: 6px 16px; margin-left: 8px; background: transparent; }
.section-nav .cta:hover{ background: var(--tiffany); border-color: var(--tiffany); color: #0a0a0a; }

/* Mobile nav toggle */
.nav-toggle{ display: none; }
@media (max-width: 760px){
  .masthead-inner{ grid-template-columns: 1fr auto; padding: 10px 18px; }
  .masthead .mid{ display: none; }
  .masthead .right{ display: none; }
  .nav-toggle{ display: flex; align-items: center; gap: 8px; font-family: var(--sc); font-size: 11px; letter-spacing: .22em; }
  .section-nav-inner{ flex-direction: column; padding: 16px 18px; gap: 8px; }
  .section-nav a + a::before{ display: none; }
  .section-nav.collapsed{ display: none; }
}

/* ── Page-hero (top of every inner page) ────────────────────── */
.page-hero{ padding: 88px 56px 64px; border-bottom: 1px solid var(--rule-strong); }
.page-hero .eyebrow{ font-family: var(--sc); font-size: 11px; letter-spacing: 0.34em; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.page-hero .eyebrow::before{ content: ""; display: inline-block; width: 36px; height: 1px; background: var(--brass); }
.page-hero h1{ font-family: var(--display); font-weight: 400; font-size: clamp(48px, 7.5vw, 104px); line-height: .92; letter-spacing: -0.02em; max-width: 16ch; }
.page-hero h1 em{ font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--ink-dim); }
.page-hero .lede{ font-family: var(--serif); font-style: italic; font-size: clamp(20px, 2vw, 26px); line-height: 1.45; color: var(--ink-dim); max-width: 640px; margin-top: 28px; }

/* ── Body sections ──────────────────────────────────────────── */
.section{ padding: 80px 56px; border-top: 1px solid var(--rule-strong); }
.section.no-rule{ border-top: none; }
.section.muted{ background: rgba(35,200,233,.04); }
.gutter{ max-width: 1180px; margin: 0 auto; }

.eyebrow{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); text-transform: uppercase; display: inline-block; }
.eyebrow.eyebrow-line::before{ content: ""; display: inline-block; vertical-align: middle; width: 28px; height: 1px; background: var(--brass); margin-right: 12px; }

.row-split{ display: grid; grid-template-columns: 240px 1fr; gap: 64px; }
.row-split .eyebrow-col{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.34em; color: var(--ink-mute); padding-top: 10px; }
.row-split .eyebrow-col em{ font-family: var(--serif); font-style: italic; font-size: 14px; text-transform: none; letter-spacing: 0; color: var(--ink-mute); display: block; margin-top: 8px; }
.row-split.flip{ grid-template-columns: 1fr 240px; }
.row-split.flip .eyebrow-col{ text-align: right; }

.head-xl{ font-family: var(--display); font-weight: 400; font-size: clamp(48px, 7.5vw, 104px); line-height: .92; letter-spacing: -0.02em; }
.head-xl em{ font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--ink-dim); }
.head-xl .aqua{ color: var(--aqua); font-family: var(--display); font-style: normal; }

.head-l{ font-family: var(--display); font-weight: 400; font-size: clamp(36px, 5vw, 64px); line-height: 1; letter-spacing: -0.01em; }
.head-l em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); }
.head-m{ font-family: var(--display); font-weight: 400; font-size: clamp(28px, 3.5vw, 40px); line-height: 1.05; letter-spacing: -0.01em; }

.lede{ font-family: var(--serif); font-size: clamp(19px, 1.7vw, 24px); line-height: 1.5; color: var(--ink-dim); max-width: 640px; }
.lede em{ color: var(--ink); }

/* ── Prose (used inside articles) ──────────────────────────── */
.prose{ max-width: 64ch; font-size: 17px; color: var(--ink-dim); line-height: 1.65; }
.prose h2{ font-family: var(--display); font-weight: 400; color: var(--ink); font-size: clamp(28px, 3vw, 40px); line-height: 1.1; letter-spacing: -0.01em; margin-top: 56px; margin-bottom: 18px; }
.prose h2:first-child{ margin-top: 0; }
.prose h3{ font-family: var(--display); font-weight: 400; color: var(--ink); font-size: 24px; line-height: 1.2; margin-top: 36px; margin-bottom: 12px; }
.prose p{ margin-bottom: 18px; }
.prose p > b, .prose p > strong, .prose li > b, .prose li > strong{ color: var(--ink); font-weight: 600; }
.prose ul, .prose ol{ margin-bottom: 20px; padding-left: 1.5em; }
.prose ul li, .prose ol li{ margin-bottom: 12px; }
.prose ul li::marker{ color: var(--brass); }
.prose ol li::marker{ font-family: var(--display); color: var(--brass); }
.prose a{ color: var(--ink); border-bottom: 1px solid var(--brass-soft); }
.prose a:hover{ color: var(--brass); border-color: var(--brass); }
.prose em{ font-style: italic; }

.callout{ background: rgba(217,191,118,.06); border-left: 2px solid var(--brass); padding: 18px 22px; margin: 24px 0; font-family: var(--serif); font-size: 16px; color: var(--ink-deep); line-height: 1.6; position: relative; }
.callout::before, .callout::after{ content: ""; position: absolute; left: 12px; right: 12px; height: 1px; background: var(--brass-soft); }
.callout::before{ top: 4px; } .callout::after{ bottom: 4px; }
.callout b{ color: var(--brass); }

/* ── Review proof blocks ─────────────────────────────────────── */
.review-proof{
  display:grid;
  grid-template-columns:.86fr 1.14fr;
  gap:32px;
  align-items:start;
  border-top:1px solid var(--ink-deep);
  border-bottom:1px solid var(--line-strong);
  padding:30px 0;
  margin:0 0 48px;
}
.review-proof.flush{ margin:48px 0 0; }
.review-proof .rp-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--sc);
  font-size:10px;
  letter-spacing:.30em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:14px;
}
.review-proof .rp-kicker::before{
  content:"";
  width:28px;
  height:1px;
  background:var(--brass);
  display:inline-block;
}
.review-proof .rp-line{
  font-family:var(--display);
  font-size:clamp(34px,4.5vw,58px);
  line-height:.98;
  letter-spacing:-.02em;
  color:var(--ink);
  max-width:10ch;
}
.review-proof .rp-line em{
  font-family:var(--serif);
  font-style:italic;
  color:var(--ink-dim);
}
.review-proof .rp-notes{ display:grid; gap:14px; }
.review-proof .rp-note{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.55;
  color:var(--ink-dim);
  border-bottom:1px dotted var(--line-strong);
  padding-bottom:14px;
}
.review-proof .rp-note:last-child{ border-bottom:none; padding-bottom:0; }
.review-proof .rp-note b{ color:var(--ink); font-weight:600; }
.review-proof .rp-source{
  font-family:var(--sc);
  font-size:9px;
  letter-spacing:.24em;
  color:var(--ink-mute);
  text-transform:uppercase;
  margin-top:4px;
}
.review-proof .rp-source a{
  color:var(--ink-mute);
  border-bottom:1px solid var(--brass-soft);
}

/* ── Tables ────────────────────────────────────────────────── */
.tbl{ width: 100%; border-collapse: collapse; margin: 14px 0 24px; font-size: 15px; }
.tbl thead th{ font-family: var(--sc); font-weight: 500; font-size: 10px; letter-spacing: .22em; color: var(--ink-mute); text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--ink-deep); }
.tbl tbody td{ padding: 14px 12px; border-bottom: 1px dotted var(--rule-strong); vertical-align: top; color: var(--ink-dim); }
.tbl tbody td:first-child{ color: var(--ink); font-family: var(--serif); font-style: italic; font-size: 17px; }
.tbl tbody tr:last-child td{ border-bottom: 1px solid var(--ink-deep); }

/* ── Aside / sticky kit card ────────────────────────────────── */
.aside-card{ position: sticky; top: 96px; background: rgba(247,241,230,.04); border: 1px solid var(--line-strong); padding: 24px 24px 26px; position: relative; }
.aside-card::before, .aside-card::after{ content: ""; position: absolute; left: 12px; right: 12px; height: 1px; background: var(--brass-soft); }
.aside-card::before{ top: 6px; } .aside-card::after{ bottom: 6px; }
.aside-card .eyebrow{ display: block; margin-bottom: 16px; }
.aside-card ul{ list-style: none; padding: 0; display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.aside-card ul li{ display: flex; gap: 10px; align-items: flex-start; font-size: 15px; color: var(--ink-dim); line-height: 1.4; }
.aside-card ul li::before{ content: ""; display: inline-block; width: 6px; height: 6px; margin-top: 8px; background: var(--brass); border-radius: 50%; flex-shrink: 0; }
.aside-card .actions{ display: flex; flex-direction: column; gap: 10px; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn{ display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-family: var(--sc); font-size: 11px; letter-spacing: 0.30em; padding: 13px 26px; border: 1px solid var(--ink-deep); cursor: pointer; transition: background .15s, color .15s, border-color .15s; text-align: center; line-height: 1; }
.btn.btn-lg{ font-size: 12px; padding: 16px 30px; }
.btn-primary{ background: var(--tiffany); color: var(--paper); border-color: var(--tiffany); }
.btn-primary:hover{ background: var(--tiffany-deep); color: var(--paper); border-color: var(--tiffany-deep); }
.btn-ghost{ background: transparent; color: var(--ink-deep); border-color: var(--line-strong); }
.btn-ghost:hover{ background: var(--ink-deep); color: #0a0a0a; border-color: var(--ink-deep); }
.btn-brass{ background: var(--brass); border-color: var(--brass); color: var(--paper); }
.btn-brass:hover{ background: transparent; color: var(--brass); }
.btn:disabled{ opacity: .35; cursor: not-allowed; }
a.btn{ border-bottom-width: 1px; padding-bottom: 13px; }
a.btn.btn-lg{ padding-bottom: 16px; }

/* CTA strip (call-to-action band at page bottom) */
.cta-strip{ padding: 88px 56px; background: var(--paper-dim); border-top: 1px solid var(--rule-strong); }
.cta-strip-inner{ display: flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; max-width: 1180px; margin: 0 auto; }
.cta-strip-actions{ display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Colophon (footer) ─────────────────────────────────────── */
.colophon{ padding: 56px 56px 88px; border-top: 1px solid var(--ink-deep); }
.colophon-grid{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; max-width: 1180px; margin: 0 auto; }
.colophon-mark{ font-family: var(--display); font-size: 36px; line-height: 1; margin-bottom: 12px; }
.colophon-mark em{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-mute); margin-right: 4px; vertical-align: 2px; font-weight: 400; }
.colophon-sub{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-mute); line-height: 1.55; max-width: 36ch; }
.colophon-col h5{ font-family: var(--sc); font-size: 10px; letter-spacing: .30em; color: var(--ink); margin-bottom: 12px; font-weight: 500; }
.colophon-col ul{ list-style: none; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.colophon-col ul li, .colophon-col ul li a{ font-family: var(--serif); font-size: 16px; color: var(--ink-dim); border: none; }
.colophon-col ul li a:hover{ color: var(--brass); }
.colophon-bottom{ margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; gap: 18px; font-family: var(--sc); font-size: 10px; letter-spacing: .26em; color: var(--ink-mute); flex-wrap: wrap; max-width: 1180px; margin-left: auto; margin-right: auto; }

@media (max-width: 980px){
  .row-split, .row-split.flip{ grid-template-columns: 1fr; gap: 18px; }
  .row-split.flip .eyebrow-col{ text-align: left; }
  .colophon-grid{ grid-template-columns: 1fr 1fr; gap: 32px; }
  .review-proof{ grid-template-columns:1fr; gap:22px; }
}
@media (max-width: 640px){
  .page-hero{ padding: 56px 24px 48px; }
  .section, .cta-strip, .colophon{ padding-left: 24px; padding-right: 24px; }
  .section{ padding-top: 56px; padding-bottom: 56px; }
  .colophon-grid{ grid-template-columns: 1fr; }
  .aside-card{ position: relative; top: auto; }
}

/* ── Piercer profile pattern (used by nicole.html, victoria.html) ─── */
.prof-hero{ display: grid; grid-template-columns: 1.2fr .8fr; gap: 48px; padding: 80px 56px 72px; border-bottom: 1px solid var(--rule-strong); align-items: end; }
.prof-eyebrow{ font-family: var(--sc); font-size: 11px; letter-spacing: .34em; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px; text-transform: uppercase; }
.prof-eyebrow::before{ content: ""; display: inline-block; width: 36px; height: 1px; background: var(--brass); }
.prof-name{ font-family: var(--serif); font-style: italic; font-weight: 400; font-size: clamp(96px, 13vw, 192px); line-height: .85; letter-spacing: -.03em; color: var(--ink); margin-bottom: 18px; }
.prof-meta{ display: flex; gap: 24px; align-items: baseline; font-family: var(--sc); font-size: 10px; letter-spacing: .22em; color: var(--ink-mute); text-transform: uppercase; padding-top: 18px; border-top: 1px solid var(--rule); flex-wrap: wrap; }
.prof-meta b{ color: var(--ink); font-family: var(--serif); font-style: italic; font-size: 17px; letter-spacing: 0; text-transform: none; font-weight: 400; margin-left: 6px; }
.prof-plate{ position: relative; aspect-ratio: 4/5; background: var(--paper-dim); border: 1px solid var(--rule-strong); display: flex; align-items: flex-end; justify-content: flex-start; padding: 28px; overflow: hidden; }
.prof-plate::before{ content: ""; position: absolute; inset: 14px; border: 1px solid var(--brass-soft); pointer-events: none; }
.prof-plate .ini{ font-family: var(--display); font-size: clamp(160px, 22vw, 220px); color: var(--ink); line-height: 1; }
.prof-plate .stamp{ position: absolute; top: 24px; right: 24px; font-family: var(--sc); font-size: 9px; letter-spacing: .30em; color: var(--ink-mute); }

.prof-essay{ display: grid; grid-template-columns: 240px 1fr; gap: 64px; }
.prof-essay .col-l{ font-family: var(--sc); font-size: 10px; letter-spacing: .34em; color: var(--ink-mute); padding-top: 12px; }
.prof-essay .col-l em{ font-family: var(--serif); font-style: italic; font-size: 14px; text-transform: none; letter-spacing: 0; color: var(--ink-mute); display: block; margin-top: 8px; }
.prof-essay h2{ font-family: var(--display); font-weight: 400; font-size: clamp(48px, 6vw, 80px); line-height: .95; letter-spacing: -.02em; margin-bottom: 24px; }
.prof-essay h2 em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); }
.prof-essay p{ font-family: var(--serif); font-size: 19px; line-height: 1.65; color: var(--ink-dim); margin-bottom: 20px; max-width: 56ch; }
.prof-essay p em{ color: var(--ink); }
.prof-essay .pull{ font-family: var(--display); font-size: clamp(28px, 3vw, 36px); line-height: 1.2; color: var(--ink); margin: 32px 0; padding-left: 32px; border-left: 2px solid var(--brass); letter-spacing: -.01em; }

.prof-known-tbl{ width: 100%; border-collapse: collapse; }
.prof-known-tbl tr{ border-bottom: 1px dotted var(--rule-strong); }
.prof-known-tbl tr:first-child{ border-top: 1px solid var(--ink-deep); }
.prof-known-tbl tr:last-child{ border-bottom: 1px solid var(--ink-deep); }
.prof-known-tbl td{ padding: 18px 0; vertical-align: baseline; }
.prof-known-tbl td:first-child{ font-family: var(--display); font-size: 26px; line-height: 1.1; color: var(--ink); width: 30%; padding-right: 24px; }
.prof-known-tbl td:first-child em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); display: block; font-size: 14px; margin-top: 4px; }
.prof-known-tbl td:last-child{ font-family: var(--serif); font-size: 16px; line-height: 1.55; color: var(--ink-dim); }

.prof-quotes{ display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.prof-q{ position: relative; padding-left: 32px; }
.prof-q::before{ content: "\201C"; position: absolute; left: 0; top: -16px; font-size: 56px; color: var(--brass); font-style: normal; line-height: 1; font-family: var(--display); }
.prof-q p{ font-family: var(--serif); font-style: italic; font-size: 21px; line-height: 1.45; color: var(--ink); margin-bottom: 14px; }
.prof-q .by{ font-family: var(--sc); font-size: 10px; letter-spacing: .22em; color: var(--ink-mute); display: flex; flex-wrap: wrap; gap: 8px; align-items: baseline; }
.prof-q .by .nm{ color: var(--ink); }
.prof-q .by .sep{ color: var(--brass); }

@media (max-width: 980px){
  .prof-hero{ grid-template-columns: 1fr; padding: 56px 24px 48px; }
  .prof-essay{ grid-template-columns: 1fr; gap: 18px; }
  .prof-quotes{ grid-template-columns: 1fr; }
}


/* ── Keyring palette system ──────────────────────────────────────
   Per-piercing keyring colorways. Each piercing point uses two layered
   rings (outer halo + inner core stroke) plus a center fill, creating
   a "keyring around a stud" look. Used in the planner and lookbook. */
:root{
  --kr-precision-a:#23c8e9; --kr-precision-b:#28239b;
  --kr-velocity-a:#42f977;  --kr-velocity-b:#24956b;
  --kr-sovereign-a:#a59523; --kr-sovereign-b:#ffb347;
  --kr-runtime-a:#c6207a;   --kr-runtime-b:#a334f3;
  --kr-critical-a:#e72020;  --kr-critical-b:#b05222;
}

/* Default — outer ring uses 'a' color, core dot uses 'b' color.
   Reverse modifier flips them. Apply as data-palette + optional .rev. */
.kr{ --kr-out:#9CE9F2; --kr-in:#0a0a0a; }
.kr[data-palette="precision"]{ --kr-out:var(--kr-precision-a); --kr-in:var(--kr-precision-b); }
.kr[data-palette="velocity"] { --kr-out:var(--kr-velocity-a);  --kr-in:var(--kr-velocity-b); }
.kr[data-palette="sovereign"]{ --kr-out:var(--kr-sovereign-a); --kr-in:var(--kr-sovereign-b); }
.kr[data-palette="runtime"]  { --kr-out:var(--kr-runtime-a);   --kr-in:var(--kr-runtime-b); }
.kr[data-palette="critical"] { --kr-out:var(--kr-critical-a);  --kr-in:var(--kr-critical-b); }
.kr.rev{ --kr-swap:var(--kr-out); --kr-out:var(--kr-in); --kr-in:var(--kr-swap); }

/* SVG visuals — three concentric layers per point */
.kr .halo { fill: var(--kr-out); opacity: .001; }
.kr .ring { fill: none; stroke: var(--kr-out); stroke-width: 1.6; }
.kr .core { fill: var(--kr-in); stroke: var(--kr-out); stroke-width: 1.2; }
.kr .label{ font-family: var(--serif); font-style: italic; font-size: 11px; fill: var(--ink-mute); opacity: 0; pointer-events: none; transition: opacity .15s; }
.kr .hit{ pointer-events: all; }

/* Interactive (planner) */
.kr.interactive,
.kr.interactive *{ cursor: pointer; pointer-events: all; }
.kr.interactive:focus{ outline: none; }
.kr.interactive:hover .halo,
.kr.interactive:focus .halo{ opacity: .18; }
.kr.interactive:hover .core,
.kr.interactive:focus .core{ fill: var(--kr-out); }
.kr.interactive:hover .label,
.kr.interactive:focus .label,
.kr.interactive.on .label{ opacity: 1; fill: var(--ink-deep); }
.kr.interactive.on .halo{ opacity: .35; }
.kr.interactive.on .ring{ stroke-width: 2.2; }
.kr.interactive.on .core{ fill: var(--kr-out); stroke: var(--kr-in); }


/* Lookbook-quiet override — keyring palette colors stay, but on the
   non-interactive lookbook ear diagrams the dots return to subtle marks.
   Only the interactive .kr.interactive (planner) shows the full effect. */
.ear-svg .ear-outline{ stroke-opacity: .55; stroke-width: 1.2; }
.ear-svg .ear-detail{ stroke-opacity: .35; }
.ear-svg .kr:not(.interactive) .halo{ opacity: 0 !important; }
.ear-svg .kr:not(.interactive) .ring{ stroke-width: 1; opacity: .85; }
.ear-svg .kr:not(.interactive) .core{ stroke-width: 0; }
