:root {
  --bg: #ececec;
  --ink: #101725;
  --dark: #202532;
  --blue: #2580f7;
  --orange: #f5a623;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Montserrat", sans-serif;
}

img {
  max-width: 100%;
  display: block;
}

.container {
  width: min(1560px, calc(100% - 80px));
  margin: 0 auto;
 
}

.hero {
  background: #111827;
  color: #fff;
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(255, 255, 255, 0.18);
}

.hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 112px;
  height: 1px;
  background: rgba(255, 255, 255, 0.14);
  z-index: 1;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(13, 18, 29, 0.92) 0%, rgba(10, 14, 23, 0.72) 52%, rgba(9, 13, 21, 0.9) 100%),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.08) 0, rgba(255, 255, 255, 0.08) 1px, transparent 1px, transparent 320px),
    url("https://images.unsplash.com/photo-1639322537228-f710d846310a?auto=format&fit=crop&w=2000&h=900&q=80") center/cover;
}

.hero-grid {
  position: relative;
  z-index: 2;
  padding: 24px 0 28px;
  min-height: 760px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  align-items: start;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 25px;
  font-weight: 800;
  letter-spacing: 0.2px;
}

.hero .brand {
  font-size: xx-large;
  font-weight: 900;
  letter-spacing: 0.6px;
  margin-bottom: 72px;
}

.shield {
  width: 42px;
  height: 42px;
  border-radius: 8px;
  background: linear-gradient(145deg, #2f96ff, #0f59be);
  box-shadow: inset 0 0 0 3px rgba(255, 255, 255, 0.18);
}

.hero-copy h1 {
  margin: 0 0 10px;
  font-size: 82px;
  line-height: 1.03;
  font-weight: 900;
  max-width: 560px;
}

.hero-copy h1 span {
  color: var(--orange);
}

.lead {
  margin: 0;
  font-size: 56px;
  line-height: 1.08;
  font-weight: 700;
}

.coin-pill {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #081019;
  border-radius: 999px;
  padding: 10px 18px;
}

.coin-pill span {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 700;
  overflow: hidden;
}

.coin-pill span:nth-child(1) { background: #f59a23; }
.coin-pill span:nth-child(2) { background: #67bda2; }
.coin-pill span:nth-child(3) { background: #efc130; }
.coin-pill span img {
  width: 70%;
  height: 70%;
  object-fit: contain;
}
.coin-pill em {
  font-style: normal;
  font-size: 42px;
  line-height: 1;
  color: #fff;
}

.sub {
  margin: 34px 0 0;
  font-size: 16px;
  font-weight: 500;
  opacity: 0.96;
}

.hero-rating {
  margin-top: 24px;
  display: flex;
  gap: 10px;
  align-items: center;
}

.avatar-row {
  display: flex;
}

.avatar-row img {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  margin-right: -14px;
  border: 2px solid #fff;
  object-fit: cover;
}

.hero-rating strong {
  font-size: 22px;
  display: block;
  font-weight: 600;
}

.hero-rating strong b {
  font-weight: 800;
}

.stars {
  color: #ffbf2c;
  font-size: 20px;
  letter-spacing: 2px;
}

.hero-form-wrap {
  position: relative;
  min-height: 620px;
  padding-top: 76px;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.spots-badge {
  position: absolute;
  top: 0;
  right: 0;
  background: #2580f7;
  border-radius: 10px;
  padding: 10px 20px;
  font-size: 18px;
  font-weight: 700;
  z-index: 5;
  white-space: nowrap;
  letter-spacing: 0.2px;
}

.spots-badge b {

  font-size: larger;
}

.phone-bg {
  position: absolute;
  width: 63%;
  right: 278px;
  top: 120px;
  opacity: 0.28;
  filter: blur(0.6px);
  border-radius: 26px;
}

.register-card {
  width: 520px;
  border-radius: 52px;
  background: rgba(39, 43, 60, 0.95);
  border: 10px solid rgba(24, 27, 38, 0.95);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.5);
  padding: 24px 24px 24px;
  position: relative;
  margin-top:60px ;
}

.brand.mini {
  font-size: 16px;
  justify-content: center;
  margin-bottom: 10px;
}

.register-card form {
  display: grid;
  gap: 12px;
}

.register-card.is-redirecting form,
.register-card.is-redirecting .payments {
  display: none;
}

.redirect-state {
  min-height: 230px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  text-align: center;
  color: #fff;
}

.redirect-state[hidden] {
  display: none;
}

.redirect-state p {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.2px;
}

.redirect-loader {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 5px solid rgba(255, 255, 255, 0.2);
  border-top-color: var(--orange);
  border-right-color: var(--blue);
  animation: redirect-spin 0.9s linear infinite;
}

@keyframes redirect-spin {
  to {
    transform: rotate(360deg);
  }
}

.register-card input {
  height: 56px;
  border: 0;
  border-radius: 8px;
  font: 500 16px "Montserrat", sans-serif;
  padding: 0 14px;
}

button {
  border: 0;
  background: var(--orange);
  color: #fff;
  border-radius: 10px;
  height: 56px;
  font: 700 16px "Montserrat", sans-serif;
  letter-spacing: 0.1px;
  cursor: pointer;
  padding: 0 24px;
}

.register-card button {
  height: 60px;
  font-size: 18px;
}

.register-card .register-link {
  display: block;
}

.register-card .register-link button {
  width: 100%;
  display: block;
}

.title-row > button {
  width: 300px;
  height: 56px;
  border-radius: 10px;
}

.phone-input {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 8px;
  height: 56px;
  padding: 0 10px;
  gap: 8px;
}

.phone-input span {
  color: #34445f;
  font-size: 16px;
  white-space: nowrap;
}

.phone-input input {
  border: 0;
  outline: 0;
  height: 100%;
  flex: 1;
  padding: 0;
}

.payments {
  margin-top: 14px;
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  overflow: hidden;
}

.payments img {
  display: block;
  width: auto;
  height: 20px;
  object-fit: contain;
  object-position: center;
  flex: 0 0 auto;
}

.payments img:nth-child(1) { height: 20px; }
.payments img:nth-child(2) { height: 24px; }
.payments img:nth-child(3) { height: 21px; }
.payments img:nth-child(4) { height: 18px; }
.payments img:nth-child(5) { height: 26px; }


.quotes {
  margin-top: 30px;
  display: grid;
  gap: 14px;
}

.quote-card {
  background: #fff;
  border: 1px solid #dbdee5;
  border-radius: 16px;
  display: grid;
  grid-template-columns: 1.45fr 0.9fr;
  overflow: hidden;
  min-height: 400px;
  margin-bottom: 30px;
}

.quote-card.reverse {
  grid-template-columns: 0.9fr 1.45fr;
}

.quote-card img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  object-position: center;
}

.quote-text {
  padding: 28px 34px;
}

.quote-mark {
  font-size: 62px;
  line-height: 0.7;
  color: #f2a41e;
  display: inline-block;
  margin-bottom: 8px;
}

.quote-text h3 {
  margin: 0;
  font-size: 46px;
  font-weight: 800;
}

.quote-text small {
  display: block;
  margin-top: 2px;
  color: #646f82;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.45px;
}

.quote-text p {
  margin: 16px 0 0;
  color: #293145;
  font-size: 16px;
  line-height: 1.42;
}

.block {
  margin-top: 36px;
}

.title-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 26px;
  align-items: center;
  margin-bottom: 22px;
}

.title-row span,
.count {
  font-size: 15px;
  font-weight: 700;
  color: #4f5b71;
}

.title-row h2 {
  margin: 0;
  font-size: 34px;
  line-height: 1.18;
  font-weight: 800;
}

.two-col {
  grid-template-columns: auto 1fr 520px;
}

.two-col p {
  margin: 0;
  font-size: 16px;
  line-height: 1.45;
  color: #4a556d;
}

.terminal {
  background: linear-gradient(130deg, #28324b, #1a1f2a);
  border-radius: 16px;
  padding: 42px 58px;
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  align-items: center;
  gap: 32px;
  min-height: 510px;
}

.coin-col {
  display: grid;
  gap: 10px;
}

.coin-col div {
  background: rgba(0, 0, 0, 0.35);
  border-radius: 12px;
  color: #fff;
  display: flex;
  justify-content: space-between;
  padding: 15px 18px;
  font-size: 14px;
}

.coin-col b {
  display: grid;
  gap: 2px;
  font-size: 18px;
}

.coin-col b small {
  font-size: 14px;
  opacity: 0.72;
}

.coin-col em {
  font-style: normal;
  color: #66e56e;
  font-weight: 700;
  font-size: 20px;
}

.phone-center {
  margin: 0 auto;
  width: 84%;
  border-radius: 16px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.44);
}

.review-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, 1fr);
}

.r-card {
  background: #ececec;
  border: 1px solid #e5e5e5;
  border-radius: 14px;
  padding: 28px;
}

.r-card p {
  font-size: 14px;
  line-height: 1.45;
  color: #2f3850;
  min-height: 126px;
  border-bottom: 1px solid #d0d5de;
  padding-bottom: 24px;
}

.user {
  display: flex;
  align-items: center;
  gap: 16px;
}

.user img {
  width: 94px;
  height: 94px;
  border-radius: 999px;
  object-fit: cover;
}

.user strong {
  font-size: 18px;
}

.user b {
  margin-left: auto;
  background: #2281f6;
  color: #fff;
  border-radius: 8px;
  padding: 12px 18px;
  font-size: 18px;
}

/* Section 02 exact styling */
.reviews-area {
  margin-top: 48px;
  padding-bottom: 12px;
}

.reviews-area .title-row.two-col {
  grid-template-columns: 56px 1fr 520px;
  align-items: start;
  gap: 28px;
  margin-bottom: 26px;
}

.reviews-area .title-row h2 {
  font-size: 50px;
  line-height: 1.18;
  max-width: 980px;
}

.reviews-area .title-row p {
  font-size: 18px;
  line-height: 1.45;
  color: #3f5f86;
  max-width: 520px;
  margin-top: 8px;
}

.reviews-area .review-grid {
  gap: 22px;
}

.reviews-area .r-card {
  background: #ececec;
  border: 1px solid #e1e2e6;
  border-radius: 14px;
  padding: 24px;
}

.reviews-area .r-card .stars {
  font-size: 18px;
  letter-spacing: 2px;
  margin-bottom: 18px;
}

.reviews-area .r-card p {
  font-size: 16px;
  line-height: 1.47;
  color: #3f5b80;
  min-height: 150px;
  border-bottom: 1px solid #d4d8df;
  margin: 0;
  padding-bottom: 18px;
}

.reviews-area .user {
  margin-top: 14px;
  display: grid;
  grid-template-columns: 86px 1fr;
  grid-template-rows: auto auto;
  column-gap: 16px;
  align-items: center;
}

.reviews-area .user img {
  grid-row: 1 / span 2;
  width: 86px;
  height: 86px;
}

.reviews-area .user strong {
  font-size: 19px;
  line-height: 1.2;
}

.reviews-area .user b {
  margin-left: 0;
  justify-self: start;
  margin-top: 6px;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: 16px;
  line-height: 1;
}

.dark-feature,
.dark-reviews,
footer {
  margin-top: 18px;
  background: #202532;
  color: #fff;
}

.dark-feature .container {
  padding: 18px 24px 16px;
}

.title-row.inverse span,
.title-row.inverse p {
  color: #9faac0;
}

.title-row.inverse h2 {
  color: #fff;
}

.feature-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, 1fr);
}

.feature-grid article {
  padding: 14px;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.03);
}

.feature-grid h4 {
  margin: 0 0 5px;
  font-size: 14px;
}

.feature-grid p {
  margin: 0;
  color: #d1dbeb;
  font-size: 12px;
  line-height: 1.42;
}

/* Section 03 screenshot alignment */
.dark-feature {
  margin-top: 22px;
  background:
    linear-gradient(180deg, rgba(28, 36, 55, 0.92), rgba(25, 32, 49, 0.9)),
    url("https://images.unsplash.com/photo-1518770660439-4636190af475?auto=format&fit=crop&w=2000&h=620&q=80") center/cover;
}

.dark-feature .container {
  padding: 26px 24px 30px;
}

.dark-feature .title-row.inverse.two-col {
  grid-template-columns: 40px 1fr 420px;
  gap: 20px;
  align-items: center;
  margin-bottom: 26px;
}

.dark-feature .title-row.inverse h2 {
  font-size: 48px;
  line-height: 1.18;
  color: #fff;
  max-width: 980px;
}

.dark-feature .title-row.inverse p {
  font-size: 16px;
  line-height: 1.4;
  color: #6f8db7;
}

.dark-feature .feature-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.14);
}

.dark-feature .feature-item {
  background: transparent;
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.14);
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 0;
  padding: 26px 34px 30px;
}

.dark-feature .feature-item h4 {
  margin: 0 0 28px;
  font-size: 18px;
  color: #fff;
}

.dark-feature .feature-row {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 22px;
  align-items: start;
}

.dark-feature .feature-icon {
  width: 100px;
  height: 100px;
  border-radius: 14px;
  background: #f5a623;
  color: #fff;
  font-weight: 800;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dark-feature .feature-item p {
  margin: 0;
  color: #fff;
  font-size: 16px;
  line-height: 1.45;
}

.bar,
.register-bar {
  background: var(--blue);
  color: #fff;
  font-weight: 700;
  text-align: center;
}

.bar {
  padding: 18px 12px;
  font-size: 30px;
  font-weight: 800;
}

.bar span {
  color: #7cff38;
}

.exchange {
  margin-top: 36px;
  display: grid;
  grid-template-columns: minmax(380px, 520px) minmax(420px, 1fr);
  gap: 34px;
  align-items: start;
  position: relative;
  padding-bottom: 18px;
}

.exchange-media {
  width: 100%;
}

.exchange-media img {
  width: 100%;
  height: 638px;
  object-fit: cover;
  border-radius: 18px;
}

.exchange-content {
  padding-top: 2px;
}

.exchange .count {
  color: #4f5b71;
  font-size: 15px;
  font-weight: 700;
}

.exchange h2 {
  margin: 8px 0 22px;
  max-width: 1000px;
  font-size: 48px;
  line-height: 1.16;
  letter-spacing: 0;
}

.exchange p {
  margin: 0;
  color: #3f5f86;
  font-size: 17px;
  line-height: 1.45;
  max-width: 980px;
}

.exchange-overlay {
  position: absolute;
  left: 195px;
  top: 362px;
  right: 38px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 30px;
}

.overlay-icons {
  background: rgba(240, 241, 243, 0.93);
  border-radius: 18px;
  height: 86px;
  padding: 0 24px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.overlay-icons .coin {
  width: 58px;
  height: 58px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 30px;
  font-weight: 800;
}

.overlay-icons .c1 { background: #1b58d6; }
.overlay-icons .c2 { background: #5346d8; text-transform: lowercase; font-size: 30px; }
.overlay-icons .c3 { background: #edb42b; font-size: 26px; }
.overlay-icons .c4 { background: #188d95; font-size: 28px; }
.overlay-icons .c5 { background: #226fdf; font-size: 24px; }

.overlay-icons em {
  margin-left: 12px;
  color: #4d6688;
  font-size: 46px;
  font-style: normal;
  font-weight: 300;
}

.exchange-overlay button {
  width: 290px;
  height: 58px;
  border-radius: 10px;
  background: #f5a11f;
  font-size: 16px;
  font-weight: 700;
}

.dark-reviews {
  margin-top: 10px;
  background: #242837;
  padding: 52px 0 34px;
}

.dark-reviews .review-grid {
  gap: 34px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dark-reviews .r-card {
  background: #f1f1f3;
  border-radius: 12px;
  border: 1px solid #dfe3eb;
  padding: 28px;
}

.dark-reviews .r-card .stars {
  font-size: 18px;
  letter-spacing: 2px;
}

.dark-reviews .r-card p {
  margin: 14px 0 0;
  min-height: 112px;
  font-size: 16px;
  color: #3f5f86;
  line-height: 1.45;
  border-bottom: 1px solid #d5d8df;
  padding-bottom: 18px;
}

.dark-reviews .user {
  margin-top: 14px;
  display: grid;
  grid-template-columns: 86px 1fr;
  grid-template-rows: auto auto;
  column-gap: 16px;
  row-gap: 6px;
  align-items: center;
}

.dark-reviews .user img {
  width: 86px;
  height: 86px;
  grid-row: 1 / span 2;
}

.dark-reviews .user strong {
  font-size: 18px;
  font-weight: 800;
  color: #091326;
}

.dark-reviews .user b {
  margin-left: 0;
  justify-self: start;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: 16px;
}

.comments-wrap {
  background: #ececec;
}

.comments {
  margin-top: 0;
  padding: 0;
}

.comments article {
  display: grid;
  grid-template-columns: 86px 280px 1fr;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid #dee1e7;
  align-items: center;
}

.comments img {
  width: 86px;
  height: 86px;
  border-radius: 999px;
  object-fit: cover;
}

.comment-author {
  display: grid;
  gap: 6px;
}

.comments h4 {
  margin: 0;
  color: #061327;
  font-size: 19px;
}

.comments .stars {
  font-size: 18px;
  letter-spacing: 2px;
}

.social-actions {
  display: flex;
  gap: 10px;
}

.social-actions button {
  border: 1px solid #8ba0bf;
  border-radius: 6px;
  height: 36px;
  color: #4a6488;
  background: #f4f5f7;
  padding: 0 12px;
  font-size: 14px;
  font-weight: 500;
}

.comments p {
  margin: 0;
  color: #3f5f86;
  font-size: 16px;
  line-height: 1.45;
}

.register-bar {
  border-radius: 12px;
  margin-top: 32px;
  margin-bottom: 34px;
  padding: 24px 20px;
  font-size: 26px;
  font-weight: 700;
}

.final-cta {
  margin-top: 0;
  margin-bottom: 0;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(360px, 610px) 1fr;
  gap: 0;
  align-items: center;
  background: #ececec;
}

.final-cta > img {
  width: 100%;
  height: 560px;
  object-fit: cover;
}

.cta-panel {
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 72px 0 58px;
}

.cta-copy {
  max-width: 960px;
}

.cta-copy h2 {
  margin: 0;
  font-size: 45px;
  line-height: 1.15;
}

.cta-copy p {
  margin: 16px 0 0;
  font-size: 50px;
  color: #3f5f86;
  line-height: 1.12;
}

footer {
  margin-top: 0;
  background: #272c3b;
  color: #fff;
  padding: 34px 0 0;
}

.foot-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 22px;
  flex-wrap: wrap;
}

.foot-brand {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.foot-brand .brand {
  margin: 0;
  font-size: 26px;
  letter-spacing: 0.2px;
  flex-shrink: 0;
}

footer .shield {
  width: 30px;
  height: 30px;
  border-radius: 6px;
}

.foot-brand > span {
  border-left: 1px solid rgba(255, 255, 255, 0.15);
  padding-left: 18px;
  font-size: 14px;
  line-height: 1.3;
  color: #fff;
}

footer nav {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

footer a {
  font-size: 14px;
  color: #fff;
  text-decoration: none;
}

.tiny {
  margin-top: 40px;
  margin-bottom: 0;
  font-size: 14px;
  line-height: 1.35;
  color: #656f80;
  overflow-wrap: anywhere;
}

.copy {
  margin: 24px 0 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  text-align: center;
  padding: 22px 12px 24px;
  font-size: 15px;
  color: #fff;
}

@media (max-width: 1280px) {
  .dark-feature .title-row.inverse.two-col {
    grid-template-columns: 32px 1fr 320px;
    gap: 16px;
  }

  .dark-feature .title-row.inverse h2 {
    font-size: 40px;
  }

  .dark-feature .feature-item {
    padding: 18px 20px 22px;
  }

  .dark-feature .feature-row {
    grid-template-columns: 78px 1fr;
    gap: 14px;
  }

  .dark-feature .feature-icon {
    width: 78px;
    height: 78px;
    font-size: 14px;
  }

  .exchange {
    grid-template-columns: minmax(320px, 450px) 1fr;
    gap: 22px;
  }

  .exchange h2 {
    font-size: 40px;
    line-height: 1.15;
  }

  .exchange-overlay {
    left: 120px;
    right: 10px;
    top: 350px;
    gap: 16px;
  }

  .overlay-icons {
    padding: 0 14px;
  }

  .overlay-icons .coin {
    width: 50px;
    height: 50px;
    font-size: 24px;
  }

  .overlay-icons em {
    font-size: 34px;
  }

  .exchange-overlay button {
    width: 240px;
  }

  .dark-reviews .review-grid {
    gap: 18px;
  }

  .comments article {
    grid-template-columns: 72px 220px 1fr;
    gap: 14px;
  }

  .comments img {
    width: 72px;
    height: 72px;
  }

  .final-cta {
    grid-template-columns: minmax(320px, 500px) 1fr;
  }

  .final-cta > img {
    height: 460px;
  }

  .cta-panel {
    padding: 0 30px;
  }

  .cta-copy h2 {
    font-size: 36px;
  }

  .cta-copy p {
    font-size: 24px;
  }
}

@media (max-width: 980px) {
  .quote-card img {
    height: 240px;
  }
  .container {
    width: calc(100% - 26px);
  }

  .hero {
    padding-top: 0;
  }

  .hero::after {
    top: 58px;
  }

  .hero-grid,
  .quote-card,
  .quote-card.reverse,
  .title-row,
  .two-col,
  .terminal,
  .review-grid,
  .feature-grid,
  .exchange,
  .final-cta {
    grid-template-columns: 1fr;
  }

  .hero-copy h1,
  .title-row h2,
  .exchange h2,
  .final-cta h2 {
    font-size: clamp(30px, 8.8vw, 42px);
  }

  .lead,
  .cta-copy p,
  .bar,
  .register-bar {
    font-size: clamp(20px, 5.2vw, 30px);
  }

  .phone-bg {
    display: none;
  }

  .hero-form-wrap {
    min-height: auto;
    justify-content: flex-start;
    padding-top: 0;
    position: static;
  }

  .hero .brand {
    font-size: 26px;
    margin-bottom: 18px;
  }

  .hero-grid {
    position: relative;
    z-index: 2;
    min-height: auto;
    padding-top: 82px;
    gap: 18px;
  }

  .hero-copy h1 {
    margin-top: 0;
    margin-bottom: 10px;
    font-size: clamp(34px, 10vw, 46px);
    line-height: 1.08;
  }

  .lead {
    font-size: clamp(22px, 6.5vw, 34px);
    line-height: 1.1;
  }

  .hero-rating {
    margin-top: 16px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .avatar-row img {
    width: 48px;
    height: 48px;
    margin-right: -10px;
  }

  .hero-rating strong {
    font-size: 18px;
    line-height: 1.25;
  }

  .hero-rating .stars {
    font-size: 16px;
    letter-spacing: 1px;
  }

  .shield {
    width: 20px;
    height: 20px;
    border-radius: 4px;
  }

  .spots-badge {
    position: absolute;
    top: 6px;
    left: 0;
    right: 0;
    width: 100%;
    border-radius: 0;
    padding: 12px 14px;
    font-size: 14px;
    text-align: center;
    z-index: 10;
  }

  .spots-badge b {
    font-size: 14px;
  }

  .register-card,
  button {
    width: 100%;
  }

  .foot-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .exchange {
    gap: 16px;
    padding-bottom: 0;
  }

  .exchange-media img {
    height: auto;
    min-height: 340px;
  }

  .exchange .count {
    font-size: 15px;
  }

  .exchange p {
    font-size: 16px;
  }

  .exchange-overlay {
    position: static;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
    margin-top: 14px;
  }

  .overlay-icons {
    height: auto;
    padding: 14px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .overlay-icons .coin {
    width: 48px;
    height: 48px;
    font-size: 22px;
  }

  .overlay-icons em {
    font-size: 34px;
    margin-left: 0;
  }

  .exchange-overlay button {
    width: 100%;
    height: 56px;
    font-size: 16px;
  }

  .dark-reviews {
    padding: 24px 0;
  }

  .dark-reviews .r-card {
    padding: 18px;
  }

  .dark-reviews .r-card p {
    margin-top: 10px;
    min-height: 0;
    font-size: 16px;
    padding-bottom: 14px;
  }

  .dark-reviews .user {
    grid-template-columns: 64px 1fr;
    column-gap: 12px;
    row-gap: 6px;
    margin-top: 14px;
  }

  .dark-reviews .user img {
    width: 64px;
    height: 64px;
  }

  .dark-reviews .user strong {
    font-size: 18px;
  }

  .dark-reviews .user b {
    font-size: 16px;
    padding: 6px 12px;
  }

  .comments article {
    grid-template-columns: 64px 1fr;
    gap: 10px;
    padding: 14px 0;
  }

  .comments img {
    width: 64px;
    height: 64px;
    grid-row: 1 / span 2;
  }

  .comment-author {
    gap: 4px;
  }

  .comments h4 {
    font-size: 18px;
  }

  .comments .stars {
    font-size: 16px;
    letter-spacing: 2px;
  }

  .social-actions button {
    height: 34px;
    padding: 0 10px;
    font-size: 14px;
  }

  .comments p {
    grid-column: 1 / -1;
    font-size: 16px;
  }

  .register-bar {
    border-radius: 10px;
    margin-top: 20px;
    margin-bottom: 20px;
    padding: 16px 12px;
    font-size: 20px;
  }

  .final-cta {
    grid-template-columns: 1fr;
  }

  .final-cta > img {
    height: 280px;
  }

  .cta-panel {
    padding: 0 12px;
  }

  .cta-copy {
    padding: 18px 0 24px;
  }

  .cta-copy h2 {
    font-size: 40px;
  }

  .cta-copy p {
    margin-top: 8px;
    font-size: 22px;
  }

  .foot-brand {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .foot-brand .brand {
    font-size: 24px;
  }

  footer .shield {
    width: 20px;
    height: 20px;
    border-radius: 4px;
  }

  .foot-brand > span {
    border-left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.16);
    padding: 8px 0 0;
    font-size: 14px;
  }

  footer nav {
    flex-wrap: wrap;
    gap: 14px;
  }

  footer a {
    font-size: 14px;
  }

  .tiny {
    margin-top: 16px;
    font-size: 12px;
  }

  .copy {
    font-size: 16px;
    padding: 14px 12px 16px;
  }

  .reviews-area .title-row.two-col {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .reviews-area .title-row h2 {
    font-size: clamp(30px, 8.8vw, 42px);
  }

  .reviews-area .title-row p {
    max-width: none;
    margin-top: 0;
  }

  .dark-feature .title-row.inverse.two-col {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .dark-feature .title-row.inverse h2 {
    font-size: 32px;
  }

  .dark-feature .title-row.inverse p {
    font-size: 14px;
  }

  .dark-feature .feature-item {
    padding: 18px 14px;
  }

  .dark-feature .feature-row {
    grid-template-columns: 64px 1fr;
    gap: 12px;
  }

  .dark-feature .feature-icon {
    width: 64px;
    height: 64px;
    border-radius: 10px;
    font-size: 12px;
  }

  .dark-feature .feature-item p {
    font-size: 14px;
  }
}

@media (max-width: 768px) {
  .dark-feature .container {
    padding: 18px 0 20px;
  }

  .dark-feature .title-row.inverse h2 {
    font-size: 28px;
    line-height: 1.2;
  }

  .dark-feature .title-row.inverse p {
    font-size: 13px;
  }

  .dark-feature .feature-grid {
    grid-template-columns: 1fr;
    border-left: 0;
  }

  .dark-feature .feature-item {
    border-right: 0;
    padding: 14px 0 16px;
  }

  .dark-feature .feature-row {
    grid-template-columns: 56px 1fr;
    gap: 12px;
  }

  .dark-feature .feature-icon {
    width: 56px;
    height: 56px;
    border-radius: 10px;
    font-size: 11px;
  }

  .bar {
    font-size: 22px;
    padding: 14px 10px;
  }

  .exchange {
    margin-top: 22px;
    gap: 12px;
  }

  .exchange-media img {
    min-height: 260px;
    border-radius: 12px;
  }

  .exchange h2 {
    font-size: 34px;
    line-height: 1.16;
  }

  .exchange p {
    font-size: 15px;
  }

  .exchange-overlay {
    margin-top: 10px;
    gap: 10px;
  }

  .overlay-icons {
    border-radius: 12px;
    padding: 10px;
    gap: 8px;
  }

  .overlay-icons .coin {
    width: 42px;
    height: 42px;
    font-size: 20px;
  }

  .overlay-icons em {
    font-size: 28px;
  }

  .dark-reviews {
    padding: 18px 0;
  }

  .dark-reviews .review-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .dark-reviews .r-card {
    padding: 14px;
  }

  .dark-reviews .r-card .stars {
    font-size: 16px;
  }

  .comments article {
    grid-template-columns: 56px 1fr;
    gap: 8px;
    padding: 12px 0;
  }

  .comments img {
    width: 56px;
    height: 56px;
  }

  .social-actions {
    flex-wrap: wrap;
  }

  .social-actions button {
    height: 32px;
    font-size: 13px;
  }

  .register-bar {
    margin-top: 16px;
    margin-bottom: 16px;
    padding: 14px 10px;
    font-size: 18px;
  }

  .final-cta > img {
    height: 220px;
  }

  .cta-copy {
    padding: 14px 0 18px;
  }

  .cta-copy h2 {
    font-size: 32px;
  }

  .cta-copy p {
    font-size: 18px;
  }

  footer {
    padding-top: 22px;
  }

  .foot-brand .brand {
    font-size: 20px;
  }

  footer nav {
    gap: 10px;
  }

  .tiny {
    font-size: 11px;
  }

  .copy {
    font-size: 12px;
    padding: 12px 10px 14px;
  }
}

@media (max-width: 560px) {
  .container {
    width: calc(100% - 18px);
  }

  .dark-feature .title-row.inverse h2 {
    font-size: 24px;
  }

  .dark-feature .feature-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .dark-feature .feature-icon {
    width: 52px;
    height: 52px;
  }

  .exchange h2 {
    font-size: 30px;
  }

  .exchange .count {
    font-size: 14px;
  }

  .hero-rating strong {
    font-size: 16px;
    line-height: 1.22;
  }

  .avatar-row img {
    width: 42px;
    height: 42px;
    margin-right: -8px;
  }

  .overlay-icons {
    justify-content: flex-start;
  }

  .overlay-icons em {
    display: none;
  }

  .comments p {
    font-size: 15px;
  }

  .register-bar {
    font-size: 16px;
  }

  .cta-copy h2 {
    font-size: 28px;
  }

  .cta-copy p {
    font-size: 16px;
  }

  .foot-brand > span {
    font-size: 12px;
  }

  footer a {
    font-size: 13px;
  }

  .tiny {
    font-size: 10px;
  }
}

.legal-main {
  padding: 42px 0 56px;
}

.legal-card {
  background: #ffffff;
  border: 1px solid #d7dbe4;
  border-radius: 14px;
  padding: 36px 34px;
}

.legal-kicker {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: #4f5b71;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

.legal-card h1 {
  margin: 10px 0 14px;
  font-size: 44px;
  line-height: 1.12;
  font-weight: 800;
  color: #101725;
}

.legal-intro {
  margin: 0 0 26px;
  font-size: 17px;
  line-height: 1.5;
  color: #33435e;
}

.legal-section + .legal-section {
  margin-top: 24px;
}

.legal-section h2 {
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 800;
  color: #101725;
}

.legal-section p {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: #3f5f86;
}

.legal-section ul {
  margin: 12px 0 0;
  padding-left: 22px;
  color: #2f4363;
}

.legal-section li {
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.5;
}

.legal-contact {
  margin-top: 6px;
  padding: 14px 16px;
  border-left: 4px solid #2580f7;
  background: #f3f7ff;
  border-radius: 8px;
}

@media (max-width: 980px) {
  .quote-card img {
    height: 240px;
  }
  .legal-main {
    padding: 26px 0 34px;
  }

  .legal-card {
    padding: 22px 16px;
  }

  .legal-card h1 {
    font-size: clamp(30px, 8.4vw, 40px);
  }

  .legal-section h2 {
    font-size: clamp(24px, 6.2vw, 30px);
  }

  .legal-intro,
  .legal-section p,
  .legal-section li {
    font-size: 16px;
  }
}

.legal-meta {
  margin: 0 0 14px;
  color: #4f5b71;
  font-size: 14px;
  font-weight: 600;
}

.legal-meta span {
  color: #1f3559;
  font-weight: 700;
}

/* Keep the two quote portraits stable across screen sizes */
.quotes .quote-card > img {
  width: 100%;
  height: 100%;
  min-height: 400px;
  object-fit: cover;
  object-position: center 14%;
}

@media (max-width: 980px) {
  .quotes .quote-card > img {
    min-height: 0;
    height: auto;
    max-height: none;
    aspect-ratio: auto;
    object-position: center top;
    padding: 0;
    background: transparent;
  }

  .quotes .quote-card,
  .quotes .quote-card.reverse {
    min-height: 0;
  }
}

@media (max-width: 560px) {
  .quotes .quote-card > img {
    height: auto;
    max-height: none;
    aspect-ratio: auto;
    object-fit: cover;
    padding: 0;
    background: transparent;
  }
}
