:root {
  --bg: #0b0f14;
  --panel: #0d171c;
  --panel-2: #121f25;
  --text: #edf7f5;
  --muted: #9cb2b0;
  --line: #253941;
  --green: #44d7a8;
  --cyan: #61b5ff;
  --danger: #ff5570;
  --warn: #ffd166;
  --radius: 8px;
  --shadow: 0 20px 70px rgba(0, 0, 0, .32);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    linear-gradient(180deg, rgba(97,181,255,.08), transparent 380px),
    linear-gradient(90deg, rgba(68,215,168,.06), transparent 46%),
    var(--bg);
  color: var(--text);
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
main { min-height: 72vh; }
:focus-visible { outline: 3px solid rgba(97,181,255,.72); outline-offset: 3px; }
.skip-link {
  position: fixed; left: 18px; top: 12px; z-index: 100; transform: translateY(-140%);
  background: var(--text); color: #071014; padding: 9px 12px; border-radius: var(--radius); font-weight: 800;
}
.skip-link:focus { transform: translateY(0); }
.site-header, .site-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 20px clamp(18px, 5vw, 72px);
  border-bottom: 1px solid var(--line);
  background: rgba(7,16,20,.86); backdrop-filter: blur(16px);
  position: sticky; top: 0; z-index: 20;
}
.site-footer { position: static; border-top: 1px solid var(--line); border-bottom: 0; color: var(--muted); }
.brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 800; letter-spacing: 0; }
.brand-mark { width: 13px; height: 13px; border-radius: 50%; background: linear-gradient(135deg, var(--green), var(--cyan)); box-shadow: 0 0 0 5px rgba(68,215,168,.11); }
.site-nav, .footer-links, .social-links { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.site-nav a, .footer-links a, .social-links a { color: var(--muted); font-weight: 750; padding: 8px 10px; border-radius: var(--radius); }
.site-nav a:hover, .footer-links a:hover, .social-links a:hover, .site-nav a[aria-current="page"] { color: var(--text); background: rgba(255,255,255,.06); }
.nav-admin { border: 1px solid var(--line); background: rgba(255,255,255,.03); }
.nav-toggle { display: none; width: 42px; height: 38px; background: var(--panel); color: var(--text); border: 1px solid var(--line); border-radius: var(--radius); padding: 8px; cursor: pointer; }
.nav-toggle span { display: block; height: 2px; width: 100%; margin: 4px 0; background: var(--text); border-radius: 999px; }
.hero, .framework-hero {
  min-height: 84vh; display: grid; grid-template-columns: minmax(0, 1.06fr) minmax(320px, .94fr); gap: clamp(28px, 5vw, 64px); align-items: center;
  padding: clamp(48px, 8vw, 110px) clamp(18px, 5vw, 72px);
}
.framework-hero {
  background: linear-gradient(135deg, rgba(97,181,255,.09), rgba(68,215,168,.03) 48%, transparent);
  align-items: start;
  padding-top: clamp(26px, 4vw, 48px);
  padding-bottom: clamp(34px, 5vw, 72px);
}
.framework-hero h1 {
  font-size: clamp(1.85rem, 3.2vw, 3.65rem);
  white-space: nowrap;
  margin-bottom: 86px;
}

.framework-hero .lead {
  margin-top: 0;
}

.framework-description {
  max-width: 1080px;
  padding: 16px 18px;
  border-left: 3px solid var(--ubuntu);
  border-radius: var(--radius);
  background:
    linear-gradient(90deg, rgba(233,84,32,.1), rgba(48,10,36,.24), transparent);
  color: #e9dedb;
  font-size: clamp(.96rem, 1.08vw, 1.02rem);
  line-height: 1.52;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.eyebrow { color: var(--green); text-transform: uppercase; font-size: .78rem; letter-spacing: .12em; font-weight: 800; }
h1, h2, h3 { line-height: 1.1; margin: 0 0 18px; letter-spacing: 0; }
h1 { font-size: clamp(2.4rem, 6vw, 5.8rem); }
h2 { font-size: clamp(1.55rem, 3vw, 2.5rem); }
.lead { font-size: clamp(1.08rem, 2vw, 1.35rem); color: #c9d8d5; max-width: 760px; }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 28px; }
.btn, button.btn {
  border: 1px solid var(--line); border-radius: var(--radius); padding: 11px 16px;
  color: var(--text); background: var(--panel-2); font-weight: 800; cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
}
.btn.primary { background: linear-gradient(135deg, var(--green), var(--cyan)); color: #031014; border: 0; }
.btn.ghost:hover, .btn:hover { transform: translateY(-1px); }
.trust-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; color: var(--muted); }
.trust-row span {
  border: 1px solid rgba(255,255,255,.09); background: rgba(255,255,255,.035);
  border-radius: 999px; padding: 7px 10px; font-size: .9rem; font-weight: 750;
}
.profile-panel, .terminal-card, .product-card, .report-card, .donation-card, .panel-form, .stat-card, .admin-card {
  background: rgba(13,23,28,.92); border: 1px solid rgba(255,255,255,.09); border-radius: var(--radius); box-shadow: var(--shadow);
}
.profile-panel { padding: 14px; position: relative; }
.profile-panel img { aspect-ratio: 4 / 4.6; width: 100%; object-fit: cover; border-radius: 6px; }
.status-card { margin-top: 12px; color: var(--muted); display: flex; gap: 10px; align-items: center; }
.pulse { width: 9px; height: 9px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 5px rgba(68,215,168,.12); flex: 0 0 auto; }
.section-grid, .contact-strip, .page-heading, .reports-list, .donation-grid, .form-section, .product-grid, .demo-band, .report-article {
  padding: clamp(42px, 6vw, 82px) clamp(18px, 5vw, 72px);
}
.section-grid { display: grid; grid-template-columns: minmax(0, .95fr) minmax(300px, 1.05fr); gap: 36px; border-top: 1px solid rgba(255,255,255,.08); }
.card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.skill-badge, .badge {
  border: 1px solid rgba(255,255,255,.1); background: rgba(68,215,168,.09); border-radius: 999px; padding: 8px 12px; color: #dffdf6; font-weight: 800;
}
.contact-strip { display: flex; justify-content: space-between; gap: 24px; align-items: center; background: rgba(255,255,255,.025); border-top: 1px solid rgba(255,255,255,.08); }
.page-heading { max-width: 980px; }
.page-heading p { color: var(--muted); }
.reports-list { display: grid; gap: 18px; }
.report-card { display: grid; grid-template-columns: 260px 1fr; gap: 24px; padding: 16px; }
.report-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 6px; background: #101820; }
.report-meta { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; color: var(--muted); font-size: .9rem; }
.company, .empty { color: var(--muted); }
.tag-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }
.tag-row span {
  border: 1px solid rgba(97,181,255,.2);
  border-radius: 999px;
  padding: 5px 9px;
  color: var(--muted);
  background: rgba(255,255,255,.035);
  font: 800 .78rem/1.2 var(--mono);
}
.sev-critical { color: #fff; background: rgba(255,85,112,.25); border-color: rgba(255,85,112,.42); }
.sev-high { color: #fff; background: rgba(255,123,84,.23); border-color: rgba(255,123,84,.42); }
.sev-medium { color: #101014; background: var(--warn); }
.sev-low { color: #031014; background: var(--green); }
.sev-info { color: #071014; background: var(--cyan); }
.inline-link { color: var(--cyan); font-weight: 800; }
.inline-link:hover { color: var(--green); }
.code-block, .terminal-card pre {
  overflow: auto; background: #05090d; border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); padding: 16px; color: #9df7df;
}
.terminal-card { padding: 18px; }
.terminal-card pre { margin: 0; white-space: pre-wrap; }
.terminal-bar { display: flex; gap: 7px; margin-bottom: 12px; }
.terminal-bar span { width: 11px; height: 11px; border-radius: 50%; background: var(--line); }
.product-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.product-card { padding: 24px; }
.product-card img { margin-top: 16px; border-radius: 6px; border: 1px solid var(--line); }
.demo-band { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: center; background: rgba(255,255,255,.025); }
.video-placeholder { min-height: 220px; border: 1px dashed rgba(97,181,255,.7); border-radius: var(--radius); display: grid; place-items: center; color: var(--muted); background: rgba(97,181,255,.055); font-weight: 750; }
.donation-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.donation-card, .panel-form { padding: 22px; }
.donation-card { display: grid; align-content: start; gap: 12px; }
.panel-form { max-width: 780px; display: grid; gap: 14px; }
label { display: grid; gap: 6px; color: var(--muted); font-weight: 700; }
input, textarea, select {
  width: 100%; border: 1px solid var(--line); background: #071017; color: var(--text); border-radius: var(--radius); padding: 11px 12px; font: inherit;
}
input:hover, textarea:hover, select:hover { border-color: rgba(97,181,255,.5); }
textarea { resize: vertical; }
.flash { padding: 12px 14px; border-radius: var(--radius); margin-bottom: 16px; border: 1px solid var(--line); }
.flash.success { background: rgba(49,247,169,.1); }
.flash.error { background: rgba(255,85,112,.12); }
.admin-body { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.admin-sidebar { background: #070c12; border-right: 1px solid var(--line); padding: 22px; position: sticky; top: 0; height: 100vh; }
.admin-sidebar nav { display: grid; gap: 8px; margin-top: 28px; }
.admin-sidebar a { color: var(--muted); padding: 10px; border-radius: var(--radius); }
.admin-sidebar a:hover { color: var(--text); background: var(--panel); }
.admin-main { padding: 28px; }
.stats-grid, .admin-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.stat-card, .admin-card { padding: 18px; }
.stat-card strong { font-size: 2rem; display: block; }
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); }
table { width: 100%; border-collapse: collapse; background: var(--panel); }
th, td { text-align: left; padding: 12px; border-bottom: 1px solid var(--line); vertical-align: top; }
th { color: var(--green); }
.actions { display: flex; gap: 8px; flex-wrap: wrap; }
.inline-form { display: inline; }
.media-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.media-item { border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; background: var(--panel); }
.media-item img { aspect-ratio: 4 / 3; object-fit: cover; border-radius: 6px; }
.admin-preview {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-weight: 800;
}
.admin-preview img {
  width: min(320px, 100%);
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.report-article { display: grid; gap: 22px; }
.report-article-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, .92fr);
  gap: clamp(22px, 4vw, 46px);
  align-items: center;
}
.report-article-hero img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  background: var(--panel);
}
.article-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.article-section {
  background: linear-gradient(180deg, rgba(13,23,28,.92), rgba(9,14,20,.9));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(18px, 3vw, 28px);
  box-shadow: var(--shadow);
}
.article-body {
  font-size: 1.04rem;
  line-height: 1.82;
}
@media (max-width: 900px) {
  .site-header { display: grid; grid-template-columns: 1fr auto; align-items: center; }
  .nav-toggle { display: inline-flex; }
  .site-nav { display: none; width: 100%; grid-column: 1 / -1; flex-direction: column; align-items: stretch; padding-top: 8px; }
  .site-nav.open { display: flex; }
  .site-nav a { width: 100%; }
  .hero, .framework-hero, .section-grid, .demo-band, .report-card, .report-article-hero { grid-template-columns: 1fr; min-height: auto; }
  .framework-hero h1 { white-space: normal; }
  .product-grid, .donation-grid, .stats-grid, .admin-grid, .media-grid, .card-grid, .article-grid { grid-template-columns: 1fr; }
  .contact-strip, .site-footer { flex-direction: column; align-items: flex-start; }
  .admin-body { grid-template-columns: 1fr; }
  .admin-sidebar { position: static; height: auto; }
  /* payload flight elements only make sense in the 2-column hero layout */
  .proxy-origin, .exploit-origin, .payload-flight, .payload2-flight { display: none; }
}
@media (max-width: 520px) {
  .hero, .framework-hero, .section-grid, .contact-strip, .page-heading, .reports-list, .donation-grid, .form-section, .product-grid, .demo-band, .report-article {
    padding-left: 16px; padding-right: 16px;
  }
  .hero-actions, .hero-actions .btn { width: 100%; }
  .report-card { padding: 12px; }
}

/* Refined security research interface layer */
:root {
  /* Animation duration — JS sets this per screen size so payload speed is constant */
  --anim-dur: 12.4s;

  --bg: #111722;
  --bg-lift: #182332;
  --panel: rgba(23, 33, 47, .94);
  --panel-2: rgba(29, 43, 60, .95);
  --text: #eef8f6;
  --muted: #9fb5bd;
  --line: rgba(122, 241, 214, .24);
  --line-strong: rgba(112, 211, 255, .5);
  --green: #7af1d6;
  --cyan: #70d3ff;
  --violet: #c69cff;
  --danger: #ff6f91;
  --warn: #ffd166;
  --shadow: 0 22px 70px rgba(0, 0, 0, .34);
  --mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
}

body {
  background:
    radial-gradient(circle at 16% 0%, rgba(122, 241, 214, .19), transparent 32vw),
    radial-gradient(circle at 84% 10%, rgba(198, 156, 255, .18), transparent 30vw),
    radial-gradient(circle at 58% 88%, rgba(255, 209, 102, .08), transparent 24vw),
    linear-gradient(135deg, rgba(112, 211, 255, .12), transparent 40%),
    linear-gradient(180deg, #17202d 0%, var(--bg) 46%, #0e131c 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    linear-gradient(rgba(122, 241, 214, .07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(112, 211, 255, .055) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, .9), transparent 86%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1000;
  background: repeating-linear-gradient(180deg, rgba(255,255,255,.025) 0 1px, transparent 1px 4px);
  opacity: .34;
  mix-blend-mode: soft-light;
}

.site-header::after,
.site-footer::after {
  content: "0x76 0x61 0x78 0x6f 0x39 0x34";
  position: absolute;
  right: clamp(18px, 5vw, 72px);
  bottom: -24px;
  color: rgba(198,156,255,.36);
  font: 900 .72rem/1 var(--mono);
  letter-spacing: .16em;
  pointer-events: none;
}

main::before {
  content: "0101  vuln  scope  1337  cve  token  recon  xss  csrf  sqli  auth  waf  hash  dns  js  api  0day  patch  triage  exploit? no  disclose  proof  payload  burp  nuclei  nmap  subfinder";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  color: rgba(122, 241, 214, .24);
  font: 900 14px/1.08 var(--mono);
  letter-spacing: .18em;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  word-spacing: 1.7rem;
  opacity: .42;
  filter: drop-shadow(0 0 12px rgba(122,241,214,.38));
  mask-image:
    linear-gradient(to right, rgba(0,0,0,.72), transparent 24%, transparent 72%, rgba(0,0,0,.78)),
    linear-gradient(to bottom, transparent, #000 16%, #000 78%, transparent);
  animation: matrix-drift 18s linear infinite;
}

main::after {
  content: "101101 vaxo94 010011\Aroot ./scan --scope\A[passive] [verified]\A001011 0x7af1d6\Atriage::accepted\Apatch::ready\A101101 vaxo94 010011\Aroot ./scan --scope\A[passive] [verified]\A001011 0x7af1d6\Atriage::accepted\Apatch::ready";
  position: fixed;
  top: -20vh;
  left: 3vw;
  width: 94vw;
  height: 140vh;
  z-index: 0;
  pointer-events: none;
  color: rgba(122,241,214,.13);
  font: 900 clamp(11px, 1.1vw, 16px)/1.65 var(--mono);
  white-space: pre;
  column-count: 6;
  column-gap: clamp(34px, 7vw, 110px);
  text-shadow: 0 0 12px rgba(122,241,214,.44);
  opacity: .62;
  transform: skewX(-4deg);
  animation: matrix-rain 11s linear infinite;
  mask-image: linear-gradient(to bottom, transparent, #000 9%, #000 82%, transparent);
}

main {
  position: relative;
  isolation: isolate;
}

main > * {
  position: relative;
  z-index: 1;
}

.hero,
.framework-hero,
.section-grid,
.page-heading,
.reports-list,
.product-grid,
.donation-grid,
.form-section,
.demo-band {
  border-left: 1px solid rgba(122,241,214,.08);
  border-right: 1px solid rgba(198,156,255,.08);
}

.site-header, .site-footer {
  background: rgba(17, 24, 36, .82);
  border-color: var(--line);
  backdrop-filter: blur(18px);
}

.site-header {
  box-shadow: 0 12px 50px rgba(0,0,0,.22), inset 0 -1px 0 rgba(122,241,214,.1);
}

.site-footer {
  position: relative;
}

.site-header::before {
  content: "";
  position: absolute;
  left: clamp(18px, 5vw, 72px);
  right: clamp(18px, 5vw, 72px);
  bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--green), var(--cyan), transparent);
  opacity: .55;
}

.brand span:last-child,
.eyebrow,
.trust-row span,
.skill-badge,
.badge,
.status-card,
.terminal-card pre,
.code-block,
.video-placeholder,
th,
.stat-card strong {
  font-family: var(--mono);
}

.brand::before {
  content: "[root@";
  color: var(--green);
}

.brand::after {
  content: "]";
  color: var(--cyan);
}

.brand-mark {
  width: 17px;
  height: 17px;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--green), var(--cyan));
  box-shadow: 0 0 0 5px rgba(67,240,184,.1), 0 0 26px rgba(67,240,184,.34);
  transform: rotate(45deg);
  animation: node-pulse 2.4s ease-in-out infinite;
}

.site-nav a,
.footer-links a,
.social-links a,
.admin-sidebar a {
  border: 1px solid transparent;
  font-family: var(--mono);
  font-size: .9rem;
}

.admin-sidebar nav a::before {
  content: "./";
  color: rgba(122,241,214,.72);
}

.site-nav a:hover,
.footer-links a:hover,
.social-links a:hover,
.site-nav a[aria-current="page"],
.admin-sidebar a:hover {
  background: rgba(122,241,214,.105);
  border-color: var(--line);
}

.nav-admin {
  background: rgba(255,209,102,.13);
  border-color: rgba(255,209,102,.46);
  color: #ffdf8a;
}

.hero,
.framework-hero {
  position: relative;
  overflow: visible;
}

.hero-copy,
.framework-hero > div:first-child {
  position: relative;
}

.hero-copy::after,
.framework-hero > div:first-child::after {
  content: "vaxo94@scope:~$ recon --target authorized --mode passive\A[+] subdomains indexed    [+] javascript mapped\A[+] signal verified       impact: business-critical\A[+] evidence archived     status: coordinated\A[+] matrix channel open  hash: 0x7af1d6";
  display: block;
  margin-top: 22px;
  max-width: 620px;
  padding: 14px 16px;
  border: 1px solid rgba(122,241,214,.2);
  border-left: 4px solid var(--green);
  border-radius: var(--radius);
  background:
    repeating-linear-gradient(180deg, rgba(122,241,214,.07) 0 1px, transparent 1px 8px),
    linear-gradient(90deg, rgba(122,241,214,.13), rgba(112,211,255,.06), transparent),
    rgba(8, 13, 19, .58);
  color: rgba(211,255,245,.78);
  font: 750 .82rem/1.55 var(--mono);
  white-space: pre-wrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 18px 44px rgba(0,0,0,.18);
}

.hero-copy h1::after,
.framework-hero h1::after {
  content: "_";
  color: var(--green);
  animation: cursor-blink 1s steps(1, end) infinite;
}

.hero-copy::before,
.framework-hero > div:first-child::before {
  content: "ACCESS GRANTED";
  display: inline-flex;
  margin-bottom: 16px;
  padding: 6px 9px;
  border: 1px solid rgba(122,241,214,.38);
  border-radius: 4px;
  background: rgba(122,241,214,.08);
  color: var(--green);
  font: 900 .72rem/1 var(--mono);
  letter-spacing: .14em;
  box-shadow: 0 0 24px rgba(122,241,214,.14);
}

.framework-hero > div:first-child::before {
  margin-bottom: 10px;
}

.framework-hero .hero-actions {
  margin-top: 18px;
}

.framework-hero > div:first-child::after {
  content: none;
  display: none;
}

.about-hero .hero-copy::after {
  content: none;
  display: none;
}

.about-hero .hero-copy::before {
  content: "TERMINAL SESSION";
  margin-bottom: 6px;
  transform: translateY(-18px);
}

.about-hero .hero-copy {
  transform: translate(28px, -78px);
}

.about-hero {
  min-height: 68vh;
  padding-bottom: 18px;
}

.framework-terminal-stack {
  margin-top: 230px;
  transform: translateX(-324px);
  display: grid;
  gap: 16px;
}

.framework-hero .terminal-card {
  margin-top: 0;
  transform: none;
}

.donation-cta {
  display: grid;
  gap: 4px;
  width: min(100%, 420px);
  justify-self: end;
  padding: 16px 18px;
  border: 1px solid rgba(255,209,102,.68);
  border-left: 5px solid var(--green);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 100% 0%, rgba(255,209,102,.22), transparent 42%),
    linear-gradient(135deg, rgba(233,84,32,.26), rgba(48,10,36,.94));
  box-shadow: 0 18px 52px rgba(17,5,22,.34), 0 0 34px rgba(255,209,102,.18);
  color: #fff8f1;
}

.donation-cta span {
  color: #ffe08a;
  font: 900 .76rem/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.donation-cta strong {
  font-size: clamp(1.05rem, 1.6vw, 1.35rem);
}

.donation-cta:hover {
  transform: translateY(-2px);
  border-color: rgba(126,231,135,.72);
  box-shadow: 0 22px 62px rgba(17,5,22,.38), 0 0 44px rgba(126,231,135,.22);
}

.donate-btn {
  border: 1px solid rgba(255,209,102,.72) !important;
  background: linear-gradient(135deg, #ffd166, #e95420 52%, #cba6f7) !important;
  color: #241018 !important;
  box-shadow: 0 16px 42px rgba(233,84,32,.26), 0 0 34px rgba(255,209,102,.18) !important;
}

.donate-btn::before {
  color: #241018;
}

.donation-note {
  flex-basis: 100%;
  max-width: 680px;
  margin: 0;
  color: #ffe08a;
  font: 800 .9rem/1.55 var(--mono);
}

.donation-note::before {
  content: "support:// ";
  color: var(--green);
}

.hero::before,
.framework-hero::before {
  content: "scope://authorized  severity:triaged  signal:verified  disclosure:coordinated";
  position: absolute;
  left: clamp(18px, 5vw, 72px);
  right: clamp(18px, 5vw, 72px);
  top: 30px;
  color: rgba(143,247,218,.22);
  font: 700 .78rem/1 var(--mono);
  letter-spacing: .04em;
  white-space: nowrap;
  overflow: visible;
}

.hero::after,
.framework-hero::after {
  content: "";
  position: absolute;
  right: -11vw;
  top: 16vh;
  width: clamp(260px, 38vw, 560px);
  aspect-ratio: 1;
  border: 1px solid rgba(112,211,255,.22);
  border-radius: 50%;
  background:
    radial-gradient(circle, transparent 0 34%, rgba(112,211,255,.14) 35% 35.6%, transparent 36% 57%, rgba(122,241,214,.16) 58% 58.6%, transparent 59%),
    conic-gradient(from 210deg, transparent, rgba(198,156,255,.26), rgba(122,241,214,.2), transparent 42%);
  opacity: .8;
  z-index: -1;
}

h1 {
  text-shadow: 0 0 34px rgba(88,199,255,.12);
  font-family: var(--mono);
  animation: title-glow 3.4s ease-in-out infinite;
}

h1::before {
  content: "> ";
  color: var(--green);
}

.lead,
p {
  color: #c7d8d5;
}

.eyebrow {
  color: var(--green);
  font-weight: 850;
  letter-spacing: .12em;
}

.btn,
button.btn {
  border-color: var(--line-strong);
  background: linear-gradient(180deg, rgba(37,55,76,.96), rgba(22,32,45,.96));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  font-family: var(--mono);
  text-transform: lowercase;
}

.btn::before,
button.btn::before {
  content: "$ ";
  color: var(--green);
}

.btn.primary {
  background: linear-gradient(135deg, var(--green), var(--cyan) 52%, var(--violet));
  color: #07111a;
  box-shadow: 0 14px 38px rgba(112,211,255,.24);
}

.btn:hover {
  border-color: rgba(88,199,255,.58);
  box-shadow: 0 0 0 1px rgba(122,241,214,.12), 0 0 28px rgba(112,211,255,.18);
}

.trust-row span,
.skill-badge,
.badge {
  background: rgba(122,241,214,.105);
  border-color: rgba(122,241,214,.24);
  color: #e5fffa;
}

.trust-row span::before,
.skill-badge::before {
  content: "# ";
  color: var(--cyan);
}

.profile-panel,
.terminal-card,
.product-card,
.report-card,
.article-section,
.donation-card,
.panel-form,
.stat-card,
.admin-card,
.media-item,
.table-wrap {
  background: linear-gradient(180deg, rgba(22,32,43,.94), rgba(11,17,24,.92));
  border-color: var(--line);
  position: relative;
  overflow: hidden;
}

.profile-panel {
  clip-path: polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px));
}

.report-card,
.product-card,
.article-section,
.donation-card,
.panel-form,
.admin-card,
.stat-card {
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 0 100%);
}

.profile-panel::after,
.terminal-card::after,
.product-card::after,
.report-card::after,
.article-section::after,
.donation-card::after,
.panel-form::after,
.stat-card::after,
.admin-card::after {
  content: "0xB17B0UNTY // evidence.log // hash:7af1d6";
  position: absolute;
  right: 10px;
  bottom: 8px;
  color: rgba(122,241,214,.12);
  font: 800 .68rem/1 var(--mono);
  letter-spacing: .08em;
  pointer-events: none;
}

.profile-panel::before,
.terminal-card::before,
.product-card::before,
.report-card::before,
.article-section::before,
.donation-card::before,
.panel-form::before,
.stat-card::before,
.admin-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(122,241,214,.18), transparent 32%, rgba(198,156,255,.11));
  opacity: .75;
}

.profile-panel {
  box-shadow: 0 24px 80px rgba(0,0,0,.38), 0 0 44px rgba(122,241,214,.1);
  width: min(100%, 760px);
  justify-self: center;
  transform: translateX(-78px);
}

.profile-panel img {
  mix-blend-mode: screen;
  aspect-ratio: 16 / 10;
  max-height: 630px;
}

.profile-panel::after,
.terminal-card::after,
.product-card::after,
.report-card::after,
.article-section::after,
.donation-card::after,
.panel-form::after,
.stat-card::after,
.admin-card::after {
  z-index: 2;
}

.report-card::before,
.article-section::before,
.product-card::before,
.donation-card::before,
.panel-form::before,
.admin-card::before,
.stat-card::before {
  background:
    linear-gradient(180deg, transparent, rgba(122,241,214,.1), transparent),
    linear-gradient(135deg, rgba(122,241,214,.18), transparent 32%, rgba(198,156,255,.11));
  background-size: 100% 220%, 100% 100%;
  animation: scan-sweep 5.8s ease-in-out infinite;
}

.report-card:hover,
.product-card:hover,
.article-section:hover,
.donation-card:hover,
.admin-card:hover,
.stat-card:hover {
  border-color: rgba(122,241,214,.5);
  box-shadow: 0 24px 76px rgba(0,0,0,.36), 0 0 0 1px rgba(122,241,214,.08), 0 0 34px rgba(112,211,255,.1);
}

.report-card:hover::after,
.product-card:hover::after,
.article-section:hover::after,
.donation-card:hover::after,
.admin-card:hover::after,
.stat-card:hover::after {
  color: rgba(122,241,214,.28);
}

.profile-panel > *,
.terminal-card > *,
.product-card > *,
.report-card > *,
.article-section > *,
.donation-card > *,
.panel-form > *,
.stat-card > *,
.admin-card > * {
  position: relative;
  z-index: 1;
}

.profile-panel img,
.report-card img,
.product-card img,
.media-item img {
  border: 1px solid rgba(255,255,255,.08);
  filter: saturate(1.06) contrast(1.04);
}

.pulse {
  box-shadow: 0 0 0 5px rgba(67,240,184,.12), 0 0 18px rgba(67,240,184,.58);
}

.section-grid {
  border-top-color: rgba(143,247,218,.12);
}

.contact-strip,
.demo-band {
  background: linear-gradient(90deg, rgba(112,211,255,.1), rgba(122,241,214,.06), rgba(198,156,255,.08));
  border-top-color: rgba(143,247,218,.12);
}

.report-card {
  isolation: isolate;
}

.report-meta {
  font-weight: 700;
}

.report-meta::before {
  content: "casefile:";
  color: var(--green);
}

.report-card h2::before,
.article-section h2::before,
.product-card h2::before,
.donation-card h2::before,
.admin-card h2::before {
  content: "## ";
  color: var(--cyan);
  font-family: var(--mono);
}

.sev-critical {
  background: rgba(255,92,124,.22);
  border-color: rgba(255,92,124,.54);
}

.sev-high {
  background: rgba(255,138,92,.2);
  border-color: rgba(255,138,92,.52);
}

.sev-medium {
  color: #120f05;
  background: var(--warn);
}

.inline-link {
  border-bottom: 1px solid rgba(88,199,255,.45);
}

.code-block,
.terminal-card pre {
  background: #0a1119;
  border-color: rgba(143,247,218,.18);
  color: #a7ffe9;
  box-shadow: inset 0 0 38px rgba(122,241,214,.06);
}

.terminal-card {
  border-color: rgba(122,241,214,.34);
  box-shadow: 0 26px 90px rgba(0,0,0,.38), inset 0 0 48px rgba(122,241,214,.045);
}

.terminal-card::after {
  content: "live telemetry";
  top: 12px;
  right: 14px;
  bottom: auto;
  color: rgba(122,241,214,.38);
}

.terminal-bar span:first-child { background: var(--danger); }
.terminal-bar span:nth-child(2) { background: var(--warn); }
.terminal-bar span:nth-child(3) { background: var(--green); }

.video-placeholder {
  min-height: 230px;
  background:
    repeating-linear-gradient(180deg, rgba(122,241,214,.1) 0 1px, transparent 1px 12px),
    linear-gradient(rgba(88,199,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(88,199,255,.055) 1px, transparent 1px),
    rgba(88,199,255,.045);
  background-size: 22px 22px;
}

.page-heading h1,
.admin-main h1 {
  display: inline-block;
  padding: 0 10px 8px 0;
  border-bottom: 1px solid rgba(122,241,214,.35);
}

input,
textarea,
select {
  background: rgba(12,18,27,.9);
  border-color: var(--line);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(67,240,184,.12);
  outline: 0;
}

.admin-body {
  background:
    radial-gradient(circle at 100% 0%, rgba(112,211,255,.15), transparent 34vw),
    radial-gradient(circle at 0% 100%, rgba(198,156,255,.1), transparent 28vw),
    #111722;
}

.admin-sidebar {
  background: rgba(13, 19, 29, .94);
  border-right-color: var(--line);
}

.stat-card strong {
  color: var(--green);
  font-weight: 900;
}

table {
  background: rgba(17,25,36,.96);
}

th,
td {
  border-bottom-color: rgba(143,247,218,.12);
}

tr:hover td {
  background: rgba(143,247,218,.035);
}

@keyframes matrix-drift {
  from { transform: translateY(-4%); }
  to { transform: translateY(4%); }
}

@keyframes matrix-rain {
  from { transform: translateY(-10%) skewX(-4deg); }
  to { transform: translateY(10%) skewX(-4deg); }
}

@keyframes node-pulse {
  0%, 100% { filter: saturate(1); box-shadow: 0 0 0 5px rgba(122,241,214,.1), 0 0 26px rgba(122,241,214,.34); }
  50% { filter: saturate(1.5); box-shadow: 0 0 0 7px rgba(112,211,255,.12), 0 0 42px rgba(198,156,255,.3); }
}

@keyframes title-glow {
  0%, 100% { text-shadow: 0 0 24px rgba(122,241,214,.12), 0 0 44px rgba(112,211,255,.08); }
  50% { text-shadow: 0 0 28px rgba(122,241,214,.24), 0 0 54px rgba(198,156,255,.16); }
}

@keyframes cursor-blink {
  0%, 48% { opacity: 1; }
  49%, 100% { opacity: 0; }
}

@keyframes terminal-line {
  0%, 6% {
    opacity: 0;
    transform: translateY(6px);
  }
  7%, 100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes type-line {
  0% {
    opacity: 1;
    width: 0;
  }
  100% {
    opacity: 1;
    width: 100%;
  }
}

@keyframes caret-active {
  0%, 99% {
    border-right-color: var(--green);
  }
  100% {
    border-right-color: transparent;
  }
}

@keyframes scan-sweep {
  0%, 100% { background-position: 0 -140%, 0 0; }
  48%, 52% { background-position: 0 140%, 0 0; }
}

@media (prefers-reduced-motion: reduce) {
  main::before,
  main::after,
  .brand-mark,
  h1,
  .hero-copy h1::after,
  .framework-hero h1::after,
  .live-terminal span,
  .live-terminal::after,
  .report-card::before,
  .article-section::before,
  .product-card::before,
  .donation-card::before,
  .panel-form::before,
  .admin-card::before,
  .stat-card::before {
    animation: none;
  }
}

@media (max-width: 520px) {
  .hero::before,
  .framework-hero::before {
    left: 16px;
    right: 16px;
    top: 18px;
  }
}

/* Ubuntu terminal inspired refinement */
:root {
  --bg: #1f1724;
  --bg-lift: #2a2030;
  --panel: rgba(35, 27, 40, .95);
  --panel-2: rgba(45, 35, 52, .96);
  --text: #f3eee9;
  --muted: #b9acbd;
  --line: rgba(233, 84, 32, .28);
  --line-strong: rgba(233, 84, 32, .56);
  --green: #7ee787;
  --cyan: #79c0ff;
  --violet: #cba6f7;
  --danger: #ff5f57;
  --warn: #ffbd2e;
  --ubuntu: #e95420;
  --aubergine: #2c001e;
  --terminal: #300a24;
}

body {
  background:
    radial-gradient(circle at 14% 0%, rgba(233, 84, 32, .18), transparent 30vw),
    radial-gradient(circle at 82% 12%, rgba(119, 41, 83, .24), transparent 30vw),
    radial-gradient(circle at 55% 88%, rgba(126, 231, 135, .07), transparent 25vw),
    linear-gradient(180deg, #2b1d30 0%, #1f1724 46%, #17111c 100%);
}

body::before {
  background:
    linear-gradient(rgba(233, 84, 32, .055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(126, 231, 135, .035) 1px, transparent 1px);
  background-size: 42px 42px;
}

.site-header,
.site-footer,
.admin-sidebar {
  background: rgba(32, 24, 38, .9);
  border-color: rgba(233,84,32,.24);
}

.site-header {
  box-shadow: 0 14px 54px rgba(17, 5, 22, .34), inset 0 -1px 0 rgba(233,84,32,.18);
}

.site-header::before {
  background: linear-gradient(90deg, transparent, var(--ubuntu), var(--violet), transparent);
}

.brand-mark {
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, #fff3 0 16%, transparent 17%),
    conic-gradient(from 40deg, var(--ubuntu), #ffbd2e, var(--violet), var(--ubuntu));
  box-shadow: 0 0 0 5px rgba(233,84,32,.12), 0 0 30px rgba(233,84,32,.34);
}

.site-nav a:hover,
.footer-links a:hover,
.social-links a:hover,
.site-nav a[aria-current="page"],
.admin-sidebar a:hover {
  background: rgba(233,84,32,.12);
  border-color: rgba(233,84,32,.34);
}

.nav-admin {
  background: rgba(126,231,135,.09);
  border-color: rgba(126,231,135,.38);
  color: #b9f6c2;
}

.hero::before,
.framework-hero::before {
  content: "ubuntu@vaxo94:~$ authorized-research --scope=coordinated --evidence=clean";
  color: rgba(255,189,46,.32);
}

.hero::after,
.framework-hero::after {
  border-color: rgba(233,84,32,.2);
  background:
    radial-gradient(circle, transparent 0 34%, rgba(233,84,32,.14) 35% 35.6%, transparent 36% 57%, rgba(126,231,135,.12) 58% 58.6%, transparent 59%),
    conic-gradient(from 210deg, transparent, rgba(233,84,32,.26), rgba(203,166,247,.22), transparent 42%);
}

.hero-copy::after,
.framework-hero > div:first-child::after,
.terminal-card,
.code-block,
.terminal-card pre {
  background: linear-gradient(180deg, rgba(48,10,36,.97), rgba(33,18,31,.97));
  border-color: rgba(233,84,32,.34);
  color: #f8f8f2;
}

.hero-copy::after,
.framework-hero > div:first-child::after {
  content: "vaxo94@ubuntu:~$ ./recon --target authorized --mode passive\A[sudo] password not required: ethical scope confirmed\A[ok] assets mapped     [ok] evidence archived\A[ok] impact verified   [ok] disclosure coordinated";
  border-left-color: var(--ubuntu);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 20px 54px rgba(48,10,36,.34);
}

.hero-copy::before,
.framework-hero > div:first-child::before {
  content: "TERMINAL SESSION";
  background: rgba(233,84,32,.12);
  border-color: rgba(233,84,32,.42);
  color: #ffbd8a;
}

h1::before {
  content: "vaxo94@ubuntu:~$ ";
  color: var(--green);
  font-size: .38em;
  vertical-align: middle;
}

.btn,
button.btn {
  background: linear-gradient(180deg, rgba(64,42,62,.98), rgba(48,10,36,.98));
  border-color: rgba(233,84,32,.42);
  color: #fff8f1;
}

.btn.primary {
  background: linear-gradient(135deg, var(--ubuntu), #ffbd2e 62%, #cba6f7);
  color: #241018;
  box-shadow: 0 15px 40px rgba(233,84,32,.24);
}

.btn::before,
button.btn::before {
  color: var(--green);
}

.profile-panel,
.terminal-card,
.product-card,
.report-card,
.article-section,
.donation-card,
.panel-form,
.stat-card,
.admin-card,
.media-item,
.table-wrap {
  background: linear-gradient(180deg, rgba(45,35,52,.96), rgba(32,24,38,.95));
  border-color: rgba(233,84,32,.25);
  box-shadow: 0 22px 72px rgba(17,5,22,.36);
}

.profile-panel::before,
.terminal-card::before,
.product-card::before,
.report-card::before,
.article-section::before,
.donation-card::before,
.panel-form::before,
.stat-card::before,
.admin-card::before {
  background:
    linear-gradient(180deg, transparent, rgba(233,84,32,.1), transparent),
    linear-gradient(135deg, rgba(233,84,32,.16), transparent 35%, rgba(203,166,247,.12));
}

.terminal-card::before {
  background:
    linear-gradient(180deg, rgba(74,53,76,.92) 0 28px, transparent 29px),
    linear-gradient(135deg, rgba(233,84,32,.16), transparent 35%, rgba(203,166,247,.12));
}

.terminal-card .terminal-bar {
  position: absolute;
  top: 14px;
  left: 18px;
  z-index: 3;
  margin: 0;
}

.terminal-card pre {
  padding-top: 18px;
}

.live-terminal {
  min-height: 390px;
  overflow-x: auto;
}

.live-terminal span {
  display: block;
  width: 0;
  max-width: max-content;
  overflow: hidden;
  white-space: nowrap;
  opacity: 0;
  border-right: 2px solid transparent;
}

.live-terminal span:nth-child(1) { animation: type-line 1.65s steps(48, end) .2s forwards, caret-active 1.65s steps(1, end) .2s; color: var(--green); }
.live-terminal span:nth-child(2) { animation: type-line .9s steps(42, end) 1.55s forwards, caret-active .9s steps(1, end) 1.55s; color: var(--muted); }
.live-terminal span:nth-child(3) { animation: type-line 1.55s steps(59, end) 2.7s forwards, caret-active 1.55s steps(1, end) 2.7s; color: #ffbd8a; }
.live-terminal span:nth-child(4) { animation: type-line .9s steps(42, end) 4.15s forwards, caret-active .9s steps(1, end) 4.15s; color: var(--muted); }
.live-terminal span:nth-child(5) { animation: type-line 1.65s steps(69, end) 5.3s forwards, caret-active 1.65s steps(1, end) 5.3s; color: var(--cyan); }
.live-terminal span:nth-child(6) { animation: type-line 1s steps(33, end) 7s forwards, caret-active 1s steps(1, end) 7s; color: var(--green); }
.live-terminal span:nth-child(7) { animation: type-line 2s steps(86, end) 8.25s forwards, caret-active 2s steps(1, end) 8.25s; color: #ffbd8a; }
.live-terminal span:nth-child(8) { animation: type-line 1.15s steps(41, end) 10.5s forwards, caret-active 1.15s steps(1, end) 10.5s; color: var(--green); }
.live-terminal span:nth-child(9) { animation: type-line 1.45s steps(60, end) 11.9s forwards, caret-active 1.45s steps(1, end) 11.9s; color: var(--cyan); }
.live-terminal span:nth-child(10) { animation: type-line 1s steps(34, end) 13.4s forwards, caret-active 1s steps(1, end) 13.4s; color: var(--green); }
.live-terminal span:nth-child(11) { animation: type-line 1.8s steps(78, end) 14.65s forwards, caret-active 1.8s steps(1, end) 14.65s; color: var(--violet); }
.live-terminal span:nth-child(12) { animation: type-line 1.85s steps(78, end) 16.7s forwards, caret-active 1.85s steps(1, end) 16.7s; color: #ffbd8a; }
.live-terminal span:nth-child(13) { animation: type-line 1.7s steps(70, end) 18.8s forwards, caret-active 1.7s steps(1, end) 18.8s; color: var(--cyan); }
.live-terminal span:nth-child(14) { animation: type-line 1.5s steps(61, end) 20.75s forwards, caret-active 1.5s steps(1, end) 20.75s; color: var(--warn); }

.live-terminal::after {
  content: "_";
  display: inline-block;
  color: var(--green);
  animation: cursor-blink 1s steps(1, end) infinite;
}

.hero-copy::after,
.framework-hero > div:first-child::after {
  background:
    radial-gradient(circle at 18px 14px, var(--danger) 0 6px, transparent 7px),
    radial-gradient(circle at 40px 14px, var(--warn) 0 6px, transparent 7px),
    radial-gradient(circle at 62px 14px, var(--green) 0 6px, transparent 7px),
    linear-gradient(180deg, rgba(74,53,76,.94) 0 28px, transparent 29px),
    linear-gradient(180deg, rgba(48,10,36,.97), rgba(33,18,31,.97));
  padding-top: 34px;
}

.trust-row span,
.skill-badge,
.badge {
  background: rgba(48,10,36,.5);
  border-color: rgba(233,84,32,.26);
}

.trust-row span::before,
.skill-badge::before,
.report-meta::before,
.report-card h2::before,
.product-card h2::before,
.article-section h2::before,
.donation-card h2::before,
.admin-card h2::before {
  color: var(--ubuntu);
}

.contact-strip,
.demo-band {
  background: linear-gradient(90deg, rgba(233,84,32,.1), rgba(48,10,36,.34), rgba(203,166,247,.08));
}

input,
textarea,
select,
table {
  background: rgba(48,10,36,.72);
  border-color: rgba(233,84,32,.24);
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--ubuntu);
  box-shadow: 0 0 0 3px rgba(233,84,32,.16);
}

main::before,
main::after {
  color: rgba(126,231,135,.18);
  text-shadow: 0 0 14px rgba(126,231,135,.38);
}

@keyframes title-glow {
  0%, 100% { text-shadow: 0 0 22px rgba(233,84,32,.16), 0 0 42px rgba(126,231,135,.08); }
  50% { text-shadow: 0 0 28px rgba(233,84,32,.28), 0 0 58px rgba(203,166,247,.18); }
}

/* Hiring-focused vaxo94 presentation */
.value-strip,
.deliverables-band,
.process-section,
.hire-panel {
  padding: clamp(42px, 6vw, 82px) clamp(18px, 5vw, 72px);
  border-top: 1px solid rgba(233,84,32,.18);
  position: relative;
  overflow: hidden;
}

.value-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: linear-gradient(90deg, rgba(233,84,32,.18), rgba(203,166,247,.12), rgba(126,231,135,.08));
  margin-top: -72px;
  padding-top: 1px;
  padding-bottom: 1px;
  z-index: 2;
}

.value-strip > div {
  min-height: 160px;
  padding: clamp(20px, 3vw, 32px);
  background:
    radial-gradient(circle at 100% 0%, rgba(233,84,32,.12), transparent 42%),
    rgba(48,10,36,.72);
}

.value-strip strong,
.deliverable-item,
.process-card span {
  font-family: var(--mono);
}

.value-strip strong {
  display: block;
  margin-bottom: 10px;
  color: #fff8f1;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
}

.value-strip span {
  color: var(--muted);
}

.credibility-section {
  background:
    linear-gradient(90deg, rgba(126,231,135,.035), transparent 55%),
    linear-gradient(180deg, rgba(48,10,36,.18), transparent);
}

.credibility-grid,
.deliverables-grid,
.process-grid {
  display: grid;
  gap: 16px;
}

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

.signal-card,
.process-card,
.deliverable-item,
.hire-panel {
  background: linear-gradient(180deg, rgba(45,35,52,.94), rgba(32,24,38,.93));
  border: 1px solid rgba(233,84,32,.24);
  border-radius: var(--radius);
  box-shadow: 0 22px 72px rgba(17,5,22,.28);
}

.signal-card,
.process-card {
  padding: 20px;
  position: relative;
  overflow: hidden;
}

.signal-card::before,
.process-card::before,
.hire-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, transparent, rgba(233,84,32,.08), transparent),
    linear-gradient(135deg, rgba(126,231,135,.08), transparent 38%, rgba(203,166,247,.1));
  background-size: 100% 220%, 100% 100%;
  animation: scan-sweep 6.5s ease-in-out infinite;
}

.signal-card > *,
.process-card > *,
.hire-panel > * {
  position: relative;
  z-index: 1;
}

.signal-card h3,
.process-card h3 {
  color: #fff8f1;
}

.signal-card h3::before {
  content: "signal://";
  color: var(--ubuntu);
  font-family: var(--mono);
  font-size: .76em;
}

.deliverables-band {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr);
  gap: clamp(24px, 5vw, 56px);
  align-items: start;
  background:
    radial-gradient(circle at 12% 20%, rgba(233,84,32,.12), transparent 28vw),
    rgba(32,24,38,.28);
}

.deliverables-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.deliverable-item {
  padding: 15px 16px;
  color: #f8f8f2;
}

.deliverable-item::before {
  content: "[ok] ";
  color: var(--green);
}

.process-section {
  display: grid;
  gap: 26px;
}

.process-heading {
  max-width: 820px;
}

.risk-story .process-heading {
  max-width: 1040px;
}

.risk-story .process-heading p {
  max-width: 980px;
}

.process-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.process-card span {
  display: inline-flex;
  margin-bottom: 16px;
  color: var(--ubuntu);
  font-weight: 900;
}

.process-card h3::before {
  content: "./";
  color: var(--green);
  font-family: var(--mono);
}

.hire-panel {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  margin: clamp(42px, 6vw, 82px) clamp(18px, 5vw, 72px);
  padding: clamp(24px, 4vw, 42px);
  border-color: rgba(233,84,32,.42);
  background:
    radial-gradient(circle at 92% 18%, rgba(255,189,46,.14), transparent 22vw),
    linear-gradient(135deg, rgba(48,10,36,.96), rgba(45,35,52,.94));
}

.hire-panel h2 {
  max-width: 760px;
}

.hire-panel p {
  max-width: 780px;
}

@media (prefers-reduced-motion: reduce) {
  .signal-card::before,
  .process-card::before,
  .hire-panel::before {
    animation: none;
  }
}

@media (max-width: 900px) {
  .value-strip,
  .deliverables-band,
  .process-grid {
    grid-template-columns: 1fr;
  }

  .hire-panel {
    flex-direction: column;
    align-items: flex-start;
  }

  .profile-panel {
    transform: none;
  }

  .framework-terminal-stack {
    margin-top: 28px;
    transform: none;
  }

  .donation-cta {
    justify-self: stretch;
  }
}

@media (max-width: 520px) {
  .value-strip,
  .deliverables-band,
  .process-section {
    padding-left: 16px;
    padding-right: 16px;
  }

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

  .hire-panel {
    margin-left: 16px;
    margin-right: 16px;
  }
}

/* Contact chat panel */
.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: clamp(22px, 4vw, 46px);
  align-items: start;
}

.contact-layout .panel-form {
  max-width: none;
}

.contact-chat {
  background:
    radial-gradient(circle at 90% 0%, rgba(233,84,32,.16), transparent 32%),
    linear-gradient(180deg, rgba(45,35,52,.96), rgba(32,24,38,.95));
  border: 1px solid rgba(233,84,32,.3);
  border-radius: var(--radius);
  box-shadow: 0 24px 80px rgba(17,5,22,.34);
  padding: 18px;
  position: sticky;
  top: 92px;
  overflow: hidden;
}

.contact-chat::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18px 14px, var(--danger) 0 6px, transparent 7px),
    radial-gradient(circle at 40px 14px, var(--warn) 0 6px, transparent 7px),
    radial-gradient(circle at 62px 14px, var(--green) 0 6px, transparent 7px),
    linear-gradient(180deg, rgba(74,53,76,.92) 0 28px, transparent 29px),
    linear-gradient(135deg, rgba(233,84,32,.12), transparent 40%, rgba(203,166,247,.1));
}

.contact-chat > * {
  position: relative;
  z-index: 1;
}

.contact-profile-photo {
  width: min(100%, 430px);
  aspect-ratio: 16 / 12;
  object-fit: cover;
  margin: 28px auto 0;
  border: 1px solid rgba(233,84,32,.34);
  border-radius: 8px;
  background: var(--terminal);
  box-shadow: 0 18px 48px rgba(0,0,0,.3), 0 0 34px rgba(233,84,32,.14);
}

.chat-profile {
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 16px;
  align-items: center;
  padding-top: 28px;
}

.chat-profile img {
  width: 118px;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(233,84,32,.34);
  background: var(--terminal);
  box-shadow: 0 16px 40px rgba(0,0,0,.28), 0 0 28px rgba(233,84,32,.14);
}

.chat-profile h2 {
  margin-bottom: 6px;
}

.chat-profile p {
  margin: 0;
}

.chat-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  color: var(--green);
  font: 900 .78rem/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.chat-thread {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.chat-bubble {
  width: fit-content;
  max-width: 92%;
  padding: 12px 14px;
  border: 1px solid rgba(233,84,32,.24);
  border-radius: 14px;
  color: #f8f8f2;
  background: rgba(48,10,36,.62);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.chat-bubble.incoming {
  border-top-left-radius: 4px;
}

.chat-bubble.outgoing {
  justify-self: end;
  border-top-right-radius: 4px;
  background: linear-gradient(135deg, rgba(233,84,32,.26), rgba(203,166,247,.16));
  border-color: rgba(233,84,32,.38);
}

.chat-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.chat-meta span {
  border: 1px solid rgba(126,231,135,.22);
  border-radius: 999px;
  padding: 6px 8px;
  color: var(--muted);
  background: rgba(126,231,135,.055);
  font: 800 .72rem/1.1 var(--mono);
}

.admin-password-form {
  max-width: 680px;
}

.admin-security-note {
  max-width: 680px;
  margin-top: 18px;
  padding: 18px;
  border: 1px solid rgba(233,84,32,.24);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(45,35,52,.94), rgba(32,24,38,.93));
  box-shadow: 0 18px 50px rgba(17,5,22,.24);
}

.admin-security-note h2::before {
  content: "policy://";
  color: var(--ubuntu);
  font-family: var(--mono);
  font-size: .75em;
}

@media (max-width: 900px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }

  .contact-chat {
    position: relative;
    top: auto;
  }
}

/* Framework tool stack */
.tool-stack,
.risk-story,
.options-section,
.pipeline-section {
  padding: clamp(42px, 6vw, 82px) clamp(18px, 5vw, 72px);
  border-top: 1px solid rgba(233,84,32,.18);
}

.tool-stack {
  display: grid;
  gap: 24px;
  background:
    radial-gradient(circle at 12% 16%, rgba(233,84,32,.12), transparent 26vw),
    rgba(48,10,36,.18);
}

.tool-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.tool-card,
.pipeline-node {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(233,84,32,.26);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(45,35,52,.95), rgba(32,24,38,.94));
  box-shadow: 0 22px 72px rgba(17,5,22,.28);
}

.tool-card {
  padding: clamp(20px, 3vw, 30px);
}

.tool-card::before,
.pipeline-node::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(180deg, rgba(126,231,135,.045) 0 1px, transparent 1px 10px),
    linear-gradient(135deg, rgba(233,84,32,.12), transparent 36%, rgba(203,166,247,.1));
}

.tool-card > *,
.pipeline-node > * {
  position: relative;
  z-index: 1;
}

.tool-card span,
.pipeline-node span {
  display: inline-flex;
  margin-bottom: 12px;
  color: var(--green);
  font: 900 .78rem/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.tool-card h2::before {
  content: "./";
  color: var(--ubuntu);
  font-family: var(--mono);
}

.tool-card ul {
  display: grid;
  gap: 9px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.tool-card li {
  color: var(--muted);
  padding-left: 24px;
  position: relative;
}

.tool-card li::before {
  content: "[ok]";
  position: absolute;
  left: 0;
  color: var(--green);
  font: 800 .72rem/1.6 var(--mono);
}

.tool-options-list {
  display: grid;
  gap: 8px;
  margin-top: -22px;
  max-height: 560px;
  overflow: auto;
  padding-right: 6px;
}

.tool-options-list div {
  display: grid;
  grid-template-columns: minmax(180px, .85fr) minmax(0, 1.15fr);
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(233,84,32,.14);
}

.tool-options-list div:last-child {
  border-bottom: 0;
}

.tool-options-list code {
  color: var(--green);
  font: 850 .8rem/1.35 var(--mono);
  overflow-wrap: anywhere;
}

.tool-options-list span {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.45;
}

.tool-controls {
  margin-top: 14px;
  padding-top: 0;
  border-top: 0;
}

.tool-controls h3 {
  margin-bottom: 10px;
  color: #ffe08a;
  font-family: var(--mono);
  text-shadow: 0 0 20px rgba(255,209,102,.18);
}

.tool-controls h3::before {
  content: "controls://";
  color: var(--green);
  font-size: .78em;
}

.pipeline-section {
  display: grid;
  gap: 26px;
}

.pipeline-flow {
  display: grid;
  grid-template-columns: repeat(7, minmax(150px, 1fr));
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 8px;
}

.pipeline-node {
  min-height: 210px;
  padding: 18px;
}

.pipeline-node:not(:last-child)::after {
  content: ">";
  position: absolute;
  right: -11px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(233,84,32,.38);
  border-radius: 50%;
  background: var(--terminal);
  color: var(--ubuntu);
  font: 900 .86rem/1 var(--mono);
}

.pipeline-node h3 {
  font-family: var(--mono);
}

.risk-story {
  display: grid;
  gap: 26px;
  margin-top: 0;
  padding-top: clamp(120px, 10vw, 170px);
  background:
    radial-gradient(circle at 12% 0%, rgba(233,84,32,.12), transparent 26vw),
    radial-gradient(circle at 88% 100%, rgba(126,231,135,.07), transparent 24vw),
    rgba(48,10,36,.2);
}

.attack-chain {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.attack-node {
  position: relative;
  min-height: 180px;
  padding: 18px;
  border: 1px solid rgba(233,84,32,.26);
  border-radius: var(--radius);
  background:
    linear-gradient(180deg, rgba(45,35,52,.95), rgba(32,24,38,.94));
  box-shadow: 0 18px 54px rgba(17,5,22,.24);
  overflow: hidden;
}

.attack-node::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(180deg, rgba(126,231,135,.04) 0 1px, transparent 1px 9px),
    linear-gradient(135deg, rgba(233,84,32,.11), transparent 44%, rgba(203,166,247,.1));
}

.attack-node:not(:last-child)::after {
  content: "->";
  position: absolute;
  right: -16px;
  top: 26px;
  z-index: 3;
  color: var(--ubuntu);
  font: 900 1rem/1 var(--mono);
  text-shadow: 0 0 14px rgba(233,84,32,.38);
}

.attack-node > * {
  position: relative;
  z-index: 1;
}

.attack-node span {
  color: var(--green);
  font: 900 .74rem/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .1em;
}

.attack-node h3 {
  margin-top: 12px;
  color: #fff8f1;
  font-family: var(--mono);
  overflow-wrap: anywhere;
}

.risk-explainer {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.risk-explainer > div {
  padding: 20px;
  border: 1px solid rgba(233,84,32,.24);
  border-radius: var(--radius);
  background: rgba(48,10,36,.55);
}

.risk-explainer h3::before {
  content: "risk://";
  color: var(--ubuntu);
  font-family: var(--mono);
  font-size: .74em;
}

.finding-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.finding-tags span {
  border: 1px solid rgba(126,231,135,.24);
  border-radius: 999px;
  padding: 6px 8px;
  color: var(--green);
  background: rgba(126,231,135,.055);
  font: 800 .72rem/1.1 var(--mono);
}

.options-section {
  display: grid;
  gap: 24px;
  background:
    radial-gradient(circle at 88% 10%, rgba(126,231,135,.08), transparent 26vw),
    rgba(32,24,38,.22);
}

.options-section .eyebrow {
  width: fit-content;
  padding: 9px 12px;
  border: 1px solid rgba(255,209,102,.72);
  border-left: 5px solid var(--green);
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(255,209,102,.2), rgba(126,231,135,.13), rgba(48,10,36,.78));
  color: #ffe08a;
  box-shadow: 0 0 0 1px rgba(126,231,135,.12), 0 0 38px rgba(255,209,102,.26), 0 0 26px rgba(126,231,135,.14);
  font-size: .88rem;
}

.options-section h2 {
  max-width: 1000px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(233,84,32,.36);
  color: #fff8f1;
  text-shadow: 0 0 24px rgba(233,84,32,.18);
}

.extract-options-section {
  background:
    radial-gradient(circle at 12% 8%, rgba(203,166,247,.1), transparent 28vw),
    rgba(48,10,36,.18);
}

.help-card {
  max-width: 760px;
}

.help-card pre {
  margin: 0;
  color: var(--green);
}

.options-grid {
  display: grid;
  border: 1px solid rgba(233,84,32,.28);
  border-radius: var(--radius);
  overflow: hidden;
  background: linear-gradient(180deg, rgba(48,10,36,.88), rgba(32,24,38,.95));
  box-shadow: 0 22px 72px rgba(17,5,22,.28);
}

.option-row {
  display: grid;
  grid-template-columns: minmax(230px, .7fr) minmax(0, 1.3fr);
  gap: 16px;
  padding: 13px 16px;
  border-bottom: 1px solid rgba(233,84,32,.16);
  align-items: center;
}

.option-row:last-child {
  border-bottom: 0;
}

.option-row code {
  color: var(--green);
  font: 850 .9rem/1.35 var(--mono);
  white-space: normal;
}

.option-row span {
  color: var(--muted);
}

@media (max-width: 900px) {
  .tool-grid {
    grid-template-columns: 1fr;
  }

  .attack-chain,
  .risk-explainer {
    grid-template-columns: 1fr;
  }

  .attack-node:not(:last-child)::after {
    right: 18px;
    top: auto;
    bottom: -8px;
    transform: rotate(90deg);
  }

  .pipeline-flow {
    grid-template-columns: 1fr;
    overflow: visible;
  }

  .option-row {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .pipeline-node:not(:last-child)::after {
    right: 50%;
    top: auto;
    bottom: -11px;
    transform: translateX(50%) rotate(90deg);
  }

  .live-terminal {
    font-size: .76rem;
  }
}

@media (max-width: 520px) {
  .chat-profile {
    grid-template-columns: 86px 1fr;
  }

  .chat-profile img {
    width: 86px;
    border-radius: 12px;
  }
}

/* Homepage value cards need to sit directly under the profile status panel. */
.about-hero {
  min-height: 58vh;
  padding-bottom: 0;
}

.about-hero + .value-strip {
  margin-top: 262px;
  transform: none;
  margin-bottom: 0;
}

.exploit-origin {
  position: relative;
  width: 180px;
  min-height: 136px;
  margin-top: 52px;
  border: 1px solid rgba(126,231,135,.18);
  border-radius: 6px;
  background:
    radial-gradient(circle at 18% 52%, rgba(126,231,135,.11), transparent 20%),
    radial-gradient(circle at 74% 48%, rgba(112,211,255,.1), transparent 18%),
    repeating-linear-gradient(90deg, rgba(126,231,135,.045) 0 1px, transparent 1px 24px),
    linear-gradient(135deg, rgba(8,13,19,.66), rgba(48,10,36,.32));
  overflow: visible;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 16px 44px rgba(0,0,0,.18);
  z-index: 20;
}

.proxy-origin {
  position: absolute;
  left: 900px;
  top: 326px;
  width: 174px;
  min-height: 122px;
  transform: none;
  border: 1px solid rgba(112,211,255,.18);
  border-radius: 6px;
  background:
    radial-gradient(circle at 50% 52%, rgba(112,211,255,.13), transparent 38%),
    repeating-linear-gradient(90deg, rgba(112,211,255,.045) 0 1px, transparent 1px 24px),
    linear-gradient(135deg, rgba(8,13,19,.66), rgba(48,10,36,.32));
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 16px 44px rgba(0,0,0,.18);
}

.proxy-origin::before {
  content: "proxy";
  position: absolute;
  left: 10px;
  top: 9px;
  color: rgba(112,211,255,.72);
  font: 850 .68rem/1 var(--mono);
  letter-spacing: .08em;
}

.proxy-mini-stack {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 17px;
  display: grid;
  gap: 6px;
}

.proxy-mini-stack span {
  height: 23px;
  border: 1px solid rgba(112,211,255,.32);
  border-left: 4px solid rgba(126,231,135,.58);
  border-radius: 4px;
  background:
    radial-gradient(circle at 88% 50%, rgba(126,231,135,.78) 0 2px, transparent 3px),
    linear-gradient(90deg, rgba(112,211,255,.14), rgba(8,13,19,.86));
  box-shadow: 0 0 18px rgba(112,211,255,.1);
}

.exploit-origin::before {
  content: "hacker";
  position: absolute;
  left: 14px;
  top: 12px;
  color: rgba(126,231,135,.62);
  font: 850 .68rem/1 var(--mono);
  letter-spacing: .08em;
}

.operator-silhouette {
  position: absolute;
  left: 38px;
  bottom: 2px;
  width: 108px;
  height: 104px;
  border: 1px solid rgba(126,231,135,.2);
  border-radius: 6px;
  background:
    radial-gradient(circle at 50% 42%, rgba(126,231,135,.1), transparent 52%),
    rgba(8,13,19,.42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 0 24px rgba(126,231,135,.06);
}

.operator-head,
.operator-body,
.operator-laptop {
  position: absolute;
  display: block;
}

.operator-head {
  left: 36px;
  top: 10px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 28%, rgba(126,231,135,.18), transparent 34%),
    #060a0f;
  border: 1px solid rgba(126,231,135,.28);
  box-shadow: 0 0 24px rgba(126,231,135,.1);
}

.operator-body {
  left: 20px;
  top: 42px;
  width: 68px;
  height: 58px;
  border-radius: 42px 42px 8px 8px;
  background:
    linear-gradient(180deg, rgba(17,24,34,.96), rgba(5,8,12,.98));
  border: 1px solid rgba(126,231,135,.18);
}

.operator-laptop {
  left: 19px;
  bottom: 8px;
  width: 70px;
  height: 15px;
  border: 1px solid rgba(112,211,255,.32);
  border-radius: 5px;
  background:
    linear-gradient(105deg, transparent 0 44%, rgba(126,231,135,.18) 45% 46%, transparent 47%),
    linear-gradient(180deg, rgba(13,23,28,.92), rgba(4,8,12,.98));
  opacity: .48;
  box-shadow: 0 0 12px rgba(112,211,255,.08);
}

.payload-flight {
  position: absolute;
  left: 118px;
  top: 510px;
  z-index: 999;
  width: 132px;
  height: 28px;
  display: grid;
  place-items: center end;
  padding-right: 12px;
  border: 1px solid rgba(255,209,102,.7);
  border-radius: 4px;
  background:
    linear-gradient(90deg, rgba(126,231,135,.18), rgba(126,231,135,.42) 42%, rgba(255,209,102,.86)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.08) 0 1px, transparent 1px 12px),
    rgba(8,13,19,.92);
  color: #fff8d8;
  font: 950 .72rem/1 var(--mono);
  letter-spacing: .08em;
  box-shadow: 0 0 28px rgba(255,209,102,.34), 0 0 18px rgba(126,231,135,.18);
  opacity: 0;
  transform: translate3d(0, 0, 0) skewX(-12deg);
  animation: laptop-payload-to-proxy var(--anim-dur, 12.4s) linear infinite;
  pointer-events: none;
}

.payload2-flight {
  position: absolute;
  left: 1000px;
  top: 392px;
  z-index: 999;
  width: 138px;
  height: 28px;
  display: grid;
  place-items: center end;
  padding-right: 12px;
  border: 1px solid rgba(126,231,135,.72);
  border-radius: 4px;
  background:
    linear-gradient(90deg, rgba(112,211,255,.14), rgba(126,231,135,.42) 42%, rgba(255,209,102,.8)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.08) 0 1px, transparent 1px 12px),
    rgba(8,13,19,.92);
  color: #eafff8;
  font: 950 .7rem/1 var(--mono);
  letter-spacing: .08em;
  box-shadow: 0 0 28px rgba(126,231,135,.28), 0 0 18px rgba(255,209,102,.14);
  opacity: 0;
  transform: translate3d(0, 0, 0) skewX(-12deg);
  animation: proxy-payload-to-system var(--anim-dur, 12.4s) linear infinite;
  pointer-events: none;
}

/* Homepage payload packet travels from the hacker laptop to the proxy. */
.about-hero {
  isolation: isolate;
}

.about-hero::after {
  content: none;
  display: none;
}

.about-hero .profile-panel {
  z-index: 2;
}

.system-breach-visual {
  position: relative;
  min-height: clamp(320px, 33vw, 520px);
  border: 1px solid rgba(126,231,135,.24);
  border-radius: 6px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 46%, rgba(126,231,135,.12), transparent 22%),
    radial-gradient(circle at 50% 46%, rgba(112,211,255,.1), transparent 44%),
    linear-gradient(180deg, rgba(17,25,34,.96), rgba(8,11,17,.98));
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.04),
    inset 0 0 80px rgba(126,231,135,.08),
    0 26px 90px rgba(0,0,0,.34);
}

.system-breach-visual::before,
.system-breach-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.system-breach-visual::before {
  background:
    linear-gradient(90deg, transparent 49.7%, rgba(126,231,135,.18) 50%, transparent 50.3%),
    linear-gradient(0deg, transparent 49.7%, rgba(126,231,135,.12) 50%, transparent 50.3%),
    repeating-linear-gradient(90deg, rgba(126,231,135,.06) 0 1px, transparent 1px 38px),
    repeating-linear-gradient(0deg, rgba(112,211,255,.045) 0 1px, transparent 1px 38px);
  opacity: .72;
  transition: opacity .7s, transform .7s;
}

.system-breach-visual::after {
  background:
    radial-gradient(circle at 50% 46%, transparent 0 18%, rgba(255,209,102,.18) 19% 20%, transparent 21%),
    conic-gradient(from 90deg at 50% 46%, transparent 0 7deg, rgba(255,209,102,.18) 8deg 12deg, transparent 13deg 42deg, rgba(233,84,32,.16) 43deg 48deg, transparent 49deg 360deg);
  opacity: 0;
  filter: blur(.2px);
}

.system-grid {
  position: absolute;
  inset: 8%;
  border: 1px solid rgba(126,231,135,.2);
  background:
    radial-gradient(circle at 50% 46%, rgba(126,231,135,.12), transparent 28%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 1px, transparent 1px 16px);
  clip-path: polygon(50% 0, 92% 23%, 92% 74%, 50% 100%, 8% 74%, 8% 23%);
  transition: opacity .7s, transform .7s, filter .7s;
}

.system-core {
  position: absolute;
  left: 50%;
  top: 46%;
  width: min(56%, 340px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  transition: transform .5s;
}

.core-ring {
  position: absolute;
  inset: 10%;
  border: 1px solid rgba(126,231,135,.48);
  border-radius: 50%;
  box-shadow: 0 0 26px rgba(126,231,135,.18);
}

.ring-one {
  animation: ring-rotate 9s linear infinite;
  transition: border-color .4s, box-shadow .4s;
}

.ring-two {
  inset: 24%;
  border-color: rgba(112,211,255,.42);
  animation: ring-rotate 6s linear infinite reverse;
  transition: border-color .4s, box-shadow .4s;
}

.core-lock {
  position: relative;
  display: grid;
  place-items: center;
  width: 34%;
  aspect-ratio: 1 / .78;
  border: 3px solid rgba(255,85,112,.86);
  border-radius: 10px 10px 14px 14px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), transparent 34%),
    radial-gradient(circle, rgba(255,85,112,.26), transparent 58%),
    rgba(8,13,19,.64);
  box-shadow:
    0 0 28px rgba(255,85,112,.26),
    inset 0 0 22px rgba(255,85,112,.14);
  transition: border-color .4s, box-shadow .4s;
  margin-top: 12%;
}

.core-lock::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 82%;
  width: 58%;
  height: 58%;
  border: 3px solid rgba(255,85,112,.86);
  border-bottom: 0;
  border-radius: 999px 999px 0 0;
  transform: translateX(-50%) rotate(0deg);
  transform-origin: left bottom;
  transition: border-color .4s, transform .4s;
}

.core-lock::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 48%;
  width: 14%;
  height: 27%;
  transform: translate(-50%, -50%);
  background:
    radial-gradient(circle at 50% 22%, currentColor 0 34%, transparent 35%),
    linear-gradient(currentColor, currentColor) 50% 66% / 42% 54% no-repeat;
  color: rgba(255,85,112,.92);
  filter: drop-shadow(0 0 8px rgba(255,85,112,.34));
  transition: color .4s, filter .4s;
}

.core-label {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  width: min(92%, 360px);
  transform: translate(-50%, 92%);
  color: rgba(255,85,112,.96);
  font: 950 clamp(1.05rem, 2.25vw, 1.85rem)/1 var(--mono);
  letter-spacing: .08em;
  text-align: center;
  text-shadow: 0 0 24px rgba(255,85,112,.38);
  transition: opacity .3s;
}

.breach-fragments {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(28deg, transparent 0 49.8%, rgba(255,247,214,.72) 50% 50.35%, transparent 50.7%),
    linear-gradient(74deg, transparent 0 42%, rgba(255,209,102,.5) 42.2% 42.55%, transparent 43%),
    linear-gradient(116deg, transparent 0 57%, rgba(112,211,255,.42) 57.2% 57.52%, transparent 58%),
    linear-gradient(151deg, transparent 0 48%, rgba(255,247,214,.56) 48.18% 48.48%, transparent 49%),
    radial-gradient(circle at 50% 46%, rgba(255,209,102,.36) 0 3px, transparent 4px 18px);
  opacity: 0;
  transition: opacity .3s, transform .3s;
}

.breach-message {
  position: absolute;
  left: 50%;
  top: 46%;
  transform: translate(-50%, -50%) scale(.94);
  width: min(78%, 420px);
  padding: 18px 20px;
  border: 1px solid rgba(126,231,135,.48);
  border-left: 4px solid rgba(126,231,135,.9);
  border-radius: 4px;
  background:
    linear-gradient(135deg, rgba(126,231,135,.2), rgba(48,10,36,.7)),
    rgba(8,13,19,.72);
  color: #d9fff2;
  font: 950 clamp(1rem, 2vw, 1.55rem)/1.25 var(--mono);
  text-align: center;
  letter-spacing: .08em;
  text-shadow: 0 0 22px rgba(126,231,135,.42);
  opacity: 0;
  transition: opacity .4s, transform .4s;
}

.about-hero .profile-panel::before {
  content: none;
  display: none;
}

.about-hero .profile-panel::after {
  content: none;
  display: none;
}

/* Fallback keyframes — JS replaces these immediately on DOMContentLoaded
   with correctly computed pixel values for the current screen size. */
@keyframes laptop-payload-to-proxy {
  0%        { opacity:1; transform:translate3d(0,0,0) skewX(-12deg) scaleX(.86); }
  24%       { opacity:1; transform:translate3d(850px,-120px,0) skewX(-12deg) scaleX(1); }
  30%, 100% { opacity:0; transform:translate3d(888px,-120px,0) skewX(-12deg) scaleX(.2); }
}

@keyframes proxy-payload-to-system {
  0%, 28%   { opacity:0; transform:translate3d(0,0,0) skewX(-12deg) scaleX(.86); }
  32%       { opacity:1; transform:translate3d(0,0,0) skewX(-12deg) scaleX(.86); }
  62%       { opacity:1; transform:translate3d(330px,-72px,0) skewX(-12deg) scaleX(1); }
  68%, 100% { opacity:0; transform:translate3d(370px,-72px,0) skewX(-12deg) scaleX(.2); }
}

@keyframes ring-rotate {
  to { transform: rotate(360deg); }
}

@keyframes secure-grid-stability {
  0%, 60%, 100% { opacity: .72; transform: none; }
  62%, 84% { opacity: .2; transform: skewX(-1deg); }
}

@keyframes system-shell-collapse {
  0%, 60%, 100% {
    opacity: 1;
    transform: none;
    filter: none;
  }
  62% {
    opacity: .98;
    transform: scale(1.03);
    filter: drop-shadow(0 0 28px rgba(255,209,102,.28));
  }
  68%, 84% {
    opacity: .18;
    transform: scale(1.18) skewX(-8deg);
    filter: blur(1px);
  }
}

@keyframes protected-core-collapse {
  0%, 60%, 100% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
  62% {
    opacity: .95;
    transform: translate(-50%, -50%) scale(1.08);
  }
  68%, 84% {
    opacity: .95;
    transform: translate(-50%, -50%) scale(1.02);
  }
}

@keyframes ring-breach {
  0%, 60%, 100% { border-color: rgba(126,231,135,.48); }
  62%, 84% { border-color: rgba(233,84,32,.62); box-shadow: 0 0 34px rgba(233,84,32,.3); }
}

@keyframes secure-label-collapse {
  0%, 60%, 100% { opacity: 1; color: rgba(255,85,112,.96); }
  62%, 84% { opacity: 0; color: rgba(255,209,102,.9); }
}

@keyframes lock-access-state {
  0%, 60%, 100% {
    border-color: rgba(255,85,112,.82);
    background:
      radial-gradient(circle, rgba(255,85,112,.26), transparent 58%),
      rgba(8,13,19,.64);
    box-shadow: 0 0 28px rgba(255,85,112,.26), inset 0 0 22px rgba(255,85,112,.14);
  }
  62%, 84% {
    border-color: rgba(126,231,135,.86);
    background:
      radial-gradient(circle, rgba(126,231,135,.32), transparent 58%),
      rgba(8,13,19,.64);
    box-shadow: 0 0 34px rgba(126,231,135,.34), inset 0 0 24px rgba(126,231,135,.16);
  }
}

@keyframes lock-shackle-open {
  0%, 60%, 100% {
    border-color: rgba(255,85,112,.82);
    transform: translateX(-50%) rotate(0deg);
  }
  62%, 84% {
    border-color: rgba(126,231,135,.86);
    transform: translateX(-64%) rotate(-36deg);
  }
}

@keyframes lock-keyhole-state {
  0%, 60%, 100% {
    color: rgba(255,85,112,.92);
    filter: drop-shadow(0 0 8px rgba(255,85,112,.34));
  }
  62%, 84% {
    color: rgba(126,231,135,.95);
    filter: drop-shadow(0 0 10px rgba(126,231,135,.38));
  }
}

@keyframes breach-collapse-flash {
  0%, 60%, 90%, 100% { opacity: 0; transform: scale(.96); }
  62% { opacity: 1; transform: scale(1.04); }
  68%, 84% { opacity: .34; transform: scale(1.18); }
}

@keyframes breach-fragment-burst {
  0%, 60%, 90%, 100% { opacity: 0; transform: scale(.86); }
  62% { opacity: 1; transform: scale(1.04); }
  68%, 84% { opacity: .72; transform: scale(1.18); }
}

@keyframes breach-message-hold {
  0%, 62%, 90%, 100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.94);
  }
  66%, 84% {
    opacity: .96;
    transform: translate(-50%, -50%) scale(1);
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Breach state — triggered by JS via .is-breaching when payload2 arrives.
   One-shot animations, ~2.8 s. Transitions above handle smooth return.
   ═══════════════════════════════════════════════════════════════════════════ */

.system-breach-visual.is-breaching::before {
  animation: b-grid-fall 2.8s ease-in-out forwards;
}
.system-breach-visual.is-breaching::after {
  animation: b-flash     2.8s ease-in-out forwards;
}
.system-breach-visual.is-breaching .system-grid {
  animation: b-shell     2.8s ease-in-out forwards;
}
.system-breach-visual.is-breaching .system-core {
  animation: b-core      2.8s ease-in-out forwards;
}
.system-breach-visual.is-breaching .ring-one,
.system-breach-visual.is-breaching .ring-two {
  border-color: rgba(233,84,32,.7);
  box-shadow:   0 0 34px rgba(233,84,32,.36);
}
.system-breach-visual.is-breaching .core-lock {
  border-color: rgba(126,231,135,.86);
  box-shadow: 0 0 28px rgba(126,231,135,.3), inset 0 0 22px rgba(126,231,135,.14);
}
.system-breach-visual.is-breaching .core-lock::before {
  animation: b-lock-open 2.8s cubic-bezier(.22,1,.36,1) forwards;
}
.system-breach-visual.is-breaching .core-lock::after {
  color:  rgba(126,231,135,.95);
  filter: drop-shadow(0 0 10px rgba(126,231,135,.38));
}
.system-breach-visual.is-breaching .core-label   { opacity: 0; }
.system-breach-visual.is-breaching .breach-fragments {
  animation: b-fragments 2.8s ease-in-out forwards;
}
.system-breach-visual.is-breaching .breach-message {
  animation: b-message   2.8s ease-in-out forwards;
}

@keyframes b-grid-fall {
  0%       { opacity:.72; transform:none; }
  14%      { opacity:.2;  transform:skewX(-1deg); }
  80%      { opacity:.2;  transform:skewX(-1deg); }
  100%     { opacity:.72; transform:none; }
}
@keyframes b-flash {
  0%       { opacity:0;   transform:scale(.96); }
  10%      { opacity:1;   transform:scale(1.04); }
  25%,78%  { opacity:.34; transform:scale(1.18); }
  100%     { opacity:0;   transform:scale(.96); }
}
@keyframes b-shell {
  0%       { opacity:1;   transform:none;                     filter:none; }
  12%      { opacity:.98; transform:scale(1.03);              filter:drop-shadow(0 0 28px rgba(255,209,102,.28)); }
  22%,78%  { opacity:.18; transform:scale(1.18) skewX(-8deg); filter:blur(1px); }
  100%     { opacity:1;   transform:none;                     filter:none; }
}
@keyframes b-core {
  0%       { transform:translate(-50%,-50%); }
  12%      { transform:translate(-50%,-50%) scale(1.08); }
  22%,78%  { transform:translate(-50%,-50%) scale(1.02); }
  100%     { transform:translate(-50%,-50%); }
}
@keyframes b-fragments {
  0%       { opacity:0;   transform:scale(.86); }
  10%      { opacity:1;   transform:scale(1.04); }
  22%,78%  { opacity:.72; transform:scale(1.18); }
  100%     { opacity:0;   transform:scale(.86); }
}
@keyframes b-message {
  0%,10%   { opacity:0;   transform:translate(-50%,-50%) scale(.94); }
  22%,78%  { opacity:.96; transform:translate(-50%,-50%) scale(1); }
  100%     { opacity:0;   transform:translate(-50%,-50%) scale(.94); }
}
@keyframes b-lock-open {
  0%       { transform:translateX(-50%) rotate(0deg);   border-color:rgba(255,85,112,.86); }
  18%,72%  { transform:translateX(-50%) rotate(-52deg); border-color:rgba(126,231,135,.86); }
  100%     { transform:translateX(-50%) rotate(0deg);   border-color:rgba(255,85,112,.86); }
}

/* ═══════════════════════════════════════════════════════════
   BLOG — LISTING  (reports.php)
   ═══════════════════════════════════════════════════════════ */

.blog-list {
  padding: 0 clamp(14px, 4vw, 72px) clamp(48px, 7vw, 96px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(14px, 2.5vw, 32px);
  max-width: 1280px;
  width: 100%;
  box-sizing: border-box;
}

.blog-card {
  background: rgba(13, 23, 28, .92);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) + 2px);
  padding: clamp(18px, 2.8vw, 34px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
  min-width: 0;
}

.blog-card:hover {
  border-color: var(--line-strong);
  box-shadow: 0 10px 48px rgba(0, 0, 0, .32);
  transform: translateY(-2px);
}

.blog-card-meta {
  color: var(--muted);
  font-family: var(--mono);
  font-size: clamp(.72rem, 1vw, .8rem);
  font-weight: 700;
  letter-spacing: .07em;
}

.blog-card-title {
  font-size: clamp(1.05rem, 1.8vw, 1.5rem);
  margin: 0;
  line-height: 1.22;
}

.blog-card-title a {
  color: var(--text);
  transition: color .14s;
}

.blog-card-title a:hover { color: var(--green); }

.blog-card-excerpt {
  color: var(--muted);
  font-size: clamp(.88rem, 1.2vw, .97rem);
  line-height: 1.7;
  margin: 0;
  flex: 1;
}

.blog-card-link {
  font-size: clamp(.82rem, 1.1vw, .9rem);
  font-weight: 800;
  margin-top: 6px;
}

/* ═══════════════════════════════════════════════════════════
   BLOG — ARTICLE  (report.php)
   ═══════════════════════════════════════════════════════════ */

.blog-article {
  padding: clamp(28px, 6vw, 80px) clamp(14px, 5vw, 72px);
  width: 100%;
  box-sizing: border-box;
}

.blog-article-inner {
  max-width: 760px;
  margin: 0 auto;
  width: 100%;
}

.blog-article-header {
  margin-bottom: clamp(28px, 5vw, 52px);
}

.back-link {
  display: inline-block;
  margin-bottom: clamp(16px, 3vw, 28px);
  font-size: clamp(.8rem, 1.1vw, .88rem);
  opacity: .82;
}

.blog-article-title {
  font-size: clamp(1.6rem, 5vw, 3.4rem);
  line-height: 1.1;
  margin: clamp(12px, 2vw, 18px) 0 clamp(8px, 1.5vw, 14px);
  word-break: break-word;
}

.blog-article-date {
  display: block;
  color: var(--muted);
  font-family: var(--mono);
  font-size: clamp(.75rem, 1vw, .82rem);
  font-weight: 700;
  letter-spacing: .06em;
}

.blog-article-body {
  font-size: clamp(.97rem, 1.4vw, 1.07rem);
  line-height: 1.88;
  color: #d5eae8;
  word-break: break-word;
  overflow-wrap: break-word;
}

/* images inside HTML content */
.blog-article-body img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 24px auto;
  border-radius: var(--radius);
  border: 1px solid var(--line);
}

/* tables inside content */
.blog-article-body table {
  width: 100%;
  border-collapse: collapse;
  font-size: .94rem;
  overflow-x: auto;
  display: block;
}

.blog-article-body th,
.blog-article-body td {
  padding: 9px 12px;
  border: 1px solid var(--line);
  text-align: left;
  white-space: nowrap;
}

.blog-article-footer {
  margin-top: clamp(36px, 6vw, 60px);
  padding-top: clamp(18px, 3vw, 28px);
  border-top: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

/* ─── Image embed (iframe) ─── */

.blog-img-wrap {
  margin: clamp(24px, 4vw, 48px) auto;
  width: 100%;
}

.blog-img-frame {
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 720px;
  height: 440px;        /* JS replaces this with the exact aspect-ratio height */
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #0e131c;
  box-shadow: var(--shadow);
}

/* ─── Login gate ─── */
.blog-gate { padding-top: clamp(48px, 10vw, 120px); }
.blog-gate .btn { margin-top: 14px; }

/* ═══════════════════════════════════════════════════════════
   ADMIN — blog helpers
   ═══════════════════════════════════════════════════════════ */

.field-hint {
  display: block;
  color: var(--muted);
  font-size: .8rem;
  font-weight: 600;
  margin-top: 3px;
}

.blog-img-gallery {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(12px, 2vw, 18px);
  background: rgba(255,255,255,.022);
}

.blog-img-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.blog-img-item {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 10px;
  background: var(--panel);
  display: grid;
  gap: 8px;
}

.blog-img-item img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 4px;
}

.blog-img-id {
  font-family: var(--mono);
  font-size: 1.1rem;
  font-weight: 900;
  color: var(--green);
  text-align: center;
}

.btn-sm { padding: 6px 10px; font-size: .82rem; }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS — blog
   ═══════════════════════════════════════════════════════════ */

/* Tablet landscape → 2 columns */
@media (max-width: 1024px) {
  .blog-list {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Tablet portrait → switch to 1 column */
@media (max-width: 720px) {
  .blog-list {
    grid-template-columns: 1fr;
    padding-left: clamp(12px, 4vw, 28px);
    padding-right: clamp(12px, 4vw, 28px);
  }

  .blog-card { padding: clamp(16px, 4vw, 24px); }

  .blog-article {
    padding-left: clamp(12px, 4vw, 28px);
    padding-right: clamp(12px, 4vw, 28px);
  }

  .blog-article-footer {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Large phone */
@media (max-width: 520px) {
  .blog-img-frame { height: 240px; }
  .blog-img-grid  { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }

  .blog-article-body table {
    font-size: .82rem;
  }
}

/* Small phone */
@media (max-width: 380px) {
  .blog-card-title { font-size: 1rem; }
  .blog-img-frame  { height: 180px; }
}
