/* ============================================================
   components.css — design refresh
   
   All component patterns re-skinned in the Stitch design language.
   Class names match the original system so existing HTML continues
   to work without changes.
   ============================================================ */


/* ============================================================
   CORNER FRAME — kept for editorial feel, refined hairlines
   ============================================================ */
.frame {
  position: fixed;
  inset: 12px;
  pointer-events: none;
  z-index: 100;
}
.frame .c {
  position: absolute;
  width: 16px;
  height: 16px;
  border: 1px solid var(--rivet);
  opacity: 0.6;
}
.frame .tl { top: 0;    left: 0;    border-right: none; border-bottom: none; }
.frame .tr { top: 0;    right: 0;   border-left: none;  border-bottom: none; }
.frame .bl { bottom: 0; left: 0;    border-right: none; border-top: none; }
.frame .br { bottom: 0; right: 0;   border-left: none;  border-top: none; }


/* ============================================================
   STATUS BAR — top thin strip with live indicator
   ============================================================ */
.statusbar {
  position: relative;
  z-index: 30;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--s-5);
  padding: 10px var(--s-7);
  background: var(--abyss-2);
  border-bottom: 1px solid var(--rivet);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
}
.statusbar .left,
.statusbar .right {
  display: flex;
  align-items: center;
  gap: var(--s-5);
}
.statusbar .right { justify-content: flex-end; }
.statusbar .center { text-align: center; }

/* Live indicator with pulsing pip */
.statusbar .live {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  color: var(--signal);
}
.statusbar .live .pip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--signal);
  box-shadow: 0 0 8px rgba(255, 198, 64, 0.5);
  animation: breathe var(--d-breathe) ease-in-out infinite;
}
@keyframes breathe {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.45; }
}

.statusbar .clk { color: var(--paper-dim); }


/* ============================================================
   DOMAIN TICKER — horizontally scrolling track
   ============================================================ */
.ticker {
  position: relative;
  z-index: 25;
  overflow: hidden;
  background: var(--abyss);
  border-bottom: 1px solid var(--rivet);
  padding: 10px 0;
}
.ticker .ticker-track {
  display: inline-block;
  white-space: nowrap;
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-lg);
  color: var(--paper-dim);
  animation: marquee var(--d-marquee) linear infinite;
  padding-left: 100%;
}
/* Three accent bands inside the ticker — keep the colour vocabulary
   consistent with the rest of the site:
     .d  = domain words      → waterline (sky blue)
     .l  = live / current    → signal (amber)
     .w  = emphasised phrase → paper (bright cream)
     .m  = separators        → paper-mute (quiet) */
.ticker .ticker-track .d { color: var(--waterline); }
.ticker .ticker-track .l { color: var(--signal); }
.ticker .ticker-track .w { color: var(--paper); }
.ticker .ticker-track .m { color: var(--paper-mute); margin: 0 var(--s-3); }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-100%); }
}


/* ============================================================
   PRIMARY NAV
   ============================================================ */
nav.primary {
  position: sticky;
  top: 0;
  z-index: 40;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-7);
  padding: var(--s-4) var(--s-7);
  background: rgba(17, 20, 23, 0.85);
  backdrop-filter: blur(var(--surface-blur));
  -webkit-backdrop-filter: blur(var(--surface-blur));
  border-bottom: 1px solid var(--rivet);
}
nav.primary .brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 20px;
  color: var(--paper);
}
nav.primary .brand em {
  font-style: italic;
  font-weight: 400;
  color: var(--waterline);
  margin-left: 4px;
}
nav.primary .brand-glyph {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 1px solid var(--waterline);
  transform: rotate(45deg);
  position: relative;
}
nav.primary .brand-glyph::after {
  content: '';
  position: absolute;
  inset: 4px;
  background: var(--waterline);
}

nav.primary ul {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: var(--s-7);
}
nav.primary ul a {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
  transition: color var(--d-base) var(--ease-out),
              border-color var(--d-base) var(--ease-out);
}
nav.primary ul a:hover { color: var(--paper); }
nav.primary ul a.active {
  color: var(--waterline);
  border-bottom-color: var(--waterline);
}

nav.primary .nav-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 10px var(--s-4);
  border: 1px solid var(--rivet);
  border-radius: var(--r-md);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-dim);
  transition: all var(--d-base) var(--ease-out);
}
nav.primary .nav-cta:hover {
  border-color: rgba(123, 209, 250, 0.4);
  color: var(--paper);
}
nav.primary .nav-cta em {
  font-style: normal;
  color: var(--paper-mute);
  transition: color var(--d-base);
}
nav.primary .nav-cta:hover em { color: var(--waterline); }


/* ============================================================
   HERO — home page
   The particle canvas is layered into the hero section via the
   home page HTML; this provides the layout shell.
   ============================================================ */
main .hero {
  position: relative;
  z-index: 2;
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-11) var(--s-7) var(--s-9);
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 1fr);
  gap: var(--s-8);
  align-items: center;
  min-height: calc(100vh - 120px);
}

.hero .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--mono);
  font-size: var(--t-eyebrow);
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--waterline);
  margin-bottom: var(--s-5);
}
.hero .eyebrow::before {
  content: '';
  width: 40px;
  height: 1px;
  background: var(--waterline-bright);
  opacity: 0.5;
}

.hero h1 {
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--t-h1);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--paper);
  margin-bottom: var(--s-6);
}
.hero h1 em {
  font-style: italic;
  color: var(--waterline);
  font-weight: 400;
}

.hero .tagline {
  font-family: var(--sans);
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.5;
  color: var(--paper-dim);
  margin-bottom: var(--s-5);
  max-width: 60ch;
}
.hero .tagline em {
  font-style: italic;
  color: var(--paper);
}

.hero .lede {
  font-family: var(--mono);
  font-size: 13px;
  line-height: 1.7;
  color: var(--paper-mute);
  max-width: 55ch;
}
.hero .lede .accent { color: var(--waterline); }


/* ============================================================
   META CARD — file-style key/value summary
   Glassmorphic in the refresh.
   ============================================================ */
.meta-card {
  background: var(--surface-glass);
  backdrop-filter: blur(var(--surface-blur));
  -webkit-backdrop-filter: blur(var(--surface-blur));
  border: 1px solid var(--rivet);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  position: relative;
  transition: border-color var(--d-base) var(--ease-out),
              box-shadow var(--d-base) var(--ease-out);
}
.meta-card:hover {
  border-color: rgba(123, 209, 250, 0.25);
  box-shadow: 0 0 32px rgba(123, 209, 250, 0.08);
}

.meta-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: var(--s-5);
  right: var(--s-5);
  height: 1px;
  background: linear-gradient(to right, transparent, var(--waterline), transparent);
  opacity: 0.4;
}

.meta-card .file-id {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: var(--s-4);
  margin-bottom: var(--s-5);
  border-bottom: 1px solid var(--rivet);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--waterline);
}
.meta-card .file-id .pip {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--signal);
  box-shadow: 0 0 8px rgba(255, 198, 64, 0.6);
  animation: breathe var(--d-breathe) ease-in-out infinite;
}

.meta-card .row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--s-4);
  align-items: baseline;
  padding: var(--s-3) 0;
  border-bottom: 1px dashed var(--rivet);
}
.meta-card .row:last-child { border-bottom: none; }

.meta-card .row .k {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
}
.meta-card .row .v {
  font-family: var(--serif);
  font-size: 17px;
  color: var(--paper);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.meta-card .row .v.accent { color: var(--waterline); }
.meta-card .row .v small {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
}
.meta-card .row .v.domains-list {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
}
.meta-card .row .v.domains-list small { color: var(--paper-dim); }


/* ============================================================
   SECTION HEADER
   ============================================================ */
.sec-head {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-7);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: var(--s-5);
  border-top: 1px solid var(--rivet);
  border-bottom: 1px solid var(--rivet);
}
.sec-head .num {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
}
.sec-head h2 {
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--t-h2);
  letter-spacing: -0.02em;
  color: var(--paper);
}
.sec-head h2 em {
  font-style: italic;
  font-weight: 400;
  color: var(--waterline);
}
.sec-head .meta {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
}


/* ============================================================
   PLACEHOLDER RIBBON
   ============================================================ */
.placeholder-ribbon {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-5) var(--s-7) 0;
  display: flex;
  justify-content: flex-end;
}
.placeholder-ribbon .tag {
  display: inline-block;
  padding: 6px var(--s-3);
  border: 1px dashed rgba(255, 198, 64, 0.5);
  border-radius: var(--r-sm);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--signal);
}


/* ============================================================
   EXPERIENCE / THE ARC
   ============================================================ */
.experience {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-7);
}
.exp-intro {
  font-family: var(--serif);
  font-size: var(--t-prose);
  line-height: 1.65;
  color: var(--paper-dim);
  max-width: 80ch;
  margin-bottom: var(--s-9);
}
.exp-intro em {
  font-style: italic;
  color: var(--paper);
}

.exp-list {
  display: flex;
  flex-direction: column;
}

.exp-row {
  position: relative;
  display: grid;
  grid-template-columns: 140px 1fr 200px 80px;
  gap: var(--s-5);
  padding: var(--s-6) var(--s-3);
  border-top: 1px solid var(--rivet);
  transition: background var(--d-base) var(--ease-out);
}
.exp-row:last-child { border-bottom: 1px solid var(--rivet); }
.exp-row:hover { background: rgba(255, 255, 255, 0.015); }
.exp-row:hover::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--waterline);
}

.exp-row.current::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--signal);
}

.exp-row .yr {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
  padding-top: 4px;
}

.exp-row .body h3 {
  font-family: var(--serif);
  font-weight: 600;
  font-size: var(--t-h3);
  color: var(--paper);
  margin-bottom: 4px;
}
.exp-row .body h3 em {
  font-style: italic;
  font-weight: 400;
  color: var(--waterline);
}
.exp-row .body .role {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
  margin-bottom: var(--s-3);
}
.exp-row .body .note {
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  color: var(--paper-dim);
  max-width: 65ch;
  margin-bottom: var(--s-4);
}
.exp-row .body .note em {
  font-style: italic;
  color: var(--paper);
}

.exp-row .promo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
  align-items: start;
  padding: var(--s-3) 0;
  border-top: 1px dashed var(--rivet);
  max-width: 380px;
}
.exp-row .promo > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.exp-row .promo > div + div {
  padding-left: var(--s-5);
  border-left: 1px dashed var(--rivet);
}
.exp-row .promo .label {
  font-family: var(--mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
}
.exp-row .promo .val {
  font-family: var(--serif);
  font-size: 15px;
  color: var(--paper);
}
.exp-row .promo .val.fast { color: var(--waterline); }
.exp-row .promo .val.typical { color: var(--paper-dim); }

.exp-row .marker {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  align-items: flex-start;
}
.exp-row .marker .badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--r-sm);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  border: 1px solid var(--rivet);
  color: var(--paper-dim);
}
.exp-row .marker .badge.fast {
  border-color: rgba(123, 209, 250, 0.4);
  color: var(--waterline);
}
.exp-row .marker .badge.young {
  border-color: rgba(255, 198, 64, 0.4);
  color: var(--signal);
}
.exp-row .marker .note {
  font-family: var(--mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
}

.exp-row .status {
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
  text-align: right;
  padding-top: 4px;
}
.exp-row .status .v {
  color: var(--paper-dim);
}
.exp-row.current .status .v {
  color: var(--signal);
}


/* ============================================================
   WORK
   ============================================================ */
.work {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-7);
}
.work-intro {
  font-family: var(--serif);
  font-size: var(--t-prose);
  line-height: 1.65;
  color: var(--paper-dim);
  max-width: 80ch;
  margin-bottom: var(--s-8);
}
.work-intro em {
  font-style: italic;
  color: var(--paper);
}

.work-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
}

.work-card {
  background: var(--surface-glass);
  backdrop-filter: blur(var(--surface-blur));
  -webkit-backdrop-filter: blur(var(--surface-blur));
  border: 1px solid var(--rivet);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  position: relative;
  overflow: hidden;
  transition: all var(--d-base) var(--ease-out);
}
.work-card:hover {
  border-color: rgba(123, 209, 250, 0.3);
  background: var(--surface-glass-strong);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2),
              0 0 24px rgba(123, 209, 250, 0.08);
}

.work-card .meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--s-4);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
}
.work-card .meta .live-tag {
  color: var(--signal);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.work-card .meta .live-tag::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--signal);
  box-shadow: 0 0 8px rgba(255, 198, 64, 0.6);
  animation: breathe var(--d-breathe) ease-in-out infinite;
}

.work-card h3 {
  font-family: var(--serif);
  font-weight: 600;
  font-size: var(--t-h3);
  color: var(--paper);
  margin-bottom: 4px;
}
.work-card h3 em {
  font-style: italic;
  font-weight: 400;
  color: var(--waterline);
}
.work-card .role {
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
  margin-bottom: var(--s-4);
}
.work-card .desc {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.6;
  color: var(--paper-dim);
  margin-bottom: var(--s-5);
}

.work-card .metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px dashed var(--rivet);
}
.work-card .metric .big {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 26px;
  color: var(--waterline);
  line-height: 1;
  margin-bottom: 6px;
}
.work-card .metric .lbl {
  font-family: var(--mono);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
}

.work-card .scope {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  padding-top: var(--s-4);
  border-top: 1px dashed var(--rivet);
}
.work-card .scope .scope-item {
  display: inline-block;
  padding: 4px 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--rivet);
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-dim);
}

/* ----- LIVE card (Reveleer) overrides ----- */
/* The italic brand name picks up the warm signal colour, reinforcing
   the "currently / in flight" character of this card. */
.work-card.live h3 em {
  color: var(--signal);
}
/* Scope items get a small amber pip before their text, mirroring the
   live indicator language used throughout the site. */
.work-card.live .scope .scope-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.work-card.live .scope .scope-item::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--signal);
  flex-shrink: 0;
}


/* ============================================================
   WRITING (teaser / empty state)
   ============================================================ */
.writing-teaser {
  max-width: var(--max-content);
  margin: 0 auto;
  padding: var(--s-7);
}
.writing-empty {
  border: 1px dashed var(--rivet);
  border-radius: var(--r-lg);
  padding: var(--s-9) var(--s-7);
  text-align: center;
  background: var(--surface-glass);
  backdrop-filter: blur(var(--surface-blur));
  -webkit-backdrop-filter: blur(var(--surface-blur));
}
.writing-empty .tag {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-md);
  color: var(--paper-mute);
  margin-bottom: var(--s-4);
}
.writing-empty p {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 20px;
  color: var(--paper-dim);
  line-height: 1.5;
  max-width: 50ch;
  margin: 0 auto;
}
.writing-empty p em {
  font-style: italic;
  color: var(--paper);
}


/* ============================================================
   FOOTER
   ============================================================ */
footer {
  max-width: var(--max-content);
  margin: var(--s-10) auto 0;
  padding: var(--s-7);
  border-top: 1px solid var(--rivet);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-5);
  font-family: var(--mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--ls-mono-sm);
  color: var(--paper-mute);
}
footer a {
  color: var(--paper-dim);
  transition: color var(--d-base);
}
footer a:hover { color: var(--waterline); }
footer .right {
  display: flex;
  align-items: center;
  gap: var(--s-5);
}


/* ============================================================
   PARTICLE CANVAS — sits behind the hero
   ============================================================ */
#particleCanvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

main .hero { position: relative; }
main .hero > * { position: relative; z-index: 2; }


/* ============================================================
   RESPONSIVE — mobile collapse
   ============================================================ */
@media (max-width: 880px) {
  .statusbar {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .statusbar .left,
  .statusbar .right { justify-content: center; }
  .statusbar .center { display: none; }

  nav.primary {
    grid-template-columns: 1fr auto;
    gap: var(--s-4);
    padding: var(--s-3) var(--s-5);
  }
  nav.primary ul { display: none; }

  main .hero {
    grid-template-columns: 1fr;
    padding: var(--s-9) var(--s-5);
    gap: var(--s-6);
  }

  .sec-head {
    padding: var(--s-5);
  }
  .experience,
  .work,
  .writing-teaser {
    padding: var(--s-5);
  }

  .exp-row {
    grid-template-columns: 1fr;
    gap: var(--s-3);
  }
  .exp-row .marker,
  .exp-row .status {
    text-align: left;
  }

  .work-grid {
    grid-template-columns: 1fr;
  }

  footer {
    flex-direction: column;
    gap: var(--s-4);
    padding: var(--s-5);
  }
}
