/* Redeem celebration visuals */
/* Salt-burst behind redeemed avatar */
.salt-burst {
  position: absolute;
  top: 50%; left: 50%;
  width: 300px; height: 300px;
  margin-left: -150px; margin-top: -150px; /* center */
  pointer-events: none;
  background-image: url("https://www.ragnaxross.com/xrosstoken/img/starburst.png");
  background-size: 100% 100%;
  animation: 12s salt-spin linear reverse infinite;
  z-index: 0;
}
.salt-burst:before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-image: inherit;
  background-size: inherit;
  transform-origin: 50% 50%;
  animation: 6s salt-pulsate linear infinite;
}
@keyframes salt-pulsate {
  0% { transform: scale(.8,.8) rotate(0); }
  50% { transform: scale(.5,.8) rotate(180deg); opacity: .5; }
  100% { transform: scale(1,1) rotate(360deg); opacity: 1; }
}
@keyframes salt-spin {
  0% { transform: rotate(45deg); }
  100% { transform: rotate(405deg); }
}

/* Confetti container and particles */
.confetti {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  overflow: hidden;
  z-index: 9999;
  pointer-events: none;
  perspective: 100vmin;
}
.confetti span {
  --size: 5;
  display: block;
  position: absolute;
  width: calc(var(--size) * 1px);
  height: calc(var(--size) * 1px);
  background-color: #4af;
  animation: rotate linear calc(var(--rs) * 1s) infinite both;
  will-change: transform;
}
@keyframes rotate {
  to { transform: rotate3d(var(--rx), var(--ry), var(--rz), 360deg); }
}
.crystalBalanceSticky, #crystalBalanceDisplay { position: sticky; top: 0; z-index: 999 !important; }
.avatar-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden; /* ensures inner tag corners follow card radius */
}

.avatar-rarity-tag {
    position: absolute;
    top: 0;
    right: 0;
    background: var(--raisin-black-3);
    padding: 0px 14px 0px 18px;
    border-bottom-left-radius: 12px; /* curve to match container */
    clip-path: polygon(0 0, 100% 0, 100% 100%, 14px 100%, 0 62%); /* angled notch with curved corner via radius above */
    z-index: 2;
}
.avatar-actions-row { display:flex; flex-direction:column; gap:10px; margin-top:10px; }
.price-button { 
    display:inline-flex !important; 
    align-items:center; 
    gap:10px; 
    line-height:1; 
    white-space:nowrap; 
    margin-top:10px; 
}
.price-button span { display:inline-block; }
.price-button img { height:51px; width:auto; display:block; }

/* Avatar Thumbnails for Wave Display */
.avatar-thumbnails {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin: 20px 0;
    padding: 15px;
    background: radial-gradient(    48.28% 48.28% at 49.66% 100%,    rgba(233, 0, 131, 0.1) 0%,    rgba(29, 14, 32, 0.1) 100%  ),  hsl(234deg 14% 14% / 63%);
    border-radius: 12px;
    border: 1px solid var(--raisin-black-3);
}

/* WAVE_3 specific styling - ensure thumbnails under wave 3 sections don't overflow */
#avatar-thumbnails-wave3 .avatar-thumbnail img { max-width: 100px; height: auto; width: auto; object-fit: contain; }

/* Remove background artifacts from any global .active/.dot:hover rules on compressed thumbs */
.compressed-thumbnails .compressed-thumb.active,
.compressed-thumbnails .compressed-thumb:hover {
    background: transparent !important;
}

.avatar-thumbnail {
    width: 60px;
    height: 60px;
    border-radius: 8px;
    overflow: hidden;
    border: 2px solid var(--raisin-black-3);
    transition: border-color var(--transition-1);
    cursor: pointer;
}

.avatar-thumbnail:hover {
    border-color: var(--spring-green);
}

.avatar-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avatar-rarity-tag span {
    font-weight: 700;
    color: #fff;
    letter-spacing: .08em;
}

.avatar-rarity-tag.common { background: #6b7280; }
.avatar-rarity-tag.uncommon { background: #22c55e; }
.avatar-rarity-tag.rare { background: #3b82f6; }
.avatar-rarity-tag.epic { background: #a855f7; }
.avatar-rarity-tag.legendary { background: #ffb300; }

@import url('https://fonts.googleapis.com/css2?family=Sonsie+One&display=swap');

:root {
    --raisin-black-1: hsl(234, 14%, 14%);
    --raisin-black-2: hsl(231, 12%, 12%);
    --raisin-black-3: hsl(228, 12%, 17%);
    --eerie-black: hsl(240, 11%, 9%);
    --light-gray: hsl(0, 0%, 80%);
    --platinum: hsl(0, 4%, 91%);
    --xiketic: hsl(275, 24%, 10%);
    --orange: #00CED1;
    --orange-gradient: linear-gradient(135deg, #00CED1, #FF1493);
    --spring-green: #00FF7F;
    --white: hsl(0, 0%, 100%);
    --onyx: hsl(240, 5%, 26%);

    --ff-refault: "Refault", Georgia;
    --ff-oswald: 'Oswald', sans-serif;
    --ff-poppins: 'Poppins', sans-serif;
    --ff-sonsie: 'Sonsie One', sans-serif;

    --fs-1: 54px;
    --fs-2: 34px;
    --fs-3: 30px;
    --fs-4: 26px;
    --fs-5: 22px;
    --fs-6: 20px;
    --fs-7: 18px;
    --fs-8: 15px;
    --fs-9: 14px;
    --fs-10: 13px;
    --fs-11: 12px;

    --fw-400: 400;
    --fw-500: 500;
    --fw-700: 700;

    --transition-1: 0.15s ease-in-out;
    --transition-2: 0.15s ease-in;
    --transition-3: 0.25s ease-out;

    --section-padding: 60px;

    --polygon-1: polygon(90% 0, 100% 34%, 100% 100%, 10% 100%, 0 66%, 0 0);
    --polygon-2: polygon(0 0, 100% 0%, 82% 100%, 0% 100%);
    --polygon-3: polygon(0 0, 100% 0%, 100% 100%, 18% 100%);
    --polygon-4: polygon(96% 0, 100% 36%, 100% 100%, 4% 100%, 0 66%, 0 0);
    
}



*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
a { text-decoration: none; }
li { list-style: none; }
a, img, span, input, button, ion-icon { display: block; }
    button { font: inherit; background: none; border: none; cursor: pointer; }
    input { font: inherit; width: 100%; border: none; }
html { font-family: var(--ff-poppins); scroll-behavior: smooth; }
body { overflow-x: hidden; }
    body.active { overflow-y: hidden; }
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--raisin-black-2); }
::-webkit-scrollbar-thumb { background: var(--spring-green); border-radius: 10px; }

.container { padding-inline: 15px; }
.h1 { color: var(--white); font-family: var(--ff-refault); font-size: var(--fs-1); font-weight: var(--fw-400); text-transform: uppercase; }
.h2 { font-size: var(--fs-2); color: var(--white); line-height: 1.2; text-transform: uppercase; font-family: var(--ff-oswald); }
.h3 { font-family: var(--ff-oswald); font-size: var(--fs-2); text-transform: uppercase; line-height: 1.2; }

/* New Animated Button Style for All Main Buttons (except heart) */
.btn {
  --border-color: linear-gradient(-45deg, #00ffbb, #920f56, #00fffb);
  --border-width: 0.125em;
  --curve-size: 0.5em;
  --blur: 30px;
  --bg: #080312;
  --color: #afffff;
  color: var(--color);
  cursor: pointer;
  position: relative;
  isolation: isolate;
  display: inline-grid;
  place-content: center;
  padding: 0.5em 1.5em;
  font-size: 17px;
  border: 0;
  text-transform: uppercase;
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.6);
  clip-path: polygon(
    0% var(--curve-size),
    var(--curve-size) 0,
    100% 0,
    100% calc(100% - var(--curve-size)),
    calc(100% - var(--curve-size)) 100%,
    0 100%
  );
  transition: color 250ms;
  background: none;
}
.btn::after,
.btn::before {
  content: "";
  position: absolute;
  inset: 0;
}
.btn::before {
  background: var(--border-color);
  background-size: 300% 300%;
  animation: move-bg7234 5s ease infinite;
  z-index: -2;
}
@keyframes move-bg7234 {
  0% { background-position: 31% 0%; }
  50% { background-position: 70% 100%; }
  100% { background-position: 31% 0%; }
}
.btn::after {
  background: var(--bg);
  z-index: -1;
  clip-path: polygon(
    var(--border-width) calc(var(--curve-size) + var(--border-width) * 0.5),
    calc(var(--curve-size) + var(--border-width) * 0.5) var(--border-width),
    calc(100% - var(--border-width)) var(--border-width),
    calc(100% - var(--border-width)) calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)),
    calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)) calc(100% - var(--border-width)),
    var(--border-width) calc(100% - var(--border-width))
  );
  transition: clip-path 500ms;
}
.btn:where(:hover, :focus)::after {
  clip-path: polygon(
    calc(100% - var(--border-width)) calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)),
    calc(100% - var(--border-width)) var(--border-width),
    calc(100% - var(--border-width)) var(--border-width),
    calc(100% - var(--border-width)) calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)),
    calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)) calc(100% - var(--border-width)),
    calc(100% - calc(var(--curve-size) + var(--border-width) * 0.5)) calc(100% - var(--border-width))
  );
  transition: 200ms;
}
.btn:where(:hover, :focus) {
  color: #fff;
}

/* Remove old .btn, .btn-primary, .btn-secondary backgrounds, borders, but keep clip-path */
.btn-primary, .btn-secondary {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}
.btn-primary { color: #ffae00; }
.btn-secondary { color: #00fffb; }

.btn-link:is(:hover, :focus ) { color: var(--orange); }
.has-scrollbar::-webkit-scrollbar { height: 12px; }
.has-scrollbar::-webkit-scrollbar-button { width: 40px; }
.section-title { position: relative; text-align: center; }
    .section-title::before, .section-title::after { 
        content: '';
        position: absolute;
        bottom: -20px;
        left: 50%;
        transform: translateX(-50%);
        height: 5px;
        width: 120px;
        background: var(--orange);
        border-radius: 0 0 5px 5px;
    }
        .section-title::before { bottom: -23px; height: 4px; width: 30px; }



/* Header */

.header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: var(--raisin-black-1);
	background: rgba(22, 39, 44, 0.68);
      backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 3px 7px hsla(0, 0%, 0%, 0.5);
    padding-block: 20px;
    z-index: 4;
}

    .header .container { display: flex; justify-content: space-between; align-items: center; }
.header-actions { display: none; }
.nav-open-btn { color: var(--white); font-size: 40px; padding: 5px; }
    .nav-open-btn ion-icon { --ionicon-stroke-width: 40px; }
.navbar {
    position: fixed;
    top: 0;
    right: -300px;
    width: 100%;
    max-width: 300px;
    background: var(--raisin-black-2);
    height: 2000px;
    box-shadow: 0 2px 8px hsla(0, 0%, 0%, 0.5);
    visibility: hidden;
    z-index: 10;
    transition: var(--transition-2);
}
    .navbar.active { right: 0; visibility: visible; transition: var(--transition-3); }
.navbar-top { display: flex; justify-content: space-between; align-items: center; padding: 25px; }
.nav-close-btn { color: #FF1493; font-size: 25px; padding: 10px; transform: translateX(15px); }
    .nav-close-btn ion-icon { --ionicon-stroke-width: 70px; }
.navbar-list { border-top: 1px solid hsla(0, 0%, 100%, 0.1); margin-bottom: 30px; }
.navbar-link {
    color: var(--white);
    font-size: 15px;
    padding: 10px 25px;
    border-bottom: 1px solid hsla(0, 0%, 100%, 0.1);
    font-weight: var(--fw-500);
    transition: .15s ease-in-out;
}
    .navbar-link:is(:hover, :focus) { color: var(--orange); }
.nav-social-list { display: flex; justify-content: center; align-items: center; gap: 15px; }
.social-link { color: #FF1493; font-size: 18px; }
.overlay { position: fixed; inset: 0; pointer-events: none; z-index: 1; transition: var(--transition-2); }
    .overlay.active { background: hsla(0, 0%, 0%, 0.7); pointer-events: all; transition: var(--transition-3); }

/*Hero*/

.hero {
    background-size: cover;
    background-position: top center;
    margin-top: 90px;
    padding: var(--section-padding) 0;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
    .hero .btn-primary ion-icon { font-size: 25px; }

.hero-subtitle {
    color: var(--white);
    font-family: var(--ff-oswald);
    font-size: var(--fs-7);
    font-weight: var(--fw-500);
    text-transform: uppercase;
    letter-spacing: 12px;
    text-shadow: 0 7px hsla(0, 0%, 0%, 0.4);
    margin-bottom: 15px;
}
.hero-title { margin-bottom: 10px; font-family: var(--ff-sonsie);}
.btn-group { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; }

/*About*/

.section-wrapper {
    position: relative;
    background: url('https://ragnaxross.com/xrosstoken/img/section-wrapper-bg.jpg') repeat-y;
    background-size: 100% auto;
    background-position: top center;
    z-index: 0;
    pointer-events: none;
}

/* Re-enable pointer events for interactive elements inside section-wrapper */
.section-wrapper * {
    pointer-events: auto;
}
.about { background: url('https://i.postimg.cc/8zmyG7dL/about-img-shadow.png') no-repeat; background-size: 100%; background-position: center; padding: 120px 0 var(--section-padding); }
.about-banner { margin-bottom: 40px; }
.about-img { width: 100%; animation: productAnimation 5s linear infinite; }
                @keyframes productAnimation {
                    0%, 100% { transform: translateY(15px); }
                    50% { transform: translateY(-15px); }
                }
.character { display: none; }
.about-content { background: var(--raisin-black-1); color: var(--white); padding: 40px 20px; border-radius: 4px; box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2); }
.about-subtitle { color: var(--spring-green); font-family: var(--ff-oswald); font-size: var(--fs-8); font-weight: var(--fw-500); text-transform: uppercase; margin-bottom: 15px; }
.about-title { font-family: var(--ff-oswald); font-size: var(--fs-2); line-height: 1.2; text-transform: uppercase; margin-bottom: 20px; }
    .about-title strong { color: #FF1493; }
.about-text, .about-bottom-text { color: var(--light-gray); font-size: var(--fs-9); line-height: 1.8; letter-spacing: 0.5px; }
    .about-text { margin-bottom: 20px; text-align: justify; }
    .about-bottom-text { display: flex; justify-content: flex-start; align-items: flex-start; gap: 8px; } 
        .about-bottom-text ion-icon { color: #00ced1; font-size: 25px; --ionicon-stroke-width: 45px; }
.about-text a {
  color: #00BFFF;
  text-decoration: underline;
  font-weight: 600;
  transition: color 0.2s;
  display: inline;
}
.about-text a:hover {
  color: #FF1493;
}
.discord-link {
  color: #00BFFF;
  text-decoration: underline;
  font-weight: 600;
  transition: color 0.2s;
  display: inline;
}
.discord-link:hover {
  color: #FF1493;
}

/*Tournament*/

.tournament { padding: var(--section-padding) 0; color: var(--white); text-align: center; }
    .tournament .btn-primary { width: max-content; margin-inline: auto; }
.tournament-content { margin-bottom: 50px; }
.tournament-subtitle { color: var(--spring-green); font-family: var(--ff-oswald); font-weight: var(--fw-500); text-transform: uppercase; margin-bottom: 10px; }
.tournament-title { margin-bottom: 20px; }
.tournament-text { color: var(--light-gray); font-size: var(--fs-9); line-height: 1.8; margin-bottom: 30px; }
.tournament-prize { margin-bottom: 50px; }
    .tournament-prize data { background: var(--spring-green); color: var(--raisin-black-1); font-family: var(--ff-oswald); font-size: var(--fs-4); padding: 8px 42px; border-radius: 50px; cursor: pointer; }
    .tournament-prize img { margin-inline: auto; }
.tournament-prize-title { font-size: var(--fs-3); margin-bottom: 20px; }
.tournament-winners { background: var(--raisin-black-3); padding: 40px 30px; border-radius: 4px; box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2); }
.tournament-winners-title { font-size: var(--fs-3); margin-bottom: 25px; }
.tournament-winners-list { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 20px; }
.winner-card .card-banner { max-width: 90px; margin-inline: auto; margin-bottom: 15px; }
.winner-card img { width: 100%; }
.winner-card .card-title {
    background: var(--orange);
    width: max-content;
    margin-inline: auto;
    font-size: var(--fs-10);
    text-transform: uppercase;
    padding: 6px 10px;
    border-radius: 4px;
}

/*Gallery*/

.gallery { padding: var(--section-padding) 0; }
.gallery-list {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 15px;
    margin: -15px;
    overflow-x: auto;
    padding-bottom: 15px;
    scroll-snap-type: inline mandatory;
    padding-inline: 15px;
}
    .gallery-list li { min-width: 95%; scroll-snap-align: center; }
    .gallery-list img { width: 100%; border-radius: 4px; box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2); }

/* Simple Auto-Scrolling Gallery */
.simple-gallery {
  width: 100%;
  max-width: 800px;
  margin: 0 auto 2rem auto;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

.gallery-container {
  position: relative;
  width: 100%;
  height: 400px;
  overflow: hidden;
}

.gallery-track {
  display: flex;
  align-items: center;
  gap: 0;
  transition: transform 0.3s cubic-bezier(.4,2,.6,1);
  will-change: transform;
  user-select: none;
  cursor: grab;
}

.gallery-track:active {
  cursor: grabbing;
}

.gallery-slide {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 400px;
  min-width: 800px;
  padding: 0;
}

.gallery-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  pointer-events: none;
}

.simple-gallery.dragging .gallery-track {
  transition: none;
}

/*Team*/

.team { padding: var(--section-padding) 0; }
    .team .btn-primary { margin-inline: auto; }
.team-list { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 30px; margin-bottom: 70px; }
    .team-list li { max-width: 40%; }
.team-member { position: relative; border-radius: 50%; border: 3px solid var(--raisin-black-3); transition: var(--transition-1); }
    .team-member:is(:hover, :focus) { border-color: var(--orange); }
    .team-member img { width: 100%; }
    .team-member ion-icon {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        color: var(--orange);
        font-size: 50px;
        transition: var(--transition-1);
        opacity: 0;
    }
        .team-member:is(:hover, :focus) ion-icon { opacity: 1; }

/*Gears*/

.gears { padding: var(--section-padding) 0; }
.gears-list { display: grid; gap: 50px; }
.gears-card .card-banner {
    position: relative;
    background: url('https://i.postimg.cc/JhHdWL8j/gears-card-bg.png') no-repeat;
    background-size: contain;
    background-position: center;
    width: 100%;
    aspect-ratio: 2 / 1.7;
    display: grid;
    place-items: center;
    margin-bottom: 30px;
}
    .gears-card .card-banner a { width: 100%; }
    .gears-card .card-banner img { width: 45%; margin-inline: auto; }
.share, .card-time-wrapper { position: absolute; color: var(--spring-green); }
    .share {
        top: 25%;
        right: 8%;
        font-size: 20px;
        border: 2px solid var(--onyx);
        width: 45px;
        height: 45px;
        display: grid;
        place-items: center;
        border-radius: 50%;
        transition: var(--transition-1);
    }
        .share:is(:hover, :focus ) { border-color: var(--spring-green); }
    .card-time-wrapper {
        top: 2%;
        right: 5%;
        font-family: var(--ff-oswald);
        font-size: var(--fs-9);
        font-weight: var(--fw-500);
        text-transform: uppercase;
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 5px;
    }
        .card-time-wrapper ion-icon { font-size: 16px; --ionicon-stroke-width: 50px; }
.gears .card-content {
    color: var(--white);
    margin-bottom: 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-transform: uppercase;
}
.gears-card :is(.card-title, .card-prize) { font-family: var(--ff-oswald); font-size: var(--fs-5); font-weight: var(--fw-700); }
    .gears-card .card-title { margin-bottom: 5px; }
.gears-card .card-subtitle { color: var(--light-gray); font-size: var(--fs-8); }
.gears .card-actions { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.gears-card .btn { padding: 18px 20px; }
.gears-card .btn-primary { font-size: var(--fs-7); padding-block: 15px; }
    .gears-card .btn-primary ion-icon { font-size: 20px; --ionicon-stroke-width: 80px; }
.gears-card .card-btn { 
    --polygon-1: polygon(75% 0, 100% 25%, 100% 100%, 25% 100%, 0 75%, 0 0);
    background: var(--orange);
    color: var(--white);
}
    .gears-card .card-btn ion-icon { --ionicon-stroke-width: 50px; }
    .gears-card .card-btn:is(:hover, :focus) { background: var(--spring-green); color: var(--white); }

/*Newsletter*/

.newsletter { padding: var(--section-padding) 0 120px; }
.newsletter-card { 
    background: url('https://i.postimg.cc/43KzBDHM/newsletter-bg.jpg') no-repeat;
    background-size: cover;
    background-position: center;
    padding: 50px 25px;
    border-radius: 12px;
    text-align: center;
}
.newsletter-content { margin-bottom: 30px; }
.newsletter-img { width: max-content; margin-inline: auto; margin-bottom: 10px; }
.newsletter-title { font-size: var(--fs-3); }
    .newsletter .input-field {
        background: hsla(0, 0%, 0%, 0.2);
        color: var(--white);
        border: 1px solid var(--white);
        font-size: var(--fs-10);
        padding: 17px 25px;
        margin-bottom: 15px;
    }
        .newsletter .input-field:focus { background: hsla(0, 0%, 0%, 0.4); outline: none; }
        .newsletter .input-field::placeholder { color: inherit; font-size: var(--fs-9); }
    .newsletter .btn-secondary { font-size: var(--fs-7); margin-inline: auto; }

/*Footer*/

.footer-top { 
    background: #1f2229;
}
    .footer-top .logo { width: max-content; margin-inline: auto; margin-bottom: 50px; }
.footer-brand-wrapper { position: relative; padding-bottom: 30px; border-bottom: 1px solid hsl(229, 14%, 8%); margin-bottom: 50px; }
    .footer-brand-wrapper::after {
        content: "";
        position: absolute;
        bottom: -4px;
        left: 0;
        width: 100%;
        height: 1px;
        background: hsla(0, 0%, 0%, 0.2);
    }
.footer-menu-list { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 5px 40px; margin-bottom: 20px; }
.footer-menu-link { 
    color: var(--platinum); 
    font-family: var(--ff-oswald); 
    font-size: var(--fs-5); 
    font-weight: var(--fw-500); 
    letter-spacing: 1px; 
    text-transform: uppercase;
    padding: 5px 10px;
    transition: var(--transition-1); 
}
    .footer-menu-link:is(:hover, :focus) { color: var(--spring-green); }
.footer-input-wrapper { position: relative; max-width: 260px; margin-inline: auto; }
    .footer-input-wrapper .btn-primary {
        --polygon-1: polygon(70% 0, 100% 30%, 100% 100%, 30% 100%, 0 63%, 0 0);

        position: absolute;
        top: 0;
        right: 0;
        padding: 17px;
    }
        .footer-input-wrapper .btn-primary:is(:hover, :focus ) { background: var(--white); color: var(--orange); }
.footer-input {
    --polygon-1: polygon(93% 0, 100% 30%, 100% 100%, 7% 100%, 0 63%, 0 0);

    background: var(--xiketic);
    color: var(--white);
    font-size: var(--fs-10);
    padding: 17px 25px;
    clip-path: var(--polygon-1);
}
    .footer-input::placeholder { font-size: var(--fs-9); }
    .footer-input:focus { outline: none; }
.quicklink-list { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 5px; margin-bottom: 20px; }
.quicklink-item {
    color: var(--light-gray);
    font-family: var(--ff-oswald);
    font-size: var(--fs-11);
    font-weight: var(--fw-500);
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 5px 10px;
    transition: var(--transition-1);
}
    .quicklink-item:is(:hover, :focus) { color: var(--spring-green); }
.footer-social-list { display: flex; justify-content: center; align-items: center; gap: 10px; }
.footer-social-link {
    background: var(--xiketic);
    color: var(--light-gray);
    width: 35px;
    height: 35px;
    display: grid;
    place-items: center;
    font-size: 14px;
    border-radius: 50%;
    transition: var(--transition-1);
}
    .footer-social-link:is(:hover, :focus) { color: var(--spring-green); }
.footer-bottom {
    padding: 25px 0;
    background: #1f2229;
    text-align: center;
}
.copyright { color: var(--light-gray); font-family: var(--ff-oswald); font-size: var(--fs-9); font-weight: var(--fw-500); text-transform: uppercase; margin-bottom: 15px; text-align: center; }
    .copyright a { display: inline-block; color: var(--spring-green); }
.footer-bottom-img { width: max-content; max-width: 100%; margin-inline: auto; }

/*Go-top Button*/

.go-top {
    --polygon-1: polygon(70% 0, 100% 30%, 100% 100%, 30% 100%, 0 70%, 0 0);

    position: fixed;
    bottom: 20px;
    right: 20px;
    padding: 15px;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-1);
}
    .go-top.active { visibility: visible; opacity: 1; pointer-events: all; }
    .go-top:is(:hover, :focus ) { background: var(--white); color: var(--spring-green); }

/*Media queries*/

@media(min-width: 420px) {
    :root { --fs-1: 70px; }
}

@media(min-width: 575px) {
    :root {
        --fs-1: 90px;
        --fs-2: 45px;
    }

    .container { max-width: 540px; margin-inline: auto; }

    .about-banner { position: relative; max-width: 410px; margin-inline: auto; z-index: 1; }
    .character-2 { display: block; position: absolute; top: 120px; left: 160px; max-width: 150px; z-index: -1; }
    .about-content { padding: 60px 40px; }

    .tournament-text { max-width: 500px; margin-inline: auto; }

    .gallery .container { max-width: unset; }
    .gallery-list li { max-width: 80%; }
}

@media(min-width: 768px) {
    :root {
        --fs-1: 115px;
        --fs-2: 36px;
    }

    .container { max-width: 700px; }
    .has-scrollbar::-webkit-scrollbar-button { width: 150px; }

    .header::before, .header::after {
        content: '';
        position: absolute;
        width: 115px;
        height: 20px;

		    background-color: var(--raisin-black-1);
	background: rgba(22, 39, 44, 0.68);
      backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 3px 7px hsla(0, 0%, 0%, 0.5);
        bottom: -20px;
    }
        .header::before { left: 0; clip-path: var(--polygon-2); }
        .header::after { right: 0; clip-path: var(--polygon-3); }

    .hero-subtitle { --fs-7: 25px; letter-spacing: 30px; }

    .about-banner { max-width: 430px; }
    .character { display: block; position: absolute; z-index: -1; }
    .character-1 { width: 160px; top: 110px; left: -120px; }
    .character-2 { left: 200px; }
    .character-3 { top: 0; right: -112px; }

    .gallery-list { padding-bottom: 30px; }
        .gallery-list li { min-width: 70%; }

    .gears-list { grid-template-columns: 1fr 1fr; }

    .newsletter-card { text-align: left; }
    .newsletter-content {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 30px;
        max-width: 440px;
        margin-inline: auto;
    }
    .newsletter-img { margin-inline: 0; }
    .newsletter-form { position: relative; max-width: 530px; margin-inline: auto; }
        .newsletter-form::after {
            content: '';
            position: absolute;
            bottom: 9px;
            left: -3px;
            width: 27px;
            height: 1px;
            background: var(--white);
            transform: rotate(43deg);
        }
    .newsletter .btn-secondary { position: absolute; top: 0; right: 0; bottom: 0; }
    .newsletter .input-field { clip-path: var(--polygon-4); margin-bottom: 0; }

    .footer-menu-wrapper, .footer-quicklinks { display: flex; justify-content: space-between; align-items: center; }
.footer-bottom .container { display: flex; justify-content: center; align-items: center; }
    .footer-menu-list { max-width: 50%; justify-content: flex-start; column-gap: 16px; margin-bottom: 0; }
    .footer-input-wrapper { margin-inline: 0; width: 50%; }
    .quicklink-list { margin-bottom: 0; column-gap: 15px; }
    .copyright { margin-bottom: 0; }

}

@media(min-width: 1024px) {
    :root { --section-padding: 100px; }
    
    .container { max-width: 1000px; }
    .has-scrollbar::-webkit-scrollbar-button { width: 200px; }

    .header { padding-block: 0; }
        .header .logo { margin-right: 25px; }
    .nav-open-btn { display: none; }
    .navbar {
        position: static;
        opacity: 1;
        visibility: visible;
        background: none;
        max-width: unset;
        width: max-content;
        height: auto;
        box-shadow: none;
    }
    .navbar-top, .nav-social-list { display: none; }
    .navbar-list { margin-bottom: 0; display: flex; justify-content: flex-end; align-items: center; }
    .navbar-link {
        position: relative;
        color: var(--platinum);
        padding-block: 34px;
        border: none;
        font-family: var(--ff-oswald);
        text-transform: uppercase;
        letter-spacing: 1px;
        z-index: 1;
    }
        .navbar-link::after {
            content: '';
            position: absolute;
            inset: 0;
            transform: skew(15deg);
            border-bottom: 5px solid transparent;
            z-index: -1;
            transition: var(--transition-1);
        }
        .navbar-link:focus { outline: none; }
        .navbar-link:is(:hover, :focus )::after { background: var(--raisin-black-2); border-color: var(--orange); }
        .header-actions { display: flex; justify-content: center; align-items: center; }
            .header-actions .search { color: var(--white); font-size: 18px; padding: 25px; transition: var(--transition-1); }
                .search ion-icon { --ionicon-stroke-width: 70px; }
                .header-actions .search:is(:hover, :focus ) { color: var(--orange); }
    .btn-sign-in {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        background: var(--raisin-black-3);
        color: var(--light-gray);
        font-family: var(--ff-oswald);
        font-size: var(--fs-11);
        font-weight: var(--fw-500);
        text-transform: uppercase;
        letter-spacing: 1px;
        padding: 5px;
        border-right: 5px solid var(--orange);
        box-shadow: 0 0 4px hsla(0, 0%, 0%, 0.2);
        margin-left: 15px;
        transition: var(--transition-1);
    }
        .btn-sign-in::after {
            content: '';
            position: absolute;
            top: 50%;
            left: -20px;
            transform: translateY(-50%);
            width: 5px;
            height: 40px;
            background: var(--eerie-black);
            box-shadow: 0 3px 7px hsla(345, 75%, 30%, 0.2), inset 0 3px 7px 0 hsla(335, 53%, 14%, .4);
        }
        .btn-sign-in:is(:hover, :focus) { color: var(--orange); }
        .btn-sign-in .icon-box { 
            font-size: 18px;
            background: var(--raisin-black-2);
            padding: 6px;
            margin-right: 5px;
            box-shadow: 0 3px 7px hsla(345, 75%, 30%, 0.2), inset 0 3px 7px 0 hsla(335, 53%, 14%, .4);
        }
            .btn-sign-in .icon-box ion-icon { --ionicon-stroke-width: 40px; }
        .btn-sign-in span { padding-inline: 10px; }
        
        /* Logged in state styling */
        .btn-sign-in.logged-in {
            background: #00FF7F; /* Bright green background */
            color: #666; /* Light gray text */
        }
        
        .btn-sign-in.logged-in .icon-box {
            background: #333; /* Dark background for icon box */
        }
        
        .btn-sign-in.logged-in .icon-box ion-icon {
            color: #fff; /* White icon */
        }

/*  
    .about { padding-top: 200px; }     */
    .about-content { max-width: 700px; margin-inline: auto; }

    .tournament {
        --fs-2: 30px;
        --fs-3: 30px;
        --fs-6: 16px;

        text-align: left;
    }
        .tournament .container { display: flex; justify-content: space-between; align-items: center; }
        .tournament .btn-primary { margin-inline: 0; }
    .tournament-content, .tournament-prize { margin-bottom: 0; }
        .tournament-content { max-width: 310px; }
    .tournament-prize, .tournament-winners { text-align: center; }
        .tournament-winners { padding: 45px 40px; }

    .gallery-list { gap: 30px; padding-inline: 30px; }
        .gallery-list li { min-width: 50%; }

    .card-time-wrapper { top: 4%; right: 8%; }

    .newsletter { padding-bottom: 200px; }
    .newsletter-card { display: flex; justify-content: space-between; align-items: center; gap: 50px; padding: 45px 50px; }
    .newsletter-content { margin-inline: 0; margin-bottom: 0; }
    .newsletter-img { padding-left: 30px; }
    .newsletter-form { flex-grow: 1; }
        .newsletter-form::after { bottom: 9px; left: -5px; width: 25px; transform: rotate(52deg); }

    .footer-brand-wrapper { display: flex; justify-content: space-between; align-items: center; }
    .footer-top .logo { margin-inline: 0; margin-bottom: 0; margin-right: 50px; }
    .footer-menu-list { flex-grow: 1; max-width: unset; }
    
    .overlay { display: none; }

}

@media(min-width: 1200px) {
    :root {
        --fs-1: 150px;
    }

    .container { max-width: 1200px; }
    /*.navbar-link { padding-block: 45px; }*/

    .hero { margin-top: 140px; }

    .about { background-size: 55%; background-position: 90% center; }
        .about .container {
            display: flex;
            flex-direction: row-reverse;
            justify-content: space-between;
            align-items: center;
            gap: 100px;
            padding-right: 110px;
        }
    .about-banner { margin-inline: 0; margin-bottom: 0; }
    .character-2 { left: 155px; top: 70px; }
    .about-content { max-width: 600px; margin-inline: 0; }

    .team-list { gap: 20px; }

    .gears-list { grid-template-columns: repeat(3, 1fr); }
    .card-time-wrapper { top: 3.5%; right: 7%; }

    .newsletter-card { padding-block: 60px; }
    .newsletter-content { max-width: 500px; }
    .newsletter-title { --fs-3: 40px; }
    .newsletter-form { max-width: 450px; margin-inline: 0; }
        .newsletter-form::after { left: -3px; transform: rotate(46deg); }

    .footer-menu-wrapper { flex-grow: 1; }
    .footer-menu-list { justify-content: flex-end; }
	
	        /* Video Container Section */
        .video-container {
            position: relative;
            text-align: center;
        }

        video {
            width: 100%;
            max-width: 1920px;
            height: auto;
        }
		
        .video-placeholder {
            display: none;
        }
		

/* Custom Services Section */
.custom-services {
  /*  padding: var(--section-padding) 0; */
 /*   background: var(--raisin-black-1);  */
    color: var(--white);
}

/* Condensed Utilization Section */
.custom-services.condensed {
    max-width: 800px;
    margin-inline: auto;
    padding: 40px 20px;
}

.custom-services.condensed p {
    text-align: center;
    color: var(--light-gray);
    font-size: var(--fs-9);
    line-height: 1.8;
    margin-bottom: 30px;
    max-width: 600px;
    margin-inline: auto;
}

.custom-services.condensed .placeholder-img-section {
    margin-inline: auto;
    margin-top: 20px;
}

.custom-services.condensed .placeholder-img-section img {
    display: block;
    margin-inline: auto;
}

.custom-services .section-title {
    margin-bottom: 40px;
}

.custom-services p {
    text-align: center;
    color: var(--light-gray);
    font-size: var(--fs-9);
    line-height: 1.8;
    margin-bottom: 40px;
}

.custom-services .form {
    max-width: 600px;
    margin-inline: auto;
    background: var(--raisin-black-3);
    padding: 40px;
    border-radius: 4px;
    box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2);
}

.custom-services .form label {
    display: block;
    margin-bottom: 20px;
    color: var(--white);
    font-family: var(--ff-oswald);
    font-size: var(--fs-8);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.custom-services .form label.deposit-disclaimer {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 1em 0 0.5em 0;
  font-size: 1em;
  font-weight: 500;
  letter-spacing: 1px;
}
.custom-services .form label.deposit-disclaimer input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: #00CED1;
  margin: 0;
}

.custom-services .form input,
.custom-services .form select,
.custom-services .form textarea {
    width: 100%;
    padding: 15px;
    background: var(--raisin-black-2);
    border: 1px solid var(--orange);
    border-radius: 4px;
    color: var(--white);
    font-size: var(--fs-9);
    margin-top: 8px;
    transition: var(--transition-1);
}

.custom-services .form input:focus,
.custom-services .form select:focus,
.custom-services .form textarea:focus {
    outline: none;
    border-color: var(--white);
    background: var(--raisin-black-1);
}

.custom-services .form textarea {
    min-height: 120px;
    resize: vertical;
}

.custom-services .form .btn-primary {
    width: 100%;
    margin-top: 20px;
}

#service-success {
    text-align: center;
    color: var(--orange);
    font-size: var(--fs-8);
    font-weight: var(--fw-500);
    margin-top: 20px;
    padding: 15px;
    background: var(--raisin-black-2);
    border-radius: 4px;
}

/* Token Section */
.token-section {
    padding: 40px 0;
    background: transparent;
}

.buy-swap {
    display: grid;
    gap: 40px;
    max-width: 1100px;
    margin: 0 auto;
    grid-template-columns: 1fr 1fr;
}

.buy-swap > div {
    /* background: var(--raisin-black-3); */
    border: 1.5px solid #32333a;
    border-radius: 18px;
    padding: 40px 32px 40px 32px;
    min-height: 400px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
}

/* Placeholder for left card (wallet integration) */
#wallet-section:empty::before {
    content: '';
    display: block;
    min-height: 320px;
}

.traditional-options {
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
}

.traditional-options > h3 {
    color: var(--white);
    font-family: var(--ff-oswald);
    text-transform: uppercase;
    margin-bottom: 24px;
    font-size: 1.1rem;
    letter-spacing: 1px;
}

.token-actions {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-bottom: 32px;
}

.token-actions .btn {
    width: 100%;
    min-width: 220px;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: 1px;
    border-radius: 0;
    border: none;
    background: var(--orange);
    color: var(--white);
    padding: 0;
    transition: background 0.2s, color 0.2s;
}
.token-actions .btn.btn-secondary {
    background: var(--white);
    color: var(--orange);
    border: none;
}
.token-actions .btn:hover {
    background: var(--spring-green);
    color: var(--eerie-black);
}

.token-info {
    border-top: 1px solid #32333a;
    padding-top: 24px;
    margin-top: 24px;
}
.token-details h4 {
    color: var(--white);
    font-family: var(--ff-oswald);
    text-transform: uppercase;
    margin-bottom: 15px;
    font-size: 1.1rem;
}
.token-details p {
    color: var(--light-gray);
    margin-bottom: 8px;
    font-size: 1rem;
}
.token-details strong {
    color: var(--white);
}

/* GOALS Section */
.funding-goals {
    padding: var(--section-padding) 0;
    background: transparent;
}
.goals-grid {
    display: grid;
    gap: 40px;
    max-width: 900px;
    margin: 0 auto;
    grid-template-columns: 1fr 1fr;
}
.goal {
    background: var(--raisin-black-3);
    border: 1.5px solid #32333a;
    border-radius: 18px;
    padding: 36px 32px 36px 32px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 0;
}
.goal h3 {
    color: var(--white);
    font-family: var(--ff-oswald);
    text-transform: uppercase;
    margin-bottom: 18px;
    font-size: 1.1rem;
    letter-spacing: 1px;
}
.progress-bar {
    width: 100%;
    height: 8px;
    background: #23242a;
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 10px;
    margin-top: 0;
}
.progress {
    height: 100%;
    background: linear-gradient(90deg, #00CED1 0%, #FF1493 100%);
    border-radius: 8px;
    transition: width 1s cubic-bezier(.4,2,.6,1);
}
.funding-text {
    color: var(--white);
    font-size: 1rem;
    font-weight: 500;
    margin-bottom: 18px;
}
.funding-form {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 12px;
}
.funding-form input[type="number"] {
    width: 100%;
    background: #23242a;
    color: var(--light-gray);
    border: 1.5px solid #32333a;
    border-radius: 8px;
    padding: 18px 16px;
    font-size: 1.1rem;
    margin-bottom: 0;
    outline: none;
    transition: border 0.2s;
}
.funding-form input[type="number"]:focus {
    border: 1.5px solid var(--orange);
    color: var(--white);
}
.funding-form button {
    width: 100%;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 1px;
    border-radius: 0;
    border: none;
    background: var(--orange);
    color: var(--white);
    padding: 22px 0 22px 0;
    clip-path: var(--polygon-1);
    transition: background 0.2s, color 0.2s;
}
.funding-form button:hover {
    background: var(--spring-green);
    color: var(--eerie-black);
}

@media (max-width: 900px) {
    .buy-swap, .goals-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .buy-swap > div, .goal {
        min-width: 0;
        padding: 28px 12px;
    }
}
/* --- END XROSS TOKEN & GOALS SECTION STYLES (ENHANCED) --- */

/* Funding Goals Section */
.funding-goals {
    padding: 40px 0;
/*     background: var(--raisin-black-1); */
    color: var(--white);
}

.funding-goals .section-title {
    margin-bottom: 40px;
}

.funding-goals .goal {
    background: var(--raisin-black-3);
    padding: 25px;
    border-radius: 4px;
    box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2);
    margin-bottom: 20px;
    text-align: left;
}

.funding-goals .goal:last-child {
    margin-bottom: 0;
}

.funding-goals .goal h3 {
    color: var(--white);
    margin-bottom: 15px;
    font-size: var(--fs-4);
    font-family: var(--ff-oswald);
    text-transform: uppercase;
    font-weight: var(--fw-600);
}

.progress-bar {
    width: 100%;
    height: 18px;
    background: var(--raisin-black-1);
    border-radius: 9px;
    overflow: hidden;
    margin-bottom: 12px;
    border: 2px solid #00CED1;
}

.progress {
    height: 100%;
    background: var(--orange-gradient);
    border-radius: 7px;
    transition: width 0.3s ease;
}

.funding-goals .goal .funding-text {
    color: var(--white);
    font-size: var(--fs-9);
    margin: 0;
    line-height: 1.4;
    text-align: left;
}

/* Contact Section */
.contact-section {
    padding: var(--section-padding) 0;
    background: transparent;
    color: var(--white);
}

.contact-section .section-title {
    margin-bottom: 40px;
}

.contact-section .form {
    max-width: 600px;
    margin-inline: auto;
    background: var(--raisin-black-3);
    padding: 40px;
    border-radius: 4px;
    box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2);
}

.contact-section .form label {
    display: block;
    margin-bottom: 20px;
    color: var(--white);
    font-family: var(--ff-oswald);
    font-size: var(--fs-8);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.contact-section .form input,
.contact-section .form textarea {
    width: 100%;
    padding: 15px;
    background: var(--raisin-black-2);
    border: 1px solid var(--orange);
    border-radius: 4px;
    color: var(--white);
    font-size: var(--fs-9);
    margin-top: 8px;
    transition: var(--transition-1);
}

.contact-section .form input:focus,
.contact-section .form textarea:focus {
    outline: none;
    border-color: var(--white);
    background: var(--raisin-black-1);
}

.contact-section .form textarea {
    min-height: 120px;
    resize: vertical;
}

.contact-section .form .btn-primary {
    width: 100%;
    margin-top: 20px;
}

#contact-success {
    text-align: center;
    color: var(--orange);
    font-size: var(--fs-8);
    font-weight: var(--fw-500);
    margin-top: 20px;
    padding: 15px;
    background: var(--raisin-black-2);
    border-radius: 4px;
}

/* Responsive Design for New Sections */
@media(min-width: 768px) {
    .custom-services .form,
    .contact-section .form {
        padding: 50px;
    }
    
    .funding-goals .goal {
        padding: 40px;
    }
    
    .buy-swap {
        padding: 40px;
    }
}

@media(min-width: 1024px) {
    .custom-services .form,
    .contact-section .form {
        max-width: 700px;
        padding: 60px;
    }
    
    .funding-goals .goal {
        padding: 50px;
    }
    
    .buy-swap {
        padding: 50px;
    }
    
    #wallet-info {
        padding: 40px;
    }
}

.ecosystem-collab {
  padding: var(--section-padding) 0;
  color: var(--white);
}
.ecosystem-collab .container {
  max-width: 900px;
  margin: 0 auto;
}
.license-tiers {
  display: flex;
  gap: 2rem;
  justify-content: center;
  margin-top: 2rem;
  flex-wrap: wrap;
}
.license-tier {
  flex: 1 1 250px;
  min-width: 220px;
  max-width: 320px;
  background: var(--raisin-black-3, #23242a);
  border-radius: 12px;
  color: var(--white);
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.5rem 1rem 1.5rem 1rem;
  text-align: center;
  margin-bottom: 1rem;
}
.license-tier h4 {
  background: linear-gradient(90deg, #00CED1, #00FF7F);
  color: #23242a;
  border-radius: 8px 8px 0 0;
  padding: 0.75em 0.5em;
  margin: -1.5rem -1rem 1rem -1rem;
  font-size: 1.1em;
  font-weight: 700;
  letter-spacing: 1px;
}
.license-tier strong {
  color: var(--spring-green, #00FF7F);
  font-weight: 600;
  display: block;
  margin-bottom: 0.5em;
}
.license-tier ul {
  margin: 0.5em 0 1em 0;
  padding: 0;
  list-style: disc inside;
  text-align: left;
}
.license-tier ul li {
  margin-bottom: 0.5em;
}
@media (max-width: 900px) {
  .license-tiers {
    flex-direction: column;
    gap: 1.5rem;
    align-items: center;
  }
  .license-tier {
    max-width: 400px;
    margin: 0 auto 1rem auto;
  }
}

.license-usage-chart {
  margin: 2rem auto 0 auto;
  max-width: 700px;
  overflow-x: auto;
}
.license-usage-chart table {
  width: 100%;
  border-collapse: collapse;
  background: var(--raisin-black-3, #23242a);
  color: var(--white);
  border-radius: 8px;
  overflow: hidden;
  font-size: 1em;
}
.license-usage-chart th, .license-usage-chart td {
  padding: 0.75em 0.5em;
  text-align: center;
  border-bottom: 1px solid #333;
}
.license-usage-chart th {
  background: #23242a;
  color: #00CED1;
  font-weight: 700;
  font-size: 1.05em;
}
.license-usage-chart tr:last-child td {
  border-bottom: none;
}
.license-usage-chart td {
  font-size: 1.1em;
}
.license-usage-chart td small {
  color: #aaa;
  font-size: 0.9em;
}
@media (max-width: 700px) {
  .license-usage-chart table {
    font-size: 0.95em;
  }
}

.orange-link {
  color: #FFA500;
  text-decoration: underline;
  font-weight: 600;
  transition: color 0.2s;
  display: inline;
}
.orange-link:hover {
  color: #FF8C00;
}

.funding-form {
  margin-top: 1rem;
}

.funding-input {
  display: flex;
  gap: 1rem;
  align-items: center;
  margin-top: 0.5rem;
  max-width: 500px;
}

.funding-input input {
  flex: 0 1 200px;
  padding: 0.75rem;
  border: 1px solid var(--raisin-black-3);
  border-radius: 4px;
  background: var(--raisin-black-2);
  color: var(--white);
  font-size: 14px;
}

.fund-btn {
  white-space: nowrap;
  padding: 0.75rem 1.5rem;
  background: var(--orange);
  color: var(--eerie-black);
  border: none;
  border-radius: 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  cursor: pointer;
  transition: background-color 0.2s;
}

.fund-btn:hover {
  background: var(--spring-green);
}

/* Slideshow Styles */
.slideshow-container {
  max-width: 530px;
  height: 300px;
  position: relative;
  margin: 30px auto 10px auto;
  border-radius: 12px;
  overflow: hidden;
  background: #181828;
  box-shadow: 0 4px 24px #0008;
}

.mySlides {
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  top: 0; left: 0;
}

.mySlides img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  display: block;
}

/* Next & previous buttons, dots, etc. remain unchanged below */
.prev, .next {
  cursor: pointer;
  position: absolute;
  top: 50%;
  width: auto;
  margin-top: -22px;
  padding: 16px;
  color: white;
  font-weight: bold;
  font-size: 18px;
  transition: 0.6s ease;
  border-radius: 0 3px 3px 0;
  user-select: none;
  background-color: rgba(0,0,0,0.8);
}

/* Position the "next button" to the right */
.next {
  right: 0;
  border-radius: 3px 0 0 3px;
}

/* On hover, add a black background color with a little bit see-through */
.prev:hover, .next:hover {
  background-color: rgba(0,0,0,0.8);
}

/* Caption text */
.text {
  color: #f2f2f2;
  font-size: 15px;
  padding: 8px 12px;
  position: absolute;
  bottom: 8px;
  width: 100%;
  text-align: center;
}

/* Number text (1/3 etc) */
.numbertext {
  color: #f2f2f2;
  font-size: 12px;
  padding: 8px 12px;
  position: absolute;
  top: 0;
}

/* The dots/bullets/indicators */
.dot {
  cursor: pointer;
  height: 15px;
  width: 15px;
  margin: 0 2px;
  background-color: #bbb;
  border-radius: 50%;
  display: inline-block;
  transition: background-color 0.6s ease;
}

.active, .dot:hover {
  background-color: #717171;
}

/* Fading animation */
.fade {
  animation-name: fade;
  animation-duration: 1.5s;
}

@keyframes fade {
  from {opacity: .4} 
  to {opacity: 1}
}

/* Responsive adjustments */
@media (max-width: 700px) {
  .slideshow-container {
    max-width: 100%;
  }
  
  .prev, .next {
    padding: 12px;
    font-size: 16px;
  }
  
  .text {
    font-size: 14px;
  }
  
  .numbertext {
    font-size: 11px;
  }
}

/* Base styling for the sound bars */
/* React-Style Floating Mute Button - Bottom Right */
.grafica {
    position: fixed;
    z-index: 1002;
    bottom: 2rem;
    right: 2rem;
    width: 50px;
    height: 50px;
    background: rgba(0, 206, 209, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--orange);
    cursor: pointer;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}

.grafica:hover {
    background: rgba(0, 206, 209, 0.4);
    transform: scale(1.1);
}

.grafica ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    gap: 2px;
    align-items: end;
}

.grafica li {
    display: inline-block;
}

.grafica li span {
    display: block;
    width: 3px;
    background-color: var(--orange);
    border-radius: 1px;
    animation: soundbar 1s ease-in-out infinite alternate;
}

/* Individual bar heights and timing exactly like React Hero component */
.grafica li:nth-child(1) span { 
    height: 10px;
    animation-duration: 1.1s;
    animation-delay: 0s;
}
.grafica li:nth-child(2) span { 
    height: 12px;
    animation-duration: 1.2s;
    animation-delay: 0.1s;
}
.grafica li:nth-child(3) span { 
    height: 14px;
    animation-duration: 1.3s;
    animation-delay: 0.2s;
}
.grafica li:nth-child(4) span { 
    height: 16px;
    animation-duration: 1.4s;
    animation-delay: 0.3s;
}
.grafica li:nth-child(5) span { 
    height: 18px;
    animation-duration: 1.5s;
    animation-delay: 0.4s;
}

@keyframes soundbar {
    0% { 
        opacity: 0.3; 
        transform: scaleY(0.3);
    }
    100% { 
        opacity: 1; 
        transform: scaleY(1);
    }
}

/* Muted state - static pink bars */
.grafica.muted li span {
    animation: none;
    background-color: #ff4081;
    opacity: 0.6;
    transform: scaleY(0.3);
}

/* Force floating position */
.mute-float {
    position: fixed !important;
    z-index: 1002 !important;
    bottom: 2rem !important;
    right: 2rem !important;
    left: auto !important;
    top: auto !important;
}

/* Condensed Pricing Table */
.pricing-table-condensed {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-top: 3rem;
}

.pricing-card-condensed {
  background: rgba(30, 34, 41, 0.55); /* semi-transparent dark */
  border-radius: 1.5rem;
  padding: 2.5rem 1.8rem;
  flex: 1 1 280px;
  max-width: 320px;
  text-align: left;
  position: relative;
  overflow: hidden;
  border: 1.5px solid rgba(255,255,255,0.18);
  box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.15);
  backdrop-filter: blur(12px) saturate(120%);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
  transition: border-color 0.3s, transform 0.3s;
}

.pricing-card-condensed:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 8px;
  background: linear-gradient(90deg, #00CED1, #00FF7F);
  opacity: 0;
  transition: opacity 0.3s;
}

.pricing-card-condensed:hover:before {
  opacity: 1;
}

.pricing-card-condensed:hover {
  transform: translateY(-8px);
  border-color: #00CED1;
}

.pricing-card-condensed__price {
  font-family: var(--ff-oswald);
  font-size: 2.8rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 0.5rem;
}

.pricing-card-condensed__price span {
  font-size: 1rem;
  font-weight: 400;
  color: var(--light-gray);
  margin-left: 0.2em;
}

.pricing-card-condensed__title {
  font-family: var(--ff-oswald);
  font-size: 1.5rem;
  color: var(--white);
  margin-bottom: 0.75rem;
}

.pricing-card-condensed__description {
  color: var(--light-gray);
  font-size: 0.95rem;
  margin-bottom: 1.75rem;
  min-height: 50px;
}

.pricing-card-condensed__features {
  list-style: none;
  padding: 0;
  margin: 0;
}

.pricing-card-condensed__features li {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: var(--light-gray);
  margin-bottom: 0.75rem;
  font-size: 1rem;
}

.pricing-card-condensed__features ion-icon {
  color: var(--spring-green);
  font-size: 1.4rem;
  flex-shrink: 0;
}
/* End Condensed Pricing Table */

/* Smaller Disclaimer Section Styles */
.disclaimer-section {
  margin: 2rem 0 1.2rem 0;
  padding: 0;
}
.disclaimer-section .container {
  background: rgba(30, 40, 50, 0.75);
  border-radius: 14px;
  box-shadow: 0 2px 12px 0 rgba(0,0,0,0.13);
  padding: 1.2rem 1rem 1rem 1rem;
  max-width: 520px;
  margin: 0 auto;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.10);
}
.disclaimer-icon {
  font-size: 1.5rem;
  color: #FFD700;
  margin-bottom: 0.2rem;
  text-align: center;
}
.disclaimer-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.6rem;
  text-align: center;
  letter-spacing: 0.01em;
}
.disclaimer-text {
  color: #e0e0e0;
  font-size: 0.92rem;
  margin-bottom: 0.7rem;
  text-align: left;
}
.disclaimer-list {
  color: #fff;
  margin-bottom: 0.7rem;
  padding-left: 1.1em;
  font-size: 0.92rem;
}
.disclaimer-list li {
  margin-bottom: 0.2em;
  list-style: disc;
}
.disclaimer-faq {
  background: rgba(255,255,255,0.05);
  border-radius: 7px;
  padding: 0.6rem 0.7rem;
  margin-bottom: 0.7rem;
}
.utilization-container {
  box-shadow: 0px 0.5rem 0.5rem rgba(171, 84, 244, 0.16);
  border-radius: 7px;
  padding: 0.6rem 0.7rem;
  color: var(--chakra-colors-chakra-body-text);
  border-width: var(--card-border-width, 0);
  border-color: var(--card-border-color);
  background-image: linear-gradient(rgb(127 204 237 / 0%), rgba(161, 104, 255, 0.31));
  border-style: solid;
  padding: 0.6rem 0.7rem;
  margin-bottom: 0.7rem;
}

.disclaimer-faq h3 {
  color: #00CED1;
  font-size: 0.98rem;
  margin-bottom: 0.4rem;
  font-weight: 600;
}
.faq-item {
  margin-bottom: 0.5rem;
  color: #fff;
  font-size: 0.89rem;
}
.faq-item strong {
  color: #FFD700;
  font-weight: 600;
}
.disclaimer-reminder {
  background: rgba(255, 20, 147, 0.10);
  color: #FF1493;
  font-weight: 700;
  border-radius: 6px;
  padding: 0.4rem 0.7rem;
  text-align: center;
  font-size: 0.95rem;
  margin-top: 0.7rem;
}
@media (max-width: 600px) {
  .disclaimer-section .container {
    padding: 0.7rem 0.2rem 0.7rem 0.2rem;
    max-width: 98vw;
  }
  .disclaimer-title {
    font-size: 0.95rem;
  }
}

/* Smaller Licensing Panels (Overrides) */
.pricing-table-condensed {
  gap: 0.7rem !important;
  margin-top: 1.2rem !important;
}
.pricing-card-condensed {
  padding: 0.8rem 0.5rem !important;
  min-width: 120px !important;
  max-width: 180px !important;
  border-radius: 0.8rem !important;
  transform: translateY(-8px) !important;
  border-color: #00CED1 !important;
}
.pricing-card-condensed:before {
  opacity: 1 !important;
}
.pricing-card-condensed__price {
  font-size: 1.1rem !important;
  margin-bottom: 0.2rem !important;
}
.pricing-card-condensed__price span {
  font-size: 0.85rem !important;
}
.pricing-card-condensed__title {
  font-size: 0.95rem !important;
  margin-bottom: 0.2rem !important;
}
.pricing-card-condensed__description {
  font-size: 0.85rem !important;
  margin-bottom: 0.5rem !important;
  min-height: 20px !important;
}
.pricing-card-condensed__features {
  font-size: 0.85rem !important;
  gap: 0.2rem !important;
}
.pricing-card-condensed__features li {
  font-size: 0.85rem !important;
  margin-bottom: 0.1rem !important;
}
.pricing-card-condensed__features ion-icon {
  font-size: 1rem !important;
}
/* Remove hover effect */
.pricing-card-condensed:hover,
.pricing-card-condensed:hover:before {
  transform: none !important;
  border-color: #00CED1 !important;
  opacity: 1 !important;
}

/* Adjusted Smaller Licensing Panels (15% larger) */
.pricing-table-condensed {
  gap: 0.85rem !important;
  margin-top: 1.4rem !important;
}
.pricing-card-condensed {
  padding: 0.92rem 0.58rem !important;
  min-width: 138px !important;
  max-width: 207px !important;
  border-radius: 0.92rem !important;
  transform: translateY(-8px) !important;
  border-color: #00CED1 !important;
}
.pricing-card-condensed:before {
  opacity: 1 !important;
}
.pricing-card-condensed__price {
  font-size: 1.27rem !important;
  margin-bottom: 0.23rem !important;
}
.pricing-card-condensed__price span {
  font-size: 0.98rem !important;
}
.pricing-card-condensed__title {
  font-size: 1.09rem !important;
  margin-bottom: 0.23rem !important;
}
.pricing-card-condensed__description {
  font-size: 0.98rem !important;
  margin-bottom: 0.58rem !important;
  min-height: 23px !important;
}
.pricing-card-condensed__features {
  font-size: 0.98rem !important;
  gap: 0.23rem !important;
}
.pricing-card-condensed__features li {
  font-size: 0.98rem !important;
  margin-bottom: 0.12rem !important;
}
.pricing-card-condensed__features ion-icon {
  font-size: 1.15rem !important;
}

/* Slightly Smaller Font Sizes for Licensing Panels */
.pricing-card-condensed__price {
  font-size: 1.08rem !important;
}
.pricing-card-condensed__price span {
  font-size: 0.82rem !important;
}
.pricing-card-condensed__title {
  font-size: 0.93rem !important;
}
.pricing-card-condensed__description {
  font-size: 0.82rem !important;
}
.pricing-card-condensed__features {
  font-size: 0.82rem !important;
}
.pricing-card-condensed__features li {
  font-size: 0.82rem !important;
}
.pricing-card-condensed__features ion-icon {
  font-size: 0.95rem !important;
}

/* Force pricing panels to fill container at the very end of the file */
.pricing-table-condensed {
  gap: 1.2rem !important;
  justify-content: center !important;
}
.pricing-card-condensed {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  width: 100% !important;
  padding-left: 2.2rem !important;
  padding-right: 2.2rem !important;
}

/* 1. Token amount and XROSS on same line */
.pricing-card-condensed__price {
  display: flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 0.3em !important;
}
.pricing-card-condensed__price span {
  margin-left: 0 !important;
}

/* 2. Checkmark lines closer to left edge */
.pricing-card-condensed__features {
  padding-left: 0.2rem !important;
  text-align: left !important;
  justify-content: flex-start !important;
}
.pricing-card-condensed__features li {
  margin-left: 0 !important;
  padding-left: 0 !important;
  text-align: left !important;
  justify-content: flex-start !important;
}

/* 3. Center top content */
.pricing-card-condensed__price,
.pricing-card-condensed__title {
  text-align: center !important;
  width: 100%;
  justify-content: center !important;
}
.pricing-card-condensed__title {
  margin-left: auto !important;
  margin-right: auto !important;
}
.pricing-card-condensed {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.pricing-card-condensed__description {
  font-size: 0.7rem !important;
  text-align: center !important;
}
.pricing-card-condensed__features {
  font-size: 0.7rem !important;
}
.pricing-card-condensed__features li {
  font-size: 0.7rem !important;
}
ion-icon[name="close"] {
  color: #FF3B3B !important;
}

@media (max-width: 700px) {
  .mute-float {
    bottom: 1rem !important;
    right: 1rem !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    padding: 0 !important;
  }
  
  .play-btn {
    font-size: 20px;
    cursor: pointer;
    background: none;
    border: none;
    margin: 10px;
    display: inline-flex;
    align-items: center;
    gap: 6px; /* spacing between icon and text */
  }

  .play-btn .icon {
    font-size: 24px;
    vertical-align: middle;
  }
}

/* Custom Bedrock Login Widget Styling - ALL BUTTONS */
.bedrock-login-btn {
    width: 48px !important;
    height: 48px !important;
    border-radius: 8px !important;
    border: 1px solid #d1d5db !important;
    background: transparent !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    font-size: 16px !important;
    color: white !important;
    transition: border-color 0.2s ease !important;
}

.bedrock-login-btn:hover {
    border-color: #00FF7F !important;
}

.bedrock-login-btn svg {
    width: 20px !important;
    height: 20px !important;
    pointer-events: none !important;
}

/* Target wallet button more specifically */
.bedrock-login-btn[data-wallet="true"],
.bedrock-login-btn[data-wallet="true"] *,
.bedrock-login-btn[data-wallet="true"] button,
.bedrock-login-btn[data-wallet="true"] span {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.bedrock-login-btn[data-wallet="true"] {
    width: 100% !important;
    height: auto !important;
    padding: 12px 16px !important;
    gap: 8px !important;
    border: 1px solid #d1d5db !important;
}

.bedrock-login-btn[data-wallet="true"]:hover {
    border-color: #00FF7F !important;
}

/* Force remove all internal borders from wallet button */
.bedrock-login-btn[data-wallet="true"] button,
.bedrock-login-btn[data-wallet="true"] span,
.bedrock-login-btn[data-wallet="true"] div {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* Target wallet button by additional class */
.wallet-btn,
.wallet-btn * {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.wallet-btn {
    width: 100% !important;
    height: auto !important;
    padding: 12px 16px !important;
    gap: 8px !important;
    border: 1px solid #d1d5db !important;
}

.wallet-btn:hover {
    border-color: #00FF7F !important;
}

/* Force all buttons to have borders */
button.bedrock-login-btn {
    border: 1px solid #d1d5db !important;
}

button.bedrock-login-btn:hover {
    border-color: #00FF7F !important;
}

/* Override any Bedrock inline styles */
button[class*="bedrock"] {
    border: 1px solid #d1d5db !important;
}

button[class*="bedrock"]:hover {
    border-color: #00FF7F !important;
}

/* Target ALL buttons in the auth modal */
#bedrock-auth-container button,
.bedrock-auth-modal button {
    border: 1px solid #d1d5db !important;
}

#bedrock-auth-container button:hover,
.bedrock-auth-modal button:hover {
    border-color: #00FF7F !important;
}

/* Force remove any internal borders */
#bedrock-auth-container button *,
.bedrock-auth-modal button * {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* Override any Bedrock default styling */
.bedrock-login-btn * {
    pointer-events: none !important;
}

.bedrock-login-btn:focus {
    outline: none !important;
    box-shadow: none !important;
}

.bedrock-login-btn:disabled {
    opacity: 0.5 !important;
}

/* Goal Stats Styling */
.goal-stat {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.stat-label {
    color: #ffffff;
    min-width: fit-content;
    white-space: nowrap;
}

.stat-value {
    color: #00FF7F;
    flex: 1;
    word-break: break-word;
}

/* Button row styling */
.button-row {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    margin-top: 1rem;
}

.button-row .btn {
    margin: 0;
}

/* Voting System Styles */
.vote-btn.voted {
    background-color: #00FF7F !important;
    color: #000 !important;
    border-color: #00FF7F !important;
}

#connect-wallet-btn.connected {
    background-color: #00FF7F !important;
    color: #000 !important;
    border-color: #00FF7F !important;
}

.vote-btn {
    margin-top: 1rem;
    padding: 0.5rem 1rem;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.vote-btn:hover {
    opacity: 0.8;
}

/* Vote count styling */
[id$="-votes"] {
    margin-top: 0.5rem;
    font-size: 0.8rem;
    color: #888;
}

/* FAQ Modal Styles */
.modal {
    display: none;
    position: fixed;
    z-index: 10000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(5px);
}

.modal-content {
    background-color: var(--raisin-black-1);
    margin: 5% auto;
    padding: 30px;
    border: 2px solid var(--spring-green);
    border-radius: 10px;
    width: 90%;
    max-width: 600px;
    position: relative;
    color: var(--white);
    max-height: 80vh;
    overflow-y: auto;
}

.close {
    color: var(--spring-green);
    float: right;
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    position: absolute;
    top: 15px;
    right: 20px;
}

.close:hover,
.close:focus {
    color: var(--white);
    text-decoration: none;
}

.modal-content h2 {
    color: var(--spring-green);
    font-family: var(--ff-oswald);
    font-size: var(--fs-3);
    text-transform: uppercase;
    margin-bottom: 20px;
    text-align: center;
}

.faq-content h3 {
    color: var(--orange);
    font-family: var(--ff-oswald);
    font-size: var(--fs-4);
    margin-bottom: 15px;
    text-transform: uppercase;
}

.faq-content p {
    color: var(--light-gray);
    font-size: var(--fs-9);
    line-height: 1.8;
    margin-bottom: 15px;
    text-align: justify;
}

.faq-content a {
    color: var(--spring-green);
    text-decoration: none;
}

.faq-content a:hover {
    text-decoration: underline;
}

/* Mobile Responsiveness - Clean Start */
@media (max-width: 768px) {
    /* Only keep navigation mobile styles */
    .navbar {
        width: 100%;
        max-width: 300px;
    }
    
    .navbar-link {
        padding: 15px 25px;
        font-size: 1.1rem;
    }
    
    /* Basic container adjustments */
    .container {
        padding: 0 15px;
    }
    
    /* Basic button text wrapping */
    .btn {
        white-space: normal;
        word-wrap: break-word;
    }
    
    /* Prevent horizontal scrolling */
    body {
        overflow-x: hidden;
    }
    
    /* Basic form element fix */
    input, textarea, select {
        font-size: 16px;
    }
}

/* Heart Button Animation Styles */
.heart-container {
    display: inline-block;
    position: relative;
}

input[type="checkbox"].toggle-heart {
    position: absolute;
    left: -100vw;
    opacity: 0;
}

input[type="checkbox"].toggle-heart:checked + label {
    color: #e2264d;
    filter: none;
    will-change: font-size;
    animation: heart 1s cubic-bezier(.17, .89, .32, 1.49);
}

input[type="checkbox"].toggle-heart:checked + label:before,
input[type="checkbox"].toggle-heart:checked + label:after {
    animation: inherit;
    animation-timing-function: ease-out;
}

input[type="checkbox"].toggle-heart:checked + label:before {
    will-change: transform, border-width, border-color;
    animation-name: bubble;
}

input[type="checkbox"].toggle-heart:checked + label:after {
    will-change: opacity, box-shadow;
    animation-name: sparkles;
}

input[type="checkbox"].toggle-heart:focus + label {
    text-shadow: 0 0 3px white, 
        0 1px 1px white, 0 -1px 1px white, 
        1px 0 1px white, -1px 0 1px white;
}

label[for*="toggle-heart"] {
    align-self: center;
    position: relative;
    color: #888;
    font-size: 2em;
    filter: grayscale(1);
    user-select: none;
    cursor: pointer;
    transition: all 0.3s ease;
}

label[for*="toggle-heart"]:before,
label[for*="toggle-heart"]:after {
    position: absolute;
    z-index: -1;
    top: 50%;
    left: 50%;
    border-radius: 50%;
    content: '';
}

label[for*="toggle-heart"]:before {
    box-sizing: border-box;
    margin: -2.25rem;
    border: solid 2.25rem #e2264d;
    width: 4.5rem;
    height: 4.5rem;
    transform: scale(0);
}

label[for*="toggle-heart"]:after {
    margin: -0.1875rem;
    width: 0.375rem;
    height: 0.375rem;
    box-shadow: 
        2.25rem 2.25rem 0 -0.1875rem hsl(0deg, 100%, 75%),
        -2.25rem 2.25rem 0 -0.1875rem hsl(51.43deg, 100%, 75%),
        2.25rem -2.25rem 0 -0.1875rem hsl(102.86deg, 100%, 75%),
        -2.25rem -2.25rem 0 -0.1875rem hsl(154.29deg, 100%, 75%),
        3.375rem 0rem 0 -0.1875rem hsl(205.71deg, 100%, 75%),
        -3.375rem 0rem 0 -0.1875rem hsl(257.14deg, 100%, 75%),
        0rem 3.375rem 0 -0.1875rem hsl(308.57deg, 100%, 75%),
        0rem -3.375rem 0 -0.1875rem hsl(360deg, 100%, 75%),
        1.125rem 1.125rem 0 -0.1875rem hsl(411.43deg, 100%, 75%),
        -1.125rem 1.125rem 0 -0.1875rem hsl(462.86deg, 100%, 75%),
        1.125rem -1.125rem 0 -0.1875rem hsl(514.29deg, 100%, 75%),
        -1.125rem -1.125rem 0 -0.1875rem hsl(565.71deg, 100%, 75%),
        2.25rem 0rem 0 -0.1875rem hsl(617.14deg, 100%, 75%),
        -2.25rem 0rem 0 -0.1875rem hsl(668.57deg, 100%, 75%),
        0rem 2.25rem 0 -0.1875rem hsl(720deg, 100%, 75%),
        0rem -2.25rem 0 -0.1875rem hsl(771.43deg, 100%, 75%);
}

@keyframes heart {
    0%, 17.5% { 
        font-size: 0; 
    }
}

@keyframes bubble {
    15% { 
        transform: scale(1);
        border-color: #cc8ef5;
        border-width: 2.25rem;
    }
    30%, 100% { 
        transform: scale(1);
        border-color: #cc8ef5;
        border-width: 0;
    }
}

@keyframes sparkles {
    0%, 20% { 
        opacity: 0; 
    }
    25% {
        opacity: 1;
        box-shadow: 
            2.25rem 2.25rem 0 0rem hsl(0deg, 100%, 75%),
            -2.25rem 2.25rem 0 0rem hsl(51.43deg, 100%, 75%),
            2.25rem -2.25rem 0 0rem hsl(102.86deg, 100%, 75%),
            -2.25rem -2.25rem 0 0rem hsl(154.29deg, 100%, 75%),
            3.375rem 0rem 0 0rem hsl(205.71deg, 100%, 75%),
            -3.375rem 0rem 0 0rem hsl(257.14deg, 100%, 75%),
            0rem 3.375rem 0 0rem hsl(308.57deg, 100%, 75%),
            0rem -3.375rem 0 0rem hsl(360deg, 100%, 75%),
            1.125rem 1.125rem 0 0rem hsl(411.43deg, 100%, 75%),
            -1.125rem 1.125rem 0 0rem hsl(462.86deg, 100%, 75%),
            1.125rem -1.125rem 0 0rem hsl(514.29deg, 100%, 75%),
            -1.125rem -1.125rem 0 0rem hsl(565.71deg, 100%, 75%),
            2.25rem 0rem 0 0rem hsl(617.14deg, 100%, 75%),
            -2.25rem 0rem 0 0rem hsl(668.57deg, 100%, 75%),
            0rem 2.25rem 0 0rem hsl(720deg, 100%, 75%),
            0rem -2.25rem 0 0rem hsl(771.43deg, 100%, 75%);
    }
}

/* Heart button when voted */
.heart-container.voted label[for*="toggle-heart"] {
    color: #e2264d;
    filter: none;
}

/* Heart button hover effect */
label[for*="toggle-heart"]:hover {
    transform: scale(1.1);
    filter: brightness(1.2);
}

/* NFT Unlocker Styles */
.nft-display {
    text-align: center;
    margin-bottom: 20px;
}

.nft-display img {
    /* Removed border, shadow, and hover effects */
}

.milestone-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    background: var(--raisin-black-3);
    border: 2px solid var(--spring-green);
    border-radius: 8px;
    padding: 20px;
    color: var(--white);
    z-index: 1000;
    animation: slideIn 0.5s ease-out;
    max-width: 300px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.milestone-content {
    text-align: center;
}

.milestone-content h4 {
    color: var(--spring-green);
    margin-bottom: 10px;
    font-size: 1.1rem;
}

.milestone-content p {
    margin: 8px 0;
    font-size: 0.9rem;
}

.milestone-content img {
    margin: 10px 0;
    border-radius: 4px;
    border: 1px solid var(--spring-green);
}

@keyframes slideIn {
    from { 
        transform: translateX(100%); 
        opacity: 0; 
    }
    to { 
        transform: translateX(0); 
        opacity: 1; 
    }
}

@keyframes slideOut {
    from { 
        transform: translateX(0); 
        opacity: 1; 
    }
    to { 
        transform: translateX(100%); 
        opacity: 0; 
    }
}

/* NFT Progress Bar Special Styling */
#nft-progress {
    background: linear-gradient(90deg, var(--spring-green), #00ff88, var(--spring-green));
    background-size: 200% 100%;
    animation: shimmer 2s ease-in-out infinite;
}

@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Mobile responsiveness for condensed utilization */
@media (max-width: 768px) {
    .custom-services.condensed {
        max-width: 100%;
        padding: 20px 15px;
    }
    
    .custom-services.condensed p {
        max-width: 100%;
        font-size: var(--fs-9);
        line-height: 1.6;
        margin-bottom: 20px;
    }
    
    .custom-services.condensed .placeholder-img-section {
        margin-top: 15px;
    }
}
}

/* Gradient Line Element */
.gradient-line {
    height: 1.5px;
    background-image: linear-gradient(
        90deg,
        rgba(171, 84, 244, 0) 0%,
        rgba(171, 84, 244, 0.5) 25%,
        rgb(255, 255, 255) 50%,
        rgba(171, 84, 244, 0.5) 75%,
        rgba(171, 84, 244, 0) 100%
    );
    border-width: 0px 0px 1px;
    border-style: initial;
    border-color: initial;
    border-image: initial;
    width: 100%;
    opacity: 0.3;
}

/* Text Gradient with Drop Shadow */
.gradient-text {
    color: transparent;
    background-clip: text;
    background-color: var(--chakra-colors-white);
    background-image: linear-gradient(
        rgb(241, 245, 255) 50%,
        rgb(125, 155, 232)
    );
}
.roadmap-section {
  position: relative;
  background: none;
  padding: 60px 0 40px 0;
  min-height: 600px;
}
.roadmap-line {
  position: absolute;
  left: 50%;
  top: 0;
  width: 6px;
  height: 100%;
  background: linear-gradient(
    180deg,
    rgba(171, 84, 244, 0) 0%,
    rgba(127, 204, 237, 0.7) 20%,
    #00cfff 50%,
    rgba(127, 204, 237, 0.7) 80%,
    rgba(171, 84, 244, 0) 100%
  );
  transform: translateX(-50%);
  z-index: 0;
  border-radius: 3px;
  opacity: 1;
}
.roadmap-item {
  width: 50%;
  display: flex;
  justify-content: flex-end;
  margin: 40px 0;
  position: relative;
  z-index: 1;
}
.roadmap-item.right {
  left: 50%;
  justify-content: flex-start;
}
.roadmap-card {
  background: linear-gradient(135deg, #101a2b 80%, #1a233a 100%);
  border: 1.5px solid #00cfff;
  border-radius: 12px;
  box-shadow: 0 4px 32px rgba(0, 207, 255, 0.08);
  padding: 56px 28px 32px 28px;
  min-width: 320px;
  max-width: 420px;
  color: #fff;
  position: relative;
  margin: 0 24px;
  overflow: hidden;
}
.roadmap-status {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0.45em 1.2em 0.45em 2.5em;
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%, 0 0%);
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  z-index: 10;
  border: none;
  border-radius: 0 0 0 8px;
  opacity: 0.98;
  overflow: visible;
}
.roadmap-status::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 0;
  width: 22px;
  height: 100%;
  z-index: -1;
  clip-path: polygon(100% 0, 0 0, 0 100%, 100% 70%);
  background: inherit;
  border-radius: 8px 0 0 0;
}
.roadmap-status.future,
.roadmap-status.future::before { background: linear-gradient(135deg, #2d8fff, #1a5fcc); }
.roadmap-status.active,
.roadmap-status.active::before { background: linear-gradient(135deg, #ffae00, #ff8c00); }
.roadmap-status.completed,
.roadmap-status.completed::before { background: linear-gradient(135deg, #7e03aa, #5a0277); }
.roadmap-status.paused,
.roadmap-status.paused::before { background: linear-gradient(135deg, #ff3b3b, #cc2e2e); }
.roadmap-status.planned,
.roadmap-status.planned::before { background: linear-gradient(135deg, #00cfff, #0099cc); }
.roadmap-status.in-progress,
.roadmap-status.in-progress::before { background: linear-gradient(135deg, #ffa500, #ffd700); }
.roadmap-status.planning,
.roadmap-status.planning::before { background: linear-gradient(135deg, #6c63ff, #4a41cc); }
.roadmap-status.complete,
.roadmap-status.complete::before { background: linear-gradient(135deg, #00ff7f, #00cc66); }

/* Stake Rewards Button Style */
.Btn {
  width: 130px;
  height: 25px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(to right,#77530a,#ffd277,#77530a,#77530a,#ffd277,#77530a);
  background-size: 250%;
  background-position: left;
  color: #ffd277;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition-duration: 1s;
  overflow: hidden;
  clip-path: polygon(
    /* Top-left */ 0% var(--curve-size),
    var(--curve-size) 0,
    /* top-right */ 100% 0,
    100% calc(100% - var(--curve-size)),
    /* bottom-right 1 */ calc(100% - var(--curve-size)) 100%,
    /* bottom-right 2 */ 0 100%);
}

.Btn::before {
  position: absolute;
  content: "STAKE REWARDS";
  color: #ffd277;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 97%;
  height: 90%;
  border-radius: 8px;
  transition-duration: 1s;
  background-color: rgba(0, 0, 0, 0.842);
  background-size: 200%;
  font-size: 80%;
    clip-path: polygon(
    /* Top-left */ 0% var(--curve-size),
    var(--curve-size) 0,
    /* top-right */ 100% 0,
    100% calc(100% - var(--curve-size)),
    /* bottom-right 1 */ calc(100% - var(--curve-size)) 100%,
    /* bottom-right 2 */ 0 100%
  );
}

/* Card Container Styles for Token Section */
.card {
  --white: hsl(0, 0%, 100%);
  --black: hsl(240, 15%, 9%);
  --paragraph: hsl(0, 0%, 83%);
  --line: hsl(240, 9%, 17%);
  --primary: hsl(266, 92%, 58%);

  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem;
  width: 100%;
  background-color: hsla(240, 15%, 9%, 1);
  background-image: radial-gradient(
      at 88% 40%,
      hsla(240, 15%, 9%, 1) 0px,
      transparent 85%
    ),
    radial-gradient(at 49% 30%, hsla(240, 15%, 9%, 1) 0px, transparent 85%),
    radial-gradient(at 14% 26%, hsla(240, 15%, 9%, 1) 0px, transparent 85%),
    radial-gradient(at 0% 64%, hsla(200, 93%, 56%, 1) 0px, transparent 85%),
    radial-gradient(at 41% 94%, hsla(284, 100%, 84%, 1) 0px, transparent 85%),
    radial-gradient(at 100% 99%, hsla(306, 100%, 57%, 1) 0px, transparent 85%);
  border-radius: 1rem;
  box-shadow: 0px -16px 24px 0px rgba(255, 255, 255, 0.25) inset;
  margin-bottom: 2rem;
  /* Ensure card expands to fit content */
  min-height: fit-content;
  overflow: visible;
}

/* Fix iframe overflow issues within cards */
.card iframe {
  max-width: 100%;
  height: auto;
  min-height: 400px;
  border: none;
  border-radius: 0.5rem;
  overflow: hidden;
}

/* Ensure iframe containers don't overflow */
.card #dexscreener-embed,
.card #geckoterminal-embed {
  max-width: 100%;
  border-radius: 0.5rem;
}

/* Ensure traditional-options content is properly contained */
.traditional-options {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100%;
  overflow: hidden;
}

/* Ensure token-info section is properly contained */
.token-info {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100%;
  overflow: hidden;
}

.card .card__border {
  overflow: hidden;
  pointer-events: none;
  position: absolute;
  z-index: -10;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  background-image: linear-gradient(
    0deg,
    hsl(0, 0%, 100%) -50%,
    hsl(0, 0%, 40%) 100%
  );
  border-radius: 1rem;
}
.card .card__border::before {
  content: "";
  pointer-events: none;
  position: absolute;
  z-index: 200;
  top: 50%;
  left: 50%;
  width: 300%;
  height: 10rem;
  background-image: linear-gradient(
    0deg,
    hsla(0, 0%, 100%, 0) 0%,
    hsl(277, 95%, 60%) 40%,
    hsl(277, 95%, 60%) 60%,
    hsla(0, 0%, 40%, 0) 100%
  );
  transform: translate(-50%, -50%) rotate(0deg);
  transform-origin: center center;
  animation: rotate 8s linear infinite;
  pointer-events: none;
}

@keyframes rotate {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
.traditional-options, #wallet-section {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.roadmap-title {
  color: #00cfff;
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 10px;
  letter-spacing: 1px;
  margin-top: 0px;
}
.roadmap-desc {
  color: #cfd8e3;
  font-size: 1rem;
  margin-bottom: 18px;
}
.roadmap-stats {
  display: flex;
  gap: 18px;
  font-size: 0.95rem;
  color: #b0b8c9;
  margin-top: 10px;
}
.roadmap-img {
  width: 100px;
  height: auto;
  border-radius: 8px;
  margin-bottom: 12px;
  float: right;
  box-shadow: 0 2px 12px rgba(0, 207, 255, 0.12);
}
@media (max-width: 900px) {
  .roadmap-item, .roadmap-item.right {
    width: 100%;
    justify-content: center;
    left: 0;
    margin: 32px 0;
  }
  .roadmap-line {
    left: 24px;
  }
  .roadmap-card {
    min-width: 0;
    max-width: 98vw;
    margin: 0 0 0 32px;
  }
}

/* Stake Rewards List Styles */
.stake-rewards-list {
  margin-top: 8px;
  margin-left: 8px;
}

.reward-tier {
  font-size: 0.85rem;
  color: var(--light-gray);
  line-height: 1.4;
  margin-bottom: 2px;
  position: relative;
  padding-left: 12px;
}

.reward-tier:before {
  content: "•";
  position: absolute;
  left: 0;
    color: var(--spring-green);
  font-weight: bold;
}

.reward-tier:last-child {
  margin-bottom: 0;
}

.reward-tier:not(:last-child) {
  color: var(--white);
  font-weight: 500;
}

.reward-includes {
  color: var(--spring-green);
  font-size: 0.75rem;
  font-weight: bold;
  opacity: 1;
  display: inline-block;
  margin-left: 4px;
  vertical-align: middle;
}

/* Stake Legend Styles */
.legend-compact {
  max-width: 800px;
  margin: 0 auto 40px auto;
  text-align: center;
  background: radial-gradient(
    48.28% 48.28% at 49.66% 100%,
    rgba(233, 0, 131, 0.1) 0%,
    rgba(29, 14, 32, 0.1) 100%
  ),
  hsl(234deg 14% 14% / 63%);
  border: 1px solid var(--raisin-black-3);
  border-radius: 8px;
  box-shadow: 0px -1px 0px 0px var(--raisin-black-3), 0 8px 16px -8px rgba(233, 0, 131, 0.3);
  padding: 20px;
  position: relative;
}

.legend-compact::before {
  content: '';
  position: absolute;
  background: linear-gradient(
    to right,
    transparent 0%,
    rgba(255, 156, 228, 0.3) 25%,
    var(--spring-green) 50%,
    rgba(255, 156, 228, 0.3) 75%,
    transparent 100%
  );
  left: 0;
  right: 0;
  bottom: -1px;
  margin: 0 auto;
  height: 1px;
  width: 80%;
  border-radius: 0 0 8px 8px;
}

.tier-key {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
    margin-bottom: 15px;
}

.key-item {
  color: var(--light-gray);
  font-size: var(--fs-9);
  line-height: 1.4;
}

.key-item strong {
  color: var(--spring-green);
}

.example-compact {
  margin-top: 10px;
}

.example-text {
  color: var(--orange);
  font-size: var(--fs-8);
  font-style: italic;
}

@media (max-width: 768px) {
  .tier-key {
    flex-direction: column;
    gap: 8px;
  }
  
  .key-item {
    font-size: var(--fs-8);
  }
}

/* Music Notification Bar */
.music-notification {
    position: fixed;
    bottom: 20px;
    right: 80px; /* Position next to mute button */
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(10px);
    border-radius: 8px;
    padding: 8px 12px;
    color: white;
    font-family: 'Poppins', sans-serif;
    z-index: 1000;
    opacity: 0;
    transform: translateX(100%);
    transition: all 0.5s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.music-notification.show {
    opacity: 1;
    transform: translateX(0);
}

.music-notification-content {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.music-ost {
    font-size: 10px;
    color: #CCCCCC;
    opacity: 0.8;
    font-style: italic;
}

.music-title {
    font-weight: 600;
    font-size: 14px;
    color: #00FF7F;
}

.music-artist {
    font-size: 12px;
    color: #CCCCCC;
    opacity: 0.8;
}

.music-artist a {
    color: #00FF7F;
    text-decoration: none;
    transition: color 0.3s ease;
}

.music-artist a:hover {
    color: #00CC66;
    text-decoration: underline;
}

/* Ensure links in roadmap descriptions flow inline */
.roadmap-desc a {
    display: inline;
    white-space: nowrap;
    word-break: keep-all;
}

/* Comprehensive Mobile Responsiveness Fixes */
@media (max-width: 768px) {
    /* Basic mobile fixes */
    .container {
        padding: 0 15px;
        max-width: 100%;
    }
    
    /* Typography scaling */
    :root {
        --fs-1: 36px;
        --fs-2: 24px;
        --fs-3: 20px;
        --fs-4: 18px;
        --fs-5: 16px;
        --fs-6: 14px;
        --fs-7: 13px;
        --fs-8: 12px;
        --fs-9: 11px;
        --fs-10: 10px;
        --fs-11: 9px;
    }
    
    /* Fix Login Button - Mobile Only */
    .btn-sign-in {
        background: var(--raisin-black-2) !important;
        color: var(--white) !important;
        border: 1px solid var(--raisin-black-3) !important;
        padding: 8px 16px !important;
        font-size: 14px !important;
        border-radius: 4px !important;
    }
    
    .btn-sign-in:hover {
        background: var(--raisin-black-3) !important;
        color: var(--spring-green) !important;
    }
    
    /* Remove door icon from login button on mobile */
    .btn-sign-in .icon-box,
    .btn-sign-in ion-icon,
    .btn-sign-in svg {
        display: none !important;
    }
    
    /* Fix Hero Section - Reduce Gap */
    .hero {
        margin-top: 0 !important;
        padding: 20px 0 !important;
    }
    
    /* Video container padding for mobile */
    .video-container {
        padding-top: 100px !important;
    }
    
    /* Header padding for mobile */
    .header {
        padding-block: 0px !important;
    }
    
    /* Fix Mute/Play Button - Match Web Version Exactly */
    .mute-float {
        position: fixed !important;
        z-index: 1002 !important;
        bottom: 2rem !important;
        right: 2rem !important;
        width: 50px !important;
        height: 50px !important;
        background: rgba(0, 206, 209, 0.2) !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        border: 2px solid var(--orange) !important;
        cursor: pointer !important;
        transition: all 0.3s ease !important;
        backdrop-filter: blur(10px) !important;
    }
    
    .mute-float:hover {
        background: rgba(0, 206, 209, 0.4) !important;
        transform: scale(1.1) !important;
    }
    
    .mute-float ul {
        list-style: none !important;
        padding: 0 !important;
        margin: 0 !important;
        display: flex !important;
        gap: 2px !important;
        align-items: end !important;
    }
    
    .mute-float li {
        display: inline-block !important;
    }
    
    .mute-float li span {
        display: block !important;
        width: 3px !important;
        background-color: var(--orange) !important;
        border-radius: 1px !important;
        animation: soundbar 1s ease-in-out infinite alternate !important;
    }
    
    /* Individual bar heights and timing exactly like web version */
    .mute-float li:nth-child(1) span { 
        height: 10px !important;
        animation-duration: 1.1s !important;
        animation-delay: 0s !important;
    }
    .mute-float li:nth-child(2) span { 
        height: 12px !important;
        animation-duration: 1.2s !important;
        animation-delay: 0.1s !important;
    }
    .mute-float li:nth-child(3) span { 
        height: 14px !important;
        animation-duration: 1.3s !important;
        animation-delay: 0.2s !important;
    }
    .mute-float li:nth-child(4) span { 
        height: 16px !important;
        animation-duration: 1.4s !important;
        animation-delay: 0.3s !important;
    }
    .mute-float li:nth-child(5) span { 
        height: 18px !important;
        animation-duration: 1.5s !important;
        animation-delay: 0.4s !important;
    }
    
    @keyframes soundbar {
        0% { 
            opacity: 0.3; 
            transform: scaleY(0.3);
        }
        100% { 
            opacity: 1; 
            transform: scaleY(1);
        }
    }
    
    /* Muted state - static pink bars */
    .mute-float.muted li span {
        animation: none !important;
        background-color: #ff4081 !important;
        opacity: 0.6 !important;
        transform: scaleY(0.3) !important;
    }
    
    /* Fix Utilization Section - Copy Web Backgrounds */
    .utilization-container {
        box-shadow: 0px 0.5rem 0.5rem rgba(171, 84, 244, 0.16) !important;
        border-radius: 7px !important;
        padding: 0.6rem 0.7rem !important;
        color: var(--white) !important;
        border-width: var(--card-border-width, 0) !important;
        border-color: var(--card-border-color) !important;
        background-image: linear-gradient(rgb(127 204 237 / 0%), rgba(161, 104, 255, 0.31)) !important;
        border-style: solid !important;
        margin: 20px 0 !important;
    }
    
    .utilization-container h2 {
        margin-top: 0 !important;
        margin-bottom: 20px !important;
        font-size: 24px !important;
        color: var(--white) !important;
    }
    
    .utilization-container p {
        color: var(--white) !important;
        font-size: 14px !important;
        line-height: 1.6 !important;
        margin-bottom: 20px !important;
    }
    
    /* Fix Token Section Text Colors */
    .token-section {
        color: var(--white) !important;
    }
    
    .token-section h2,
    .token-section h3,
    .token-section h4 {
        color: var(--white) !important;
    }
    
    .token-section p {
        color: var(--white) !important;
    }
    
    .token-details h4 {
        color: var(--white) !important;
    }
    
    .token-details p {
        color: var(--white) !important;
    }
    
    .token-details strong {
        color: var(--spring-green) !important;
    }
    
    /* Fix Queen's Order Text Colors */
    .legend-compact {
        color: var(--white) !important;
    }
    
    .legend-compact p {
        color: var(--white) !important;
    }
    
    .legend-compact span {
        color: var(--white) !important;
    }
    
    /* Fix Custom Services Section */
    .custom-services {
        color: var(--white) !important;
    }
    
    .custom-services .section-title {
        color: var(--white) !important;
        text-align: center !important;
        margin-bottom: 20px !important;
    }
    
    .custom-services p {
        color: var(--white) !important;
        text-align: left !important;
        line-height: 1.6 !important;
        margin-bottom: 15px !important;
        font-size: 14px !important;
    }
    
    .custom-services a {
        color: #FF8C00 !important;
        text-decoration: none !important;
        font-weight: 600 !important;
        display: inline !important;
        white-space: nowrap !important;
        word-break: keep-all !important;
    }
    
    .custom-services a:hover {
        color: var(--spring-green) !important;
        text-decoration: underline !important;
    }
    
    /* Fix all links in avatar section to be orange */
    .custom-services a,
    .custom-services .orange-link,
    .custom-services span[style*="blue"],
    .custom-services span[style*="light-blue"],
    .custom-services span[style*="light blue"],
    .custom-services span[style*="cyan"],
    .custom-services span[style*="blue"] {
        color: #FF8C00 !important;
    }
    
    /* Override any inline styles for links */
    .custom-services span[style*="color"] {
        color: #FF8C00 !important;
    }
    
    /* Fix hyperlinks breaking into new lines */
    .custom-services a {
        display: inline !important;
        white-space: nowrap !important;
        word-break: keep-all !important;
    }
    
    /* Force all colored text in custom services to be orange */
    .custom-services *[style*="color"] {
        color: #FF8C00 !important;
    }
    
    /* Copy Custom Services Form Style for Mobile */
    .custom-services .form {
        background: var(--raisin-black-1) !important;
        padding: 25px 20px !important;
        border-radius: 8px !important;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3) !important;
        margin: 20px 0 !important;
        text-align: center !important;
    }
    
    .custom-services .form input,
    .custom-services .form textarea,
    .custom-services .form select {
        background: var(--raisin-black-2) !important;
        border: 1px solid var(--raisin-black-3) !important;
        color: var(--white) !important;
        font-size: 16px !important;
        padding: 12px 15px !important;
        margin-bottom: 15px !important;
        border-radius: 4px !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    
    .custom-services .form input:focus,
    .custom-services .form textarea:focus,
    .custom-services .form select:focus {
        border-color: var(--spring-green) !important;
        outline: none !important;
        box-shadow: 0 0 0 2px rgba(0, 255, 127, 0.2) !important;
    }
    
    .custom-services .form label {
        color: var(--white) !important;
        font-size: 14px !important;
        margin-bottom: 8px !important;
        font-weight: 500 !important;
        text-align: left !important;
        display: block !important;
    }
    
    /* Center the request button */
    .custom-services .form .btn-primary {
        margin: 0 auto !important;
        display: block !important;
        width: auto !important;
        min-width: 200px !important;
    }
    
    /* Fix checkbox alignment */
    .custom-services .form label.deposit-disclaimer {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        text-align: left !important;
        margin-bottom: 15px !important;
    }
    
    .custom-services .form label.deposit-disclaimer input[type="checkbox"] {
        margin: 0 !important;
        flex-shrink: 0 !important;
        width: auto !important;
    }
    
    /* Move description label above textarea */
    .custom-services .form label[for="description"] {
        order: -1 !important;
        margin-bottom: 8px !important;
    }
    
    .custom-services .form textarea {
        margin-top: 0 !important;
        min-height: 100px !important;
    }
    
    /* Copy Contact Section Form Style for Mobile */
    .contact-section .form {
        background: var(--raisin-black-1) !important;
        padding: 25px 20px !important;
        border-radius: 8px !important;
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3) !important;
        margin: 20px 0 !important;
        text-align: center !important;
    }
    
    .contact-section .form input,
    .contact-section .form textarea {
        background: var(--raisin-black-2) !important;
        border: 1px solid var(--raisin-black-3) !important;
        color: var(--white) !important;
        font-size: 16px !important;
        padding: 12px 15px !important;
        margin-bottom: 15px !important;
        border-radius: 4px !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    
    .contact-section .form input:focus,
    .contact-section .form textarea:focus {
        border-color: var(--spring-green) !important;
        outline: none !important;
        box-shadow: 0 0 0 2px rgba(0, 255, 127, 0.2) !important;
    }
    
    .contact-section .form label {
        color: var(--white) !important;
        font-size: 14px !important;
        margin-bottom: 8px !important;
        font-weight: 500 !important;
        text-align: left !important;
        display: block !important;
    }
    
    /* Center the send message button */
    .contact-section .form .btn-primary {
        margin: 0 auto !important;
        display: block !important;
        width: auto !important;
        min-width: 200px !important;
    }
    
    /* Move message label above textarea */
    .contact-section .form label[for="message"] {
        order: -1 !important;
        margin-bottom: 8px !important;
    }
    
    .contact-section .form textarea {
        margin-top: 0 !important;
        min-height: 100px !important;
    }
    
    /* Button improvements */
    .btn {
        padding: 12px 20px;
        font-size: 14px;
        white-space: normal;
        word-wrap: break-word;
        min-height: 44px;
    display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .button-row {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
    
    .button-row .btn {
        width: 100%;
        margin: 0;
    }
    
    /* Navigation fixes */
    .navbar {
        width: 100%;
        max-width: 300px;
        padding: 20px;
    }
    
    .navbar-link {
        padding: 15px 25px;
        font-size: 16px;
    text-align: center;
    }
    
    /* Roadmap improvements */
    .roadmap-item, .roadmap-item.right {
        width: 100%;
        justify-content: center;
        left: 0;
        margin: 20px 0;
    }
    
    .roadmap-card {
        min-width: 0;
        max-width: 100%;
        margin: 0;
        padding: 20px;
    }
    
    .roadmap-title {
        font-size: 18px;
        line-height: 1.3;
        margin-bottom: 15px;
    }
    
    .roadmap-desc {
        font-size: 14px;
    line-height: 1.6;
        margin-bottom: 15px;
    }
    
    .roadmap-img {
        max-width: 100%;
        height: auto;
        margin: 15px 0;
    }
    
        /* Slideshow improvements */
    .slideshow-container {
        max-width: 100%;
        height: 250px;
        margin: 20px auto 30px auto;
        position: relative;
        z-index: 1;
    }
    
    .mySlides {
        width: 100% !important;
        height: 100% !important;
        position: relative !important;
    }
    
    .mySlides img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        object-position: center !important;
        display: block !important;
    }
    
    .prev, .next {
        font-size: 18px;
        padding: 8px 12px;
        z-index: 999 !important;
        position: absolute !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        background: rgba(0, 0, 0, 0.7) !important;
        color: white !important;
        border: none !important;
        border-radius: 4px !important;
        cursor: pointer !important;
    }
    
    .prev {
        left: 10px !important;
    }
    
    .next {
        right: 10px !important;
    }
    
    .text {
    font-size: 14px;
        padding: 8px 12px;
        position: relative;
        z-index: 5;
    }
    
    .numbertext {
        font-size: 12px;
        padding: 8px 12px;
    position: relative;
        z-index: 5;
    }
    
    /* Fix slideshow overlapping text */
    .custom-services .slideshow-container {
        margin-bottom: 60px !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    .custom-services .slideshow-container + p,
    .custom-services .slideshow-container + div,
    .custom-services .slideshow-container ~ p {
        margin-top: 40px !important;
        position: relative !important;
        z-index: 1 !important;
        clear: both !important;
    }
    
    /* Ensure text below slideshow doesn't overlap */
    .custom-services p {
        margin-top: 20px !important;
        position: relative !important;
        z-index: 1 !important;
        clear: both !important;
    }
    
    /* Force proper spacing after slideshow */
    .slideshow-container + * {
        margin-top: 30px !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    /* Music notification positioning */
    .music-notification {
        bottom: 10px;
        right: 10px;
        left: 10px;
        max-width: calc(100% - 20px);
    }
    
    .music-notification-content {
        flex-direction: column;
        gap: 4px;
        text-align: center;
    }
    
    /* Hero section */
    .hero-title {
        font-size: 28px;
        margin-bottom: 15px;
    }
    
    .hero-subtitle {
        font-size: 16px;
        letter-spacing: 8px;
    }
    
    /* About section */
    .about {
        padding: 60px 0;
    }
    
    .about-content {
        padding: 25px 15px;
    }
    
    .about-title {
        font-size: 22px;
        margin-bottom: 15px;
    }
    
    .about-text {
        font-size: 14px;
        line-height: 1.6;
    }
    
    /* Tournament section */
    .tournament {
        padding: 40px 0;
    }
    
    .tournament-text {
        font-size: 14px;
        line-height: 1.6;
        margin-bottom: 20px;
    }
    
    /* Footer improvements */
    .footer-top {
        padding: 20px 0 5px 0 !important;
    }
    
    .footer-menu-list {
        flex-direction: column;
        gap: 10px;
        text-align: center;
    }
    
    .footer-input-wrapper {
        max-width: 100%;
        margin: 20px auto;
    }
    
    /* Remove bottom padding from footer */
    .footer-bottom {
        padding: 5px 0 0 0 !important;
    }
    
    .footer {
        padding-bottom: 0 !important;
    }
    
    /* Modal improvements */
    .modal-content {
        width: 95%;
        max-width: 400px;
        margin: 20px auto;
        padding: 20px;
    }
    
    .modal-content h2 {
        font-size: 20px;
        margin-bottom: 15px;
    }
    
    .faq-content h3 {
        font-size: 16px;
        margin-bottom: 10px;
    }
    
    .faq-content p {
        font-size: 14px;
        line-height: 1.5;
    }
    
    /* Prevent horizontal scrolling */
    body {
        overflow-x: hidden;
        width: 100%;
    }
    
    /* Image responsiveness */
    img {
        max-width: 100%;
        height: auto;
    }
    
    /* Prevent zoom on input focus */
    input, textarea, select {
        font-size: 16px;
        max-width: 100%;
    }
    
    /* Heart button sizing */
    label[for*="toggle-heart"] {
        font-size: 1.5em;
    }
    
    /* Fix heart button on mobile - completely hide checkbox and use only label */
    input[type="checkbox"].toggle-heart {
        display: none !important;
        opacity: 0 !important;
        position: absolute !important;
        left: -9999px !important;
        pointer-events: none !important;
        visibility: hidden !important;
    }
    
    /* Ensure heart button works like web version */
    .heart-container {
        position: relative !important;
        display: inline-block !important;
    }
    
    .heart-container label[for*="toggle-heart"] {
        cursor: pointer !important;
        display: inline-block !important;
        position: relative !important;
        color: #666 !important;
        font-size: 1.5em !important;
        transition: all 0.3s ease !important;
    }
    
    /* Hide the original heart content and use pseudo-element */
    .heart-container label[for*="toggle-heart"] {
        color: transparent !important;
    }
    
    .heart-container label[for*="toggle-heart"]:before {
        content: "♡" !important;
        color: #666 !important;
        font-size: 1.5em !important;
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        transition: all 0.3s ease !important;
    }
    
    /* Only show filled heart when checked */
    input[type="checkbox"].toggle-heart:checked + label[for*="toggle-heart"]:before {
        content: "♥" !important;
        color: #ff4081 !important;
    }
    
    /* Remove any default activated state */
    .heart-container.voted label[for*="toggle-heart"]:before {
        content: "♡" !important;
        color: #666 !important;
    }
    
    /* Play button improvements */
    .play-btn {
        padding: 10px 15px;
        font-size: 12px;
        margin: 5px;
    }
    
    .play-btn .icon {
        font-size: 12px;
    }
}

/* Extra small devices */
@media (max-width: 480px) {
    :root {
        --fs-1: 28px;
        --fs-2: 20px;
        --fs-3: 18px;
        --fs-4: 16px;
        --fs-5: 14px;
        --fs-6: 13px;
        --fs-7: 12px;
        --fs-8: 11px;
        --fs-9: 10px;
        --fs-10: 9px;
        --fs-11: 8px;
    }
    
    .container {
        padding: 0 10px;
    }
    
    .btn {
        padding: 10px 15px;
        font-size: 13px;
    }
    
    .roadmap-card {
        padding: 15px;
    }
    
    .slideshow-container {
        height: 200px;
    }
    
    .music-notification {
        bottom: 5px;
        right: 5px;
        left: 5px;
        padding: 8px 10px;
    }
    
    .mute-float {
        width: 40px;
        height: 40px;
    }
    
    .hero-title {
        font-size: 24px;
    }
    
    .hero-subtitle {
        font-size: 14px;
        letter-spacing: 4px;
    }
}

/* Landscape orientation fixes */
@media (max-width: 768px) and (orientation: landscape) {
    .hero {
        margin-top: 60px;
        padding: 20px 0;
    }
    
    .about {
        padding: 40px 0;
    }
    
    .tournament {
        padding: 30px 0;
    }
    
    .slideshow-container {
        height: 180px;
    }
}

/* Fix text alignment for wallet buttons */
#connect-wallet,
#disconnect-wallet,
#disconnect-wallet-traditional,
#wallet-btn,
.btn[data-action="connect-wallet"] {
    text-align: center !important;
    display: inline-grid !important; 
    place-content: center !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
    vertical-align: middle !important;
}

/* Footer Styles */
.footer-top {
    padding: 0;
    background: var(--raisin-black-3);
}

.footer-brand-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin: 20px 0;
}

.footer-brand-wrapper .copyright {
    color: var(--white);
    font-size: 14px;
    margin: 0;
}

.footer-brand-wrapper .footer-social-link {
    color: var(--spring-green);
    font-size: 20px;
}

.footer-logo {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.logo-icon {
    font-size: 20px;
    color: var(--light-gray);
}

.logo-text {
    color: var(--white);
    font-size: 18px;
    font-weight: bold;
}

.footer-divider {
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--orange), transparent);
    margin: 0;
}

.footer-bottom {
    padding: 30px 0;
    background: var(--raisin-black-3);
}

.footer-bottom .container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.footer-menu-list {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
}

.footer-menu-link {
    color: var(--white);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    transition: color 0.3s ease;
}

.footer-menu-link:hover {
    color: var(--spring-green);
}

.footer-social {
    margin: 20px 0;
}

.footer-social-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: var(--raisin-black-2);
    border-radius: 50%;
    color: var(--white);
    font-size: 24px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.footer-social-button:hover {
    background: var(--spring-green);
    color: var(--raisin-black-1);
    transform: scale(1.1);
}

.copyright-bottom {
    color: var(--white);
    font-size: 14px;
    margin: 0;
    text-align: center;
}

/* Banner Submission Section */
#banner-submission {
    padding: var(--section-padding) 0;
}

#banner-submission .form {
    max-width: 800px;
    margin: 0 auto;
}

#banner-submission label {
    display: block;
    margin-bottom: 15px;
    color: var(--white);
    font-weight: var(--fw-500);
}

#banner-submission input[type="text"],
#banner-submission input[type="email"],
#banner-submission textarea {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid var(--orange);
    border-radius: 5px;
    background: var(--raisin-black-2);
    color: var(--white);
    font-size: var(--fs-9);
    transition: border-color var(--transition-1);
}

#banner-submission input[type="text"]:focus,
#banner-submission input[type="email"]:focus,
#banner-submission textarea:focus {
    outline: none;
    border-color: var(--spring-green);
}

#banner-submission textarea {
    min-height: 100px;
    resize: vertical;
}

#banner-submission input[type="file"] {
    border: 2px dashed var(--orange);
    padding: 20px;
    text-align: center;
    background: var(--raisin-black-2);
    color: var(--white);
    cursor: pointer;
}

#banner-submission input[type="file"]:hover {
    border-color: var(--spring-green);
}

#banner-submission small {
    display: block;
    margin-top: 5px;
    color: var(--light-gray);
    font-size: var(--fs-10);
}

#banner-submission .deposit-disclaimer {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 20px;
    color: var(--white);
    font-size: var(--fs-9);
    line-height: 1.6;
}

#banner-submission .deposit-disclaimer input[type="checkbox"] {
    width: auto;
    margin-top: 3px;
}

#banner-submission .btn {
    margin-top: 20px;
}

/* Guidelines Modal */
#guidelines-modal {
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: none;
    justify-content: center;
    align-items: center;
}

#guidelines-modal.show {
    display: flex;
}

#guidelines-modal .form-popup-content {
    background: var(--raisin-black-1);
    border: 2px solid var(--spring-green);
    border-radius: 10px;
    padding: 30px;
    max-width: 700px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    position: relative;
    color: var(--white);
}

#guidelines-modal h3 {
    color: var(--spring-green);
    font-family: var(--ff-oswald);
    font-size: var(--fs-3);
    text-transform: uppercase;
    margin-bottom: 20px;
    text-align: center;
}

#guidelines-modal h4 {
    color: var(--orange);
    font-family: var(--ff-oswald);
    font-size: var(--fs-4);
    margin-bottom: 15px;
    text-transform: uppercase;
}

#guidelines-modal p {
    color: var(--light-gray);
    font-size: var(--fs-9);
    line-height: 1.8;
    margin-bottom: 15px;
    text-align: justify;
}

#guidelines-modal ul {
    margin-left: 20px;
    margin-bottom: 15px;
}

#guidelines-modal li {
    color: var(--light-gray);
    font-size: var(--fs-9);
    line-height: 1.6;
    margin-bottom: 8px;
}

#guidelines-modal a {
    color: var(--spring-green);
    text-decoration: none;
}

#guidelines-modal a:hover {
    text-decoration: underline;
}

/* Form Popup Modal */
.form-popup {
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: flex;
    justify-content: center;
    align-items: center;
}

.form-popup-content {
    background: var(--raisin-black-3);
    border: 2px solid var(--orange);
    border-radius: 10px;
    padding: 30px;
    max-width: 500px;
    width: 90%;
    position: relative;
    text-align: center;
    color: var(--white);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

.form-popup-close {
    position: absolute;
    top: 10px;
    right: 15px;
    color: var(--orange);
    font-size: 28px;
    font-weight: bold;
    cursor: pointer;
    line-height: 1;
}

.form-popup-close:hover {
    color: var(--spring-green);
}

#form-popup-message {
    font-size: 16px;
    line-height: 1.5;
    margin-top: 10px;
}

.form-popup.success .form-popup-content {
    border-color: var(--spring-green);
}

.form-popup.error .form-popup-content {
    border-color: #ff4444;
}

.form-popup.success #form-popup-message {
    color: var(--spring-green);
}

.form-popup.error #form-popup-message {
    color: #ff4444;
}

/* Ensure button text is properly centered */
.btn {
    text-align: center !important;
   /*  display: inline-grid !important;  */
    place-content: center !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Fix for any button with wallet-related classes */
[class*="wallet"] {
    text-align: center !important;
    display: inline-grid !important;
    place-content: center !important;
}

/* Override for Add to MetaMask button to display icon inline with text */
#add-to-metamask-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: row !important;
    gap: 8px !important;
}

#add-to-metamask-btn img {
    display: inline-block !important;
    flex-shrink: 0 !important;
}

/* Cookie Consent Banner */
.cookie-consent {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--raisin-black-3);
    border-top: 2px solid var(--orange);
    z-index: 10000;
    padding: 20px 0;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3);
}

.cookie-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.cookie-text {
    flex: 1;
    min-width: 300px;
}

.cookie-text h3 {
    color: var(--spring-green);
    margin: 0 0 10px 0;
    font-size: 18px;
}

.cookie-text p {
    color: var(--white);
    margin: 0 0 15px 0;
    line-height: 1.5;
    font-size: 14px;
}

.cookie-details {
    margin-top: 10px;
}

.cookie-details details {
    color: var(--light-gray);
    font-size: 13px;
}

.cookie-details summary {
    cursor: pointer;
    color: var(--orange);
    font-weight: bold;
    margin-bottom: 8px;
}

.cookie-details summary:hover {
    color: var(--spring-green);
}

.cookie-details ul {
    margin: 8px 0 0 0;
    padding-left: 20px;
}

.cookie-details li {
    margin-bottom: 5px;
    line-height: 1.4;
}

.cookie-buttons {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}

.cookie-btn {
    padding: 10px 20px;
    border: none;
    border-radius: 5px;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 14px;
}

.cookie-btn.accept {
    background: var(--spring-green);
    color: var(--raisin-black-1);
}

.cookie-btn.accept:hover {
    background: #00cc66;
    transform: translateY(-2px);
}

.cookie-btn.reject {
    background: transparent;
    color: var(--light-gray);
    border: 1px solid var(--light-gray);
}

.cookie-btn.reject:hover {
    background: var(--raisin-black-2);
    color: var(--white);
    border-color: var(--orange);
}

/* Responsive design for cookie banner */
@media (max-width: 768px) {
    .cookie-content {
        flex-direction: column;
        text-align: center;
    }
    
    .cookie-text {
        min-width: auto;
    }
    
    .cookie-buttons {
        width: 100%;
        justify-content: center;
    }
    
    .cookie-btn {
        flex: 1;
        max-width: 150px;
    }
}

/* Hide Bedrock Passport separator line */
[data-orientation="horizontal"][role="none"] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
}

/* Crystal Balance Display */
.crystal-balance-display {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 1000;
    display: none;
}

.crystal-balance-container {
    background: url('VIBE_BAL.png') no-repeat center center;
    background-size: contain;
    width: 235px;
    height: 114px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin: 25px;
}

.crystal-balance-text {
    text-align: center;
    color: var(--white);
    font-weight: bold;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
    padding-left: 30px;
    padding-top: 15px;
}

#crystalBalanceAmount {
    font-size: 20px;
    color: var(--spring-green);
    text-shadow: 0 0 1px var(--spring-green);
}

.crystal-label {
    font-size: 12px;
    color: var(--white);
    display: block;
    margin-top: -5px;
}

/* Avatar Redemption Styles - Matching existing design */
.avatar-redemption {
    padding: var(--section-padding) 0;
    background: transparent;
}

.avatars-grid {
    display: grid;
    gap: 15px;
    max-width: 1200px;
    margin: 0 auto;
    grid-template-columns: repeat(4, 1fr);
}

.avatar-card {
    background: radial-gradient(    48.28% 48.28% at 49.66% 100%,    rgba(233, 0, 131, 0.1) 0%,    rgba(29, 14, 32, 0.1) 100%  ),  hsl(234deg 14% 14% / 63%);
    border: 1.5px solid #32333a;
    border-radius: 18px;
    padding: 15px 12px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 0;
    position: relative;
}

.avatar-card:hover {
    border-color: var(--spring-green);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(0, 255, 127, 0.15);
}

.avatar-name {
    color: var(--white);
    font-family: var(--ff-oswald);
    text-transform: uppercase;
    margin-bottom: 8px;
    font-size: 1rem;
    letter-spacing: 1px;
    font-weight: var(--fw-700);
}

.avatar-description {
    color: var(--light-gray);
    font-size: var(--fs-9);
    margin: 0 0 8px 0;
    line-height: 1.3;
    text-align: left;
}

.avatar-rarity {
    display: inline-block;
    padding: 0.45em 1.2em 0.45em 2.5em;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%, 0 0%);
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    z-index: 10;
    border: none;
    border-radius: 0 0 0 8px;
    opacity: 0.98;
    overflow: visible;
    position: absolute;
    top: 0;
    right: 0;
    margin-bottom: 15px;
}

.avatar-rarity::before {
    content: "";
    position: absolute;
    left: -18px;
    top: 0;
    width: 22px;
    height: 100%;
    z-index: -1;
    clip-path: polygon(100% 0, 0 0, 0 100%, 100% 70%);
    background: inherit;
    border-radius: 8px 0 0 0;
}

.avatar-rarity.legendary,
.avatar-rarity.legendary::before { 
    background: linear-gradient(135deg, #FFD700, #FFA500); 
}

.avatar-rarity.epic,
.avatar-rarity.epic::before { 
    background: linear-gradient(135deg, #9B59B6, #7D3C98); 
}

.avatar-rarity.rare,
.avatar-rarity.rare::before { 
    background: linear-gradient(135deg, #3498DB, #2980B9); 
}

.avatar-rarity.uncommon,
.avatar-rarity.uncommon::before { 
    background: linear-gradient(135deg, #2ECC71, #27AE60); 
}

.avatar-rarity.common,
.avatar-rarity.common::before { 
    background: linear-gradient(135deg, #95A5A6, #7F8C8D); 
}

.avatar-requirement {
    font-size: var(--fs-9);
    color: var(--spring-green);
    margin-bottom: 8px;
    font-weight: var(--fw-500);
}

.avatar-status {
    font-size: var(--fs-9);
    padding: 4px 12px;
    border-radius: 15px;
    font-weight: var(--fw-500);
    display: inline-block;
    margin-bottom: 15px;
}

.avatar-status.active {
    background: rgba(0, 255, 127, 0.1);
    color: var(--spring-green);
    border: 1px solid var(--spring-green);
}

.avatar-status.used {
    background: rgba(255, 255, 255, 0.1);
    color: var(--light-gray);
    border: 1px solid var(--light-gray);
}

.avatar-status.expired {
    background: rgba(255, 0, 0, 0.1);
    color: #FF6B6B;
    border: 1px solid #FF6B6B;
}

.avatar-status.revoked {
    background: rgba(255, 0, 0, 0.1);
    color: #FF6B6B;
    border: 1px solid #FF6B6B;
}

.avatar-actions-row {
    display: flex;
    flex-direction: row;
    gap: 8px;
    width: 100%;
}

.avatar-actions-row .btn {
    flex: 1;
}

.avatar-actions-row .btn:last-child {
    padding: 0.5em 0.5em;
}

/* Avatar Popup Modal - Clean Design */
.avatar-popup {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.avatar-popup-content {
    background: var(--raisin-black-2);
    border: 1px solid var(--raisin-black-3);
    border-radius: 12px;
    padding: 30px;
    max-width: 500px;
    width: 100%;
    position: relative;
    text-align: center;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

.avatar-popup-close {
    position: absolute;
    top: 15px;
    right: 20px;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    color: var(--light-gray);
    transition: color var(--transition-1);
}

.avatar-popup-close:hover {
    color: var(--white);
}

.avatar-info {
    margin-bottom: 25px;
}

.avatar-info p {
    margin: 10px 0;
    font-size: var(--fs-5);
    color: var(--white);
}

.avatar-popup-content h3 {
    color: var(--white) !important;
    margin-bottom: 20px;
    font-size: 1.5rem;
    text-align: center;
}

.avatar-url-section {
    margin-bottom: 25px;
}

.avatar-url-section p {
    margin-bottom: 15px;
    color: var(--light-gray);
    font-size: var(--fs-9);
}

.url-container {
    display: flex;
    gap: 10px;
    margin-bottom: 20px;
}

.url-container input {
    flex: 1;
    padding: 12px;
    background: var(--raisin-black-3);
    border: 1px solid var(--raisin-black-3);
    border-radius: 8px;
    color: var(--white);
    font-size: var(--fs-9);
}

.url-container input:focus {
    outline: none;
    border-color: var(--spring-green);
}

.avatar-warning {
    background: rgba(255, 193, 7, 0.1);
    border: 1px solid rgba(255, 193, 7, 0.3);
    border-radius: 8px;
    padding: 15px;
    margin-top: 20px;
}

.avatar-warning p {
    margin: 0;
    font-size: var(--fs-9);
    color: #FFC107;
}

/* Responsive Design - Matching existing patterns */
@media (max-width: 768px) {
    .avatars-grid {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 0 15px;
    }
    
    .avatar-card {
        padding: 10px 15px;
    }
    
    .avatar-popup-content {
        padding: 20px;
        margin: 10px;
    }
    
    .url-container {
        flex-direction: column;
    }
}

@media (max-width: 1200px) {
    .avatars-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 900px) {
    .avatars-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .avatars-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 1024px) {
    .avatar-card {
        padding: 10px;
    }
}

/* Duplicate counter under rarity tag */
.avatar-card .avatar-duplicate-counter {
    font-family: var(--ff-oswald);
    font-size: 0.9rem;
    color: var(--spring-green);
    background: rgba(0, 255, 127, 0.12);
    border: 1px solid var(--spring-green);
    border-radius: 100px;
    display: inline-block;
    padding: 2px 8px;
    letter-spacing: 0.5px;
}

