/* adri.css — drenched violet+coral, glitch typography, gen-Z energy */

:root {
  --d-bg:      oklch(0.16 0.13 285);
  --d-bg-2:    oklch(0.22 0.13 285);
  --d-ink:     oklch(0.97 0.02 285);
  --d-mute:    oklch(0.74 0.05 285);
  --d-coral:   oklch(0.72 0.22 25);
  --d-violet:  oklch(0.55 0.25 305);
  --d-cyan:    oklch(0.78 0.18 200);
  --d-magenta: oklch(0.65 0.30 340);
}

html, body { background: var(--d-bg); color: var(--d-ink); }

.hero {
  position: relative;
  min-height: 100dvh;
  display: grid;
  place-content: center;
  text-align: center;
  isolation: isolate;
  padding: var(--space-5) var(--space-3);
  overflow: hidden;
}
.hero canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: -1;
  opacity: 0.85;
}

.hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--d-coral);
  margin-bottom: var(--space-3);
  opacity: 0;
  animation: fadein 900ms var(--ease-out-expo) 200ms forwards;
}

/* Glitch headline — chromatic aberration via text-shadow, NOT background-clip:text */
.hero__name {
  font-family: var(--font-body);
  font-weight: 900;
  font-size: clamp(var(--type-9), 13vw, 8rem);
  line-height: 0.88;
  letter-spacing: -0.04em;
  margin: 0;
  color: var(--d-ink);
  text-shadow:
    0.05em 0 0 var(--d-cyan),
    -0.05em 0 0 var(--d-magenta);
  opacity: 0;
  animation: rise 1100ms var(--ease-out-expo) 300ms forwards, glitch-shift 6s var(--ease-out-quart) 2.5s infinite;
}

.hero__role {
  font-family: var(--font-mono);
  font-size: var(--type-3);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--d-mute);
  margin-top: var(--space-3);
  opacity: 0;
  animation: rise 1100ms var(--ease-out-expo) 500ms forwards;
}
.hero__role span { color: var(--d-coral); }

.section {
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-4) var(--space-5);
  position: relative;
}
.section__num {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--d-coral);
  margin-bottom: var(--space-3);
}
.section__title {
  font-family: var(--font-body);
  font-weight: 900;
  font-size: clamp(var(--type-7), 6vw, var(--type-9));
  line-height: 0.94;
  letter-spacing: -0.025em;
  margin: 0 0 var(--space-4);
}
.section__lead {
  font-size: var(--type-4);
  max-width: 56ch;
  color: var(--d-mute);
  margin-bottom: var(--space-4);
}

/* What I do — angular ticker rows */
.skills {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
}
.skills li {
  padding: var(--space-3) 0;
  border-top: 1px solid oklch(0.40 0.06 305 / 0.5);
  display: grid;
  grid-template-columns: 5ch 1fr auto;
  gap: var(--space-3);
  align-items: baseline;
  cursor: default;
  transition: padding-left 350ms var(--ease-out-quart), color 250ms;
}
.skills li:last-child { border-bottom: 1px solid oklch(0.40 0.06 305 / 0.5); }
.skills li b {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.2em;
  color: var(--d-coral);
}
.skills li h3 {
  font-family: var(--font-body);
  font-weight: 800;
  font-size: clamp(var(--type-5), 3vw, var(--type-7));
  margin: 0;
  letter-spacing: -0.015em;
}
.skills li small {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--d-mute);
  text-align: right;
}
.skills li:hover { padding-left: 1.5rem; color: var(--d-coral); }
.skills li:hover h3 { color: var(--d-coral); }

/* Projects — diagonal cards w/ chromatic hover */
.projects {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-3);
}
.projects article {
  background: var(--d-bg-2);
  padding: var(--space-3) var(--space-3) var(--space-4);
  border: 1px solid oklch(0.40 0.06 305 / 0.5);
  position: relative;
  transition: transform 500ms var(--ease-out-quart), border-color 350ms;
  overflow: hidden;
}
.projects article:hover {
  transform: translateY(-4px);
  border-color: var(--d-coral);
}
.projects article::after {
  content: "";
  position: absolute; right: -20px; top: -20px;
  width: 100px; height: 100px;
  background: var(--d-coral);
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  opacity: 0.18;
  transition: opacity 350ms, transform 600ms var(--ease-out-expo);
}
.projects article:hover::after { opacity: 0.45; transform: scale(1.3) rotate(-8deg); }
.projects article h3 {
  font-weight: 900;
  font-size: var(--type-5);
  margin: 0 0 var(--space-1);
  letter-spacing: -0.015em;
}
.projects article p { color: var(--d-mute); margin: 0; font-size: var(--type-3); }
.projects article .tags {
  margin-top: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--d-coral);
}

/* Vision quote-block */
.vision {
  padding: var(--space-5) 0;
  border-top: 1px solid oklch(0.40 0.06 305 / 0.4);
  border-bottom: 1px solid oklch(0.40 0.06 305 / 0.4);
}
.vision blockquote {
  margin: 0;
  font-weight: 700;
  font-size: clamp(var(--type-5), 3vw, var(--type-7));
  line-height: 1.2;
  letter-spacing: -0.015em;
  max-width: 28ch;
}
.vision blockquote span { color: var(--d-coral); }

.contacts {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--type-3);
  margin-top: var(--space-3);
}
.contacts a {
  text-decoration: none;
  border-bottom: 1px solid oklch(0.40 0.06 305 / 0.6);
  padding-bottom: 2px;
  transition: border-color 250ms var(--ease-out-quart), color 250ms var(--ease-out-quart);
}
.contacts a:hover { border-bottom-color: var(--d-coral); color: var(--d-coral); }
.contacts a small { display: block; font-size: var(--type-1); color: var(--d-mute); letter-spacing: 0.15em; text-transform: uppercase; margin-bottom: 2px; }

footer.foot {
  padding: var(--space-5) var(--space-4) var(--space-4);
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--d-mute);
}
footer.foot a { color: var(--d-coral); text-decoration: none; }

@keyframes fadein { to { opacity: 1; } }
@keyframes rise { to { opacity: 1; transform: translateY(0); } from { opacity: 0; transform: translateY(12px); } }
@keyframes glitch-shift {
  0%, 100% { text-shadow: 0.05em 0 0 var(--d-cyan), -0.05em 0 0 var(--d-magenta); }
  20%      { text-shadow: 0.08em 0 0 var(--d-cyan), -0.08em 0 0 var(--d-magenta); transform: translateY(-1px); }
  21%      { text-shadow: -0.04em 0 0 var(--d-cyan), 0.04em 0 0 var(--d-magenta); transform: translateY(0); }
  40%      { text-shadow: 0.05em 0 0 var(--d-cyan), -0.05em 0 0 var(--d-magenta); }
}

.reveal { opacity: 0; transform: translateY(20px); transition: opacity 900ms var(--ease-out-expo), transform 900ms var(--ease-out-expo); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── Section subtitle (reused inside sections) ─────────────── */
.section__subtitle {
  font-family: var(--font-body);
  font-weight: 900;
  font-size: clamp(var(--type-5), 3vw, var(--type-7));
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: var(--space-5) 0 var(--space-3);
}

/* ── About prose with drop-cap ─────────────────────────────── */
.prose {
  max-width: 64ch;
  font-size: var(--type-4);
  line-height: 1.65;
  color: var(--d-ink);
}
.prose p { margin: 0 0 var(--space-3); }
.prose p:first-of-type::first-line { font-weight: 600; }
.prose p:first-of-type::first-letter {
  font-family: var(--font-body);
  font-weight: 900;
  font-size: 3.6em;
  line-height: 0.9;
  float: left;
  margin: 0.08em 0.12em -0.06em 0;
  color: var(--d-coral);
}

/* ── Case study layout ─────────────────────────────────────── */
.case {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: var(--space-5);
  align-items: start;
}
@media (max-width: 900px) { .case { grid-template-columns: 1fr; gap: var(--space-4); } }
.case__rail {
  position: sticky; top: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--d-mute);
  display: grid;
  gap: var(--space-2);
}
.case__rail b { color: var(--d-coral); font-weight: 700; letter-spacing: 0.18em; }
.case__rail .meta { display: grid; gap: 0.3em; padding: var(--space-2) 0; border-top: 1px solid oklch(0.40 0.06 285 / 0.5); }
.case__rail .meta dt { color: var(--d-mute); }
.case__rail .meta dd { color: var(--d-ink); margin: 0; font-family: var(--font-body); text-transform: none; letter-spacing: 0; font-size: var(--type-3); }
.case__body h3 {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--d-coral);
  margin: var(--space-4) 0 var(--space-2);
}
.case__body h3:first-of-type { margin-top: 0; }
.case__body p { font-size: var(--type-4); line-height: 1.65; margin: 0 0 var(--space-2); color: var(--d-ink); }
.case__pull {
  margin: var(--space-4) 0;
  padding-left: var(--space-3);
  border-left: 3px solid var(--d-coral);
  font-family: var(--font-body);
  font-size: var(--type-6);
  line-height: 1.25;
  font-weight: 800;
  color: var(--d-ink);
  letter-spacing: -0.01em;
}
.case__pull cite { display: block; margin-top: var(--space-1); font-family: var(--font-mono); font-style: normal; font-size: var(--type-1); letter-spacing: 0.16em; text-transform: uppercase; color: var(--d-mute); }

/* ── Workflow numbered steps ──────────────────────────────── */
.steps { list-style: none; padding: 0; margin: var(--space-3) 0 0; counter-reset: step; }
.steps li {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-top: 1px solid oklch(0.40 0.06 285 / 0.5);
  align-items: baseline;
  font-size: var(--type-3);
  counter-increment: step;
}
.steps li::before {
  content: counter(step, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: var(--type-2);
  letter-spacing: 0.08em;
  color: var(--d-coral);
  font-weight: 700;
}

/* ── Anti-list (what I don't do) ──────────────────────────── */
.antilist { list-style: none; padding: 0; margin: 0; }
.antilist li {
  font-size: var(--type-4);
  padding: var(--space-2) 0;
  border-top: 1px solid oklch(0.40 0.06 285 / 0.5);
  display: grid;
  grid-template-columns: 2em 1fr;
  gap: var(--space-2);
  align-items: baseline;
}
.antilist li::before {
  content: "✕";
  color: var(--d-coral);
  font-family: var(--font-mono);
  font-weight: 700;
  text-align: center;
}

/* ── Availability grid ─────────────────────────────────────── */
.availability {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3);
  margin: var(--space-3) 0 0;
}
.availability > div {
  border-top: 1px solid var(--d-coral);
  padding-top: var(--space-2);
}
.availability dt {
  font-family: var(--font-mono);
  font-size: var(--type-1);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--d-mute);
  margin-bottom: var(--space-1);
}
.availability dd { margin: 0; font-size: var(--type-4); line-height: 1.45; color: var(--d-ink); }
.availability dd b { color: var(--d-coral); font-weight: 800; }
