:root{
  --glow: 0 0 18px rgba(155,230,10,.35);
}

body{
  background:
    radial-gradient(900px 500px at 85% -8%, color-mix(in srgb, var(--accent) 9%, transparent), transparent 60%),
    radial-gradient(700px 460px at 8% 18%, color-mix(in srgb, var(--accent-2) 7%, transparent), transparent 55%),
    var(--bg);
}

/* faint circuit grid */
.section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(80% 60% at 50% 0%, #000 0%, transparent 75%);
          mask-image:radial-gradient(80% 60% at 50% 0%, #000 0%, transparent 75%);
  opacity:.25;
}
.section{position:relative;}

.site-header{
  background:color-mix(in srgb, var(--panel) 80%, transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

/* Headings — Chakra Petch character */
.hero-title,h1,h2,h3{
  font-weight:700;
  letter-spacing:.02em;
}
.hero-title{
  letter-spacing:.01em;
  background:linear-gradient(180deg, var(--text), color-mix(in srgb, var(--accent) 60%, var(--text)));
  -webkit-background-clip:text;
          background-clip:text;
  color:transparent;
}
h2{text-transform:uppercase; letter-spacing:.04em;}

.hero{
  background:
    radial-gradient(600px 320px at 78% 6%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 65%),
    linear-gradient(180deg, var(--panel-2), var(--bg));
  border-bottom:1px solid var(--line);
}

.fact{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.fact b{color:var(--accent);}

/* Cards */
.card,.feature{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  position:relative;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.card::before,.feature::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:0;
  transition:opacity .2s ease;
}
.card:hover,.feature:hover{
  transform:translateY(-3px);
  border-color:color-mix(in srgb, var(--accent) 45%, var(--line));
  box-shadow:var(--glow);
}
.card:hover::before,.feature:hover::before{opacity:1;}

.feature .icon{
  color:var(--accent);
  background:color-mix(in srgb, var(--accent) 12%, var(--panel-2));
  border:1px solid var(--line);
  border-radius:var(--radius);
}

/* Buttons */
.btn{
  border-radius:var(--radius);
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{
  background:var(--accent);
  color:var(--on-accent);
  border:1px solid color-mix(in srgb, var(--accent) 70%, #000);
  font-weight:600;
}
.btn-primary:hover{box-shadow:var(--glow); transform:translateY(-2px);}
.btn-ghost{
  background:transparent;
  border:1px solid var(--line);
  color:var(--text);
}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent);}

.badge{
  background:color-mix(in srgb, var(--accent-2) 14%, var(--panel));
  border:1px solid color-mix(in srgb, var(--accent-2) 35%, var(--line));
  color:var(--accent-2);
  border-radius:999px;
  letter-spacing:.03em;
}

/* Links / code-tags in cyan */
.article a{color:var(--accent-2); text-decoration-color:color-mix(in srgb, var(--accent-2) 50%, transparent);}
.article code{color:var(--accent-2); background:var(--panel-2); border:1px solid var(--line); border-radius:6px;}

/* Catalog tiles */
.tab{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:999px;
  transition:color .2s, border-color .2s, background .2s;
}
.tab:hover{border-color:var(--accent); color:var(--accent);}
.tab.active{
  background:var(--accent);
  color:var(--on-accent);
  border-color:var(--accent);
}
.tile{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.tile:hover{
  transform:translateY(-3px);
  border-color:color-mix(in srgb, var(--accent) 50%, var(--line));
  box-shadow:var(--glow);
}
.tile.noimg{
  background:
    radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 70%),
    var(--panel-2);
}
.tile .gp{color:var(--accent-2);}
.tile .nm{color:var(--text);}

.table{border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;}
.table th{background:var(--panel-2); color:var(--text); border-bottom:1px solid var(--line);}
.table td{border-top:1px solid var(--line); color:var(--prose);}

/* FAQ */
.faq-item{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:border-color .2s ease;
}
.faq-item:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--line));}
.faq-q{color:var(--text); font-weight:600;}
.faq-q::after{color:var(--accent);}

.site-footer{border-top:1px solid var(--line); background:var(--panel-2);}