:root{
  --shadow-soft: 0 1px 0 var(--line), 0 18px 40px rgba(0,0,0,.45);
}

body{
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(198,155,60,.06), transparent 60%),
    var(--bg);
}

.section:nth-of-type(even){
  background:
    linear-gradient(180deg, rgba(255,255,255,.012), transparent 40%),
    var(--bg);
}

/* Headings — Bodoni display, ivory, calm letter-spacing */
.hero-title,
.article h2,
.section > .container > h2,
.feature h3,
.card h3{
  color: var(--text);
  font-weight: 600;
  letter-spacing: .02em;
}

.hero-title{
  letter-spacing: .03em;
  font-style: italic;
}

.section > .container > h2{
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: clamp(1.4rem, 2.6vw, 2rem);
}

/* Hairline accent under section titles */
.section > .container > h2::after{
  content:"";
  display:block;
  width: 64px;
  height: 1px;
  margin-top: .7rem;
  background: var(--accent);
}

/* Hero — onyx with single gold hairline */
.hero{
  background:
    radial-gradient(90% 70% at 50% 0%, rgba(198,155,60,.05), transparent 65%),
    var(--bg);
  border-bottom: 1px solid var(--line);
}

.hero-sub{ color: var(--prose); }

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

/* Cards / features — charcoal panels, brown-gold hairline */
.card,
.feature{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: border-color .5s ease, transform .5s ease, box-shadow .5s ease;
  opacity: 0;
  animation: og-fade .9s ease forwards;
}

.card:hover,
.feature:hover{
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: 0 1px 0 var(--accent), 0 22px 48px rgba(0,0,0,.5);
}

.feature .icon{
  color: var(--accent);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
}

/* Buttons — 24k outline CTA, no glow */
.btn{
  border-radius: var(--radius);
  letter-spacing: .04em;
  transition: background .45s ease, color .45s ease, border-color .45s ease;
}
.btn-primary{
  background: var(--accent);
  color: var(--on-accent);
  border: 1px solid var(--accent);
}
.btn-primary:hover{ 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: var(--accent); color: var(--on-accent); }

/* Badge */
.badge{
  background: var(--panel-2);
  border: 1px solid var(--accent);
  color: var(--accent);
  border-radius: 999px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

/* Catalog tiles — quiet onyx frames */
.tile{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .5s ease, transform .5s ease;
}
.tile:hover{ border-color: var(--accent); transform: translateY(-2px); }
.tile .nm{ color: var(--text); letter-spacing: .03em; }
.tile .gp{ color: var(--accent); }
.tile.noimg{
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(198,155,60,.07), transparent 70%),
    var(--panel-2);
}

/* Tabs */
.tab{
  background: transparent;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text-2);
  letter-spacing: .06em;
  transition: color .4s ease, border-color .4s ease;
}
.tab.active,
.tab:hover{ color: var(--accent); border-color: var(--accent); }

/* FAQ — hairline-divided */
.faq-item{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.faq-q{ color: var(--text); font-weight: 600; letter-spacing: .02em; }
.faq-a{ color: var(--prose); }

/* Tables */
.table{ border: 1px solid var(--line); }
.table th{
  background: var(--panel-2);
  color: var(--accent);
  letter-spacing: .06em;
  border-bottom: 1px solid var(--accent);
}
.table td{ border-bottom: 1px solid var(--line); color: var(--prose); }

/* Header */
.site-header{
  background: var(--panel);
  border-bottom: 1px solid var(--line);
}

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