body {
  background-color: var(--body);
  font-family: Arial, sans-serif;
  margin: 0;
  padding: 0;
  transition: background-color 0.3s ease;
  will-change: background-color;
}

html {
  transition: background-color 0.3s ease;
}

.scroll-locked {
  overflow: hidden !important;
}

[x-cloak] {
  display: none !important;
}

.special-elite-regular {
  font-family: "Special Elite", system-ui;
  font-weight: 400;
  font-style: normal;
}

/* Default to dark theme */
:root {
  --dark-gray: #e0e0e0;
  --shield: #101115;
  --in-between: #a5a5a580;
  --contrast: #2f2f2f;
  --opacity-40: 0.4;
  --opacity-60: 0.6;
  /* --backgroundImage: url('img/bgImageDark.png'); */
  --body: #101115;
  --body-op: #10111595;
  --body-contrast: #efeeea;
  --bg-image: url("img/Hero.png");
  --md-image: url("img/mediumDarkHero.png");
  --sm-image: url("img/smallHeroDark.png");
  --hero-accent: #ffd21d;
  --payment-link-bg: #2f2f2f;
  --faded-hero-accent: #b3833180;
  --nav-bg: #10111580;
  --banner-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

.pink {
  color: #ff00ff;
}

/* Override for light theme */
.light {
  --banner-shadow: 0 4px 8px rgba(255, 255, 255, 0.3);
  --nav-bg: #efeeea80;
  --dark-gray: #2f2f2f;
  --in-between: #2f2f2f90;
  --shield: #e0e0e0;
  --contrast: #e0e0e0;
  --opacity-40: 0.4;
  --opacity-60: 0.6;
  /* --backgroundImage: url('img/test.png'); */
  --body: #efeeea;
  --body-op: #efeeea95;
  --body-contrast: #101115;
  --bg-image: url("img/invertHero.png");
  --md-image: url("img/mediumHero.png");
  --sm-image: url("img/smallHeroLight.png");
  --hero-accent: #00146e;
  --faded-hero-accent: #10692e80;
  --payment-link-bg: #ffffff;
}

.blog {
  color: var(--dark-gray);
  border: 2px solid var(--dark-gray);
  border-radius: 50%;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--shield);
}

.blog-blur {
  color: var(--dark-gray);
  border: 2px solid var(--hero-accent);
  border-radius: 50%;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--shield);
}

.cta-index {
  color: var(--dark-gray);
  border-radius: 50%;
  padding: 10px;
  display: inline-flex;
  align-items: center;
  align-items: center;
}

.special-elite-regular {
  font-family: "Special Elite", system-ui;
  font-weight: 400;
  font-style: normal;
}

@media (min-width: 788px) {
  .circle-float {
    float: left; /* comment: we float the image so text flows around it */
    shape-outside: circle(50%); /* comment: makes text wrap a circle shape */
    clip-path: circle(50%); /* comment: clips the actual image to a circle */
    width: 500px; /* comment: fixed width is required for shape-outside */
    height: 500px; /* comment: fixed height is required for shape-outside */
    margin: 0 1rem 1rem 0; /* comment: adds spacing around the image */
    object-fit: cover;
  }
}

@media (max-width: 787px) {
  .circle-float {
    float: left; /* comment: we float the image so text flows around it */
    shape-outside: circle(50%); /* comment: makes text wrap a circle shape */
    clip-path: circle(50%); /* comment: clips the actual image to a circle */
    width: 350px; /* comment: fixed width is required for shape-outside */
    height: 350px; /* comment: fixed height is required for shape-outside */
    margin: 0 1rem 1rem 0; /* comment: adds spacing around the image */
    object-fit: cover;
  }
}

@media (max-width: 546px) {
  .circle-float {
    float: none;
    margin: auto;
    margin-bottom: 10px;
    width: 100%; /* comment: fixed width is required for shape-outside */
    height: 100%;
  }
}

.h-34 {
  height: 34px;
}

@media (min-width: 1024px) {
  .banner-margin {
    margin-top: 250px;
  }
}

@media (min-width: 641px) and (max-width: 1023px) {
  .banner-margin {
    margin-top: 150px;
  }
}

@media (max-width: 640px) {
  .banner-margin {
    margin-top: 90%;
  }
}

.height-319 {
  height: 319px;
}

@media (max-width: 550px) {
  .banner-margin {
    margin-top: 100%;
  }
}

@media (min-width: 1024px) {
  .mt-208 {
    margin-top: 210px;
  }
}

@media (max-width: 1023px) {
  .mt-208 {
    margin-top: 12rem;
  }
}

@media (max-width: 639px) {
  .mt-208 {
    margin-top: 470px;
  }
}

@media (max-width: 570px) {
  .mt-208 {
    margin-top: 420px;
  }
}

@media (max-width: 520px) {
  .mt-208 {
    margin-top: 390px;
  }
}

@media (max-width: 454px) {
  .mt-208 {
    margin-top: 340px;
  }
}

@media (max-width: 916px) {
  .blog-row {
    flex-direction: column;
    align-items: center;
    gap: 5px !important;
  }
  .blog-row-links a {
    padding: 10px !important;
  }
}

@media (max-width: 640px) and (min-width: 530px) {
  .controled-mt {
    margin-top: 440px;
  }
}

@media (max-width: 529px) and (min-width: 400px) {
  .controled-mt {
    margin-top: 340px;
  }
}

@media (max-width: 399px) and (min-width: 300px) {
  .controled-mt {
    margin-top: 270px;
  }
}

.q {
  height: 350px;
}

.q2 {
  height: 150px;
}

.w-150 {
  width: 150px;
}

.pay-here {
  background-image: url("img/pay-here.png");

  width: 200px;
  height: 200px;
}

.payment-link-width {
  width: calc(33% - 10px);
}

.display-contents {
  display: contents;
}

.accent-dot {
  width: 50px;
  background-color: var(--hero-accent);
  border-radius: 50%;
  margin: auto;
}

.mt-130 {
  margin-top: 130px;
}

.min-width-168 {
  min-width: 200px;
}

.mobile-background {
  background-color: var(--shield);
  opacity: 60%;
}

.margin-5 {
  margin-right: 5px;
}

.payment-icons {
  height: 50px;
}

#exaplain {
  scroll-margin-top: 70px;
}

.payment-link-bg {
  background-color: var(--payment-link-bg);
}

.text-accent {
  color: var(--hero-accent);
}

.background-accent {
  background-color: var(--hero-accent);
}

.background-gradient {
  background-color: var(--body);
  background-repeat: no-repeat;
  /* height: 100%; */
  background-size: cover;
  background-position: top;
}

@media all and (max-width: 1000px) {
  .background-gradient {
    background-color: var(--body);
    background-repeat: no-repeat;
    height: 100%;
    background-position: bottom;
  }
}

@media all and (max-width: 600px) {
  .background-gradient {
    background-color: var(--body);
    background-repeat: no-repeat;
    height: 100%;
    background-position: top;
  }
}

.wt-line-left {
  width: 100%;
  height: 5px;
  border-radius: 50% 0% 0% 50%;
  background-color: #e0e0e0;
}

.wt-line-right {
  width: 100%;
  height: 5px;
  border-radius: 0% 50% 50% 0%;
  background-color: #e0e0e0;
}

/* .image-mask {
  background-image: url('img/goldwall.png'); 
  -webkit-background-clip: text;
  background-clip: text;
  background-position: center;
  color: transparent; 
} */

.width-40 {
  width: 40%;
}

.width-20 {
  width: 20%;
}

.in-between-bc {
  border-color: var(--in-between);
}

.background-shield {
  background-color: var(--body-contrast);
}

.bg-theme-color {
  border: 2px solid var(--dark-gray);
  padding: 10px;
}

.calc {
  width: calc(30% - 1px);
}

.bar {
  width: 100%;
  height: 20px;
  background: radial-gradient(circle, var(--hero-accent) 45%, transparent 50%);
  background-color: var(--dark-gray); /* Base background color */
  background-size: 20px 20px;
  background-position: center;
  opacity: 70%;
  margin-left: 0px !important;
}

[x-cloak] {
  display: none !important;
}

.circle-bg-gradient {
  background-color: var(--contrast);
}

.body1 {
  background-color: var(--body);
}

.body {
  background-color: var(--body-op);
}

.img-bg-about {
  background-color: var(--dark-gray);
}

.logo-text a {
  color: var(--hero-accent);
  text-decoration: underline;
}

.logo-text-accent {
  color: var(--hero-accent);
  text-decoration: underline;
}

.lora-400-a {
  font-family: lora;
}

.logo-text {
  color: #e0e0e0;
}

.hsdiscuss {
  width: 100%;
}

.h-95 {
  height: 95%;
}

.h-120 {
  max-height: 120px;
}

.w-339 {
  max-width: 339px;
}

.discussion-container {
  position: relative; /* Makes the parent element the reference for absolute positioning */
}

@media all and (min-width: 750px) and (max-width: 1220px) {
  .joinhs,
  .joine {
    font-size: 2rem !important;
    padding: 1.5rem !important;
    bottom: 2% !important;
  }
}

@media all and (min-width: 550px) and (max-width: 749px) {
  .joinhs,
  .joine {
    font-size: 1.5rem !important;
    padding: 1.3rem !important;
    bottom: 3% !important;
  }
}

@media all and (min-width: 300px) and (max-width: 749px) {
  .joinhs,
  .joine {
    font-size: 1.5rem !important;
    padding: 1.2rem !important;
    bottom: -8% !important;
  }
}

.joinhs {
  position: absolute;
  bottom: 4%;
  left: 10%;
}

.joine {
  position: absolute;
  bottom: 4%;
  left: 41%;
}

.width-200 {
  width: 200px;
}

.all-dark-text {
  color: #2f2f2f;
}

.missed {
  border: 2px solid red; /* Highlight border in red */
  outline: none; /* Remove default outline for better appearance */
}

.missed:focus {
  border: 2px solid #ccc; /* Restore to default border when focused */
}

.outlined-text {
  text-shadow:
    -1px -1px 7px var(--contrast),
    1px -1px 7px var(--contrast),
    -1px 1px 7px var(--contrast),
    1px 1px 7px var(--contrast); /* Outline effect using black color */
}

.outlined-text-contrast {
  text-shadow:
    -1px -1px 7px var(--dark-gray),
    1px -1px 7px var(--dark-gray),
    -1px 1px 7px var(--dark-gray),
    1px 1px 7px var(--dark-gray); /* Outline effect using black color */
}

.contrast-outlined-text {
  text-shadow:
    -1px -1px 7px #e0e0e0,
    1px -1px 7px #e0e0e0,
    -1px 1px 7px #e0e0e0,
    1px 1px 7px #e0e0e0; /* Outline effect using black color */
}

.outlined-text-dark {
  text-shadow:
    -1px -1px 7px #2f2f2f,
    1px -1px 7px #2f2f2f,
    -1px 1px 7px #2f2f2f,
    1px 1px 7px #2f2f2f; /* Outline effect using black color */
}

/* Apply a transition to all elements or specific ones */
html,
body,
div,
span {
  /* Add other tags as necessary */
  transition:
    background-color 0.3s ease,
    color 0.3s ease; /* Smooth transition for background and text colors */
}

.static-bg-color-dark {
  background-color: #101115;
}

.contrast {
  color: #2f2f2f;
}
.contrast-variable {
  color: var(--dark-gray);
}
.toggle-padding {
  padding: 2px; /* Padding around the toggle */
  display: inline-block; /* Keeps dimensions correct for padding */
  position: relative;
  width: 42px; /* Adjust width as needed */
  height: 24px; /* Adjust height as needed */
  background-color: var(--contrast); /* Light grey background */
  border: 3px solid var(--in-between); /* In-between grey border */
  border-radius: 9999px; /* Fully rounded ends */
}
.toggle-circle {
  position: absolute;
  top: 0; /* 2px from the top of the parent container */
  left: 0; /* Starts 2px from the left, will translate to right */
  width: 18px; /* Adjust size of the circle */
  height: 18px; /* Keep width and height same for a circle */
  background-color: var(
    --dark-gray
  ); /* Dark grey color for the toggle circle */
  border-radius: 9999px; /* Makes it round */
  transition: transform 0.3s ease-in-out; /* Smooth transition for moving */
}

html {
  scroll-behavior: smooth;
}

.basic-border2 {
  border: 1px solid var(--dark-gray);
}

.img-bg {
  background-color: var(--gradient-middle);
}

.work-sans-500 {
  font-family: "Work Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

@font-face {
  font-family: "DM Serif Display";
  src: url("./fonts/DMSerifDisplay-Regular.ttf") format("truetype"); /* Regular weight */
  font-weight: 400; /* Regular weight */
  font-style: normal;
  font-display: swap; /* Optional: Ensures fallback font is used until loaded */
}

@font-face {
  font-family: "Jura";
  src: url("./fonts/Jura-VariableFont_wght.ttf") format("truetype"); /* Regular weight */
  font-weight: 400; /* Regular weight */
  font-style: normal;
  font-display: swap; /* Optional: Ensures fallback font is used until loaded */
}

@font-face {
  font-family: "Rye Regular";
  src: url("./fonts/Rye-Regular.ttf") format("truetype"); /* Regular weight */
  font-weight: 400; /* Regular weight */
  font-style: normal;
  font-display: swap; /* Optional: Ensures fallback font is used until loaded */
}

@font-face {
  font-family: Walter Turncoat;
  src: url("./fonts/WalterTurncoat-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

.walter {
  font-family:
    Walter Turncoat,
    cursive; /* cursive = graceful fallback */
}

.background-color {
  background-color: var(--body);
}

.numbered {
  background-color: var(--hero-accent);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  color: white;
  border: 1px solid var(--dark-gray);
}

@font-face {
  font-family: "Megrim";
  src: url("fonts/Megrim-Regular.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}

/* 2.  A reusable class that applies it */
.megrim {
  font-family: "Megrim", cursive; /* cursive = graceful fallback */
}

.btb {
  border: 1px solid var(--dark-gray);
}

.bbb {
  border: 1px solid var(--dark-gray);
}

.jura-400 {
  font-family: "Jura", sans-serif; /* Use the Jura font */
  font-weight: 400; /* Regular weight */
  font-style: normal; /* Regular style */
}

.dm-serif-400 {
  font-family: "DM Serif Display", serif; /* Use the DM Serif Display font */
  font-weight: 400; /* Regular weight */
  font-style: normal; /* Regular style */
}

.dm-serif-bold {
  font-family: "DM Serif Display", serif; /* Use the DM Serif Display font */
  font-weight: 700; /* Simulated bold weight */
  font-style: normal; /* Regular style */
}

.lora-400 {
  font-family: "Lora", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

.lora-700 {
  font-family: "Lora", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.playfair-display-500 {
  font-family: "Playfair Display", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}

.playfair-display-300 {
  font-family: "Playfair Display", serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
}

.blurs {
  filter: blur(5px); /* Blurs the element */
  pointer-events: none; /* Prevents interactions */
  position: relative; /* Required for the overlay positioning */
}

#unBlurBtn {
  position: fixed;
}

.break-prevent {
  break-inside: avoid; /* Prevents the div from breaking inside a column */
}

.text-dark-gray-40 {
  color: var(--contrast);
  opacity: var(--opacity-40);
}

.bg-dark-gray {
  background-color: var(--contrast);
}

.text-dark-gray-60 {
  color: var(--dark-gray);
  opacity: var(--opacity-60);
}

.font-bold-dark-gray-60 {
  font-weight: bold;
  color: var(--dark-gray);
  opacity: var(--opacity-60);
}

.drop-zone {
  width: 300px;
  height: 200px;
  border: 2px dashed #007bff;
  border-radius: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 16px;
  color: #007bff;
  cursor: pointer;
  transition: background 0.3s;
}

.max-2500 {
  max-width: 2500px;
}

.drop-zone.dragover {
  background-color: rgba(0, 123, 255, 0.2);
}

#file-input {
  display: none;
}

.file-list {
  margin-top: 15px;
  list-style: none;
  padding: 0;
}

.neg-letter {
  letter-spacing: -1px;
}
.more-neg-letter {
  letter-spacing: -4px;
}
.dark-gray {
  color: var(--dark-gray);
}

.middle-light-color {
  color: var(--gradient-middle);
}

.neg-z {
  z-index: -1;
}

.minus-150 {
  min-height: calc(100vh - 290px);
}

@media (max-width: 768px) {
  .minus-150 {
    min-height: calc(100vh - 230px);
  }
}

@media (max-width: 640px) {
  .minus-150 {
    min-height: calc(100vh - 150px);
  }
}

.z {
  z-index: 1;
}

.button-border {
  color: var(--dark-gray);
}

.logo-border {
  border: 2px solid var(--dark-gray);
  border-radius: 5px;
  background-color: var(--hero-accent);
  color: var(--contrast);
}

.mobile-menu-button-border {
  color: var(--dark-gray);
}
.light-button-border {
  border: 2px solid var(--dark-gray);
  border-radius: 50%;
}
.feature-border {
  border: 2px solid var(--dark-gray);
  padding: 25px;
}
.feature-border-mobile {
  border: 2px solid var(--dark-gray);
  padding: 7px;
  border-radius: 17px;
}
.img-border-radius {
  border-radius: 45%;
}
.lc {
  text-transform: lowercase;
}

.z-1 {
  z-index: -1;
}

.top-10 {
  top: 10%;
}

.li > div > li {
  display: flex;
  border-radius: 50%;
  font-family: Lora;
  font-weight: 700;
  padding: 10px 10px 10px 0px;
}
.explain-span-text {
  font-weight: 900;
  opacity: 100%;
}
.p-line-h > p {
  line-height: 1.625;
}
.li2 > li {
  padding: 5px;
  display: flex;
  align-items: center;
  border-radius: 50%;
}
.hover-link:hover {
  color: #0000ff;
}
.link {
  color: #0000ff;
}
.flex-col-hover:hover {
  flex-direction: column;
}
.visited-link {
  color: #800080;
}
.img-hover {
  filter: brightness(0) saturate(100%) hue-rotate(-50deg) sepia(100%)
    saturate(1500%) brightness(1.8);
}
.h-500 {
  height: 530px;
}
.h-120 {
  height: 120px;
}

.line {
  width: 100%;
  height: 2px;
  background-color: var(--dark-gray);
  margin: 20px 0;
}
.text-bg {
  background-color: var(--gradient-start);
}
.view-height-50 {
  height: 50vh;
}
.mobile-position {
  left: 12.5%;
  transition: top 0.5s;
}
.mobile-radius {
  border-radius: 0% 0% 50% 50%;
}
.gap-20 {
  gap: 20%;
}

.io-link {
  color: rgb(126, 2, 126);
}

.nav-icon-1 {
  width: 30px;
  height: 30px;
  position: relative;
  transition: 0.1s;
  cursor: pointer;
  display: inline-block;
}
.nav-icon-1 span {
  width: 5px;
  height: 5px;
  background-color: var(--hero-accent);
  display: block;
  border-radius: 50%;
  position: absolute;
}

.calc-height {
  height: calc(100vh - 150px);
}

.hero-padding {
  padding: 60px;
}

.basic-border {
  border: 1px solid var(--dark-gray);
  border-radius: 10px;
  padding: 5px;
  background-color: var(--contrast);
}

.border-50 {
  border-radius: 50%;
}

.nav-icon-1 .open {
  background-color: var(--dark-gray);
}
.nav-icon-1:hover span {
  transform: scale(1.2);
  transition: 350ms cubic-bezier(0.8, 0.5, 0.2, 1.4);
}
.nav-icon-1 span:nth-child(1) {
  left: 0;
  top: 0;
}
.nav-icon-1 span:nth-child(2) {
  left: 12px;
  top: 0;
}
.nav-icon-1 span:nth-child(3) {
  right: 0;
  top: 0;
}
.nav-icon-1 span:nth-child(4) {
  left: 0;
  top: 12px;
}
.nav-icon-1 span:nth-child(5) {
  position: absolute;
  left: 12px;
  top: 12px;
}
.nav-icon-1 span:nth-child(6) {
  right: 0px;
  top: 12px;
}
.nav-icon-1 span:nth-child(7) {
  left: 0px;
  bottom: 0px;
}
.nav-icon-1 span:nth-child(8) {
  position: absolute;
  left: 12px;
  bottom: 0px;
}
.nav-icon-1 span:nth-child(9) {
  right: 0px;
  bottom: 0px;
}
.nav-icon-1.open {
  transform: rotate(180deg);
  cursor: pointer;
  transition: 0.2s cubic-bezier(0.8, 0.5, 0.2, 1.4);
}
.nav-icon-1.open span {
  border-radius: 50%;
  transition-delay: 200ms;
  transition: 0.5s cubic-bezier(0.8, 0.5, 0.2, 1.4);
}
.nav-icon-1.open span:nth-child(2) {
  left: 6px;
  top: 6px;
}
.nav-icon-1.open span:nth-child(4) {
  left: 6px;
  top: 18px;
}
.nav-icon-1.open span:nth-child(6) {
  right: 6px;
  top: 6px;
}
.nav-icon-1.open span:nth-child(8) {
  left: 18px;
  bottom: 6px;
}

.-top-full {
  top: -100% !important;
}

@keyframes smooth-pulse {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
}

.animate-smooth-pulse {
  animation: smooth-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.glow-static {
  text-shadow: 0 0 20px rgba(179, 131, 49, 0.8);
  transition: text-shadow 0.3s ease-in-out;
}

.podcast-h2 {
  transition: transform 0.3s ease-in-out;
}

.podcast-h2:hover {
  transform: scale(1.1);
  text-shadow: 0 0 20px rgba(49, 138, 179, 0.644);
}

@keyframes glow {
  0%,
  100% {
    text-shadow: 0 0 5px rgba(179, 131, 49, 0.5);
  }
  50% {
    text-shadow: 0 0 20px rgba(179, 131, 49, 0.8);
  }
}

.animate-glow {
  animation: glow 0.6s ease-in-out infinite;
}
