:root{ --shadow-soft: 0 18px 50px rgba(0,0,0,.55); }

body{
  background:
    radial-gradient(1200px 600px at 50% -10%, color-mix(in srgb, var(--accent) 6%, transparent), transparent 60%),
    radial-gradient(900px 500px at 100% 110%, color-mix(in srgb, var(--accent-2) 5%, transparent), transparent 55%),
    var(--bg);
}

::selection{ background: color-mix(in srgb, var(--accent) 35%, transparent); color: var(--text); }

@keyframes oxFade{ from{ opacity:0; transform: translateY(14px); } to{ opacity:1; transform:none; } }

.hero-title, .hero-sub, .section > .container > h2, .card, .feature, .tile, .faq-item, .article > h2{
  animation: oxFade .9s cubic-bezier(.2,.7,.2,1) both;
}

/* Headings — Bodoni Moda, calm and large */
.hero-title{
  color: var(--text);
  font-weight: 600;
  letter-spacing: .02em;
}
.hero-title::after{
  content:""; display:block; width: 88px; height:1px;
  margin: clamp(14px, 2vw, 22px) auto 0;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
h2, .article > h2, .feature h3, .card h3{
  color: var(--text);
  font-weight: 600;
  letter-spacing: .015em;
}
.hero-sub, .muted{ color: var(--text-2); }

/* Header — quiet onyx bar with a gold hairline */
.site-header{
  background: color-mix(in srgb, var(--panel) 78%, transparent);
  backdrop-filter: blur(10px) saturate(120%);
  border-bottom: 1px solid var(--line);
}

/* Hero panel */
.hero{
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 60%, transparent), transparent 70%);
  border-bottom: 1px solid var(--line);
}
.facts .fact{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}
.facts .fact b{ color: var(--accent); font-weight: 600; letter-spacing:.02em; }

/* Badges */
.badge{
  background: color-mix(in srgb, var(--panel-2) 80%, transparent);
  border: 1px solid var(--line);
  color: var(--text-2);
  border-radius: 999px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Cards & features */
.card, .feature, .faq-item{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform .5s cubic-bezier(.2,.7,.2,1), border-color .5s, box-shadow .5s;
  position: relative;
}
.card::before, .feature::before{
  content:""; position:absolute; left:0; top:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity:.4; transition: opacity .5s;
}
.card:hover, .feature:hover{
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  box-shadow: 0 26px 60px rgba(0,0,0,.6);
}
.card:hover::before, .feature:hover::before{ opacity:1; }

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

/* Buttons — gold outline CTA */
.btn{ border-radius: var(--radius); transition: transform .35s, background .35s, color .35s, border-color .35s; letter-spacing:.04em; }
.btn-primary{
  background: var(--accent);
  color: var(--on-accent);
  border: 1px solid var(--accent);
}
.btn-primary:hover{ transform: translateY(-2px); background: var(--accent-2); border-color: var(--accent-2); }
.btn-ghost{
  background: transparent;
  color: var(--text);
  border: 1px solid var(--accent);
}
.btn-ghost:hover{ background: color-mix(in srgb, var(--accent) 12%, transparent); }

/* Catalog tiles */
.tabs .tab{
  background: transparent;
  border: 1px solid var(--line);
  color: var(--text-2);
  border-radius: 999px;
  transition: color .4s, border-color .4s, background .4s;
}
.tabs .tab.active, .tabs .tab:hover{
  color: var(--text); border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}
.tile{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .5s cubic-bezier(.2,.7,.2,1), border-color .5s, box-shadow .5s;
}
.tile:hover{ transform: translateY(-4px); border-color: color-mix(in srgb, var(--accent) 50%, var(--line)); box-shadow: var(--shadow-soft); }
.tile .gp{ color: var(--accent); letter-spacing:.1em; text-transform: uppercase; }
.tile .nm{ color: var(--text); }
.tile.noimg{ background: linear-gradient(160deg, var(--panel-2), var(--panel)); }
.tile.noimg .nm{ color: var(--text); font-weight: 600; letter-spacing:.02em; }

/* Article & table */
.article{ color: var(--prose); }
.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(--accent); letter-spacing:.04em; }
.table td{ border-bottom: 1px solid var(--line); color: var(--prose); }

/* FAQ */
.faq-q{ color: var(--text); font-weight: 600; }
.faq-item:hover{ border-color: color-mix(in srgb, var(--accent) 40%, var(--line)); }
.faq-a{ color: var(--prose); }

/* Footer */
.site-footer{ border-top: 1px solid var(--line); background: color-mix(in srgb, var(--panel) 50%, transparent); }
.site-footer a{ color: var(--text-2); transition: color .3s; }
.site-footer a:hover{ color: var(--accent); }