:root {
  /* matched to vishkul.com portfolio tokens */
  --bg:        #0b0b0d;
  --surface:   #141418;
  --surface-2: #17171c;
  --bg-soft:   #111114;
  --border:    #26262b;
  --border-2:  #34343b;
  --text:      #f2f1ee;
  --dim:       #a3a29c;
  --dimmer:    #6b6a64;
  --accent:    #ff2d78;
  --accent-soft:#ff5e96;
  --accent-dim:rgba(255,45,120,0.10);
  --accent-line:rgba(255,45,120,0.30);
  --green:     #3ddc84;
  --amber:     #febc2e;
  --red:       #ff4d4d;
  --mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --display: "Space Grotesk", system-ui, sans-serif;
  --body:    "Inter", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

/* terminal default stays mono; prose elements opt into Inter, headings into Space Grotesk */
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--mono);
  font-size: 15px;
  line-height: 1.6;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
  background-image:
    linear-gradient(rgba(255,255,255,0.012) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 32px 32px;
}

a { color: inherit; text-decoration: none; }
::selection { background: var(--accent); color: #0b0b0d; }

.wrap { max-width: 780px; margin: 0 auto; padding: 0 26px; }

/* pink highlight, like the portfolio h1 .mark */
.mark { background: var(--accent); color: #0b0b0d; padding: 0 .12em;
  -webkit-box-decoration-break: clone; box-decoration-break: clone; }

/* ---- top nav ---- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 0; border-bottom: 1px solid var(--border);
}
.brand { font-size: 14px; color: var(--dim); display: flex; align-items: center; gap: 8px; }
.brand b { color: var(--text); font-weight: 700; }
.brand .accent { color: var(--accent); }
.brand .blink { width: 8px; height: 15px; background: var(--accent); display: inline-block;
  animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
.topbar .back { font-size: 13px; color: var(--dimmer); transition: color .18s; }
.topbar .back:hover { color: var(--accent); }

a:focus-visible, button:focus-visible, input:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 2px;
}

/* ---- terminal window chrome ---- */
.term { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.term-head {
  display: flex; align-items: center; gap: 8px; padding: 11px 14px;
  background: var(--bg-soft); border-bottom: 1px solid var(--border);
  font-size: 12px; color: var(--dimmer);
}
.dot { width: 11px; height: 11px; border-radius: 50%; background: var(--border-2); }
.term-path { margin-left: 8px; color: var(--dim); }
.term-path .accent { color: var(--accent); }
.term-body { padding: 22px; }

.prompt { color: var(--green); }
.muted { color: var(--dim); }
.dimmer { color: var(--dimmer); }

.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}
.mt28{margin-top:28px}.mt40{margin-top:40px}.mt56{margin-top:56px}
.small{font-size:13px}.tiny{font-size:12px}

@media (max-width: 560px) {
  body { font-size: 14px; }
  .wrap { padding: 0 18px; }
  .term-body { padding: 16px; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
