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

body{
  background:
    radial-gradient(900px 500px at 12% -8%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%),
    radial-gradient(800px 480px at 92% 6%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 62%),
    var(--bg);
}

.section:nth-of-type(even){
  background:
    radial-gradient(700px 360px at 84% 0%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 70%);
}

/* Headings — regal, wide-tracked Cormorant */
.hero-title,.article h2,.section > .container > h2,.feature h3,.card h3{
  letter-spacing:0.03em;
  font-weight:600;
}
.hero-title{
  letter-spacing:0.04em;
  background:linear-gradient(180deg, var(--text), color-mix(in srgb, var(--accent) 45%, var(--text)));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.article h2{
  padding-bottom:.35em;
  border-bottom:1px solid var(--line);
}
.article h2::after{
  content:"";
  display:block;
  width:64px;
  height:2px;
  margin-top:.45em;
  background:var(--accent-2);
}

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

/* Hero panel */
.hero{
  background:
    radial-gradient(600px 320px at 78% -10%, 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:inset 0 0 0 1px color-mix(in srgb, var(--accent-2) 10%, transparent), 0 24px 60px rgba(0,0,0,0.4);
}
.fact{
  background:color-mix(in srgb, var(--panel) 70%, transparent);
  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);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.card{
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--accent-2), transparent);
  opacity:.6;
}
.card:hover,.feature:hover{
  transform:translateY(-4px);
  border-color:color-mix(in srgb, var(--accent) 55%, var(--line));
  box-shadow:var(--halo), 0 18px 40px rgba(0,0,0,0.45);
}

.feature .icon{
  color:var(--accent-2);
  background:radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--accent) 40%, transparent), color-mix(in srgb, var(--accent) 12%, transparent));
  border:1px solid color-mix(in srgb, var(--accent-2) 35%, var(--line));
  border-radius:var(--radius);
  box-shadow:inset 0 0 14px color-mix(in srgb, var(--accent) 25%, transparent);
}

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

/* Badges */
.badge{
  background:color-mix(in srgb, var(--accent) 18%, transparent);
  border:1px solid color-mix(in srgb, var(--accent-2) 45%, var(--line));
  color:var(--text);
  border-radius:999px;
}

/* Tabs */
.tab{
  border:1px solid var(--line);
  border-radius:999px;
  transition:all .2s ease;
}
.tab.active{
  background:var(--accent);
  color:var(--on-accent);
  border-color:var(--accent-2);
  box-shadow:var(--halo);
}

/* Catalogue 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) 55%, var(--line));
  box-shadow:var(--halo), 0 16px 34px rgba(0,0,0,0.45);
}
.tile .gp{color:var(--accent-2);}
.tile.noimg{
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 60%),
    linear-gradient(180deg, var(--panel-2), var(--panel));
}
.tile.noimg .nm{
  color:var(--text);
  letter-spacing:0.02em;
}

/* Table */
.table{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.table th{
  background:color-mix(in srgb, var(--accent) 16%, var(--panel));
  color:var(--text);
  border-bottom:2px solid var(--accent-2);
}
.table td{border-bottom:1px solid var(--line);}

/* FAQ */
.faq-item{transition:border-color .2s ease, box-shadow .2s ease;}
.faq-item:hover{border-color:color-mix(in srgb, var(--accent) 45%, var(--line));}
.faq-q{color:var(--text);font-weight:600;}
.faq-q::after{color:var(--accent-2);}

/* Footer */
.site-footer{
  border-top:1px solid var(--line);
  background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--accent) 8%, transparent));
}

a{transition:color .2s ease;}
.article a{
  color:var(--accent-2);
  text-decoration:underline;
  text-underline-offset:3px;
  text-decoration-color:color-mix(in srgb, var(--accent-2) 50%, transparent);
}
.article a:hover{color:var(--accent);}