html, body {
  width: 100%;
  max-width: 100vw;
  overflow-x: hidden;
  font-family: 'Inter', sans-serif;
  margin: 0;
  padding: 0;
  background: linear-gradient(145deg, #0d0d0d, #1a1a1a);
  color: #fff;
}
.container {
  max-width: 1100px;
  margin: auto;
  padding: 60px 20px;
}
h1 {
  font-size: 2.8rem;
  font-weight: 700;
  text-align: center;
  background: linear-gradient(90deg, #FFD700, #ffffff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 10px;
}
p.subtitle {
  text-align: center;
  color: #bbb;
  margin-bottom: 50px;
}
.steps {
  display: flex;
  justify-content: center;
  margin-bottom: 40px;
}
.step {
  padding: 12px 24px;
  border-radius: 20px;
  border: 2px solid #FFD700;
  font-weight: 600;
  color: #FFD700;
  margin: 0 8px;
  background: rgba(255, 215, 0, 0.1);
  cursor: pointer;
  transition: all 0.3s;
}
.step.inactive {
  border-color: #444;
  color: #666;
  background: rgba(255, 255, 255, 0.05);
  cursor: pointer;
}
.step.active {
  border-color: #FFD700;
  color: #FFD700;
  background: rgba(255, 215, 0, 0.1);
  cursor: default;
}
.grid {
  display: flex;
  gap: 32px;
}
.section-billing {
  flex: 2 1 0%;
  min-width: 350px;
}
.section-summary {
  flex: 1.2 1 0%;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  background: #181818;
  border-radius: 16px;
  padding: 24px 12px;
  box-shadow: 0 2px 16px #0002;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  align-self: auto;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  overflow-x: hidden;
}
.section {
  background: #181818;
  padding: 30px;
  border-radius: 16px;
  box-shadow: 0 0 40px rgba(255, 215, 0, 0.07);
}
.section h3 {
  margin-bottom: 20px;
  font-size: 1.1rem;
  color: #FFD700;
}
.options button {
  display: inline-block;
  margin: 8px 8px 8px 0;
  padding: 12px 18px;
  border: 2px solid #555;
  border-radius: 30px;
  background: #121212;
  color: #fff;
  cursor: pointer;
  transition: all 0.3s ease;
}
.options button:hover,
.options button.selected {
  background: linear-gradient(145deg, #FFD700, #d4af37);
  color: #000;
  font-weight: 700;
  border-color: #FFD700;
}
.options .badge {
  margin-left: 8px;
  background-color: #FFD700;
  color: #000;
  border-radius: 12px;
  font-size: 0.7rem;
  padding: 2px 6px;
}
.coupon {
  margin-bottom: 20px;
}
.coupon input {
  width: 100%;
  padding: 12px;
  border: 2px solid #555;
  background: #1c1c1c;
  color: #fff;
  border-radius: 6px;
  font-size: 1rem;
}
.coupon-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
}
.coupon button {
  padding: 12px 18px;
  background: linear-gradient(90deg, #FFD700, #e6c200);
  border: none;
  color: #000;
  font-weight: 600;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.addons label {
  display: block;
  margin: 10px 0;
  cursor: pointer;
  font-size: 1rem;
  color: #ccc;
}
.addons .addon-none {
  color: #888;
  border-bottom: 1px solid #333;
  padding-bottom: 10px;
  margin-bottom: 15px;
}
.addons input[type="radio"] {
  margin-right: 10px;
}
.addons .badge {
  margin-left: 8px;
  background-color: #FFD700;
  color: #000;
  border-radius: 12px;
  font-size: 0.7rem;
  padding: 2px 6px;
}
.terms {
  margin-top: 20px;
  font-size: 0.9rem;
  color: #aaa;
}
.terms input[type="checkbox"] {
  margin-right: 10px;
}
.price-box .price {
  font-size: 2.4rem;
  font-weight: 700;
  color: #FFD700;
}
.price-box .old-price {
  text-decoration: line-through;
  color: #888;
  margin-left: 10px;
  font-weight: 400;
}
.btn-continue {
  margin-top: 30px;
  display: block;
  width: 100%;
  padding: 18px;
  background: linear-gradient(90deg, #FFD700, #e6c200);
  color: #000;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s ease;
}
.btn-continue:hover {
  background: linear-gradient(90deg, #e6c200, #FFD700);
}
.payment-section {
  display: none;
  margin-top: 50px;
}
.payment-section.visible {
  display: block;
}
.payment-section .grid {
  margin-top: 30px;
  align-items: flex-start;
}
.payment-methods button {
  margin: 10px 10px 0 0;
  padding: 12px 20px;
  border-radius: 10px;
  border: 2px solid #555;
  background: #121212;
  color: #fff;
  cursor: pointer;
  transition: all 0.3s ease;
}
.payment-methods button:hover {
  border-color: #FFD700;
  background: linear-gradient(145deg, #FFD700, #d4af37);
  color: #000;
}
.initial-selection {
  transition: opacity 0.3s ease;
}
.initial-selection.hidden {
  display: none;
}
.form-group {
  margin-bottom: 26px;
  width: 100%;
  box-sizing: border-box;
}
.form-group label {
  font-size: 0.98rem;
  color: #bbb;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  margin-bottom: 4px;
  transition: color 0.2s;
}
.form-group input,
.form-group select {
  width: 100%;
  padding: 16px 14px;
  border: 2px solid #333;
  background: #232323;
  color: #fff;
  border-radius: 10px;
  font-size: 1.08rem;
  box-sizing: border-box;
  margin-top: 4px;
  transition: border 0.2s, box-shadow 0.2s;
}
.form-group input:focus,
.form-group select:focus {
  border-color: #FFD700;
  box-shadow: 0 0 0 2px #FFD70033;
  outline: none;
}
.form-group input:focus + label,
.form-group select:focus + label {
  color: #FFD700;
}
.summary-item {
  display: flex;
  justify-content: space-between;
  margin-bottom: 15px;
  color: #ccc;
}
.summary-item.total {
  color: #FFD700;
  font-size: 1.2rem;
  font-weight: 600;
  border-top: 1px solid #333;
  padding-top: 15px;
  margin-top: 15px;
}
html, body, .container, .section {
  box-sizing: border-box;
}
@media (max-width: 900px) {
  .container {
    max-width: 500px;
    margin: 0 auto;
    padding: 30px 10px;
  }
  .grid { flex-direction: column; }
  .section-billing, .section-summary { min-width: 0; }
  .section {
    padding: 18px;
  }
  h1 {
    font-size: 2rem;
  }
}
@media (max-width: 600px) {
  body {
    background: #23252b;
  }
  .container {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0 0;
    box-sizing: border-box;
  }
  .section {
    margin-bottom: 18px;
    margin-left: 10px;
    margin-right: 10px;
    box-shadow: none;
    border-radius: 10px;
    padding: 16px 10px;
    background: #181818;
    box-sizing: border-box;
  }
  .steps {
    margin-bottom: 20px;
  }
  .options {
    flex-wrap: wrap;
    gap: 8px;
  }
  .options button {
    min-width: 60px;
    min-height: 36px;
    font-size: 0.95rem;
    margin: 6px 3px 6px 0;
    padding: 8px 10px;
    width: auto;
  }
  .btn-continue, .coupon-row button {
    width: 100%;
    font-size: 1rem;
    padding: 12px 0;
    margin-top: 12px;
  }
  .coupon-row input {
    font-size: 0.95rem;
    padding: 10px 6px;
  }
  .price-box .price {
    font-size: 1.3rem;
    text-align: left;
  }
  h3 {
    font-size: 1rem;
    margin-top: 12px;
  }
  h1 {
    font-size: 1.1rem;
  }
  .section-summary {
    padding: 12px 2vw;
    min-width: 0;
    max-width: 100vw;
    width: 100vw;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }
  #card-sdk-container {
    padding: 16px 0;
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }
}
/* === AEON FOOTER === */
.aeon-footer {
  position: relative;
  background: linear-gradient(145deg, #0d0d0d, #1a1a1a);
  color: #fff;
  font-family: 'Inter', sans-serif;
  margin-top: 80px;
  padding-top: 0;
  padding-bottom: 56px;
  overflow: hidden;
}
.aeon-footer__shadow {
  display: none;
}
.aeon-footer__container {
  position: relative;
  z-index: 20;
  max-width: 1200px;
  margin: 0 auto;
  padding: 60px 20px 30px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: transparent;
}
.aeon-footer__logo-nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 24px;
}
.aeon-footer__logo {
  height: 48px;
  margin-bottom: 18px;
}
.aeon-footer__nav {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  justify-content: center;
}
.aeon-footer__nav a {
  color: #fff;
  text-decoration: none;
  font-size: 1.08rem;
  font-weight: 500;
  transition: color 0.2s;
}
.aeon-footer__nav a:hover {
  color: #FFD700;
}
.aeon-footer__social {
  display: flex;
  gap: 24px;
  margin: 28px 0 18px 0;
}
.aeon-footer__social-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255, 215, 0, 0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #FFD700;
  font-size: 1.5rem;
  border: 2px solid #FFD700;
  transition: background 0.2s, color 0.2s;
}
.aeon-footer__social-btn:hover {
  background: #FFD700;
  color: #000;
}
/* Social icons (SVG inline for best compatibility) */
.icon-instagram::before {
  content: '';
  display: inline-block;
  width: 22px; height: 22px;
  background: url('data:image/svg+xml;utf8,<svg fill="%23FFD700" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M12 2.2c3.2 0 3.584.012 4.85.07 1.17.056 1.97.24 2.43.41.59.22 1.01.48 1.45.92.44.44.7.86.92 1.45.17.46.354 1.26.41 2.43.058 1.266.07 1.65.07 4.85s-.012 3.584-.07 4.85c-.056 1.17-.24 1.97-.41 2.43-.22.59-.48 1.01-.92 1.45-.44.44-.86.7-1.45.92-.46.17-1.26.354-2.43.41-1.266.058-1.65.07-4.85.07s-3.584-.012-4.85-.07c-1.17-.056-1.97-.24-2.43-.41-.59-.22-1.01-.48-1.45-.92-.44-.44-.7-.86-.92-1.45-.17-.46-.354-1.26-.41-2.43C2.212 15.784 2.2 15.4 2.2 12s.012-3.584.07-4.85c.056-1.17.24-1.97.41-2.43.22-.59.48-1.01.92-1.45.44-.44.86-.7 1.45-.92.46-.17 1.26-.354 2.43-.41C8.416 2.212 8.8 2.2 12 2.2zm0-2.2C8.736 0 8.332.013 7.052.072 5.77.13 4.73.31 3.89.6c-.84.29-1.54.68-2.23 1.37C.68 2.66.29 3.36 0 4.2c-.29.84-.47 1.88-.53 3.16C-.013 8.332 0 8.736 0 12c0 3.264.013 3.668.072 4.948.058 1.282.24 2.322.53 3.162.29.84.68 1.54 1.37 2.23.69.69 1.39 1.08 2.23 1.37.84.29 1.88.47 3.16.53C8.332 23.987 8.736 24 12 24s3.668-.013 4.948-.072c1.282-.058 2.322-.24 3.162-.53.84-.29 1.54-.68 2.23-1.37.69-.69 1.08-1.39 1.37-2.23.29-.84.47-1.88.53-3.16.059-1.28.072-1.684.072-4.948 0-3.264-.013-3.668-.072-4.948-.058-1.282-.24-2.322-.53-3.162-.29-.84-.68-1.54-1.37-2.23-.69-.69-1.39-1.08-2.23-1.37-.84-.29-1.88-.47-3.16-.53C15.668.013 15.264 0 12 0z"/><circle cx="12" cy="12" r="3.6"/><circle cx="18.406" cy="5.594" r="1.44"/></svg>') center/contain no-repeat;
}
.icon-facebook::before {
  content: '';
  display: inline-block;
  width: 22px; height: 22px;
  background: url('data:image/svg+xml;utf8,<svg fill="%23FFD700" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M22.675 0h-21.35C.595 0 0 .592 0 1.326v21.348C0 23.408.595 24 1.325 24h11.495v-9.294H9.692v-3.622h3.128V8.413c0-3.1 1.893-4.788 4.659-4.788 1.325 0 2.463.099 2.797.143v3.24l-1.918.001c-1.504 0-1.797.715-1.797 1.763v2.313h3.587l-.467 3.622h-3.12V24h6.116C23.406 24 24 23.408 24 22.674V1.326C24 .592 23.406 0 22.675 0"/></svg>') center/contain no-repeat;
}
.icon-discord::before {
  content: '';
  display: inline-block;
  width: 22px; height: 22px;
  background: url('data:image/svg+xml;utf8,<svg fill="%23FFD700" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M20.317 4.3698a19.7913 19.7913 0 00-4.8851-1.5152.0741.0741 0 00-.0785.0371c-.211.3753-.4447.8648-.6083 1.2495-1.8447-.2762-3.68-.2762-5.4868 0-.1636-.3933-.4058-.8742-.6177-1.2495a.077.077 0 00-.0785-.037 19.7363 19.7363 0 00-4.8852 1.515.0699.0699 0 00-.0321.0277C.5334 9.0458-.319 13.5799.0992 18.0578a.0824.0824 0 00.0312.0561c2.0528 1.5076 4.0413 2.4228 5.9929 3.0294a.0777.0777 0 00.0842-.0276c.4616-.6304.8731-1.2952 1.226-1.9942a.076.076 0 00-.0416-.1057c-.6528-.2476-1.2743-.5495-1.8722-.8923a.077.077 0 01-.0076-.1277c.1258-.0943.2517-.1923.3718-.2914a.0743.0743 0 01.0776-.0105c3.9278 1.7933 8.18 1.7933 12.0614 0a.0739.0739 0 01.0785.0095c.1202.099.246.1981.3728.2924a.077.077 0 01-.0066.1276c-.598.3428-1.2205.6447-1.8733.8923a.0766.0766 0 00-.0407.1067c.3604.698.7719 1.3628 1.225 1.9932a.076.076 0 00.0842.0286c1.961-.6067 3.9495-1.5218 6.0023-3.0294a.077.077 0 00.0313-.0552c.5004-5.177-.8382-9.6739-3.5485-13.6604a.061.061 0 00-.0312-.0286zM8.02 15.3312c-1.1835 0-2.1569-1.0857-2.1569-2.419 0-1.3332.9555-2.4189 2.157-2.4189 1.2108 0 2.1757 1.0952 2.1568 2.419 0 1.3332-.9555 2.4189-2.1569 2.4189zm7.9748 0c-1.1835 0-2.1569-1.0857-2.1569-2.419 0-1.3332.9554-2.4189 2.1569-2.4189 1.2108 0 2.1757 1.0952 2.1568 2.419 0 1.3332-.946 2.4189-2.1568 2.4189Z"/></svg>') center/contain no-repeat;
}
.icon-x::before {
  content: '';
  display: inline-block;
  width: 22px; height: 22px;
  background: url('data:image/svg+xml;utf8,<svg fill="%23FFD700" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><path d="M17.53 2.47a.75.75 0 0 1 1.06 1.06L13.06 9l5.53 5.47a.75.75 0 1 1-1.06 1.06L12 10.06l-5.47 5.47a.75.75 0 1 1-1.06-1.06L10.94 9 5.41 3.53A.75.75 0 1 1 6.47 2.47L12 7.94l5.53-5.47z"/></svg>') center/contain no-repeat;
}
.aeon-footer__links {
  display: flex;
  gap: 32px;
  margin: 18px 0 0 0;
  flex-wrap: wrap;
  justify-content: center;
}
.aeon-footer__links a {
  color: #fff;
  text-decoration: none;
  font-size: 1rem;
  transition: color 0.2s;
}
.aeon-footer__links a:hover {
  color: #FFD700;
}
.aeon-footer__copyright {
  margin: 18px 0 0 0;
  font-size: 1rem;
  color: #ccc;
  text-align: center;
}
.aeon-footer__disclaimer {
  margin: 22px 0 0 0;
  font-size: 1.01rem;
  color: #bbb;
  text-align: center;
  max-width: 900px;
}
.aeon-footer__powered {
  margin: 28px 0 0 0;
  font-size: 1rem;
  color: #fff;
  text-align: right;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}
@media (max-width: 900px) {
  .aeon-footer__container {
    padding: 40px 10px 20px 10px;
  }
  .aeon-footer__logo {
    height: 38px;
  }
  .aeon-footer__nav {
    gap: 16px;
  }
  .aeon-footer__social {
    gap: 16px;
  }
  .aeon-footer__links {
    gap: 18px;
  }
  .aeon-footer__disclaimer {
    font-size: 0.95rem;
    max-width: 98vw;
  }
}
@media (max-width: 600px) {
  .aeon-footer__container {
    padding: 24px 2vw 10px 2vw;
  }
  .aeon-footer__logo {
    height: 28px;
  }
  .aeon-footer__nav {
    gap: 8px;
    font-size: 0.95rem;
  }
  .aeon-footer__social {
    gap: 10px;
  }
  .aeon-footer__links {
    gap: 8px;
    font-size: 0.95rem;
  }
  .aeon-footer__disclaimer {
    font-size: 0.85rem;
    margin-top: 14px;
  }
  .aeon-footer__powered {
    font-size: 0.9rem;
    margin-top: 16px;
  }
}
/* === AEON HEADER === */
.aeon-header {
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 20px 18px 20px;
  background: transparent;
  box-sizing: border-box;
}
.aeon-header__logo img {
  height: 38px;
  display: block;
}
.aeon-header__btn {
  display: inline-block;
  padding: 8px 28px;
  border: 2px solid #1a73e8;
  color: #1a73e8;
  background: transparent;
  border-radius: 24px;
  font-size: 1.1rem;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.aeon-header__btn:hover {
  background: #1a73e8;
  color: #fff;
}
@media (max-width: 700px) {
  .aeon-header {
    padding: 16px 10px 10px 10px;
    max-width: 100vw;
  }
  .aeon-header__logo img {
    height: 28px;
  }
  .aeon-header__btn {
    padding: 7px 16px;
    font-size: 1rem;
  }
}
.order-recap-card {
  background: #181818;
  border-radius: 12px;
  padding: 24px 20px;
  margin-bottom: 32px;
  box-shadow: 0 2px 16px rgba(0,0,0,0.12);
}
.order-recap-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: #FFD700;
  margin-bottom: 18px;
}
.order-recap-row {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
  font-size: 1rem;
  color: #fff;
}
.order-recap-total {
  display: flex;
  justify-content: space-between;
  font-size: 1.2rem;
  font-weight: 700;
  color: #FFD700;
  border-top: 1px solid #333;
  padding-top: 12px;
  margin-top: 18px;
}
.section form {
  width: 100%;
}
#confirmOrderBtn {
  width: 100%;
  margin-top: 32px;
  padding: 18px;
  background: linear-gradient(90deg, #FFD700, #e6c200);
  color: #000;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s ease;
  display: block;
}
#confirmOrderBtn:hover {
  background: linear-gradient(90deg, #e6c200, #FFD700);
}
.payment-section .section {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
#card-sdk-container {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 24px;
  background: #181818;
  border-radius: 12px;
  padding: 24px 0;
  box-shadow: 0 2px 16px rgba(0,0,0,0.12);
  margin-left: 0;
  margin-right: 0;
  display: block;
  overflow-x: hidden;
}
#card-sdk-id {
  margin-bottom: 18px;
}
#tapCardSubmitBtn {
  width: 100%;
  margin-top: 18px;
  padding: 18px;
  background: linear-gradient(90deg, #FFD700, #e6c200);
  color: #000;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  text-align: center;
  transition: all 0.3s ease;
  display: block;
}
#tapCardSubmitBtn:hover {
  background: linear-gradient(90deg, #e6c200, #FFD700);
}
::placeholder {
  color: #aaa;
  opacity: 1;
} 