:root{
  --halo: 0 0 24px rgba(130,56,179,0.45);
}

body{
  background:
    radial-gradient(1100px 620px at 12% -8%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(900px 560px at 92% 4%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 55%),
    var(--bg);
}

.section:nth-of-type(even){
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--panel) 40%, transparent), transparent 70%);
}

/* Headings — Cormorant Garamond, wide & regal */
.hero-title,h2,h3,.hero-sub{
  letter-spacing:0.03em;
}
.hero-title{
  font-weight:700;
  letter-spacing:0.035em;
  color:var(--text);
  background:linear-gradient(92deg, var(--text), var(--accent-2) 120%);
  -webkit-background-clip:text;
  background-clip:text;
}
h2{
  font-weight:600;
  position:relative;
  padding-bottom:.35em;
}
h2::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:64px;height:2px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  border-radius:2px;
}

/* Hero */
.hero{
  background:
    radial-gradient(700px 360px at 50% -20%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 65%),
    linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 30px 80px -40px rgba(0,0,0,0.7), inset 0 1px 0 color-mix(in srgb, var(--accent-2) 20%, transparent);
}
.fact{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.fact b{ color:var(--accent-2); }

/* Cards & features */
.card,.feature,.faq-item{
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 18px 50px -34px rgba(0,0,0,0.8);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.card::after,.feature::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--accent-2), transparent);
  opacity:0;
  transition:opacity .25s ease;
}
.card,.feature{ position:relative; }
.card:hover,.feature:hover{
  transform:translateY(-4px);
  border-color:color-mix(in srgb, var(--accent) 60%, var(--line));
  box-shadow:var(--halo), 0 26px 60px -36px rgba(0,0,0,0.85);
}
.card:hover::after,.feature:hover::after{ opacity:1; }

.feature .icon{
  color:var(--on-accent);
  background:linear-gradient(145deg, var(--accent), color-mix(in srgb, var(--accent) 60%, var(--bg)));
  border:1px solid var(--accent-2);
  border-radius:var(--radius);
  box-shadow:inset 0 1px 0 color-mix(in srgb, var(--on-accent) 30%, transparent);
}

/* Buttons */
.btn{
  border-radius:var(--radius);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn-primary{
  background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, var(--bg)));
  color:var(--on-accent);
  border:1px solid var(--accent-2);
  border-bottom-width:2px;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--halo);
}
.btn-ghost{
  background:transparent;
  color:var(--text);
  border:1px solid var(--line);
}
.btn-ghost:hover{
  border-color:var(--accent-2);
  box-shadow:var(--halo);
}

/* Badges */
.badge{
  background:color-mix(in srgb, var(--accent) 16%, var(--panel));
  color:var(--text);
  border:1px solid var(--line);
  border-bottom:1px solid var(--accent-2);
  border-radius:999px;
  letter-spacing:.04em;
}

/* Tabs */
.tab{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:border-color .2s ease, box-shadow .2s ease, color .2s ease;
}
.tab:hover{ border-color:var(--accent-2); }
.tab.active{
  background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 65%, var(--bg)));
  color:var(--on-accent);
  border-color:var(--accent-2);
  box-shadow:var(--halo);
}

/* Catalog tiles */
.tile{
  background:linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.tile:hover{
  transform:translateY(-4px);
  border-color:color-mix(in srgb, var(--accent) 60%, var(--line));
  box-shadow:var(--halo), 0 24px 56px -34px rgba(0,0,0,0.85);
}
.tile .gp{ color:var(--accent-2); letter-spacing:.05em; }
.tile .nm{ color:var(--text); font-weight:600; }
.tile.noimg{
  background:
    radial-gradient(420px 220px at 50% -30%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 70%),
    linear-gradient(180deg, var(--panel-2), var(--panel));
}
.tile.noimg .nm{
  letter-spacing:.03em;
  background:linear-gradient(92deg, var(--text), var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
}

/* FAQ */
.faq-item{ transition:border-color .2s ease, box-shadow .2s ease; }
.faq-item:hover{ border-color:var(--accent-2); }
.faq-q{ color:var(--text); font-weight:600; }
.faq-a{ color:var(--prose); }

/* Article */
.article table.table th{
  background:color-mix(in srgb, var(--accent) 18%, var(--panel));
  color:var(--text);
  border-bottom:2px solid var(--accent-2);
}
.article table.table td{ border-bottom:1px solid var(--line); }

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