:root{
  --shadow-soft: 0 1px 2px rgba(0,40,80,0.06);
  --shadow-hover: 0 8px 24px rgba(0,80,140,0.10);
}

/* ===== Base canvas: cool ocean light ===== */
body{
  background:
    radial-gradient(1100px 520px at 88% -8%, color-mix(in srgb, var(--accent) 8%, transparent), transparent 60%),
    radial-gradient(900px 480px at -6% 6%, color-mix(in srgb, var(--accent) 6%, transparent), transparent 55%),
    var(--bg);
}

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

/* ===== Hero: airy, crisp ===== */
.hero{
  background:
    radial-gradient(680px 340px at 18% 0%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 62%),
    radial-gradient(520px 300px at 95% 30%, color-mix(in srgb, var(--accent-2) 10%, transparent), transparent 60%),
    var(--panel);
  border:1px solid var(--line);
  border-radius: calc(var(--radius) + 6px);
  box-shadow: var(--shadow-soft);
}
.hero-title{
  font-weight:700;
  letter-spacing:-0.02em;
}
.hero-title b, .hero-title span{
  color:var(--accent);
}
.hero-sub{ color:var(--prose); }

.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); }

/* ===== Cards & features: white on cool, hairline borders ===== */
.card,.feature,.faq-item{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.card:hover,.feature:hover{
  border-color: color-mix(in srgb, var(--accent) 35%, var(--line));
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}

.feature .icon{
  color:var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--panel));
  border:1px solid color-mix(in srgb, var(--accent) 22%, var(--line));
  border-radius:12px;
  box-shadow: var(--shadow-soft);
}
.feature:nth-child(3n+2) .icon{
  color:var(--accent-2);
  background: color-mix(in srgb, var(--accent-2) 12%, var(--panel));
  border-color: color-mix(in srgb, var(--accent-2) 26%, var(--line));
}

/* ===== Headings ===== */
.section h2,.article h2{
  font-weight:700;
  letter-spacing:-0.015em;
}
.section h2::after{
  content:"";
  display:block;
  width:46px;height:3px;
  margin-top:.5rem;
  border-radius:3px;
  background:var(--accent);
}

/* ===== Buttons: flat ocean CTA ===== */
.btn{
  border-radius:12px;
  border:1px solid var(--line);
  transition: background .18s ease, box-shadow .18s ease, transform .12s ease, color .18s ease;
}
.btn-primary{
  background:var(--accent);
  color:var(--on-accent);
  border-color: color-mix(in srgb, var(--accent) 70%, #002850);
  box-shadow: var(--shadow-soft);
}
.btn-primary:hover{
  background: color-mix(in srgb, var(--accent) 88%, #000);
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px);
}
.btn-ghost{
  background:var(--panel);
  color:var(--accent);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
}
.btn-ghost:hover{
  background: color-mix(in srgb, var(--accent) 8%, var(--panel));
  border-color:var(--accent);
}

/* ===== Badges ===== */
.badge{
  background: color-mix(in srgb, var(--accent-2) 12%, var(--panel));
  color: color-mix(in srgb, var(--accent-2) 75%, var(--text));
  border:1px solid color-mix(in srgb, var(--accent-2) 30%, var(--line));
  border-radius:999px;
}

/* ===== Catalog tiles ===== */
.tabs .tab{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--text-2);
  transition: all .18s ease;
}
.tabs .tab:hover{ border-color: color-mix(in srgb, var(--accent) 40%, var(--line)); color:var(--text); }
.tabs .tab.active{
  background:var(--accent);
  color:var(--on-accent);
  border-color:var(--accent);
  box-shadow: var(--shadow-soft);
}
.tile{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow: var(--shadow-soft);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.tile:hover{
  border-color: color-mix(in srgb, var(--accent) 40%, var(--line));
  box-shadow: var(--shadow-hover);
  transform: translateY(-3px);
}
.tile .gp{ color:var(--accent); }
.tile .nm{ color:var(--text); font-weight:600; }
.tile.noimg{
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 8%, var(--panel)), var(--panel));
}

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

/* ===== FAQ ===== */
.faq-item{ overflow:hidden; }
.faq-q{ color:var(--text); font-weight:600; }
.faq-q::before{ content:""; }
.faq-item:hover{ border-color: color-mix(in srgb, var(--accent) 30%, var(--line)); }

/* ===== Links ===== */
.article a, .prose a{
  color:var(--accent);
  text-decoration-color: color-mix(in srgb, var(--accent) 45%, transparent);
  text-underline-offset:2px;
}
.article a:hover{ color: color-mix(in srgb, var(--accent) 80%, #000); }

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