:root {
  --navy-950: #0b091c;
  --navy-900: #1d174a;
  --navy-800: #2d284b;
  --ink: #1d174a;
  --muted: #6f6880;
  --line: #dedbe8;
  --mist: #eeedf4;
  --paper: #f8f7fb;
  --white: #ffffff;
  --mint: #e98246;
  --mint-dark: #bd5720;
  --coral: #e98246;
  --lavender: #c2bcd2;
  --violet: #9f15e8;
  --shadow: 0 22px 60px rgba(29, 23, 74, 0.16);
}

@font-face {
  font-family: "R-Flex Light";
  src: url("https://esatoshi.club/wp-content/themes/blocksy/fonts/R-FLEX-LIGHT.otf") format("opentype");
  font-display: swap;
}
@font-face {
  font-family: "R-Flex Regular";
  src: url("https://esatoshi.club/wp-content/themes/blocksy/fonts/R-FLEX-REGULAR.otf") format("opentype");
  font-display: swap;
}
@font-face {
  font-family: "R-Flex Bold";
  src: url("https://esatoshi.club/wp-content/themes/blocksy/fonts/R-FLEX-BOLD.otf") format("opentype");
  font-display: swap;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "R-Flex Light", "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.5;
}
button, input, select { font: inherit; }
a { color: inherit; }
button, a, select { -webkit-tap-highlight-color: transparent; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link {
  position: fixed;
  z-index: 100;
  left: 16px;
  top: -80px;
  padding: 10px 16px;
  background: var(--mint);
  color: var(--navy-950);
  border-radius: 8px;
}
.skip-link:focus { top: 12px; }

.site-header {
  height: 78px;
  padding: 0 clamp(22px, 5vw, 76px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--white);
  background: var(--navy-950);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.brand-logo { display: block; width: 123px; height: 40px; }
.brand-product { display: flex; align-items: baseline; gap: 5px; padding-left: 14px; border-left: 1px solid rgba(255,255,255,.18); }
.brand strong { font: 700 18px "R-Flex Bold", sans-serif; letter-spacing: -.3px; }
.brand small { color: #948aa8; font-size: 12px; }
.site-header nav { display: flex; gap: 34px; }
.site-header nav a { color: #c2d0d4; font-size: 14px; text-decoration: none; }
.site-header nav a:hover { color: var(--white); }
.header-cta {
  padding: 10px 15px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 8px;
  font-size: 13px;
  text-decoration: none;
}
.header-cta:hover { border-color: var(--mint); color: var(--mint); }

.hero {
  min-height: 612px;
  position: relative;
  overflow: hidden;
  padding: 92px clamp(22px, 7.5vw, 116px) 100px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 314px;
  gap: 8vw;
  align-items: center;
  color: var(--white);
  background:
    radial-gradient(circle at 78% 13%, rgba(77, 190, 162, 0.19), transparent 28%),
    linear-gradient(120deg, #071c2b 0%, #0a2635 64%, #0b2d3a 100%);
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: rgba(255,255,255,.1);
}
.hero-content { position: relative; z-index: 2; max-width: 800px; }
.eyebrow, .section-kicker {
  display: flex;
  align-items: center;
  gap: 9px;
  margin: 0 0 19px;
  color: var(--mint);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.7px;
  text-transform: uppercase;
}
.eyebrow span { width: 24px; height: 1px; background: var(--mint); }
.hero h1 {
  max-width: 820px;
  margin: 0;
  font: 700 clamp(43px, 5.4vw, 76px)/1.04 "R-Flex Bold", sans-serif;
  letter-spacing: -3.6px;
}
.hero-copy {
  max-width: 660px;
  margin: 25px 0 33px;
  color: #b8c9ce;
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.65;
}
.hero-search {
  width: min(760px, 100%);
  height: 66px;
  padding: 6px 7px 6px 20px;
  display: flex;
  align-items: center;
  gap: 13px;
  background: var(--white);
  border-radius: 11px;
  box-shadow: 0 14px 35px rgba(0,0,0,.18);
}
.hero-search svg, .filter-search svg {
  width: 21px;
  fill: none;
  stroke: #698087;
  stroke-width: 1.8;
  stroke-linecap: round;
}
.hero-search input {
  min-width: 0;
  flex: 1;
  color: var(--ink);
  border: 0;
  outline: 0;
  background: transparent;
}
.hero-search input::placeholder { color: #84959a; }
.hero-search button {
  align-self: stretch;
  padding: 0 20px;
  color: var(--navy-950);
  background: var(--mint);
  border: 0;
  border-radius: 7px;
  font-weight: 700;
  cursor: pointer;
}
.hero-search button:hover { background: #a3efd8; }
.hero-search button span { margin-left: 8px; }
.hero-meta { display: flex; gap: 25px; margin-top: 18px; color: #8fa5ac; font-size: 12px; }
.hero-meta span { display: flex; align-items: center; gap: 7px; }
.status-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--mint); box-shadow: 0 0 0 4px rgba(141,232,203,.1); }
.hero-card {
  position: relative;
  z-index: 2;
  padding: 24px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 14px;
  backdrop-filter: blur(10px);
  box-shadow: 0 25px 70px rgba(0,0,0,.16);
}
.hero-card-top { display: flex; justify-content: space-between; align-items: center; color: #9fb1b6; font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px; }
.hero-card-top svg { width: 20px; fill: none; stroke: var(--mint); stroke-width: 1; }
.hero-card > strong { display: block; margin-top: 32px; font: 700 54px "R-Flex Bold", sans-serif; letter-spacing: -2px; }
.hero-card > p { margin: -4px 0 27px; color: #9fb1b6; font-size: 13px; }
.mini-stats { display: grid; grid-template-columns: 1fr 1fr; padding: 19px 0; border-top: 1px solid rgba(255,255,255,.12); border-bottom: 1px solid rgba(255,255,255,.12); }
.mini-stats div { display: flex; flex-direction: column; }
.mini-stats div + div { padding-left: 20px; border-left: 1px solid rgba(255,255,255,.12); }
.mini-stats b { font: 700 23px "R-Flex Bold", sans-serif; }
.mini-stats span { color: #8fa5ac; font-size: 11px; }
.card-footnote { padding-top: 17px; color: var(--mint); font-size: 11px; }
.hero-orbit { position: absolute; border: 1px solid rgba(141,232,203,.07); border-radius: 50%; }
.orbit-one { width: 620px; height: 620px; right: -140px; top: -300px; }
.orbit-two { width: 400px; height: 400px; right: 90px; bottom: -300px; }

.trust-strip {
  min-height: 74px;
  padding: 17px clamp(22px, 7.5vw, 116px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  color: #455d65;
  background: #edf3f1;
  border-bottom: 1px solid #dce6e3;
  font-size: 13px;
}
.trust-strip p { max-width: 850px; margin: 0; }
.trust-strip strong { color: var(--ink); }
.trust-strip a { color: var(--mint-dark); font-weight: 700; text-decoration: none; white-space: nowrap; }
.section-shell { width: min(1200px, calc(100% - 44px)); margin-inline: auto; }
.register { padding-block: 100px; }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 50px; margin-bottom: 38px; }
.section-kicker { color: var(--mint-dark); margin-bottom: 13px; }
.section-heading h2, .about h2, .methodology h2, .source h2 {
  max-width: 650px;
  margin: 0;
  font: 700 clamp(32px, 3.3vw, 46px)/1.15 "R-Flex Bold", sans-serif;
  letter-spacing: -1.8px;
}
.section-heading > p { max-width: 420px; margin: 0 0 4px; color: var(--muted); font-size: 14px; }
.register-panel { background: var(--white); border: 1px solid var(--line); border-radius: 13px; box-shadow: 0 8px 35px rgba(7,28,43,.05); overflow: hidden; }
.filters { padding: 18px; display: grid; grid-template-columns: 1.6fr 1fr 1fr auto; gap: 10px; background: #f7f9f8; border-bottom: 1px solid var(--line); }
.filters input, .filters select {
  width: 100%;
  height: 45px;
  color: var(--ink);
  background: var(--white);
  border: 1px solid #d3dfe0;
  border-radius: 7px;
  outline: none;
}
.filters input:focus, .filters select:focus, .result-summary select:focus { border-color: var(--mint-dark); box-shadow: 0 0 0 3px rgba(11,117,95,.1); }
.filter-search { position: relative; }
.filter-search svg { position: absolute; left: 15px; top: 12px; width: 19px; }
.filter-search input { padding: 0 13px 0 45px; }
.filters select { padding: 0 34px 0 13px; }
.reset-button { padding: 0 14px; color: #6c7e83; background: transparent; border: 0; cursor: pointer; font-size: 13px; }
.reset-button:hover { color: var(--mint-dark); }
.result-summary { padding: 18px 22px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line); }
.result-summary p { margin: 0; color: var(--muted); font-size: 13px; }
.result-summary p strong { color: var(--ink); }
.result-summary label { color: var(--muted); font-size: 12px; }
.result-summary select { margin-left: 8px; padding: 7px 28px 7px 9px; color: var(--ink); background: #f7f9f8; border: 1px solid var(--line); border-radius: 6px; outline: 0; }
.provider-row { min-height: 93px; padding: 17px 22px; display: grid; grid-template-columns: minmax(230px, 1.45fr) minmax(130px, .75fr) minmax(260px, 1.25fr) 115px 30px; gap: 20px; align-items: center; border-bottom: 1px solid #e6ecec; }
.table-header { min-height: 42px; padding-block: 11px; color: #71848a; background: #fbfcfc; font-size: 10px; letter-spacing: .8px; text-transform: uppercase; }
.provider-row:not(.table-header) { cursor: pointer; transition: background .18s ease; }
.provider-row:not(.table-header):hover { background: #f8fbfa; }
.provider-identity { display: flex; align-items: center; gap: 13px; min-width: 0; }
.provider-monogram { flex: 0 0 38px; width: 38px; height: 38px; display: grid; place-items: center; color: var(--mint-dark); background: #e9f7f2; border-radius: 50%; font: 700 13px "R-Flex Bold", sans-serif; }
.provider-identity div { min-width: 0; }
.provider-identity strong { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 14px; }
.provider-identity small { display: block; margin-top: 3px; overflow: hidden; color: #71848a; font-size: 11px; text-overflow: ellipsis; white-space: nowrap; }
.market { display: flex; align-items: center; gap: 8px; font-size: 13px; }
.flag { width: 27px; height: 20px; display: grid; place-items: center; color: #50656c; background: #eef2f1; border: 1px solid #dce4e3; border-radius: 4px; font-size: 8px; font-weight: 700; }
.service-tags { display: flex; flex-wrap: wrap; gap: 5px; }
.service-tag { max-width: 170px; padding: 4px 8px; overflow: hidden; color: #476069; background: #f0f4f3; border-radius: 4px; font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }
.service-more { color: var(--mint-dark); background: #e5f5f0; }
.date { color: #4f666e; font-size: 12px; }
.row-arrow { color: #8ba0a5; font-size: 18px; }
.load-more { width: 100%; padding: 18px; color: var(--ink); background: #fbfcfc; border: 0; font-weight: 700; font-size: 12px; cursor: pointer; }
.load-more:hover { background: #f4f8f7; color: var(--mint-dark); }
.load-more span { margin-left: 8px; }
.empty-state { padding: 68px 24px; text-align: center; }
.empty-state div { width: 43px; height: 43px; margin: auto; display: grid; place-items: center; color: var(--mint-dark); background: #e7f5f1; border-radius: 50%; font-weight: 700; }
.empty-state h3 { margin: 16px 0 8px; font: 700 20px "R-Flex Bold", sans-serif; }
.empty-state p { max-width: 540px; margin: auto; color: var(--muted); font-size: 13px; }
.empty-state button { margin-top: 20px; padding: 9px 14px; color: var(--mint-dark); background: transparent; border: 1px solid #a9d8ca; border-radius: 6px; cursor: pointer; }

.about { padding: 104px 0; color: var(--white); background: var(--navy-900); }
.about-grid { display: grid; grid-template-columns: .9fr 1.25fr; gap: 9vw; }
.section-kicker.light { color: var(--mint); }
.about-intro p:not(.section-kicker) { max-width: 460px; margin: 23px 0; color: #9fb3b9; font-size: 15px; line-height: 1.7; }
.about-intro a { color: var(--mint); font-size: 13px; font-weight: 700; text-decoration: none; }
.principles { border-top: 1px solid rgba(255,255,255,.15); }
.principles article { padding: 25px 0; display: grid; grid-template-columns: 55px 150px 1fr; gap: 18px; align-items: start; border-bottom: 1px solid rgba(255,255,255,.15); }
.principles article > span { color: var(--mint); font: 600 11px "R-Flex Bold", sans-serif; }
.principles h3 { margin: 0; font: 600 16px "R-Flex Bold", sans-serif; }
.principles p { margin: 0; color: #91a7ad; font-size: 13px; line-height: 1.6; }
.methodology { padding-block: 98px; display: grid; grid-template-columns: 80px 1fr 1fr; gap: 6vw; align-items: start; }
.method-number { width: 48px; height: 48px; display: grid; place-items: center; color: var(--mint-dark); border: 1px solid #a7d8ca; border-radius: 50%; font: 700 12px "R-Flex Bold", sans-serif; }
.method-copy { color: var(--muted); font-size: 14px; line-height: 1.75; }
.method-copy p { margin: 0 0 17px; }
.source { padding-bottom: 100px; }
.source-card { padding: 33px; display: grid; grid-template-columns: 65px 1fr auto; gap: 28px; align-items: center; color: var(--white); background: #0e3543; border-radius: 14px; }
.source-icon { width: 58px; height: 58px; display: grid; place-items: center; background: rgba(141,232,203,.1); border: 1px solid rgba(141,232,203,.25); border-radius: 50%; }
.source-icon svg { width: 25px; fill: none; stroke: var(--mint); stroke-width: 1.5; }
.source-card .section-kicker { margin-bottom: 8px; color: var(--mint); }
.source-card h2 { font-size: 26px; letter-spacing: -1px; }
.source-card p:not(.section-kicker) { max-width: 650px; margin: 10px 0 0; color: #a2b7bc; font-size: 13px; }
.source-actions { display: flex; flex-direction: column; gap: 8px; }
.source-actions a { min-width: 185px; padding: 10px 14px; color: var(--navy-950); background: var(--mint); border: 1px solid var(--mint); border-radius: 6px; text-align: center; text-decoration: none; font-size: 12px; font-weight: 700; }
.source-actions .secondary { color: #c0d0d4; background: transparent; border-color: rgba(255,255,255,.2); }
footer { padding: 34px clamp(22px, 7.5vw, 116px); display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 30px; align-items: center; color: #8fa4aa; background: var(--navy-950); font-size: 11px; }
.footer-brand { display: flex; align-items: center; gap: 11px; }
.footer-brand .brand-mark { width: 34px; height: 34px; }
.footer-brand div { display: flex; flex-direction: column; }
.footer-brand strong { color: var(--white); font: 700 14px "R-Flex Bold", sans-serif; }
.footer-brand span:not(.brand-mark) { color: #728c93; }
footer p { margin: 0; }
footer > div:last-child { display: flex; justify-content: flex-end; gap: 20px; }
footer a { text-decoration: none; }
footer a:hover { color: var(--mint); }

dialog { width: min(680px, calc(100% - 30px)); max-height: calc(100vh - 40px); padding: 0; color: var(--ink); background: var(--paper); border: 0; border-radius: 15px; box-shadow: var(--shadow); }
dialog::backdrop { background: rgba(1,14,22,.7); backdrop-filter: blur(4px); }
.dialog-close { position: absolute; z-index: 2; right: 18px; top: 17px; width: 34px; height: 34px; color: #b7c8cc; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: 50%; font-size: 22px; line-height: 1; cursor: pointer; }
.dialog-hero { padding: 34px; color: var(--white); background: var(--navy-900); }
.dialog-hero .status-badge { display: inline-flex; align-items: center; gap: 7px; padding: 5px 9px; color: var(--mint); background: rgba(141,232,203,.1); border-radius: 4px; font-size: 10px; text-transform: uppercase; letter-spacing: .8px; }
.dialog-hero .status-badge::before { content: ""; width: 6px; height: 6px; background: var(--mint); border-radius: 50%; }
.dialog-hero h2 { margin: 18px 45px 3px 0; font: 700 29px "R-Flex Bold", sans-serif; letter-spacing: -1px; }
.dialog-hero p { margin: 0; color: #9db1b7; font-size: 13px; }
.dialog-body { padding: 30px 34px 34px; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; padding-bottom: 28px; border-bottom: 1px solid var(--line); }
.detail-grid div { min-width: 0; }
.detail-grid span, .dialog-section-title { display: block; margin-bottom: 5px; color: #7b8e94; font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
.detail-grid strong, .detail-grid a { display: block; overflow-wrap: anywhere; font-size: 13px; font-weight: 600; text-decoration: none; }
.detail-grid a { color: var(--mint-dark); }
.dialog-section { padding-top: 25px; }
.dialog-services { display: flex; flex-wrap: wrap; gap: 7px; }
.dialog-services span { padding: 7px 10px; color: #3d5961; background: #ebf1ef; border-radius: 5px; font-size: 11px; }
.passport-list { display: flex; flex-wrap: wrap; gap: 5px; }
.passport-list span { width: 28px; height: 23px; display: grid; place-items: center; color: #50656c; background: #eef2f1; border: 1px solid #dce4e3; border-radius: 4px; font-size: 8px; font-weight: 700; }
.dialog-note { margin: 26px 0 0; padding: 13px; color: #657a81; background: #f0f4f3; border-left: 3px solid var(--mint-dark); font-size: 11px; }

.market-pulse { padding-block: 108px 20px; }
.pulse-heading { margin-bottom: 30px; }
.pulse-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 14px;
}
.pulse-kpis article {
  min-height: 132px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: 0 12px 35px rgba(29,23,74,.05);
}
.pulse-kpis article:first-child {
  color: var(--white);
  background: var(--navy-900);
  border-color: var(--navy-900);
}
.pulse-kpis span {
  color: var(--muted);
  font-size: 11px;
  letter-spacing: .7px;
  text-transform: uppercase;
}
.pulse-kpis article:first-child span { color: #aaa3ba; }
.pulse-kpis strong {
  color: var(--navy-900);
  font: 700 38px/1 "R-Flex Bold", sans-serif;
}
.pulse-kpis article:first-child strong { color: var(--white); }
.pulse-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.chart-card {
  min-width: 0;
  padding: 27px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: 0 12px 35px rgba(29,23,74,.05);
}
.timeline-card { grid-column: 1 / -1; }
.chart-heading {
  min-height: 52px;
  margin-bottom: 25px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 20px;
}
.chart-heading h3 { margin: 0; color: var(--navy-900); font-size: 17px; }
.chart-heading p { margin: 5px 0 0; color: var(--muted); font-size: 11px; }
.chart-heading > strong { color: var(--mint-dark); font-size: 12px; white-space: nowrap; }
.horizontal-chart { display: grid; gap: 13px; }
.chart-row {
  display: grid;
  grid-template-columns: minmax(95px, 145px) 1fr 30px;
  gap: 12px;
  align-items: center;
}
.chart-label {
  overflow: hidden;
  color: #514a64;
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.chart-track {
  height: 8px;
  overflow: hidden;
  background: #efedf4;
  border-radius: 999px;
}
.chart-track i {
  display: block;
  height: 100%;
  background: var(--mint);
  border-radius: inherit;
}
.service-chart .chart-track i { background: #6d2d91; }
.chart-row strong { color: var(--navy-900); font-size: 11px; text-align: right; }
.timeline-chart {
  height: 210px;
  padding-top: 10px;
  display: grid;
  grid-template-columns: repeat(12, minmax(28px, 1fr));
  gap: clamp(6px, 1.2vw, 16px);
  align-items: end;
  border-bottom: 1px solid #d9d5e2;
}
.timeline-column {
  height: 100%;
  min-width: 0;
  display: grid;
  grid-template-rows: 18px 1fr 28px;
  justify-items: center;
  gap: 5px;
}
.timeline-column strong { color: #766f87; font-size: 9px; font-weight: 500; }
.timeline-track {
  width: min(26px, 70%);
  height: 100%;
  display: flex;
  align-items: end;
}
.timeline-track i {
  width: 100%;
  min-height: 2px;
  background: var(--mint);
  border-radius: 5px 5px 0 0;
}
.timeline-column small { color: #7b748b; font-size: 9px; }

.verification-result {
  padding: 18px;
  display: grid;
  gap: 10px;
  background: #faf9fc;
  border-bottom: 1px solid var(--line);
}
.verification-card {
  padding: 20px;
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 15px;
  align-items: start;
  border: 1px solid;
  border-radius: 18px;
}
.verification-authorised { background: #f5f1f8; border-color: #d7c8e1; }
.verification-ended { background: #fff6f0; border-color: #f1c3a8; }
.verification-warning { background: #fff6f0; border-color: #f1c3a8; }
.verification-neutral { background: #f3f2f6; border-color: #dcd8e5; }
.verification-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  color: var(--white);
  background: #6d2d91;
  border-radius: 50%;
  font-family: "R-Flex Bold", sans-serif;
}
.verification-warning .verification-icon { background: var(--mint); }
.verification-ended .verification-icon { background: var(--mint); }
.verification-neutral .verification-icon { color: #6f6880; background: #e3e0e9; }
.verification-label {
  display: block;
  margin: 1px 0 7px;
  color: #6d2d91;
  font: 700 10px "R-Flex Bold", sans-serif;
  letter-spacing: .8px;
  text-transform: uppercase;
}
.verification-warning .verification-label { color: #ad4e1b; }
.verification-ended .verification-label { color: #ad4e1b; }
.verification-neutral .verification-label { color: #6f6880; }
.alias-match {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 4px 8px;
  color: #6d2d91;
  background: #ebe2f1;
  border-radius: 7px;
  font-size: 10px;
}
.verification-card h3 { margin: 0; color: var(--navy-900); font-size: 20px; }
.verification-card p { margin: 5px 0 0; color: var(--muted); font-size: 12px; }
.verification-facts {
  margin-top: 13px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.verification-facts span {
  padding: 6px 9px;
  color: #5e576f;
  background: rgba(255,255,255,.72);
  border-radius: 8px;
  font-size: 10px;
}
.verification-card > div > button {
  margin-top: 15px;
  padding: 9px 13px;
  color: var(--white);
  background: var(--navy-900);
  border: 0;
  border-radius: 10px;
  cursor: pointer;
  font-size: 11px;
}
.verification-entities { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 7px; }
.verification-entities button {
  padding: 8px 10px;
  color: var(--navy-900);
  background: var(--white);
  border: 1px solid #d7c8e1;
  border-radius: 9px;
  cursor: pointer;
  font-size: 11px;
}
.verification-entities button span { color: var(--muted); font-size: 9px; }
.verification-websites { overflow-wrap: anywhere; }
.warning-records { margin-top: 12px; display: grid; gap: 7px; }
.warning-record {
  padding: 9px 11px;
  display: grid;
  gap: 2px;
  background: rgba(255,255,255,.62);
  border-radius: 9px;
}
.warning-record strong { color: var(--navy-900); font-size: 11px; }
.warning-record span { color: #6f6880; font-size: 10px; }
.warning-record small { overflow-wrap: anywhere; color: #9a4619; font-size: 9px; }
.verification-caveat { max-width: 760px; font-size: 10px !important; }

/* Satoshi Club brand system */
strong, h1, h2, h3, h4, h5, h6 { font-family: "R-Flex Bold", sans-serif; }
.accent-dot { color: var(--mint); }

.site-header {
  height: 112px;
  padding-inline: clamp(24px, 6.5vw, 100px);
  background: #1d174a;
  border-bottom-color: #2d284b;
}
.site-header nav { gap: clamp(26px, 4vw, 64px); }
.site-header nav a { color: #948aa8; font-size: 15px; }
.header-cta {
  padding: 12px 22px;
  color: var(--white);
  background: var(--mint);
  border: 0;
  border-radius: 12px;
  font-family: "R-Flex Regular", sans-serif;
}
.header-cta:hover { color: var(--white); background: #f09158; }

.hero {
  min-height: 650px;
  padding: 86px clamp(24px, 7.5vw, 116px) 112px;
  background:
    linear-gradient(120deg, rgba(11, 9, 28, .97) 0%, rgba(29, 23, 74, .94) 58%, rgba(45, 40, 75, .92) 100%),
    url("https://esatoshi.club/wp-content/uploads/2022/08/main-bg-solid.png") center / cover;
}
.hero::before {
  content: "";
  position: absolute;
  width: 520px;
  height: 520px;
  right: 4vw;
  top: 25px;
  background: radial-gradient(circle, rgba(233,130,70,.16), rgba(159,21,232,.06) 42%, transparent 70%);
  filter: blur(8px);
}
.eyebrow, .section-kicker { color: var(--mint); }
.eyebrow span { background: var(--mint); }
.hero h1 {
  max-width: 880px;
  font-size: clamp(47px, 5vw, 72px);
  line-height: 1.09;
  letter-spacing: -2.8px;
}
.hero-copy { color: #c2bcd2; font-size: clamp(16px, 1.35vw, 18px); }
.hero-search {
  min-height: 70px;
  border-radius: 16px;
  box-shadow: 0 20px 64px rgba(0,0,0,.28);
}
.hero-search button {
  padding-inline: 25px;
  color: var(--white);
  background: var(--mint);
  border-radius: 12px;
  font-family: "R-Flex Regular", sans-serif;
}
.hero-search button:hover { background: #f09158; }
.hero-meta { color: #948aa8; }
.status-dot { background: var(--mint); box-shadow: 0 0 0 4px rgba(233,130,70,.12); }
.hero-card {
  padding: 29px;
  color: var(--ink);
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(145deg, #9f15e8, #ea9548) border-box;
  border: 2px solid transparent;
  border-radius: 32px;
  backdrop-filter: none;
  box-shadow: 0 28px 80px rgba(0,0,0,.24);
}
.hero-card-top { color: #756e88; }
.hero-card-top svg { stroke: var(--mint); }
.hero-card > strong { color: var(--navy-900); font-size: 60px; }
.hero-card > p { color: #756e88; }
.mini-stats { border-color: #e6e3ed; }
.mini-stats div + div { border-left-color: #e6e3ed; }
.mini-stats b { color: var(--navy-900); }
.mini-stats span { color: #837c94; }
.card-footnote { color: var(--mint-dark); }
.hero-orbit { border-color: rgba(233,130,70,.1); }

.trust-strip {
  color: #6f6880;
  background: #eeedf4;
  border-bottom-color: #dedbe8;
}
.trust-strip strong { color: var(--navy-900); }
.trust-strip a { color: var(--mint-dark); }

.register { padding-block: 112px; }
.section-kicker { color: var(--mint-dark); }
.section-heading h2, .about h2, .methodology h2, .source h2 { letter-spacing: -1.2px; }
.register-panel {
  border-color: #dedbe8;
  border-radius: 24px;
  box-shadow: 0 18px 55px rgba(29,23,74,.08);
}
.filters { padding: 20px; background: #eeedf4; border-bottom-color: #dedbe8; }
.filters input, .filters select {
  height: 48px;
  border-color: #d5d0e0;
  border-radius: 12px;
}
.filters input:focus, .filters select:focus, .result-summary select:focus {
  border-color: var(--mint);
  box-shadow: 0 0 0 3px rgba(233,130,70,.13);
}
.reset-button:hover { color: var(--mint-dark); }
.result-summary select { border-radius: 9px; }
.provider-row { border-bottom-color: #e8e5ee; }
.provider-row:not(.table-header):hover { background: #f8f6fb; }
.table-header { color: #7b748b; background: #faf9fc; }
.provider-monogram {
  color: #6d2d91;
  background: #f0e8f5;
}
.flag, .passport-list span {
  color: #665f77;
  background: #eeedf4;
  border-color: #dedbe8;
}
.service-tag {
  color: #625b73;
  background: #f0eef4;
  border-radius: 8px;
}
.service-more { color: #9a4619; background: #fbece3; }
.load-more { background: #faf9fc; }
.load-more:hover { color: var(--mint-dark); background: #f3f0f7; }

.about {
  background:
    radial-gradient(circle at 78% 40%, rgba(159,21,232,.12), transparent 30%),
    linear-gradient(135deg, #0b091c, #1d174a 70%, #211c47);
}
.section-kicker.light, .about-intro a, .principles article > span { color: var(--mint); }
.about-intro p:not(.section-kicker), .principles p { color: #aaa3ba; }
.principles, .principles article { border-color: rgba(194,188,210,.2); }
.method-number {
  color: var(--white);
  background: var(--mint);
  border-color: var(--mint);
}
.source-card {
  background:
    linear-gradient(#211c47, #211c47) padding-box,
    linear-gradient(135deg, #9f15e8, #ea9548) border-box;
  border: 2px solid transparent;
  border-radius: 32px;
}
.source-icon {
  background: rgba(233,130,70,.1);
  border-color: rgba(233,130,70,.28);
}
.source-icon svg { stroke: var(--mint); }
.source-card p:not(.section-kicker) { color: #b8b2c7; }
.source-actions a {
  color: var(--white);
  background: var(--mint);
  border-color: var(--mint);
  border-radius: 12px;
}
.source-actions .secondary { color: #ddd9e6; border-color: rgba(255,255,255,.22); }

footer {
  min-height: 132px;
  background: #0b091c;
  color: #948aa8;
}
.footer-brand { gap: 18px; }
.footer-brand div { padding-left: 18px; border-left: 1px solid rgba(255,255,255,.16); }
.footer-brand span:not(.brand-mark) { color: #776f89; }
footer a:hover { color: var(--mint); }

dialog { border-radius: 24px; }
dialog::backdrop { background: rgba(11,9,28,.78); }
.dialog-hero { background: linear-gradient(135deg, #0b091c, #1d174a); }
.dialog-hero .status-badge { color: #f1a77d; background: rgba(233,130,70,.12); }
.dialog-hero .status-badge::before { background: var(--mint); }
.dialog-services span { color: #5f586f; background: #efedf4; border-radius: 9px; }
.detail-grid a { color: var(--mint-dark); }
.dialog-note { color: #665f77; background: #f0eef4; border-left-color: var(--mint); }

@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; min-height: auto; padding-block: 75px; }
  .hero-card { display: none; }
  .pulse-kpis { grid-template-columns: repeat(2, 1fr); }
  .pulse-grid { grid-template-columns: 1fr; }
  .timeline-card { grid-column: 1; }
  .provider-row { grid-template-columns: minmax(210px, 1.2fr) 120px minmax(200px, 1fr) 28px; }
  .provider-row > :nth-child(4) { display: none; }
  .about-grid { grid-template-columns: 1fr; gap: 60px; }
  .methodology { grid-template-columns: 60px 1fr; }
  .method-copy { grid-column: 2; }
  .source-card { grid-template-columns: 55px 1fr; }
  .source-actions { grid-column: 2; flex-direction: row; }
  footer { grid-template-columns: 1fr 1fr; }
  footer p { display: none; }
}

@media (max-width: 900px) {
  .site-header { padding-inline: 28px; }
  .site-header nav { gap: 25px; }
  .site-header nav a { white-space: nowrap; }
  .header-cta { display: none; }
}

@media (max-width: 720px) {
  .site-header { height: 68px; }
  .site-header nav, .header-cta { display: none; }
  .hero { padding-top: 24px; padding-bottom: 54px; }
  .hero-content { display: flex; flex-direction: column; }
  .eyebrow { order: 1; margin-bottom: 16px; }
  .hero h1 {
    order: 2;
    font-size: clamp(40px, 10.5vw, 44px);
    line-height: 1.08;
    letter-spacing: -2.1px;
  }
  .hero h1 br { display: none; }
  .hero-search {
    order: 3;
    height: auto;
    margin-top: 22px;
    padding: 7px 7px 7px 14px;
    flex-wrap: wrap;
  }
  .hero-search input { height: 39px; width: calc(100% - 40px); }
  .hero-search button { width: 100%; height: 43px; }
  .hero-copy { order: 4; margin: 22px 0 0; line-height: 1.58; }
  .hero-meta { order: 5; margin-top: 14px; flex-direction: column; gap: 5px; }
  .trust-strip { align-items: start; flex-direction: column; gap: 9px; }
  .market-pulse { padding-top: 72px; }
  .pulse-kpis { gap: 9px; }
  .pulse-kpis article { min-height: 108px; padding: 18px; border-radius: 16px; }
  .pulse-kpis strong { font-size: 30px; }
  .chart-card { padding: 21px 18px; border-radius: 19px; }
  .chart-row { grid-template-columns: 92px 1fr 27px; gap: 8px; }
  .timeline-chart {
    padding-bottom: 2px;
    grid-template-columns: repeat(12, minmax(24px, 1fr));
    gap: 5px;
  }
  .timeline-track { width: 18px; }
  .verification-result { padding: 10px; }
  .verification-card { padding: 16px; grid-template-columns: 35px 1fr; gap: 11px; }
  .verification-icon { width: 35px; height: 35px; }
  .verification-card h3 { font-size: 17px; }
  .verification-facts { flex-direction: column; align-items: start; }
  .register { padding-block: 72px; }
  .section-heading { align-items: start; flex-direction: column; gap: 18px; }
  .filters { grid-template-columns: 1fr; }
  .reset-button { min-height: 38px; }
  .result-summary { align-items: start; gap: 12px; flex-direction: column; }
  .table-header { display: none; }
  .provider-row { padding: 18px; grid-template-columns: 1fr 20px; gap: 14px; }
  .provider-row > .market, .provider-row > .service-tags { grid-column: 1; }
  .provider-row > .row-arrow { grid-column: 2; grid-row: 1; }
  .provider-row > :nth-child(4) { display: none; }
  .about { padding-block: 75px; }
  .principles article { grid-template-columns: 35px 1fr; }
  .principles p { grid-column: 2; }
  .methodology { padding-block: 72px; grid-template-columns: 1fr; gap: 25px; }
  .method-copy { grid-column: 1; }
  .source { padding-bottom: 72px; }
  .source-card { padding: 25px; grid-template-columns: 1fr; }
  .source-icon { width: 48px; height: 48px; }
  .source-actions { grid-column: 1; flex-direction: column; }
  footer { grid-template-columns: 1fr; }
  footer > div:last-child { justify-content: flex-start; flex-wrap: wrap; }
  .detail-grid { grid-template-columns: 1fr; }
  .dialog-hero, .dialog-body { padding-left: 24px; padding-right: 24px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition-duration: .01ms !important; }
}
